home *** CD-ROM | disk | FTP | other *** search
/ PC World 2000 April / PCWorld_2000-04_cd.bin / Komunik / Servery / sambar / _setup.1 / sambar.h < prev    next >
C/C++ Source or Header  |  2000-01-15  |  21KB  |  801 lines

  1. /*
  2. ** SAMBAR.H
  3. **
  4. **      This is the public WIN32 header file for the Sambar 
  5. **        Server application.
  6. **
  7. **        Confidential Property of Tod Sambar
  8. **        (c) Copyright Tod Sambar 1996-1997
  9. **        All rights reserved.
  10. **
  11. **
  12. ** History:
  13. ** Chg#    Date    Description                                                Resp
  14. ** ----    -------    -------------------------------------------------------    ----
  15. **        10AUG96    Created                                                    sambar
  16. **        11APR97    Added server start/stop APIs                            sambar
  17. */
  18.  
  19. #if     !defined(__SAMBAR_H__)
  20. #define __SAMBAR_H__
  21.  
  22. /*
  23. ** Types
  24. */
  25. typedef int                            SA_RETCODE;
  26. typedef long                        SA_INT;
  27. typedef int                            SA_BOOL;
  28. typedef void                        SA_VOID;
  29. typedef unsigned char                SA_BYTE;
  30. typedef unsigned char                SA_CHAR;
  31.  
  32. #ifndef TEXT
  33. #define TEXT(x)                        (x)
  34. #endif
  35.  
  36. #ifndef MAX
  37. #define MAX(a,b)                    ((SA_INT)(a) > (SA_INT)(b) ? (a) : (b))
  38. #endif
  39.  
  40. #ifndef MIN
  41. #define MIN(a,b)                    ((SA_INT)(a) < (SA_INT)(b) ? (a) : (b))
  42. #endif
  43.  
  44. /*
  45. ** Public Structures
  46. */
  47. #define SA_CTX                        SA_VOID
  48. #define SA_CONN                        SA_VOID
  49. #define SA_PARAMS                    SA_VOID
  50. #define SA_REC                        SA_VOID
  51.  
  52.  
  53. /*
  54. ** Return Codes
  55. */
  56. #define SA_SUCCEED                    1
  57. #define SA_FAIL                        0
  58.  
  59.  
  60. /*
  61. ** Error Codes
  62. */
  63. #define SA_E_DOCFOLLOWS                (SA_INT)-1
  64. #define SA_E_INTERNALSYSTEM            (SA_INT)0
  65. #define SA_E_ALREADYLOGGEDIN        (SA_INT)1
  66. #define SA_E_BADCOOKIE                (SA_INT)2
  67. #define SA_E_INVALIDLOGIN            (SA_INT)3
  68. #define SA_E_MAXLOGINS                (SA_INT)4
  69. #define SA_E_ALREADYDEFINED            (SA_INT)5
  70. #define SA_E_INVALIDDATA            (SA_INT)6
  71. #define SA_E_NOTIMPLEMENTED            (SA_INT)7
  72. #define SA_E_FORBIDDEN                (SA_INT)8
  73. #define SA_E_NOTFOUND                (SA_INT)9
  74. #define SA_E_DUPLICATE                (SA_INT)10
  75. #define SA_E_DBOPFAILED                (SA_INT)11
  76. #define SA_E_BADGATEWAY                (SA_INT)12
  77. #define SA_E_REDIRECT                (SA_INT)13
  78. #define SA_E_USRDEF1                (SA_INT)14
  79. #define SA_E_USRDEF2                (SA_INT)15
  80. #define SA_E_USRDEF3                (SA_INT)16
  81. #define SA_E_USRDEF4                (SA_INT)17
  82. #define SA_E_USRDEF5                (SA_INT)18
  83. #define SA_E_USRDEF6                (SA_INT)19
  84. #define SA_E_USRDEF7                (SA_INT)20
  85. #define SA_E_USRDEF8                (SA_INT)21
  86. #define SA_E_USRDEF9                (SA_INT)22
  87. #define SA_E_USRDEF10                (SA_INT)23
  88. #define SA_E_USRDEF11                (SA_INT)24
  89. #define SA_E_USRDEF12                (SA_INT)25
  90. #define SA_E_USRDEF13                (SA_INT)26
  91. #define SA_E_USRDEF14                (SA_INT)27
  92. #define SA_E_USRDEF15                (SA_INT)28
  93. #define SA_E_USRDEF16                (SA_INT)29
  94. #define SA_E_USRDEF17                (SA_INT)30
  95. #define SA_E_USRDEF18                (SA_INT)31
  96. #define SA_E_USRDEF19                (SA_INT)32
  97. #define SA_E_USRDEF20                (SA_INT)33
  98. #define SA_E_TIMEOUT                (SA_INT)34
  99. #define SA_E_SHUTDOWN                (SA_INT)35
  100. #define SA_E_SERVERDOWN                (SA_INT)36
  101. #define SA_E_PAUSED                    (SA_INT)37
  102. #define SA_E_MAXCGIS                (SA_INT)38
  103. #define SA_E_INUSE                    (SA_INT)39
  104. #define SA_E_RESTART                (SA_INT)40
  105. #define SA_E_INTERRUPTED            (SA_INT)41
  106. #define SA_E_SSLONLY                (SA_INT)42
  107.  
  108.  
  109. /*
  110. ** Actions
  111. */
  112. #define    SA_GET                        (SA_INT)1
  113. #define    SA_SET                        (SA_INT)2
  114. #define    SA_CLEAR                    (SA_INT)3
  115.  
  116. /*
  117. ** Misc Defines
  118. */
  119. #define SA_NULLTERM                    (SA_INT)-3
  120.  
  121. /*
  122. ** Context Properties
  123. */
  124. #define SA_CTXPROP_SYSADMIN            (SA_INT)1
  125. #define SA_CTXPROP_HOMEDIR            (SA_INT)2
  126. #define SA_CTXPROP_LOGDIR            (SA_INT)3
  127. #define SA_CTXPROP_DBCACHE            (SA_INT)4
  128. #define SA_CTXPROP_APPLICDIR        (SA_INT)5
  129. #define SA_CTXPROP_SERVERSW            (SA_INT)7
  130. #define SA_CTXPROP_SERVERPORT        (SA_INT)8
  131. #define SA_CTXPROP_SERVERNAME        (SA_INT)9
  132. #define SA_CTXPROP_SERVERIP            (SA_INT)10
  133. #define SA_CTXPROP_BUILDID            (SA_INT)11
  134. #define SA_CTXPROP_HTTPLOGFUNC        (SA_INT)12
  135. #define SA_CTXPROP_SECURITYMODEL    (SA_INT)13
  136. #define SA_CTXPROP_LICENSETYPE        (SA_INT)14
  137.  
  138. /*
  139. ** Connection Properties
  140. */
  141. #define SA_CONNPROP_HOST            (SA_INT)1
  142. #define SA_CONNPROP_AGENT            (SA_INT)2
  143. #define SA_CONNPROP_REFERER            (SA_INT)3
  144. #define SA_CONNPROP_REQUEST            (SA_INT)4
  145. #define SA_CONNPROP_REQUESTMETHOD    (SA_INT)5
  146. #define SA_CONNPROP_USERNAME        (SA_INT)6
  147. #define SA_CONNPROP_NAME            (SA_INT)7
  148. #define SA_CONNPROP_PASSWORD        (SA_INT)8
  149. #define SA_CONNPROP_IPADDR            (SA_INT)9
  150. #define SA_CONNPROP_DOCSDIR            (SA_INT)10
  151. #define SA_CONNPROP_DOCSPATH        (SA_INT)11
  152.  
  153. /*
  154. ** Scheduler Time Arguments
  155. */
  156. #define SA_SCHEDULETIME_TIMEOUT        (SA_INT)1        /* Every 2 minutes    */
  157. #define SA_SCHEDULETIME_HOURLY        (SA_INT)2        /* Every hour         */
  158. #define SA_SCHEDULETIME_DAILY        (SA_INT)3        /* Every day         */
  159. #define SA_SCHEDULETIME_WEEKLY        (SA_INT)4        /* Every week         */
  160. #define SA_SCHEDULETIME_MONTHLY        (SA_INT)5        /* Every month         */
  161.  
  162. /*
  163. ** Next Page Argument
  164. */
  165. #define SA_PAGE_ARG                    TEXT("RCpage")
  166. #define SA_REDIRECT_ARG                TEXT("RCredirect")
  167.  
  168. /*
  169. ** System Administrator Folder
  170. */
  171. #define SA_ADMIN_FOLDER                TEXT("sysadmin")
  172.  
  173. /*
  174. ** Default group
  175. */
  176. #define SA_DEFAULT_GROUP            TEXT("other")
  177.  
  178. /*
  179. ** RPC authorization types
  180. */
  181. #define SA_AUTHORIZATION_ALL        (SA_INT)0        /* All clients */
  182. #define SA_AUTHORIZATION_USER        (SA_INT)1        /* Logged in users only */
  183. #define SA_AUTHORIZATION_ADMIN        (SA_INT)2        /* Admin only */
  184.  
  185. /*
  186. ** RPC parameters
  187. */
  188. typedef struct sa__rpcparam
  189. {
  190.     SA_CHAR            *name;                /* Parameter name */
  191.     SA_BOOL            required;            /* Required or optional param */
  192.     SA_CHAR            *descr;                /* Parameter description */
  193. } SA_RPCPARAM;
  194.  
  195. typedef struct sa__arg
  196. {
  197.     SA_CHAR            *value;                /* Parameter value */
  198.     struct sa__arg    *next;
  199. } SA_ARG;
  200.  
  201. /*
  202. ** Scalar parameters
  203. */
  204. typedef struct sa__scalararg
  205. {
  206.     SA_CHAR            *name;                /* Argument name */
  207.     SA_CHAR            *descr;                /* Argument description */
  208. } SA_SCALARARG;
  209.  
  210. /*
  211. ** Request-handler modules
  212. */
  213. typedef struct sa__request
  214. {
  215.         SA_INT        method;                /* SA_METHOD_* */
  216.         SA_CHAR        *uri;                /* URI requested. */
  217.         SA_INT         urilen; 
  218.         SA_CHAR        *path;                /* path to requested URI. */
  219.         SA_INT         pathlen; 
  220.         SA_CHAR     *args;
  221.         SA_INT         argslen; 
  222.         SA_CHAR     *content;
  223.         SA_INT         contentlen;
  224.         SA_CHAR     *pathinfo;
  225.         SA_INT         pathinfolen;
  226. } SA_REQUEST;
  227.  
  228. #define SA_METHOD_GET                (SA_INT)1
  229. #define SA_METHOD_POST                (SA_INT)2
  230. #define SA_METHOD_PUT                (SA_INT)3
  231. #define SA_METHOD_HEAD                (SA_INT)4
  232. #define SA_METHOD_PATCH                (SA_INT)5
  233. #define SA_METHOD_PROPFIND            (SA_INT)6
  234. #define SA_METHOD_PROPPATCH            (SA_INT)7
  235. #define SA_METHOD_DELETE            (SA_INT)8
  236. #define SA_METHOD_CONNECT            (SA_INT)9
  237. #define SA_METHOD_COPY                (SA_INT)10
  238. #define SA_METHOD_MKCOL                (SA_INT)11
  239. #define SA_METHOD_MOVE                (SA_INT)12
  240. #define SA_METHOD_OPTIONS            (SA_INT)13
  241. #define SA_METHOD_TRACE                (SA_INT)14
  242. #define SA_METHOD_LOCK                (SA_INT)15
  243. #define SA_METHOD_UNLOCK            (SA_INT)16
  244. #define SA_METHOD_SEARCH            (SA_INT)17
  245. #define SA_METHOD_CHECKOUT            (SA_INT)18
  246. #define SA_METHOD_UNCHECKOUT        (SA_INT)19
  247. #define SA_METHOD_CHECKIN            (SA_INT)20
  248. #define SA_METHOD_MKRESOURCE        (SA_INT)21
  249. #define SA_METHOD_REPORT            (SA_INT)22
  250.  
  251. /*
  252. ** HTTP Log callback structure
  253. */
  254. typedef struct sa__httplog
  255. {
  256.         SA_INT         size; 
  257.         SA_INT         status; 
  258.         SA_CHAR        *method;
  259.         SA_CHAR     *timestamp;
  260.         SA_CHAR     *request;
  261.         SA_CHAR     *args;
  262.         SA_CHAR     *vhost;
  263.         SA_CHAR     *user;                /* User IP Address */
  264.         SA_CHAR        *username;
  265.         SA_CHAR        *referer;
  266.         SA_CHAR        *agent;
  267.  
  268.         /* Include system statistics.                                    */
  269.         SA_INT         allconns;             /* Total network connections    */
  270.         SA_INT         httpconns;             /* # of HTTP connections        */
  271.         SA_INT         threads;             /* Total threads                */
  272. } SA_HTTPLOG;
  273.  
  274. /*
  275. ** Password Management
  276. */
  277. #define SA_PASSWD_FILE                TEXT("passwd")
  278. #define SA_MAX_NAME                    (SA_INT)64
  279. #define SA_MAX_VALUE                (SA_INT)1000
  280.  
  281. typedef struct sa__ftp
  282. {
  283.     SA_INT        privs;                                    /* FTP access */
  284.     SA_INT        ftpmax;                                    /* Maximum FTP MB */
  285.     SA_INT        dirlen;
  286.     SA_CHAR        dir[SA_MAX_NAME + 1];                    /* FTP root dir */
  287. } SA_FTP;
  288.  
  289. typedef struct sa__sip
  290. {
  291.     SA_INT        unused;                                    /* SIP access */
  292. } SA_SIP;
  293.  
  294. typedef struct sa__passwd
  295. {
  296.     SA_INT        ftpprivs;                                /* FTP priviledges */
  297.     SA_INT        ftpmax;                                    /* FTP max upload */
  298.     SA_INT        dirlen;
  299.     SA_INT        namelen;
  300.     SA_INT        grouplen;
  301.     SA_INT        passwordlen;
  302.     SA_CHAR        name[SA_MAX_NAME + 1];                    /* Symbolic name */
  303.     SA_CHAR        group[SA_MAX_NAME + 1];
  304.     SA_CHAR        password[SA_MAX_NAME + 1];
  305.     SA_CHAR        dir[SA_MAX_NAME + 1];                    /* FTP dir */
  306.  
  307. } SA_PASSWD;
  308.  
  309. typedef struct sa__user
  310. {
  311.     SA_INT        grouplen;
  312.     SA_INT        usernamelen;
  313.     SA_CHAR        group[SA_MAX_NAME + 1];
  314.     SA_CHAR        username[SA_MAX_NAME + 1];
  315. } SA_USER;
  316.  
  317. typedef struct sa__group
  318. {
  319.     SA_INT        namelen;
  320.     SA_CHAR        name[SA_MAX_NAME + 1];
  321. } SA_GROUP;
  322.  
  323. /*
  324. ** FTP Priviledges
  325. */
  326. #define SA_PRIV_NOACCESS            (SA_INT)0
  327. #define SA_PRIV_READONLY            (SA_INT)1
  328. #define SA_PRIV_READWRITE            (SA_INT)2
  329.  
  330. /*
  331. ** Server Types
  332. */
  333. #define SA_SERVERTYPE_HTTP            (SA_INT)100
  334. #define SA_SERVERTYPE_HTTPPROXY        (SA_INT)101
  335. #define SA_SERVERTYPE_FTP            (SA_INT)102
  336. #define SA_SERVERTYPE_SMTPPROXY        (SA_INT)103
  337. #define SA_SERVERTYPE_POP3PROXY        (SA_INT)104
  338. #define SA_SERVERTYPE_IMAP4PROXY    (SA_INT)105
  339. #define SA_SERVERTYPE_BRIDGEPROXY    (SA_INT)106
  340. #define SA_SERVERTYPE_NNTPPROXY        (SA_INT)107
  341. #define SA_SERVERTYPE_FTPPROXY        (SA_INT)108
  342. #define SA_SERVERTYPE_SOCKSPROXY    (SA_INT)109
  343. #define SA_SERVERTYPE_TELNETPROXY    (SA_INT)110
  344. #define SA_SERVERTYPE_REALPROXY        (SA_INT)111
  345. #define SA_SERVERTYPE_SMTP            (SA_INT)112
  346. #define SA_SERVERTYPE_POP3            (SA_INT)113
  347. #define SA_SERVERTYPE_IMAP4            (SA_INT)114
  348. #define SA_SERVERTYPE_TELNET        (SA_INT)115
  349. #define SA_SERVERTYPE_DNS            (SA_INT)116
  350. #define SA_SERVERTYPE_SIP            (SA_INT)117
  351. #define SA_SERVERTYPE_DHCP            (SA_INT)118
  352.  
  353. /*
  354. ** Record Flags
  355. */ 
  356. #define SA_REC_CREATE                (SA_INT)0x0001
  357. #define SA_REC_DELETE                (SA_INT)0x0002
  358.  
  359.  
  360. /*
  361. ** Sambar Server callbacks
  362. */
  363. typedef SA_RETCODE                (* SA_INITFUNC)(SA_CTX *ctx);
  364. typedef SA_RETCODE                (* SA_EXITFUNC)(SA_CTX *ctx);
  365. typedef SA_RETCODE                (* SA_LOGINFUNC)(SA_CTX *ctx, SA_CONN *conn, 
  366.                                     SA_CHAR *username, SA_INT usernamelen, 
  367.                                     SA_CHAR *password, SA_INT passwordlen, 
  368.                                     SA_INT *infop);
  369. typedef SA_RETCODE                (* SA_LOGOUTFUNC)(SA_CTX *ctx, SA_CONN *conn);
  370. typedef SA_RETCODE                (* SA_PROFILEFUNC)(SA_CTX *ctx, SA_CONN *conn,
  371.                                     SA_CHAR *buffer, SA_INT buflen, 
  372.                                     SA_CHAR *data);
  373. typedef SA_RETCODE                (* SA_REQUESTFUNC)(SA_CTX *ctx, SA_CONN *conn,
  374.                                     SA_CHAR *uri, SA_INT urilen, 
  375.                                     SA_PARAMS *params, SA_INT *infop);
  376. typedef SA_RETCODE                (* SA_RPCFUNC)(SA_CTX *ctx, SA_CONN *conn,
  377.                                     SA_PARAMS *params, SA_INT *infop);
  378. typedef SA_RETCODE                (* SA_SCALARFUNC)(SA_CTX *ctx, SA_CONN *conn,
  379.                                     SA_ARG *args, SA_CHAR *value);
  380. typedef SA_RETCODE                (* SA_PROPFUNC)(SA_CTX *ctx, SA_VOID *argp, 
  381.                                     SA_CHAR *name, SA_CHAR *value);
  382. typedef SA_RETCODE                (* SA_FTPFUNC)(SA_CTX *ctx, SA_CHAR *name,
  383.                                     SA_INT namelen, SA_CHAR *password, 
  384.                                     SA_INT passwordlen, SA_FTP *ftpresp);
  385. typedef SA_RETCODE                (* SA_SIPFUNC)(SA_CTX *ctx, SA_CHAR *name,
  386.                                     SA_INT namelen, SA_CHAR *password, 
  387.                                     SA_INT passwordlen, SA_SIP *sipresp);
  388. typedef SA_RETCODE                (* SA_TELNETFUNC)(SA_CTX *ctx, SA_CHAR *name,
  389.                                     SA_INT namelen, SA_CHAR *password, 
  390.                                     SA_INT passwordlen);
  391. typedef SA_RETCODE                (* SA_MAILFUNC)(SA_CTX *ctx, SA_CHAR *name,
  392.                                     SA_INT namelen, SA_CHAR *password, 
  393.                                     SA_INT passwordlen);
  394. typedef SA_RETCODE                (* SA_NETCONNECTFUNC)(SA_CTX *ctx, 
  395.                                     SA_CHAR *ipaddr, SA_INT servertype);
  396. typedef SA_RETCODE                (* SA_HTTPPROXYFUNC)(SA_CTX *ctx, SA_CONN *conn,
  397.                                     SA_CHAR *host, SA_INT hostlen,
  398.                                     SA_CHAR *url, SA_INT urllen);
  399. typedef SA_RETCODE                (* SA_ENVTFUNC)(SA_CTX *ctx, SA_CONN *conn,
  400.                                     SA_CHAR *buffer, SA_INT buflen, 
  401.                                     SA_CHAR *data);
  402. typedef SA_RETCODE                (* SA_MODULEFUNC)(SA_CTX *ctx, SA_CONN *conn,
  403.                                     SA_REQUEST *request, SA_INT *infop);
  404. typedef SA_VOID                    (* SA_HTTPLOGFUNC)(SA_CTX *ctx, 
  405.                                     SA_HTTPLOG *httplog);
  406. typedef SA_RETCODE                (* SA_SCHEDULEFUNC)(SA_CTX *ctx, SA_CHAR *name,
  407.                                     SA_VOID *argp);
  408.  
  409.  
  410. /*
  411. ** Sambar Server Function Prototypes
  412. */
  413. #ifdef    WIN32
  414. #define SA_PUBLIC                __cdecl
  415. #define SA_EXPORT                __declspec(dllexport)
  416. #else    /* UNIX */
  417. #define SA_PUBLIC
  418. #define SA_EXPORT
  419. #endif
  420.  
  421. #if defined(__cplusplus)
  422. extern "C" {
  423. #endif    /* defined(__cplusplus) */
  424.  
  425. /*
  426. ** Sambar Server startup/shutdown
  427. */
  428. extern SA_RETCODE SA_EXPORT        sa_server(
  429.                                 SA_VOID            *hWnd
  430.                                 );
  431. extern SA_BOOL SA_EXPORT        sa_stopped(
  432.                                 void
  433.                                 );
  434. extern SA_RETCODE SA_EXPORT        sa_shutdown(
  435.                                 SA_BOOL            restart
  436.                                 );
  437. extern SA_RETCODE SA_EXPORT        sa_pause(
  438.                                 SA_BOOL            unpause
  439.                                 );
  440. /*
  441. ** General Functions
  442. */
  443.  
  444. extern SA_RETCODE SA_EXPORT        sa_cgi_exec(
  445.                                 SA_CTX            *ctx,
  446.                                 SA_CONN            *conn,
  447.                                 SA_REQUEST        *request
  448.                                 );
  449. extern SA_RETCODE SA_EXPORT        sa_wincgi_exec(
  450.                                 SA_CTX            *ctx,
  451.                                 SA_CONN            *conn,
  452.                                 SA_REQUEST        *request
  453.                                 );
  454. extern SA_RETCODE SA_EXPORT        sa_cmd_init(
  455.                                 SA_CTX            *ctx,
  456.                                 SA_CHAR            *name,
  457.                                 SA_RPCPARAM        *params,
  458.                                 SA_INT            numparams,
  459.                                 SA_INT            authorization,
  460.                                 SA_CHAR            *descr,
  461.                                 SA_RPCFUNC        funcp
  462.                                 );
  463. extern SA_RETCODE SA_EXPORT        sa_scalar_init(
  464.                                 SA_CTX            *ctx,
  465.                                 SA_CHAR            *name,
  466.                                 SA_SCALARARG    *args,
  467.                                 SA_INT            numargs,
  468.                                 SA_CHAR            *descr,
  469.                                 SA_SCALARFUNC    funcp
  470.                                 );
  471. extern SA_RETCODE SA_EXPORT        sa_props_load(
  472.                                 SA_CTX            *ctx,
  473.                                 SA_CHAR            *filename,
  474.                                 SA_CHAR            *section,
  475.                                 SA_VOID            *argp,
  476.                                 SA_PROPFUNC        funcp
  477.                                 );
  478. extern SA_RETCODE SA_EXPORT        sa_send_file(
  479.                                 SA_CONN            *conn,
  480.                                 SA_CHAR            *filename
  481.                                 );
  482. extern SA_RETCODE SA_EXPORT        sa_send_macro(
  483.                                 SA_CONN            *conn,
  484.                                 SA_CHAR            *macroname
  485.                                 );
  486. extern SA_RETCODE SA_EXPORT        sa_send_header(
  487.                                 SA_CONN            *conn,
  488.                                 SA_CHAR            *buffer,
  489.                                 SA_INT            buflen
  490.                                 );
  491. extern SA_RETCODE SA_EXPORT        sa_params(
  492.                                 SA_CTX            *ctx,
  493.                                 SA_CONN            *conn,
  494.                                 SA_PARAMS        **paramsp
  495.                                 );
  496. extern SA_RETCODE SA_EXPORT        sa_param(
  497.                                 SA_CTX            *ctx,
  498.                                 SA_PARAMS        *params,
  499.                                 SA_CHAR            *name,
  500.                                 SA_CHAR            **valuep,
  501.                                 SA_INT            *valuelenp
  502.                                 );
  503. extern SA_RETCODE SA_EXPORT        sa_param_set(
  504.                                 SA_CTX            *ctx,
  505.                                 SA_PARAMS        *params,
  506.                                 SA_CHAR            *name,
  507.                                 SA_CHAR            *value,
  508.                                 SA_INT            valuelen
  509.                                 );
  510. extern SA_VOID SA_EXPORT        sa_log(
  511.                                 SA_CTX            *ctx,
  512.                                 SA_CHAR            *buffer
  513.                                 );
  514. extern SA_VOID SA_EXPORT        sa_observe(
  515.                                 SA_CTX            *ctx,
  516.                                 SA_CHAR            *buffer
  517.                                 );
  518. extern SA_RETCODE SA_EXPORT        sa_get_macro(
  519.                                 SA_CTX            *ctx,
  520.                                 SA_CHAR            *macroname,
  521.                                 SA_CHAR            **macrop,
  522.                                 SA_INT            *macrolenp
  523.                                 );
  524. extern SA_RETCODE SA_EXPORT        sa_get_mime(
  525.                                 SA_CTX            *ctx,
  526.                                 SA_CHAR            *name,
  527.                                 SA_INT            namelen,
  528.                                 SA_CHAR            **mimetypep
  529.                                 );
  530. extern SA_RETCODE SA_EXPORT        sa_get_realpath(
  531.                                 SA_CTX            *ctx,
  532.                                 SA_CONN            *conn,
  533.                                 SA_CHAR            *name,
  534.                                 SA_INT            namelen,
  535.                                 SA_CHAR            *path,
  536.                                 SA_INT            maxpath
  537.                                 );
  538. extern SA_INT SA_EXPORT            sa_wildcmp(
  539.                                 SA_CTX            *ctx,
  540.                                 SA_CHAR            *wildstr,
  541.                                 SA_INT            wildstrlen,
  542.                                 SA_CHAR            *arg,
  543.                                 SA_INT            arglen
  544.                                 );
  545. extern SA_RETCODE SA_EXPORT        sa_schedule_task(
  546.                                 SA_CTX            *ctx,
  547.                                 SA_CHAR            *name,
  548.                                 SA_SCHEDULEFUNC    func,
  549.                                 SA_VOID            *argp,
  550.                                 SA_INT            when
  551.                                 );
  552.                                 
  553.  
  554. /*
  555. ** Mail Utility Functions
  556. */
  557. extern SA_RETCODE SA_EXPORT        sa_smtpmail(
  558.                                 SA_CTX            *ctx,
  559.                                 SA_CHAR            *from,
  560.                                 SA_CHAR            *tolist,
  561.                                 SA_CHAR            *cclist,
  562.                                 SA_CHAR            *bcclist,
  563.                                 SA_CHAR            *subject,
  564.                                 SA_CHAR            *message,
  565.                                 SA_CHAR            *attachment
  566.                                 );
  567. extern SA_RETCODE SA_EXPORT        sa_smtpmail2(
  568.                                 SA_CTX            *ctx,
  569.                                 SA_CHAR            *from,
  570.                                 SA_CHAR            *tolist,
  571.                                 SA_CHAR            *cclist,
  572.                                 SA_CHAR            *bcclist,
  573.                                 SA_CHAR            *subject,
  574.                                 SA_CHAR            *message,
  575.                                 SA_CHAR            *attachname,
  576.                                 SA_BYTE            *attachdata,
  577.                                 SA_INT            attachdatalen
  578.                                 );
  579.  
  580. extern SA_RETCODE SA_EXPORT        sa_mbox_create(
  581.                                 SA_CTX            *ctx,
  582.                                 SA_CHAR            *user
  583.                                 );
  584. extern SA_RETCODE SA_EXPORT        sa_mbox_delete(
  585.                                 SA_CTX            *ctx,
  586.                                 SA_CHAR            *user
  587.                                 );
  588. extern SA_BOOL SA_EXPORT        sa_mbox_exists(
  589.                                 SA_CTX            *ctx,
  590.                                 SA_CHAR            *user
  591.                                 );
  592.  
  593. /*
  594. ** Context Functions
  595. */
  596. extern SA_RETCODE SA_EXPORT        sa_ctx_global(
  597.                                 SA_CTX            **ctxp
  598.                                 );
  599. extern SA_RETCODE SA_EXPORT        sa_ctx_key(
  600.                                 SA_CTX            *ctx,
  601.                                 SA_INT            action,
  602.                                 SA_CHAR            *key,
  603.                                 SA_VOID            **valuep
  604.                                 );
  605. extern SA_RETCODE SA_EXPORT        sa_ctx_props(
  606.                                 SA_CTX            *ctx,
  607.                                 SA_INT            action,
  608.                                 SA_INT            property,
  609.                                 SA_BYTE            *buffer,
  610.                                 SA_INT            buflen,
  611.                                 SA_INT            *outlenp
  612.                                 );
  613. extern SA_RETCODE SA_EXPORT        sa_envt_prop(
  614.                                 SA_CTX            *ctx,
  615.                                 SA_CONN            *conn,
  616.                                 SA_BYTE            *prop,
  617.                                 SA_INT            proplen,
  618.                                 SA_CHAR            *buffer
  619.                                 );
  620.  
  621. /*
  622. ** Connection Functions
  623. */
  624. extern SA_RETCODE SA_EXPORT        sa_conn_key(
  625.                                 SA_CONN            *conn,
  626.                                 SA_INT            action,
  627.                                 SA_CHAR            *key,
  628.                                 SA_VOID            **valuep
  629.                                 );
  630. extern SA_RETCODE SA_EXPORT        sa_conn_props(
  631.                                 SA_CONN            *conn,
  632.                                 SA_INT            action,
  633.                                 SA_INT            property,
  634.                                 SA_BYTE            *buffer,
  635.                                 SA_INT            buflen,
  636.                                 SA_INT            *outlenp
  637.                                 );
  638. extern SA_RETCODE SA_EXPORT        sa_conn_send(
  639.                                 SA_CONN            *conn,
  640.                                 SA_CHAR            *buffer,
  641.                                 SA_INT            buflen
  642.                                 );
  643. extern SA_RETCODE SA_EXPORT        sa_conn_flush(
  644.                                 SA_CONN            *conn
  645.                                 );
  646. extern SA_RETCODE SA_EXPORT        sa_conn_redirect(
  647.                                 SA_CONN            *conn,
  648.                                 SA_CHAR            *location,
  649.                                 SA_CHAR            *buffer,
  650.                                 SA_INT            buflen
  651.                                 );
  652.  
  653. /*
  654. ** User/Password Management Routines
  655. */
  656. extern SA_RETCODE SA_EXPORT        sa_passwd_lookup(
  657.                                 SA_CTX            *ctx,
  658.                                 SA_CHAR            *username,
  659.                                 SA_INT            usernamelen,
  660.                                 SA_PASSWD        *passwd
  661.                                 );
  662. extern SA_RETCODE SA_EXPORT        sa_passwd_add(
  663.                                 SA_CTX            *ctx,
  664.                                 SA_CHAR            *username,
  665.                                 SA_INT            usernamelen,
  666.                                 SA_PASSWD        *passwd
  667.                                 );
  668. extern SA_RETCODE SA_EXPORT        sa_passwd_update(
  669.                                 SA_CTX            *ctx,
  670.                                 SA_CHAR            *username,
  671.                                 SA_INT            usernamelen,
  672.                                 SA_PASSWD        *passwd
  673.                                 );
  674. extern SA_RETCODE SA_EXPORT        sa_passwd_delete(
  675.                                 SA_CTX            *ctx,
  676.                                 SA_CHAR            *username,
  677.                                 SA_INT            usernamelen
  678.                                 );
  679. extern SA_RETCODE SA_EXPORT        sa_passwd_list(
  680.                                 SA_CTX            *ctx,
  681.                                 SA_USER            *users,
  682.                                 SA_INT            numusers,
  683.                                 SA_INT            *countp
  684.                                 );
  685.  
  686. /*
  687. ** Group Management Routines
  688. */
  689. extern SA_RETCODE SA_EXPORT        sa_group_add(
  690.                                 SA_CTX            *ctx,
  691.                                 SA_CHAR            *name,
  692.                                 SA_INT            namelen
  693.                                 );
  694. extern SA_RETCODE SA_EXPORT        sa_group_delete(
  695.                                 SA_CTX            *ctx,
  696.                                 SA_CHAR            *name,
  697.                                 SA_INT            namelen
  698.                                 );
  699. extern SA_RETCODE SA_EXPORT        sa_group_list(
  700.                                 SA_CTX            *ctx,
  701.                                 SA_GROUP        *groups,
  702.                                 SA_INT            numgroups,
  703.                                 SA_INT            *countp
  704.                                 );
  705.  
  706. /*
  707. ** Search Functions
  708. */
  709. extern SA_RETCODE SA_EXPORT        sa_search_add(
  710.                                 SA_CTX            *ctx,
  711.                                 SA_CHAR            *indexname,
  712.                                 SA_CHAR            *title,
  713.                                 SA_CHAR            *url,
  714.                                 SA_CHAR            *data,
  715.                                 SA_INT            datalen
  716.                                 );
  717.  
  718. /*
  719. ** RAS Functions
  720. */
  721. extern SA_RETCODE SA_EXPORT        sa_ras_disconnect(
  722.                                 SA_CTX            *ctx,
  723.                                 SA_BOOL            *activep
  724.                                 );
  725.  
  726. /*
  727. ** Record Functions
  728. */
  729. extern SA_RETCODE SA_EXPORT        sa_rec_init(
  730.                                 SA_CTX            *ctx,
  731.                                 SA_CHAR            *filename,
  732.                                 SA_INT            flags,
  733.                                 SA_INT            reclen,
  734.                                 SA_REC            **recp
  735.                                 );
  736. extern SA_RETCODE SA_EXPORT        sa_rec_exit(
  737.                                 SA_REC            *rec,
  738.                                 SA_INT            flags
  739.                                 );
  740. extern SA_RETCODE SA_EXPORT        sa_rec_insert(
  741.                                 SA_REC            *rec,
  742.                                 SA_BYTE            *data,
  743.                                 SA_INT            *idp
  744.                                 );
  745. extern SA_RETCODE SA_EXPORT        sa_rec_update(
  746.                                 SA_REC            *rec,
  747.                                 SA_INT            id,
  748.                                 SA_BYTE            *data
  749.                                 );
  750. extern SA_RETCODE SA_EXPORT        sa_rec_delete(
  751.                                 SA_REC            *rec,
  752.                                 SA_INT            id
  753.                                 );
  754. extern SA_RETCODE SA_EXPORT        sa_rec_fetch(
  755.                                 SA_REC            *rec,
  756.                                 SA_INT            id,
  757.                                 SA_BYTE            *data
  758.                                 );
  759. extern SA_RETCODE SA_EXPORT        sa_rec_next(
  760.                                 SA_REC            *rec,
  761.                                 SA_INT            lastid,
  762.                                 SA_BYTE            *data,
  763.                                 SA_INT            *idp
  764.                                 );
  765.  
  766. /*
  767. ** General Utilities
  768. */
  769. extern SA_INT SA_EXPORT            sa_dirsize(
  770.                                 SA_CHAR            *dirpath
  771.                                 );
  772. extern SA_INT SA_EXPORT            sa_dirfiles(
  773.                                 SA_CHAR            *dirpath
  774.                                 );
  775. extern SA_RETCODE SA_EXPORT        sa_gzip(
  776.                                 SA_CHAR            *filename,
  777.                                 SA_CHAR            *ext
  778.                                 );
  779. extern SA_RETCODE SA_EXPORT        sa_gunzip(
  780.                                 SA_CHAR            *filename,
  781.                                 SA_CHAR            *ext
  782.                                 );
  783. extern SA_RETCODE SA_EXPORT        sa_compress(
  784.                                 SA_BYTE            *in,
  785.                                 SA_INT            inlen,
  786.                                 SA_BYTE            *out,
  787.                                 SA_INT            *outlenp
  788.                                 );
  789. extern SA_RETCODE SA_EXPORT        sa_uncompress(
  790.                                 SA_BYTE            *in,
  791.                                 SA_INT            inlen,
  792.                                 SA_BYTE            *out,
  793.                                 SA_INT            *outlenp
  794.                                 );
  795.  
  796. #if defined(__cplusplus)
  797. }
  798. #endif    /* defined(__cplusplus) */
  799.  
  800. #endif /* __SAMBAR_H__ */
  801.