Вход Регистрация
Файл: vsime.com/system/includes/smsc_api.php
Строк: 181
<?php
// SMSC.RU API (www.smsc.ru) версия 2.7 (07.06.2012)

define("SMSC_LOGIN""de5d");        // логин клиента

define("SMSC_PASSWORD""Sedrigaylo");    // пароль или MD5-хеш пароля в нижнем регистре

define("SMSC_POST"0);                    // использовать метод POST
define("SMSC_HTTPS"0);                // использовать HTTPS протокол
define("SMSC_CHARSET""utf-8");    // кодировка сообщения: utf-8, koi8-r или windows-1251 (по умолчанию)
define("SMSC_DEBUG"0);                // флаг отладки
define("SMTP_FROM""api@smsc.ru");     // e-mail адрес отправителя

// Функция отправки SMS
//
// обязательные параметры:
//
// $phones - список телефонов через запятую или точку с запятой
// $message - отправляемое сообщение
//
// необязательные параметры:
//
// $translit - переводить или нет в транслит (1,2 или 0)
// $time - необходимое время доставки в виде строки (DDMMYYhhmm, h1-h2, 0ts, +m)
// $id - идентификатор сообщения. Представляет собой 32-битное число в диапазоне от 1 до 2147483647.
// $format - формат сообщения (0 - обычное sms, 1 - flash-sms, 2 - wap-push, 3 - hlr, 4 - bin, 5 - bin-hex, 6 - ping-sms)
// $sender - имя отправителя (Sender ID). Для отключения Sender ID по умолчанию необходимо в качестве имени
// передать пустую строку или точку.
// $query - строка дополнительных параметров, добавляемая в URL-запрос ("valid=01:00&maxsms=3&tz=2")
//
// возвращает массив (<id>, <количество sms>, <стоимость>, <баланс>) в случае успешной отправки
// либо массив (<id>, -<код ошибки>) в случае ошибки

function send_sms($phones$message$translit 0$time 0$id 0$format 0$sender false$query "")
{
    static 
$formats = array(=> "flash=1""push=1""hlr=1""bin=1""bin=2""ping=1");

    
$m _smsc_send_cmd("send""cost=3&phones=".urlencode($phones)."&mes=".urlencode($message).
                    
"&translit=$translit&id=$id".($format "&".$formats[$format] : "").
                    (
$sender === false "" "&sender=".urlencode($sender))."&charset=".SMSC_CHARSET.
                    (
$time "&time=".urlencode($time) : "").($query "&$query""));

    
// (id, cnt, cost, balance) или (id, -error)

    
if (SMSC_DEBUG) {
        if (
$m[1] > 0)
            echo 
"Сообщение отправлено успешно. ID: $m[0], всего SMS: $m[1], стоимость: $m[2] руб., баланс: $m[3] руб.n";
        else 
            echo 
"Ошибка №", -$m[1], $m[0] ? ", ID: ".$m[0] : """n";
    }

    return 
$m;
}

// SMTP версия функции отправки SMS

function send_sms_mail($phones$message$translit 0$time 0$id 0$format 0$sender "")
{
    return 
mail("send@send.smsc.ru"""SMSC_LOGIN.":".SMSC_PASSWORD.":$id:$time:$translit,$format,$sender:$phones:$message""From: ".SMTP_FROM."nContent-Type: text/plain; charset=".SMSC_CHARSET."n");
}

// Функция получения стоимости SMS
//
// обязательные параметры:
//
// $phones - список телефонов через запятую или точку с запятой
// $message - отправляемое сообщение 
//
// необязательные параметры:
//
// $translit - переводить или нет в транслит (1,2 или 0)
// $format - формат сообщения (0 - обычное sms, 1 - flash-sms, 2 - wap-push, 3 - hlr, 4 - bin, 5 - bin-hex, 6 - ping-sms)
// $sender - имя отправителя (Sender ID)
// $query - строка дополнительных параметров, добавляемая в URL-запрос ("list=79999999999:Ваш пароль: 123n78888888888:Ваш пароль: 456")
//
// возвращает массив (<стоимость>, <количество sms>) либо массив (0, -<код ошибки>) в случае ошибки

function get_sms_cost($phones$message$translit 0$format 0$sender false$query "")
{
    static 
$formats = array(=> "flash=1""push=1""hlr=1""bin=1""bin=2""ping=1");

    
$m _smsc_send_cmd("send""cost=1&phones=".urlencode($phones)."&mes=".urlencode($message).
                    (
$sender === false "" "&sender=".urlencode($sender))."&charset=".SMSC_CHARSET.
                    
"&translit=$translit".($format "&".$formats[$format] : "").($query "&$query""));

    
// (cost, cnt) или (0, -error)

    
if (SMSC_DEBUG) {
        if (
$m[1] > 0)
            echo 
"Стоимость рассылки: $m[0] руб. Всего SMS: $m[1]n";
        else
            echo 
"Ошибка №", -$m[1], "n";
    }

    return 
$m;
}

// Функция проверки статуса отправленного SMS или HLR-запроса
//
// $id - ID cообщения
// $phone - номер телефона
// $all - вернуть все данные отправленного SMS, включая текст сообщения (0 или 1)
//
// возвращает массив:
//
// для SMS-сообщения:
// (<статус>, <время изменения>, <код ошибки доставки>)
//
// для HLR-запроса:
// (<статус>, <время изменения>, <код ошибки sms>, <код IMSI SIM-карты>, <номер сервис-центра>, <код страны регистрации>, <код оператора>,
// <название страны регистрации>, <название оператора>, <название роуминговой страны>, <название роумингового оператора>)
//
// При $all = 1 дополнительно возвращаются элементы в конце массива:
// (<время отправки>, <номер телефона>, <стоимость>, <sender id>, <название статуса>, <текст сообщения>)
//
// либо массив (0, -<код ошибки>) в случае ошибки

function get_status($id$phone$all 0)
{
    
$m _smsc_send_cmd("status""phone=".urlencode($phone)."&id=".$id."&all=".(int)$all);

    
// (status, time, err, ...) или (0, -error)

    
if (SMSC_DEBUG) {
        if (
$m[1] != "" && $m[1] >= 0)
            echo 
"Статус SMS = $m[0]"$m[1] ? ", время изменения статуса - ".date("d.m.Y H:i:s"$m[1]) : """n";
        else
            echo 
"Ошибка №", -$m[1], "n";
    }

    if (
$all && count($m) > && (!isset($m[14]) || $m[14] != "HLR")) // ',' в сообщении
        
$m explode(","implode(","$m), 9);

    return 
$m;
}

// Функция получения баланса
//
// без параметров
//
// возвращает баланс в виде строки или false в случае ошибки

function get_balance()
{
    
$m _smsc_send_cmd("balance"); // (balance) или (0, -error)

    
if (SMSC_DEBUG) {
        if (!isset(
$m[1]))
            echo 
"Сумма на счете: "$m[0], " руб.n";
        else
            echo 
"Ошибка №", -$m[1], "n";
    }

    return isset(
$m[1]) ? false $m[0];
}


// ВНУТРЕННИЕ ФУНКЦИИ

// Функция вызова запроса. Формирует URL и делает 3 попытки чтения

function _smsc_send_cmd($cmd$arg "")
{
    
$url = (SMSC_HTTPS "https" "http")."://smsc.ru/sys/$cmd.php?login=".urlencode(SMSC_LOGIN)."&psw=".urlencode(SMSC_PASSWORD)."&fmt=1&".$arg;

    
$i 0;
    do {
        if (
$i)
            
sleep(2);

        
$ret _smsc_read_url($url);
    }
    while (
$ret == "" && ++$i 3);

    if (
$ret == "") {
        if (
SMSC_DEBUG)
            echo 
"Ошибка чтения адреса: $urln";

        
$ret ","// фиктивный ответ
    
}

    return 
explode(","$ret);
}

// Функция чтения URL. Для работы должно быть доступно:
// curl или fsockopen (только http) или включена опция allow_url_fopen для file_get_contents

function _smsc_read_url($url)
{
    
$ret "";
    
$post SMSC_POST || strlen($url) > 2000;

    if (
function_exists("curl_init"))
    {
        static 
$c 0// keepalive

        
if (!$c) {
            
$c curl_init();
            
curl_setopt($cCURLOPT_RETURNTRANSFERtrue);
            
curl_setopt($cCURLOPT_CONNECTTIMEOUT10);
            
curl_setopt($cCURLOPT_TIMEOUT10);
            
curl_setopt($cCURLOPT_SSL_VERIFYPEER0);
        }

        if (
$post) {
            list(
$url$post) = explode('?'$url2);
            
curl_setopt($cCURLOPT_POSTtrue);
            
curl_setopt($cCURLOPT_POSTFIELDS$post);
        }

        
curl_setopt($cCURLOPT_URL$url);

        
$ret curl_exec($c);
    }
    elseif (!
SMSC_HTTPS && function_exists("fsockopen"))
    {
        
$m parse_url($url);

        
$fp fsockopen($m["host"], 80$errno$errstr10);

        if (
$fp) {
            
fwrite($fp, ($post "POST $m[path]"GET $m[path]?$m[query]")." HTTP/1.1rnHost: smsc.rurnUser-Agent: PHP".($post "rnContent-Type: application/x-www-form-urlencodedrnContent-Length: ".strlen($m['query']) : "")."rnConnection: Closernrn".($post $m['query'] : ""));

            while (!
feof($fp))
                
$ret .= fgets($fp1024);
            list(, 
$ret) = explode("rnrn"$ret2);

            
fclose($fp);
        }
    }
    else
        
$ret file_get_contents($url);

    return 
$ret;
}

// Examples:
// list($sms_id, $sms_cnt, $cost, $balance) = send_sms("79999999999", "Ваш пароль: 123", 1);
// list($sms_id, $sms_cnt, $cost, $balance) = send_sms("79999999999", "http://smsc.runSMSC.RU", 0, 0, 0, 0, false, "maxsms=3");
// list($sms_id, $sms_cnt, $cost, $balance) = send_sms("79999999999", "0605040B8423F0DC0601AE02056A0045C60C037761702E736D73632E72752F0001037761702E736D73632E7275000101", 0, 0, 0, 5, false);
// list($sms_id, $sms_cnt, $cost, $balance) = send_sms("79999999999", "", 0, 0, 0, 3, false);
// list($cost, $sms_cnt) = get_sms_cost("79999999999", "Вы успешно зарегистрированы!");
// send_sms_mail("79999999999", "Ваш пароль: 123", 0, "0101121000");
// list($status, $time) = get_status($sms_id, "79999999999");
// $balance = get_balance();

?>
Онлайн: 3
Реклама