#!/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 json_init(request, options): """The main daemon is telling us the relevant cli options """ global greeting greeting = request['params']['options']['greeting'] 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 as e: 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 = ""