US7877694B2 - Hosted notifications templates - Google Patents

Hosted notifications templates Download PDF

Info

Publication number
US7877694B2
US7877694B2 US10/728,697 US72869703A US7877694B2 US 7877694 B2 US7877694 B2 US 7877694B2 US 72869703 A US72869703 A US 72869703A US 7877694 B2 US7877694 B2 US 7877694B2
Authority
US
United States
Prior art keywords
notifications
template
specified
content provider
category
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Expired - Fee Related, expires
Application number
US10/728,697
Other versions
US20050144266A1 (en
Inventor
Jason Antonelli
Ramu Movva
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Microsoft Technology Licensing LLC
Original Assignee
Microsoft Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Microsoft Corp filed Critical Microsoft Corp
Priority to US10/728,697 priority Critical patent/US7877694B2/en
Assigned to MICROSOFT CORPORATION reassignment MICROSOFT CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ANTONELLI, JASON, MOVVA, RAMU
Publication of US20050144266A1 publication Critical patent/US20050144266A1/en
Application granted granted Critical
Publication of US7877694B2 publication Critical patent/US7877694B2/en
Assigned to MICROSOFT TECHNOLOGY LICENSING, LLC reassignment MICROSOFT TECHNOLOGY LICENSING, LLC ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: MICROSOFT CORPORATION
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/40Network security protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/50Network services
    • H04L67/55Push-based network services
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L69/00Network arrangements, protocols or services independent of the application payload and not provided for in the other groups of this subclass
    • H04L69/30Definitions, standards or architectural aspects of layered protocol stacks
    • H04L69/32Architecture of open systems interconnection [OSI] 7-layer type protocol stacks, e.g. the interfaces between the data link level and the physical level
    • H04L69/322Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions
    • H04L69/329Intralayer communication protocols among peer entities or protocol data unit [PDU] definitions in the application layer [OSI layer 7]

Definitions

  • Embodiments of the present invention relate to the field of software notifications.
  • embodiments of this invention relate to implementing a template-based notification application use in generating notifications.
  • Up-to-date information in a wide variety of areas is very important to many people. These people often desire to be alerted to time-sensitive events and information.
  • Content providers generate content for notifications, which are then delivered to one or more user electronically (e.g., via electronic mail).
  • a news organization may provide notification content relating stock prices, breaking news, weather conditions, traffic conditions, etc.
  • a user's expressed interest to receive electronic notifications for a particular class of content is generally called a notification subscription.
  • Such subscriptions often are made between the end user and the content provider that sends the notifications.
  • Event-driven notifications of this type are often referred to as alerts.
  • An alerts application typically consists of an event feed component, multiple subscription offerings, mapping of events to notifications for subscription offerings, a signup user interface, and final notification formatting to be delivered to subscribers.
  • conventional alerts technology places a heavy burden on either the content providers or the alerts notification service for managing and generating notifications.
  • a hosted alerts system is desired to quickly develop and host alerts applications based on content feeds from interested content providers. In such a system, however, content providers are required to develop a custom alerts application each time aspects of the application changes. This results in additional and undesirable development and deployment time. For example, the ability for a retailer to quickly and easily deploy a notification involving a new special offer involving certain goods to a particular set of subscribers in a matter of hours rather than weeks could provide a significant competitive advantage.
  • Embodiments of the invention overcome one or more deficiencies in the prior art by providing template-based notification applications for use in a hosted alerts environment.
  • the invention enables a template containing necessary information relating to an alerts subscription.
  • an exemplary notifications system can execute multiple applications without burdensome additional code development, testing, and deployment overhead.
  • the features of the present invention described herein are less laborious and easier to implement than currently available techniques as well as being economically feasible and commercially practical.
  • a method embodying aspects of the invention generates notifications in a notifications system.
  • the notifications which are sent to subscribers via a data communication network, contain content provided by one or more content providers.
  • the method includes receiving a parameter-driven template from a content provider.
  • the template contains one or more parameters related to a subscription for notifications specified by the content provider.
  • the method also includes enabling a notifications application based on the received template and executing the notifications application.
  • the notifications application maps a recurring event to one or more subscribers as a function of the parameters specified by the content provider and a notification is generated and delivered to the subscribers in response to the recurring event.
  • a computer-readable medium has a data structure stored thereon that defines an application for use in a notifications system.
  • the notifications system is configured to execute the defined application for providing notifications to subscribers via a data communication network.
  • the notifications contain content provided by one or more content providers.
  • the data structure includes a scenario template configured to contain information for defining the application.
  • the scenario template has one or more parameters specified by the content provider and relating to a subscription for notifications.
  • the data structure also includes a notification generation component responsive to an event feed for mapping a recurring event to one or more subscribers as a function of the parameters specified by the content provider and generating a notification for it. A delivery component then routes the notification to the subscribers.
  • Yet another embodiment relates to a system configured for generating and delivering notifications to subscribers via a data communication network.
  • the system includes a computing device coupled to a data communication network and configured to receive a parameter-driven template from a content provider via the data communication network.
  • the template contains information provided by the content provider and relating to a subscription for notifications.
  • the system also includes a computer-readable medium that stores computer-executable instructions to be executed on the computing device to implement a notifications application based on the template.
  • the notifications application maps a recurring event to one or more subscribers as a function of one or more parameters specified by the content provider and delivers the notification to the subscribers in response to the recurring event.
  • a notification system embodying aspects of the invention generates and delivers notifications to subscribers.
  • the system includes a computing device coupled to a data communication network and configured to receive a parameter-driven template from a content provider via the data communication network.
  • the template contains information provided by the content provider and relating to a subscription for notifications.
  • the system also includes a subscription store associated with the computing device.
  • the subscription store is configured to store one or more notification offerings described by an application definition file.
  • the system also includes a computer-readable medium that stores computer-executable instructions to be executed on the computing device to implement a notifications application according to the application definition file.
  • the notifications application delivers the notification to the subscribers in response to a recurring event.
  • Computer-readable media having computer-executable instructions for performing methods of notifications management embody further aspects of the invention.
  • the invention may comprise various other methods and apparatuses.
  • FIG. 1 is a block diagram illustrating one example of a suitable alerts service environment in which the invention may be implemented.
  • FIG. 2 is an exemplary block diagram illustrating a computer-readable medium according to one embodiment of the invention.
  • FIG. 3 is an exemplary flow diagram illustrating operation according to one embodiment of the invention.
  • FIG. 4 is a block diagram illustrating one example of a suitable computing system environment in which the invention may be implemented.
  • FIG. 1 an exemplary block diagram illustrates one example of a suitable alerts service environment in which the invention may be implemented.
  • FIG. 1 illustrates the communication flow between a content provider 102 such as content provider # 1 through content provider #N, an alerts service 104 , and a user device 106 such as user device # 1 through user device #M.
  • the content provider 102 , the alerts service 104 , and the user device 106 are coupled to a data communication network such as described with reference to FIG. 4 .
  • the content provider 102 sends a notification to the alerts service 104 for delivery to one or more of the user devices 106 .
  • Alerts service 104 accesses a subscription database 108 storing subscription information and user routing preferences 110 to determine which user device(s) 106 should receive the alert. Alerts service 104 then delivers the alert to the determined user device 106 .
  • the alerts service environment is referred to as a notification pipeline and database (NPD).
  • the alerts service 104 illustrated in FIG. 1 transcends any one particular transport medium for delivery of notifications.
  • the invention may use any of a plurality of transport mediums such as electronic mail, instant messaging, mobile short-message-service messaging, wireless communications, etc.
  • a notifications system i.e., alerts service 104 operating in accordance with embodiments of the invention sends a message, often referred to as a notification or alert, to a subscribing user via his or her specified user device 106 .
  • the message contains event-driven information from content provider 102 relevant to a topic of interest to which the user has signed up.
  • a subscriber is a user or other entity that expresses an interest in a topic and receives notifications related to the topic from content provider 102 .
  • the combination of a subscriber and a topic constitutes a subscription.
  • Exemplary topics for alerts include news, weather, sports, finance, traffic, hobbies, bargains, and so forth.
  • the notifications are usually driven by events such as breaking news, changes in weather or traffic conditions, auction outbid notices, etc.
  • alert content providers 102 manage subscriber accounts, subscriptions, delivery of alerts, and the like.
  • a hosted alerts system centralizes managing subscriber accounts and subscriptions so that content providers 102 can focus on providing content rather than operating an alerts management system.
  • content providers 102 send alert content to hosted alerts system 104 in a protocol such as Simple Object Access Protocol (SOAP).
  • SOAP Simple Object Access Protocol
  • the hosted alerts system 104 determines which subscribers should receive the alert and then sends the alert to the appropriate subscribers.
  • a set of protocols for notification-based applications based on SOAP for example, provides the basis for a programming model for managing notification-based applications and serves as building blocks for a platform for such applications.
  • Notification-based applications may also be referred to as publisher/subscriber applications.
  • subscribers create subscriptions for the topics of interest to them.
  • a notification-based application matches the topic corresponding to the event with the subscriptions.
  • the notification system then sends the appropriate notification to each subscriber for all of the matches.
  • a notifications application has components for the following: subscription store (and corresponding application programming interfaces (APIs)); external “event” feed (and corresponding APIs); notification generation by matching external events with the corresponding stored subscriptions; and delivery/routing of notifications; subscription management application.
  • alerts service 104 processes notification or alert information received via the data communication network from content provider 102 .
  • An interface component 112 receives a data packet representing the notification and alerts service 104 stores it in a memory area.
  • the memory area includes a plurality of databases (not shown).
  • the notification includes routing information and content.
  • One or more computing devices associated with the alerts service 104 enable delivery of the stored notification to one or more subscribing users based on the routing information.
  • the user device 106 may be a computer such as computer 70 described with reference to FIG. 4 . Further, user device 106 may execute an alerts application (e.g., an instant messaging application) that receives and processes alerts in a web-based notifications system. The alerts application executes on user device 106 , which may also. be, for example, a cellular telephone (e.g., a Smartphone device), a pager, or a handheld computing device (e.g., a personal digital assistant or a Pocket PC device). Moreover, user device 106 may include any of the above exemplary devices enabled with an information service such as a SMART PERSONAL OBJECTS TECHNOLOGY (SPOT) brand of telecommunication service and/or devices.
  • SPOT SMART PERSONAL OBJECTS TECHNOLOGY
  • the information service comprises a computing infrastructure (e.g., a telecommunication service) for sending data and information to personal and home devices via computer networks, wireless networks and the Internet.
  • User devices 106 that may be enabled with the information service include, but are not limited to, the following devices: clocks, alarm clocks, radios incorporating clocks, watches, billfolds, wallets, checkbook and passbook wallets, purses, pens, metal key rings, key holders, wireless devices, computer hardware (e.g., peripherals, monitors, and displays), electronic calendar devices, and refrigerator magnets.
  • magazines, books, and user manuals relating to computers, computer programs, personal information devices and wireless communications may also incorporate the information service.
  • the information service enables billions of devices to communicate with each other.
  • Information available to users on devices using the information service includes personal messages, calendar updates, and customized news, weather, financial and sports information.
  • alerts service 104 may include a distributed processing system.
  • content provider 102 posts an alert such as in the form of an extensible markup language (XML) document
  • alerts service 104 parses the alert and validates the packet.
  • Alerts service 104 may also asynchronously process the alert by queuing it into an NPD queue or other memory area.
  • the NPD queue represents an internal queue of work items that are acted upon by any one of the multiple threads in the thread pool, but only one thread processes the item at any given time.
  • the alerts service 104 retrieves information regarding, for example, a specific broadcast list specified in the alert, such as the number of members or users, and an internal 32-bit row identifier from a database such as a broadcast list database (BLDB) (not shown).
  • a web services component e.g., an ASP.NET web service
  • UPS user profile store
  • a computer-readable medium storing a data structure embodies application definition file 202 .
  • the application definition file 202 defines an application for use in a notifications system, such as alerts system 104 .
  • alerts system 104 in this embodiment is configured to execute the defined application for providing notifications to subscribers via a data communication network.
  • Application definition file 202 includes a scenario template 204 configured to contain information for defining the application.
  • the scenario template 204 of FIG. 2 has one or more parameters specified by content provider 102 and relating to a subscription for notifications.
  • a notification generation component 206 responsive to an event feed maps a recurring event to one or more subscribers as a function of the parameters specified by content provider 102 , which in turn yields a notification.
  • Application definition file 202 also includes a delivery component 208 for routing the notification to the subscribers.
  • scenario template 204 of application definition file 202 includes a category component 210 for defining a category of events for which the notifications are to be generated and a scheduling component 212 for defining when the notifications are to be delivered.
  • a category component 210 for defining a category of events for which the notifications are to be generated
  • a scheduling component 212 for defining when the notifications are to be delivered.
  • one of the parameters specified by content provider 102 may relate to delivery of the notifications at a predetermined time of day and another one of the parameters specified by content provider 102 may relate to delivery of the notifications upon occurrence of the recurring event.
  • applications may be completely defined through metadata described in application definition file 202 . Additional code need not be written once the basic code is written to handle applications and the corresponding scenario templates 204 . This is a key to delivering many alerting applications quickly without custom coding, testing, and deployment.
  • scenario template 204 is described in the context of category component 210 in the embodiment of FIG. 2
  • alternative embodiments of the present invention may be used to enable applications other than category-based applications.
  • category component 210 may be replaced by a stock component for enabling determination of when a stock hits a certain price, i.e., a threshold.
  • a user interface template 214 is configured to contain information for defining a user interface corresponding to the application for managing the subscription.
  • application definition file 202 Further aspects of application definition file 202 are described in greater detail below.
  • FIG. 3 illustrates a method of generating notifications in a notifications system in the form of an exemplary flow diagram.
  • notifications system 104 is configured to provide notifications to subscribers via a data communication network.
  • the notifications contain content provided by one or more content providers 102 .
  • hosted alerts service 104 provides a parameter-driven template to content provider 102 for completion.
  • scenario template 204 or user interface template 214 is part of the parameter-driven template.
  • the template is received from content provider 102 (e.g., by alerts service 104 ).
  • the template in this embodiment contains one or more parameters specified by content provider 102 and relating to a subscription for notifications.
  • a notifications application based on the received template is enabled.
  • alerts system 104 enables a notifications application based on application definition file 202 (i.e., new code need not be implemented).
  • Enabling the application includes defining, with the template, a category of events for which the notifications are to be generated and when the notifications are to be delivered. For example, alerts service 104 matches a most recent instance of the recurring event to the subscription to generate the notifications for delivery at a user-defined, scheduled predetermined time of day. In another example, alerts service 104 matches the recurring event to the subscription to generate the notifications for broadcast delivery upon occurrence of the recurring event.
  • the notifications application in this instance maps a recurring event to one or more subscribers as a function of the parameters specified by content provider 102 .
  • FIG. 3 further illustrates at 308 executing the notifications application to generate a notification in response to the recurring event and to deliver the notification to the subscribers.
  • a hosted alerts system embodying aspects of the invention such as alerts service 104 , quickly develops and hosts notifications applications based on content feeds from content providers 102 . Hosted alerts in this instance take on the burden of managing user's content subscriptions and generating alerts, which permits content providers 102 to focus on aggregating, editorializing, transforming, and publishing rich content. According to embodiments of the invention, the use of scenario templates 204 minimizes the development and deployment time of event-driven notifications.
  • Alerts or notifications applications generally include components relating to event feeds, multiple subscription offerings, event to notification mapping for subscription offerings, signup user interfaces, and final notification formatting to be delivered to subscribers.
  • Scenario template 204 advantageously contains necessary information relating to an individual subscription such that hosted alerts applications can choose between multiple scenario templates supported.
  • Alerts service 104 implements the required logic based on scenario template 204 and multiple applications can utilize them without further code development and testing and without significant increases in deployment overhead.
  • Embodiments of the present invention employ an application that includes reusable, predefined scenario templates 204 among other things.
  • Scenario templates 204 are building blocks that can be specialized through parameters to represent a single alert offering.
  • the full description of the application is found in the application definition file 202 .
  • alerts service 104 Given a set of application definition files 202 , alerts service 104 provides a full set of components for the alerting applications that described by the application definition files.
  • a subscription store stores the user's notification subscriptions described by the scenarios defined with the application and a provisioning script provisions the applications in the alerts system.
  • middle tier subscription APIs may be driven off of application definition file 202 to validate incoming subscription management requests and to commit them to the subscription store.
  • middle tier eventing APIs may be driven off of application definition file 202 to validate incoming event management requests and to commit them to the event store. Jobs/processes are configured in one embodiment of the invention to generate notifications based on the matching external events with the corresponding subscriptions and to deliver the notifications to the core alerts service 104 delivery/routing mechanism.
  • a web site may be driven off of application definition file 202 to provide a user interface with which end users could interact to create, update, and delete subscriptions.
  • a Category-Based Scheduled scenario template provides subscriptions to be defined in terms of subscribing to a specific category (or channel) of notifications to be delivered at a predetermined time of day.
  • event feeds including the full “alert” to be sent are expected to come in for each category or channel on a recurring basis.
  • Notifications are generated based on matching the latest event of a given category with the subscriptions for the same category at the predefined schedule time.
  • a Category-Based Broadcast scenario template provides subscriptions to be defined in terms of subscribing to a specific category (or channel) of notifications to be delivered at a time that they occurred. Again, event feeds including the full “alert” to be sent are expected to come in for each category on a recurring basis. Notifications are generated based on matching each event of a given category with the subscriptions for that category at the time the event is submitted to hosted alerts service 104 .
  • Horoscope Users sign up for a given horoscope sign at a given time of day for a given set of days each week. This offering may be implemented using a category-based scheduled scenario template 204 where the category represents the horoscope sign.
  • Lottery Users sign up for lottery results of a given state at a given time of day for a given set of days each week. This offering may be implemented using a category-based scheduled scenario template 204 where the category represents the state.
  • News Users either sign up for summary news or headline news or both for a given topic of news (e.g. Top stories, Sports, International, etc.) for a given time of day for a given set of days each week.
  • This offering may be implemented using two instances of a category-based scheduled scenario template 204 where the category for each represents the topic of news.
  • the first instance of the category-based scheduled scenario template represents summary news and the second instance represents headline news.
  • user interface template 214 provides an additional level of abstraction for building a subscription management application.
  • User interface templates 214 are templates that define a user interface to manage subscriptions for a given application.
  • a single alerting system brings any number of alert offerings implemented via parameterized scenario templates 204 . Accordingly, some flexibility to define how the various alert offerings are presented to the user for a given application is desired.
  • user interface template 214 applied independently of scenario templates 204 permit a user to sign up for multiple types of alert offerings that are similar (e.g., summary news and headline news that shared the same categories) at the same time.
  • a Category-Based Scheduled user interface template manages subscriptions for one or more Category-Based Scheduled scenario templates 204 that share the same category lists among all category-based schedule scenarios. For example, such a user interface template 214 shows the list of categories just once but still allows managing either type of subscriptions.
  • User interface templates 214 are parameterized to specify the names of the scenarios as well as the localized text to plug in throughout the user interface.
  • the user interface for example, includes web pages accessible over network such as the Internet.
  • a single set of ASP.NET-based web pages for each user interface template 214 with mechanisms to access the parameters of application definition files 202 may be programmatically customized according to the parameters given for the application.
  • each application also includes additional information to provision the application in the delivery/routing alert system (e.g., core alerts service 104 ).
  • the additional information contains the additional parameters used to “provision” the application in the alerts system.
  • APPENDIX A describes an exemplary application definition file schema according to embodiments of the invention.
  • the schema of APPENDIX A constitutes a parameter-driven template.
  • APPENDIX B provides an example of an application definition file according to the schema of APPENDIX A (i.e., an example of a template returned by content provider 102 ).
  • FIG. 4 shows one example of a general purpose computing device in the form of a computer 70 .
  • a computer such as the computer 70 is suitable for use in alerts service 104 .
  • computer 70 has one or more processors or processing units 72 and a system memory 74 .
  • a system bus 76 couples various system components including the system memory 74 to the processors 72 .
  • the bus 76 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures.
  • bus architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus.
  • the computer 70 typically has at least some form of computer readable media.
  • Computer readable media which include both volatile and nonvolatile media, removable and non-removable media, may be any available medium that may be accessed by computer 70 .
  • Computer readable media comprise computer storage media and communication media.
  • Computer storage media include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data.
  • computer storage media include RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that may be used to store the desired information and that may be accessed by computer 70 .
  • Communication media typically embody computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and include any information delivery media. Those skilled in the art are familiar with the modulated data signal, which has one or more of its characteristics set or changed in such a manner as to encode information in the signal.
  • Wired media such as a wired network or direct-wired connection
  • wireless media such as acoustic, RF, infrared, and other wireless media
  • communication media such as acoustic, RF, infrared, and other wireless media
  • the system memory 74 includes computer storage media in the form of removable and/or non-removable, volatile and/or nonvolatile memory.
  • system memory 74 includes read only memory (ROM) 78 and random access memory (RAM) 80 .
  • ROM read only memory
  • RAM random access memory
  • the RAM 80 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 72 .
  • FIG. 4 illustrates operating system 84 , application programs 86 , other program modules 88 , and program data 90 .
  • the computer 70 may also include other removable/non-removable, volatile/nonvolatile computer storage media.
  • FIG. 4 illustrates a hard disk drive 94 that reads from or writes to non-removable, nonvolatile magnetic media.
  • FIG. 4 also shows a magnetic disk drive 96 that reads from or writes to a removable, nonvolatile magnetic disk 98 , and an optical disk drive 100 that reads from or writes to a removable, nonvolatile optical disk 102 such as a CD-ROM or other optical media.
  • removable/non-removable, volatile/nonvolatile computer storage media that may be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like.
  • the hard disk drive 84 , and magnetic disk drive 96 and optical disk drive 100 are typically connected to the system bus 76 by a non-volatile memory interface, such as interface 106 .
  • hard disk drive 94 is illustrated as storing operating system 110 , application programs 112 , other program modules 114 , and program data 116 . Note that these components can either be the same as or different from operating system 84 , application programs 86 , other program modules 88 , and program data 90 . Operating system 110 , application programs 112 , other program modules 114 , and program data 116 are given different numbers here to illustrate that, at a minimum, they are different copies.
  • a user may enter commands and information into computer 70 through input devices or user interface selection devices such as a keyboard 120 and a pointing device 122 (e.g., a mouse, trackball, pen, or touch pad).
  • Other input devices may include a microphone, joystick, game pad, satellite dish, scanner, or the like.
  • processing unit 72 through a user input interface 124 that is coupled to system bus 76 , but may be connected by other interface and bus structures, such as a parallel port, game port, or a universal serial bus (USB).
  • a monitor 128 or other type of display device is also connected to system bus 76 via an interface, such as a video interface 130 .
  • computers often include other peripheral output devices (not shown) such as a printer and speakers, which may be connected through an output peripheral interface (not shown).
  • the computer 70 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 134 .
  • the remote computer 134 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to computer 70 .
  • the logical connections depicted in FIG. 4 include a local area network (LAN) 136 and a wide area network (WAN) 138 , but may also include other networks.
  • LAN 136 and/or WAN 138 may be a wired network, a wireless network, a combination thereof, and so on.
  • Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and global computer networks (e.g., the Internet).
  • computer 70 When used in a local area networking environment, computer 70 is connected to the LAN 136 through a network interface or adapter 140 . When used in a wide area networking environment, computer 70 typically includes a modem 142 or other means for establishing communications over the WAN 138 , such as the Internet.
  • the modem 142 which may be internal or external, is connected to system bus 76 via the user input interface 134 , or other appropriate mechanism.
  • program modules depicted relative to computer 70 may be stored in a remote memory storage device (not shown).
  • FIG. 4 illustrates remote application programs 144 as residing on the memory device.
  • the network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
  • the data processors of computer 70 are programmed by means of instructions stored at different times in the various computer-readable storage media of the computer.
  • Programs and operating systems are typically distributed, for example, on floppy disks or CD-ROMs. From there, they are installed or loaded into the secondary memory of a computer. At execution, they are loaded at least partially into the computer's primary electronic memory.
  • the invention described herein includes these and other various types of computer-readable storage media when such media contain instructions or programs for implementing the steps described herein in conjunction with a microprocessor or other data processor.
  • the invention also includes the computer itself when programmed according to the methods and techniques described herein.
  • the invention is operational with numerous other general purpose or special purpose computing system environments or configurations.
  • the computing system environment is not intended to suggest any limitation as to the scope of use or functionality of the invention.
  • the computing system environment should not be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary operating environment.
  • Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, mobile telephones, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
  • Embodiments of the invention may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices.
  • program modules include, but are not limited to, routines, programs, objects, components, and data structures that perform particular tasks or implement particular abstract data types.
  • the invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network.
  • program modules may be located in both local and remote computer storage media including memory storage devices.
  • An interface in the context of software architecture includes a software module, component, code portion, or other sequence of computer-executable instructions.
  • the interface includes, for example, a first module accessing a second module to perform computing tasks on behalf of the first module.
  • the first and second modules include, in one example, application programming interfaces (APIs) such as provided by operating systems, component object model (COM) interfaces (e.g., for peer-to-peer application communication), and extensible markup language metadata interchange format (XMI) interfaces (e.g., for communication between web services).
  • APIs application programming interfaces
  • COM component object model
  • XMI extensible markup language metadata interchange format
  • the interface may be a tightly coupled, synchronous implementation such as in Java 2 Platform Enterprise Edition (J2EE), COM, or distributed COM (DCOM) examples.
  • the interface may be a loosely coupled, asynchronous implementation such as in a web service (e.g., using the simple object access protocol).
  • the interface includes any combination of the following characteristics: tightly coupled, loosely coupled, synchronous, and asynchronous.
  • the interface may conform to a standard protocol, a proprietary protocol, or any combination of standard and proprietary protocols.
  • the interfaces described herein may all be part of a single interface or may be implemented as separate interfaces or any combination therein.
  • the interfaces may execute locally or remotely to provide functionality. Further, the interfaces may include additional or less functionality than illustrated or described herein.
  • computer 70 executes computer-executable instructions such as those described herein to receive a parameter-driven template, including scenario template 204 , from content provider 102 .
  • Computer 70 in this exemplary embodiment, enables a notifications application based on the received template and executes the notifications application.
  • the notifications application maps a recurring event to one or more subscribers as a function of the parameters specified by content provider 102 and computer 70 generates a notification and delivers it to the subscribers in response to the recurring event.
  • the Application Definition file follows the exemplary schema shown above in APPENDIX A.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Computer Security & Cryptography (AREA)
  • Information Transfer Between Computers (AREA)

Abstract

Method and systems for generating notifications in a notifications system. A parameter-driven template received from a content provider contains one or more parameters related to a subscription for notifications. The notifications system enables an application based on the received template and executes it to map a recurring event to one or more subscribers as a function of the parameters specified by the content provider. In response to the recurring event, the notification system generates a notification. Other aspects of the invention relate to a computer-readable medium that defines the application for use in a notifications system.

Description

TECHNICAL FIELD
Embodiments of the present invention relate to the field of software notifications. In particular, embodiments of this invention relate to implementing a template-based notification application use in generating notifications.
BACKGROUND OF THE INVENTION
Up-to-date information in a wide variety of areas is very important to many people. These people often desire to be alerted to time-sensitive events and information. Content providers generate content for notifications, which are then delivered to one or more user electronically (e.g., via electronic mail). For example, a news organization may provide notification content relating stock prices, breaking news, weather conditions, traffic conditions, etc. A user's expressed interest to receive electronic notifications for a particular class of content is generally called a notification subscription. Such subscriptions often are made between the end user and the content provider that sends the notifications. Event-driven notifications of this type are often referred to as alerts.
An alerts application typically consists of an event feed component, multiple subscription offerings, mapping of events to notifications for subscription offerings, a signup user interface, and final notification formatting to be delivered to subscribers. Disadvantageously, conventional alerts technology places a heavy burden on either the content providers or the alerts notification service for managing and generating notifications. A hosted alerts system is desired to quickly develop and host alerts applications based on content feeds from interested content providers. In such a system, however, content providers are required to develop a custom alerts application each time aspects of the application changes. This results in additional and undesirable development and deployment time. For example, the ability for a retailer to quickly and easily deploy a notification involving a new special offer involving certain goods to a particular set of subscribers in a matter of hours rather than weeks could provide a significant competitive advantage.
Accordingly, faster development and deployment of notifications is desired to address one or more of these and other disadvantages.
SUMMARY OF THE INVENTION
Embodiments of the invention overcome one or more deficiencies in the prior art by providing template-based notification applications for use in a hosted alerts environment. In one embodiment, the invention enables a template containing necessary information relating to an alerts subscription. By enabling the required logic based on the template, an exemplary notifications system can execute multiple applications without burdensome additional code development, testing, and deployment overhead. Moreover, the features of the present invention described herein are less laborious and easier to implement than currently available techniques as well as being economically feasible and commercially practical.
Briefly described, a method embodying aspects of the invention generates notifications in a notifications system. The notifications, which are sent to subscribers via a data communication network, contain content provided by one or more content providers. The method includes receiving a parameter-driven template from a content provider. The template contains one or more parameters related to a subscription for notifications specified by the content provider. The method also includes enabling a notifications application based on the received template and executing the notifications application. In this instance, the notifications application maps a recurring event to one or more subscribers as a function of the parameters specified by the content provider and a notification is generated and delivered to the subscribers in response to the recurring event.
In another embodiment, a computer-readable medium has a data structure stored thereon that defines an application for use in a notifications system. The notifications system is configured to execute the defined application for providing notifications to subscribers via a data communication network. The notifications contain content provided by one or more content providers. The data structure includes a scenario template configured to contain information for defining the application. In this embodiment, the scenario template has one or more parameters specified by the content provider and relating to a subscription for notifications. The data structure also includes a notification generation component responsive to an event feed for mapping a recurring event to one or more subscribers as a function of the parameters specified by the content provider and generating a notification for it. A delivery component then routes the notification to the subscribers.
Yet another embodiment relates to a system configured for generating and delivering notifications to subscribers via a data communication network. The system includes a computing device coupled to a data communication network and configured to receive a parameter-driven template from a content provider via the data communication network. The template contains information provided by the content provider and relating to a subscription for notifications. The system also includes a computer-readable medium that stores computer-executable instructions to be executed on the computing device to implement a notifications application based on the template. The notifications application maps a recurring event to one or more subscribers as a function of one or more parameters specified by the content provider and delivers the notification to the subscribers in response to the recurring event.
A notification system embodying aspects of the invention generates and delivers notifications to subscribers. The system includes a computing device coupled to a data communication network and configured to receive a parameter-driven template from a content provider via the data communication network. The template contains information provided by the content provider and relating to a subscription for notifications. The system also includes a subscription store associated with the computing device. The subscription store is configured to store one or more notification offerings described by an application definition file. The system also includes a computer-readable medium that stores computer-executable instructions to be executed on the computing device to implement a notifications application according to the application definition file. The notifications application delivers the notification to the subscribers in response to a recurring event.
Computer-readable media having computer-executable instructions for performing methods of notifications management embody further aspects of the invention.
Alternatively, the invention may comprise various other methods and apparatuses.
Other features will be in part apparent and in part pointed out hereinafter.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram illustrating one example of a suitable alerts service environment in which the invention may be implemented.
FIG. 2 is an exemplary block diagram illustrating a computer-readable medium according to one embodiment of the invention.
FIG. 3 is an exemplary flow diagram illustrating operation according to one embodiment of the invention.
FIG. 4 is a block diagram illustrating one example of a suitable computing system environment in which the invention may be implemented.
Corresponding reference characters indicate corresponding parts throughout the drawings.
DETAILED DESCRIPTION OF THE INVENTION
Referring first to FIG. 1, an exemplary block diagram illustrates one example of a suitable alerts service environment in which the invention may be implemented. FIG. 1 illustrates the communication flow between a content provider 102 such as content provider #1 through content provider #N, an alerts service 104, and a user device 106 such as user device #1 through user device #M. The content provider 102, the alerts service 104, and the user device 106 are coupled to a data communication network such as described with reference to FIG. 4. The content provider 102 sends a notification to the alerts service 104 for delivery to one or more of the user devices 106. Alerts service 104 accesses a subscription database 108 storing subscription information and user routing preferences 110 to determine which user device(s) 106 should receive the alert. Alerts service 104 then delivers the alert to the determined user device 106. In one example, the alerts service environment is referred to as a notification pipeline and database (NPD).
The alerts service 104 illustrated in FIG. 1 transcends any one particular transport medium for delivery of notifications. The invention may use any of a plurality of transport mediums such as electronic mail, instant messaging, mobile short-message-service messaging, wireless communications, etc.
Aspects of the present invention provide a hosted notification mechanism for greater versatility and usability. In general, a notifications system (i.e., alerts service 104) operating in accordance with embodiments of the invention sends a message, often referred to as a notification or alert, to a subscribing user via his or her specified user device 106. The message contains event-driven information from content provider 102 relevant to a topic of interest to which the user has signed up. In other words, a subscriber is a user or other entity that expresses an interest in a topic and receives notifications related to the topic from content provider 102. In one embodiment, the combination of a subscriber and a topic constitutes a subscription. Exemplary topics for alerts include news, weather, sports, finance, traffic, hobbies, bargains, and so forth. As described above, the notifications are usually driven by events such as breaking news, changes in weather or traffic conditions, auction outbid notices, etc.
In a de-centralized system, alert content providers 102 manage subscriber accounts, subscriptions, delivery of alerts, and the like. A hosted alerts system according to embodiments of the invention centralizes managing subscriber accounts and subscriptions so that content providers 102 can focus on providing content rather than operating an alerts management system. For example, content providers 102 send alert content to hosted alerts system 104 in a protocol such as Simple Object Access Protocol (SOAP). The hosted alerts system 104 determines which subscribers should receive the alert and then sends the alert to the appropriate subscribers. A set of protocols for notification-based applications based on SOAP, for example, provides the basis for a programming model for managing notification-based applications and serves as building blocks for a platform for such applications.
Notification-based applications may also be referred to as publisher/subscriber applications. In this instance, subscribers create subscriptions for the topics of interest to them. When an event occurs, a notification-based application matches the topic corresponding to the event with the subscriptions. The notification system then sends the appropriate notification to each subscriber for all of the matches. In general, a notifications application has components for the following: subscription store (and corresponding application programming interfaces (APIs)); external “event” feed (and corresponding APIs); notification generation by matching external events with the corresponding stored subscriptions; and delivery/routing of notifications; subscription management application.
Referring further to FIG. 1, alerts service 104 processes notification or alert information received via the data communication network from content provider 102. An interface component 112 receives a data packet representing the notification and alerts service 104 stores it in a memory area. In one example, the memory area includes a plurality of databases (not shown). The notification includes routing information and content. One or more computing devices associated with the alerts service 104 enable delivery of the stored notification to one or more subscribing users based on the routing information.
The user device 106 may be a computer such as computer 70 described with reference to FIG. 4. Further, user device 106 may execute an alerts application (e.g., an instant messaging application) that receives and processes alerts in a web-based notifications system. The alerts application executes on user device 106, which may also. be, for example, a cellular telephone (e.g., a Smartphone device), a pager, or a handheld computing device (e.g., a personal digital assistant or a Pocket PC device). Moreover, user device 106 may include any of the above exemplary devices enabled with an information service such as a SMART PERSONAL OBJECTS TECHNOLOGY (SPOT) brand of telecommunication service and/or devices. The information service comprises a computing infrastructure (e.g., a telecommunication service) for sending data and information to personal and home devices via computer networks, wireless networks and the Internet. User devices 106 that may be enabled with the information service include, but are not limited to, the following devices: clocks, alarm clocks, radios incorporating clocks, watches, billfolds, wallets, checkbook and passbook wallets, purses, pens, metal key rings, key holders, wireless devices, computer hardware (e.g., peripherals, monitors, and displays), electronic calendar devices, and refrigerator magnets. Further, magazines, books, and user manuals relating to computers, computer programs, personal information devices and wireless communications may also incorporate the information service. The information service enables billions of devices to communicate with each other. For example, customers select the type of information and services they want to receive on the enabled devices via a configuration web page. This content is subsequently beamed to and displayed on the device. Information available to users on devices using the information service includes personal messages, calendar updates, and customized news, weather, financial and sports information.
In one embodiment, the system shown in FIG. 1 is implemented as a web service and functionality associated with alerts service 104 may be distributed among one or more computers. For example, alerts service 104 may include a distributed processing system. When content provider 102 posts an alert such as in the form of an extensible markup language (XML) document, alerts service 104 parses the alert and validates the packet. Alerts service 104 may also asynchronously process the alert by queuing it into an NPD queue or other memory area. The NPD queue represents an internal queue of work items that are acted upon by any one of the multiple threads in the thread pool, but only one thread processes the item at any given time. The alerts service 104 then retrieves information regarding, for example, a specific broadcast list specified in the alert, such as the number of members or users, and an internal 32-bit row identifier from a database such as a broadcast list database (BLDB) (not shown). A web services component (e.g., an ASP.NET web service), for example, embodying a subscription management web service manipulates a user profile database (UPDB) or user profile store (UPS) (not shown) to obtain information regarding the subscribing user based on the notification information received from content provider 102.
Referring now to FIG. 2, a computer-readable medium storing a data structure embodies application definition file 202. The application definition file 202 defines an application for use in a notifications system, such as alerts system 104. In particular, alerts system 104 in this embodiment is configured to execute the defined application for providing notifications to subscribers via a data communication network. Application definition file 202 includes a scenario template 204 configured to contain information for defining the application. The scenario template 204 of FIG. 2 has one or more parameters specified by content provider 102 and relating to a subscription for notifications. A notification generation component 206 responsive to an event feed maps a recurring event to one or more subscribers as a function of the parameters specified by content provider 102, which in turn yields a notification. Application definition file 202 also includes a delivery component 208 for routing the notification to the subscribers.
As shown in FIG. 2, scenario template 204 of application definition file 202 includes a category component 210 for defining a category of events for which the notifications are to be generated and a scheduling component 212 for defining when the notifications are to be delivered. For example, one of the parameters specified by content provider 102 may relate to delivery of the notifications at a predetermined time of day and another one of the parameters specified by content provider 102 may relate to delivery of the notifications upon occurrence of the recurring event.
Thus, applications may be completely defined through metadata described in application definition file 202. Additional code need not be written once the basic code is written to handle applications and the corresponding scenario templates 204. This is a key to delivering many alerting applications quickly without custom coding, testing, and deployment.
Although scenario template 204 is described in the context of category component 210 in the embodiment of FIG. 2, alternative embodiments of the present invention may be used to enable applications other than category-based applications. For example, in a threshold-based application, category component 210 may be replaced by a stock component for enabling determination of when a stock hits a certain price, i.e., a threshold. In a further embodiment, a user interface template 214 is configured to contain information for defining a user interface corresponding to the application for managing the subscription.
Further aspects of application definition file 202 are described in greater detail below.
FIG. 3 illustrates a method of generating notifications in a notifications system in the form of an exemplary flow diagram. In FIG. 3 notifications system 104 is configured to provide notifications to subscribers via a data communication network. The notifications contain content provided by one or more content providers 102. Beginning at 302, hosted alerts service 104 provides a parameter-driven template to content provider 102 for completion. In certain embodiments of the invention, scenario template 204 or user interface template 214 is part of the parameter-driven template. At 304, the template is received from content provider 102 (e.g., by alerts service 104). The template in this embodiment contains one or more parameters specified by content provider 102 and relating to a subscription for notifications. Proceeding to 306, a notifications application based on the received template is enabled. In other words, alerts system 104 enables a notifications application based on application definition file 202 (i.e., new code need not be implemented).
Enabling the application includes defining, with the template, a category of events for which the notifications are to be generated and when the notifications are to be delivered. For example, alerts service 104 matches a most recent instance of the recurring event to the subscription to generate the notifications for delivery at a user-defined, scheduled predetermined time of day. In another example, alerts service 104 matches the recurring event to the subscription to generate the notifications for broadcast delivery upon occurrence of the recurring event. The notifications application in this instance maps a recurring event to one or more subscribers as a function of the parameters specified by content provider 102.
FIG. 3 further illustrates at 308 executing the notifications application to generate a notification in response to the recurring event and to deliver the notification to the subscribers.
A hosted alerts system embodying aspects of the invention, such as alerts service 104, quickly develops and hosts notifications applications based on content feeds from content providers 102. Hosted alerts in this instance take on the burden of managing user's content subscriptions and generating alerts, which permits content providers 102 to focus on aggregating, editorializing, transforming, and publishing rich content. According to embodiments of the invention, the use of scenario templates 204 minimizes the development and deployment time of event-driven notifications.
Alerts or notifications applications generally include components relating to event feeds, multiple subscription offerings, event to notification mapping for subscription offerings, signup user interfaces, and final notification formatting to be delivered to subscribers. Scenario template 204 advantageously contains necessary information relating to an individual subscription such that hosted alerts applications can choose between multiple scenario templates supported. Alerts service 104 implements the required logic based on scenario template 204 and multiple applications can utilize them without further code development and testing and without significant increases in deployment overhead.
Embodiments of the present invention employ an application that includes reusable, predefined scenario templates 204 among other things. Scenario templates 204 are building blocks that can be specialized through parameters to represent a single alert offering. The full description of the application is found in the application definition file 202. Given a set of application definition files 202, alerts service 104 provides a full set of components for the alerting applications that described by the application definition files. Specifically, for each application definition file 202, a subscription store stores the user's notification subscriptions described by the scenarios defined with the application and a provisioning script provisions the applications in the alerts system.
In addition, middle tier subscription APIs may be driven off of application definition file 202 to validate incoming subscription management requests and to commit them to the subscription store. Similarly, middle tier eventing APIs may be driven off of application definition file 202 to validate incoming event management requests and to commit them to the event store. Jobs/processes are configured in one embodiment of the invention to generate notifications based on the matching external events with the corresponding subscriptions and to deliver the notifications to the core alerts service 104 delivery/routing mechanism.
In yet another embodiment of the invention, a web site may be driven off of application definition file 202 to provide a user interface with which end users could interact to create, update, and delete subscriptions.
Referring now to specific examples embodying aspects of the invention, many alerting offerings share the same basic schema such that they can be defined in terms of predefined scenario templates 204. For example, a Category-Based Scheduled scenario template provides subscriptions to be defined in terms of subscribing to a specific category (or channel) of notifications to be delivered at a predetermined time of day. In this instance, event feeds including the full “alert” to be sent are expected to come in for each category or channel on a recurring basis. Notifications are generated based on matching the latest event of a given category with the subscriptions for the same category at the predefined schedule time.
In another example, a Category-Based Broadcast scenario template provides subscriptions to be defined in terms of subscribing to a specific category (or channel) of notifications to be delivered at a time that they occurred. Again, event feeds including the full “alert” to be sent are expected to come in for each category on a recurring basis. Notifications are generated based on matching each event of a given category with the subscriptions for that category at the time the event is submitted to hosted alerts service 104.
The following are examples of alert offerings that may be provided using a scenario template model:
Horoscope: Users sign up for a given horoscope sign at a given time of day for a given set of days each week. This offering may be implemented using a category-based scheduled scenario template 204 where the category represents the horoscope sign.
Lottery: Users sign up for lottery results of a given state at a given time of day for a given set of days each week. This offering may be implemented using a category-based scheduled scenario template 204 where the category represents the state.
News: Users either sign up for summary news or headline news or both for a given topic of news (e.g. Top Stories, Sports, International, etc.) for a given time of day for a given set of days each week. This offering may be implemented using two instances of a category-based scheduled scenario template 204 where the category for each represents the topic of news. The first instance of the category-based scheduled scenario template represents summary news and the second instance represents headline news.
Although major components of a notifications application can be defined in terms of scenario templates 204 (e.g., subscription store, generation matching logic, etc.), user interface template 214 provides an additional level of abstraction for building a subscription management application. User interface templates 214 are templates that define a user interface to manage subscriptions for a given application.
In one embodiment of the invention, a single alerting system brings any number of alert offerings implemented via parameterized scenario templates 204. Accordingly, some flexibility to define how the various alert offerings are presented to the user for a given application is desired. For example, user interface template 214 applied independently of scenario templates 204 permit a user to sign up for multiple types of alert offerings that are similar (e.g., summary news and headline news that shared the same categories) at the same time.
Referring now to a specific example of user interface templates 214, a Category-Based Scheduled user interface template manages subscriptions for one or more Category-Based Scheduled scenario templates 204 that share the same category lists among all category-based schedule scenarios. For example, such a user interface template 214 shows the list of categories just once but still allows managing either type of subscriptions.
User interface templates 214 are parameterized to specify the names of the scenarios as well as the localized text to plug in throughout the user interface. The user interface, for example, includes web pages accessible over network such as the Internet. In this instance, a single set of ASP.NET-based web pages for each user interface template 214 with mechanisms to access the parameters of application definition files 202 may be programmatically customized according to the parameters given for the application.
According to embodiments of the invention, each application also includes additional information to provision the application in the delivery/routing alert system (e.g., core alerts service 104). The additional information contains the additional parameters used to “provision” the application in the alerts system.
APPENDIX A describes an exemplary application definition file schema according to embodiments of the invention. For example, the schema of APPENDIX A constitutes a parameter-driven template. APPENDIX B provides an example of an application definition file according to the schema of APPENDIX A (i.e., an example of a template returned by content provider 102).
FIG. 4 shows one example of a general purpose computing device in the form of a computer 70. In one embodiment of the invention, a computer such as the computer 70 is suitable for use in alerts service 104.
In the illustrated embodiments, computer 70 has one or more processors or processing units 72 and a system memory 74. In the illustrated embodiment, a system bus 76 couples various system components including the system memory 74 to the processors 72. The bus 76 represents one or more of any of several types of bus structures, including a memory bus or memory controller, a peripheral bus, an accelerated graphics port, and a processor or local bus using any of a variety of bus architectures. By way of example, and not limitation, such architectures include Industry Standard Architecture (ISA) bus, Micro Channel Architecture (MCA) bus, Enhanced ISA (EISA) bus, Video Electronics Standards Association (VESA) local bus, and Peripheral Component Interconnect (PCI) bus also known as Mezzanine bus.
The computer 70 typically has at least some form of computer readable media. Computer readable media, which include both volatile and nonvolatile media, removable and non-removable media, may be any available medium that may be accessed by computer 70. By way of example and not limitation, computer readable media comprise computer storage media and communication media. Computer storage media include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. For example, computer storage media include RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium that may be used to store the desired information and that may be accessed by computer 70. Communication media typically embody computer readable instructions, data structures, program modules, or other data in a modulated data signal such as a carrier wave or other transport mechanism and include any information delivery media. Those skilled in the art are familiar with the modulated data signal, which has one or more of its characteristics set or changed in such a manner as to encode information in the signal. Wired media, such as a wired network or direct-wired connection, and wireless media, such as acoustic, RF, infrared, and other wireless media, are examples of communication media. Combinations of the any of the above are also included within the scope of computer readable media.
The system memory 74 includes computer storage media in the form of removable and/or non-removable, volatile and/or nonvolatile memory. In the illustrated embodiment, system memory 74 includes read only memory (ROM) 78 and random access memory (RAM) 80. A basic input/output system 82 (BIOS), containing the basic routines that help to transfer information between elements within computer 70, such as during start-up, is typically stored in ROM 78. The RAM 80 typically contains data and/or program modules that are immediately accessible to and/or presently being operated on by processing unit 72. By way of example, and not limitation, FIG. 4 illustrates operating system 84, application programs 86, other program modules 88, and program data 90.
The computer 70 may also include other removable/non-removable, volatile/nonvolatile computer storage media. For example, FIG. 4 illustrates a hard disk drive 94 that reads from or writes to non-removable, nonvolatile magnetic media. FIG. 4 also shows a magnetic disk drive 96 that reads from or writes to a removable, nonvolatile magnetic disk 98, and an optical disk drive 100 that reads from or writes to a removable, nonvolatile optical disk 102 such as a CD-ROM or other optical media. Other removable/non-removable, volatile/nonvolatile computer storage media that may be used in the exemplary operating environment include, but are not limited to, magnetic tape cassettes, flash memory cards, digital versatile disks, digital video tape, solid state RAM, solid state ROM, and the like. The hard disk drive 84, and magnetic disk drive 96 and optical disk drive 100 are typically connected to the system bus 76 by a non-volatile memory interface, such as interface 106.
The drives or other mass storage devices and their associated computer storage media discussed above and illustrated in FIG. 4, provide storage of computer readable instructions, data structures, program modules and other data for the computer 70. In FIG. 4, for example, hard disk drive 94 is illustrated as storing operating system 110, application programs 112, other program modules 114, and program data 116. Note that these components can either be the same as or different from operating system 84, application programs 86, other program modules 88, and program data 90. Operating system 110, application programs 112, other program modules 114, and program data 116 are given different numbers here to illustrate that, at a minimum, they are different copies.
A user may enter commands and information into computer 70 through input devices or user interface selection devices such as a keyboard 120 and a pointing device 122 (e.g., a mouse, trackball, pen, or touch pad). Other input devices (not shown) may include a microphone, joystick, game pad, satellite dish, scanner, or the like. These and other input devices are connected to processing unit 72 through a user input interface 124 that is coupled to system bus 76, but may be connected by other interface and bus structures, such as a parallel port, game port, or a universal serial bus (USB). A monitor 128 or other type of display device is also connected to system bus 76 via an interface, such as a video interface 130. In addition to the monitor 128, computers often include other peripheral output devices (not shown) such as a printer and speakers, which may be connected through an output peripheral interface (not shown).
The computer 70 may operate in a networked environment using logical connections to one or more remote computers, such as a remote computer 134. The remote computer 134 may be a personal computer, a server, a router, a network PC, a peer device or other common network node, and typically includes many or all of the elements described above relative to computer 70. The logical connections depicted in FIG. 4 include a local area network (LAN) 136 and a wide area network (WAN) 138, but may also include other networks. LAN 136 and/or WAN 138 may be a wired network, a wireless network, a combination thereof, and so on. Such networking environments are commonplace in offices, enterprise-wide computer networks, intranets, and global computer networks (e.g., the Internet).
When used in a local area networking environment, computer 70 is connected to the LAN 136 through a network interface or adapter 140. When used in a wide area networking environment, computer 70 typically includes a modem 142 or other means for establishing communications over the WAN 138, such as the Internet. The modem 142, which may be internal or external, is connected to system bus 76 via the user input interface 134, or other appropriate mechanism. In a networked environment, program modules depicted relative to computer 70, or portions thereof, may be stored in a remote memory storage device (not shown). By way of example, and not limitation, FIG. 4 illustrates remote application programs 144 as residing on the memory device. The network connections shown are exemplary and other means of establishing a communications link between the computers may be used.
Generally, the data processors of computer 70 are programmed by means of instructions stored at different times in the various computer-readable storage media of the computer. Programs and operating systems are typically distributed, for example, on floppy disks or CD-ROMs. From there, they are installed or loaded into the secondary memory of a computer. At execution, they are loaded at least partially into the computer's primary electronic memory. The invention described herein includes these and other various types of computer-readable storage media when such media contain instructions or programs for implementing the steps described herein in conjunction with a microprocessor or other data processor. The invention also includes the computer itself when programmed according to the methods and techniques described herein.
For purposes of illustration, programs and other executable program components, such as the operating system, are illustrated herein as discrete blocks. It is recognized, however, that such programs and components reside at various times in different storage components of the computer, and are executed by the data processor(s) of the computer.
Although described in connection with an exemplary computing system environment, including computer 70, the invention is operational with numerous other general purpose or special purpose computing system environments or configurations. The computing system environment is not intended to suggest any limitation as to the scope of use or functionality of the invention. Moreover, the computing system environment should not be interpreted as having any dependency or requirement relating to any one or combination of components illustrated in the exemplary operating environment. Examples of well known computing systems, environments, and/or configurations that may be suitable for use with the invention include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, microprocessor-based systems, set top boxes, programmable consumer electronics, mobile telephones, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
Embodiments of the invention may be described in the general context of computer-executable instructions, such as program modules, executed by one or more computers or other devices. Generally, program modules include, but are not limited to, routines, programs, objects, components, and data structures that perform particular tasks or implement particular abstract data types. The invention may also be practiced in distributed computing environments where tasks are performed by remote processing devices that are linked through a communications network. In a distributed computing environment, program modules may be located in both local and remote computer storage media including memory storage devices.
An interface in the context of software architecture includes a software module, component, code portion, or other sequence of computer-executable instructions. The interface includes, for example, a first module accessing a second module to perform computing tasks on behalf of the first module. The first and second modules include, in one example, application programming interfaces (APIs) such as provided by operating systems, component object model (COM) interfaces (e.g., for peer-to-peer application communication), and extensible markup language metadata interchange format (XMI) interfaces (e.g., for communication between web services).
The interface may be a tightly coupled, synchronous implementation such as in Java 2 Platform Enterprise Edition (J2EE), COM, or distributed COM (DCOM) examples. Alternatively or in addition, the interface may be a loosely coupled, asynchronous implementation such as in a web service (e.g., using the simple object access protocol). In general, the interface includes any combination of the following characteristics: tightly coupled, loosely coupled, synchronous, and asynchronous. Further, the interface may conform to a standard protocol, a proprietary protocol, or any combination of standard and proprietary protocols.
The interfaces described herein may all be part of a single interface or may be implemented as separate interfaces or any combination therein. The interfaces may execute locally or remotely to provide functionality. Further, the interfaces may include additional or less functionality than illustrated or described herein.
In operation, computer 70 executes computer-executable instructions such as those described herein to receive a parameter-driven template, including scenario template 204, from content provider 102. Computer 70, in this exemplary embodiment, enables a notifications application based on the received template and executes the notifications application. In this instance, the notifications application maps a recurring event to one or more subscribers as a function of the parameters specified by content provider 102 and computer 70 generates a notification and delivers it to the subscribers in response to the recurring event.
The order of execution or performance of the methods illustrated and described herein is not essential, unless otherwise specified. That is, elements of the methods may be performed in any order, unless otherwise specified, and that the methods may include more or less elements than those disclosed herein.
Information in this document, including uniform resource locator and other Internet web site references, is subject to change without notice. Unless otherwise noted, the example companies, organizations, products, domain names, e-mail addresses, logos, people, places and events depicted herein are fictitious, and no association with any real company, organization, product, domain name, e-mail address, logo, person, place or event is intended or should be inferred.
When introducing elements of the present invention or the embodiment(s) thereof, the articles “a,” “an,” “the,” and “said” are intended to mean that there are one or more of the elements. The terms “comprising,” “including,” and “having” are intended to be inclusive and mean that there may be additional elements other than the listed elements.
In view of the above, it will be seen that the several objects of the invention are achieved and other advantageous results attained.
As various changes could be made in the above constructions, products, and methods without departing from the scope of the invention, it is intended that all matter contained in the above description and shown in the accompanying drawings shall be interpreted as illustrative and not in a limiting sense.
Appendix A
Application Definition File Schema
An exemplary XSD schema used to define an application according to embodiments of the invention follows.
<?xml version=“1.0” encoding=“utf-8” ?>
<xs:schema
targetNamespace=“http://alerts.microsoft.com/hosted/2003/07/application”
elementFormDefault=“qualified”
 xmlns=“http://alerts.microsoft.com/hosted/2003/07/application”
xmlns:mstns=“http://alerts.microsoft.com/hosted/2003/07/application”
 xmlns:xs=“http://www.w3.org/2001/XMLSchema”>
 <xs:simpleType name=“Category_t”>
  <xs:restriction base=“xs:string”>
   <xs:maxLength value=“16” />
  </xs:restriction>
 </xs:simpleType>
 <xs:complexType name=“CpInfo_t”>
  <xs:sequence>
   <xs:element name=“Cpid” type=“xs:integer” />
   <xs:element name=“Password” type=“xs:string” />
   <xs:element name=“Uri” type=“xs:anyURI” />
   <xs:element name=“ReplyToEmail” type=“xs:string” />
   <xs:element name=“DefaultMarket” type=“xs:string” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“Categories_t”>
  <xs:sequence>
   <xs:element name=“Category” type=“Category_t” minOccurs=“0”
maxOccurs=“unbounded” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“Locales_t”>
  <xs:sequence>
   <xs:element name=“Locale” type=“xs:string” minOccurs=“0”
maxOccurs=“unbounded” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“PageText_t”>
  <xs:sequence>
   <xs:element name=“HomePage_Heading” type=“xs:string” />
   <xs:element name=“HomePage_SubHead” type=“xs:string” />
   <xs:element name=“HomePage_BulletTwo” type=“xs:string” />
   <xs:element name=“ViewPage_Heading” type=“xs:string” />
   <xs:element name=“ViewPage_SubHead” type=“xs:string” />
   <xs:element name=“ViewPage_CatHead” type=“xs:string” />
   <xs:element name=“ViewPage_SchedHead” type=“xs:string” />
   <xs:element name=“EditPage_Heading” type=“xs:string” />
   <xs:element name=“EditPage_SubHead” type=“xs:string” />
   <xs:element name=“AddPage_Heading” type=“xs:string” />
   <xs:element name=“AddPage_SubHead” type=“xs:string” />
   <xs:element name=“AddPage_ChooseCat” type=“xs:string” />
   <xs:element name=“AddPage_ChooseTime” type=“xs:string” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“CategoryBasedScheduleScenario_t”>
  <xs:sequence>
   <xs:element name=“Categories” type=“Categories_t” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“Scenario_t”>
  <xs:sequence>
   <xs:element name=“Locales” type=“Locales_t” />
   <xs:choice>
    <xs:element name=“CategoryBasedScheduleScenario”
type=“CategoryBasedScheduleScenario_t” />
   </xs:choice>
  </xs:sequence>
  <xs:attribute name=“name” type=“xs:string” use=“required” />
  <xs:attribute name=“type” type=“xs:string” use=“required” />
 </xs:complexType>
 <xs:complexType name=“Schema_t”>
  <xs:sequence>
   <xs:element name=“Scenario” type=“Scenario_t” minOccurs=“0”
maxOccurs=“unbounded” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UICpInfo_t”>
  <xs:sequence>
   <xs:element name=“Name” type=“xs:string” />
   <xs:element name=“SignupText” type=“xs:string” />
   <xs:element name=“SignupImage” type=“xs:string” />
   <xs:element name=“Icon” type=“xs:string” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UICategory_t”>
  <xs:sequence>
   <xs:element name=“Category” type=“xs:string” />
   <xs:element name=“Display” type=“xs:string” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UICategories_t”>
  <xs:sequence>
   <xs:element name=“Category” type=“UICategory_t”
   minOccurs=“0”
maxOccurs=“unbounded” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UIScenario_t”>
  <xs:sequence>
   <xs:element name=“Scenario” type=“xs:string” />
   <xs:element name=“Display” type=“xs:string” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UIScenarios_t”>
  <xs:sequence>
   <xs:element name=“Scenario” type=“UIScenario_t”
   minOccurs=“0”
maxOccurs=“unbounded” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UICategoryBasedSchedule_t”>
  <xs:sequence>
   <xs:element name=“DisplayName” type=“xs:string” />
   <xs:element name=“LogoGraphic” type=“xs:string” />
   <xs:element name=“PageText” type=“PageText_t” />
   <xs:element name=“Scenarios” type=“UIScenarios_t” />
   <xs:element name=“Categories” type=“UICategories_t” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“UISubscription_t”>
  <xs:choice>
   <xs:element name=“CategoryBasedSchedule”
type=“UICategoryBasedSchedule_t” />
  </xs:choice>
  <xs:attribute name=“type” type=“xs:string” use=“required” />
 </xs:complexType>
 <xs:complexType name=“UserInterface_t”>
  <xs:sequence>
   <xs:element name=“CpInfo” type=“UICpInfo_t” />
   <xs:element name=“Subscription” type=“UISubscription_t” />
  </xs:sequence>
  <xs:attribute ref=“xml:lang” use=“required” />
 </xs:complexType>
 <xs:complexType name=“UserInterfaces_t”>
  <xs:sequence>
   <xs:element name=“UserInterface” type=“UserInterface_t”
   minOccurs=“1”
maxOccurs=“unbounded” />
  </xs:sequence>
 </xs:complexType>
 <xs:complexType name=“Application_t”>
  <xs:sequence>
   <xs:element name=“CpInfo” type=“CpInfo_t” />
   <xs:element name=“Schema” type=“Schema_t” />
   <xs:element name=“UserInterfaces” type=“UserInterfaces_t”/>
  </xs:sequence>
 </xs:complexType>
 <xs:element name=“Application” type=“Application_t” />
</xs:schema>
Appendix B
Sample Application Definition File
An exemplary Application Definition file used to deliver news is shown below. The Application Definition file follows the exemplary schema shown above in APPENDIX A.
<?xml version=“1.0” encoding=“utf-8” ?>
<Application xmlns=“http://alerts.microsoft.com/hosted/2003/07/application”>
 <CpInfo>
  <Cpid>716</Cpid>
  <Password>password</Password>
  <Uri>http://localhost</Uri>
  <ReplyToEmail></ReplyToEmail>
  <DefaultMarket>en-US</DefaultMarket>
 </CpInfo>
 <Schema>
  <Scenario name=“HeadlineNews” type=“CategoryBasedSchedule”>
   <Locales>
    <Locale>en-US</Locale>
    <Locale>en-CA</Locale>
    <Locale>fr-CA</Locale>
   </Locales>
   <CategoryBasedScheduleScenario>
    <Categories>
     <Category>Top</Category>
     <Category>Nat</Category>
     <Category>Int</Category>
     <Category>Spo</Category>
     <Category>Pol</Category>
     <Category>Bus</Category>
     <Category>Ent</Category>
     <Category>S&amp;H</Category>
     <Category>C&amp;T</Category>
    </Categories>
   </CategoryBasedScheduleScenario>
  </Scenario>
  <Scenario name=“SummaryNews” type=“CategoryBasedSchedule”>
   <Locales>
    <Locale>en-US</Locale>
    <Locale>en-CA</Locale>
    <Locale>fr-CA</Locale>
   </Locales>
   <CategoryBasedScheduleScenario>
    <Categories>
     <Category>Top</Category>
     <Category>Nat</Category>
     <Category>Int</Category>
     <Category>Spo</Category>
     <Category>Pol</Category>
     <Category>Bus</Category>
     <Category>Ent</Category>
     <Category>S&amp;H</Category>
     <Category>C&amp;T</Category>
    </Categories>
   </CategoryBasedScheduleScenario>
  </Scenario>
 </Schema>
 <UserInterfaces>
  <UserInterface xml:lang=“en-US” _locID=“L_LocaleID_TEXT”
_locAttrData=“xml:lang”
xmlns=“http://alerts.microsoft.com/hosted/2003/07/application”>
   <CpInfo>
    <Name _locID=“L_CpInfo_Name_TEXT”>MSN News</Name>
    <SignupText _locID=“L_CpInfo_SignupText_TEXT”>What's happening in the
world today? Find out now with MSN News alerts.</SignupText>
    <SignupImage _loc=“locNone”>news53x20.gif</SignupImage>
    <Icon _loc=“locNone”>news_24x16.gif</Icon>
   </CpInfo>
   <Subscription type=“CategoryBasedSchedule”>
    <CategoryBasedSchedule>
     <DisplayName _locID=“L_CpDisplayName_TEXT”><!--
_locComment_text=“The cp name as it will appear on the website pages”-->MSN
News</DisplayName>
     <LogoGraphic _loc=“locNone”>news_large.gif</LogoGraphic>
     <PageText>
      <HomePage_Heading _locID=“L_HomePageHeading_TEXT”><!--
_locComment_text=“Home page Header text”-->Sign up for free alerts from MSN
News</HomePage_Heading>
      <HomePage_SubHead _locID=“L_HomePageSubHead_TEXT”><!--
_locComment_text=“Instruction text under heading on home page”-->What's
happening in the world today? Find out now with MSN News
alerts.</HomePage_SubHead>
      <HomePage_BulletTwo _locID=“L_HomePageBulletTwo_TEXT”><!--
_locComment_text=“The second_u98 ?ullet text on home page”-->Select news
alert categories, then choose delivery times and days.</HomePage_BulletTwo>
      <ViewPage_Heading _locID=“L_ViewPageHeading_TEXT”><!--
_locComment_text=“View page header text”-->Your MSN News
alerts</ViewPage_Heading>
      <ViewPage_SubHead _locID=“L_ViewPageSubHead_TEXT”><!--
_locComment_text=“View page instruction text under heading”-->Click Edit
Delivery to change the delivery locations for all MSN News alerts. Click
Edit to change delivery times for individual alerts.</ViewPage_SubHead>
      <ViewPage_CatHead _locID=“L_ViewPageCatHead_TEXT”><!--
_locComment_text=“View page category column heading text”-->News
Category</ViewPage_CatHead>
      <ViewPage_SchedHead _locID=“L_ViewPageSchedHead_TEXT”><!--
_locComment_text=“View page in edit mode heading for times”-->Alert
Me</ViewPage_SchedHead>
      <EditPage_Heading _locID=“L_EditPageHeading_TEXT”><!--
_locComment_text=“Edit page header text”-->Edit your MSN News
alerts</EditPage_Heading>
      <EditPage_SubHead _locID=“L_EditPageSubHead_TEXT”><!--
_locComment_text=“Edit page instruction text under heading”-->Make your
changes and click Update.</EditPage_SubHead>
      <AddPage_Heading _locID=“L_AddPageHeading_TEXT”><!--
_locComment_text=“Add page header text”-->What MSN News alerts do you want to
receive?</AddPage_Heading>
      <AddPage_SubHead _locID=“L_AddPageSubHead_TEXT”><!--
_locComment_text=“Add page instruction text under heading”-->Select check
boxes next to news categories, then choose delivery times and
days.</AddPage_SubHead>
      <AddPage_ChooseCat _locID=“L_AddPageChooseCat_TEXT”><!--
_locComment_text=“Add page heading text for category section”-->Choose news
categories</AddPage_ChooseCat>
      <AddPage_ChooseTime _locID=“L_AddPageChooseTime_TEXT ”><!--
_locComment_text=“Add page heading text for schedule section”-->Specify
delivery times and days</AddPage_ChooseTime>
     </PageText>
     <Scenarios>
      <Scenario>
       <Scenario _loc=“locNone”>HeadlineNews</Scenario>
       <Display _locID=“L_HeadlineNewsScenario_TEXT”>News
headlines</Display>
      </Scenario>
      <Scenario>
       <Scenario _loc=“locNone”>SummaryNews</Scenario>
       <Display _locID=”L_SummaryNewsScenario_TEXT”>News
summaries</Display>
      </Scenario>
     </Scenarios>
     <Categories>
      <Category>
       <Category _loc=“locNone”>Top</Category>
       <Display _locID=“L_CategoryTopStories_TEXT”>Top
Stories</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>Nat</Category>
       <Display _locID=“L_CategoryNational_TEXT”>National</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>Int</Category>
       <Display
_locID=“L_CategoryInternational_TEXT”>International</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>Spo</Category>
       <Display _locID=“L_CategorySports_TEXT”>Sports</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>Pol</Category>
       <Display _locID=“L_CategoryPolitics_TEXT”>Politics</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>Bus</Category>
       <Display _locID=“L_CategoryBusiness_TEXT”>Business</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>Ent</Category>
       <Display
_locID=“L_CategoryEntertainment_TEXT”>Entertainment</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>S&amp;H</Category>
       <Display _locID=“L_CategoryScienceHealth_TEXT”>Science &amp;
Health</Display>
      </Category>
      <Category>
       <Category _loc=“locNone”>C&amp;T</Category>
       <Display _locID=“L _CategoryComputersTechnology_TEXT”>Computers
&amp; Technology</Display>
      </Category>
     </Categories>
    </CategoryBasedSchedule>
   </Subscription>
  </UserInterface>
 </UserInterfaces>
</Application>

Claims (21)

1. A method of generating notifications in a notifications system, said notifications system being configured to provide notifications to subscribers via a data communication network, said notifications containing content provided by a plurality of content providers, said method comprising:
providing a parameter-driven template to the plurality of content providers for completion by the content providers;
receiving a parameter-driven template from at least one of the plurality of content providers, said received template relating to a category specified by the content provider, said received template containing one or more parameters specified by the content provider, said parameters defining a plurality of events specified by the content provider and relating to the specified category, each of said events comprising a recurring event specified by the content provider, said parameters relating to a subscription for notifications and specifying a predefined scheduled generation time for the generation of notifications to occur, wherein one of the parameters in the received parameter-driven template relates to delivery of the generated notifications at a predetermined time of day specified by the content provider;
enabling a notifications application based on the received template, said notifications application mapping the latest recurring event of the specified category to one or more subscribers as a function of the parameters specified by the content provider in the received parameter-driven template provided by the content provider, wherein enabling the notifications application based on the received template includes creating an application definition file that describes the notifications application;
executing the notifications application on a recurring basis to generate a notification in accordance with the predefined scheduled generation time specified by the received parameter-driven template parameters, wherein the notification is generated based on matching the latest recurring event of the specified category with subscribers of the specified category, and wherein the generated notification is delivered to the subscribers of the specified category on a recurring basis in accordance with the time of day delivery parameter specified by the received parameter-driven template; and
providing a user interface for the subscribers to manage the subscription whereby the managed subscription has parameters corresponding the received parameter-driven template received from the content provider.
2. The method of claim 1, further comprising matching a most recent instance of the recurring event to the subscription to generate the notifications for delivery at the predetermined time of day.
3. The method of claim 1, wherein one of the parameters specified by the content provider relates to delivery of the notifications upon occurrence of the recurring event.
4. The method of claim 3, further comprising matching the recurring event to the subscription to generate the notifications for broadcast delivery upon occurrence of the recurring event.
5. The method of claim 1, wherein the notifications relate to one or more of following categories: horoscope, lottery, and news.
6. The method of claim 1, further comprising defining the template based on common features of a plurality of notifications applications.
7. One or more computer-readable storage media having computer-executable instructions for performing the method of claim 1.
8. A computer-readable storage medium having a data structure stored thereon, said data structure defining an application for use in a notifications system, said notifications system being configured to execute the defined application for providing notifications to subscribers via a data communication network, said notifications containing content provided by a plurality of content providers, said data structure comprising:
a user interface template configured to contain information for defining a user interface corresponding to the application for managing the subscription of the user, said interface allowing the user to select a category, wherein a subscription is generated for the user from the user interface template, said subscription indicating that the user wants to receive notifications related to the selected category;
a scenario template configured to contain information for defining the application, said scenario template receiving from one of the plurality of content providers having one or more parameters specified by the content provider and relating to a subscription for notifications, wherein one of the parameters in the scenario template relates to delivery of the notifications at a predetermined time of day specified by the content provider, wherein the scenario template includes a category component defining a plurality of events specified by the content provider and relating to a category specified by the content provider, for which the notifications are to be generated, each of said events relating to a recurring event specified by the content provider;
a notification generation component responsive to an event feed for mapping a latest recurring event to one or more subscribers as a function of the parameters specified by the content provider in the scenario template provided by the content provider and as a function of the subscription of the subscriber, said notification generation component generating a notification for the recurring event in accordance with a predefined scheduled time specified for notification generation by the scenario template parameters, wherein the notification is generated based on matching the latest recurring event of the specified category with subscribers of the specified category; and
a delivery component for routing the notification to the subscribers of the specified category related to the event, wherein the notification is routed to the subscribers of the specified category in accordance with a time of day delivery parameter specified by the scenario template parameters.
9. The medium of claim 8, wherein the notifications relate to one or more of following topics: horoscope, lottery, and news.
10. The medium of claim 8, wherein the scenario template is based on common features of a plurality of notifications applications.
11. A system configured for generating and delivering notifications to subscribers via a data communication network, said notifications containing content provided by a plurality of content providers, said system comprising:
a computing device coupled to a data communication network and configured to:
receive a subscription from a subscriber specifying a category for which the subscriber wants to receive notifications of events relating to the specified category;
provide a parameter-driven template to the plurality of content providers for completion by the content providers;
receive the parameter-driven template from one of the plurality a content provider via the data communication network, said received template containing information provided by the content provider and relating to a subscription for notifications, said received template relating to a category specified by the content provider, said received template containing one or more parameters specified by the content provider, said parameters defining a plurality of events specified by the content provider and relating to the category, wherein one of the parameters in the received parameter-driven template relates to delivery of the notifications at a predetermined time of day specified by the content provider, each of said events relating to a recurring event specified by the content provider, said parameters relating to a subscription for notifications and specifying a predefined scheduled generation time for generation of the notifications to occur;
a computer-readable medium storing computer-executable instructions to be executed on the computing device to enable a notifications application based on the received template, said notifications application mapping the latest recurring event to one or more subscribers as a function of the parameters specified by the content provider in the received parameter-driven template provided by the content provider on a recurring basis in accordance with the predefined scheduled generation time defined by the received parameter-driven template parameters, wherein the notification is generated based on matching the latest recurring event of the specified category with subscribers of the specified category, and wherein the generated notification is delivered to the subscribers in accordance with the time of day delivery parameter specified by the received parameter-driven template parameters.
12. The system of claim 11, wherein the computing device is further configured to receive another parameter-driven template from the content provider via the data communication network, said other template containing information provided by the content provider and defining a user interface corresponding to the application for managing the subscription.
13. The system of claim 11, wherein the notifications relate to one or more of following topics: horoscope, lottery, and news.
14. The system of claim 11, wherein the template is based on common features of a plurality of notifications applications.
15. The system of claim 11, wherein the computer-readable medium further stores computer-executable instructions to be executed on the computing device to create an application definition file that describes the notifications application.
16. The system of claim 15, further comprising a subscription store configured to store notification offerings described by the application definition file.
17. The system of claim 16, wherein the computer-readable medium further stores computer-executable instructions to be executed on the computing device to validate incoming subscription management requests and commit the requests to the subscription store.
18. The system of claim 11, wherein the computer-readable medium further stores computer-executable instructions to be executed on the computing device to generate the notification based on matching external events with corresponding subscriptions.
19. The system of claim 11, wherein the computer-readable medium further stores computer-executable instructions to be executed on the computing device to deliver the notification to the system.
20. The system of claim 11, wherein the template is predefined and re-usable.
21. A notification system for generating and delivering notifications to subscribers, said notifications containing content provided by one or more content providers, said system comprising:
a computing device coupled to a data communication network, said computing device being configured to receive a parameter-driven template provided by a content provider via the data communication network, said template containing information provided by the content provider and relating to a subscription for notifications, said template relating to a category specified by the content provider, said template containing one or more parameters specified by the content provider, said parameters defining a plurality of events specified by the content provider and relating to the category, wherein one of the parameters in the received parameter-driven template relates to delivery of the notifications at a predetermined time of day specified by the content provider, each of said events relating to a recurring event specified by the content provider, said parameters relating to a subscription for notifications and defining a predefined scheduled generation time for the generation of notifications to occur;
a subscription store associated with the computing device, said subscription store being configured to store one or more notification offerings described by an application definition file, said application definition file being generated from the received parameter-driven template, said application definition file including the predefined scheduled generation time for the generation of notifications to occur; and
a computer-readable medium storing computer-executable instructions to be executed on the computing device to enable a notifications application to execute on a recurring basis according to the predefined scheduled generation time for the generation of notifications to occur included in the application definition file, said notifications application delivering the notification to the subscribers in accordance with the time of day delivery parameter included in the application definition file, wherein the notifications application maps the latest recurring event of the specified category to one or more subscribers as a function of the parameters specified by the content provider in the received parameter-driven template provided by the content provider.
US10/728,697 2003-12-05 2003-12-05 Hosted notifications templates Expired - Fee Related US7877694B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/728,697 US7877694B2 (en) 2003-12-05 2003-12-05 Hosted notifications templates

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US10/728,697 US7877694B2 (en) 2003-12-05 2003-12-05 Hosted notifications templates

Publications (2)

Publication Number Publication Date
US20050144266A1 US20050144266A1 (en) 2005-06-30
US7877694B2 true US7877694B2 (en) 2011-01-25

Family

ID=34700352

Family Applications (1)

Application Number Title Priority Date Filing Date
US10/728,697 Expired - Fee Related US7877694B2 (en) 2003-12-05 2003-12-05 Hosted notifications templates

Country Status (1)

Country Link
US (1) US7877694B2 (en)

Cited By (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050002499A1 (en) * 2003-07-01 2005-01-06 Ordille Joann J. Method and apparatus for event notification based on the identity of a calling party
US20050268291A1 (en) * 2004-05-27 2005-12-01 International Business Machines Corporation Specifying user interface interactions for controls in a data driven system
US20090100348A1 (en) * 2005-04-19 2009-04-16 France Telecom Warning method during content modification and system therefor
US20120102502A1 (en) * 2010-10-22 2012-04-26 Medicity, Inc. Managing healthcare information in a distributed system
US8495163B2 (en) 2004-03-18 2013-07-23 Avaya, Inc. Method and apparatus for a publish-subscribe system with templates for role-based view of subscriptions
US8510392B2 (en) 2002-05-14 2013-08-13 Avaya Inc. Method and apparatus for automatic notification and response
US20150302387A1 (en) * 2012-09-11 2015-10-22 Cashstar, Inc. Method for using a user interface control to transfer an id from a server
US20170093766A1 (en) * 2015-09-25 2017-03-30 Microsoft Technology Licensing, Llc User-Defined Notification Templates

Families Citing this family (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7302634B2 (en) 2001-03-14 2007-11-27 Microsoft Corporation Schema-based services for identity-based data access
US9886309B2 (en) 2002-06-28 2018-02-06 Microsoft Technology Licensing, Llc Identity-based distributed computing for device resources
US7685265B1 (en) 2003-11-20 2010-03-23 Microsoft Corporation Topic-based notification service
US7877694B2 (en) * 2003-12-05 2011-01-25 Microsoft Corporation Hosted notifications templates
US9374266B1 (en) * 2003-12-30 2016-06-21 Aol Inc. Tailoring notifications through resource specific notification controls
US8904042B1 (en) 2003-12-30 2014-12-02 Aol Inc. System and method for subject matter notifications
US7873912B1 (en) * 2005-02-25 2011-01-18 Apple Inc. Process and system for providing a reduced set of fields associated with a report layout
GB2424972A (en) * 2005-04-08 2006-10-11 Motorola Inc Monitoring content topics in a communication system
US20070169015A1 (en) * 2005-12-07 2007-07-19 Sbc Knowledge Ventures, L.P. Web services development automation toolkit with test case driver and customized configuration file
US7747942B2 (en) * 2005-12-20 2010-06-29 American Express Travel Related Services Company, Inc. System and method for obtaining a markup language template through reversing engineering
US8126970B2 (en) * 2006-12-20 2012-02-28 Sap Ag Method and apparatus for engineering change management
US20080222563A1 (en) * 2007-03-06 2008-09-11 Prinsky Robert D Method and System for Providing Machine-Readable News content
US20090181614A1 (en) * 2008-01-15 2009-07-16 Nicolas Wolff Method and system for providing playback of digital audio content available through a computer network
US10389761B2 (en) 2009-11-17 2019-08-20 Time Warner Cable Enterprises Llc Internet protocol multimedia subsystem voice-video mail service over a home network
US20130084009A1 (en) * 2011-10-03 2013-04-04 Steven W. Lundberg Systems, methods and user interfaces in a patent management system
US9967317B2 (en) * 2013-07-25 2018-05-08 Tencent Technology (Shenzhen) Company Limited Methods and systems for sending and receiving alerts
US10244040B2 (en) * 2015-05-22 2019-03-26 Microsoft Technology Licensing, Llc Content event notifications
US10620920B2 (en) * 2016-05-17 2020-04-14 Google Llc Automatic graphical user interface generation from notification data
US12111860B1 (en) * 2017-12-06 2024-10-08 Dennis J M Donahue, III Patent application preparation system and template creator
US11463395B1 (en) * 2018-07-18 2022-10-04 Intrado Corporation System and method of providing notifications
US20230342540A1 (en) * 2022-04-21 2023-10-26 Black Hills Ip Holdings, Llc Method and apparatus for generating a document and data processing

Citations (36)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5754939A (en) * 1994-11-29 1998-05-19 Herz; Frederick S. M. System for generation of user profiles for a system for customized electronic identification of desirable objects
US5915001A (en) * 1996-11-14 1999-06-22 Vois Corporation System and method for providing and using universally accessible voice and speech data files
US6047327A (en) * 1996-02-16 2000-04-04 Intel Corporation System for distributing electronic information to a targeted group of users
US6269369B1 (en) * 1997-11-02 2001-07-31 Amazon.Com Holdings, Inc. Networked personal contact manager
US20010044275A1 (en) 2000-05-22 2001-11-22 Nec Corporation Repeater, mobile radio communication system, fault notification method for said repeater or said mobile radio communication system, and recording medium having, recorded thereon, fault notification program for said repeater or said mobile radio communication system
US20020042846A1 (en) * 2000-10-05 2002-04-11 Bottan Gustavo L. Personal support network
US20020065884A1 (en) * 1998-09-01 2002-05-30 Donoho David Leigh Relevance clause for computed relevance messaging
US20020073158A1 (en) 2000-12-08 2002-06-13 Dalal Siddhartha R. Method and system for general-purpose interactive notifications
US20020080948A1 (en) * 2000-12-21 2002-06-27 Alcatel Method for managing event communications between Agent and Manager processing entities in a telecommunication network management system
US20020087740A1 (en) * 2000-11-06 2002-07-04 Rick Castanho System and method for service specific notification
US20020087397A1 (en) 2000-12-28 2002-07-04 Sam Mazza Buying, selling, and marketing advertisements
US20020090934A1 (en) * 2000-11-22 2002-07-11 Mitchelmore Eliott R.D. Content and application delivery and management platform system and method
US20020107985A1 (en) 2000-08-25 2002-08-08 W-Phone, Inc. Providing data services via wireless mobile devices
US20020120711A1 (en) 2001-02-23 2002-08-29 International Business Machines Corporation Method and system for intelligent routing of business events on a subscription-based service provider network
US20020124182A1 (en) 2000-11-20 2002-09-05 Bacso Stephen R. Method and system for targeted content delivery, presentation, management and reporting in a communications nertwork
US6459913B2 (en) * 1999-05-03 2002-10-01 At&T Corp. Unified alerting device and method for alerting a subscriber in a communication network based upon the result of logical functions
US20020184092A1 (en) 2001-06-01 2002-12-05 Cherry Darrel D. Customized advertising methods for personal media services
US6501832B1 (en) * 1999-08-24 2002-12-31 Microstrategy, Inc. Voice code registration system and method for registering voice codes for voice pages in a voice network access provider system
US20030055897A1 (en) * 2001-09-20 2003-03-20 International Business Machines Corporation Specifying monitored user participation in messaging sessions
US20030097485A1 (en) 2001-03-14 2003-05-22 Horvitz Eric J. Schemas for a notification platform and related information services
US20030101190A1 (en) 2001-03-14 2003-05-29 Microsoft Corporation Schema-based notification service
US20030100326A1 (en) 2001-11-27 2003-05-29 Grube Gary W. Group location and route sharing system for communication units in a trunked communication system
US20030110262A1 (en) * 2001-07-06 2003-06-12 Taqi Hasan Integrated rule network management system
US20030120785A1 (en) 2001-12-20 2003-06-26 International Business Machines Corporation Message filtering
US20030131142A1 (en) 2001-03-14 2003-07-10 Horvitz Eric J. Schema-based information preference settings
US20030135556A1 (en) 2001-12-14 2003-07-17 International Business Machines Corporation Selection of communication strategies for message brokers or publish/subscribe communications
US20030225683A1 (en) * 2002-05-31 2003-12-04 Mt One, Inc. Electronic bid/proposal system for the construction industry
US20040002972A1 (en) * 2002-06-26 2004-01-01 Shyamalan Pather Programming model for subscription services
US6741980B1 (en) 1999-03-23 2004-05-25 Microstrategy Inc. System and method for automatic, real-time delivery of personalized informational and transactional data to users via content delivery device
US6763384B1 (en) 2000-07-10 2004-07-13 International Business Machines Corporation Event-triggered notification over a network
US6766362B1 (en) 2000-07-28 2004-07-20 Seiko Epson Corporation Providing a network-based personalized newspaper with personalized content and layout
US6816878B1 (en) * 2000-02-11 2004-11-09 Steven L. Zimmers Alert notification system
US20050027741A1 (en) * 2003-06-13 2005-02-03 Matthias Eichstaedt Method and system for alert delivery architecture
US20050144266A1 (en) * 2003-12-05 2005-06-30 Microsoft Corporation Hosted notifications templates
US7127232B2 (en) * 2003-05-08 2006-10-24 Bell South Intellectual Property Corporation Multiple access internet portal revenue sharing
US7133869B2 (en) * 2001-03-06 2006-11-07 Knowledge Vector, Inc. Methods and systems for and defining and distributing information alerts

Patent Citations (38)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5754939A (en) * 1994-11-29 1998-05-19 Herz; Frederick S. M. System for generation of user profiles for a system for customized electronic identification of desirable objects
US6047327A (en) * 1996-02-16 2000-04-04 Intel Corporation System for distributing electronic information to a targeted group of users
US5915001A (en) * 1996-11-14 1999-06-22 Vois Corporation System and method for providing and using universally accessible voice and speech data files
US6269369B1 (en) * 1997-11-02 2001-07-31 Amazon.Com Holdings, Inc. Networked personal contact manager
US20020065884A1 (en) * 1998-09-01 2002-05-30 Donoho David Leigh Relevance clause for computed relevance messaging
US6741980B1 (en) 1999-03-23 2004-05-25 Microstrategy Inc. System and method for automatic, real-time delivery of personalized informational and transactional data to users via content delivery device
US6459913B2 (en) * 1999-05-03 2002-10-01 At&T Corp. Unified alerting device and method for alerting a subscriber in a communication network based upon the result of logical functions
US6501832B1 (en) * 1999-08-24 2002-12-31 Microstrategy, Inc. Voice code registration system and method for registering voice codes for voice pages in a voice network access provider system
US6816878B1 (en) * 2000-02-11 2004-11-09 Steven L. Zimmers Alert notification system
US20010044275A1 (en) 2000-05-22 2001-11-22 Nec Corporation Repeater, mobile radio communication system, fault notification method for said repeater or said mobile radio communication system, and recording medium having, recorded thereon, fault notification program for said repeater or said mobile radio communication system
US6763384B1 (en) 2000-07-10 2004-07-13 International Business Machines Corporation Event-triggered notification over a network
US6766362B1 (en) 2000-07-28 2004-07-20 Seiko Epson Corporation Providing a network-based personalized newspaper with personalized content and layout
US20020107985A1 (en) 2000-08-25 2002-08-08 W-Phone, Inc. Providing data services via wireless mobile devices
US20020042846A1 (en) * 2000-10-05 2002-04-11 Bottan Gustavo L. Personal support network
US20020087740A1 (en) * 2000-11-06 2002-07-04 Rick Castanho System and method for service specific notification
US20020124182A1 (en) 2000-11-20 2002-09-05 Bacso Stephen R. Method and system for targeted content delivery, presentation, management and reporting in a communications nertwork
US20020090934A1 (en) * 2000-11-22 2002-07-11 Mitchelmore Eliott R.D. Content and application delivery and management platform system and method
US20020073158A1 (en) 2000-12-08 2002-06-13 Dalal Siddhartha R. Method and system for general-purpose interactive notifications
US20020080948A1 (en) * 2000-12-21 2002-06-27 Alcatel Method for managing event communications between Agent and Manager processing entities in a telecommunication network management system
US20020087397A1 (en) 2000-12-28 2002-07-04 Sam Mazza Buying, selling, and marketing advertisements
US20020120711A1 (en) 2001-02-23 2002-08-29 International Business Machines Corporation Method and system for intelligent routing of business events on a subscription-based service provider network
US7133869B2 (en) * 2001-03-06 2006-11-07 Knowledge Vector, Inc. Methods and systems for and defining and distributing information alerts
US20030097485A1 (en) 2001-03-14 2003-05-22 Horvitz Eric J. Schemas for a notification platform and related information services
US20030101190A1 (en) 2001-03-14 2003-05-29 Microsoft Corporation Schema-based notification service
US20030131073A1 (en) * 2001-03-14 2003-07-10 Lucovsky Mark H. Schema-based services for identity-based data access
US20030131142A1 (en) 2001-03-14 2003-07-10 Horvitz Eric J. Schema-based information preference settings
US20020184092A1 (en) 2001-06-01 2002-12-05 Cherry Darrel D. Customized advertising methods for personal media services
US20030110262A1 (en) * 2001-07-06 2003-06-12 Taqi Hasan Integrated rule network management system
US20030055897A1 (en) * 2001-09-20 2003-03-20 International Business Machines Corporation Specifying monitored user participation in messaging sessions
US20030100326A1 (en) 2001-11-27 2003-05-29 Grube Gary W. Group location and route sharing system for communication units in a trunked communication system
US20030135556A1 (en) 2001-12-14 2003-07-17 International Business Machines Corporation Selection of communication strategies for message brokers or publish/subscribe communications
US20030120785A1 (en) 2001-12-20 2003-06-26 International Business Machines Corporation Message filtering
US20030225683A1 (en) * 2002-05-31 2003-12-04 Mt One, Inc. Electronic bid/proposal system for the construction industry
US20040002972A1 (en) * 2002-06-26 2004-01-01 Shyamalan Pather Programming model for subscription services
US7127232B2 (en) * 2003-05-08 2006-10-24 Bell South Intellectual Property Corporation Multiple access internet portal revenue sharing
US20050027741A1 (en) * 2003-06-13 2005-02-03 Matthias Eichstaedt Method and system for alert delivery architecture
US7143118B2 (en) * 2003-06-13 2006-11-28 Yahoo! Inc. Method and system for alert delivery architecture
US20050144266A1 (en) * 2003-12-05 2005-06-30 Microsoft Corporation Hosted notifications templates

Non-Patent Citations (5)

* Cited by examiner, † Cited by third party
Title
Faensen et al., "Hermes: A Notification Service for Digital Libraries," Proceedings of the First ACM/IEEE-CS Joint Conference on Digital Libraries, 2001, pp. 373-380, ACM Press, New York, U.S.A.
Huang et al., "Publish/Subscribe in a Mobile Environment," Second ACM International Workshop on Data Engineering for Wireless and Mobile Access, 2001, pp. 27-34, ACM Press, New York, U.S.A.
Miller et al., "News On-Demand for Multimedia Networks," Proceedings of the First ACM International Conference on Multimedia, 1993, pp. 383-392, ACM Press, New York, U.S.A.
Nielsen et al., "Web Services Routing Protocol (WS-Routing)," printed from http://msdn.micfosoft.com/library/en-us/dnglobspe/html/ws-routing.asp?frame=true, Oct. 23, 2001, 25 pages.
Wang et al., "The SIMBA User Alert Service Architecture for Dependable Alert Delivery," Proceedings of the International Conference on Dependable Systems and Networks, 2001, pp. 463-472, Institute of Electrical and Electronics Engineers, Inc., U.S.A.

Cited By (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8510392B2 (en) 2002-05-14 2013-08-13 Avaya Inc. Method and apparatus for automatic notification and response
US9124643B2 (en) 2002-06-26 2015-09-01 Avaya Inc. Method and apparatus for a publish-subscribe system with templates for role-based view of subscriptions
US8102974B2 (en) * 2003-07-01 2012-01-24 Avaya Inc. Method and apparatus for event notification based on the identity of a calling party
US20050002499A1 (en) * 2003-07-01 2005-01-06 Ordille Joann J. Method and apparatus for event notification based on the identity of a calling party
US8495163B2 (en) 2004-03-18 2013-07-23 Avaya, Inc. Method and apparatus for a publish-subscribe system with templates for role-based view of subscriptions
US8516045B2 (en) 2004-03-18 2013-08-20 Avaya Inc. Method and apparatus for automatic notification and response based on communication flow expressions having dynamic context
US20050268291A1 (en) * 2004-05-27 2005-12-01 International Business Machines Corporation Specifying user interface interactions for controls in a data driven system
US20090100348A1 (en) * 2005-04-19 2009-04-16 France Telecom Warning method during content modification and system therefor
US20120102502A1 (en) * 2010-10-22 2012-04-26 Medicity, Inc. Managing healthcare information in a distributed system
US8661453B2 (en) * 2010-10-22 2014-02-25 Medicity, Inc. Managing healthcare information in a distributed system
US8990834B2 (en) 2010-10-22 2015-03-24 Medicity, Inc. Managing healthcare information in a distributed system
US20150302387A1 (en) * 2012-09-11 2015-10-22 Cashstar, Inc. Method for using a user interface control to transfer an id from a server
US10664823B2 (en) * 2012-09-11 2020-05-26 Cashstar, Inc. Method for using a user interface control to transfer an ID from a server
US20170093766A1 (en) * 2015-09-25 2017-03-30 Microsoft Technology Licensing, Llc User-Defined Notification Templates
US11374888B2 (en) * 2015-09-25 2022-06-28 Microsoft Technology Licensing, Llc User-defined notification templates

Also Published As

Publication number Publication date
US20050144266A1 (en) 2005-06-30

Similar Documents

Publication Publication Date Title
US7877694B2 (en) Hosted notifications templates
US7685265B1 (en) Topic-based notification service
US7783593B2 (en) Method, device and computer program product including a lightweight directory access protocol client
US8307378B2 (en) Method, system and computer program product for a lightweight directory access protocol client application program interface
JP3930432B2 (en) Computer system for business applications with alarm notification and conditional execution
US20070133876A1 (en) Device, method, and computer program product for enhancing the use of electronic forms in mobile devices
US7293034B2 (en) Dynamically customizing a user interface for the aggregation of content
US6449657B2 (en) Internet hosting system
US7765228B2 (en) Method and system for data collection for alert delivery
JP4546744B2 (en) Method for processing e-mail and alert messages, computer program, and computer-readable recording medium having the computer program
US7606808B2 (en) Maintaining and establishing subscriptions with load-balanced servers
US20060294396A1 (en) Multiplatform synchronized data access from mobile devices of dynamically aggregated content
US8812440B2 (en) Web-based information delivery method, system, and apparatus
US9111003B2 (en) Scalable derivative services
US20090100321A1 (en) Universal contextual actions menu across windows applications
US20050131778A1 (en) Customized subscription builder
JP2003533899A (en) Advertising integrated into wireless communication devices with rich content and direct user response mechanism
US20040012626A1 (en) Method for creating configurable and customizable web user interfaces
US20030106022A1 (en) Outputting dynamic local content on mobile devices
JP2009199606A (en) System and method for stateful web-based computing
KR20090005097A (en) Systems and methods of transforming data for web communities and web applications
US20130024549A1 (en) Method, system and computer program product for lightweight directory access protocol applications
US20050071754A1 (en) Pushing information to distributed display screens
WO2001011443A2 (en) Internet hosting system
US20170048181A1 (en) Method and System for Creating Dynamic Email Signatures

Legal Events

Date Code Title Description
AS Assignment

Owner name: MICROSOFT CORPORATION, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ANTONELLI, JASON;MOVVA, RAMU;REEL/FRAME:014776/0215

Effective date: 20031204

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: MICROSOFT TECHNOLOGY LICENSING, LLC, WASHINGTON

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:MICROSOFT CORPORATION;REEL/FRAME:034541/0477

Effective date: 20141014

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552)

Year of fee payment: 8

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20230125