⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 smsc_http.c

📁 主要包括sms网关和wap网关实现说明和源码
💻 C
📖 第 1 页 / 共 4 页
字号:
    http_destroy_headers(reply_headers);}/*---------------------------------------------------------------- * Brunet - A german aggregator (mainly doing T-Mobil D1 connections) * *  o bruHTT v1.3L (for MO traffic)  *  o bruHTP v2.1 (date 22.04.2003) (for MT traffic) * * Stipe Tolj <stolj@wapme.de> * Tobias Weber <weber@wapme.de> *//* MT related function */static void brunet_send_sms(SMSCConn *conn, Msg *sms){    ConnData *conndata = conn->data;    Octstr *url, *tid, *xser;    List *headers;    char id[UUID_STR_LEN + 1];    int dcs;    /*      * Construct TransactionId.     * Beware that brunet needs an "clean" octstr representation,      * without the dashes in the string. So remove them.     */    uuid_unparse(sms->sms.id, id);    tid = octstr_create(id);    octstr_replace(tid, octstr_imm("-"), octstr_imm(""));    /* form the basic URL */    url = octstr_format("%S?MsIsdn=%E&Originator=%E",        conndata->send_url, sms->sms.receiver, sms->sms.sender);        /*      * We use &binfo=<foobar> from sendsms interface to encode     * additional paramters. If a mandatory value is not set,     * a default value is applied     */    if (octstr_len(sms->sms.binfo)) {        octstr_url_decode(sms->sms.binfo);        octstr_format_append(url, "&%S", sms->sms.binfo);    }    /* CustomerId */    if (octstr_search(url, octstr_create("CustomerId="), 0) == -1) {        octstr_format_append(url, "&CustomerId=%S", conndata->username);    }    /* TransactionId */    if (octstr_search(url, octstr_create("TransactionId="), 0) == -1) {        octstr_format_append(url, "&TransactionId=%S", tid);    }    /* SMSCount */    if (octstr_search(url, octstr_create("SMSCount="), 0) == -1) {        octstr_format_append(url, "&%s", "SMSCount=1");    }    /* ActionType */    if (octstr_search(url, octstr_create("ActionType="), 0) == -1) {        octstr_format_append(url, "&%s", "ActionType=A");    }    /* ServiceDeliveryType */    if (octstr_search(url, octstr_create("ServiceDeliveryType="), 0) == -1) {        octstr_format_append(url, "&%s", "ServiceDeliveryType=P");    }    /* if coding is not set and UDH exists, assume DC_8BIT     * else default to DC_7BIT */    if (sms->sms.coding == DC_UNDEF)        sms->sms.coding = octstr_len(sms->sms.udhdata) > 0 ? DC_8BIT : DC_7BIT;    if (sms->sms.coding == DC_8BIT)        octstr_format_append(url, "&MessageType=B&Text=%H", sms->sms.msgdata);    else        octstr_format_append(url, "&MessageType=S&Text=%E", sms->sms.msgdata);    dcs = fields_to_dcs(sms,        (sms->sms.alt_dcs != SMS_PARAM_UNDEFINED ? sms->sms.alt_dcs : 0));    /* XSer processing */        xser = octstr_create("");    /* XSer DCS values */    if (dcs != 0 && dcs != 4)        octstr_format_append(xser, "0201%02x", dcs & 0xff);    /* add UDH header */    if (octstr_len(sms->sms.udhdata)) {        octstr_format_append(xser, "01%02x%H", octstr_len(sms->sms.udhdata),                              sms->sms.udhdata);    }    if (octstr_len(xser) > 0)        octstr_format_append(url, "&XSer=%S", xser);    octstr_destroy(xser);    headers = http_create_empty_headers();    debug("smsc.http.brunet", 0, "HTTP[%s]: Sending request <%s>",          octstr_get_cstr(conn->id), octstr_get_cstr(url));    /*      * Brunet requires an SSL-enabled HTTP client call, this is handled     * transparently by the Kannel HTTP layer module.     */    http_start_request(conndata->http_ref, HTTP_METHOD_GET, url, headers,                        NULL, 0, sms, NULL);    octstr_destroy(url);    octstr_destroy(tid);    http_destroy_headers(headers);}/* * Parse a line in the format: <name=value name=value ...> * and return a Dict with the name as key and the value as value, * otherwise return NULL if a parsing error occures. */static Dict *brunet_parse_body(Octstr *body){    Dict *param = NULL;    List *words = NULL;    long len;    Octstr *word;    words = octstr_split_words(body);    if ((len = gwlist_len(words)) > 0) {        param = dict_create(4, NULL);        while ((word = gwlist_extract_first(words)) != NULL) {            List *l = octstr_split(word, octstr_imm("="));            Octstr *key = gwlist_extract_first(l);            Octstr *value = gwlist_extract_first(l);            if (octstr_len(key))                dict_put(param, key, value);            octstr_destroy(key);            octstr_destroy(word);            gwlist_destroy(l, (void(*)(void *)) octstr_destroy);        }    }    gwlist_destroy(words, (void(*)(void *)) octstr_destroy);    return param;}static void brunet_parse_reply(SMSCConn *conn, Msg *msg, int status,                               List *headers, Octstr *body){    if (status == HTTP_OK || status == HTTP_ACCEPTED) {        Dict *param;        Octstr *status;        if ((param = brunet_parse_body(body)) != NULL &&            (status = dict_get(param, octstr_imm("Status"))) != NULL &&            octstr_case_compare(status, octstr_imm("0")) == 0) {            Octstr *msg_id;            /* pass the MessageId for this MT to the logging facility */            if ((msg_id = dict_get(param, octstr_imm("MessageId"))) != NULL)                msg->sms.binfo = octstr_duplicate(msg_id);            bb_smscconn_sent(conn, msg, NULL);        } else {            error(0, "HTTP[%s]: Message was malformed. SMSC response `%s'.",                  octstr_get_cstr(conn->id), octstr_get_cstr(body));            bb_smscconn_send_failed(conn, msg,	                SMSCCONN_FAILED_MALFORMED, octstr_duplicate(body));        }        dict_destroy(param);    } else {        error(0, "HTTP[%s]: Message was rejected. SMSC reponse `%s'.",              octstr_get_cstr(conn->id), octstr_get_cstr(body));        bb_smscconn_send_failed(conn, msg,	            SMSCCONN_FAILED_REJECTED, octstr_duplicate(body));    }}/* MO related function */static void brunet_receive_sms(SMSCConn *conn, HTTPClient *client,                               List *headers, Octstr *body, List *cgivars){    ConnData *conndata = conn->data;    Octstr *user, *from, *to, *text, *udh, *date, *type;    Octstr *retmsg;    int	mclass, mwi, coding, validity, deferred;    List *reply_headers;    int ret;    mclass = mwi = coding = validity = deferred = 0;    user = http_cgi_variable(cgivars, "CustomerId");    from = http_cgi_variable(cgivars, "MsIsdn");    to = http_cgi_variable(cgivars, "Recipient");    text = http_cgi_variable(cgivars, "SMMO");    udh = http_cgi_variable(cgivars, "XSer");    date = http_cgi_variable(cgivars, "DateReceived");    type = http_cgi_variable(cgivars, "MessageType");    debug("smsc.http.brunet", 0, "HTTP[%s]: Received a request",          octstr_get_cstr(conn->id));        if (user == NULL || octstr_compare(user, conndata->username) != 0) {        error(0, "HTTP[%s]: Authorization failure. CustomerId was <%s>.",              octstr_get_cstr(conn->id), octstr_get_cstr(user));        retmsg = octstr_create("Authorization failed for MO submission.");    }    else if (from == NULL || to == NULL || text == NULL) {        error(0, "HTTP[%s]: Insufficient args.",              octstr_get_cstr(conn->id));        retmsg = octstr_create("Insufficient arguments, rejected.");    }    else {        Msg *msg;        msg = msg_create(sms);        debug("smsc.http.brunet", 0, "HTTP[%s]: Received new MO SMS.",              octstr_get_cstr(conn->id));	        msg->sms.sender = octstr_duplicate(from);        msg->sms.receiver = octstr_duplicate(to);        msg->sms.msgdata = octstr_duplicate(text);        msg->sms.udhdata = octstr_duplicate(udh);        msg->sms.smsc_id = octstr_duplicate(conn->id);        msg->sms.time = time(NULL); /* XXX maybe extract from DateReceived */         msg->sms.mclass = mclass;        msg->sms.mwi = mwi;        msg->sms.coding = coding;        msg->sms.validity = validity;        msg->sms.deferred = deferred;        ret = bb_smscconn_receive(conn, msg);        if (ret == -1)            retmsg = octstr_create("Status=1");        else            retmsg = octstr_create("Status=0");    }    reply_headers = gwlist_create();    http_header_add(reply_headers, "Content-Type", "text/plain");    debug("smsc.http.brunet", 0, "HTTP[%s]: Sending reply `%s'.",          octstr_get_cstr(conn->id), octstr_get_cstr(retmsg));    http_send_reply(client, HTTP_OK, reply_headers, retmsg);    octstr_destroy(retmsg);    http_destroy_headers(reply_headers);}/*---------------------------------------------------------------- * 3united.com (formerly Xidris) - An austrian (AT) SMS aggregator  * Implementing version 1.3, 2003-05-06 * Updating to version 1.9.1, 2004-09-28 * * Stipe Tolj <stolj@wapme.de> *//* MT related function */static void xidris_send_sms(SMSCConn *conn, Msg *sms){    ConnData *conndata = conn->data;    Octstr *url, *new_msg;    List *headers;    int dcs, esm_class;    url = new_msg = NULL;    dcs = esm_class = 0;    /* format the URL for call */    url = octstr_format("%S?"        "app_id=%E&key=%E&dest_addr=%E&source_addr=%E",        conndata->send_url, conndata->username,         conndata->password, sms->sms.receiver, sms->sms.sender);    if (octstr_len(sms->sms.udhdata)) {        /* RAW additions for binary (8bit) msgs  */        /* set the data coding scheme (DCS) and ESM class fields */        dcs = fields_to_dcs(sms, sms->sms.alt_dcs);        /* ESM_CLASS_SUBMIT_STORE_AND_FORWARD_MODE |            ESM_CLASS_SUBMIT_UDH_INDICATOR */        esm_class = 0x03 | 0x40;             /* prepend UDH header to message block */        new_msg = octstr_duplicate(sms->sms.udhdata);        octstr_append(new_msg, sms->sms.msgdata);        octstr_format_append(url, "&type=200&dcs=%d&esm=%d&message=%H",                             dcs, esm_class, new_msg);    }  else {        /* additions for text (7bit) msgs */        octstr_format_append(url, "&type=%E&message=%E",                            (sms->sms.mclass ? octstr_imm("1") : octstr_imm("0")),                            sms->sms.msgdata);    }    /*      * We use &account=<foobar> from sendsms interface to encode any additionaly     * proxied parameters, ie. billing information.     */    if (octstr_len(sms->sms.account)) {        octstr_url_decode(sms->sms.account);        octstr_format_append(url, "&%s", octstr_get_cstr(sms->sms.account));    }    headers = gwlist_create();    debug("smsc.http.xidris", 0, "HTTP[%s]: Sending request <%s>",          octstr_get_cstr(conn->id), octstr_get_cstr(url));    http_start_request(conndata->http_ref, HTTP_METHOD_GET, url, headers,                        NULL, 0, sms, NULL);    octstr_destroy(url);    octstr_destroy(new_msg);    http_destroy_headers(headers);}/*  * Parse for an parameter of an given XML tag and return it as Octstr */static Octstr *parse_xml_tag(Octstr *body, Octstr *tag){    Octstr *stag, *etag, *ret;    int spos, epos;       stag = octstr_format("<%s>", octstr_get_cstr(tag));    if ((spos = octstr_search(body, stag, 0)) == -1) {        octstr_destroy(stag);        return NULL;    }    etag = octstr_format("</%s>", octstr_get_cstr(tag));    if ((epos = octstr_search(body, etag, spos+octstr_len(stag))) == -1) {        octstr_destroy(stag);        octstr_destroy(etag);        return NULL;    }        ret = octstr_copy(body, spos+octstr_len(stag), epos+1 - (spos+octstr_len(etag)));      octstr_strip_blanks(ret);    octstr_strip_crlfs(ret);    octstr_destroy(stag);    octstr_destroy(etag);    return ret;}static void xidris_parse_reply(SMSCConn *conn, Msg *msg, int status,                               List *headers, Octstr *body){    Octstr *code, *desc, *mid;    if (status == HTTP_OK || status == HTTP_ACCEPTED) {        /* now parse the XML document for error code */        code = parse_xml_tag(body, octstr_imm("status"));        desc = parse_xml_tag(body, octstr_imm("description"));                /* The following parsing assumes we get only *one* message id in the          * response XML. Which is ok, since we garantee via previous concat         * splitting, that we only pass PDUs of 1 SMS size to SMSC. */        mid = parse_xml_tag(body, octstr_imm("message_id"));        if (octstr_case_compare(code, octstr_imm("0")) == 0 && mid != NULL) {            /* ensure the message id gets logged */            msg->sms.binfo = octstr_duplicate(mid);            /* SMSC ACK.. now we have the message id. */            if (DLR_IS_ENABLED_DEVICE(msg->sms.dlr_mask))                dlr_add(conn->id, mid, msg);            octstr_destroy(mid);

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -