mirror of
https://github.com/owntone/owntone-server.git
synced 2025-01-27 22:46:02 -05:00
Move xml stuff out of plugins
This commit is contained in:
parent
1b8244b7f3
commit
b10762b4d5
99
src/plugin.c
99
src/plugin.c
@ -68,18 +68,10 @@ 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 */
|
/* webserver helpers */
|
||||||
char *pi_ws_uri(WS_CONNINFO *pwsc);
|
char *pi_ws_uri(WS_CONNINFO *pwsc);
|
||||||
void pi_ws_close(WS_CONNINFO *pwsc);
|
void pi_ws_close(WS_CONNINFO *pwsc);
|
||||||
int pi_ws_returnerror(WS_CONNINFO *pwsc, int error, char *description);
|
int pi_ws_fd(WS_CONNINFO *pwsc);
|
||||||
char *pi_ws_getvar(WS_CONNINFO *pwsc, char *var);
|
|
||||||
|
|
||||||
/* misc helpers */
|
/* misc helpers */
|
||||||
char *pi_server_ver(void);
|
char *pi_server_ver(void);
|
||||||
@ -89,27 +81,22 @@ void pi_log(int, char *, ...);
|
|||||||
/* db helpers */
|
/* db helpers */
|
||||||
int pi_db_count(void);
|
int pi_db_count(void);
|
||||||
int pi_db_enum_start(char **pe, DBQUERYINFO *pinfo);
|
int pi_db_enum_start(char **pe, DBQUERYINFO *pinfo);
|
||||||
int pi_db_enum_fetch_row(char **pe, PACKED_MP3FILE *row, DBQUERYINFO *pinfo);
|
int pi_db_enum_fetch_row(char **pe, char ***row, DBQUERYINFO *pinfo);
|
||||||
int pi_db_enum_end(char **pe);
|
int pi_db_enum_end(char **pe);
|
||||||
void pi_stream(WS_CONNINFO *pwsc, DBQUERYINFO *pqi, char *id);
|
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_parse(PARSETREE tree, char *term);
|
||||||
int pi_sp_dispose(PARSETREE tree);
|
|
||||||
char *pi_sp_get_error(PARSETREE tree);
|
|
||||||
|
|
||||||
PLUGIN_INPUT_FN pi = {
|
PLUGIN_INPUT_FN pi = {
|
||||||
pi_xml_init,
|
|
||||||
pi_xml_push,
|
|
||||||
pi_xml_pop,
|
|
||||||
pi_xml_output,
|
|
||||||
pi_xml_deinit,
|
|
||||||
|
|
||||||
pi_ws_uri,
|
pi_ws_uri,
|
||||||
pi_ws_close,
|
pi_ws_close,
|
||||||
pi_ws_returnerror,
|
ws_returnerror,
|
||||||
pi_ws_getvar,
|
ws_getvar,
|
||||||
|
ws_writefd,
|
||||||
|
ws_addresponseheader,
|
||||||
|
ws_emitheaders,
|
||||||
|
pi_ws_fd,
|
||||||
|
ws_getrequestheader,
|
||||||
|
|
||||||
pi_server_ver,
|
pi_server_ver,
|
||||||
pi_server_name,
|
pi_server_name,
|
||||||
@ -121,10 +108,10 @@ PLUGIN_INPUT_FN pi = {
|
|||||||
pi_db_enum_end,
|
pi_db_enum_end,
|
||||||
pi_stream,
|
pi_stream,
|
||||||
|
|
||||||
pi_sp_init,
|
sp_init,
|
||||||
pi_sp_parse,
|
pi_sp_parse,
|
||||||
pi_sp_dispose,
|
sp_dispose,
|
||||||
pi_sp_get_error
|
sp_get_error
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -377,36 +364,6 @@ int plugin_auth_handle(WS_CONNINFO *pwsc, char *username, char *pw) {
|
|||||||
* interface to older plugins even if we get newer functions or apis
|
* interface to older plugins even if we get newer functions or apis
|
||||||
* upstream... it's a binary compatibility layer.
|
* upstream... it's a binary compatibility layer.
|
||||||
*/
|
*/
|
||||||
XMLSTRUCT *pi_xml_init(WS_CONNINFO *pwsc, int emit_header) {
|
|
||||||
return xml_init(pwsc, emit_header);
|
|
||||||
}
|
|
||||||
|
|
||||||
void pi_xml_push(XMLSTRUCT *pxml, char *term) {
|
|
||||||
xml_push(pxml, term);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
void pi_xml_pop(XMLSTRUCT *pxml) {
|
|
||||||
xml_pop(pxml);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* FIXME: 256? */
|
|
||||||
void pi_xml_output(XMLSTRUCT *pxml, char *section, char *fmt, ...) {
|
|
||||||
char buf[256];
|
|
||||||
va_list ap;
|
|
||||||
|
|
||||||
va_start(ap,fmt);
|
|
||||||
vsnprintf(buf,sizeof(buf),fmt,ap);
|
|
||||||
va_end(ap);
|
|
||||||
|
|
||||||
xml_output(pxml,section,"%s",buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
void pi_xml_deinit(XMLSTRUCT *pxml) {
|
|
||||||
xml_deinit(pxml);
|
|
||||||
}
|
|
||||||
|
|
||||||
char *pi_ws_uri(WS_CONNINFO *pwsc) {
|
char *pi_ws_uri(WS_CONNINFO *pwsc) {
|
||||||
return pwsc->uri;
|
return pwsc->uri;
|
||||||
}
|
}
|
||||||
@ -415,12 +372,8 @@ void pi_ws_close(WS_CONNINFO *pwsc) {
|
|||||||
pwsc->close=1;
|
pwsc->close=1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int pi_ws_returnerror(WS_CONNINFO *pwsc, int error, char *description) {
|
int pi_ws_fd(WS_CONNINFO *pwsc) {
|
||||||
return ws_returnerror(pwsc,error,description);
|
return pwsc->fd;
|
||||||
}
|
|
||||||
|
|
||||||
char *pi_ws_getvar(WS_CONNINFO *pwsc, char *var) {
|
|
||||||
return ws_getvar(pwsc,var);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void pi_log(int level, char *fmt, ...) {
|
void pi_log(int level, char *fmt, ...) {
|
||||||
@ -453,31 +406,19 @@ int pi_db_enum_start(char **pe, DBQUERYINFO *pinfo) {
|
|||||||
return db_enum_start(pe, pinfo);
|
return db_enum_start(pe, pinfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
int pi_db_enum_fetch_row(char **pe, PACKED_MP3FILE *row, DBQUERYINFO *pinfo) {
|
int pi_db_enum_fetch_row(char **pe, char ***row, DBQUERYINFO *pinfo) {
|
||||||
return db_enum_fetch_row(pe, row, pinfo);
|
return db_enum_fetch_row(pe, (PACKED_MP3FILE*)row, pinfo);
|
||||||
}
|
}
|
||||||
|
|
||||||
int pi_db_enum_end(char **pe) {
|
int pi_db_enum_end(char **pe) {
|
||||||
return db_enum_end(pe);
|
return db_enum_end(pe);
|
||||||
}
|
}
|
||||||
|
|
||||||
PARSETREE pi_sp_init(void) {
|
|
||||||
return sp_init();
|
|
||||||
}
|
|
||||||
|
|
||||||
int pi_sp_parse(PARSETREE tree, char *term) {
|
|
||||||
return sp_parse(tree,term,0);
|
|
||||||
}
|
|
||||||
|
|
||||||
int pi_sp_dispose(PARSETREE tree) {
|
|
||||||
return sp_dispose(tree);
|
|
||||||
}
|
|
||||||
|
|
||||||
char *pi_sp_get_error(PARSETREE tree) {
|
|
||||||
return sp_get_error(tree);
|
|
||||||
}
|
|
||||||
|
|
||||||
void pi_stream(WS_CONNINFO *pwsc, DBQUERYINFO *pqi, char *id) {
|
void pi_stream(WS_CONNINFO *pwsc, DBQUERYINFO *pqi, char *id) {
|
||||||
dispatch_stream_id(pwsc, pqi,id);
|
dispatch_stream_id(pwsc, pqi,id);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int pi_sp_parse(PARSETREE tree, char *term) {
|
||||||
|
return sp_parse(tree, term, 0);
|
||||||
|
}
|
||||||
|
12
src/plugin.h
12
src/plugin.h
@ -63,18 +63,16 @@ typedef struct tag_plugin_info {
|
|||||||
|
|
||||||
/* version 1 plugin imports */
|
/* version 1 plugin imports */
|
||||||
typedef struct tag_plugin_input_fn {
|
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 */
|
/* webserver helpers */
|
||||||
char* (*ws_uri)(WS_CONNINFO *);
|
char* (*ws_uri)(WS_CONNINFO *);
|
||||||
void (*ws_close)(WS_CONNINFO *);
|
void (*ws_close)(WS_CONNINFO *);
|
||||||
int (*ws_returnerror)(WS_CONNINFO *, int, char *);
|
int (*ws_returnerror)(WS_CONNINFO *, int, char *);
|
||||||
char* (*ws_getvar)(WS_CONNINFO *, char *);
|
char* (*ws_getvar)(WS_CONNINFO *, char *);
|
||||||
|
int (*ws_writefd)(WS_CONNINFO *, char *, ...);
|
||||||
|
int (*ws_addresponseheader)(WS_CONNINFO *, char *, char *, ...);
|
||||||
|
void (*ws_emitheaders)(WS_CONNINFO *);
|
||||||
|
int (*ws_fd)(WS_CONNINFO *);
|
||||||
|
char* (*ws_getrequestheader)(WS_CONNINFO *, char *);
|
||||||
|
|
||||||
/* misc helpers */
|
/* misc helpers */
|
||||||
char* (*server_ver)(void);
|
char* (*server_ver)(void);
|
||||||
|
@ -18,9 +18,6 @@ typedef void* PARSETREE;
|
|||||||
struct tag_ws_conninfo;
|
struct tag_ws_conninfo;
|
||||||
typedef struct tag_ws_conninfo 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);
|
||||||
int(*auth)(WS_CONNINFO *pwsc, char *username, char *pw);
|
int(*auth)(WS_CONNINFO *pwsc, char *username, char *pw);
|
||||||
@ -148,18 +145,16 @@ typedef struct tag_dbqueryinfo {
|
|||||||
} DBQUERYINFO;
|
} DBQUERYINFO;
|
||||||
|
|
||||||
typedef struct tag_plugin_input_fn {
|
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 */
|
/* webserver helpers */
|
||||||
char* (*ws_uri)(WS_CONNINFO *);
|
char* (*ws_uri)(WS_CONNINFO *);
|
||||||
void (*ws_close)(WS_CONNINFO *);
|
void (*ws_close)(WS_CONNINFO *);
|
||||||
int (*ws_returnerror)(WS_CONNINFO *, int, char *);
|
int (*ws_returnerror)(WS_CONNINFO *, int, char *);
|
||||||
char* (*ws_getvar)(WS_CONNINFO *, char *);
|
char* (*ws_getvar)(WS_CONNINFO *, char *);
|
||||||
|
int (*ws_writefd)(WS_CONNINFO *, char *, ...);
|
||||||
|
int (*ws_addresponseheader)(WS_CONNINFO *, char *, char *, ...);
|
||||||
|
void (*ws_emitheaders)(WS_CONNINFO *);
|
||||||
|
int (*ws_fd)(WS_CONNINFO *);
|
||||||
|
char* (*ws_getrequestheader)(WS_CONNINFO *, char *);
|
||||||
|
|
||||||
/* misc helpers */
|
/* misc helpers */
|
||||||
char* (*server_ver)(void);
|
char* (*server_ver)(void);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user