refactoring (in progress, tbf)
[src/app-framework-binder.git] / include / local-def.h
index 8fe87d0..3f61871 100644 (file)
@@ -1,5 +1,5 @@
 /*
-   alsajson-gw -- provide a REST/HTTP interface to ALSA-Mixer
+   local-def.h -- provide a REST/HTTP interface
 
    Copyright (C) 2015, Fulup Ar Foll
 
@@ -18,6 +18,8 @@
    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
 */
+#ifndef LOCAL_DEF_H
+#define LOCAL_DEF_H
 
 #ifndef _GNU_SOURCE
   #define _GNU_SOURCE
 #include <magic.h>
 #include <setjmp.h>
 #include <signal.h>
+#include <uuid/uuid.h>
 
 
 
-#define AJQ_VERSION "0.1"
-
 /* other definitions --------------------------------------------------- */
 
 // Note: because of a bug in libmagic MAGIC_DB NULL should not be used for default
-#define MAGIC_DB "/usr/share/misc/magic.mgc"
 #define OPA_INDEX "index.html"
-#define MAX_ALIAS 10  // max number of aliases
+#define MAX_ALIAS 10           // max number of aliases
+#define COOKIE_NAME   "afb-session"
+
+#define DEFLT_CNTX_TIMEOUT  3600   // default Client Connection Timeout
+#define DEFLT_API_TIMEOUT   0      // default Plugin API Timeout [0=NoLimit for Debug Only]
+#define DEFLT_API_TIMEOUT   0      // default Plugin API Timeout
+#define DEFLT_CACHE_TIMEOUT 100000 // default Static File Chache [Client Side Cache 100000~=1day]
+#define DEFLT_AUTH_TOKEN    NULL   // expect for debug should == NULL
+#define DEFLT_HTTP_TIMEOUT  15     // Max MibMicroHttp timeout
+#define AFB_MAX_PLUGINS     20     // Max number of plugins for a given binder
 
-typedef int BOOL;
 #ifndef FALSE
   #define FALSE 0
 #endif
@@ -63,32 +71,120 @@ typedef int BOOL;
 #define STATIC    static
 #define FAILED    -1
 
-// prebuild json error are constructed in config.c
-typedef enum  { AFB_FALSE, AFB_TRUE, AFB_FATAL, AFB_FAIL, AFB_WARNING, AFB_EMPTY, AFB_SUCCESS} AFB_error;
+#define AUDIO_BUFFER "/tmp/buf"
 
-extern char *ERROR_LABEL[];
-#define ERROR_LABEL_DEF {"false", "true","fatal", "fail", "warning", "empty", "success"}
+extern int verbose;  // this is the only global variable
+
+// prebuild json error are constructed in helper-api.c
+typedef enum  { AFB_FALSE, AFB_TRUE, AFB_FATAL, AFB_FAIL, AFB_WARNING, AFB_EMPTY, AFB_SUCCESS, AFB_DONE, AFB_UNAUTH} AFB_error;
 
-#define BANNER "<html><head><title>Application Framework Binder</title></head><body>Application Framework </body></html>"
-#define JSON_CONTENT  "application/json"
 #define MAX_POST_SIZE  4096   // maximum size for POST data
+#define CTX_NBCLIENTS   10   // allow a default of 10 authenticated clients
+
+
+
+
+
+
+
+
+// Plugin Type
+enum  AFB_pluginE
+{
+       AFB_PLUGIN_JSON = 123456789,
+       AFB_PLUGIN_JSCRIPT = 987654321,
+       AFB_PLUGIN_RAW = 987123546
+};
+
+// Enum for Session/Token/Authentication middleware
+enum AFB_sessionE
+{
+       AFB_SESSION_NONE,
+       AFB_SESSION_CREATE,
+       AFB_SESSION_CLOSE,
+       AFB_SESSION_RENEW,
+       AFB_SESSION_CHECK
+};
+
+// API definition
+struct AFB_restapi
+{
+       const char *name;
+       enum AFB_sessionE session;
+       json_object* (*callback)();
+       const char *info;
+};
+
+// Plugin definition
+struct AFB_plugin
+{
+       enum AFB_pluginE type;  
+       const char *info;
+       const char *prefix;
+       const struct AFB_restapi *apis;
+       void (*freeCtxCB)(void*);  // callback to free application context [null for standard free]
+};
+
+typedef enum AFB_pluginE AFB_pluginE;
+typedef enum AFB_sessionE AFB_sessionE;
+typedef json_object* (*AFB_apiCB)();
+typedef void (*AFB_freeCtxCB)(void*);
+typedef struct AFB_restapi AFB_restapi;
+typedef struct AFB_plugin AFB_plugin;
+
+
+
+
+
+
+
+
+
+
+
 
-// use to check anonymous data when using dynamic loadable lib
-typedef enum  {AFB_PLUGIN=1234, AFB_REQUEST=5678} AFB_type;
 
-// Error code are requested through function to manage json usage count
-typedef struct {
-  int   level;
-  char* label;
-  json_object *json;
-} AFB_errorT;
 
+typedef enum  {AFB_POST_NONE=0, AFB_POST_JSON, AFB_POST_FORM, AFB_POST_EMPTY} AFB_PostType;
+typedef enum  {AFB_MODE_LOCAL=0, AFB_MODE_REMOTE, AFB_MODE_GLOBAL} AFB_Mode;
+
+
+
+// Post Upload File Handle
+typedef struct {
+   int   fd; 
+   char *path; 
+   int  errcode;
+   json_object* jresp;
+} AFB_PostCtx;
+
+typedef  struct {
+    int  len;   // post element size
+    char *data; // post data in raw format
+    AFB_PostType type; // Json type
+} AFB_PostRequest;
+  
 // Post handler
 typedef struct {
-  char* data;
-  int   len;
-  int   uid;
-} AFB_HttpPost;
+  void*  ctx;               // Application context
+  int    len;               // current len for post
+  int    uid;               // post uid for debug
+  AFB_PostType type;        // JSON or FORM
+  AFB_apiCB  completeCB;    // callback when post is completed
+  char   *privatebuf;       // use internally to keep track or partial buffer
+  struct MHD_PostProcessor *pp; // iterator handle
+} AFB_PostHandle;
+
+typedef struct {
+    enum MHD_ValueKind kind; // kind type of the value
+    const char *key;         // key 0-terminated key for the value
+    const char *filename;    // filename of the uploaded file, NULL if not known
+    const char *mimetype;    // content_type mime-type of the data, NULL if not known
+    const char *encoding;    // transfer_encoding encoding of the data, NULL if not known
+    const char *data;        // data pointer to size bytes of data at the specified offset
+    uint64_t   offset;       // offset of data in the overall value
+    size_t     len;          // number of bytes in data available
+} AFB_PostItem;
 
 typedef struct {
   char  path[512];
@@ -101,88 +197,66 @@ typedef struct {
   size_t len;
 } AFB_aliasdir;
 
-
-// some usefull static object initialized when entering listen loop.
-extern int verbose;
-// MHD_lookup_connection_value(connection, MHD_GET_ARGUMENT_KIND, "value");
-typedef struct {
-  const char *url;
-  char *plugin;
-  char *api;
-  char *post;
-  struct MHD_Connection *connection;
-  sigjmp_buf checkPluginCall; // context save for timeout set/longjmp
-} AFB_request;
-
 typedef struct {
      char    *msg;
      size_t  len;
 } AFB_redirect_msg;
 
 // main config structure
-typedef struct {
-  char *logname;           // logfile path for info & error log
+struct AFB_config
+{
   char *console;           // console device name (can be a file or a tty)
-  int  localhostOnly;
   int   httpdPort;
-  char *smack;             // smack label
-  char *plugins;           // list of requested plugins
+  char *ldpaths;           // list of plugins directories
   char *rootdir;           // base dir for httpd file download
   char *rootbase;          // Angular HTML5 base URL
   char *rootapi;           // Base URL for REST APIs
-  char *pidfile;           // where to store pid when running background
   char *sessiondir;        // where to store mixer session files
-  char *configfile;        // where to store configuration on gateway exit
-  uid_t setuid;
+  char *token;             // initial authentication token [default NULL no session]
   int  cacheTimeout;
   int  apiTimeout;
+  int  cntxTimeout;        // Client Session Context timeout
+  AFB_Mode mode;           // mode of listening
   AFB_aliasdir *aliasdir;  // alias mapping for icons,apps,...
-} AFB_config;
-
-// Command line structure hold cli --command + help text
-typedef struct {
-  int  val;        // command number within application
-  int  has_arg;    // command number within application
-  char *name;      // command as used in --xxxx cli
-  char *help;      // help text
-} AFB_options;
-
-typedef json_object* (*AFB_apiCB)();
+};
 
-// API definition
+// MHD_lookup_connection_value(connection, MHD_GET_ARGUMENT_KIND, "value");
 typedef struct {
-  char *name;
-  AFB_apiCB callback;
-  char *info;
-  void * handle;
-} AFB_restapi;
+  const char *uuid;
+  const char *url;
+  const char *prefix;              // plugin convivial name
+  const char *method;
+/*
+  AFB_PostRequest *post;
+*/
+  json_object *jresp;
+  void *context;             // Hold Client Context when using session
+  int  restfull;             // request is resfull [uuid token provided]
+  int  errcode;              // http error code
+  struct AFB_config *config;         // plugin may need access to config
+  struct afb_req *areq;
+} AFB_request;
 
-// Plugin definition
-typedef struct {
-  AFB_type type;  
-  char *info;
-  char *prefix;
-  size_t prefixlen;
-  json_object *jtype;
-  AFB_restapi *apis;
-} AFB_plugin;
+struct afb_hsrv_handler;
+struct MHD_Daemon;
 
-typedef struct {
-  AFB_config  *config;   // pointer to current config
+struct AFB_session {
+  struct AFB_config  *config;   // pointer to current config
   // List of commands to execute
-  int  killPrevious;
   int  background;        // run in backround mode
   int  foreground;        // run in forground mode
-  int  checkAlsa;         // Display active Alsa Board
-  int  configsave;        // Save config on disk on start
   char *cacheTimeout;     // http require timeout to be a string
-  void *httpd;            // anonymous structure for httpd handler
+  struct MHD_Daemon *httpd;            // structure for httpd handler
   int  fakemod;           // respond to GET/POST request without interacting with sndboard
-  int  forceexit;         // when autoconfig from script force exit before starting server
-  AFB_plugin **plugins;   // pointer to REST/API plugins 
+  int  readyfd;           // a #fd to signal when ready to serve
   magic_t  magic;         // Mime type file magic lib
-  sigjmp_buf restartCkpt; // context save for restart set/longjmp
-} AFB_session;
+  struct afb_hsrv_handler *handlers;
+};
+
 
+typedef struct AFB_config AFB_config;
+typedef struct AFB_session AFB_session;
 
 #include "proto-def.h"
+
+#endif /* LOCAL_DEF_H */