PC Gen: Contents of Modem Script File CREDCARD.MDM

ID: Q80252


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 :
Version : WINDOWS:2.1e
Platform : WINDOWS
Issue type :


Last Reviewed: November 3, 1999
© 2000 Microsoft Corporation. All rights reserved. Terms of Use.