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