mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-15 16:53:18 -05:00
pass functions to plugins through struct, rather than relying on auto-exported functions from executable
This commit is contained in:
parent
c2c4bb1542
commit
e2fd480c78
64
src/plugin.c
64
src/plugin.c
@ -68,6 +68,65 @@ void _plugin_writelock(void);
|
|||||||
void _plugin_unlock(void);
|
void _plugin_unlock(void);
|
||||||
int _plugin_error(char **pe, int error, ...);
|
int _plugin_error(char **pe, int error, ...);
|
||||||
|
|
||||||
|
/* Helpers */
|
||||||
|
XMLSTRUCT *pi_xml_init(WS_CONNINFO *pwsc, int emit_header);
|
||||||
|
void pi_xml_push(XMLSTRUCT *pxml, char *term);
|
||||||
|
void pi_xml_pop(XMLSTRUCT *pxml);
|
||||||
|
void pi_xml_output(XMLSTRUCT *pxml, char *section, char *fmt, ...);
|
||||||
|
void pi_xml_deinit(XMLSTRUCT *pxml);
|
||||||
|
|
||||||
|
/* webserver helpers */
|
||||||
|
char *pi_ws_uri(WS_CONNINFO *pwsc);
|
||||||
|
void pi_ws_close(WS_CONNINFO *pwsc);
|
||||||
|
int pi_ws_returnerror(WS_CONNINFO *pwsc, int error, char *description);
|
||||||
|
char *pi_ws_getvar(WS_CONNINFO *pwsc, char *var);
|
||||||
|
|
||||||
|
/* misc helpers */
|
||||||
|
char *pi_server_ver(void);
|
||||||
|
int pi_server_name(char *, int *);
|
||||||
|
void pi_log(int, char *, ...);
|
||||||
|
|
||||||
|
/* db helpers */
|
||||||
|
int pi_db_count(void);
|
||||||
|
int pi_db_enum_start(char **pe, DBQUERYINFO *pinfo);
|
||||||
|
int pi_db_enum_fetch_row(char **pe, char ***row, DBQUERYINFO *pinfo);
|
||||||
|
int pi_db_enum_end(char **pe);
|
||||||
|
void pi_stream(WS_CONNINFO *pwsc, DBQUERYINFO *pqi, char *id);
|
||||||
|
|
||||||
|
/* smart parser helpers */
|
||||||
|
PARSETREE pi_sp_init(void);
|
||||||
|
int pi_sp_parse(PARSETREE tree, char *term);
|
||||||
|
int pi_sp_dispose(PARSETREE tree);
|
||||||
|
char *pi_sp_get_error(PARSETREE tree);
|
||||||
|
|
||||||
|
PLUGIN_INPUT_FN pi = {
|
||||||
|
pi_xml_init,
|
||||||
|
pi_xml_push,
|
||||||
|
pi_xml_pop,
|
||||||
|
pi_xml_output,
|
||||||
|
pi_xml_deinit,
|
||||||
|
|
||||||
|
pi_ws_uri,
|
||||||
|
pi_ws_close,
|
||||||
|
pi_ws_returnerror,
|
||||||
|
pi_ws_getvar,
|
||||||
|
|
||||||
|
pi_server_ver,
|
||||||
|
pi_server_name,
|
||||||
|
pi_log,
|
||||||
|
|
||||||
|
pi_db_count,
|
||||||
|
pi_db_enum_start,
|
||||||
|
pi_db_enum_fetch_row,
|
||||||
|
pi_db_enum_end,
|
||||||
|
pi_stream,
|
||||||
|
|
||||||
|
pi_sp_init,
|
||||||
|
pi_sp_parse,
|
||||||
|
pi_sp_dispose,
|
||||||
|
pi_sp_get_error
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* initialize stuff for plugins
|
* initialize stuff for plugins
|
||||||
*
|
*
|
||||||
@ -191,6 +250,7 @@ int plugin_load(char **pe, char *path) {
|
|||||||
ppi->functions = pinfo->handler_functions;
|
ppi->functions = pinfo->handler_functions;
|
||||||
|
|
||||||
DPRINTF(E_INF,L_PLUG,"Loaded plugin %s (%s)\n",path,ppi->versionstring);
|
DPRINTF(E_INF,L_PLUG,"Loaded plugin %s (%s)\n",path,ppi->versionstring);
|
||||||
|
pinfo->pi = (void*)π
|
||||||
|
|
||||||
_plugin_writelock();
|
_plugin_writelock();
|
||||||
if(!_plugin_initialized) {
|
if(!_plugin_initialized) {
|
||||||
@ -355,8 +415,8 @@ void pi_ws_close(WS_CONNINFO *pwsc) {
|
|||||||
pwsc->close=1;
|
pwsc->close=1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void pi_ws_returnerror(WS_CONNINFO *pwsc, int error, char *description) {
|
int pi_ws_returnerror(WS_CONNINFO *pwsc, int error, char *description) {
|
||||||
ws_returnerror(pwsc,error,description);
|
return ws_returnerror(pwsc,error,description);
|
||||||
}
|
}
|
||||||
|
|
||||||
char *pi_ws_getvar(WS_CONNINFO *pwsc, char *var) {
|
char *pi_ws_getvar(WS_CONNINFO *pwsc, char *var) {
|
||||||
|
33
src/plugin.h
33
src/plugin.h
@ -23,6 +23,7 @@
|
|||||||
#define _PLUGIN_H_
|
#define _PLUGIN_H_
|
||||||
|
|
||||||
#include "webserver.h"
|
#include "webserver.h"
|
||||||
|
#include "xml-rpc.h"
|
||||||
|
|
||||||
extern int plugin_init(void);
|
extern int plugin_init(void);
|
||||||
extern int plugin_load(char **pe, char *path);
|
extern int plugin_load(char **pe, char *path);
|
||||||
@ -57,7 +58,39 @@ typedef struct tag_plugin_info {
|
|||||||
char *server;
|
char *server;
|
||||||
char *url; /* for output plugins */
|
char *url; /* for output plugins */
|
||||||
void *handler_functions;
|
void *handler_functions;
|
||||||
|
void *pi; /* exported functions */
|
||||||
} PLUGIN_INFO;
|
} PLUGIN_INFO;
|
||||||
|
|
||||||
|
/* version 1 plugin imports */
|
||||||
|
typedef struct tag_plugin_input_fn {
|
||||||
|
/* xml helpers */
|
||||||
|
XMLSTRUCT* (*xml_init)(WS_CONNINFO *, int);
|
||||||
|
void (*xml_push)(XMLSTRUCT *, char *);
|
||||||
|
void (*xml_pop)(XMLSTRUCT *);
|
||||||
|
void (*xml_output)(XMLSTRUCT *, char *, char *, ...);
|
||||||
|
void (*xml_deinit)(XMLSTRUCT *);
|
||||||
|
|
||||||
|
/* webserver helpers */
|
||||||
|
char* (*ws_uri)(WS_CONNINFO *);
|
||||||
|
void (*ws_close)(WS_CONNINFO *);
|
||||||
|
int (*ws_returnerror)(WS_CONNINFO *, int, char *);
|
||||||
|
char* (*ws_getvar)(WS_CONNINFO *, char *);
|
||||||
|
|
||||||
|
/* misc helpers */
|
||||||
|
char* (*server_ver)(void);
|
||||||
|
int (*server_name)(char *, int *);
|
||||||
|
void (*log)(int, char *, ...);
|
||||||
|
|
||||||
|
int (*db_count)(void);
|
||||||
|
int (*db_enum_start)(char **, DBQUERYINFO *);
|
||||||
|
int (*db_enum_fetch_row)(char **, char ***, DBQUERYINFO *);
|
||||||
|
int (*db_enum_end)(char **);
|
||||||
|
void (*stream)(WS_CONNINFO *, DBQUERYINFO *, char *);
|
||||||
|
|
||||||
|
PARSETREE (*sp_init)(void);
|
||||||
|
int (*sp_parse)(PARSETREE tree, char *term);
|
||||||
|
int (*sp_dispose)(PARSETREE tree);
|
||||||
|
char* (*sp_get_error)(PARSETREE tree);
|
||||||
|
} PLUGIN_INPUT_FN;
|
||||||
|
|
||||||
#endif /* _PLUGIN_H_ */
|
#endif /* _PLUGIN_H_ */
|
||||||
|
@ -12,8 +12,14 @@
|
|||||||
|
|
||||||
#define PLUGIN_VERSION 1
|
#define PLUGIN_VERSION 1
|
||||||
|
|
||||||
struct tag_wsconninfo;
|
|
||||||
typedef struct tag_wsconninfo WS_CONNINFO;
|
typedef void* PARSETREE;
|
||||||
|
|
||||||
|
struct tag_ws_conninfo;
|
||||||
|
typedef struct tag_ws_conninfo WS_CONNINFO;
|
||||||
|
|
||||||
|
struct tag_xmlstruct;
|
||||||
|
typedef struct tag_xmlstruct XMLSTRUCT;
|
||||||
|
|
||||||
typedef struct tag_plugin_output_fn {
|
typedef struct tag_plugin_output_fn {
|
||||||
void (*handler)(WS_CONNINFO *pwsc);
|
void (*handler)(WS_CONNINFO *pwsc);
|
||||||
@ -25,31 +31,10 @@ typedef struct tag_plugin_info {
|
|||||||
char *server;
|
char *server;
|
||||||
char *url; /* regex of namespace to handle if OUTPUT type */
|
char *url; /* regex of namespace to handle if OUTPUT type */
|
||||||
void *handler_functions;
|
void *handler_functions;
|
||||||
|
void *input_functions;
|
||||||
} PLUGIN_INFO;
|
} PLUGIN_INFO;
|
||||||
|
|
||||||
/* these are the functions that must be exported by the plugin */
|
|
||||||
PLUGIN_INFO *plugin_info(void);
|
|
||||||
|
|
||||||
/* xml helpers for output plugins */
|
/* xml helpers for output plugins */
|
||||||
struct tag_xmlstruct;
|
|
||||||
typedef struct tag_xmlstruct XMLSTRUCT;
|
|
||||||
typedef void *PARSETREE;
|
|
||||||
|
|
||||||
extern XMLSTRUCT *pi_xml_init(WS_CONNINFO *pwsc, int emit_header);
|
|
||||||
extern void pi_xml_push(XMLSTRUCT *pxml, char *term);
|
|
||||||
extern void pi_xml_pop(XMLSTRUCT *pxml);
|
|
||||||
extern void pi_xml_output(XMLSTRUCT *pxml, char *section, char *fmt, ...);
|
|
||||||
extern void pi_xml_deinit(XMLSTRUCT *pxml);
|
|
||||||
|
|
||||||
/* webserver helpers for output plugins */
|
|
||||||
extern char *pi_ws_uri(WS_CONNINFO *pwsc);
|
|
||||||
extern void pi_ws_close(WS_CONNINFO *pwsc);
|
|
||||||
extern int pi_ws_returnerror(WS_CONNINFO *pwsc, int error, char *description);
|
|
||||||
extern char *pi_ws_getvar(WS_CONNINFO *pwsc, char *var);
|
|
||||||
|
|
||||||
/* misc helpers */
|
|
||||||
extern char *pi_server_ver(void);
|
|
||||||
extern int pi_server_name(char *, int *);
|
|
||||||
|
|
||||||
/* logging */
|
/* logging */
|
||||||
#define E_FATAL 0
|
#define E_FATAL 0
|
||||||
@ -57,10 +42,6 @@ extern int pi_server_name(char *, int *);
|
|||||||
#define E_INF 5
|
#define E_INF 5
|
||||||
#define E_DBG 9
|
#define E_DBG 9
|
||||||
|
|
||||||
void pi_log(int level, char *fmt, ...);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/* db stuff */
|
/* db stuff */
|
||||||
typedef enum {
|
typedef enum {
|
||||||
queryTypeItems,
|
queryTypeItems,
|
||||||
@ -165,19 +146,40 @@ typedef struct tag_dbqueryinfo {
|
|||||||
void *output_info;
|
void *output_info;
|
||||||
} DBQUERYINFO;
|
} DBQUERYINFO;
|
||||||
|
|
||||||
|
typedef struct tag_plugin_input_fn {
|
||||||
|
/* xml helpers */
|
||||||
|
XMLSTRUCT* (*xml_init)(WS_CONNINFO *, int);
|
||||||
|
void (*xml_push)(XMLSTRUCT *, char *);
|
||||||
|
void (*xml_pop)(XMLSTRUCT *);
|
||||||
|
void (*xml_output)(XMLSTRUCT *, char *, char *, ...);
|
||||||
|
void (*xml_deinit)(XMLSTRUCT *);
|
||||||
|
|
||||||
/* db helpers */
|
/* webserver helpers */
|
||||||
extern int pi_db_count(void);
|
char* (*ws_uri)(WS_CONNINFO *);
|
||||||
extern int pi_db_enum_start(char **pe, DBQUERYINFO *pinfo);
|
void (*ws_close)(WS_CONNINFO *);
|
||||||
extern int pi_db_enum_fetch_row(char **pe, char ***row, DBQUERYINFO *pinfo);
|
int (*ws_returnerror)(WS_CONNINFO *, int, char *);
|
||||||
extern int pi_db_enum_end(char **pe);
|
char* (*ws_getvar)(WS_CONNINFO *, char *);
|
||||||
extern void pi_stream(WS_CONNINFO *pwsc, DBQUERYINFO *pqi, char *id);
|
|
||||||
|
|
||||||
/* smart parser helpers */
|
/* misc helpers */
|
||||||
extern PARSETREE pi_sp_init(void);
|
char* (*server_ver)(void);
|
||||||
extern int pi_sp_parse(PARSETREE tree, char *term);
|
int (*server_name)(char *, int *);
|
||||||
extern int pi_sp_dispose(PARSETREE tree);
|
void (*log)(int, char *, ...);
|
||||||
extern char *pi_sp_get_error(PARSETREE tree);
|
|
||||||
|
int (*db_count)(void);
|
||||||
|
int (*db_enum_start)(char **, DBQUERYINFO *);
|
||||||
|
int (*db_enum_fetch_row)(char **, char ***, DBQUERYINFO *);
|
||||||
|
int (*db_enum_end)(char **);
|
||||||
|
void (*stream)(WS_CONNINFO *, DBQUERYINFO *, char *);
|
||||||
|
|
||||||
|
PARSETREE (*sp_init)(void);
|
||||||
|
int (*sp_parse)(PARSETREE tree, char *term);
|
||||||
|
int (*sp_dispose)(PARSETREE tree);
|
||||||
|
char* (*sp_get_error)(PARSETREE tree);
|
||||||
|
} PLUGIN_INPUT_FN;
|
||||||
|
|
||||||
|
|
||||||
|
/* these are the functions that must be exported by the plugin */
|
||||||
|
PLUGIN_INFO *plugin_info(void);
|
||||||
|
|
||||||
|
|
||||||
#endif /* _MTD_PLUGINS_H_ */
|
#endif /* _MTD_PLUGINS_H_ */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user