throbber
LAWRENCE C. STEWART
`
`oreo-=[om
`
`ap)
`
`WV)
`
`EE
`
`& Z
`
`z|
`
`aan—es=
`
`rea
`
`NY
`
`Li
`
`1008
`“APPL
`APPLEINC. / Page 1 of 20
`
`APPL-1008
`APPLE INC. / Page 1 of 20
`
`
`

`

`Designing Systems
`for
`Internet Commerce
`Second Edition
`
`
`
`G. Winfield Treese
`LawrenceC. Stewart
`
`vvAddison-Wesley
`
`Boston * San Francisco * New York « Toronto * Montreal
`London * Munich Paris « Madrid
`Capetown * Sydney * Tokyo « Singapore * MexicoCity
`
`APPL-1008
`APPLEINC./ Page 2 of 20
`
`APPL-1008
`APPLE INC. / Page 2 of 20
`
`

`

`Manyofthe designations used by manufacturers and seller
`"=
`claimed as trademarks. Where those designations appear in
`aware of a trademark claim, the designations have been pr
`all capitals.
`
`z
`
`"em.
`
`=r products are
`S2cison-Wesley was
`capital letters orin
`
`amc
`mit!
`
`The authors and publisherhave taken care in the preparatior
`or implied warranty of any kind and assume no responsib
`liability is assumedfor incidental or consequential damages
`the use ofthe information or programs contained herein.
`
`make no expressed
`
`missions. No
`“> orarising out of
`
`The publisher offers discounts on this book when ordered = =
`special sales. For more information, please contact:
`
`~ sulk purchases and
`
`U.S. Corporate and GovernmentSales
`(800) 382-3419
`corpsales@pearsontechgroup.com
`
`Forsales outside of the U.S.. please contact:
`
`International Sales
`(317) 581-3793
`international@pearsontechgroup.com
`
`Visit Addison-Wesley on the Web: www.awprofessional.c
`
`Library of Congress Cataloging-in-Publication Data
`
`Treese, G. Winfield.
`Designing systemsfor Internet commerce / G. Winfield Treesc.
`2nded.
`p. cm.
`Includes bibliographical references and index.
`ISBN 0-201-76035-5 (pbk. : alk. paper)
`1. System design. 2. Electronic commerce. I. Stewart. Lawrence CIT. Title.
`
`Ls
`
`rence C. Stewart—
`
`QA76.9.888 T74 2003
`658.8°00285’4678—de21
`
`Copyright 2003 by Pearson Education, Inc.
`
`202074788
`
`stored imaretrieval system,
`All rights reserved. Nopart of this publication may be reproduced.
`
`a). photocopying, recording,
`or transmitted, in any form, or by any means, electronic, mec
`or otherwise, without the prior consentofthe publisher. Printed in the - nited States of America.
`Published simultaneously in Canada.
`
`Forinformation on obtaining permissionfor use of material from this work. please submit a
`written request to the following address:
`
`Pearson Education, Inc.
`Rights and Contracts Department
`75 Arlington Street, Suite 300
`Boston, MA 02116
`Fax: (617) 848-7047
`
`ISBN: 0-201-76035-5
`Text printed on recycled paper
`123456789 10—CRS—0605040302
`First printing, September 2002
`
`APPL-1008
`APPLEINC./ Page 3 of 20
`eenenTSE
`
`APPL-1008
`APPLE INC. / Page 3 of 20
`
`

`

`[PETTERSELEYEETELT
`
`
`
`CHAPTER21
`
`Putting It All Together
`
`Three things are to be looked to in a building: that it stand on the right
`spot; that it be securely founded; that it be successfully executed.
`—Johann Wolfgang von Goethe!
`
`
`
`
`
`Building Complete Systems
`
`In Part One ofthis book, we discussed issues of business, architecture, and implemen-
`tation. In Part Two, we discussed implementation technologies for various aspects of
`Internet commerce. In this chapter, we try to assemble the pieces into complete sys-
`tems. There are many workable ways to build Internet commerce systems; the ap-
`proaches we describe here are but a few examples.
`
`We will first present an architecture for a federated commerce system. Next, we de-
`scribe a core system architecture and its requirements, followed by a discussion of
`how this architecture may be applied to the business models discussed in Chapter 4.
`
`Federated Commerce System
`
`We envision many individual Internet commerce systems as being membersofa glo-
`bal federated commerce system, as shown in Figure 21-1. In the federated commerce
`system, customers may join one or more buyer communities and conduct commerce
`
`
`1.
`
`Johann Wolfgang von Goethe, Elective Affinities (1808).
`
`APPL-1008)
`APPLEINC./ Page 4 of 20
`
`APPL-1008
`APPLE INC. / Page 4 of 20
`
`

`

`402
`
`Chapter 21 Putting It All Together
`
`
`
`Customer
`
`Customer
`
`Community
`
`
`
`
`
`
`STEGERFTATATETEETEREARLE
`
`Community ASP
`
`Value-Added
`Service
`
`a
`Value-Added
`Service
`
`
`
`FIGURE21-1. Federated Commerce System
`
`with any numberofsellers. Buyers get the advantages of a single account to remem-
`ber and unified customerservice. Sellers gain the advantages ofstandardization, ease
`of use, access to a large aggregation of customers, and easy access to network-based
`value-addedservices. In this example, we will abbreviate the generic federated com-
`merce system as FCS.
`
`The authorsfirst proposed an FCS ina series of memoranda at Open Market in March
`1995. In December 1998, Open Market launched an effort called CommerceToneto
`bring a federated commerce environment to the market. The project wasn’t finished,
`but a separate company called CommerceTonewascreated to deliver some of the en-
`visioned marketing and value-added services.”
`
`In March 2001, Microsoft announcedits Passport system, whichit intended to be the
`single buyer communityfor the entire Internet. Passport provides single sign-on for
`its affiliated Web sites such as the Microsoft Network (MSN) and Hotmail, and also
`provides a server-side wallet for storage of credit card numbers and other personal in-
`formation such asbill-to and ship-to addresses. Some of Microsoft’s competitors, led
`by Sun Microsystems, then announced the Liberty Alliance, whose purpose wasto
`create an open, federated single sign-on system, to be followed by some kind of FCS.
`Microsoft then announced the opening up of Passport to a federated model. At the
`
`
`
`2. CommerceTone waslater acquired by Mercantec.
`
`LT
`
`APPL-1008
`APPLEINC./ Page 5 of 20
`
`
`APPL-1008
`APPLE INC. / Page 5 of 20
`
`

`

`PEERS10000000 TLLaImEEennratureerersere see
`
`
`
`|
`
`Authentication
`Statements
`
`Customer
`
`ol
`
`
`— Ed
`
`C="
`
`Orders
`
`Status
`
`“4
`
`i ig
`
`Registration and
`
`
`
`2HL
`
`Lec
`~~
`;
`4d
`Sas
`E
`Login
`eI
`
`
`
`
`Clearinghouse
`
`Customer Info
`
`Transaction Record
`
`
`FIGURE21-2. Federated Commerce System Transaction
`
`time this book is being written,all of these systemsare in the early stages of deploy -
`ment, at best.
`Let’s follow a typical consumertransaction through its life cycle, with reference t
`Figure 21-2.
`1. Previously, customer Jane joined a buyer community, completing its registration
`process.
`2. Jane connects to the catalogWebsite of the seller andselects items for purchase.
`3. On the checkout screen, Jane selects Use my FCS account.
`4. Theseller system usesthe services of the FCS clearinghouse to locate Jane’s home
`community system (FCS Login).
`5, Jane authenticates herself to her own homesystem.
`6. Theseller system requests buyer information from the home system, which Jane
`chooses to release.
`7. The seller system completes the transaction and transmits a transaction record to
`Jane’s unified customer statement held on her home system. This could be just a
`link to the seller’s customerservice module.
`s. Later, Jane can view a unifiedlist of all her FCS transactions and query any of
`them for status. The status link will take her to the particularseller system for cur-
`rent order status.
`
`APPL-1008
`APPLEINC./ Page 6 of 20
`cc
`
`APPL-1008
`APPLE INC. / Page 6 of 20
`
`

`

`404
`
`Chapter 21 Putting It All Together
`
`ConsumerServices
`
`The federated commerce system,if built correctly, has many benefits for consumers.
`
`With isolated systems, customerservice is problematic because the customer must
`rememberall the sites at which she has made purchases. With federated com-
`merce, the seller always sends a short transaction record to the buyer's home sys-
`tem, to be placed on a unified statement. The unified account statement can also
`easily be integrated with personal finance software.
`e Privacy
`People desire different levels of privacy. Some may chooseto join a buyer commu-
`nity that provides cash-back oran affinity program in exchangefor revealing addi-
`tional personal information and accepting advertising. Others may chooseto join a
`high-privacy community, which could go so far as to conceal completely the
`buyer’s true identity from all other sites. In any event, the buyerhasthe ability to
`configure her personalprivacy policy without the full-time job of studying the pol-
`icies of everysite visited.
`e Multiple accounts
`Becausethere is a single point of control for an account, it is possible to put con-
`trols on the use of that account. This might be useful, for example, to allow chil-
`dren to shop online at selected sellers and with preestablished limits on their
`spending. The parents would have control overthe limits on the account, and they
`would have access to a combined statement summarizingall activity on the fam-
`ily’s accounts.
`e Multistore gift registry
`Gift registries are typically limited to a single store or chain ofstores. In a feder-
`ated system, it wouldbestraightforward to create gift registries that span multiple
`stores, providing more choices and easier shopping.
`
`Value-Added Services
`
`Federated commerce,by virtue of standardized APIs and service agreements, makes
`it straightforward to create value-added services, suchas the following.
`
`e Affiliate programs
`The FCSis a natural venuefor affiliate programs. Rather than requiring affiliates
`to join seller programsindividually, the affiliate can set up one account and poten-
`tially join many programsat once.
`
`APPL-1008
`APPLEINC./ Page 7 of 20
`ooo EEE
`
`e
`
`Simple purchasing
`If the consumerallows, her home system can release ship-to addresses and pay-
`ment informationto theseller. This allowsall participating sites to haveastraight-
`forward checkout process with few clicks and no typing.
`e Unified statements
`
`
`
`APPL-1008
`APPLE INC. / Page 7 of 20
`
`

`

`
`
`Federated Commerce System
`
`405
`
`e
`
`Payment providers
`Payment providers can more easily connect with sellers by virtue of FCS standard
`interfaces. Standardized service agreements also promote competition.
`° Tax calculation
`
`Domestic and international tax services can easily provide services. Of course, ba-
`sic Web services do not require a federated system, but standardizationof the rele-
`vant interfaces makes integration easier. For greater value, tax services could
`provide filing and payment as well.
`e Logistics
`Logistics companies can offer rate calculators, shipping, and package tracking
`through standard interfaces. By connecting with both the buyerand seller, a logis-
`tics company could enhanceprivacy by concealing the ship-to address fromthe
`seller.
`
`The FCS can offer many services, but they all build on three mechanisms.
`
`1. The powerof standardized APIs
`The FCS uses a Web services model for communications and integration. This
`meansthat interfaces are defined by agreed-on XML data types, and the existence
`and typesofinterfaces are defined by XML metadata. The FCS sets standards for
`the APIs to the network, which helps to ensure that systems provided by different
`vendors will interoperate.
`2. The powerof standardized contracts and directories
`Participants in the FCS can take advantageofstandardroles. For example, some-
`one can registeras an affiliate and agree to the standardaffiliate “deal” and then
`consult listings of sellers who offer that deal and sign up with many ofthemat
`once. Similarly, customers of a service who accept a standard deal can select sup-
`pliers who offerit. Standardized specifications of agreements suchas percentage
`discounts for quick payment can evenbe processed automatically.
`3. The power of networking
`Metcalfe’s Law saysthat the value of a networkincreases as the square of the num-
`ber of participants. Something similar seems to apply to the FCS: the aggregate
`expense of the network growslinearly with its size, but the savings grow withthe
`numberofpossible interactions. In addition, the FCS is a boonfor service provid-
`ers, such as logistics companies, that must communicate with both the buyer and
`theseller. In standalone systems, this contact point is internal andinaccessible, but
`in the FCS, the contact between buyerandseller is external and easy to hookinto.
`
`Who Pays Whom?
`As we have learned from the late 1990s, there are many possible business models for
`Internet services. It is probably easiest to compareparts of the FCS to the credit card
`system. In the credit card system, whenever a consumeruses a card, most of the
`
`APPL-1008
`APPLEINC./ Page 8 of 20
`
`APPL-1008
`APPLE INC. / Page 8 of 20
`
`

`

`406
`
`Chapter 21
`
`Putting It All Together
`
`money goes to the merchant, but a portion of the paymentis split among the mer-
`chant’s bank, the cardholder’s bank, and processing companies. Generally, small fixed
`fees go to those parties whoserole is merely to route transactions, whereaslarger, al-
`thoughstill small, percentage amounts go to parties who take on the financialrisks of
`fraud, default, and so on. This seems to be a good modelfor the FCS. Roughly speak-
`ing, the networkitself, the clearinghouse, may qualify for a fixed processing fee, and
`the buyer’s community may qualify fora fixed fee for record keeping,but unless par-
`ties take on financialrisk, they should not qualify for a fee based onthe size ofthe
`transaction.
`
`
`
`System Functionality
`
`In Chapter 2, we introduced the commercevalue chain: attract and keep customers,
`turn interest into orders, manage orders, and provide customer service. Excellence in
`managing orders and providing customer service can help attract and keep customers.
`The more one learns about one’s customers (with great attention to privacy), the better
`one can market to them.
`
`Our implementation approach divides the components ofthe value chain into the fol-
`lowing groups.
`
`* Content servers and applications
`e Linking the content to transactions
`¢ Order management, including order processing, payment, fulfillment, and cus-
`tomerservice
`
`Sv LLETREATEETHTL ENTUICNTETTETTT1
`
`Walking Through a Transaction
`Before we discuss the system architecture and design issues, we’ll walk through a
`transaction.
`
`Before opening for business, a seller creates an online catalog containing the product
`descriptions, prices, and so forth. The seller also creates a merchantprofile, which de-
`scribes the accepted means of paymentand tax and shipping rules, and configures the
`fulfillment system to route orders.
`
`Whenthe buyer browsesthecatalog, the purchasing process begins, consisting of the
`followingsteps.
`
`1. The buyerlocates products of interest in the catalog and clicks the associated of-
`fers. This creates items in the buyer’s shoppingcart.
`2. On checkout, the buyer sees the order form, an example of which is shownin Fig-
`ure 21-3. The screen shownalready has somebuyer informationfilled in, as
`would bethe case for a repeat buyer, based on saved memberinformation.
`
`TEETEOOEETEEEEOEEECOETTEEETE
`
`SSS TESSTSGT TESTS TEES TESSTE
`
`APPL-1008
`/ Page 9 of 20
`TEETER SAE
`TT
`Bann
`
`
`APPL-1008
`APPLE INC. / Page 9 of 20
`
`

`

`
`
`System Functionality
`
`407
`
`3. The transaction engine calculates sales tax using the buyer’s billing address, the
`seller’s tax profile, and the producttax classification code.
`4. The transaction engine calculates shipping charges using the buyer's choice of
`seller-defined shipping methods, together with productprice or weight.
`5. The buyer clicks Buy Now.
`6. The transaction engine performsa credit card authorization and address verifica-
`tion check with the seller’s choice of card processing network.
`7. The transaction is recorded in permanentstorage.
`s. An adviceof order received is routed to the seller.
`9. The transaction enginereturns a receipt to the customer, which contains a copy of
`the invoice and a link to a status page for customerservice.
`10. The seller ships the product and informs the transaction engine of the shipment,
`using the online order status pages.
`11. The transaction engine performs credit card settlement, transferring funds from
`the buyer to the seller’s account.
`12. The transaction engine updates the buyer’s online statement and optionally sends
`the buyer an e-mail advising of the order shipment.
`
`Afterward, the buyer’s receipt remainsactive, bringing the buyerto his online state-
`mentofactivity. Each itemis a hypertextlink to a status page for the particulartrans-
`action.
`
`Digital Goods
`If the product purchasedis in electronic form, the buyer’s receipt is a hypertext link
`directly to the fulfillment area. Either the receipt carries with it security codes grant-
`ing access by the buyerto specified areas within the fulfillmentsite for a specified
`periodof time, or access control for the fulfillment area must be updated.
`
`Subscriptions
`If the product purchasedis an ongoing subscriptionto an electronic publication, the
`transaction engine makes appropriate entries in its subscription database for the pur-
`posesofbilling and control of access to the fulfillment servers.
`
`Whenthe buyerlinks to the fulfillment serverata latertime, he will be challenged to
`authenticate himself against the customer database. Then an access control check will
`be performedagainst the subscription database. If the subscription is current, the
`buyerwill be granted a ticket good for access to the contentareas. Only whenthe
`ticket expires, perhaps weekly,will the buyer be required to reauthenticate himself.
`
`APPL-1008
`APPLEINC./ Page 10 of 20
`
`APPL-1008
`APPLE INC. / Page 10 of 20
`
`

`

`408
`
`Chapter 21 Putting It All Together
`
`
`
` Order Form - Netscape
`File Edit View Go ‘Communicator Help
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`Use my Regictered Information
`
`|
`
`Marre [Eawrence C. Stewart
`Address [1 Wayside Road
`
`-
`
`;
`
`Set differnt Shin To ecidness
`
`J
`
`
`
`
`
`City or town [pari ington
`State or province fas
`Zip or postal Code foreos
`Country [United States
`Phone number
`
`[781-259-7272
`
`
`
`
`
`
`
`Payment card nuher |
`
`Expiration date
`Month [os 2 |vear [oe =|
`(Your payment information will be kept secure.)
`
`
`* Recalculate atter = eo |
`
`
`
`Copyright © 1997 Open Market, Duc. All rights reserved.
`
`=e
`OpenMiket Transact™servicesprovidedbyfreame ofTransactcamer).
`_ :
`:
`:
`r
`Document
`
`
`FIGURE21-3. Example of Order Form
`
` APPLE INC. / Page M1 of 20
`
`APPL-1008
`
`APPL-1008
`APPLE INC. / Page 11 of 20
`
`

`

`
`
`System Architecture
`
`409
`
`Transaction
`
`
`Fulfillment
`
`
`Business
`Catalog
`Server |
`Retail
`Content
`Server
`
`Information
`Content
`Server
`
` Financial
`Networks
`
`Networks
`
`
`
`
`End User
`
`Merchant
`
`Operator
`
`
`
`FIGURE21-4. Commerce Architecture
`
`
`
`System Architecture
`
`Whenwe introduced various architectures in Chapter 6, we said, “The architecture of
`a system defines its basic components and important concepts and describes the rela-
`tionships among them.” Figure 21-4 showsa block diagram of a commerce system
`built from these components. Overall, this is a three-tier architecture with clients us-
`ing Web browsers connecting over the Internet to content servers of various types.
`The content servers in turn use shared commerceservices. The applicationis inter-
`connected overthe public Internet. Finally, the transaction engine connects to services
`off the public Internet, such as financial networks and fulfillment systems.
`
`The key architectural ideas are to separate management of content from management
`of transactions, to support a broad range of applications, to enable scaling of the sys-
`tem, and to accommodate evolution in technology and functionality.
`
`Separating Content from Transactions
`
`Whenwestarted thinking through the problems of commerceon the Internet, ourfirst
`observation was that although we usually think of Web content as being present on a
`server somewhere on the network, it becomesdisplayable, rendered text and graphics
`only on the screen of the end user’s Web browser. Consequently, the buyer’s decision
`to buy will be communicated to the rest of the system as a network event, and we do
`not have to send that event to the same system that generated the page of content.
`
`APPL-1008
`APPLEINC./ Page 12 of 20
`
`APPL-1008
`APPLE INC. / Page 12 of 20
`
`

`

`410
`
`Chapter 21 Putting It All Together
`
`Our key decision was to treat product information as content and to maintain it on a
`content server, and then to deliver the product informationto the transaction serveras
`part of the click-to-buy process, using the standardWeb HTTPprotocol. This idea en-
`ables managementof content to be separated from managementoftransactions, and
`permits several benefits.
`
`Reduction of Operational Costs
`Splitting up content and transaction managementcan reduce total operationalcosts.
`
`Content servers have very different operational requirements than transaction servers.
`Indeed, if content is delivered by e-mail or CD-ROM,there may not be a content
`serveratall.
`
`Ournext observation was on the nature of a business transaction. Typically, informa-
`tion aboutthe buyer, the seller, and the product being purchased must be brought to-
`gether in one place. Buyer information includes items such as means ofpayment,
`shipping address, andso forth. Seller information includes items that are not depen-
`denton the particular item sold but that relate to the seller across multiple products,
`such as payment methodsaccepted and meansoffulfillment. Product information in-
`cludesitems suchasdescription, price, weight, and taxability.
`
`siiTEEESEET LN
`
`Placing the transaction and business records in one place minimizes the number of
`systemsthat require database management systems and expensivereliability and in-
`tegrity protections, and minimizes the numberof systemsthat require specialized
`managementand operationsskills.
`
`Because many content servers can share the services of a transaction engine, the costs
`of the transaction engine are amortized over many users. The content server costs are
`reduced because there is no need for each system to build in all the commoncosts of
`transaction handling.
`
`Enabling ofService Providers
`Multiple content servers can rely on shared commerceservices providedbya transac-
`tion engine. This creates a new business—a commerceservice provider, which oper-
`ates a shared transaction system onbehalf of multiple contentservers. The transaction
`server can be shared across multiple divisions of a corporate enterprise or as a busi-
`ness in its own right.
`
`Provision of Security Containment
`A security systemsis as strong asits weakest link. If valuable information is spread
`around the system,the security properties of the system must be equally strong every-
`where. By placing mission-critical business functions and transaction records in a
`
`APPL-1008
`APPLEINC./ Page 13 of 20 OORTPERETEETEET
`
`APPL-1008
`APPLE INC. / Page 13 of 20
`
`

`

`System Architecture
`
`411
`
`shared transaction server, the security effort can be focused. The efforts of attackers
`may be concentrated on the transaction system “becausethat’s where the moneyis,”
`but the vigilance of security mechanisms is concentrated as well.
`It is actually easier to secure the transaction engine, which has limited and stylized
`connections with the outside world, than it is to secure a content server, which must be
`accessible to content creation and management personnel as well as to customers.
`
`Supporting a Broad Range of Applications
`A shared commerce services environmentenables a very broad range of commerce
`applications. At the very simple endof the spectrum, small stores can be prepared
`with desktop publishing tools and uploaded onto the Net. Offers to sell, encoded in
`the content, point to a commerceservice provider, which managesthe resulting orders
`on a fee basis. There is no need for the content provider to understand or operate a
`complex transaction system.
`In the midrange, dynamic content and rich site-development tools can create a com-
`pelling commerce experience for the consumer and provide compelling value for the
`business user.
`
`At the high end, an enterprise may have multiple divisions with different content sys-
`tems, sharing transaction services provided by the IT department. Thetransaction en-
`gine may be integrated closely with enterprise financial and logistics systems.
`By leveraging a shared infrastructure, small and medium-sized enterprises can access
`all the servicesthat are available to large enterprises.
`
`Supporting System Scaling
`Splitting up content and transaction systemsallowsthemto scale independently. Con-
`tent systems need to grow according to the type and volumeofcontent, which may be
`unrelated to the volume oftransactions. A dynamic content site delivering pages rich
`in graphics and multimedia will have greater computing and bandwidth requirements
`than a content system delivering even a large numberof simple pages. On the fulfill-
`mentside for digital goods, a single transaction may grant very substantial access
`rights to fulfillment servers over an extended period.
`With the shared services design, content servers can be added to the system as the
`need for them arises as a result of increased demandfor or volume of content. Content
`servers representing additional businesses may register for commerce services at any
`time.
`
`Thetransaction engine also needsto be scalable. Wedesignedit as a set oflogical
`servers backed byarelational database managementsystem. The application logic
`scales by running the componentservers on more powerful hardware or by load shar-
`
`_
`
`APPL-1008
`APPLEINC./ Page 14 of 20
`
`-
`
`———
`
`APPL-1008
`APPLE INC. / Page 14 of 20
`
`

`

`412
`
`Chapter 21 Putting It All Together
`
`ing. The database scales by running on more powerful hardware and by exploiting the
`database vendors’ parallel and cluster capabilities.
`
`Supporting System Evolution
`Anarchitecture is needed when one doesn’t know whatkinds of problemswill arise
`tomorrow. Internet commerceis changing very rapidly, and so systemsinstalled today
`will need to add new functionality and exploit new technologies as the industry ma-
`tures,
`
`Functional Evolution
`
`Separating contentandtransaction systems permits functions to be addedto each sys-
`tem without affecting or requiring upgradesto the other. For example, a new payment
`method such as purchase orders can be added in one place at the transaction server,
`making the new functionality immediately availableto all affiliated content servers.
`
`A content server employing dynamically generated pages can replacea server using
`static pages without any changein the transaction machinery.
`
`Technological Evolution
`An importantpart of an architecture is defining interfaces between the partsof the
`system that remain stable across multiple releases and technological changes. For ex-
`ample, server-side wallets may replace HTML forms and SSL/TLSforcredit card
`paymenton the Internet. When wallet supportis added to the transaction engine,all
`the affiliated content servers can take immediate advantageofit without having to up-
`grade each content system—perhapsusing several different content creation and man-
`agement systems.
`
`
`
`Transaction Engine
`
`The best way to think ofthe transaction engineis as a suite of applications for its dif-
`ferent users: buyers, sellers, and operators. This model is shown in Figure 21-5. In
`more traditional business settings, buyers interact directly with sellers, and both
`interact directly with operations and support groups. On the Internet, the situationis
`different because the parties involved arerarely online at the same time. Instead, each
`group ofusers interacts with applications that place their retained state in a database
`where the next group can pick it up and carry on. The database, without loss of gener-
`ality, can be a set of databases with workflow capabilities.
`
`The transaction engine is organized in this way, with application logic and user inter-
`face capabilities for buyers, sellers (merchants), and system operators.It is a rich ap-
`plication; the following sections are not exhaustive but are included here to give
`
`SEEETERSTAGEDToDoOOEEEDETOOSGUESEenoanaT
`
`APPL-1008
`APPLEINC./ Page 15 of 20
`
`
`
`|aS
`
`
`
`
`
`OREREGTTOSENSSSTONITOCUTECUCTETIETUUSTONOTOOONOCGACETECTTEEEOOEEO OSESDESEOSOCOSTTOTORENMeNTTTeTDanH NTEyTeTTy yre yang ese eeTTT TTT PTET TE TTT FFTEEEERECOTENTTTTUGS, CERSERRSTORE
`
`APPL-1008
`APPLE INC. / Page 15 of 20
`
`

`

`EEES00OeET TTT
`
`SINANsareeee a —
`
`_
`
`nl
`
`
`
`Transaction Engine
`
`413
`
`
`
`
`Catalog
`System
`
`User
`Database
`
`Order
`Management
`
`Other
`Functions
`
`Internet Commerce System
`
`
`
`|
`
`SAP R/3
`ERP System
`
`|
`
`||| |
`
`Marketing Data
`
`
`
`FIGURE 21-5. Transaction Engine Application
`
`readers an appreciation ofthe kinds of functionalities and APIs that are included. In
`many implementations, the transaction engine includesthe userinterface, but in our
`example,the userinterface for the buyers is specifically provided by the content man-
`agementand catalog systems through transaction engine APIs.
`
`Buyer Applications: User Interface and APIs
`The buyer experienceis primarily with catalog and other content systems.In the case
`of high-end content systems, or those with complex marketing and promotionslogic.
`buyerinteractions with the transaction engine are indirect, through contentserver user
`interfaces supported by application programmerinterfaces provided by the transac-
`tion engine. In support of simpler catalog systemsor of offers made by advertise-
`ments, buyersinteract directly with transaction engine userinterface software.
`
`BuyerApplications with User Interface
`
`e Order capture
`The ordercapture application appearsto be aninteractive order form. Buyers pop-
`ulate the order formdirectly by clicking digital offers and digital coupons. or ths
`seller may prepopulate the order form through an API. The order form provices
`the facilities for the buyer to adjust item quantities, choose coupons, enter or oo
`billing and shipping addresses, and select payment and shipping methods. In acc-
`tion to providing the order form userinterface, the order capture subsystem ca oo
`lates discounts from coupons (including matching coupons against items
`validates addresses, and calculates sales tax and shipping charges, leading |
`
`ordertotal. If a consumer payment methodsuch asa credit card is selectec
`transaction engine obtains the necessary authorization in real time. The prs
`
`is to validate the success of the orderto the fullest extent possible while the >
`is online, in order to resolve any problems right away. In the case of digita’
`2
`
`APPL-1008
`APPLEINC./ Page 16 of 20
`
`APPL-1008
`APPLE INC. / Page 16 of 20
`
`

`

`414
`
`Chapter 21 Putting It All Together
`
`The goal of the customerservice applications is customerself-service. For regis-
`tered buyers, the system provides online statements of all transaction activity.
`Each item is active and can be clicked through to reach detailed order status infor-
`mation or the catalog page from which the item wasoriginally selected. From the
`orderstatus screen, the buyer can click through to the package tracking services
`offered by some logistics companies. The subscription capabilities are also sup-
`ported by somespecial customer service applications. For example, if a subscrip-
`tion involves periodic payments and the associated credit card expires oris
`canceled, the system permits the buyerto substitute a different paymentinstru-
`ment without intervention by the operator.
`
`Buyer APIs
`
`Buyers will not use these APIs themselves. Instead, these are APIs that sellers who
`have relationships with the transaction engine use in order to implementthe buyerex-
`perience.
`
`and subscriptions, the buyer experience ends with a receipt, granting immediate
`access to the appropriate fulfillment server. For physical goods, the buyer obtains
`a receipt that can be used later for order status and customerservice.
`e Accountregistration and managementprofiles
`There are multiple models of buyers. Walk-in buyers may have no previousrela-
`tionship with the system. Walk-in buyers mustfill out the complete order form,al-
`though parts of the process may be automated by buyer software such as an
`electronic wallet. There are also registered buyers, who have chosen to save an ac-
`countprofile as repeat visitors. Registered buyers get the order form already pop-
`ulated with their stored information, for faster checkout. Registered buyers also
`have access to account administration applications, for creating and changing user
`and security profiles and for registering additional means of payment, suchas a
`microtransaction account. Finally, there are buyers whose profiles are held else-
`where by a buyer communitythat is part of the FCS. These buyers can be handled
`either as walk-in buyers whose orderformsare filled out automatically or as regis-
`tered buyers, some of whoseregistration informationis held remotely.
`e Customerservice
`
`
`
`¢ Commerce objects
`The commerceobjects, including offers, coupons, and receipts, constitute the pri-
`mary APIto the transaction engine. These objects are the primary mechanisms
`through which items for sale, merchandising, and fulfillment of digital goods are
`handled betwee

This document is available on Docket Alarm but you must sign up to view it.


Or .

Accessing this document will incur an additional charge of $.

After purchase, you can access this document again without charge.

Accept $ Charge
throbber

Still Working On It

This document is taking longer than usual to download. This can happen if we need to contact the court directly to obtain the document and their servers are running slowly.

Give it another minute or two to complete, and then try the refresh button.

throbber

A few More Minutes ... Still Working

It can take up to 5 minutes for us to download a document if the court servers are running slowly.

Thank you for your continued patience.

This document could not be displayed.

We could not find this document within its docket. Please go back to the docket page and check the link. If that does not work, go back to the docket and refresh it to pull the newest information.

Your account does not support viewing this document.

You need a Paid Account to view this document. Click here to change your account type.

Your account does not support viewing this document.

Set your membership status to view this document.

With a Docket Alarm membership, you'll get a whole lot more, including:

  • Up-to-date information for this case.
  • Email alerts whenever there is an update.
  • Full text search for other cases.
  • Get email alerts whenever a new case matches your search.

Become a Member

One Moment Please

The filing “” is large (MB) and is being downloaded.

Please refresh this page in a few minutes to see if the filing has been downloaded. The filing will also be emailed to you when the download completes.

Your document is on its way!

If you do not receive the document in five minutes, contact support at support@docketalarm.com.

Sealed Document

We are unable to display this document, it may be under a court ordered seal.

If you have proper credentials to access the file, you may proceed directly to the court's system using your government issued username and password.


Access Government Site

We are redirecting you
to a mobile optimized page.





Document Unreadable or Corrupt

Refresh this Document
Go to the Docket

We are unable to display this document.

Refresh this Document
Go to the Docket