Skip to content

Commit

Permalink
plugin: rescan restarts plugin on update
Browse files Browse the repository at this point in the history
This adds a `u32 checksum` field to the plugin struct that is used
to identify if a plugin is outdated and needs to be restarted on `rescan`.

Changelog-Added: Plugin: Restarts on `rescan` when binary was changed.
  • Loading branch information
m-schmoock committed Jun 17, 2021
1 parent 40544b7 commit d89b1dd
Show file tree
Hide file tree
Showing 2 changed files with 25 additions and 0 deletions.
24 changes: 24 additions & 0 deletions lightningd/plugin.c
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
#include <ccan/array_size/array_size.h>
#include <ccan/crc32c/crc32c.h>
#include <ccan/list/list.h>
#include <ccan/mem/mem.h>
#include <ccan/opt/opt.h>
Expand All @@ -15,6 +16,7 @@
#include <lightningd/plugin_control.h>
#include <lightningd/plugin_hook.h>
#include <signal.h>
#include <stdio.h>
#include <sys/stat.h>
#include <sys/types.h>

Expand Down Expand Up @@ -215,6 +217,21 @@ static void destroy_plugin(struct plugin *p)
}
}

static u32 plugin_checksum(const char* path)
{
FILE *fp;
char buf[1024];
size_t nread;
u32 checksum = 0;

fp = fopen(path, "r");
assert(fp);
while ((nread = fread(buf, 1, sizeof(buf), fp)) > 0)
checksum = crc32c(checksum, &buf, nread);
fclose(fp);
return checksum;
}

struct plugin *plugin_register(struct plugins *plugins, const char* path TAKES,
struct command *start_cmd, bool important,
const char *parambuf STEALS,
Expand All @@ -225,6 +242,12 @@ struct plugin *plugin_register(struct plugins *plugins, const char* path TAKES,
/* Don't register an already registered plugin */
list_for_each(&plugins->plugins, p_temp, list) {
if (streq(path, p_temp->cmd)) {
/* stop and restart plugin on different checksum */
if (p_temp->checksum != plugin_checksum(path)) {
plugin_kill(p_temp, LOG_INFORM,
"Plugin changed, needs restart.");
break;
}
if (taken(path))
tal_free(path);
/* If added as "important", upgrade to "important". */
Expand All @@ -239,6 +262,7 @@ struct plugin *plugin_register(struct plugins *plugins, const char* path TAKES,
p->cmd = tal_strdup(p, path);
p->shortname = path_basename(p, p->cmd);
p->start_cmd = start_cmd;
p->checksum = plugin_checksum(path);

p->plugin_state = UNCONFIGURED;
p->js_arr = tal_arr(p, struct json_stream *, 0);
Expand Down
1 change: 1 addition & 0 deletions lightningd/plugin.h
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,7 @@ struct plugin {

pid_t pid;
char *cmd;
u32 checksum;
struct io_conn *stdin_conn, *stdout_conn;
struct plugins *plugins;
const char **plugin_path;
Expand Down

0 comments on commit d89b1dd

Please sign in to comment.