aboutsummaryrefslogtreecommitdiffstats
path: root/include/asterisk
diff options
context:
space:
mode:
authoroej <oej@f38db490-d61c-443f-a65b-d21fe96a405b>2006-04-07 19:11:22 +0000
committeroej <oej@f38db490-d61c-443f-a65b-d21fe96a405b>2006-04-07 19:11:22 +0000
commit3c9910c57ea93ad5c743ee7d4384f74df5f462f1 (patch)
tree9fcb07813c761c6698388573346bd546999bfbe0 /include/asterisk
parentb104ac7d191ff501f7a5e095873a85ad0b36c290 (diff)
Issue #6899 - remove OSP support code from chan_sip.c and app_dial.c
- implement all functions through internal APIs in res_osp.c and app_osplookup.c (homesick) git-svn-id: http://svn.digium.com/svn/asterisk/trunk@18369 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'include/asterisk')
-rw-r--r--include/asterisk/astosp.h110
1 files changed, 94 insertions, 16 deletions
diff --git a/include/asterisk/astosp.h b/include/asterisk/astosp.h
index 9781ca639..b7ef46598 100644
--- a/include/asterisk/astosp.h
+++ b/include/asterisk/astosp.h
@@ -16,33 +16,111 @@
* at the top of the source tree.
*/
-/*! \file
+/*!
+ * \file
* \brief OSP support (Open Settlement Protocol)
*/
#ifndef _ASTERISK_OSP_H
#define _ASTERISK_OSP_H
-#include "asterisk/channel.h"
-#include <netinet/in.h>
#include <time.h>
+#include <netinet/in.h>
-struct ast_osp_result {
- int handle;
- int numresults;
- char tech[20];
- char dest[256];
- char token[4096];
-};
+#include "asterisk/channel.h"
-/* Note: Channel will be auto-serviced if specified. Returns -1 on hangup,
- 0 if nothing found, or 1 if something is found */
-int ast_osp_lookup(struct ast_channel *chan, char *provider, char *extension, char *callerid, struct ast_osp_result *result);
+#define OSP_DEF_PROVIDER ((char*)"default") /* Default provider context name */
+#define OSP_INVALID_HANDLE ((int)-1) /* Invalid OSP handle, provider, transaction etc. */
+#define OSP_DEF_TIMELIMIT ((unsigned int)0) /* Default duration limit, no limit */
-int ast_osp_next(struct ast_osp_result *result, int cause);
+#define OSP_INTSTR_SIZE ((unsigned int)16) /* Signed/unsigned int string buffer size */
+#define OSP_NORSTR_SIZE ((unsigned int)256) /* Normal string buffer size */
+#define OSP_TOKSTR_SIZE ((unsigned int)4096) /* Token string buffer size */
-int ast_osp_terminate(int handle, int cause, time_t start, time_t duration);
+#define OSP_APP_SUCCESS ((char*)"SUCCESS") /* Return status, success */
+#define OSP_APP_FAILED ((char*)"FAILED") /* Return status, failed */
+#define OSP_APP_ERROR ((char*)"ERROR") /* Return status, error */
-int ast_osp_validate(char *provider, char *token, int *handle, unsigned int *timeout, const char *callerid, struct in_addr addr, const char *extension);
+struct ast_osp_result {
+ int inhandle;
+ int outhandle;
+ unsigned int intimelimit;
+ unsigned int outtimelimit;
+ char tech[20];
+ char dest[OSP_NORSTR_SIZE];
+ char calling[OSP_NORSTR_SIZE];
+ char token[OSP_TOKSTR_SIZE];
+ int numresults;
+};
+
+/*!
+ * \brief OSP Increase Use Count function
+ */
+void ast_osp_adduse(void);
+/*!
+ * \brief OSP Decrease Use Count function
+ */
+void ast_osp_deluse(void);
+/*!
+ * \brief OSP Authentication function
+ * \param provider OSP provider context name
+ * \param transaction OSP transaction handle, output
+ * \param source Source of in_bound call
+ * \param calling Calling number
+ * \param called Called number
+ * \param token OSP token, may be empty
+ * \param timelimit Call duration limit, output
+ * \return 1 Authenricated, 0 Unauthenticated, -1 Error
+ */
+int ast_osp_auth(
+ const char* provider, /* OSP provider context name */
+ int* transaction, /* OSP transaction handle, output */
+ const char* source, /* Source of in_bound call */
+ const char* calling, /* Calling number */
+ const char* called, /* Called number */
+ const char* token, /* OSP token, may be empty */
+ unsigned int* timelimit /* Call duration limit, output */
+);
+/*!
+ * \brief OSP Lookup function
+ * \param provider OSP provider context name
+ * \param srcdev Source device of out_bound call
+ * \param calling Calling number
+ * \param called Called number
+ * \param result Lookup results
+ * \return 1 Found , 0 No route, -1 Error
+ */
+int ast_osp_lookup(
+ const char* provider, /* OSP provider conttext name */
+ const char* srcdev, /* Source device of out_bound call */
+ const char* calling, /* Calling number */
+ const char* called, /* Called number */
+ struct ast_osp_result* result /* OSP lookup results, in/output */
+);
+/*!
+ * \brief OSP Next function
+ * \param reason Last destination failure reason
+ * \param result Lookup results, in/output
+ * \return 1 Found , 0 No route, -1 Error
+ */
+int ast_osp_next(
+ int reason, /* Last destination failure reason */
+ struct ast_osp_result *result /* OSP lookup results, in/output */
+);
+/*!
+ * \brief OSP Finish function
+ * \param handle OSP in/out_bound transaction handle
+ * \param reason Last destination failure reason
+ * \param start Call start time
+ * \param duration Call duration
+ * \return 1 Success, 0 Failed, -1 Error
+ */
+int ast_osp_finish(
+ int handle, /* OSP in/out_bound transaction handle */
+ int reason, /* Last destination failure reason */
+ time_t start, /* Call start time */
+ time_t connect, /* Call connect time */
+ time_t end /* Call end time */
+);
#endif /* _ASTERISK_OSP_H */