Embodiments presently disclosed generally relate to network communications. More specifically, embodiments herein relate to distributing and serving various media and content resources across a content delivery network.
The Internet has enabled a proliferation of information to become available to end users across a myriad of different heterogeneous networks. Users of the Internet enjoy the ability to quickly access various types of multimedia (e.g., audio, video, games, etc.) for viewing and playback on their devices (e.g., PCs, laptops, mobile phones, etc.). Various streaming protocols and procedures are used to deliver multimedia in a real-time, or near-real time fashion, such that a user may interact with the media (e.g., watch a video) while the media is simultaneously being distributed over one or more networks.
All media is not freely available however. Many content providers and publishers wish to protect and/or monetize their media assets when providing such content over the Internet. For example, various digital rights management policies (e.g., encryption/decryption) have been established to protect media assets of content providers and publishers. Automated e-commerce technologies have also been deployed so that content providers and publishers can conveniently monetize the various media content being distributed to end users.
Embodiments generally disclosed herein include computer-implemented methods for delivery of video content across a network. Such methods comprise a content delivery manager capable of receiving a video stream from a content source for delivery to a client of a content publisher. According to an example configuration, the client subscribes to the content publisher to receive video content. The content delivery manager is capable of detecting a trigger signal within the video stream. For example, the trigger signal can indicate a temporal mark injected into the video stream by the content publisher.
During general operation, the content delivery manager processes the trigger signal to determine whether to modify delivery of the video stream to the client. If necessary, the content delivery manager modifies delivery of the video stream in accordance with the processing of the trigger signal.
According to another general embodiment, a computer-implemented method is provided for authorizing delivery of a video stream to an end user. As such, the video stream is associated with a content publisher. The method comprises an authorization manager capable of receiving a request from the end user for delivery of the video stream to the end user across a network.
In operation, the authorization manager queries a subscription database associated with the content publisher. In response to the query, the authorization manager processes a reply from the subscription database to determine whether the end user has authorization to receive delivery of the video stream.
According to one example embodiment, if it is determined (per the reply from the subscription database) that the end user is not authorized to receive delivery of the video stream from the content publisher, the authorization manager transmits a notification to the end user indicating that the end user is not authorized to receive delivery of the video stream based on the processing of the reply from the subscription database.
In another example embodiment, if it is determined (per the reply from the subscription database) that the end user is authorized to receive delivery of the video stream from the content publisher, the authorization manager initiates delivery of the video stream to the end user based on the processing of the reply from the subscription database.
The foregoing and other objects, features and advantages of the invention will be apparent from the following description of particular embodiments of the invention, as illustrated in the accompanying drawings in which like reference characters refer to the same parts throughout the different views. The drawings are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the invention.
Throughout the drawing figures, like reference numerals will be understood to refer to like parts and components.
System Component Overview
With reference to
To maximize performance, scalability and availability, the system 10 deploys the servers in a tiered hierarchy distribution network indicated generally at 12 that can be built from different numbers and combinations of network building components comprising media serving systems 14, regional data centers 16 and master data centers 18. The system also comprises an acquisition network 22 that is preferably a dedicated network for obtaining media or content for distribution from different sources. The acquisition network 22 can operate as a network operations center (NOC) which manages the content to be distributed, as well as the resources for distributing it. For example, content is preferably dynamically distributed across the system network 12 in response to changing traffic patterns in accordance with the present invention. While only one master data center 18 is illustrated, it is to be understood that the system can employ multiple master data centers, or none at all and simply use regional data centers 16 and media serving systems 14, or only media serving systems 14.
An illustrative acquisition network 22 comprises content sources 24 such as content received from audio and/or video equipment employed at a stadium for a live broadcast via satellite 26. The broadcast signal is provided to an encoding facility 28. Live or simulated live broadcasts can also be rendered via stadium or studio cameras, for example, and transmitted via a terrestrial network such as a T1, T3 or ISDN or other type of a dedicated network 30 that employs asynchronous transfer mode (ATM or other technology. In addition to live analog or digital signals, the content can include analog tape recordings, and digitally stored information (e.g., media-on-demand or MOD), among other types of content. Further, in addition to a dedicated link 30 or a satellite link 26, the content harvested by the acquisition network 22 can be received via the Internet, other wireless communication links besides a satellite link, or even via shipment of storage media containing the content, among other methods. The encoding facility 28 converts raw content such as digital video into Internet-ready data in different formats such as the Microsoft Windows Media (MWM), RealNetworks G2, or Apple QuickTime (QT) formats. The system 10 also employs unique encoding methods to maximize fidelity of the audio and video signals that are delivered via multicast by the distribution network 12.
With continued reference to
The system 10 employs a director agent to monitor the status of all of the tiers of the distribution network 12 and redirect users 20 to the optimal server, depending on the requested content. The director agent can originate, for example, from the NOC/encoding facility 28. The system employs an Internet Protocol or IP address map to determine where a user 20 is located and then identifies which of the tiered servers 14, 16 and 18 can deliver the highest quality stream, depending on network performance, content location, central processing unit load for each network component, application status, among other factors. Cookies and data from other databases can also be employed to facilitate this system intelligence.
Media serving systems 14 comprise hardware and software installed in ISP facilities at the edge of the Internet. The media serving systems preferably only serve users 20 in its subnetwork. Thus, the media serving systems 14 are configured to provide the best media transmission quality possible because the end users 20 are local. A media serving system 14 is similar to an ISP caching server, except that the content served from the media serving system is controlled by the content provider that input the content into the system 10. The media serving systems 14 each serve live streams delivered by the satellite link 32, and store popular content such as current and/or geographically-specific news clips. Each media serving system 14 manages its storage space and deletes content that is less frequently accessed by users 20 in its subnetwork. Content that is not stored at the media serving system 14 can be served from regional data centers.
With reference to
The regional data centers 16 are located at strategic points around the Internet backbone. With reference to
The master data centers 18 are similar to regional data centers 16, except that they are preferably much larger hardware deployments and are preferably located in a few peered data centers and co-location facilities, which provide the master data centers with connections to thousands of ISPs. With reference to
Transmissions can occur out of the data centers 16 and 18. In the case of the satellite 32, however, transmissions can also be implemented by taking what is being received and routing a copy thereof directly to the uplink system without first passing through the media serving systems 14.
System Operation Overview
With reference to
Content obtained via the acquisition phase 100 is preferably provided to one or more broadcasters 110 via a multicast cloud or network(s) 108. The content is unicast or preferably multicast from the different acquisition modules 106 to the broadcasters 110 via the cloud 108. As stated above, the cloud 108 is preferably a point-to-multipoint broadcast backbone. The cloud 108 can be implemented as one or more of a wireless network such as a satellite network or a terrestrial or wireline network such as optical fiber link. The cloud 108 can employ a dedicated ATM link or the Internet backbone, as well as a satellite link, to multicast streaming media. The broadcasters 110 are preferably in tier 120, that is, they are master data centers 18 that receive content from the acquisition modules 106 and, in turn, broadcast the content to other receivers in tiers 116, 118 and 120.
During the broadcasting phase 102, broadcasters 110 operate as gatekeepers, as described below in connection with
During the reception phase 104, high-fidelity streams that have been transmitted via the broadcasters 110 across the multicast cloud 108 are received by servers 14, 16 and 18 located as close to end users as possible. The system 10 is therefore advantageous in that streams bypass congestion and expense associated with the Internet backbone. As stated previously, the servers are preferably deployed in a tiered hierarchy comprising media serving systems 14, regional data centers 16 and master data centers 18 that correspond to tiers 116, 118 and 120, respectively. The tiers 116, 118 and 120 provide serving functions (e.g., transcoding from RTP to MMS, RealNet, HTTP, WAP or other protocol), as well as delivery via a local area network (LAN), the Internet, a wireless network or other network to user devices 122 for rendering (e.g., PCs, workstations, set-top boxes such as for cable, WebTV, DTV, and so on, telephony devices, and the like). The tiers in the reception phase are described in further detail below in connection with
Data Transport Management
With reference to
Acquisition for plural customers A through X is illustrated in
The transport components described in connection with
The transport manager will now be described with reference to
With continued reference to
The transport sender 138 receives the XBM call and responds by announcing the stream that is going to be sent. All of the transport components listen to the announcement. Once the transport sender 138 commences sending the stream into the assigned multicast IP address and port, the corresponding transport broadcaster 140 filter the stream. The transport receiver 144 joins the multicast IP address and receives the data or stream if the stream is intended for a group to which the receiver 144 belongs. As stated above in connection with
As stated above, the transport components described with reference to
RTP is used for transmitting real-time data such as audio and video, and particularly for time-sensitive data such as streaming media, whether transmission is unicast or multicast. RTP employs User Datagram Protocol (UDP), as opposed to Transmission Control Protocol (TCP) that is typically used for non-real-time data such as file transfer and e-mail. Unlike with TCP, software and hardware devices that create and carry UDP packets do not fragment and reassemble them before they have reached their intended destination, which is important in streaming applications. RTP adds header information that is separate from the payload (e.g., content to be distributed) that can be used by the receiver. The header information is merely interpreted as payload by routers that are not configured to use it.
RTSP is an application-level protocol for control over the delivery of data with real-time properties and provides an extensible framework to enable controlled, on-demand delivery of real-time data including live feeds and stored clips. RTSP can control multiple data delivery sessions, provide means for choosing delivery channels such as UDP, multicast UDP and TCP, and provide means for choosing delivery mechanisms based on RTP. HTTP is not suitable for streaming media because it is more of a store-and-forward protocol that is more suitable for web pages and other content that is read repeatedly. Unlike HTTP, RTSP is highly dynamic and provides persistent interactivity between the user device (hereinafter referred to as a client) and server that is beneficial for time-based media. Further, HTTP does not allow for multiple sessions between a client and server, and travels over only a single port. RTP can encapsulate HTTP data, and can be used to dynamically open multiple RTP sessions to deliver many different streams at the same time.
The system 10 employs transmission control software deployed at the encoding facilities 28, which can operate as a network operations center (NOC), and at broadcasters 110 (e.g., master data centers 120) to determine which streams will be available to which nodes in the distribution system 12 and to enable the distribution system 12 to support one-to-one streaming or one-to-many streaming. The extensible language capabilities of RTSP augment the transmission control software at the edge of the distribution network 12. Since RTSP is a bi-directional protocol, its use enables encoders 134 and receivers 144 to talk to each other, allowing for routing, conditional access (e.g., authentication) and bandwidth control in the distribution network 12. Standard RTSP proxies can be provided between any network components to allow them to communicate with each other. The proxy can therefore manage the RTSP traffic without necessarily understanding the actual content.
For every RTSP stream, there is an RTP stream. Further, RTP sessions support data packing with timestamps and sequence numbers. They can also be used for carrying stereo information, wide screen versions of requested media, different audio tracks, and so on. RTP packets are wrapped in a broadcast protocol. Applications in the receiving phase 104 can use this information to determine when to expect the next packet. Further, system operators can use this information to monitor network 12 and satellite 32 connections to determine the extent of latency, if any.
Encoders and data encapsulators written with RTP as the payload standard are advantageous because off-the-shelf encoders (e.g., MPEG2 encoders) can be introduced without changing the system 10. Further, encoders that output RTP/RTSP can connect to RTP/RTSP transmission servers. In addition, the use of specific encoder and receiver combinations can be eliminated when all of the media players support RTP/RTSP.
The authentication and selective network connection provided by the present invention allows networks to offer multi-tiered service (e.g., different users can access different types of streams), and control over user errors when requesting access (e.g., requesting incorrect bandwidth for their connection speed). Thus, service providers can distinguish users who have paid for value-added services and authenticate these users for higher quality digital audio and video services.
System Operation: Broadcast Triggers
Methods and systems described with respect to
More specifically,
With reference to
In general, the content source 910 (and/or content publisher 905) acquires content (e.g., video capture of a live sporting event) for subsequent and, at times, real-time distribution to various end users associated with the content publisher 905. Note that content streams may be stored and cached for on-demand type contribution as well. As shown in
In addition to the satellite/terrestrial broadcast system 920, the content source 910 (and/or content publisher 905) can also distribute a content stream 912 (e.g., audio media, video media, etc.) via streaming system 925 in furtherance of various embodiments that will be described in greater detail below. Accordingly, streaming system 925 has similar architectures and provides similar functionalities as the methods and systems previously described with respect to the example embodiments in
A trigger generator 915 can inject additional information (i.e., a trigger signal) into the content stream 912 that is not initially captured by the content source 910. The trigger generator 915 can be an automated process (e.g., software, sensors, etc.), a human (as shown in
For example, assume that a content publisher “Broadcaster A” intends to provide a live broadcast of a sporting event. Broadcaster A would acquire the audio/video directly from the sporting event via a content source such as a camera system installed at the event. As it is commonly known, a live (or real-time) broadcast of a sporting event does not provide a continuous content stream from a single static acquisition source such as the camera system. In other words, a live broadcast typically includes commercials, cut-outs to other broadcast feeds, and the like. These other content feeds are managed by Broadcaster A's play-out system.
In the context of embodiments described in this specification, the play-out system would indicate a switch or transfer to the alternate content feeds (e.g., commercials/advertisements, cut-outs, etc.) by way of a trigger signal injected into the content stream (i.e., as injected by the trigger generator 915). In this manner, the trigger signal provides real-time notification to downstream broadcast systems (e.g., content delivery manager 935) that the content stream is subject to switch to an alternate content feed (e.g., commercial or advertisement). The downstream broadcast systems have discretion to switch to an alternative content feed or continue transmitting the original content stream in accordance with the downstream broadcast systems' contractual relationship with the broadcaster (i.e., content publisher).
Still referring to
According to one example embodiment, the encoder 930 provides real-time encoding of the content stream 912 and can include Real encoding, QT encoding, WM encoding, and the like (see
During general operation, and as will be discussed in greater detail below with respect to
After processing the content stream 912, the content delivery manager 935 transmits the content stream 912 (or a modification thereof) to content delivery network 950-1 and content delivery network 950-2 (hereinafter collectively referred to as content delivery network 950) for subsequent delivery to end user 965-1 and end user 965-2 (hereinafter collectively referred to as end user 965), respectively.
In the example embodiment of
Although shown as different entities in the example configuration of
Other example embodiments can include betting triggers used for delivery of online gambling and betting events such as horse races, dog races, etc. For instance, in one embodiment the trigger generator 915 can inject a trigger signal into a content stream, where the content stream is that of, say, a dog race and the pre-race activities associated therewith. Assume that the trigger signal is injected into the content stream to indicate the start of the dog race. In one embodiment, the content delivery manager 935 could detect the trigger signal and cease any further betting activities associated with that particular race. For example, the content delivery manager 935 could instruct web server 955 to stop accepting further bets for the dog race that had just begun (i.e., cease e-commerce interaction with the end user). The trigger signal could further indicate that the race has completed and that the content delivery manager 935 should discontinue delivery of the content stream to end users authorized to view only that race.
Referring now to
In the example embodiment of
It should also be noted that, in accordance with the example broadcast scenario described above with respect to
The content source 1005 may interact with the content publisher 1010 for various reasons, such as for play-out management and control. For example, the content publisher 1010 may inject a trigger signal(s) into the content stream for subsequent processing at the content delivery manager 1015.
Note that content publisher 1010 and content source 1005 have the same or similar configurations, relationships, and functionalities as the content publisher 905 and content source 910 previously described with respect to
During general operation, the content delivery manager 1015 receives the content stream via stream intake module 1020. The stream intake module 1020 processes the content stream and then, according to one example embodiment, sends the content stream to stream delivery module 1040. During its processing, the stream intake module 1020 is also capable of detecting and/or extracting trigger signals embedded in the content stream. For example, in one embodiment the trigger signal contains additional information (e.g., metadata) related to the type of content and/or trigger event (e.g., advertisement, black out, etc.) associated with the trigger signal.
Having detected and/or extracted a trigger signal within the content stream, the stream intake module 1020 provides information related to the detected trigger signal to trigger processing logic 1025. For example, as shown in the embodiment of
In one example embodiment, and with the trigger signal information provided by the stream intake module 1020, the trigger processing logic 1025 interacts with EPG 1055 (e.g., across a network such as the Internet) to determine whether the content stream should be modified. As shown in the example embodiment of
Note that trigger processing logic 1025 can use proximity data (e.g., an IP address) associated with the end user 1050 to determine which region to query within EPG 1055 (as depicted by arrow 1037).
Assume that in another example embodiment the EPG 1055 indicates that program P6 does not need to be blacked out during time period T2 in Region A. In this example, the trigger processing logic 1025 can determine that the trigger signal detected in the content stream indicates a modification to the content stream, such as a commercial break. As such, the trigger processing logic 1025 would initiate a process to modify the content stream by inserting an advertisement or commercial into the content stream for delivery to end users. As will be described in more detail below, insertion of a commercial or advertisement may be targeted to end users in a particular geographic region (e.g., Region A).
Having determined that the content stream should be blacked out and/or a commercial or advertisement should be inserted, the trigger processing logic 1025 passes this information along to stream packaging module 1030. Stream packaging module 1030 prepares and configures modifications to content streams in accordance with instructions from the trigger processing logic 1025.
For example, if the trigger processing logic 1025 instructs the stream packaging module 1030 that the corresponding content stream currently being processed by the content delivery manager 1015 should be blacked out, the stream packaging module 1030 can instruct the stream delivery module 1040 to terminate delivery of the content stream to end users that are subject to the black out restrictions. Alternatively, the stream packaging module 1030 can provide alternative content (e.g., commercials, advertisements, pre-configured black out programs or static messages, etc.) to stream to end users in lieu of the blacked out content stream.
If the trigger processing logic 1025 indicates to the stream packaging module 1030 that the content stream should be modified by inserting a commercial or advertisement, the stream packaging module 1030 would perform various steps to determine which commercials or advertisement should be inserted into the content stream. For example, in one embodiment the stream packaging module 1030 inserts pre-configured commercials and/or advertisements into the content stream that have been provided by the content publisher or other entities potentially associated with monetizing content delivery to end users.
In another example embodiment, the stream packaging module 1030 queries an advertisement server 1060 (e.g., across a network such as the Internet) to determine which commercials or advertisements should be inserted into the content stream. In this manner, the stream packaging module 1030 can provide information that is specific to the user (i.e., user data 1035) to the advertisement server 1060. Information specific to a user can include, for example, geographical data, prior viewing history such as which types/categories of content a user has previously requested for viewing, information personal to the user such as age, sex, and the like, as well as other attributes suitable for selecting commercials and/or advertisements for a targeted advertising campaign. Assume for the example embodiment of
According to the present example, the computer system 1100 includes a bus 1101 (i.e., interconnect), at least one processor 1102, at least one communications port 1103, a main memory 1104, a removable storage media 1105, a read-only memory 1106, and a mass storage 1107. Processor(s) 1102 can be any known processor, such as, but not limited to, an Intel® Itanium® or Itanium 2® processor(s), AMD® Opteron® or Athlon MP® processor(s), or Motorola® lines of processors. Communications ports 1103 can be any of an RS-232 port for use with a modem based dial-up connection, a 10/100 Ethernet port, a Gigabit port using copper or fiber, or a USB port. Communications port(s) 1103 may be chosen depending on a network such as a Local Area Network (LAN), a Wide Area Network (WAN), or any network to which the computer system 1100 connects (e.g., content delivery network 950 and/or 1045). The computer system 1100 may be in communication with peripheral devices (e.g., display screen 130, input device 116) via Input/Output (I/O) port 1109.
Main memory 1104 can be Random Access Memory (RAM), or any other dynamic storage device(s) commonly known in the art. Read-only memory 1106 can be any static storage device(s) such as Programmable Read-Only Memory (PROM) chips for storing static information such as instructions for processor 1102. Mass storage 1107 can be used to store information and instructions. For example, hard disks such as the Adaptec® family of Small Computer Serial Interface (SCSI) drives, an optical disc, an array of disks such as Redundant Array of Independent Disks (RAID), such as the Adaptec® family of RAID drives, or any other mass storage devices may be used.
Bus 101 communicatively couples processor(s) 1102 with the other memory, storage and communications blocks. Bus 1101 can be a PCI/PCI-X, SCSI, or Universal Serial Bus (USB) based system bus (or other) depending on the storage devices used. Removable storage media 1105 can be any kind of external hard-drives, floppy drives, IOMEGA® Zip Drives, Compact Disc-Read Only Memory (CD-ROM), Compact Disc-Re-Writable (CD-RW), Digital Video Disk-Read Only Memory (DVD-ROM), etc.
Embodiments herein may be provided as a computer program product, which may include a machine-readable medium having stored thereon instructions, which may be used to program a computer (or other electronic devices) to perform a process. The machine-readable medium may include, but is not limited to, floppy diskettes, optical discs, CD-ROMs, magneto-optical disks, ROMs, RAMs, erasable programmable read-only memories (EPROMs), electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, flash memory, or other type of media/machine-readable medium suitable for storing electronic instructions. Moreover, embodiments herein may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., modem or network connection).
As shown, main memory 1104 is encoded with content delivery manager application 1150-1 that supports functionality as discussed above and as discussed further below. Content delivery manager application 1150-1 (and/or other resources as described herein) can be embodied as software code such as data and/or logic instructions (e.g., code stored in the memory or on another computer readable medium such as a disk) that supports processing functionality according to different embodiments described herein. During operation of one embodiment, processor(s) 1102 accesses main memory 1104 via the use of bus 1101 in order to launch, run, execute, interpret or otherwise perform the logic instructions of the content delivery manager application 1150-1. Execution of content delivery manager application 1150-1 produces processing functionality in content delivery manager process 1150-2. In other words, the content delivery manager process 1150-2 represents one or more portions of the content delivery manager application 1150-1 performing within or upon the processor(s) 102 in the computer system 1100.
It should be noted that, in addition to the content delivery manager process 1150-2 that carries out method operations as discussed herein, other embodiments herein include the content delivery manager application 1150-1 itself (i.e., the un-executed or non-performing logic instructions and/or data). The content delivery manager application 1150-1 may be stored on a computer readable medium (e.g., a repository) such as a floppy disk, hard disk or in an optical medium. According to other embodiments, the content delivery manager application 1150-1 can also be stored in a memory type system such as in firmware, read only memory (ROM), or, as in this example, as executable code within the main memory 1104 (e.g., within Random Access Memory or RAM). For example, content delivery manager application 1150-1 may also be stored in removable storage media 1105, read-only memory 1106, and/or mass storage device 1107.
In addition to these embodiments, it should also be noted that other embodiments herein include the execution of the content delivery manager application 1150-1 in processor(s) 1102 as the content delivery manager process 1150-2. Thus, those skilled in the art will understand that the computer system 1100 can include other processes and/or software and hardware components, such as an operating system that controls allocation and use of hardware resources.
It should be noted that the content delivery manager 935 in
As discussed herein, embodiments of the present invention include various steps or operations. A variety of these steps may be performed by hardware components or may be embodied in machine-executable instructions, which may be used to cause a general-purpose or special-purpose processor programmed with the instructions to perform the operations. Alternatively, the steps may be performed by a combination of hardware, software, and/or firmware.
It should be noted that many routine program elements, such as initialization of loops and variables and the use of temporary variables are inherent in the flowcharts. It will be appreciated by those of ordinary skill in the art that unless otherwise indicated herein, the particular sequence of steps described is illustrative only and can be varied without departing from the spirit of the invention. Thus, unless otherwise stated the steps described below are unordered meaning that, when possible, the steps can be performed in any convenient or desirable order.
Now, more specifically,
In step 1205, the content delivery manager 1150 receives a video stream from a content source for delivery to an end user (e.g., client) of a content publisher. For example, the end user can subscribe to the content publisher to receive video content. In other words, the end user can log onto a content publisher's website (if the end user is a subscriber of the content publisher) to receive a live video stream from the content publisher as delivered by the content delivery manager 1150, according to one example embodiment.
In step 1210, the content delivery manager 1150 detects a trigger signal within the video stream. The trigger signal can be indicative of a temporal mark injected into the video stream by the content publisher (e.g., the trigger signal indicates that a commercial and/or advertisement should be inserted into the content stream). The trigger can also be injected into the video stream by an entity associated with content publisher. For example, in one embodiment the trigger signal is generated relative to the content source by a human associated with the content publisher.
In step 1215, the content delivery manager 1150 processes the trigger signal to determine whether to modify delivery of the video stream to the end user.
In step 1220, the content delivery manager 1150 modifies, if necessary, the delivery of the video stream in accordance with the processing of the trigger signal. For example, the content delivery manager 1150 can modify the video stream to include a commercial and/or advertisement.
In step 1305, the content delivery manager 1150 processes the trigger signal to determine whether to modify the video stream prior to being delivered to the end user(s).
In step 1310, the content delivery manager 1150 queries a data repository having information related to a content programming schedule associated with the content publisher. In an example embodiment, the data repository includes an Electronic Programming Guide (EPG) configured to provide a schedule that identifies when various content provided by the content publisher will be available for reception by authorized end users of the content publisher.
In step 1315, the content delivery manager 1150 receives a response from the data repository that includes synchronization information for modifying, if necessary, the delivery of the video stream to the end user. Additionally, the synchronization information can include geo-filtering information and/or advertisement information. For example, the geo-filtering information can include regions (e.g., related to IP addresses) to which the video content should not be delivered (or regions that are not authorized to receive delivery of the video stream). As its name suggests, the synchronization information can inform the content delivery manager 1150 when and how to modify the video stream, especially if the video stream is being delivered to the end user(s) in real-time.
In step 1320, the content delivery manager 1150 modifies delivery of the video stream (e.g., inserts a commercial, blacks out the video stream, etc.).
In step 1325, and in response to querying the data repository, the content delivery manager 1150 discontinues the delivery of the video content based on programming data received from the data repository (e.g., due to black out restrictions).
In step 1330, the content delivery manager 1150 continues to receive the video stream from the content source. In one embodiment, the continued receipt of the video stream enables the content delivery manager 1150 to detect a second trigger signal that would be capable of reinitiating delivery of the video stream to the end user (e.g., the trigger signal indicates that a commercial or black out time period has ended).
According to another example embodiment, the content delivery manager 1150 extracts synchronization information from the trigger signal. In this manner, the synchronization information indicates a type of event associated with the video stream and can specify temporal information relative to the detection of the trigger signal. The type of event can include, for example, an advertisement event, a program initiation event, a program termination event, etc. When the trigger signal includes supplemental information (e.g., trigger event type, time codes, etc.), the trigger processing logic of the content delivery manager 1150 can be disencumbered with the additional processing necessary to determine whether to modify delivery of the video stream as previously described and, as a result, may not necessarily have to communicate with external data sources such as the electronic programming guide (EPG).
In step 1405, the content delivery manager 1150 processes the trigger signal to determine whether to modify, if necessary, delivery of the video stream.
In step 1410, the content delivery manager 1150 applies proximity parameters (e.g., IP addresses) associated with the end user to the trigger signal in order to determine whether to modify the delivery of the video stream to the end user.
In step 1415, the content delivery manager 1150 modifies delivery of the video stream.
In step 1420, the content delivery manager 1150 discontinues delivery of the video stream to the end user based on the application of the proximity parameters to the trigger signal. For example, the proximity parameters can indicate that the end user is not authorized to receive the video stream due to: i) a time relative to the detection of the trigger signal, and/or ii) a geographic location associated with the end user as indicated by the proximity parameters.
In step 1425, the content delivery manager 1150 processes the IP address to determine a geographic region associated with the network from where the end user receives video content.
In step 1505, the content delivery manager 1150 determines that an advertisement should be injected into the video stream.
In step 1510, the content delivery manager 1150 queries an advertisement server.
In step 1515, the content delivery manager 1150 receives a response from the advertisement server that identifies a plurality of candidate advertisements for injection into the video stream.
In step 1520, the content delivery manager 1150 selects, from the plurality of candidate advertisements, a candidate advertisement for injection into the video stream based on proximity parameters associated with the end user. In this manner, the proximity parameters can specify a geographic location of the end user to where video content is transmitted.
In step 1525, the content delivery manager 1150 modifies delivery of the video stream.
In step 1530, the content delivery manager 1150 injects the selected candidate advertisement into the video stream for delivery to the end user. In one example embodiment, the selected candidate advertisement is targeted for the geographic location of the end user.
According to yet another example embodiment, the content delivery manager 1150 selects an advertisement to inject into the video stream based on information extracted from the trigger signal. For example, the selected advertisement can be targeted to a geographic location associated with the end user. In turn, the content delivery manager 1150 injects the selected advertisement into the video stream for delivery to the end user.
In accordance with another embodiment, the content delivery manager 1150 receives a video stream from a content source for delivery to a end user of a content publisher. The content source is associated with the content publisher in this particular example. Furthermore, the end user has been pre-authorized to receive video content from the content publisher.
During operation, the content delivery manager 1150 detects a trigger signal within the video stream. In this example embodiment, the trigger signal is indicative of a temporal mark injected into the video stream by a human associated with the content publisher. In response to detecting the trigger signal, the content delivery manager 1150 queries an Electronic Programming Guide (EPG) to determine whether to modify the delivery of the video stream to the end user. For purposes of example, the EPG can be configured to provide a schedule that identifies when various content provided by the content publisher will be available for reception by authorized end users of the content publisher.
Accordingly, the content delivery manager 1150 receives a response from the EPG that includes advertisement information and/or geo-filtering information. If necessary, the content delivery manager 1150 modifies delivery of the video stream to the end user in accordance with the advertisement information and/or the geo-filtering information.
System Operation: User Authentication
Similar to the content delivery configuration previously described with respect to
For example, an authentication manager can “dip” into a subscriber's or content publisher's database to determine whether a given end user is authorized to receive certain content from the content publisher or broadcaster. This so-called “dipping” provides a seamless means for authenticating Internet end users to receive video content associated with a content publisher such that the content publisher does not have to create a new subscriber database for Internet end users or modify its already-established subscriber databases for traditional television end users (e.g., satellite and cable subscriber databases).
In particular,
Note that content publisher 1605 and content source 1610 have the same or similar configurations, relationships, and functionalities as the content publisher 905 and content source 910 previously described with respect to
It should also be noted that satellite/terrestrial broadcast system 1617 has the same or similar configurations, functionalities, and features as satellite/terrestrial broadcast system 920 previously discussed with respect to
During general operation, the content source 1610 (e.g., via content publisher 1605) distributes a content stream 1620 (e.g., audio stream, video stream, etc.) into streaming system 1625 at the stream ingest. The content stream 1620 may be contain live content, such as a sporting event, for real-time (or near real-time) distribution to end users across streaming system 1625 and content delivery network 1650. Note that video streams 160 may also be stored and cached for on-demand type distribution.
Similar to the encoder 930 described with respect to
Referring still to the example embodiment of
Note that the authorization manager 1635 supports functionality for both streaming and authentication/authorization services, as shown in the example embodiment of
To authorize/authenticate end user 1660 for delivery of content stream 1620, the authorization manager 1635 first receives an authorization request 1665 from end user 1660. For example, in one embodiment the authorization manager 1635 receives the authorization request 1665 from end user 1660 via web server 1655 of content delivery network 1650. In another embodiment, the end user 1660 sends an authorization request 1667 (as shown by the perforated arrow) directly to authorization manager 1635.
Note that, similar to the example embodiment of
As its name suggests, streaming server 1655 typically provides back-end streaming services by delivering, for example, the content stream 1620 as provided by either authorization manager 1635 and/or encoder 1630. Note that the vertical ellipses in content delivery network 1650 indicate that there can be multiple web and/or streaming servers associated with content delivery network 1650.
Having received the authorization request 1665 (or 1667) from end user 1660, the authorization manager 1635 communicates with (“dips” into) subscription database 1640 to determine whether end user 1660 is authorized to receive content stream 1620. As previously mentioned subscription database 1640 is associated with content publisher 1605 and provides subscription information related to various end users authorized to receive content from content publisher 1605. For example, subscription database 1640 may contain subscription information related to traditional satellite and/or cable television services provided by content publisher 1605. The authorization manager's 1635 interaction with subscription database 1640 is discussed in more detail below with respect to
After verifying that the end user 1660 is authorized to receive the content stream 1620, the authorization manager 1635 initiates delivery of the content stream 1620 to end user 1660 via content delivery network 1650. The content stream 1620 can propagate downstream directly from encoder 1630 to content delivery network 1650, from encoder 1630 to authorization manager 1635 and then to content delivery network 1650, or from encoder 1630 to the content delivery network 1650 via another mechanism for managing delivery of content streams in streaming system 1625 (e.g., via content delivery manager 935, 1015, and/or 1150).
Note that content publisher 1705 and content source 1710 have the same or similar configurations, relationships, and functionalities as the content publisher 905 and content source 910 previously described with respect to
It should also be noted that the end user 11770 may communicate directly with the verification module 1730 of authorization manager 1715 or, alternatively, the end user 11770 may communicate with verification module 1730 via a web server (e.g., web server 1655) associated with content delivery network 1760.
During operation, the stream intake module 1720 of authorization manager 1715 receives a content stream (e.g., video stream) from content source 1710 and/or content publisher 1705. Upon receiving the content stream, the stream intake module 1720 checks with the verification module 1730 to determine whether end user 11770 is authorized to receive the content stream.
The stream intake module 1720 passes the content stream through to stream delivery module 1725 so that the content stream can be delivered (via content delivery network 1760) to end user 11770 upon authorization/authentication by verification module 1730. Note that the verification module 1730 may notify either the stream intake module 1720 and/or the stream delivery module 1725 of the authorization status of end user 11770. If, for example, the verification module 1730 notifies the stream intake module 1720 that end user 11770 is authorized to receive the content stream, the stream intake module 1720 passes the content stream to stream delivery module 1725 for unfettered content stream delivery to end user 11770 via content delivery network 1760.
In the example embodiment of
It should be noted that, in the example embodiment of
The verification module 1730 can initiate authorization of end user 11770 by either receiving a request for authorization 1772 from end user 11770, or by proactively soliciting a request for authorization 1774 (or soliciting information necessary to authorize end user 11770) if, for example, the content stream has already arrived at the authorization manager 1715.
According to an example embodiment, the verification module 1730 can first determine whether the end user 11770 is authorized to receive delivery of the content stream by querying local end user repository 1740 (via data storage module 1735). End user data repository 1740 is populated with subscription data for end users associated with authorization manager 1715. In this manner, the end user data repository 1740 is progressively updated with subscription data each time the verification module 1730 receives information from subscription database 1750.
For purposes of example only, the end user data repository 1740 stores both session information and proximity parameters related to each end user associated with authorization manager 1715. Note that the end user data repository 1740 may store different parameters and/or information related to each end user in addition to, or in lieu of the parameters and information shown in the example embodiment of
The session information indicates that, for each applicable end user (end user 1, end user 2, end user 5, . . . end user M), the authorization manager 1715 initiated delivery of a content stream (CS1, CS2, CS4, CSY) at a respective time (T1, T3, T7, . . . TX). Delivery of a specific content stream at a respective time represents a “session.”
Still referring to the end user data repository 1740, the proximity parameters column indicates an Internet Protocol “IP” address associated with each applicable end user (e.g., end user 1=IP1, end user 2=IP2, end user 5=IP5, . . . end user M=IPM). The proximity parameters may be used in furtherance of authenticating/authorizing an end user for purposes of geo-filtering/geo-blocking.
For example, assume that the end user data repository 1740 indicates that end user 11770 is already receiving content stream as part of an earlier-initiated session for that particular content stream. In one embodiment, the authorization manager 1715 can deny access to the end user 11770 since the end user had already requested delivery of that particular content stream as evidenced by the session information. By denying access in this manner, the authorization manager 1715 can prevent unscrupulous users (e.g., hackers, spoofers, etc.) from trying to gain unauthorized access to content streams.
Continuing with the same example, the authorization manager 1715 can alternatively grant the request by the end user 11770 to receive delivery of the content stream. In this manner, the authorization manager 1715 would terminate the earlier-initiated session and initiate a new session with end user 11770 for delivery of the content stream in accordance with the second request. By terminating the first session and initiating the second session, the authorization manager 1715 trusts that the second request is authentic (e.g., was actually sent by end user 11770) and that the first session with end user 11770 may have been prematurely disconnected or fallen victim to any number of network anomalies.
In response to receiving the request for authorization 1772, and now assuming that the end user data repository 1740 does not have information (an entry) related to end user 11770, the verification module 1730 queries subscription database 1750 to determine whether end user 11770 is authorized to receive delivery of the content stream. As shown, the subscription database contains a table of authorized subscribers (end user 1, end user 4, end user 9, . . . end user N). Since end user 1 is listed as an authorized subscriber in subscription database 1750, the subscription database would indicate to verification module 1730 that end user 11770 is in fact authorized to receive delivery of the content stream.
Note that the subscription database 1750 associated with content publisher 1705 may only contain subscription information related to non-Internet services such as satellite television services, cable television services, and the like. As such, and in accordance with embodiments herein, the subscription database 1750 is capable of authorizing end user for web-based delivery of content such that the content publisher 1705 does not have to create (or modify existing) subscription database specific to Internet, or web-based services.
According to the present example, the computer system 1800 includes a bus 1801 (i.e., interconnect), at least one processor 1802, at least one communications port 1803, a main memory 1804, a removable storage media 1805, a read-only memory 1806, and a mass storage 1807. Processor(s) 1802 can be any known processor, such as, but not limited to, an Intel® Itanium® or Itanium 2® processor(s), AMD® Opteron® or Athlon MP® processor(s), or Motorola® lines of processors. Communications ports 1803 can be any of an RS-232 port for use with a modem based dial-up connection, a 10/100 Ethernet port, a Gigabit port using copper or fiber, or a USB port. Communications port(s) 1803 may be chosen depending on a network such as a Local Area Network (LAN), a Wide Area Network (WAN), or any network to which the computer system 100 connects (e.g., content deliver/network 950, 1045, 1650, and/or 1760). The computer system 1800 may be in communication with peripheral devices (e.g., display screen 1830, input device 1816) via Input/Output (I/O) port 1809.
Main memory 1804 can be Random Access Memory (RAM), or any other dynamic storage device(s) commonly known in the art. Read-only memory 1806 can be any static storage device(s) such as Programmable Read-Only Memory (PROM) chips for storing static information such as instructions for processor 1802. Mass storage 1807 can be used to store information and instructions. For example, hard disks such as the Adaptec® family of Small Computer Serial Interface (SCSI) drives, an optical disc, an array of disks such as Redundant Array of Independent Disks (RAID), such as the Adaptec® family of RAID drives, or any other mass storage devices may be used.
Bus 101 communicatively couples processor(s) 1802 with the other memory, storage and communications blocks. Bus 1801 can be a PCI/PCI-X, SCSI, or Universal Serial Bus (USB) based system bus (or other) depending on the storage devices used. Removable storage media 1805 can be any kind of external hard-drives, floppy drives, IOMEGA® Zip Drives, Compact Disc-Read Only Memory (CD-ROM), Compact Disc-Re-Writable (CD-RW), Digital Video Disk-Read Only Memory (DVD-ROM), etc.
Embodiments herein may be provided as a computer program product, which may include a machine-readable medium having stored thereon instructions, which may be used to program a computer (or other electronic devices) to perform a process. The machine-readable medium may include, but is not limited to, floppy diskettes, optical discs, CD-ROMs, magneto-optical disks, ROMs, RAMs, erasable programmable read-only memories (EPROMs), electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, flash memory, or other type of media/machine-readable medium suitable for storing electronic instructions. Moreover, embodiments herein may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., modem or network connection).
As shown, main memory 1804 is encoded with authorization manager application 1850-1 that supports functionality as discussed above and as discussed further below. Authorization manager application 1850-1 (and/or other resources as described herein) can be embodied as software code such as data and/or logic instructions (e.g., code stored in the memory or on another computer readable medium such as a disk) that supports processing functionality according to different embodiments described herein. During operation of one embodiment, processor(s) 1802 accesses main memory 1804 via the use of bus 1801 in order to launch, run, execute, interpret or otherwise perform the logic instructions of the authorization manager application 1850-1. Execution of authorization manager application 1850-1 produces processing functionality in authorization manager process 1850-2. In other words, the authorization manager process 1850-2 represents one or more portions of the authorization manager application 1850-1 performing within or upon the processor(s) 1802 in the computer system 1800.
It should be noted that, in addition to the authorization manager process 1850-2 that carries out method operations as discussed herein, other embodiments herein include the authorization manager application 1850-1 itself (i.e., the un-executed or non-performing logic instructions and/or data). The authorization manager application 1850-1 may be stored on a computer readable medium (e.g., a repository) such as a floppy disk, hard disk or in an optical medium. According to other embodiments, the authorization manager application 1850-1 can also be stored in a memory type system such as in firmware, read only memory (ROM), or, as in this example, as executable code within the main memory 1804 (e.g., within Random Access Memory or RAM). For example, authorization manager application 1850-1 may also be stored in removable storage media 1805, read-only memory 1806, and/or mass storage device 1807.
In addition to these embodiments, it should also be noted that other embodiments herein include the execution of the authorization manager application 1850-1 in processor(s) 1802 as the authorization manager process 1850-2. Thus, those skilled in the art will understand that the computer system 1800 can include other processes and/or software and hardware components, such as an operating system that controls allocation and use of hardware resources.
It should be noted that the authorization manager 1635 in
As discussed herein, embodiments of the present invention include various steps or operations. A variety of these steps may be performed by hardware components or may be embodied in machine-executable instructions, which may be used to cause a general-purpose or special-purpose processor programmed with the instructions to perform the operations. Alternatively, the steps may be performed by a combination of hardware, software, and/or firmware.
It should be noted that many routine program elements, such as initialization of loops and variables and the use of temporary variables are inherent in the flowcharts. It will be appreciated by those of ordinary skill in the art that unless otherwise indicated herein, the particular sequence of steps described is illustrative only and can be varied without departing from the spirit of the invention. Thus, unless otherwise stated the steps described below are unordered meaning that, when possible, the steps can be performed in any convenient or desirable order.
Now, more specifically,
In step 1905, the authorization manager 1850 receives a request from the end user for delivery of the video stream to the end user across a network. For example, the request received from the user may be in response to a solicitation or request for authorization information previously sent to the end user.
In step 1910, the authorization manager 1850 queries a subscription database associated with the content publisher. For example, the subscription database may include subscription information related to traditional satellite television services, cable television services, and the like.
In step 1915, the authorization manager 1850 processes a reply from the subscription database to determine whether the end user has authorization to receive delivery of the video stream.
In step 1920, the authorization manager 1850 transmits a notification to the end user indicating that the end user is not authorized to receive delivery of the video stream based on the processing of the reply from the subscription database.
In step 1925, the authorization manager 1850 initiates delivery of the video stream to the end user based on the processing of the reply from the subscription database. The reply from the subscription database can indicate that the end user is authorized to receive delivery of the video stream. For instance, the end user may be authorized to receive delivery of the web-based video stream since the end user is already authorized to receive satellite and/or cable television services.
In step 2005, the authorization manager 1850 receives a request from the end user.
In step 2010, the authorization manager 1850 receives metadata from the end user (e.g., token, cookie, etc.). For example, the end user may have received the token and/or cookie from a third party authorization service associated with the content publisher. In this manner, the authorization manager 1850 does not necessarily have to query a subscription database to determine whether the end user is authorized to receive delivery of the video stream.
In step 2015, the authorization manager 1850 processes the metadata (e.g., cookie and/or token) to identify a content publisher associated with the end user.
In step 2020, the authorization manager 1850 determines whether the content publisher associated with the video stream is the same as the content publisher associated with the end user. For example, if it is determined from the metadata (e.g., token and/or cookie) that the end user is already authorized to receive delivery of content from the content publisher associated with the video stream, then the authorization manager 1850 initiates delivery of the content stream to the end user.
In step 2105, the authorization manager 1850 receives a request from the end user for delivery of the video stream to the end user across a network.
In step 2110, the authorization manager 1850 processes proximity parameters associated with the end user. For example, the proximity parameters can specify a geographic location of the end user to where video content is transmitted.
In step 2115, the authorization manager 1850 determines that the end user is not authorized to receive the video stream. Such a determination can be based on the processing of the proximity parameters (e.g., as part of a geo-filtering and/or geo-blocking regime).
In step 2120, and given a relative time associated with the receipt of the request from the end user, the authorization manager 1850 determines whether the video stream should be blacked out for at least a time period associated with the relative time in relation to the geographic location of the end user.
In step 2125, the authorization manager 1850 restricts delivery of the video stream to the end user.
In step 2130, the authorization manager 1850 restricts delivery of the video stream to the end user in accordance with black out rules associated with the content publisher. In this manner, the black out rules have associated time restrictions and geographic restrictions prescribed by the content publisher for the end user.
In step 2135, the authorization manager 1850 restricts delivery of the video stream to the end user in accordance with subscription parameters of the content publisher for a group of end users. For example, the subscription parameters can include a time restriction and/or a geographic restriction. Additionally, in this embodiment the end user is a member of the group of end users to which the subscription parameters apply.
In step 2140, the authorization manager 1850 terminates the delivery of the video stream to the end user if delivery of the video stream to the end user has already been initiated.
In step 2205, the authorization manager 1850 processes the reply from the subscription database to detect whether the end user is a subscriber of the content publisher.
In step 2210, the authorization manager 1850 stores an entry in a subscriber verification table to indicate that the end user is an authorized subscriber of the content publisher. For instance, in one embodiment, the authorization manager 1850 analyzes a token and/or a cookie associated with the second request received from the second end user.
According to another embodiment, the authorization manager 1850 detects that the end user is not a subscriber of the content publisher. In such a scenario, the authorization manager 1850 stories an entry in the subscriber verification table to indicate that the end user is not an authorized subscriber of the content publisher. The authorization manager 1850 can also transmit a notification to the end user to indicate that the end user is not authorized to receive delivery of the video stream. As such, the authorization manager 1850 would specify in the notification that the end user is not an authorized subscriber of the content publisher from which the end user had requested delivery of the video stream.
In step 2215, the authorization manager 1850 receives a second request from a second end user for delivery of the video stream to the second end user.
In step 2220, the authorization manager 1850 processes the second request to determine that the second end user is authorized to receive delivery of the video stream.
In step 2225, the authorization manager 1850 determines that the second end user is the same as the end user. Such a determination is made so as to prevent unauthorized access to video streams by the unscrupulous users (e.g., hackers, spoofers, etc.).
In step 2230, and in response to querying the subscriber verification table, the authorization manager 1850 determines that the second end user is an authorized subscriber of the content publisher.
In step 2235, the authorization manager 1850 initiates delivery of the video stream to the second user. For example, the authorization manager 1850 may initiate delivery of the content stream to the end user via a content delivery network.
In step 2240, the authorization manager 1850 stores session information in the subscriber verification table. The session information is associated with the delivery of the video stream to the end user. Furthermore, the session information is stored in accordance with a relative time at which the request from the end user was received.
In accordance with another example embodiment, the authorization manager 1850 receives a request from the end user for delivery of the video stream to the end user across a network. In response, the authorization manager 1850 queries a subscription database associated with the content publisher and, then, processes a reply from the subscription database to determine whether the end user has authorization to receive delivery of the video stream.
As an example, if the end user is determined to have authorization to receive delivery of the video stream, the authorization manager 1850 creates an entry in a subscriber verification table specifying that the end user is an authorized subscriber of the content publisher. The entry can specify, for example, session information associated with delivery of the video stream to the end user. Furthermore, the session information is stored in accordance with a relative time at which the request from the end user was received. Having determined that the end user is authorized, the authorization manager 1850 initiates delivery of the video stream to the end user.
Although the present invention has been described with reference to various embodiments, it will be understood that the invention is not limited to the details thereof. Various modifications and substitutions will occur to those of ordinary skill in the art. All such substitutions are intended to be embraced within the scope of the invention as defined in the appended claims.
This application claims the benefit of commonly owned U.S. Provisional Application No. 61/113,941, filed Nov. 12, 2008, entitled “Content Delivery Management and Administration”, which is incorporated by reference in its entirety for all purposes. This application is related to concurrently-filed and commonly owned U.S. Non-Provisional Application Ser. No. 12/604,518, filed Oct. 23, 2009, entitled “Dynamic Processing of Streamed Content,” which is incorporated by reference in its entirety for all purposes.
Number | Name | Date | Kind |
---|---|---|---|
4977455 | Young | Dec 1990 | A |
5151789 | Young | Sep 1992 | A |
5253066 | Vogel | Oct 1993 | A |
5307173 | Yuen et al. | Apr 1994 | A |
5335079 | Yuen et al. | Aug 1994 | A |
5353121 | Young et al. | Oct 1994 | A |
5382983 | Kwoh et al. | Jan 1995 | A |
5457776 | Wong et al. | Oct 1995 | A |
5479266 | Young et al. | Dec 1995 | A |
5479268 | Young et al. | Dec 1995 | A |
5499103 | Mankovitz | Mar 1996 | A |
5512963 | Mankovitz | Apr 1996 | A |
5515173 | Mankovitz et al. | May 1996 | A |
5532732 | Yuen et al. | Jul 1996 | A |
5532754 | Young et al. | Jul 1996 | A |
5541738 | Mankovitz | Jul 1996 | A |
5550576 | Klosterman | Aug 1996 | A |
5553123 | Chan et al. | Sep 1996 | A |
5559550 | Mankovitz | Sep 1996 | A |
5600711 | Yuen | Feb 1997 | A |
5619274 | Roop et al. | Apr 1997 | A |
5640484 | Mankovitz | Jun 1997 | A |
5654886 | Zereski, Jr. et al. | Aug 1997 | A |
5684525 | Klosterman | Nov 1997 | A |
5701383 | Russo et al. | Dec 1997 | A |
5706145 | Hindman et al. | Jan 1998 | A |
5727060 | Young | Mar 1998 | A |
5727159 | Kikinis | Mar 1998 | A |
5734786 | Mankovitz | Mar 1998 | A |
5742762 | Scholl et al. | Apr 1998 | A |
5745909 | Perlman et al. | Apr 1998 | A |
5748188 | Hu et al. | May 1998 | A |
5790198 | Roop et al. | Aug 1998 | A |
5801787 | Schein et al. | Sep 1998 | A |
5805815 | Hill | Sep 1998 | A |
5808608 | Young et al. | Sep 1998 | A |
5809204 | Young et al. | Sep 1998 | A |
5812205 | Milnes et al. | Sep 1998 | A |
5822324 | Kostresti et al. | Oct 1998 | A |
5828945 | Klosterman | Oct 1998 | A |
5848427 | Hyodo | Dec 1998 | A |
5870150 | Yuen | Feb 1999 | A |
5883661 | Hoarty | Mar 1999 | A |
5886746 | Yuen et al. | Mar 1999 | A |
5901286 | Danknick et al. | May 1999 | A |
5903816 | Broadwin et al. | May 1999 | A |
5915026 | Mankovitz | Jun 1999 | A |
5918013 | Mighdoll et al. | Jun 1999 | A |
5918014 | Robinson | Jun 1999 | A |
5923362 | Klosterman | Jul 1999 | A |
5929850 | Broadwin et al. | Jul 1999 | A |
5940073 | Klosterman et al. | Aug 1999 | A |
5949954 | Young et al. | Sep 1999 | A |
5959688 | Schein et al. | Sep 1999 | A |
5969748 | Casement et al. | Oct 1999 | A |
5970206 | Yuen et al. | Oct 1999 | A |
5974222 | Yuen et al. | Oct 1999 | A |
5978791 | Farber | Nov 1999 | A |
5982445 | Eyer et al. | Nov 1999 | A |
5987213 | Mankovitz et al. | Nov 1999 | A |
5987518 | Gotwald | Nov 1999 | A |
5988078 | Levine | Nov 1999 | A |
5991498 | Young | Nov 1999 | A |
5996025 | Day | Nov 1999 | A |
6002394 | Schein | Dec 1999 | A |
6006257 | Slezak | Dec 1999 | A |
6016141 | Knudson et al. | Jan 2000 | A |
6028599 | Yuen et al. | Feb 2000 | A |
6034689 | White et al. | Mar 2000 | A |
6049652 | Yuen et al. | Apr 2000 | A |
6049831 | Gardell | Apr 2000 | A |
6052145 | Macrae et al. | Apr 2000 | A |
6072983 | Klosterman | Jun 2000 | A |
6075551 | Berezowski et al. | Jun 2000 | A |
6075575 | Schein et al. | Jun 2000 | A |
6078348 | Klosterman et al. | Jun 2000 | A |
6091882 | Yuen et al. | Jul 2000 | A |
6118492 | Milnes et al. | Sep 2000 | A |
6133909 | Schein et al. | Oct 2000 | A |
6137950 | Yuen | Oct 2000 | A |
6144401 | Casement et al. | Nov 2000 | A |
6151059 | Schein et al. | Nov 2000 | A |
6167188 | Young et al. | Dec 2000 | A |
6177931 | Alexander et al. | Jan 2001 | B1 |
6185598 | Farber | Feb 2001 | B1 |
6189039 | Harvey | Feb 2001 | B1 |
6195680 | Goldszmidt | Feb 2001 | B1 |
6216265 | Roop et al. | Apr 2001 | B1 |
6226618 | Downs | May 2001 | B1 |
6239794 | Yuen et al. | May 2001 | B1 |
6240555 | Shoff et al. | May 2001 | B1 |
6247176 | Schein et al. | Jun 2001 | B1 |
6262722 | Allison et al. | Jul 2001 | B1 |
6263313 | Milsted | Jul 2001 | B1 |
6263501 | Schein et al. | Jul 2001 | B1 |
6272566 | Craft | Aug 2001 | B1 |
6275825 | Kobayashi et al. | Aug 2001 | B1 |
6311182 | Colbath | Oct 2001 | B1 |
6323911 | Schein et al. | Nov 2001 | B1 |
6341195 | Mankovitz et al. | Jan 2002 | B1 |
6341374 | Schein et al. | Jan 2002 | B2 |
6388714 | Schein et al. | May 2002 | B1 |
6396546 | Alten et al. | May 2002 | B1 |
6398245 | Gruse | Jun 2002 | B1 |
6405188 | Schwartz | Jun 2002 | B1 |
6412110 | Schein et al. | Jun 2002 | B1 |
6415280 | Farber | Jul 2002 | B1 |
6418421 | Hurtado | Jul 2002 | B1 |
6430358 | Yuen et al. | Aug 2002 | B1 |
6430359 | Yuen et al. | Aug 2002 | B1 |
6453471 | Klosterman | Sep 2002 | B1 |
6460082 | Lumelsky | Oct 2002 | B1 |
6460181 | Donnelly | Oct 2002 | B1 |
6463508 | Wolf | Oct 2002 | B1 |
6466734 | Yuen et al. | Oct 2002 | B2 |
6469753 | Klosterman et al. | Oct 2002 | B1 |
6477705 | Yuen et al. | Nov 2002 | B1 |
6477707 | King et al. | Nov 2002 | B1 |
6490580 | Dey | Dec 2002 | B1 |
6493707 | Dey | Dec 2002 | B1 |
6498895 | Young et al. | Dec 2002 | B2 |
6505348 | Knowles et al. | Jan 2003 | B1 |
6538701 | Yuen | Mar 2003 | B1 |
6549719 | Mankovitz | Apr 2003 | B2 |
6564379 | Knudson et al. | May 2003 | B1 |
6567606 | Milnes et al. | May 2003 | B2 |
6587837 | Spagna | Jul 2003 | B1 |
6588013 | Lumley et al. | Jul 2003 | B1 |
6654807 | Farber | Nov 2003 | B2 |
6668133 | Yuen et al. | Dec 2003 | B2 |
6687906 | Yuen et al. | Feb 2004 | B1 |
6732369 | Schein et al. | May 2004 | B1 |
6742183 | Reynolds et al. | May 2004 | B1 |
6745391 | Macrae et al. | Jun 2004 | B1 |
6756997 | Ward, III et al. | Jun 2004 | B1 |
6760537 | Mankovitz | Jul 2004 | B2 |
6763377 | Belknap | Jul 2004 | B1 |
6799326 | Boylan, III et al. | Sep 2004 | B2 |
6799327 | Reynolds et al. | Sep 2004 | B1 |
6850693 | Young et al. | Feb 2005 | B2 |
6859791 | Spagna | Feb 2005 | B1 |
6859799 | Yuen | Feb 2005 | B1 |
6862264 | Moura et al. | Mar 2005 | B1 |
6928442 | Farber | Aug 2005 | B2 |
6963910 | Belknap | Nov 2005 | B1 |
6965890 | Dey | Nov 2005 | B1 |
7039633 | Dey | May 2006 | B1 |
7039935 | Knudson et al. | May 2006 | B2 |
7054935 | Farber | May 2006 | B2 |
7069576 | Knudson et al. | Jun 2006 | B1 |
7103564 | Ehnebuske | Sep 2006 | B1 |
7110984 | Spagna | Sep 2006 | B1 |
7117259 | Rohwer | Oct 2006 | B1 |
7162468 | Schwartz | Jan 2007 | B2 |
7188085 | Pelletier | Mar 2007 | B2 |
7206748 | Gruse | Apr 2007 | B1 |
7404010 | Gardell et al. | Jul 2008 | B1 |
7487529 | Orlick | Feb 2009 | B1 |
7647418 | Ash et al. | Jan 2010 | B2 |
7720432 | Colby et al. | May 2010 | B1 |
20010029610 | Corvin et al. | Oct 2001 | A1 |
20010047298 | Moore et al. | Nov 2001 | A1 |
20010054181 | Corvin | Dec 2001 | A1 |
20020073424 | Ward, III et al. | Jun 2002 | A1 |
20020124255 | Reichardt et al. | Sep 2002 | A1 |
20030005445 | Schein et al. | Jan 2003 | A1 |
20030056219 | Reichardt et al. | Mar 2003 | A1 |
20030063752 | Medvinsky et al. | Apr 2003 | A1 |
20030110495 | Bennington et al. | Jun 2003 | A1 |
20030110499 | Knudson et al. | Jun 2003 | A1 |
20030115599 | Bennington et al. | Jun 2003 | A1 |
20030115602 | Knee et al. | Jun 2003 | A1 |
20030163813 | Klosterman et al. | Aug 2003 | A1 |
20030164858 | Klosterman et al. | Sep 2003 | A1 |
20030188310 | Klosterman et al. | Oct 2003 | A1 |
20030188311 | Yuen et al. | Oct 2003 | A1 |
20030196201 | Schein et al. | Oct 2003 | A1 |
20030204847 | Ellis et al. | Oct 2003 | A1 |
20030208756 | Macrae et al. | Nov 2003 | A1 |
20040010806 | Yuen et al. | Jan 2004 | A1 |
20040045025 | Ward, III et al. | Mar 2004 | A1 |
20040107437 | Reichardt et al. | Jun 2004 | A1 |
20040139097 | Farber | Jul 2004 | A1 |
20040168189 | Reynolds et al. | Aug 2004 | A1 |
20040194138 | Boylan, III et al. | Sep 2004 | A1 |
20040205811 | Grandy et al. | Oct 2004 | A1 |
20040261098 | Macrae et al. | Dec 2004 | A1 |
20050010949 | Ward et al. | Jan 2005 | A1 |
20050021202 | Russell et al. | Jan 2005 | A1 |
20050028201 | Klosterman et al. | Feb 2005 | A1 |
20050114296 | Farber | May 2005 | A1 |
20050125823 | McCoy et al. | Jun 2005 | A1 |
20050149964 | Thomas et al. | Jul 2005 | A1 |
20050155056 | Knee et al. | Jul 2005 | A1 |
20050198334 | Farber | Sep 2005 | A1 |
20050216936 | Knudson et al. | Sep 2005 | A1 |
20050235307 | Relan et al. | Oct 2005 | A1 |
20050251824 | Thomas et al. | Nov 2005 | A1 |
20060015574 | Seed | Jan 2006 | A1 |
20060015892 | Hirt et al. | Jan 2006 | A1 |
20060156336 | Knudson et al. | Jul 2006 | A1 |
20060212894 | Knudson et al. | Sep 2006 | A1 |
20060218265 | Farber | Sep 2006 | A1 |
20060277574 | Schein et al. | Dec 2006 | A1 |
20060277576 | Acharya et al. | Dec 2006 | A1 |
20060288366 | Boylan, III et al. | Dec 2006 | A1 |
20070016926 | Ward, III et al. | Jan 2007 | A1 |
20070033613 | Ward, III et al. | Feb 2007 | A1 |
20070107010 | Jolna et al. | May 2007 | A1 |
20070179950 | Kester et al. | Aug 2007 | A1 |
20070233705 | Farber | Oct 2007 | A1 |
20070233706 | Farber | Oct 2007 | A1 |
20070233846 | Farber | Oct 2007 | A1 |
20070233884 | Farber | Oct 2007 | A1 |
20080065724 | Seed | Mar 2008 | A1 |
20080071855 | Farber | Mar 2008 | A1 |
20080071859 | Seed | Mar 2008 | A1 |
20080104268 | Farber | May 2008 | A1 |
20080104624 | Narasimhan et al. | May 2008 | A1 |
20080140800 | Farber | Jun 2008 | A1 |
20080201736 | Gordon et al. | Aug 2008 | A1 |
20080215735 | Farber | Sep 2008 | A1 |
20080215750 | Farber | Sep 2008 | A1 |
20080215755 | Farber | Sep 2008 | A1 |
20080263056 | Murray et al. | Oct 2008 | A1 |
20080263602 | Murray et al. | Oct 2008 | A1 |
20080275987 | Gardell et al. | Nov 2008 | A1 |
20090259611 | Wang | Oct 2009 | A1 |
20090282159 | Wang | Nov 2009 | A1 |
20100027974 | Ansari | Feb 2010 | A1 |
20110197237 | Turner | Aug 2011 | A1 |
Number | Date | Country |
---|---|---|
2893731 | May 2007 | FR |
1020040084932 | Oct 2004 | KR |
Entry |
---|
U.S. Appl. No. 12/495,990, entitled “Flexible Token for Use in Content Delivery,” filed Jul. 1, 2009 (Hopkins). |
International Search Report from WIPO, International Application No. PCT/US2009/061880, International Filing Date Oct. 23, 2009. Date of mailing ISR Jun. 15, 2010, 3 pages. |
Written Opinion, International Application No. PCT/US2009/061880, International Filing Date Oct. 23, 2009. Date of mailing Written Opinion Jun. 15, 2010, 5 pages. |
International Preliminary Report on Patentability, International Application No. PCT/US2009/061880, International Filing Date Oct. 23, 2009. Date of mailing Preliminary Report May 17, 2011, 1 page. |
International Search Report from WIPO, International Application No. PCT/US2009/061908, International Filing Date Oct. 23, 2009. Date of mailing ISR May 19, 2010, 5 pages. |
Written Opinion, International Application No. PCT/US2009/061908, International Filing Date Oct. 23, 2009. Date of mailing Written Opinion May 19, 2010, 5 pages. |
International Preliminary Report on Patentability, International Application No. PCT/US2009/061908, International Filing Date Oct. 23, 2009. Date of mailing Preliminary Report May 17, 2011, 1 page. |
European Extended Search Report, dated May 3, 2013, European Appl. No. 09826529.1, 8 pgs. |
European Extended Search Report, mailed May 3, 2013, European Appl. No. 09826527.5, 7 pgs. |
Number | Date | Country | |
---|---|---|---|
20100122303 A1 | May 2010 | US |
Number | Date | Country | |
---|---|---|---|
61113941 | Nov 2008 | US |