Jump to content
Skysnake

DllCall() with C example

Recommended Posts

bool SMSAPI_sendsms(
const LPSMSAPI_NETWORKCONFIGURATION lpNetConfig, 
const LPSMSAPI_ACCOUNTINFO lpAccInfo, 
const LPSMSAPI_MESSAGEINFO lpMsgInfo, 
LPSMSAPI_RESPONSEINFO lpResponseInfo);

The previous posts:

struct in dllcall and my attempt plus documentation

I have put everything I have come up with on the forum.  I need help.  I do not understand the syntax, nor the process.  

The idea is to have a simple little GUI with two options, one for config (such as server name account name and password)

and the second with a simple input for SMS destination number and the message...

Problem is, I dont know how to do that.  Obviously once the basics are done, this kind of integration can go anywhere...

Edited by Skysnake

Skysnake

Why is the snake in the sky?

Share this post


Link to post
Share on other sites

I got registered on that page but the y don't send me any code (maybe because I from South America) 

Also I notice you can use the web API for send message. (look easier than Desltop App API)

Saludos

 

Share this post


Link to post
Share on other sites

What confuses me is why would you even consider using third party dll to access SMS API interface. It's obviously only a thin wrapper around something as simple as this:

#include "Crypt.au3"
#include "WinHttp.au3"


$sFrom = "Info" ; what goes here?
$sTo = "555555" ; some phone number?
$sMessage = "Test Message Text. Works?"

$sRet = SMS_Send($sFrom, $sTo, $sMessage)
ConsoleWrite("Error = " & @error & ", Response code = " & @extended & @CRLF)
ConsoleWrite("> Returned = " & $sRet & @CRLF)



Func SMS_Send($sFrom, $sTo, $sMessage, $fBackup = False)
    Local Const $sAddress = $fBackup ? "https://api2.smsapi.com/sms.do" : "https://api.smsapi.com/sms.do"
    Local Const $sUserName = "you@whatever.com" ; account mail here
    Local Const $sPassword = "password" ; your password

    ; Construct the form (API's post method)
    Local Const $sForm = _
            '<form action="' & $sAddress & '" method="post" enctype="multipart/form-data">' & _
            ' <input name="username"/>' & _ ;
            ' <input name="password"/>' & _
            ' <input name="from"/>' & _
            ' <input name="to"/>' & _
            ' <input name="message"/>' & _
            '</form>'

    ; Initialize and get session handle
    Local $hOpen = _WinHttpOpen()
    ; Get connection handle
    Local $hConnect = $sForm
    ; Fill the form
    Local $sRead = _WinHttpSimpleFormFill($hConnect, $hOpen, _
            Default, _ ; location of the form
            "name:username", $sUserName, _
            "name:password", Hex(_Crypt_HashData($sPassword, $CALG_MD5)), _
            "name:from", $sFrom, _
            "name:to", $sTo, _
            "name:message", $sMessage)
    ; Collect error number and HTTP status code
    Local $iErr = @error, $iStatus = @extended

    If $iStatus <> $HTTP_STATUS_OK And Not $fBackup Then
        $sRead = SMS_Send($sFrom, $sTo, $sMessage, True)
        $iErr = @error
        $iStatus = @extended
    EndIf

    ; Close handles
    _WinHttpCloseHandle($hConnect)
    _WinHttpCloseHandle($hOpen)

    Return SetError($iErr, $iStatus, $sRead)
EndFunc

By using dll you just make your life harder.

Share this post


Link to post
Share on other sites

It confuses me because I can not code.  I do not understand C.  I can not make a C app and put the code into whatever I am doing.  I do not even understand what I am looking at.  If you say ""Const" is irrelevant for you." then I can only agree because I do not have the knowledge nor insight to argue.  I use AutoIt as a tool to automate reports in my office.  And I can do lots of things easily and quickly that used to take hours.  Learning AutoIt is a hobby.  I simply do not have the time to learn C.  Reality is such a hassle.  Problem is, in order to increase the potential benefit to be derived from AutoIt I need to use new tools, one of which is a 3rd Party DLL such as that under discussion.

As far as the HTTP sender is concerned, it works, I have done it manually and it is ugly.  The reason for using  the smsdll is simple, once developed it can be integrated almost anywhere and seamlessly integrate into future projects.

I presume you are an engineer or software developer.  You have been trained to deal with this and for you a simple DllCall is trivial.  My background is very different and far removed from software development.  For me it presents an almost insurmountable challenge.  I can not even tell whether "const" is an issue or not.

Thank you kindly for the code above.  I will experiment. with it.  If it means anything, I have an existing BulkSMS account loaded with credits.  I just can't get it to work with such code as I have written (and posted here).

Thanks again for taking the time to read and the patience to provide an answer.  I really do appreciate.

S


Skysnake

Why is the snake in the sky?

Share this post


Link to post
Share on other sites

@Trancexx I ran your code :) 

Error = 0, Response code = 200
> Returned = ERROR:101

 

The reason is that your code is designed for smsapi, while I am trying to runb with BulkSMS.

smsapi and BulkSMS are not the same.  Bear in mind practical issues like non-availability in the target area

 

I will keep on playing.  Maybe you are right.  Maybe I am trying to overkill.  This is obviously much easier and I understand the code :) 

By using dll you just make your life harder.

 

Seems you are right :)

 

Edited by Skysnake

Skysnake

Why is the snake in the sky?

Share this post


Link to post
Share on other sites

That one seems even simpler.

#include "WinHttp.au3"


$sTo = "5555555554" ; some phone number?
$sMessage = "Test Message Text. Works?"

$sRet = SMS_Send($sTo, $sMessage)
ConsoleWrite("Error = " & @error & ", Response code = " & @extended & @CRLF)
ConsoleWrite("> Returned = " & $sRet & @CRLF)



Func SMS_Send($sTo, $sMessage)
    Local Const $sAddress = "https://bulksms.vsms.net/eapi/submission/send_sms/2/2.0" ; your's here
    Local Const $sUserName = "you" ; your user name
    Local Const $sPassword = "password" ; your password

    ; Construct the form (API's post method)
    Local Const $sForm = _
            '<form action="' & $sAddress & '" method="post" enctype="application/x-www-form-urlencoded">' & _
            ' <input name="username"/>' & _ ;
            ' <input name="password"/>' & _
            ' <input name="msisdn"/>' & _
            ' <input name="message"/>' & _
            '</form>'

    ; Initialize and get session handle
    Local $hOpen = _WinHttpOpen()
    ; Get connection handle
    Local $hConnect = $sForm
    ; Fill the form
    Local $sRead = _WinHttpSimpleFormFill($hConnect, $hOpen, _
            Default, _ ; location of the form
            "name:username", $sUserName, _
            "name:password", $sPassword, _
            "name:msisdn", $sTo, _
            "name:message", $sMessage)
    ; Collect error number and HTTP status code
    Local $iErr = @error, $iStatus = @extended

    ; Close handles
    _WinHttpCloseHandle($hConnect)
    _WinHttpCloseHandle($hOpen)

    Return SetError($iErr, $iStatus, $sRead)
EndFunc

 

Share this post


Link to post
Share on other sites

wow.

I go to https://www.smsapi.com/contact and what I see this is Polish product: https://www.smsapi.pl/
I was using this 2 years ago.

even here:

https://www.smsapi.com/rest

you can see in example #2:

$password 'password-md5');               //lub $password = md5('open-text-password'),

lub >> or 

$password 'password-md5');               //or $password = md5('open-text-password'),

Signature beginning:   Wondering who uses AutoIT and what it can be used for ?
* GHAPI UDF - modest beginning - communication with GitHub REST API Forum Rules *
ADO.au3 UDF     POP3.au3 UDF     XML.au3 UDF    How to use IE.au3  UDF with  AutoIt v3.3.14.x  for other useful stuff click the following button

Spoiler

Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST APIErrorLog.au3 UDF - A logging Library *

My contribution to others projects or UDF based on  others projects: * _sql.au3 UDF  * POP3.au3 UDF *  RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * 

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

Signature last update: 2019-10-01

Share this post


Link to post
Share on other sites

Here is my full UDF 

_Example()
Func _Example()

    _SMSApi_URL('https://api.smsapi.com/sms.do')
    _SMSApi_UserName('my@email.pl')
    _SMSApi_Password('SOMEPASSWORDINMD5')
    Local $output = _SMSApi_Sender('Eco', '48502xxxxxx', 'Hello World.'.)
    ConsoleWrite(_SMSApi_Error($output) & @CRLF)
EndFunc

Func _SMSApi_Password($vPassword_Param = Default)
    Local Static $sPassword = ''
    If $vPassword_Param = Default Then
        Return SetError(0,0,$sPassword)
    ElseIf IsString($vPassword_Param) Then
        $sPassword = $vPassword_Param
        Return SetError(0,1,$sPassword)
    Else
        Return SetError(1,0,$sPassword)
    EndIf
EndFunc

Func _SMSApi_UserName($vUserName_Param = Default)
    Local Static $sUserName = ''
    If $vUserName_Param = Default Then
        Return SetError(0,0,$sUserName)
    ElseIf IsString($vUserName_Param) Then
        $sUserName = $vUserName_Param
        Return SetError(0,1,$sUserName)
    Else
        Return SetError(1,0,$sUserName)
    EndIf
EndFunc

Func _SMSApi_URL($vURL_Param = Default)
    Local Static $sURL = 'https://ssl.smsapi.pl/sms.do'
    If $vURL_Param = Default Then
        Return SetError(0,0,$sURL)
    ElseIf IsString($vURL_Param) Then
        $sURL = $vURL_Param
        Return SetError(0,1,$sURL)
    Else
        Return SetError(1,0,$sURL)
    EndIf
EndFunc

Func _SMSApi_Sender($sSenderName, $sRecipient, $sSmsMessage)
;~  https://ssl.smsapi.pl/sms.do?username=uzytkownik&password=hasloMD5&from=nazwa&to=48500XXX000&message=test wiadomosci
;~  https://ssl.smsapi.pl/sms.do?username=USERNEAME&password=PASSWORDMD5&from=SENDERNAME&to=RECIPIENT&message=SMS_MESSAGE

    If $sSenderName = Default Then $sSenderName = "INFO"
    Local $sURL
    $sURL = _SMSApi_URL()
    $sURL &= '?username=' & _SMSApi_UserName() & '&password=' & _SMSApi_Password()
    $sURL &= '&from=' & $sSenderName & '&to=' & $sRecipient
    $sURL &= '&message=' & $sSmsMessage

    Local $oXmlHttp = ObjCreate("Microsoft.XMLHTTP")
    $oXmlHttp.Open('POST', $sURL, False)
    $oXmlHttp.Send()
    Local $output = $oXmlHttp.ResponseText
    $oXmlHttp = ''
    Return $output
EndFunc   ;==>_SMSApi_Sender

Func _SMSApi_Status($iStatus)
    Local $sDescription_1
    Local $sDescription_2
    Switch Number($iStatus)
        Case 401
            $sDescription_1 = 'Nie istnieje'
            $sDescription_2 = 'Błędny numer ID wiadomości lub raport wygasł.'
        Case 402
            $sDescription_1 = 'Przedawniona'
            $sDescription_2 = 'Wiadomość niedostarczona z powodu zbyt długiego czasu niedostępność numeru.'
        Case 403
            $sDescription_1 = 'Wysłana'
            $sDescription_2 = 'Wiadomość została wysłana ale operator nie zwrócił jeszcze raportu doręczenia.'
        Case 404
            $sDescription_1 = 'Dostarczona'
            $sDescription_2 = 'Wiadomość dotarła do odbiorcy.'
        Case 405
            $sDescription_1 = 'Niedostarczona'
            $sDescription_2 = 'Wiadomość niedostarczona (np.: błędny numer, numer niedostępny).'
        Case 406
            $sDescription_1 = 'Nieudana'
            $sDescription_2 = 'Błąd podczas wysyłki wiadomości (prosimy o zgłoszenie problemu).'
        Case 408
            $sDescription_1 = 'Nieznany'
            $sDescription_2 = 'Brak raportu doręczenia dla wiadomości.'
        Case 409
            $sDescription_1 = 'Kolejka'
            $sDescription_2 = 'Wiadomość zaplanowana.'
        Case 410
            $sDescription_1 = 'Zaakceptowana'
            $sDescription_2 = 'Wiadomość przyjęta przez operatora.'
        Case 411
            $sDescription_1 = 'Ponawianie'
            $sDescription_2 = 'Wykonana była próba połączenia która nie została odebrana, połączenie zostanie ponowione.'
    EndSwitch
    Return $iStatus & ': ' & $sDescription_1 & ': ' & $sDescription_2
EndFunc   ;==>_SMSApi_Status

Func _SMSApi_Error($sError)
    Local $sDescription
    Switch $sError
        Case 'ERROR:8'
            $sDescription = 'Błąd w odwołaniu (Prosimy zgłosić)'
        Case 'ERROR:11'
            $sDescription = 'Zbyt długa lub brak wiadomości lub ustawiono parametr nounicode i pojawiły się znaki specjalne w wiadomości. Dla wysyłki VMS błąd oznacza brak pliku WAV lub treści TTS.'
        Case 'ERROR:12'
            $sDescription = 'Wiadomość zawiera ponad 160 znaków (gdy użyty parametr &single=1).'
        Case 'ERROR:13'
            $sDescription = 'Brak prawidłowych numerów telefonów (numery błędne, znajdujące się na czarnej liście lub zagraniczne przy wyłączonej opcji wysyłki za granicę).'
        Case 'ERROR:14'
            $sDescription = 'Nieprawidłowe pole nadawcy.'
        Case 'ERROR:17'
            $sDescription = 'Nie można wysłać FLASH ze znakami specjalnymi.'
        Case 'ERROR:18'
            $sDescription = 'Nieprawidłowa liczba parametrów.'
        Case 'ERROR:19'
            $sDescription = 'Za dużo wiadomości w jednym odwołaniu.'
        Case 'ERROR:20'
            $sDescription = 'Nieprawidłowa liczba parametrów IDX.'
        Case 'ERROR:21'
            $sDescription = 'Wiadomość MMS ma za duży rozmiar (maksymalnie 300kB).'
        Case 'ERROR:22'
            $sDescription = 'Błędny format SMIL.'
        Case 'ERROR:23'
            $sDescription = 'Błąd pobierania pliku dla wiadomości MMS lub VMS.'
        Case 'ERROR:24'
            $sDescription = 'Błędny format pobieranego pliku.'
        Case 'ERROR:25'
            $sDescription = 'Parametry &normalize oraz &datacoding nie mogą być używane jednocześnie.'
        Case 'ERROR:26'
            $sDescription = 'Za długi temat wiadomości. Temat może zawierać maksymalnie 30 znaków.'
        Case 'ERROR:27'
            $sDescription = 'Parametr IDX za długi. Maksymalnie 255 znaków.'
        Case 'ERROR:30'
            $sDescription = 'Brak parametru UDH jak podany jest datacoding=bin.'
        Case 'ERROR:31'
            $sDescription = 'Błąd konwersji TTS'
        Case 'ERROR:32'
            $sDescription = 'Nie można wysyłać wiadomości Eco, MMS i VMS na zagraniczne numery.'
        Case 'ERROR:33'
            $sDescription = 'Brak poprawnych numerów.'
        Case 'ERROR:35'
            $sDescription = 'Błędna wartość parametru tts_lector. Dostępne wartości: agnieszka, ewa, jacek, jan, maja.'
        Case 'ERROR:36'
            $sDescription = 'Nie można wysyłać wiadomości binarnych z ustawioną stopką.'
        Case 'ERROR:40'
            $sDescription = 'Brak grupy o podanej nazwie'
        Case 'ERROR:41'
            $sDescription = 'Wybrana grupa jest pusta (brak kontaktów w grupie).'
        Case 'ERROR:50'
            $sDescription = 'Nie można zaplanować wysyłki na więcej niż 3 miesiące w przyszłość.'
        Case 'ERROR:51'
            $sDescription = 'Ustawiono błędną godzinę wysyłki, wiadomość VMS mogą być wysyłane tylko pomiędzy godzinami 8 a 22 lub ustawiono kombinację parametrów try i interval powodującą możliwość próby połączenia po godzinie 22.'
        Case 'ERROR:52'
            $sDescription = 'Za dużo prób wysyłki wiadomości do jednego numeru (maksymalnie 10 prób w przeciągu 60sek do jednego numeru).'
        Case 'ERROR:53'
            $sDescription = 'Nieunikalny parametr idx. Została już przyjęta wiadomość z identyczną wartością parametru idx przy wykorzystaniu parametru &check_idx=1.'
        Case 'ERROR:54'
            $sDescription = 'Błędny format daty. Ustawiono sprawdzanie poprawności daty &date_validate=1.'
        Case 'ERROR:55'
            $sDescription = 'Brak numerów stacjonarnych w wysyłce i ustawiony parametr skip_gsm.'
        Case 'ERROR:56'
            $sDescription = 'Różnica pomiędzy datą wysyłki a datą wygaśnięcia nie może być mniejsza niż 15 minut i większa niż 12 godzin.'
        Case 'ERROR:57'
            $sDescription = 'Numer znajduje się na czarnej liście dla danego użytkownika.'
        Case 'ERROR:60'
            $sDescription = 'Grupa kodów o podanej nazwie nie istnieje.'
        Case 'ERROR:61'
            $sDescription = 'Data ważności grupy kodów minęła.'
        Case 'ERROR:62'
            $sDescription = 'Brak wolnych kodów w podanej grupie (wszystkie kody zostały już wykorzystane).'
        Case 'ERROR:65'
            $sDescription = 'Brak wystarczającej liczby kodów rabatowych dla wysyłki. Liczba niewykorzystanych kodów w grupie musi być co najmniej równa liczbie numerów w wysyłce.'
        Case 'ERROR:66'
            $sDescription = 'W treści wiadomości brak jest znacznika [%kod%] dla wysyłki z parametrem &discount_group (znacznik taki jest wymagany).'
        Case 'ERROR:70'
            $sDescription = 'Błędny adres CALLBACK w parametrze notify_url.'
        Case 'ERROR:72'
            $sDescription = 'Parametr notify_url może być używany tylko dla odwołań z jednym numerem (nie może być stosowany dla wysyłek masowych).'
        Case 'ERROR:101'
            $sDescription = 'Niepoprawne lub brak danych autoryzacji. UWAGA! Hasło do API może różnić się od hasła do Panelu Klienta.'
        Case 'ERROR:102'
            $sDescription = 'Nieprawidłowy login lub hasło.'
        Case 'ERROR:103'
            $sDescription = 'Brak punktów dla tego użytkownika.'
        Case 'ERROR:104'
            $sDescription = 'Brak szablonu.'
        Case 'ERROR:105'
            $sDescription = 'Błędny adres IP (włączony filtr IP dla interfejsu API).'
        Case 'ERROR:110'
            $sDescription = 'Usługa (SMS, MMS, VMS lub HLR) nie jest dostępna na danym koncie.'
        Case 'ERROR:200'
            $sDescription = 'Nieudana próba wysłania wiadomości, prosimy ponowić odwołanie.'
        Case 'ERROR:201'
            $sDescription = 'Wewnętrzny błąd systemu (prosimy zgłosić).'
        Case 'ERROR:202'
            $sDescription = 'Zbyt duża ilość jednoczesnych odwołań do serwisu, wiadomość nie została wysłana (prosimy odwołać się ponownie).'
        Case 'ERROR:300'
            $sDescription = 'Nieprawidłowa wartość pola points (przy użyciu pola points jest wymagana wartość 1).'
        Case 'ERROR:301'
            $sDescription = 'Wiadomość o podanym ID nie istnieje lub jest zaplanowana do wysłania w przeciągu najbliższych 60 sekund (nie można usunąć takiej wiadomości).'
        Case 'ERROR:400'
            $sDescription = 'Nieprawidłowy ID statusu wiadomości.'
        Case 'ERROR:999'
            $sDescription = 'Wewnętrzny błąd systemu (prosimy zgłosić).'
        Case 'ERROR:1000'
            $sDescription = 'Akcja dostępna tylko dla użytkownika głównego.'
        Case 'ERROR:1001'
            $sDescription = 'Nieprawidłowa akcja (oczekiwane jedna z add_user, set_user, get_user, credits).'
        Case 'ERROR:1010'
            $sDescription = 'Błąd dodawania podużytkownika.'
        Case 'ERROR:1020'
            $sDescription = 'Błąd edycji konta podużytkownika.'
        Case 'ERROR:1021'
            $sDescription = 'Brak danych do edycji, przynajmniej jeden parametr musi być edytowany.'
        Case 'ERROR:1030'
            $sDescription = 'Błąd pobierania danych użytkownika.'
        Case 'ERROR:1032'
            $sDescription = 'Nie istnieje podużytkownik o podanej nazwie dla danego użytkownika głównego.'
        Case 'ERROR:1100'
            $sDescription = 'Błąd danych podużytkownika.'
        Case 'ERROR:1110'
            $sDescription = 'Błędna nazwa tworzonego podużytkownika.'
        Case 'ERROR:1111'
            $sDescription = 'Nie podano nazwy tworzonego konta podużytkownika.'
        Case 'ERROR:1112'
            $sDescription = 'Nazwa konta podużytkownika za krótka (minimum 3 znaki).'
        Case 'ERROR:1113'
            $sDescription = 'Nazwa konta podużytkownika za długa, łączna długość nazwy podużytkownika wraz z prefiksem użytkownika głównego może mieć maksymalnie 32 znaki.'
        Case 'ERROR:1114'
            $sDescription = 'W nazwie podużytkownika pojawiły się niedozwolone znaki, dozwolone są litery [A – Z], cyfry [0 – 9] oraz znaki @, -, _ i .'
        Case 'ERROR:1115'
            $sDescription = 'Istnieje już podużytkownik o podanej nazwie.'
        Case 'ERROR:1120'
            $sDescription = 'Błąd hasła dla tworzonego konta podużytkownika.'
        Case 'ERROR:1121'
            $sDescription = 'Hasło dla tworzonego konta podużytkownika za krótkie.'
        Case 'ERROR:1122'
            $sDescription = 'Hasło dla tworzonego konta podużytkownika za długie.'
        Case 'ERROR:1123'
            $sDescription = 'Hasło powinno być zakodowane w MD5.'
        Case 'ERROR:1130'
            $sDescription = 'Błąd limitu punktów przydzielanego podużytkownikowi.'
        Case 'ERROR:1131'
            $sDescription = 'Parametr limit powinno zawierać wartość numeryczną.'
        Case 'ERROR:1140'
            $sDescription = 'Błąd limitu miesięcznego punktów przydzielanego podużytkownikowi.'
        Case 'ERROR:1141'
            $sDescription = 'Parametr month_limit powinno zawierać wartość numeryczną.'
        Case 'ERROR:1150'
            $sDescription = 'Błędna wartość parametru senders, dopuszczalne wartości dla tego parametru to 0 lub 1.'
        Case 'ERROR:1160'
            $sDescription = 'Błędna wartość parametru phonebook, dopuszczalne wartości dla tego parametru to 0 lub 1.'
        Case 'ERROR:1170'
            $sDescription = 'Błędna wartość parametru active, dopuszczalne wartości dla tego parametru to 0 lub 1.'
        Case 'ERROR:1180'
            $sDescription = 'Błąd parametru info.'
        Case 'ERROR:1183'
            $sDescription = 'Zawartość parametru info jest za długa.'
        Case 'ERROR:1190'
            $sDescription = 'Błąd hasła do interfejsu API dla konta podużytkownika.'
        Case 'ERROR:1192'
            $sDescription = 'Błędna długość hasła do interfejsu API dla konta podużytkownika (hasło zakodowane w md5 powinno mieć 32 znaki).'
        Case 'ERROR:1193'
            $sDescription = 'Hasło do interfejsu powinno zostać podane w formie zakodowanej w md5.'
        Case 'ERROR:2001'
            $sDescription = 'Nieprawidłowa akcja (oczekiwane jedna z add, status, delete, list).'
        Case 'ERROR:2010'
            $sDescription = 'Błąd dodawania pola nadawcy.'
        Case 'ERROR:2030'
            $sDescription = 'Błąd sprawdzania statusu pola nadawcy.'
        Case 'ERROR:2031'
            $sDescription = 'Nie istnieje pole nadawcy o podanej nazwie.'
        Case 'ERROR:2060'
            $sDescription = 'Błąd dodawania domyślnego pola nadawcy.'
        Case 'ERROR:2061'
            $sDescription = 'Pole nadawcy musi być aktywne, żeby ustawić je jako domyślne.'
        Case 'ERROR:2062'
            $sDescription = 'Pole nadawcy już jest ustawione jako domyślne.'
        Case 'ERROR:2100'
            $sDescription = 'Błąd przesyłanych danych.'
        Case 'ERROR:2110'
            $sDescription = 'Błąd nazwy pola nadawcy.'
        Case 'ERROR:2111'
            $sDescription = 'Brak nazwy dodawanego pola nadawcy (parametr &add jest pusty).'
        Case 'ERROR:2112'
            $sDescription = 'Niepoprawna nazwa pola nadawcy (np. numer telefonu, zawierająca polskie i/lub specjalne znaki lub za długie), pole nadawcy może mieć maksymalnie 11 znaków, dopuszczalne znaki: a-z A-Z 0-9 - . [spacja].'
        Case 'ERROR:2115'
            $sDescription = 'Pole o podanej nazwie już istnieje.'
        Case 'ERROR:4000'
            $sDescription = 'Ogólny błąd operacji na bazie numerów.'
        Case 'ERROR:4001'
            $sDescription = 'Usługa nie jest dostępna na danym koncie.'
        Case 'ERROR:4002'
            $sDescription = 'Nieprawidłowa operacja.'
        Case 'ERROR:4003'
            $sDescription = 'Nieprawidłowe użycie parametru.'
        Case 'ERROR:4004'
            $sDescription = 'Za duża wartość parametru limit (np. dla operacji list_contacts maksymalna wartość wyświetlanych rekordów to 200).'
        Case 'ERROR:4100'
            $sDescription = 'Ogólny błąd operacji na grupach bazy numerów.'
        Case 'ERROR:4101'
            $sDescription = 'Grupa o podanej nazwie nie została znaleziona.'
        Case 'ERROR:4110'
            $sDescription = 'Ogólny błąd nazwy grupy bazy numerów.'
        Case 'ERROR:4111'
            $sDescription = 'Nieprawidłowa nazwa grupy.'
        Case 'ERROR:4112'
            $sDescription = 'Nazwa grupy nie może być pusta.'
        Case 'ERROR:4113'
            $sDescription = 'Nazwa grupy za krótka (minimalnie 2 znaki).'
        Case 'ERROR:4114'
            $sDescription = 'Nazwa grupy za długa (maksymalnie 32 znaki).'
        Case 'ERROR:4115'
            $sDescription = 'W nazwie grupy pojawiły się niedozwolone znaki.'
        Case 'ERROR:4116'
            $sDescription = 'Grupa o podanej nazwie już istnieje.'
        Case 'ERROR:4121'
            $sDescription = 'Nieprawidłowa wartość parametru Info dla grupy.'
        Case 'ERROR:4122'
            $sDescription = 'Za długa wartość pola Info dla grupy (maksymalnie 200 znaków).'
        Case 'ERROR:4200'
            $sDescription = 'Ogólny błąd kontaktu bazy numerów.'
        Case 'ERROR:4201'
            $sDescription = 'Kontakt o podanej nazwie nie został odnaleziony.'
        Case 'ERROR:4210'
            $sDescription = 'Ogólny błąd numeru telefonu przydzielonego do kontaktu.'
        Case 'ERROR:4211'
            $sDescription = 'Nieprawidłowy numer.'
        Case 'ERROR:4212'
            $sDescription = 'Kontakt musi zawierać numer telefonu.'
        Case 'ERROR:4213'
            $sDescription = 'Numer jest za krótki.'
        Case 'ERROR:4214'
            $sDescription = 'Numer jest za długi.'
        Case 'ERROR:4220'
            $sDescription = 'Błąd Imienia kontaktu.'
        Case 'ERROR:4221'
            $sDescription = 'Imię za krótkie (minimum 2 znaki).'
        Case 'ERROR:4222'
            $sDescription = 'Imię za długie (maksymalnie 100 znaków).'
        Case 'ERROR:4230'
            $sDescription = 'Błąd Nazwiska kontaktu.'
        Case 'ERROR:4231'
            $sDescription = 'Nazwisko za krótkie (minimum 2 znaki).'
        Case 'ERROR:4232'
            $sDescription = 'Nazwisko za długie (maksymalnie 100 znaków).'
        Case 'ERROR:4240'
            $sDescription = 'Błąd pola Info dla kontaktu.'
        Case 'ERROR:4241'
            $sDescription = 'Za długa wartość pola Info dla kontaktu (maksymalnie 200 znaków).'
        Case 'ERROR:4250'
            $sDescription = 'Błąd adresu e-mail dla kontaktu.'
        Case 'ERROR:4260'
            $sDescription = 'Błąd daty urodzenia kontaktu.'
        Case 'ERROR:4270'
            $sDescription = 'Błąd grupy dla danego kontaktu.'
        Case 'ERROR:4271'
            $sDescription = 'Grupa o podanej nazwie nie została znaleziona.'
        Case 'ERROR:4272'
            $sDescription = 'Przy operacji na kontaktach wymagana jest nazwa grupy.'
        Case 'ERROR:4280'
            $sDescription = 'Błąd płci kontaktu.'
    EndSwitch
    Return 'SMSAPI: ' & $sError & ': ' & $sDescription
EndFunc   ;==>_SMSApi_Error

Unfortunately statuses are in Polish, but can be easily adjusted through the list from this link: https://www.smsapi.com/resp

btw. I never used 

_SMSApi_Status()

so for now, there is no example .

 

mLipok

 

EDIT: UDF changed - added _SMSApi_URL()

Edited by mLipok

Signature beginning:   Wondering who uses AutoIT and what it can be used for ?
* GHAPI UDF - modest beginning - communication with GitHub REST API Forum Rules *
ADO.au3 UDF     POP3.au3 UDF     XML.au3 UDF    How to use IE.au3  UDF with  AutoIt v3.3.14.x  for other useful stuff click the following button

Spoiler

Any of my own code posted anywhere on the forum is available for use by others without any restriction of any kind. 

My contribution (my own projects): * Debenu Quick PDF Library - UDF * Debenu PDF Viewer SDK - UDF * Acrobat Reader - ActiveX Viewer * UDF for PDFCreator v1.x.x * XZip - UDF * AppCompatFlags UDF * CrowdinAPI UDF * _WinMergeCompare2Files() * _JavaExceptionAdd() * _IsBeta() * Writing DPI Awareness App - workaround * _AutoIt_RequiredVersion() * Chilkatsoft.au3 UDF * TeamViewer.au3 UDF * JavaManagement UDF * VIES over SOAP * WinSCP UDF * GHAPI UDF - modest begining - comunication with GitHub REST APIErrorLog.au3 UDF - A logging Library *

My contribution to others projects or UDF based on  others projects: * _sql.au3 UDF  * POP3.au3 UDF *  RTF Printer - UDF * XML.au3 UDF * ADO.au3 UDF SMTP Mailer UDF * Dual Monitor resolution detection * * 2GUI on Dual Monitor System * _SciLexer.au3 UDF * SciTE - Lexer for console pane

Useful links: * Forum Rules * Forum etiquette *  Forum Information and FAQs * How to post code on the forum * AutoIt Online Documentation * AutoIt Online Beta Documentation * SciTE4AutoIt3 getting started * Convert text blocks to AutoIt code * Games made in Autoit * Programming related sites * Polish AutoIt Tutorial * DllCall Code Generator * 

Wiki: Expand your knowledge - AutoIt Wiki * Collection of User Defined Functions * How to use HelpFile * Good coding practices in AutoIt * 

IE Related:  * How to use IE.au3  UDF with  AutoIt v3.3.14.x * Why isn't Autoit able to click a Javascript Dialog? * Clicking javascript button with no ID * IE document >> save as MHT file * IETab Switcher (by LarsJ ) * HTML Entities * _IEquerySelectorAll() (by uncommon) * IE in TaskScheduler

I encourage you to read: * Global Vars * Best Coding Practices * Please explain code used in Help file for several File functions * OOP-like approach in AutoIt * UDF-Spec Questions *  EXAMPLE: How To Catch ConsoleWrite() output to a file or to CMD *

"Homo sum; humani nil a me alienum puto" - Publius Terentius Afer
"Program are meant to be read by humans and only incidentally for computers and execute" - Donald Knuth, "The Art of Computer Programming"
:naughty:  :ranting:, be  :) and       \\//_.

Anticipating Errors :  "Any program that accepts data from a user must include code to validate that data before sending it to the data store. You cannot rely on the data store, ...., or even your programming language to notify you of problems. You must check every byte entered by your users, making sure that data is the correct type for its field and that required fields are not empty."

Signature last update: 2019-10-01

Share this post


Link to post
Share on other sites
;http://developer.bulksms.com/eapi/libraries/supported/

Private Sub cmdSendTextMessage_Click()

    Dim oHttp As Object
    Dim strUrl, strUsername, strPassword, strMessage, strMobileNumber  As String
    Set oHttp = CreateObject("Microsoft.XMLHTTP")
    strUsername = "your username"
    strPassword = "your password"
    strMessage = "your message text goes here…"
    strMobileNumber = "your mobile number in the format 44your_number_with_the_zero_removed"
    
    strUrl = "http://www.bulksms.co.uk:5567/eapi/submission/send_sms/2/2.0?username=" + strUsername + "&password=" + strPassword + "&message=" + strMessage + "&msisdn=" + strMobileNumber
    
    oHttp.Open "GET", strUrl, False
    oHttp.send
    
    MsgBox (oHttp.responseText)
    
End Sub

Found this on the BulkSMS site. Looks very similar to Trancexx first post. :)

Obviously there is more than one way to do this.

Thx mLipok.  


Skysnake

Why is the snake in the sky?

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now

  • Similar Content

    • By Skysnake
      This is relevant
      From here https://stackoverflow.com/questions/3454315/is-it-possible-to-pin-a-dll-in-memory-to-prevent-unloading
      I use several UDFs on the Forum to do various things.  Those UDFs work very well.
      Effectively the UDFs are DLL wrappers, that make it possible to access DLL functions easily without the long hard slog of DLLCall() every time.
      However, I have now run into the issue that multiple UDF DLLCalls are slow. Not mind numbingly slow, but slow enough to become noticeable with a large of repeated function calls.
      So I was wondering, is it possible to "load a DLL into memory" and leave it there for the duration of my script's lifetime, avoid repeated DLL on-disk reads with a persistent in memory DLL?
      From Microsoft
      https://docs.microsoft.com/en-us/windows/desktop/dlls/about-dynamic-link-libraries
      Looks like what I want to do is: load-time dynamic linking,
      So next question, (a) how do I do this with AutoIt (b) How would this impact on standard AutoIt type DLL calls?
       
      The point is speed.  Is there a different approach?
      Or am I barking up the wrong tree?
      Skysnake
    • By supersonic
      Hi -
      Currently I'm playing around with Windows Credential Manager. I'm trying to access it with DllCall("advapi32.dll", ...) using the functions 'CredWriteW', 'CredReadW' and 'CredDeleteW'. All well. Another function I have to deal with is 'CredEnumerateW': https://docs.microsoft.com/en-us/windows/desktop/api/wincred/nf-wincred-credenumeratew/ .
      That's the test code I have so far:
      #include <Array.au3> #include <String.au3> Local $tCredentialsCount = DllStructCreate("DWORD;") Local $tPointerToArrayOfPointers = DllStructCreate("PTR;") ; Local $tPointerToArrayOfPointers = DllStructCreate(_StringRepeat("PTR;", 200)) ; ??? Local $aResult = DllCall("advapi32.dll", "BOOL", "CredEnumerateW", _ "WSTR", Null, "DWORD", 1, "DWORD", DllStructGetPtr($tCredentialsCount), "PTR", DllStructGetPtr($tPointerToArrayOfPointers)) If (Not @error) Then Local $iCredentialsCount = DllStructGetData($tCredentialsCount, 1) _ArrayDisplay($aResult, $iCredentialsCount) Local $hPointerToArrayOfPointers = DllStructGetData($tPointerToArrayOfPointers, 1) MsgBox(0, "$hPointerToArrayOfPointers", $hPointerToArrayOfPointers) ; Fails... For $i = 1 To 10 ; $iCredentialsCount MsgBox(0, $i & "___" & (($i * 2) - 1), DllStructGetData($tPointerToArrayOfPointers, ($i * 2) - 1)) Next $tCredentialsCount = 0 $tPointerToArrayOfPointers = 0 DllCall("advapi32.dll", "NONE", "CredFreeW", "PTR", $hPointerToArrayOfPointers) EndIf The DllCall seems to function properly - I get a valid count of credentials (on my computer ~ 133) and a pointer "to array of pointers".
      What is meant by "array of pointers"?
      Microsoft says: Pointer to an array of pointers to credentials. The returned credential is a single allocated block. Any pointers contained within the buffer are pointers to locations within this single allocated block.
      How to access these pointers... Contained within the buffer???
      Any information you can provide me would be greatly appreciated.
    • By bladem2003
      Hello,
      i need help to translate the c code to autoit .
      I don't understand the callback function.
       
      #include <windows.h> #include <stdio.h> // native IR Data by PAnsiChar typedef void CALLBACK CallBackPAnsiChar(char*, char*, char*, char*); typedef int (__stdcall *impInitPAnsiChar)(CallBackPAnsiChar); CALLBACK MyCallBackPAnsiChar(char* Protocol, char* Address, char* Command, char* Flags) { printf("\nIR Data received: Protocol: %s, Address: 0x%s, Command: 0x%s, Flags: 0x%s", Protocol, Address, Command, Flags); fflush(stdout); } int main(int argc, char **argv) { impInitPAnsiChar InitPAnsiChar = NULL; // Load DLL file HINSTANCE hinstLib = LoadLibrary(TEXT("USB_IR_Remote_Receiver.dll")); if (hinstLib == NULL) { printf("\nERROR: unable to load DLL\n"); return 1; } // Get function pointer InitPAnsiChar InitPAnsiChar = (impInitPAnsiChar)GetProcAddress(hinstLib, "InitPAnsiChar"); if (InitPAnsiChar == NULL) { printf("\nERROR: unable to find DLL function\n"); FreeLibrary(hinstLib); return 1; } if (InitPAnsiChar(*MyCallBackPAnsiChar)) { printf("\nInit DLL with InitPAnsiChar successfull"); } else { // Unload DLL file FreeLibrary(hinstLib); return 0; } while(1) { } //return 0; }  
    • By Yirrlaar
      Hello All,
      I'm using "ImageSearch2015.au3" and i'm trying to figure out WHY, for the life of me, I can't find an image is hidden.
      So what I came up with, is as follows:
      _ImageSearchAreaHidden("C:\icon.png", 1, 0, 0, 800, 600, $x1, $y1, 80, 0) Func _ImageSearchAreaHidden($findImage, $resultPosition, $x1, $y1, $right, $bottom, ByRef $x, ByRef $y, $tolerance, $transparency = 0) Local $h, $result local $TestScreen = "C:\TestScreen.png" ;previsous screenshot of the image looking for, fully visible If Not FileExists($findImage) Then Return "Image File not found" If $transparency <> 0 Then $findImage = "*" & $transparency & " " & $findImage If $tolerance < 0 Or $tolerance > 255 Then $tolerance = 0 If $h_ImageSearchDLL = -1 Then _ImageSearchStartup() If $tolerance > 0 Then $findImage = "*" & $tolerance & " " & $findImage $result = DllCall($h_ImageSearchDLL, "str", "ImageSearchEx", "str", $TestScreen, "int", $x1, "int", $y1, "int", $right, "int", $bottom, "str", $findImage) If @error Then Return "DllCall Error=" & @error If $result = "0" Then Return False $array = StringSplit($result[0], "|") If (UBound($array) >= 4) Then $x = Int(Number($array[2])) ; Get the x,y location of the match $y = Int(Number($array[3])) If $resultPosition = 1 Then $x = $x + Int(Number($array[4]) / 2) ; Account for the size of the image to compute the centre of search $y = $y + Int(Number($array[5]) / 2) EndIf Return True EndIf EndFunc ;==>_ImageSearchAreaHidden Now when the folder with the icon is completely visible, it finds the icon without any issues, however if I cover up the icon, it no longer finds the image in the folder.
      Any ideas?
    • By Bilgus
      So first things first the example in the help file for _WinApi_Enum_Windows has an error
      ;_ArrayDisplay($aResult, "_WinAPI_EnumWindows", Default, Default, Default, Default, "#|Handle|Class|Title|Text|Process") Should Be _ArrayDisplay($aResult, "_WinAPI_EnumWindows", Default, Default, Default, "Handle|Class|Title|Text|Process") Next is a bit of helpful info on LPCSTR in a callback function it needs  to be passed as a PTR
      DllCallbackRegister($sFUNCT, $sRETURN, "ptr") Finally on to my question
      I'd want to call EnumPropsEX and pass a string through lparam + append to it rather than declaring anything globally
      I can Come up with two ways to do this The second it a lot more code but possibly safer but the first way I think Should do
      1. From a bit of testing It seems AutoIt won't overflow a DllStruct?
      2. Are strings passed through DLL call guaranteed to be 'an ANSI string (a minimum of 65536 chars is allocated)' as the Helpfile clearly states?
      #include <Array.au3> #include <WinAPI.au3> Example() Func Example() Local $aWindows = _WinAPI_EnumWindows() Local $aResult[$aWindows[0][0]][6] For $i = 1 To $aWindows[0][0] $aResult[$i - 1][0] = "0x" & Hex($aWindows[$i][0], 8) $aResult[$i - 1][1] = $aWindows[$i][1] $aResult[$i - 1][2] = WinGetTitle($aWindows[$i][0]) $aResult[$i - 1][3] = WinGetText($aWindows[$i][0]) $aResult[$i - 1][4] = WinGetProcess($aWindows[$i][0]) $aResult[$i - 1][5] = _ArrayToString(EnumProps($aWindows[$i][0]), ", ", 1) Next _ArrayDisplay($aResult, "_WinAPI_EnumWindows", Default, Default, Default, "Handle|Class|Title|Text|Process|Properties") EndFunc ;==>Example Func EnumProps($hWnd, $vDLL = 'user32.dll') ; Create callback function. Local $iErr = 0 Local $aProps[1] = [0] Local $hCb = DllCallbackRegister('_PropEnumProcEx', 'int', 'hwnd;ptr;handle;ptr') ; Call EnumPropsEx Local $aRet = DllCall($vDLL, 'int', 'EnumPropsEx', 'HWND', $hWnd, 'ptr', DllCallbackGetPtr($hCb), 'str', "") If @error Or Not $aRet[0] Then $iErr = @error ConsoleWrite("EnumProps Error:" & $iErr & @CRLF) ElseIf $aRet[3] <> "" Then $aProps = StringSplit($aRet[3], ";") EndIf DllCallbackFree($hCb) Return SetError($iErr, 0, $aProps) EndFunc ;==>EnumProps Func _PropEnumProcEx($hWnd, $sProp, $hData, $pStr) Local $iSzStr = _WinAPI_StringLenA($sProp) + 1 ; + Null Char If $iSzStr > 1 Then Local $tProp = DllStructCreate('char[' & $iSzStr & ']', $sProp) Local $tRetn = DllStructCreate('char[65535]', $pStr) DllStructSetData($tRetn, 1, DllStructGetData($tRetn, 1) & DllStructGetData($tProp, 1) & ";") EndIf Return 1 EndFunc ;==>_PropEnumProcEx ;-------------------------------------------------------------------------------------------------------------- Func EnumProps2($hWnd, $iSzBuffer = 4096, $vDLL = 'user32.dll') ; Create callback function. Local $iErr = 0 Local $sProps Local $aProps[1] = [0] Local $hCb = DllCallbackRegister('_PropEnumProcEx', 'int', 'hwnd;ptr;handle;ptr') Local $tProps = DllStructCreate('int;int;char[' & $iSzBuffer & ']') DllStructSetData($tProps, 1, $iSzBuffer) ;BufferSz DllStructSetData($tProps, 2, $iSzBuffer) ;BufferRemaining ; Call EnumPropsEx Local $aRet = DllCall($vDLL, 'int', 'EnumPropsEx', 'HWND', $hWnd, 'ptr', DllCallbackGetPtr($hCb), 'ptr', DllStructGetPtr($tProps)) If @error Or Not $aRet[0] Then $iErr = @error DllStructSetData($tProps, 2, 0) EndIf DllCallbackFree($hCb) $sProps = DllStructGetData($tProps, 3) If DllStructGetData($tProps, 2) > 0 Then If $sProps <> "" Then $aProps = StringSplit(StringTrimRight($sProps, 1), ";") EndIf Else If Not $iErr Then $iErr = 6 ;buffer overflow Return SetError($iErr, -DllStructGetData($tProps, 2), $aProps) EndIf Return $aProps EndFunc ;==>EnumProps2 Func _PropEnumProcEx2($hWnd, $sProp, $hData, $ptProp) Local $iSzStr = _WinAPI_StringLenA($sProp) + 1 Local $tProp = DllStructCreate('char[' & $iSzStr & ']', $sProp) If $iSzStr > 1 Then Local $sRet = DllStructGetData($tProp, 1) Local $iSzBuffer = DllStructGetData(DllStructCreate('int', $ptProp), 1) Local $tRetn = DllStructCreate('int;int;char[' & $iSzBuffer & ']', $ptProp) DllStructSetData($tRetn, 2, DllStructGetData($tRetn, 2) - $iSzStr) If DllStructGetData($tRetn, 2) > 0 Then DllStructSetData($tRetn, 3, DllStructGetData($tRetn, 3) & $sRet & ";") EndIf EndIf Return 1 EndFunc ;==>_PropEnumProcEx2  
×
×
  • Create New...