DOCUMENT:Q80252 04-NOV-1999 [pcmail] TITLE :PC Gen: Contents of Modem Script File CREDCARD.MDM PRODUCT :Microsoft Mail For PC Networks PROD/VER:WINDOWS:2.1e OPER/SYS: KEYWORDS: ====================================================================== ------------------------------------------------------------------------------- The information in this article applies to: - Microsoft Mail for PC Networks, version 2.1e ------------------------------------------------------------------------------- SUMMARY ======= The following is the contents of the Microsoft Mail version 2.1E modem script file CREDCARD.MDM, which can be compiled with SCRCOMP.EXE: ;******************************************************************** ; ; Microsoft Mail Script File ; ; Filename: credcard.mdm ; Date : March 21, 1990 ; Script : Standard script file for Hayes-compatible modems ; modified to allow use of credit card dialing. ; ; This script file contains the standard modem setup strings used ; by the External, Transmit and Listen programs. There are five ; procedures defined in this script file for setting up the modem ; and for connecting to a remote External machine. ; ; The modem setup strings used here will be adequate for most ; people but there may be some changes required if you are dialing ; overseas and require a longer wait for Carrier Detect (S7 register) ; or if you wish to change the speaker volume. Note that if you used ; the -Innn option in version 1.0 or 2.0 that you will have to modify ; the S7 register and recompile this script file. ; ; Consult your modem manual for more information on setup options. ; ; Script procedures defined: ; INITIALIZE ; RESET ; CALL ; ANSWER ; DISCONNECT ; ; Return codes for External, Transmit, Listen: ; 0 - OK ; 1 - CONNECT 300 ; 2 - not defined ; 3 - NO CARRIER ; 4 - ERROR ; 5 - CONNECT 1200 ; 6 - not defined ; 7 - BUSY ; 8 - NO ANSWER ; 9 - not defined ; 10 - CONNECT 2400 ; 11 - not defined ; 12 - CONNECT 9600 (high speed connection) ; ; ;******************************************************************** INITIALIZE: title "Credit Card Script" $attempts = 5 init_retry: sendln "ATZ" ; reset modem to default settings wait 2 waitrsp 1 if ("0" isin response) goto reset_okay if ("OK" isin response) { reset_okay: sendln "ATE0V0" wait 1 waitrsp 1 if ("0^M" isin response) { sendln "ATS0=0S7=45S9=6S10=50S12=50" waitrsp 1 if (response = "0^M") return 0 } } dec $attempts if ($attempts > 0) goto init_retry return 4 RESET: sendln "ATZ" ; reset modem to default settings wait 2 waitrsp 1 if ("0" isin response) goto reset_okay if ("OK" isin response) { reset_okay: sendln "ATE0V0" wait 1 waitrsp 1 if ("0^M" isin response) { sendln "ATS0=0S7=45S9=6S10=50S12=50" waitrsp 1 if (response = "0^M") return 0 else return 4 } } return 4 CALL: $ret = 8 ; set default ret code to "no answer" clearrsp ; clear the response buffer echo 0 ; do not display phone number ; If this script is specified in the phone number field then the ; initialize script in the default script file may have turned off the ; speaker. The following commands will turn the speaker back on for ; Hayes compatible modems: ; sendln "ATM1" ; turn speaker on waitrsp 1 ; get the response back from the modem ; In order to make credit card dialing work, the modem being used must ; support the ";" dial modifier. This character returns the modem to ; command state after the dial string is sent, allowing us to proceed ; with further processing. The operator is prompted to press a key. ; When he does, send another dial string. This time the dial string ; is the credit card number. ; Remember that the phone number must be in the form: ; 0 - area code - number ; ; sendln "ATD" + dial_mode + phone_number + ";" ; execute the ; dial up echo 1 ; turn echo back on display 'Press any key when you hear the "bong"...' ; Wait until a key is struck operator_wait_loop: getkey if (key = 0) goto operator_wait_loop ; Now send the credit card number. You will have to replace the ; number used here with your credit card number. echo 0 ; do not display credit card number sendln "ATD" + dial_mode + "123-456-7890" echo 1 ; echo back on to see response waitrsp 2 ; should get "OK" from modem if (response != "0^M") return $ret waitrsp 120 ; wait up to 2 minutes for return code ; from modem if (response = "1^M") { baud 300 display ">>> CONNECT 300 <<<" $ret = 1 } else if (response = "3^M") { display ">>> NO CARRIER <<<" $ret = 8 ; no answer or no connect } else if (response = "5^M") { baud 1200 display ">>> CONNECT 1200 <<<" $ret = 5 } else if (response = "10^M") { baud 2400 display ">>> CONNECT 2400 <<<" $ret = 10 } return $ret ; return connect baud rate to ; application ANSWER: $ret = 8 ; set default ret code to "no answer" waitrsp 1 ; see if phone is ringing if (response = "2^M") ; 2 is numeric form of "RING" { if (listen = 1) ; see if Listen program is running or sendln "ATD" ; not answer phone in originate mode ; (Listen) else sendln "ATA" ; answer the phone normally waitrsp 120 ; wait up to 2 minutes for return code ; from modem if (response = "1^M") { baud 300 display ">>> CONNECT 300 <<<" $ret = 1 } else if (response = "3^M") { display ">>> NO CARRIER <<<" $ret = 3 ; no answer or no connect } else if (response = "5^M") { baud 1200 display ">>> CONNECT 1200 <<<" $ret = 5 } else if (response = "10^M") { baud 2400 display ">>> CONNECT 2400 <<<" $ret = 10 } } return $ret ; return connect baud rate to ; application DISCONNECT: wait 2 ; wait 2 seconds send "+++" ; send escape sequence to put modem ; back to command state wait 2 ; wait 2 seconds clearrsp ; clear the response buffer send "ATH0^M" ; hang up the phone waitrsp 1 ; wait for a response if (response != "0^M") ; if hang up failed, drop DTR to force ; hang up { DTR 0 ; drop DTR to reset modem wait 2 ; some modems require a delay here DTR 1 ; raise DTR } return 0 ; always return OK Additional query words: 2.10 2.1 2.10e ====================================================================== Keywords : Technology : kbMailSearch kbZNotKeyword3 kbMailPCN210e Version : WINDOWS:2.1e ============================================================================= THE INFORMATION PROVIDED IN THE MICROSOFT KNOWLEDGE BASE IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND. MICROSOFT DISCLAIMS ALL WARRANTIES, EITHER EXPRESS OR IMPLIED, INCLUDING THE WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL MICROSOFT CORPORATION OR ITS SUPPLIERS BE LIABLE FOR ANY DAMAGES WHATSOEVER INCLUDING DIRECT, INDIRECT, INCIDENTAL, CONSEQUENTIAL, LOSS OF BUSINESS PROFITS OR SPECIAL DAMAGES, EVEN IF MICROSOFT CORPORATION OR ITS SUPPLIERS HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. SOME STATES DO NOT ALLOW THE EXCLUSION OR LIMITATION OF LIABILITY FOR CONSEQUENTIAL OR INCIDENTAL DAMAGES SO THE FOREGOING LIMITATION MAY NOT APPLY. Copyright Microsoft Corporation 1999.