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