mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-07 14:29:33 +01:00
0321d79540
The example code had the `plugin` argument as the last argument. this disallows arguments that have a standard value. As far as I understand the dispatching code the order of arguments does not matter since it is the name `plugin` that is relevant. Therefor I changed the order so that newbe's don't have to read the entire code and can easily add optional arguments
39 lines
905 B
Python
Executable File
39 lines
905 B
Python
Executable File
#!/usr/bin/env python3
|
|
from lightning import Plugin
|
|
|
|
|
|
plugin = Plugin(autopatch=True)
|
|
|
|
|
|
@plugin.method("hello")
|
|
def hello(plugin, name="world"):
|
|
"""This is the documentation string for the hello-function.
|
|
|
|
It gets reported as the description when registering the function
|
|
as a method with `lightningd`.
|
|
|
|
"""
|
|
greeting = plugin.get_option('greeting')
|
|
s = '{} {}'.format(greeting, name)
|
|
plugin.log(s)
|
|
return s
|
|
|
|
|
|
@plugin.method("init")
|
|
def init(options, configuration, plugin):
|
|
plugin.log("Plugin helloworld.py initialized")
|
|
|
|
|
|
@plugin.subscribe("connect")
|
|
def on_connect(plugin, id, address):
|
|
plugin.log("Received connect event for peer {}".format(id))
|
|
|
|
|
|
@plugin.subscribe("disconnect")
|
|
def on_disconnect(plugin, id):
|
|
plugin.log("Received disconnect event for peer {}".format(id))
|
|
|
|
|
|
plugin.add_option('greeting', 'Hello', 'The greeting I should use.')
|
|
plugin.run()
|