|
|
|
#!/usr/bin/env python3
|
|
|
|
"""Simple plugin to show how to build new plugins for c-lightning
|
|
|
|
|
|
|
|
It demonstrates how a plugin communicates with c-lightning, how it
|
|
|
|
registers command line arguments that should be passed through and how
|
|
|
|
it can register JSON-RPC commands. We communicate with the main daemon
|
|
|
|
through STDIN and STDOUT, reading and writing JSON-RPC requests.
|
|
|
|
|
|
|
|
"""
|
|
|
|
import json
|
|
|
|
import sys
|
|
|
|
|
|
|
|
|
|
|
|
greeting = "World"
|
|
|
|
|
|
|
|
|
|
|
|
def json_hello(request, name):
|
|
|
|
greeting = "Hello {}".format(name)
|
|
|
|
return greeting
|
|
|
|
|
|
|
|
|
|
|
|
def json_fail(request):
|
|
|
|
raise ValueError("This will fail")
|
|
|
|
|
|
|
|
|
|
|
|
def json_getmanifest(request):
|
|
|
|
global greeting
|
|
|
|
return {
|
|
|
|
"options": [
|
|
|
|
{"name": "greeting",
|
|
|
|
"type": "string",
|
|
|
|
"default": greeting,
|
|
|
|
"description": "What name should I call you?"},
|
|
|
|
],
|
|
|
|
"rpcmethods": [
|
|
|
|
{
|
|
|
|
"name": "hello",
|
|
|
|
"description": "Returns a personalized greeting for {name}",
|
|
|
|
},
|
|
|
|
{
|
|
|
|
"name": "fail",
|
|
|
|
"description": "Always returns a failure for testing",
|
|
|
|
},
|
|
|
|
]
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
def plugin_log(message, level="info"):
|
|
|
|
payload = {
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"method": "log",
|
|
|
|
"params": {
|
|
|
|
"level": level,
|
|
|
|
"message": message,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
json.dump(payload, fp=sys.stdout)
|
|
|
|
sys.stdout.write('\n\n')
|
|
|
|
sys.stdout.flush()
|
|
|
|
|
|
|
|
|
|
|
|
def json_init(request, options, configuration):
|
|
|
|
"""The main daemon is telling us the relevant cli options
|
|
|
|
"""
|
|
|
|
global greeting
|
|
|
|
greeting = request['params']['options']['greeting']
|
|
|
|
plugin_log("Plugin helloworld.py initialized with greeting \"{}\"".format(greeting), "debug")
|
|
|
|
|
|
|
|
return "ok"
|
|
|
|
|
|
|
|
|
|
|
|
methods = {
|
|
|
|
'hello': json_hello,
|
|
|
|
'fail': json_fail,
|
|
|
|
'getmanifest': json_getmanifest,
|
|
|
|
'init': json_init,
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
partial = ""
|
|
|
|
for l in sys.stdin:
|
|
|
|
try:
|
|
|
|
partial += l
|
|
|
|
request = json.loads(partial)
|
|
|
|
except Exception:
|
|
|
|
continue
|
|
|
|
|
|
|
|
result = None
|
|
|
|
method = methods[request['method']]
|
|
|
|
params = request['params']
|
|
|
|
try:
|
|
|
|
if isinstance(params, dict):
|
|
|
|
result = method(request, **params)
|
|
|
|
else:
|
|
|
|
result = method(request, *params)
|
|
|
|
result = {
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"result": result,
|
|
|
|
"id": request['id']
|
|
|
|
}
|
|
|
|
except Exception:
|
|
|
|
result = {
|
|
|
|
"jsonrpc": "2.0",
|
|
|
|
"error": "Error while processing {}".format(request['method']),
|
|
|
|
"id": request['id']
|
|
|
|
}
|
|
|
|
|
|
|
|
json.dump(result, fp=sys.stdout)
|
|
|
|
sys.stdout.write('\n')
|
|
|
|
sys.stdout.flush()
|
|
|
|
partial = ""
|