Application program interface for message routing and management system

Information

  • Patent Application
  • 20050198356
  • Publication Number
    20050198356
  • Date Filed
    October 28, 2004
    19 years ago
  • Date Published
    September 08, 2005
    19 years ago
Abstract
Transmission of messages composed on one or more input devices to a single or multiple recipients by means of one or plural communication modes is facilitated. Such communication modes may include conventional or wireless telephone, facsimile transmission, pager, e-mail, postal mail or courier. An application program interface (API) mediates between remote applications requesting messaging functions and a message server that actually implements these functions. The API is capable of processing high-volume requests for message routing, status information, and various other functions on an automated basis, enabling businesses to make routine use of these functions.
Description
FIELD OF THE INVENTION

The present invention relates to communication services, and in particular to delivery of messages to selected recipients through one or more specified communication modes.


BACKGROUND OF THE INVENTION

Thanks to improvements in technology and widespread consumer interest, once-exotic forms of communication have become commonplace, and today the average consumer has access to a broad array of communications services. The Internet and wireless telephony, once the preserve of an elite few, now routinely supplement traditional telephone services and are frequently supplied by the same carriers. Even inexpensive home computers now include facsimile capability. Businesses employing mobile employees can furnish them with economical pagers that incorporate advanced features, such as text transmission and Internet access.


The sheer proliferation of communication options, while greatly improving access and convenience, has engendered problems as well. The existence of a communication channel does not ensure that the recipient of a message will be “listening” to that particular channel at a given time, yet the sender of a message has no way to know this. Indeed, more channels of communication traffic mean more demands on the attentions of potential recipients, who, feeling besieged by the assault of e-mail, voice mail, pages, etc., may simply inactivate some communication devices at different times. Message senders, therefore, are faced with the choice of risking non-delivery of their messages, or painstakingly re-transmitting a message on every possible mode of communication modality.


It may also be difficult to transmit the same message to multiple recipients. While a single e-mail message, sent once, can reach an unlimited number of destinations, phone messages must be repeated for each call. Moreover, different recipients may have access to different types of communication channels; perhaps some recipients can be reached efficiently only by e-mail, others by fax, and still others by page.


The integration of communication input devices also raises the prospect of messages having multiple forms of content. Today, a single message may include input from a variety of sources (e.g., voice and text); transmitting such a message by traditional means may be quite cumbersome, involving multiple separate transmissions that must be coordinated or difficult “packaging” of the different inputs into a single message.


U.S. Ser. No. 09/496,170, filed on Feb. 1, 2000 and entitled Multi-Mode Message Routing and Management (the entire disclosure of which is hereby incorporated by reference) addresses these difficulties and discloses, inter alia, a facility for transmission of messages composed on one or more input devices to a single or multiple recipients by means of one or plural communication modalities. Such communication modalities may include, for example, conventional or wireless telephone, facsimile transmission, pager, e-mail, postal mail or courier. Thus, a message may be directed to a single recipient via multiple modalities, such as e-mail and fax, in order to ensure the earliest possible receipt of the message; or may be directed to multiple recipients by a single modality or by different modalities (e.g., some recipients receive the message by e-mail, others by fax, others by phone). The facility may be configured to respond to defined “escalation” rules that specify conditions under which different delivery modalities may be sequentially employed. For example, the rules may specify that if there is no response to an e-mailed question within an hour, the recipient is to be telephoned. Moreover, in addition to alternative transmission modalities, the escalation rules may specify alternative recipients (as well as alternative modalities for those recipients). The escalation rules may also specify default contact methods, which may apply to specific individuals or to lists of recipients.


The invention disclosed in the '170 application may include functionality for determining whether a message has been received (e.g., telephone and e-mail polling), as well as automatic sender notification upon confirmation of receipt. Moreover, in addition to monitoring messages in order to confirm their receipt, the invention may facilitate recipients' responses. In this way, the invention can orchestrate multi-question surveys utilizing multiple communication modes; for example, individuals contacted directly can respond immediately, while others can respond later in accordance with instructions delivered to them—e.g., via a web site or by calling a toll-free number.


The invention disclosed in the '170 application supports messages having embedded questions that call for response by the recipient. Such responses, when received, may be communicated to the message sender and/or accumulated.


Also facilitated by the invention disclosed in the '170 is scheduling of message delivery, on a mode-by-mode basis where appropriate. Scheduling may include delivery at a particular time or within a designated time window, or may involve preventing delivery during specified “black-out” periods. In some embodiments, scheduling may be automatic and based on considerations such as the recipient's time zone and the form of communication (e.g., to avoid awakening the recipient by telephone).


However, the '170 application contemplates a system in which customers' client computers communicate via the World Wide Web (the “web”) with a server implementing the foregoing functions. In other words, the interaction is essentially manual and stepwise in nature, with customers selecting options and indicating preferences in an interactive session. This model is generally unsuited to business applications requiring more automated, high-volume access to messaging functions.


DESCRIPTION OF THE INVENTION

Brief Summary of the Invention


The present invention provides an application program interface (API) facilitating interaction, generally (although not necessarily) via the Internet, with a message-handling facility such as that disclosed in the '170 application. In accordance with the invention, application programmers utilize a markup language (preferably XML-derived) to configure applications for compatibility and communication with the message-handling facility. The API is capable of processing high-volume requests for message routing, status information, and various other functions on an automated basis, enabling businesses to make routine use of these functions.


Indeed, the range of business-to-business and business-to-consumer organizations that can benefit from flexible messaging services is virtually limitless. For example, an airline may obtain contact information from passengers when tickets are purchased. Should a flight be delayed or cancelled, the airline can generate a single notification for transmission to all passengers via the messaging facility; as the flight time approaches, efforts to reach passengers not yet contacted can be intensified according to defined escalation rules. Similarly, a club or other organization can send out notices of meetings, receive confirmations and preferences from members, and alert them to changes using the messaging facility by means of the API. The message need be written and transmitted by the organization only once; all remaining operations, from bulk retransmission to collecting and organizing responses, are performed automatically.


In accordance with the invention, a message server comprising a plurality of modalities for transmitting messages is associated with an API. An application, typically implemented on a remote server, is configured to receive a message and a designation of one or more transmission modalities, and is further adapted for interaction with the API. The API comprises stored instructions supporting the interaction. Upon receiving the message and the designation from the application server, the API causes the message server to transmit the message according to the designation.




BRIEF DESCRIPTION OF THE DRAWINGS

The foregoing discussion will be understood more readily from the following detailed description of the invention, when taken in conjunction with the accompanying drawings, in which:



FIG. 1 schematically represents the environment of the invention; and



FIG. 2 schematically illustrates the components of the API and its mode of interaction.




DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS
1. Technical Context

The functions of the messaging system are implemented by a server 125, which may be realized as a single workstation or as a network of server computers, depending on the activity level and included functionality. For explanatory purposes, server 125 is represented as a single machine that includes a network interface 127 continuously connected to the Internet. Network interface 127 and the other internal components of server 125 intercommunicate over a main bidirectional bus 130 (which may be a physical bus in a single hardware device, or can instead represent a network such as a LAN or a WAN). The main sequence of instructions effectuating the functions of server 125 and facilitating interaction among customers, server 125, the Internet, and other modes of communication reside on a mass storage device (such as a hard disk or optical storage unit) 132 as well as in a main system memory 134 during operation. Execution of these instructions and effectuation of the functions of server 125 is accomplished by a central-processing unit (“CPU”) 136.


A group of functional modules that control the operation of CPU 136 and perform the operations of server 125 is shown conceptually as located in system memory 134; once again, however, it should be stressed that this organization is for explanatory purposes. The various modules and servers may indeed be implemented as active processes running on a single machine, but functionality may instead be distributed among multiple machines (or processors within a single machine), once again depending on the activity level and included capabilities.


An operating system 140 directs the execution of low-level, basic system functions such as memory allocation, file management, and operation of mass storage devices 132. At a higher level, a control block 142, implemented as a series of stored instructions, manages interaction among the various functional components of the server and ensures proper routing of data thereamong.


Although server 125 may be capable of communicating directly with customers by means of the web and electronic mail, as explained in the '170 application, the present application is concerned primarily with hardware-to-hardware communications. Accordingly, an API 145 receives and processes communications from external sources, and transmits proper responses to those sources, via network interface 127. API 145 represents a programmatic interface for direct connection to appropriately configured third-party applications. The pattern of interaction with the external source, including the content of transmissions thereto, is handled by a transaction server 150. Transaction server 150 has access to various databases, collectively indicated at 152; these databases, discussed in greater detail below, are ordinarily stored on devices 132 and accessed as necessary. Depending on the requests received by API 145, transaction server 150 causes messages to be assembled and transmitted to designated contacts, and retrieves and assembles information for transmission to outside inquiries. Credit-card validation and billing for services are handled by a billing server 160.


The various functions performed by server 125, which result in different patterns of interaction with customers, will now be described.


1.1 Media Conversion and Basic Message Transmission

A series of media servers, collectively indicated at 175, represent the interface servers that format messages for transmission; these messages may be in the form of voice, text (for transmission by e-mail, web or postal mail), or other desired format. Messages and media designations are received from remote applications via API 145, and once transaction server 150 has received sufficient commands and content to fully specify a message (i.e., the message body, the recipient(s), desired delivery methods, and message options such as delivery scheduling and/or escalation rules), a message “job” is created and stored in a database 152. The job is passed to a job queue server 165, which is responsible for implementing and scheduling all message jobs.


At this point, the message remains in the format in which it was generated. As noted previously, however, server 125 is capable of receiving messages, via the interface servers, in one format and transmitting them in a different, customer-selected format. The functions of media conversion and message assembly are performed by a series of message delivery servers, collectively illustrated at 167, dedicated thereto. The appropriate message delivery server 167 converts messages to the specified format and causes their transmission, via the designated communication medium, by means of a corresponding device driver selected from among a suite of drivers. The drivers operate a series of transmission devices, which include network interface 127 for e-mail and/or web-based message delivery; a telephone interface 170 for message transmission by telephone, facsimile, pager, or handheld wireless device (although it should be noted that pager and wireless transmission can occur through network interface 127); and a document-generation module 172 for message transmission by postal mail or overnight courier.


The timing of message transmission is governed by job queue server 165. In response to the customer's authorization to send a message, job queue server 165 triggers the conversion and transmission operations just discussed. Job queue server 165 also contains (or, as shown for illustrative purposes, communicates with) a scheduling module 180, which can orchestrate transmission of messages at customer-specified times based on the computer's internal clock.


Server block 165 may contain a text-to-speech conversion module, enabling customer-provided text to be transmitted by voice to the recipient by means of telephone interface 170. Conversely, telephony server 175 may be configured to respond to spoken customer commands, allowing the customer to compose and address a message by telephone (i.e., by communicating with server 125 by means of telephone interface 170).


In still more complex operational modes, server 125 may facilitate catenation of message—either as separate segments of the same format, or as segments encoded in different formats. In the case of audio messages, for example, a message delivery server 167 may append an audio “header” (typically a so-called “professional prompt”) and a “trailer” to the customer's message. Thus, when the recipient answers the telephone, the header portion of the message may tell him that he is about to receive a message from the customer, and the trailer portion may facilitate response (as explained in further detail below).


1.2 Confirming Message Receipt

Any of a variety of techniques can be used to assess whether and when a message is received. Many e-mail systems natively support receipt confirmation. Alternatively, a URL can be embedded in the message; when the recipient receives the e-mail and clicks on this URL, receipt is automatically recorded. Moreover, the URL-specified web page may contain questions inviting response by the recipient, who thereupon transmits the web page back to server 125.


Hard-copy deliveries can be tracked through the courier or by means of a follow-up telephone call to the recipient, while for telephone messages, the recipient can be asked to press a number to confirm receipt. In the context of telephone messages, it may be useful to detect whether a person or an answering machine has answered the phone. This determination can be used, for example, to select a proper audio header or even to choose between alternative messages, which may differ depending whether the message is delivered to the recipient or a recording device; an answering machine, obviously, would not be asked to press a number to confirm receipt, nor would delivery typically be confirmed to the sender if the message was left on an answering machine. To implement answer detection, telephony server 147 is programmed to monitor the level of noise on the line once a connection is established, distinguishing between a “silence” noise level and a “speech” level. If an individual answers, he or she will typically issue a short greeting; that is, the signal pattern of a human answer is a short speech signal followed by silence. An answering machine, by contrast, will generally issue a long greeting (“Hello, you have reached the Smiths . . . ”). Based on the observed lengths of a sustained speech signal and an ensuing silence, telephony server 147 forms an initial guess as to whether a person or a machine has answered. If a person is guessed, telephony server 147 will play the audio header that prompts the answerer to press a touch-tone key, and if the proper touch-tone pulse is not detected, server 147 may revise its guess and assume that it is communicating with an answering machine.


1.3 Message Scheduling

It may not be appropriate to transmit messages by certain modes during particular time periods at the recipient's location. These “blackout” time periods may be established automatically by server 125, or may be designated by the customer or the recipient. Via API 145, an external application may indicate blackout time periods for a particular message, or may permanently designate such periods for particular contacts (and particular communication modalities). Most commonly, permanently designated blackout periods are used to prevent messages from being sent by telephone or pager during times when the recipient is generally likely to be asleep or away from the communication modality. Message-specific blackout periods may be utilized by message senders familiar with the recipient's immediate schedule, or who do not wish to permanently establish blackout periods.


Conversely, the external source may specify particular allowed time windows within which a message must be delivered. Once again, these may be established permanently for particular contacts or “on the fly” for specific messages.


Time-zone scheduling may be employed automatically. For example, if the customer authorizes immediate message delivery at a time that would be late at night where the recipient is located, or schedules message delivery for such a time, transaction server 150 may cause the customer to be prompted with this information and asked to confirm or reschedule delivery.


1.4 Escalation

Rather than send a message to a prospective recipient redundantly via multiple communication modalities, transaction server 150 may be configured to allow the specification of escalation rules for sequential transmission as necessary. The external application selects a plurality of communication modalities and/or contacts, and criteria in the form of rules governing their use. Typically, an escalation rule will specify resort to a different communication modality (or a different recipient) if delivery of the message is not confirmed by a specified time, or within a specified period, using the current communication modality.


Like scheduling restrictions, escalation rules may be defined permanently for a contact (and stored, along with “address book” information pertaining to that contact, in database 152b) or may instead be defined for a particular message. Default message modalities and permanent escalation rules are particularly useful in the context of distribution lists, since the external application can simply enter a message and leave it to server 125 to deliver it to every person on a selected distribution list in accordance with each contact's escalation rules. On the other hand, message-specific escalation rules may be designated for particular messages transmitted to API 145.


To implement the escalation rules, the time period specified in a rule relevant to the initial message transmission is sent to scheduler 180. At the end of that time period following transmission, transaction server 150 determines whether the message has been received in the manner described above. If not, the escalation rule (defined in database 152b or in the transaction record for the particular message) is executed, and the message re-transmitted by a different modality. If further escalation rules remain for the message, the appropriate time period is once again provided to scheduler 180, and the flow sequence repeated.


2. An Exemplary Application Program Interface

With reference to FIGS. 1 and 2, external sources such as a server 190 generate requests for messaging functions and status information, and transmit these to server 125 via a computer network, such as the Internet, for processing. FIG. 2 illustrates in greater detail the role and basic components of API 145. Requests are actually generated by an application 210 running as an active process on server 190. Application 210 formats these requests in the syntax allowed by API 145. Requests received by API 145 from application 210 are analyzed by a parser 210, which interprets the request and causes the various server modules of server 125 to take appropriate action. The server modules may generate direct responses to the requests or provide status information for transmission to application 210. A converter 220 places such information into statements conforming to the API syntax prior to transmission.


Preferably, the API syntax conforms to the conventions of XML, using “tags” to characterize elements such as statements and field data. A tag surrounds the relevant element(s), beginning with a string of the form <tagname> and ending with </tagname>. Thus, parser 215 can be (or be based on) a conventional XML parser.


The contents of a communication to or from API 145 take the form of a “document,” which contains an identifying tag and either a “Request” (for documents generated by application 210) or a “Response” (for documents that API 145 returns to applications 210). Document elements are hierarchically organized into objects. Each object specifies the contents of fields associated with the object, and may also contain one or more nested, hierarchically inferior objects; this structure maintains the organization of information, facilitates movement of information in meaningful packages, and allows for re-use of information without explicit repetition.


At the highest hierarchical level, “Super Objects” define the communication as a Request or a Response, and contain one or more “Major Objects.” The Major Objects specify key functional elements of messaging activities, defining the relevant user accounts and the nature of the desired message functions, and may contain sub-objects and/or entries for various fields within the Major Objects. Fields contain information, such as character strings or numbers, relevant to the objects containing them.


The overall organization of a preferred implementation of API 145 appears in summary form below; following the summary, the various objects and fields are described in greater detail. It should be understood that this API is illustrative only.

TABLE 1Basic API OrganizationI.Super Objects: contain required fields and one or more major objectsA.Request (fields:)i)UserNameii)Passwordiii)Domainiv)OEMIdv)OEMPasswordvi)RequestTypeB.Response: same fields/objects as request + errors, warningsII.Major Objects: required elements of documents, may contain sub-objects and fieldsA.Member (fields:)i)Commandii)Idiii)FirstNameiv)LastNamev)Companyvi)UserNamevii)Passwordviii)AllowNoticesix)DialinIdx)Dialin PasswordMember (subobjects:)i)Contact Methodii)Billing (fields: Id; Billing Plan; CurrentBalance)iii)Credit Card (fields you'd expect)B.Contact (subobjects:)i)Contact Method (fields:)a.Idb.Transportc.Qualifierd.Ordinale.PhoneNum, FaxNum, PagerNumf.Access Codeg.Email Addressh.Street1i.Street2j.Suitek.Cityl.Statem.Zipn.Countryii)Contact MethodRef (fields:)a.Idb.FirstName, LastName, Companyc.Transport, Qualifier, Ordinald.AllowMultipleContact (fields:)i)Commandii)Idiii)Prefix (optional)iv)First Name, Middle Name, Last Namev)Company (optional)vi)Title (optional)C.Distribution List (fields:)i.Command (create, replace, append, delete, remove)ii.Nameiii.Descriptioniv.IdD.Job (fields:)i.Idii.ChargesJob (subobjects:)i.Message (fields:)A.SubjectB.Template (optional)C.IdD.DateMessage (subobjects:)A.MessageArg Objects: series of Name/Value tags:1)SENDER2)BODY3)ASK_YESNO_QUESTION4)QUESTION_TO_ASK5)EMAIL_ADDRB.DeliveryTime ObjectsC.DeliveryTimeModifier Objectsii.Contact (to specify one-time recipient of message)iii.Delivery Request (elements:)A.DeliveryOptions field (in)B.Contact MethodRef sub-objectDelivery Request (returned elements:)A.ContactMethodB.ContactC.Delivery (fields:)1)Id2)Timestamp3)Duration4)Status (Not Sent, Sent, Failed, Cancelled,Cancel Pending)5)Details (Bad Address, Delivery Address isunreachable, No Answer, Busy, AnsweringMachine (assumed), Answering Machine,Maximum Delivery Attempts Exceeded,Acknowledged, Modem, Hangup, CallbackLater, Internal Error6)Size7)CostD.DeliveryRequest fields (out)1)Id2)EstDuration3)EstSize4)Status5)Details6)CompletedE.Range (fields:)i.Object (i.e., type of object trying to look up)ii.Typeiii.Startiv.End


Every transmission to API 145 requires a Request, which will generate a Response from API 145 (and the server modules with which it functions). The Request must identify one or more valid “Members” by means of UserNames. A request contains the following required fields:

TABLE 2Request FieldsAllowedFieldDescriptionIn/OutValuesExampleUserNameLogin name that identifies the memberInString<UserName>Ralphw</UserName>PasswordPassword for the member, assigned by theInString<Password>abc123domain</Password>DomainIdentifier (generally identifies theInString<Domain>POETS</Domain>company or organization to which themember belongs)OEMIdThe domain ID (identifies company orIn<OEMId>kkk52057kkorganization)</OEMId>OEMPasswordThe client passwordIn<OEMPassword>OEMpassword</OEMPassword>Request typeRequest one of the following actions:Invalidate<RequestType>validateValidate (Check all of the fields and sub-commit</RequestType>objects for syntax and validation errors;lookupdoes not take any additional action)Commit (Put the document in database,and initiate requested actions)Look up (Find objects in the database,based on specified criteria, used with theRange object only)


(In this and other tables, the In/Out column indicates whether the field is used in a Request (in), in a corresponding Response (out), or in both.)


In addition to fields, the Request will generally contain one or more Major Objects. Typical actions include: send message to specified recipients; add/edit/delete member, distribution list, contact information; look up the status of a job; send a billing inquiry. The following represents a typical Request (with the Contact Object, discussed in greater detail below, indicated but not actually specified):

<Request> <UserName>RalphW</UserName>  <Password>abc123</Password>  <Domain>POETS</Domain>  <OEMId>OEMId</OEMId>  <OEMPassword>OEMPassword</OEMPassword>  <RequestType>validate</RequestType> [Contact Object]</Request>


The Response is generally returned with the same objects that were included in the Request; if, however, the Request asks for information (e.g., a request for message status or for billing information), some objects or fields may be added or changed. In addition, the Response will contain Errors and Warnings fields as appropriate:

TABLE 3Errors and Warnings (Response Fields)AllowedFieldsDescriptionIn/OutValuesExampleErrorsSet to the number ofOutUnsigned<Errors>2</Errors>errors discoverd whileintegerprocessing the majorobjects included inthe RequestWarningsSet to the number ofOutUnsigned<Warnings>0</warnings>warnings (a less severe error)integerdiscoverd while processingthe major objects includedin the Request


Errors and Warnings are described in greater detail below.


The following represents a typical Response (with the Contact Object once again indicated but not actually specified):

<Response>  <UserName>Ralphw</UserName>  <Password>abc123</Password>  <Domain>Poets, Inc.</Domain>  <OEMId> OEMId<OEMId>  <OEMPassword> OEMPassword</OEMPassword>  <ResponseType>validate</ResponseType>  <Errors>2</Errors>  <Warnings>0</Warnings> [Contact Object]</Response>


Requests and Responses specify one or more Major Objects as follows:

TABLE 4Major ObjectsMajor ObjectDescriptionMemberUser-level login that identifies a useraccount (end user or member)ContactPerson or organization to which amessage may be sentDistribution ListA group of contact methods (forexample, phone number, pager number, emailaddress) to which a message may be sentJobMessage to one or more contacts usingone or more contact methodsRangeUsed to look up other objects based onspecific search criteria; for example, tolook up a job by Id, or jobs sent on a certaindate, or all contacts from the sameorganization


Each Major Object contains zero or more fields and sub-objects, which may themselves contain additional sub-objects and/or fields. The various Major Objects will now be described in detail.


Major Objects—Member: generally an end user of the messaging service.


Major Objects—Member—Fields: The Member object has the following fields:

TABLE 5Member Major Object FieldsAllowedFieldDescriptionIn/OutValueExampleCommandRequests one of the followingIncreate<Command>create</Command>(Required)actions:updateCreate (Add a new Memberremoveobject)Update (Modify Member objectinformation)Remove (Remove a Memberobject)IdUnique identifier assigned in aCreateAlphanumeric<Id>k5j34kd</Id>Response to a Request to create a(Out)stringMember objectUpdate (In)Remove(In)FirstNameThe member's first nameInString<FirstName>Virginia</FirstName>(Required)with a 32-characterlimitLastNameThe member's last nameInString<LastName>Woolf</LastName>(Required)with a 32-characterlimitCompanyThe member's company affiliationInString<Company>Hogarth(Optional)with a 32-Press</Company>characterlimitUserNameThe member's login; must beInString<UserName>VirginiaW</UserName>unique within the domainwith a 32-characterlimitPasswordThe member's secret passwordInString<Password>abc123</Password>with a 32-characterlimitAllowNoticesMarks this member as beingIn“True” (to<AllowNotices>trueinterested in receiving receiveallow)</AllowNotices>periodic mailings specific to thisotherwise,domain“False”DailinIdThis is a way for the member toInNumeric<DialinId>9146445543</DialinId>identify himself when calling intostringa voice response (automatedtouch tone telephone) system.DialinPasswordServes as a PIN for the voiceInNumeric<DialinPassword>1234response systemstring</DialinPassword>


Major Objects—Member—Sub-objects: In addition, the Member object contains the following required sub-objects:


Major Objects—Member—Sub-objects—Contact Method: specifies communication mode (e-mail, telephone, etc.) and contact information (e-mail address, telephone number, etc.) specific thereto. Contact Method sub-objects are further described below in connection with the Contact Major Object.


Major Objects—Member—Sub-objects—Billing: specifies the billing plan and details necessary to bill the member (such as a credit-card number). The object also describes the current account status. The following table sets for the required fields for the billing sub-object:

TABLE 6Member Major ObjectBilling Sub-objectIn/AllowedFieldsDescriptionOutValuesExampleIdUnique identifierOut<Id>k123lbj4</Id>Billing PlanIndicates which planIn<BillingPlan>kkk33kkkkthe member is using</BillingPlan>(pay-as-you-go, prepaid,both using a credit card)CurrentBalanceCurrent balance in USOut<currentBalance>15.22dollars as a floating</CurrentBalance>point number


The billing sub-object, in turn, contains a Credit Card sub-object, the fields for which are set forth in the following table:

TABLE 7Member Major ObjectBilling Sub-objectCredit Card Sub-objectAllowedFieldsDescriptionIn/OutValuesExampleFirstName,Name as itInEach name field<FirstName>Virginia</FirstName>MiddleName,appears on theis a string with a<MiddleName>L.</MiddleName>LastNamecredit card32-character<LastName>Woolf</LastName>limitCreditCardRequiredInNumber as it<CreditCardNumber>5123123412341233Numberappears on the</CreditCardNumber>credit cardExpirationExpirationInTwo-digit<ExpirationMonth>8</ExpirationMonth>Monthmonth as itnumber as itappears on theappears on thecredit cardcardExpirationYearExpiration yearInFour-digit<ExpirationYear>2001</ExpirationYear>as it appears onnumberthe credit cardStreetAddress1First line of theInFirst line of<StreetAddress1>25 Hollywoodstreet addressbilling addressst.</StreetAddress1>for this cardfor this cardStreetAddress2Second line ofInSecond line of<StreetAddress2>Hogarth Pressthe streetbilling addressInc.</StreetAddress2>address for thisfor this cardcardCityCity of billingInCity Name<City>Los Angeles</Cityaddress for thiscardStateState of billingInUse two-letter<State>CA</State>address for thisstatecardabbreviationZipZip code in theInZip codes can be<Zip>90210-1234</Zip>US postal codeeither five oroutsidenine digits;hyphen isoptionalCountryCountryInCountry name<Country>USA</Country>


The following is an example of entire Member Object:

<Member> <Command>create</Command> <FirstName>Ralph</FirstName> <LastName>Emerson</LastName> <Company>Poets R Us</Company> <UserName>RWE</UserName>  <Password>MyPassword</Password>  <DialinId>12345</DialinId> <DialinPassword>12345</DialinPassword>  <ContactMethod>   <Transport>email</Transport>   <Qualifier>none</Qualifier>   <EmailAddress>ralph@Poets.com</EmailAddress>  </ContactMethod>  <ContactMethod>   <Transport>phone</Transport>   <Qualifier>office</Qualifier>   <Ordinal>0<Ordinal/Ordinal>   <PhoneNum>617-123-4567</PhoneNum>  </ContactMethod>  <Billing>   <BillingPlan>kkk33kkkk<BillingPlan>   <CurrentBalance>1.00<CurrentBalance>    <CreditCard>     <FirstName>Ralph</FirstName>     <MiddleName>Waldo</MiddleName>     <LastName>Emerson</LastName>     <CreditCardType>Master   Card</CreditCardType>     <CreditCardNumber>5123123412341233</   CreditCardNumber>     <ExpirationYear>2001</ExpirationYear>     <ExpirationMonth>8</ExpirationMonth>     <StreetAddress1>1313 Mockingbird  Lane</StreetAddress1>     <StreetAddress2>Poets R  Us</StreetAddress2>     <City>Warren</City     <State>MA</State>     <Zip>01810</Zip>     <Country>USA</Country    </CreditCard>   </Billing></Member>


Major Objects—Contact: identifies an individual to whom a message may be sent. A Contact Object contains one or more Contact Method sub-objects (described below), each of which identifies a way to reach the individual. Contact and Contact Method information may or may not be stored in a member's Address Book (i.e., the a collection of a member's Contacts and their associated Contact Methods stored in database 152b). Thus, a Contact Major Object may be created to be stored in an Address Book, or for one-time use.


Major Objects—Contact—Fields: The Contact object has the following fields:

TABLE 8Contact Major Object FieldsFieldsDescriptionIn/OutAllowed ValuesExampleCommandRequests one of theIncreate<Command>create</Command>following actions:updateCreate(Add a newremoveContact object)NOTE: (This field isUpdate(Modify Contactrequired only when theobject information)Contact is to be used asRemove(Remove aa major object that is, soContact object)the contact is stored inthe Address Book forreuse.)IdRequired field thatIn (forSupplied after a contact<Id>k5j34kd</Id>identifies the memberupdatehas been createdwhen the Command fieldandis used to update, orremove)remove the Contact.PrefixIndicates the contact'sInString<Prefix>Mr.</Prefix>(Optional)preferred title; forexample; Mr., Ms, Dr.First NameThe contact's first, middleInEach name field is a<FirstNamex>WillamMiddle Nameand last names; first andString with a 32-</FirstName>Last Namelast names are requiredcharacter limit<MiddleName>S.</MiddleName><LastName>Shakespeare</LastName>CompanyIndicates the name of theInString with a 32-<Company>Globe Theater,(Optional)company or organizationcharacter limitInc.</Company>with which the contact isaffiliatedTitleIndicates a job title forInString with a 32-<Title>Director</Title>(Optional)the contactcharacter limit


Use of the Command field ensures that the Contact Object will be stored in the Address Book of the member with which it is associated. When the Contact Object is nested as a sub-object of a Job object (described below), the contact information will not be stored in an Address Book.


The following represents a typical Contact Object (with Contact Method objects indicated but not actually specified):

<Contact>  <prefix>Mr.</Prefix>   <FirstName>William</FirstName>   <MiddleName>L.</MiddleName>   <LastName>Shakespeare</LastName>   <Company>Globe Theater, Inc.</Company>   <Title>Director</Title>   [ContactMethod Objects]</Contact>


Major Objects—Contact—Sub-objects—Contact Method: as explained above, this object specifies the manner in which a member may be contacted. A Contact Method sub-object may contain some or all of the following fields:

TABLE 9Contact Method Sub-object FieldsFieldDescriptionIn/OutAllowed ValuesExampleIdIdentifies thisIn or OutRequired based on the logic<Id>k5j34kd</Id>Contact Methodfor the parent Contact objectobjectNOTE: The Contact Methodobject does not have aCommand field; rather, it isnested within a Contact objectthat does have a Commandfield.TransportIndicatesInPhone<Transport>email</Transport>(Required)deliveryFaxmethodPagerEmailMailQualifierIndicates theInHome<Qualifier>cell</Qualifier>(Required)type of phoneHome2or faxOfficeOffice2CellNOTE: Member is a legalvalue for Qualifier only whenused in a Member object.OrdinalA counter thatInUnsigned integer; Only<Ordinal>0</Ordinal>allows entry ofrequired if there is more thanmore than oneone of a particular kind ofexact type ofcontact method (home 0,contact method.home1). For example, for yourfirst phone number, theordinal would be “0”; for thesecond, the ordinal would be“1”PhoneNumTelephoneInTypical phone number with<PhoneNum>212-123-FaxNumnumber forarea code (no “1” for long4567</PhoneNum>PagerNumphone, fax,distance needed); for example<FaxNum>2121234568</FaxNum>pager2121234567; hyphen is<PagerNum>800-456-optional4567</PagerNum>AccessAccess numberInUsed only when the pager<AccessCode>77325#</AccessCode>Codefor a pagerservice requires the caller toenter an identifying touch tonestring (sometimes, ending withthe pound sign or asterisk)before entering a callbacknumber.EmailEmail addressInTypical email address<EmailAddress>1<[CDATA[jkrowlingAddress@bloomsbury.com]]></EmailAddress>Street1Street addressInString with 32 character limit<Street1>100 parkAvenue</Street1>Street2Second line ofInString with 32 character limit<Street2>Waldorf AstoriaaddressHotel</Street2>SuiteSuite number, ifInString with 32 character limit<Suite>Tower Suite 1400</Suite>applicableCityCityInString with 32 character limit<City>New York</City>StateStateInTwo-character abbreviation<State>NY</State>ZipZip code in theInString<Zip>10021</Zip>US; postal codeelsewhereCountryCountryInString with 32 character limit<Country>USA</Country>


To denote a member's primary e-mail address, for example, the following syntax is employed:

<Contact Method>   <transport>email</transport>   <qualifier>member</qualifier>   <EmailAddress>ralph@poets.com</EmailAddress></Contact Method>


The following example illustrates addition of a new contact to an Address Book:

<Contact>  <Command>create</Command>    <FirstName>Albus</FirstName>    <LastName>Dumbledore</LastName>    <Company>Hogwarts School for Witchcraft and    <Wizardry</Company>    <Title>Headmaster</Title> <ContactMethod>   <Transport>phone</Transport>   <Qualifier>cell</Qualifier>   <PhoneNum>9785551234</PhoneNum>  </ContactMethod>  <ContactMethod>   <Transport>pager</Transport>   <PagerNum>8885551234</PagerNum>   <AccessCode>1030#</AccessCode>  </ContactMethod></Contact>


Major Objects—Contact—Sub-objects—Contact MethodRef: once a Contact Method has been created and stored, it may be referred to using a pointer called a Contact MethodRef. The pointer contains the Contact Method's Id, or a combination of fields that will uniquely identify that Contact Method.


A Contact MethodRef sub-object may contain some or all of the following fields:

TABLE 10Contact MethodRef Sub-object FieldsFieldDescriptionIn/OutAllowed ValuesExampleIdIdentifies this ContactInExisting Contact Method Id<Id>k5734kd</Id>Method objectFirstNameThese fields are allInExisting Contact fields<FirstName>Ron</Firstname>LastNamefrom the Contact<LastName>Weasley</Lastname>Companyobject<Company>Hogwarts<Company>TransportThese field are allInExisting Contact Method<Transport>email</Transport>Qualifierfrom the Contactfields<Qualifier>home</Qualifier>OrdinalMethod sub-object<ordinal>0<Ordinal>AllowMultipleIntrue (default value)<AllowMultiple>truefalse</AllowMultiple>If this field is set to a valueof “false”, will only returnthe first Contact Methodthat meets your criteria.


Major Objects—Distribution List: a Distribution List is a grouping of Contact Methods. It allows a member to send a message to all of the Contact Methods in that list. A Distribution List object may contain some or all of the following fields:

TABLE 11Distribution List Major Object FieldsFieldDescriptionIn/OutAllowed ValuesExampleCommandIndicates the desired action. OptionsInMust include one of<Command>append(Required)include:the following values:</Command>Create (Create a Distribution List)createReplace (Replace existing ContactreplaceMethods in this list with the ContactappendMethods contained in this request)deleteAppend (Add Contact Methods to theremoveexisting list)Delete (Delete Contact Methods from thelist)Remove (Remove the whole DistributionList)NameUnique name for Distribution ListInWhen creating a list,<Name>Gryffindor</Name>give it a unique name;for example,“Gryffindor” (32character limit).NOTE: When usingany other commandoption, you must entereither Name or Id fieldto identify theDistribution ListDescriptionDescriptive text about the listInOptional field<Description>GryffindorHouse</Description>IdUnique identifier for the listIn/OutIf the value of the<Id>k431k45</Id>Command-field iscreate, no Id field isrequired, if any othervalue, enter a valuefor either Name or Idfield


In addition, the Distribution List object must have a list of Contact MethodRef sub-objects (i.e., pointers to already-created Contact Method objects). An exemplary Distribution List object is as follows:

<Distribution List>   <Command>append</Command   <Name>Gryffindor</Name>   <ContactMethodRef>    <LastName>Potter</LastName>    <Transport>email</Transport>   </ContactMethodRef>   <ContactMethodRef>    <Id>kkk3btkk</Id>   </ContactMethodRef>   </Distribution List>


Major Objects—Job: a Job object contains a message to one or more Contacts using one or more Contact Methods, and contains sub-objects that define the specifics of the messaging task (e.g., the sender, the body of the message, recipients, etc.) A Job object also contains at least one Message sub-object (described below), and one or more Delivery Request or Contact sub-objects.


A Job object contains only two fields, and these are specified only in a Response:

TABLE 12Job Major Object FieldsAllowedFieldsDescriptionIn/OutValuesExamplesIdIdentifier forOut<Id>kkk3btkk</Id>this Job.ChargesEstimatedOutFloating<Charges>1.60</Charges>cost of thispointJobnumber


Major Objects—Job—Sub-objects—Message: the Message sub-object specifies the actual message. It includes fields and optional MessageArg Objects, and allows the requester to specify delivery times.

TABLE 13Job Major ObjectMessage Sub-object FieldsAllowedFieldsDescriptionIn/OutValuesExampleSubject fieldThe “Subject” line of theInThe actual text<Subject><![CDATA[(Required)messageof your messageFriday's sales meetingis cancelled.]]></Subject>TemplateIn<Template>generic(optional)</Template>fieldIdUnique identifier for thisOut<Id>kkk17lbj4</Id>Message sub-objectDateMarks the date and timeOut<Date>1999:10:20the message was19:14:39</Date>submittedDelivery TimeMarks the requested timeIn<DeliveryTime>1999:10:20of delivery19:14:39</DeliveryTime>DeliveryTimeOptions related to theInStartingAt or<DeliveryTimeModifier>Modifierrequested delivery timeTry ToFinishByStartingAt</DeliveryTimeModifier>


Major Objects—Job—Sub-objects—Message—MessageArg Sub-objects: a Message object contains one or more MessageArg sub-objects that consist of a series of Name/Value tags according to the following syntax:

<MessageArg>   <Name>SENDER</Name>   <Value>Hermione Grainger</Value></MessageArg>


The optional MessageArg Name/Value tags are as follows:

TABLE 14Job Major ObjectMessage Sub-objectMessageArg Sub-object TagsLegalNameValuesDescriptionExampleSENDERCharacterThe sender's<MessageArg>string(member) name. It is<Name>SENDER</Name>used in the From field<Value>Oliver Wood</Value>for all methods of</MessageArg>transport exceptemail.BODYCharacterThe actual text of the<MessageArg>stringmessage. This text<Name>BODY</Name>should be enclosed in<Value><![CDATA[CDATA tags.I have scheduled an extra Quidditchpractice session before the matchwith Slytherin. Be there Wednesday at8:00AM sharp.]]></Value></MessageArg>ASK_YESNO_QUESTIONYESIf a yes/no question is<MessageArg>NOasked, this should be<Name>ASK_YESNO_QUESTION</Name>set to YES, otherwise<Value>YES</Value>NO; for example,</MessageArg>QUESTION_TO_ASKIf the<MessageArg>ASK_YESNO_QUESTION<Name><QUESTION_TO_ASK</Name>field is set to<Value><![CDATA[YES, use this field toCan you make the practice session?]]>enter the actual text of</Value>the question.</MessageArg>EMAIL_ADDRThe email address that<MessageArg>is used in the From<Name>EMAIL_ADDR</Name>and Reply-to fields<Value><![CDATA[wood@Hogwarts.edu]]>when sending a</Value>message via email.</MessageArg>


An exemplary Job Object is as follows:

<Job>   <Message>   <Subject>Extra Quidditch Practice</Subject>   <Template>generic</Template>      <MessageArg>        <Name>SENDER</Name>        <Value>Oliver Wood</Value>      </MessageArg>      <MessageArg>        <Name>BODY</Name>        <Value><![CDATA[          I have scheduled an extra Quidditch      practice session before the match with      Slytherin. Be there Wednesday at 8:00AM sharp.          ]]>        </Value>      </MessageArg>      <MessageArg>       <Name>ASK_YESNO_QUESTION</Name>       <Value>YES</Value>      </MessageArg>      <MessageArg>       <Name><QUESTION_TO_ASK</Name>       <Value><![CDATA[        Can you make the practice session?]]>       </Value>      </MessageArg>      <MessageArg>       <Name>EMAIL_ADDR</Name>       <Value><![CDATA[         wood@Hogwarts.edu]]>       </Value>      </MessageArg></Message><Contact>   <FirstName>Harry</FirstName>   <LastName>Potter</LastName>   <ContactMethod>     <Transport>email</Transport>     <EmailAddress>potter@hogwarts.edu</EmailAdddress>   </ContactMethod></Contact><DeliveryRequest>   <ContactMethodRef>      <LastName>Weasley</LastName>      <Transport>email</Transport>   </ContactMethodRef></DeliveryRequest></Job>


Major Objects—Job—Sub-objects—Delivery Request: the Delivery Request sub-object allows the requester to specify a recipient for a job, as well as to specify delivery options (as fields within the sub-object). The Delivery Request Object may contain a Contact MethodRef sub-object (to refer to a previously created contact method for the recipient) or may instead refer to a Contact sub-object of a Job object (for one-time use of that Contact/Contact Method).


An exemplary Delivery Request sub-object is as follows:

<DeliveryRequest>   <ContactMethodRef>      <LastName>Potter</LastName>      <Transport>email</Transport>      <Qualifier>home</Qualifier>   </ContactMethodRef></DeliveryRequest>


The Delivery Request sub-object is also returned by API 145 as a Response. Furthermore, when an existing Job object is retrieved using a Range object lookup (described below), that job's Delivery Requests are also returned.


The Delivery Request sub-object may contain the following fields:

TABLE 15Job Major ObjectDelivery Request Sub-object FieldsAllowedFieldsDescriptionIn/OutValuesExampleDeliveryOptionsSets the delivery options.Instandard<DeliveryOptions>standardurgent</DeliveryOptions>IdUnique identifier for this DeliveryOut<Id>kkk224524</Id>RequestEstDurationReturns length of time, in seconds, thatOutInteger<EstDuration>80server estimates it will be on the phone</EstDuration>during this delivery.EstSizeEstimated number of pages in a fax, if itOutInteger<EstSize>3</EstSize>was a faxStatusReturns delivery status of the message forOutNot Sent<Status>SENT</Status>this Delivery Request:SentNot Sent (This Delivery Request has notFailedyet been delivered.)CancelledSent (This Delivery Request has beenCancelsuccessfully delivered.)PendingFailed (The final attempt at deliveryfailed.)Cancelled (Your Delivery Request wascancelled.)Cancel Pending (Your Delivery Requestcancellation is pending.)DetailsGives the following information about theOutSee<Details>Modem</Details>status of the current delivery attempt:DescriptionBad AddressDelivery Address is unreachable (Nofurther attempts will be made.)No Answer (another delivery may beattempted.)Busy (another delivery may beattempted.)Answering Machine (assumed) (phonemessage delivered, no further attemptswill be made)Answering Machine (phone messagedelivered, no further attempts will bemade)Maximum Delivery Attempts Exceeded(No further attempts will be made.)Acknowledged (message delivered; ifphone; the person acknowledged bypressing 1. No further attempts will bemade.)Modem (No further attempts will bemade.)Hangup (Call was dropped beforemessage could be dropped; may attemptanother delivery.)Callback Later (Message recipientelected a later callback, another deliverywill be attempted.)Internal Error (internal errorencountered, may attempt anotherdelivery.)CompletedTrue if no further delivery attempts willOuttrue<Completed>truebe made for this delivery requestfalse</Completed>


An exemplary Delivery Request Response is as follows:

<DeliveryRequest>   <ID>kztubkkkk</ID>   <EstDuration>80</EstDuration>   <Status>Not Sent</Status>   <DeliveryOptions>Standard</DeliveryOptions>   <Completed>false</Completed>   <ContactMethod>      <ID>kit5bkkuk</ID>      <Transport>phone</Transport>      <Qualifier>office</Qualifier>      <Unreachable>false</Unreachable>      <EmailAddress>potter@hogwarts.edu</E      mailAddress>   </ContactMethod>   <Contact>      <ID>kk36bkkkk</ID>      <Prefix></Prefix>      <FirstName>Harry</FirstName>      <MiddleName></MiddleName>      <LastName>Potter</LastName>      <Company>Hogwarts School for      Witchcraft and Wizardry</Company>      <Title>Student</Title>      <OneTime>true</OneTime>   </Contact></DeliveryRequest>


Major Objects—Job—Sub-objects—Delivery Request—Delivery Sub-object: the Delivery sub-object never appears in a Request. It is returned by API 145 as a sub-object of a Delivery Request object when a Range object lookup (see below) is performed on a job.


The Delivery sub-object may contain the following fields:

TABLE 16Job Major ObjectDelivery Request Sub-objectDelivery Sub-object FieldsAllowedFieldsDescriptionIn/OutValuesExampleIdUnique identifier for this DeliveryOut<Id>kkk224524</Id>TimestampTime delivery was madeOutInteger<Timestamp>2000:06:0504:15:22</Timestamp>DurationReturns length of time, in seconds, that serverOutInteger<Duration>80</Duration>was on the phone during this deliveryStatusReturns delivery status of the message for thisOutNot Sent<Status>SENT</Status>Delivery:SentNot Sent (This Delivery has not yet beenFailedSent (This Delivery has been successfullyCancelleddelivered.)CancelFailed (The final attempt at delivery failed.)PendingCancelled (Your Delivery was cancelled.)Cancel Pending (Your Delivery cancellationis pending.)DetailsGives the following information about theOut<Details>Modem</Details>status of this delivery attempt:Bad AddressDelivery Address is unreachable (Nofurther attempts will be made.)No Answer (another delivery may beattempted.)Busy (another delivery may be attempted.)Answering Machine (assumed) (phonemessage delivered, no further attempts willbe made)Answering Machine (phone messagedelivered, no further attempts will be made)Maximum Delivery Attempts Exceeded(No further attempts will be made.)Acknowledged (message delivered; if phone,the person acknowledged by pressing 1. Nofurther attempts will be made.)Modem (No further attempts will be made.)Hangup (Call was dropped before messagecould be delivered; may attempt anotherdelivery.)Callback Later (Message recipient elected alater callback, another delivery will beattempted.)Internal Error (internal error encountered,may attempt another delivery.)SizeNumber of pages in a fax, if it was a faxOutstandard<Size>3</Size>urgentCostActual cost for this delivery in US DollarsOutFloating<Cost>18.20</Cost>pointvalue


Major Objects—Range: The Range object facilitates retrieval of a list of objects based on specified criteria. In particular, the Range object can retrieve Distribution List, Job, and Contact objects. The Response to a Range object returns the requested objects.


The Range Major Object may contain the following fields:

TABLE 17Range Major Object FieldsFieldsDescriptionIn/OutAllowed ValuesExampleObjectSpecifies the type of object youInDistributionList<Object>are trying to look upJobDistributionListContact</Object>MemberTypeSpecifies criteria for theInIf <Object> value is<Type>Name </Type>lookup; depend on the valueDistribution List:of <Object>;Name (look up by Name field)Distribution ListId (look up by Id field)JobAll (return all Dist Lists forContactthis Member)MemberJob:Date (look up by date)Id (look up by Id)All (return all Jobs for thisMember)Contact:LastName (look up byLastName field)Id (lookup by Id field)Company (lookup byCompany field)All (return all Contacts for thisMember)Member:Username (lookup byUsername field)Id (lookup by Id field)StartSpecifies criteria for the data youInStringIf <Type>LastName</Type>are looking up; depends on theThenvalue of <Type><Start>Potter</Start>If <Type>Date</Type>Then, <Start>2000:02:1412:30:00</Start>EndSpecifies the end of a date range;Inyyyy:mm:dd hh:mm:ss<End>2000:02:14only used if the value of12:35:00 </End><Type> is “Date”


The Range object is always included in a Request object, with the value of the RequestType set to “lookup.” The most common use for the Range object is to look up a Job object by Id, for example,

<Range>   <Object>job</Object>   <Type>Id</Type>   <Start>kkky5btk</Start><Range>


Error Handling: Errors fall into three classes: parsing errors, fatal errors, and errors/warnings encountered while validating any object or field.


Parsing errors occur when the input XML tags do not conform to XML specifications. Typical examples of malformed XML code include tags that are not closed and illegal characters; to avoid the latter type of error, free-form text should be enclosed within CDATA tags. When parsing errors are encountered, API 145 returns a ParseErrors object, which contains one or more sub-objects called ParseError and having the following fields:

TABLE 18ParseError Sub-object FieldsDes-AllowedFieldscriptionIn/OutValuesExampleErrorStringTextOutString<ErrorString>Expectingexplaining‘a name’, foundthe error‘?’</ErrorString>LineNumberLineOutInteger<LineNumber>0number</LineNumber>whereerrorfound


An example is as follows:

<ParseErrors>   <ParseError>      <ErrorString>Expecting ‘a name’, found ‘?’ ,/ErrorString>      <LineNumber>9</LineNumber>   </ParseError></ParseErrors>


A fatal error signifies a significant problem encountered in the course of processing a Request. API 145 returns a FatalError object with a single field (ErrorString), which indicates the nature of the error. For example,

<FatalError>   <ErrorString>User Transaction Server Unavailable.</ErrorString></FatalError>


Validation errors and warnings are attached to problematic objects or fields as “attributes.” The Errors and Warnings fields of a Response object contain the following information:

TABLE 19Response Super Object Errors and Warnings FieldsAllowedFieldsDescriptionIn/OutValuesExampleErrorsSet to the number ofOutUnsigned<Errors>errors discoveredinteger2</Errors>while processing themajor objects includedin the RequestWarningsSet to the number orOutUnsigned<Warnings>warnings (a less severeinteger1</Warnings>error) discovered whileprocessing the majorobjects included inthe Request


For example, if a Request contains an invalid telephone number, a warning attribute will be attached to the problematic <PhoneNum> field. If a Request fails to provide a Billing sub-object when trying to add a Member, an error attribute will be attached to the Member object.


It will therefore be seen that the foregoing represents a full-featured messaging system capable of operating in multiple communication modes and interacting with remote applications through a common, extensible interface. The terms and expressions employed herein are used as terms of description and not of limitation, and there is no intention, in the use of such terms and expressions, of excluding any equivalents of the features shown and described or portions thereof, but it is recognized that various modifications are possible within the scope of the invention claimed.

Claims
  • 1-36. (canceled)
  • 37. Apparatus comprising: a messaging application program interface (API) comprising a message and designation receive mechanism to receive, from remote enterprise applications via a network connection, messages and corresponding designations, individual ones of the corresponding designations comprising destination information identifying (i) a set of multiple human recipients and (ii) different modalities for transmitting the message to respective ones of the multiple human recipients; the API further comprising a messaging facility direction mechanism to direct a messaging facility to effect transmission of each of the messages to their corresponding destinations in accordance with their corresponding designations.
RELATED APPLICATION

This application claims the benefits of U.S. Provisional Application Serial No. 60/189,145, filed on Mar. 14, 2000.

Provisional Applications (1)
Number Date Country
60189145 Mar 2000 US
Continuations (1)
Number Date Country
Parent 09621188 Jul 2000 US
Child 10976347 Oct 2004 US