WO2008109581A1 - Method and apparatus for widget and widget-container distribution control based on content rules - Google Patents

Method and apparatus for widget and widget-container distribution control based on content rules Download PDF

Info

Publication number
WO2008109581A1
WO2008109581A1 PCT/US2008/055756 US2008055756W WO2008109581A1 WO 2008109581 A1 WO2008109581 A1 WO 2008109581A1 US 2008055756 W US2008055756 W US 2008055756W WO 2008109581 A1 WO2008109581 A1 WO 2008109581A1
Authority
WO
WIPO (PCT)
Prior art keywords
widget
container
aggregation point
content aggregation
response
Prior art date
Application number
PCT/US2008/055756
Other languages
French (fr)
Inventor
Stewart O. Allen
Scott F. Cosby
Hasseltine R. Debutts
John A. Fath
Matthew J. Keesan
Hooman Radfar
Carlos F. Reverte
Original Assignee
Clearspring Technologies, Inc.
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 Clearspring Technologies, Inc. filed Critical Clearspring Technologies, Inc.
Publication of WO2008109581A1 publication Critical patent/WO2008109581A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F40/00Handling natural language data
    • G06F40/10Text processing
    • G06F40/12Use of codes for handling textual entities
    • G06F40/14Tree-structured documents
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/6209Protecting access to data via a platform, e.g. using keys or access control rules to a single file or object, e.g. in a secure envelope, encrypted and accessed using a key, or with access control rules appended to the object itself
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/01Input arrangements or combined input and output arrangements for interaction between user and computer
    • G06F3/048Interaction techniques based on graphical user interfaces [GUI]
    • G06F3/0484Interaction techniques based on graphical user interfaces [GUI] for the control of specific functions or operations, e.g. selecting or manipulating an object, an image or a displayed text element, setting a parameter value or selecting a range
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2221/00Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/21Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/2111Location-sensitive, e.g. geographical location, GPS

Definitions

  • the disclosed invention relates generally to control of distribution of content over a network, and in particular, to control of processing and/or distribution of static, media, and/or software objects in a procedural software framework.
  • the world wide web is a platform that has been used to exchange various forms of content including videos, text, music, etc. Often this content is distributed to users and/or computers in an ad-hoc fashion, for example, using e-mail or as files embedded in a web- page.
  • various forms of "viral" distribution or replication of content have been developed that allow users to more easily spread content to other users than previously known ad-hoc methods.
  • these viral distribution methods are more convenient than distributing content in an ad-hoc fashion, they have many shortcomings. For example, they do not provide for methods to control undesirable distribution of content based on criteria defined by, for example, an owner of the content. In other words, the spreading of content using ad-hoc methods and/or forms of viral spreading cannot be controlled in a useful way.
  • a method includes receiving an instruction used to define a widget-container containing a service module associated with a widget.
  • the widget-container is a procedural software framework configured to be executed at a widget-container processing device in response to a reference to the widget-container being accessed from a content aggregation point.
  • the widget-container has a portion configured for receiving the widget.
  • the method also includes determining whether processing of the widget within the portion of the widget- container is restricted and/or allowed.
  • FIG. 1 is a schematic block diagram of a widget-container host configured to control, configure, and coordinate the sending of widget-containers and/or components of a widget-container to widget-container processing devices based on control information, according to an embodiment of the invention.
  • FIG. 2 is a schematic diagram illustrating a widget-container associated with a content aggregation point being displayed at a widget-container processing device, according to an embodiment of the invention.
  • FIG. 3 is a table that illustrates a set of control rules that are based on content aggregation point identifiers, according to an embodiment of the invention.
  • FIG. 4 illustrates a set of category-based control tables that can be used in a control determination, according to an embodiment of the invention.
  • FIG. 5 is a flowchart that illustrates a control determination performed after a widget-container has been sent to a widget-container processing device, according to an embodiment of the invention.
  • FIG. 6 is a flowchart that illustrates a method for restricting or allowing processing of a component associated with a widget-container before sending the widget- container for display in a content aggregation point, according to an embodiment of the invention.
  • a widget-container (also can be referred to as a container) is a procedural software framework that can be configured to contain a widget and/or contain at least one service module that can be associated with the widget and/or widget-container.
  • the widget-container can be a series of instructions that are executable (e.g., interpretable) by, for example, a processor of, for example, a computer or mobile phone.
  • the widget and/or service module is "contained" in the widget-container when a widget and/or service module is either referenced in a widget-container or actually integrated into the procedural software framework of the widget-container.
  • the widget-container includes a portion that is configured for processing of the widget within the widget-container.
  • the widget and/or service module when being contained in the widget-container can be referred to as being wrapped or containerized in the widget- container.
  • the widget and/or the service module (or references to the widget and/or service module) can be referred to as components or portions of the widget- container.
  • the widget-container is a portable framework that can be referenced in (e.g., embedded in, referenced using an embed or object tag) and/or accessed from/using a content aggregation point (e.g., web-page, wireless access protocol (WAP) page).
  • a content aggregation point e.g., web-page, wireless access protocol (WAP) page.
  • WAP wireless access protocol
  • the widget can be any type of object such as a static data object (e.g., text or textual document), media object (e.g., video, mp3, or image), and/or software object (e.g., javascript, Flash program) that can be contained (e.g., integrated or referenced) and/or processed in the widget-container.
  • a static data object e.g., text or textual document
  • media object e.g., video, mp3, or image
  • software object e.g., javascript, Flash program
  • Components of the widget- container are processed in the widget-container when they are, for example, executed, rendered, manipulated, and/or displayed.
  • Placing, sending (e.g., sending and instance of, serving and instance of), and/or processing of a portion associated with a widget-container can be restricted or allowed (e.g., permitted) based on control information (e.g., restriction/blocking information, allowance/permission information) and based on parameter values/identifiers, for example, included in a request for a widget-container.
  • control information e.g., restriction/blocking information, allowance/permission information
  • This determination can be referred to generically as a control determination, or as a restriction determination or an allowance determination.
  • the parameters/identifiers can be, for example, extracted from a reference associated with a widget-container and/or associated with a content aggregation point where a reference to the widget-container has been placed.
  • the control information can be, for example, a control rule, a control condition, and/or a control instruction that can be associated with any portion associated with the widget-container.
  • control information can be based on a metadata parameter value (e.g., tracking parameter values) associated with a portion associated with a widget-container and stored in a database such as a metadata database. More details regarding metadata parameter values as related to a widget-container are set forth in co-pending Application Serial No. 11/537,375, "Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation," which is incorporated herein by reference in its entirety.
  • a control determination can be performed at various times. For example, a control determination can be performed before or in response to a widget-container being placed in a content aggregation point, before the widget-container is sent to a widget-container processing device, or after the widget-container is sent to a widget-container processing device. For example, a widget can be prevented from processing in a widget-container before the widget-container is sent to a widget-container processing device based on, for example, content included in a content aggregation point where the widget is to be processed. In some embodiments, a control determination can prevent (e.g., block) a widget-container from being placed in one or more specified content aggregation points.
  • a content aggregation point can be, for example, a desktop, a start page, a wireless application protocol (WAP) gallery, a gallery, a portal, a processor readable-vehicle (e.g., web-page, web site), and/or a directory.
  • WAP galleries, web galleries, and so forth are types of content aggregation points that can be referred to as content distribution points because they can be vehicles from which content such as widgets and/or widget-containers can be distributed.
  • a content distribution point can be a type of processor-readable vehicle. More details regarding processor-readable vehicles are set forth in co-pending Application Serial No. 11/537,362, "Method and Apparatus for Widget-Container Hosting and Generation," which is incorporated herein by reference in its entirety.
  • the widget-container can be defined (e.g., dynamically generated) and/or modified to control processing and/or sending associated with the widget-container in accordance with a control determination (e.g., restriction determination, allowance determination). Modifying the widget-container, for example, can enable control of the processing and/or sending of portions of a widget-container such as a widget and/or a service module even when these components are served from separate devices/locations.
  • Statistics related to control determinations can be collected and/or processed and proactive control determinations can be performed based on the placement (e.g., parentage, tracking) of widget-containers. The statistics can be based on tracking parameters associated with a metadata database.
  • widget-containers e.g., widget associated with a widget-container, service module associated with a widget-container, widget-container framework, entire widget-container containing a widget(s)and/or a service module(s)
  • FIG. 1 is a schematic block diagram of a widget- container host 100 configured to control, configure, and/or coordinate the sending of widget- containers and/or components of a widget-container to widget-container processing devices 150 based on control information 130, according to an embodiment of the invention.
  • a widget-container is a procedural software framework that can contain (e.g., include a reference to) one or more components such as a widget and/or a service module.
  • the widget-container can be executed on various platforms (e.g., mobile phone, personal computer, personal digital assistant (PDA)) and instances of references to the widget-container can be included in and/or spread to a variety of locations such as content aggregation points (e.g., web sites, WAP site) that can be content aggregation points executed (e.g., read) using the widget-container processing devices 150.
  • the widget- container can be configured to include a portion configured for processing one or more widgets when the widget-container is executed at a widget-container processing device 150.
  • the service module (or reference to the service module) contained in the widget-container can be a pre-defined and/or customizable (e.g., user-defined) function related to a variety of functions (e.g., tracking, placing) related to the widget-container and/or its components (e.g., widget).
  • the service module and/or widget can be wrapped in the widget-container, for example, at the time that the widget-container is first defined, after the widget-container has been generated before serving, dynamically when the widget-container is being served, and/or after the widget-container has been served.
  • the widget- container can be produced dynamically and/or statically for storage, for example, using a hardware and/or software generation engine (not shown) that can be included in the widget- container host 100 and/or a widget-container creation device 120.
  • the widget-container can be dynamically modified using dynamic injection (i.e., injecting data into the widget-container just before/when the widget-container is served). More details related to dynamic widget-container generation are set forth in the above-identified co- pending application entitled, "Method and Apparatus for Widget-Container Hosting and Generation.”
  • Each of the widget-container processing devices 150 can be any type of device that is configured to process the widget- container and a widget and/or service module that can be contained in the widget-container.
  • Each of the widget-container processing devices 150 can be, for example, a computer, a mobile phone, a PDA, a server, and/or any other processor-based device.
  • the widget- container can be configured such that the widget-container can be processed by each of these widget-container processing devices 150 even though the platforms (e.g., hardware, architecture, software, operating system, runtime libraries, programming languages) of the respective widget-container processing devices 150 may be different.
  • the network 140 can be any type of network such as a local area network (LAN) and/or a wide area network (WAN) implemented as a wired and/or wireless network with one or more segments in a variety of environments such as, for example, an office complex.
  • LAN local area network
  • WAN wide area network
  • the widget-container host 100 is configured to use the control information 130 to determine whether or not to allow any portion associated with a widget-container to be sent to and/or processed at one or more of the widget-container processing devices 150.
  • the widget-container host 100 can receive a request for a widget-container from a widget-container processing device 150. Based on a parameter value/identifier included in the request and based on the control information 130, sending a portion associated with a widget-container that is stored at the widget-container host 100 and/or dynamically generated at the widget-container host 100 can be restricted or allowed.
  • the parameter value/identifier can be retrieved from, for example, a metadata database (not shown) based on a value included in the request.
  • the widget-container host 100 can be configured to determine whether or not one or more service modules should be contained in a widget-container based on the control information 130.
  • the block diagram also illustrates a widget-server 110 in communication with the widget-container processing devices 150 via network 140.
  • the widget server 110 can be configured to store and send the widget referenced within a widget-container.
  • the widget server 110 can send (e.g., serve) the widget to one or more of the widget-container processing devices 150.
  • the request for the widget can be defined based on a reference to a widget being accessed from an instance of the widget-container at a widget-container processing device 150.
  • the widget can then be sent from the widget server 110 to the widget-container processing device 150 and processed within the instance of the widget-container.
  • the widget-container host 100 can be configured to control sending and/or processing of any portion (e.g., widget) of a widget-container by modifying the widget- container in a variety of ways. For example, if processing of a widget within an instance of a widget-container is restricted based on the control information 130, a reference to the widget that is normally included in the widget-container can be removed when the instance of the widget-container is generated and/or served (e.g., sent). In other words, the widget-container can be modified such that processing of the widget is prevented. Because the widget server 110, for example, may not have access to the control information 130 and/or may not be configured to process the control information 130, the sending of the widget from the widget server 110 can be controlled by modifying the widget-container associated with the widget.
  • any portion e.g., widget
  • the widget-container host 100 can modify a widget- container such that a reference to a portion that is typically included in the widget-container is not included in the widget-container when the widget-container is generated or can be removed after the widget-container is generated.
  • the widget-container host 100 can also include a null reference in place of a valid reference to a portion associated with the widget-container (e.g., widget). This can effectively prevent the portion from being sent and/or processed.
  • the widget-container host 100 can send an indicator to, for example, a widget-container processing device 150 to trigger the widget- container processing device 150 to stop processing a portion associated with a widget- container.
  • the widget-container host 100 can send an indicator to, for example, the widget server 110 to prevent the widget server 110 from sending (e.g., block streaming) a widget for processing within a widget-container.
  • a control determination can be based on parameters and/or identifiers included in a request for a widget-container that can be, for example, extracted from a reference associated with a widget-container as well as based on control information 130 related to the widget-container stored in a memory (e.g., database). For example, an identifier associated with a placement of a widget-container can be received at the widget-container host 100 in a request for the widget-container and used by the widget-container host 100 with reference to the control information 130 to make a control determination. The request can be defined by any of the widget-container processing devices 150. The widget-container 100 can then generate, modify, and/or send the widget-container based on a result of the control determination.
  • the control information 130 can be any type of information that can be used to determine whether or not to allow sending and/or processing of portions of a widget- container associated with one or more of the widget-container processing devices 150.
  • the control information 130 can include or be an instruction that specifies whether or not a particular widget, service module, and/or widget-container should be sent to a particular type of widget-container processing device 150.
  • the control information can include information from a whitelist database (e.g., third party whitelist database, widget- container specific whitelist database) or blacklist database (e.g., third party blacklist database, widget-container specific blacklist database) associated with any portion associated with a widget-container.
  • the control information 130 can be stored in, for example, the memory 105 of the widget-container host 100 or a separate database (e.g., metadata database) that can be accessed by the widget-container host 100 via a network such as network 140.
  • the control information 130 can be associated with or include metadata parameters and metadata parameter values (e.g., tracking parameter values) associated with a widget-container and/or a component of the widget-container (e.g., widget or service module).
  • the metadata parameters and values can be used to, for example, dynamically customize or track the widget-container and/or the component of the widget-container.
  • the control determination can include a restriction or allowance of a customizable feature of any portion associated with the widget-container. For example, a determination can be based on a tracking history of a particular viewer of any portion associated with a widget-container, a location where any portion associated with a widget-container is viewed, a placement history of any portion associated with a widget- container.
  • any portion associated with the widget-container can be stored and retrieved from the memory 105 of the widget-container host.
  • the memory 105 can be, for example, a database included in the widget-container host 100.
  • any portion associated with the widget-container can be stored in and accessed from a memory device such as a database that is a remote database and/or a distributed database that can be accessed by the widget-container host 100 via network 140 or via a separate network (not shown).
  • a widget-container served from the widget-container host 100 can contain a reference to one or more service modules that are served from, for example, a service module server (not shown).
  • a widget-container creation device 120 can be connected to the container host 100 via network 140.
  • the widget-container creation device 120 can be used to generate, define, and/or modify a widget-container.
  • the widget-container creation device 120 can be, for example, a personal computer, a mobile device (e.g., mobile phone and/or PDA), and/or a server (e.g., back-end server, network server).
  • the widget-container creation device 120 can be configured to automatically produce instructions used to generate and/or modify widgets containers, for example, when a widget is received.
  • the widget-container creation device 120 can also store widgets and function as a widget server.
  • Each of the widget-container processing devices 150 can also be configured to function as a widget-container creation device 120 and vice versa.
  • the widget-container creation device 120 can trigger the generation and/or modification of the widget-container at the widget-container host 100.
  • the widget-container creation device 120 can send an instruction from, for example, a processor (not shown) to cause the widget-container host 100 to generate and/or modify a widget-container.
  • widget-container creation device 120 can trigger the generation and/or modification of the widget-container at the widget-container host 100.
  • the widget-container host 100 is a centralized control/storage mechanism that manages requests received from container processing devices 150 and manages the sending of widgets containers (e.g., prompts a separate device (not shown) to send a widget-container stored in a separate database (not shown)), the functionality of the widget-container host 100 can be decentralized and/or distributed.
  • a hierarchy of widget-container hosts 100 can be arranged, for example, with management components and/or slave components that control, configure, and coordinate the sending of widget-containers to the widget-container processing devices 150.
  • FIG. 2 is a schematic diagram illustrating a widget-container 250 associated with a content aggregation point 220 being displayed on a display 242 at a widget-container processing device 240, according to an embodiment of the invention.
  • the widget-container server 270 can be configured to determine whether sending/processing of the widget 260 within the widget-container 250 and/or sending/execution of the widget-container 250 are allowed based on control information 295 stored in a control database 290 (also can be referred to as a restriction database or permission database).
  • the widget-container 250 is served from the widget-container server 270 to the widget-container processing device 240 in response to a widget-container reference 222 being accessed from the content aggregation point 220.
  • the widget-container reference 222 is defined to trigger sending of the widget-container 250 from the widget- container server 270 for display in the content aggregation point 220, for example, when accessed.
  • the widget-container 250 can be dynamically generated based on an instruction used to define the widget-container 250 or retrieved (e.g., from a memory (not shown)) before the widget-container 250 is served (e.g., sent) to the widget- container processing device 240.
  • the generating or retrieving of the widget-container 250 can be triggered in response to a request for the widget-container 250.
  • a widget 260 is served from a widget-server 280 for processing (e.g., execution) within the widget container 250 in response to a widget reference 252 being accessed from the widget-container 250.
  • the widget 260 is served from the widget server 280 in response to a request for the widget 260 defined based on the widget reference 252.
  • the widget 260 can be requested, received, and/or processed within the widget-container 250 after the widget-container 250 is received at the content aggregation point 220.
  • the content aggregation point 220 can be, for example, a web-page, and the widget-container reference 222 can be, for example, an embed tag included in the content aggregation point 220.
  • the widget-container 250 is a Flash object and the content aggregation point 220 is a Flash-enabled web browser or Flash-enabled web browser page.
  • FIG. 2 illustrates a single instance of the widget-container 250/widget 260 being sent to content aggregation point 220
  • multiple instances of the widget-container 250/widget 260 can be synchronously or asynchronously generated (e.g., dynamically generated) and/or distributed to multiple widget-container processing devices and/or to multiple content aggregation points that each include a reference to the widget-container 250.
  • the widget-container server 270 can be configured to determine whether processing of the widget 260 within the widget-container 250 and/or sending/execution of the widget-container 250 are allowed based on control information 295.
  • the control information 295 is stored in and accessed by the widget-container server 270 from a control database 290
  • the control information 295 can be stored in a memory (not shown) of the widget-container server 270 or in a set of distributed memory devices (not shown) such as distributed databases.
  • the control information 295 can be generated and/or collected by the widget- container server 270 when needed.
  • the control database 290 can be a third-party database that includes control information 295 such as a white-list or a black-list.
  • the control information 295 can be defined by the owner of widget 260 and/or the owner/creator of the widget-container 250.
  • the widget 260 and the widget- container 250 can be served from two different devices — the widget server 280 and widget- container server 270, respectively — the owner of each can be the same entity.
  • the owner of the widget 260 can define a control rule or control condition based on content (e.g., images, text) associated with content aggregation point 220 (e.g., web-page, WAP page).
  • the owner of widget 260 may restrict (or allow) processing of widget 260 within the content aggregation point 220 because the content of content aggregation point 220 may be viewed as conflicting or incompatible with the content of widget 260.
  • the control information 295 can be based on a content rule associated with a content aggregation point. More details regarding content rules associated with content aggregation points are set forth in co-pending Application Serial No. unassigned, filed on March 6, 2007, and entitled, "Method and Apparatus for Widget- Container Platform Adaptation and Distribution" which is incorporated herein by reference in its entirety.
  • the control information 295 can be related to any type of information that can be used to determine whether or not to allow processing of widget 260 within the widget- container 250 and/or whether or not to allow sending of the widget-container 250 to the widget-container processing device 240 for execution within the content aggregation point 220.
  • the control information 295 can be configured such that a control determination (e.g., restriction determination, allowance determination) can be based on an identifier (e.g., uniform resource locator (URL), uniform resource identifier (URI)) associated with the content aggregation point 220 where the widget-container reference 222 is placed.
  • the control information 295 can include, for example, a rule that indicates whether processing of widget 260 in content aggregation point 220 is allowed or restricted.
  • a control determination can be based on a location of the widget-container processing device 240.
  • an indicator e.g., Internet Protocol (IP) address or portion of an IP address
  • IP Internet Protocol
  • a control determination can be performed in response to the widget-container 250 being placed (e.g., widget-container reference 222 to the widget- container 250 being placed) in content aggregation point 220.
  • the result of the control determination can be stored (e.g., at the widget-container host 100) and associated with a placement identifier uniquely associated with the placement of the widget-container 250 in the content aggregation point 220. If the unique placement identifier is received in a request for an instance of the widget-container 250, the result of the control determination can be immediately implemented without performing the control determination a second time.
  • the widget-container reference 222 can be used as the trigger for implementing the stored control determination result.
  • the widget-container 250 can also contain a service module integrated into the widget-container 250 (e.g., integrated during dynamic generation) or served from, for example, a service module server (not shown).
  • a control determination can also be based on or related to the service module.
  • the service module can be a pre-defined function associated with the widget 260.
  • a service module can be a metadata searching/retrieval function, a polling/categorizing function, a widget-container deployment function (e.g., using a placement service module), a transaction service function (e.g., service module for facilitating a web purchase, service module used for signing a user up for a web service, etc.), a security function (e.g., security firewall function), and/or a widget-container tracking function.
  • a widget-container deployment function e.g., using a placement service module
  • a transaction service function e.g., service module for facilitating a web purchase, service module used for signing a user up for a web service, etc.
  • security function e.g., security firewall function
  • the widget 260 can be, for example, a static data object, a software object, and/or a media object. Within each of these categories, the widget can be a specific content type. For example, the widget 260 can be an processed (e.g., played) or a displayed media object such as a video file (i.e., a video content file), an mp3 file (i.e., audio content file), or an image file (i.e., image content file).
  • the widget 260 can be a static data object that is, for example, displayed within the widget-container 250.
  • the static data object can be, for example, a textual object such as a set of letters, a textual document, or an html based textual document.
  • the static data object can include, for example, links to other widgets (not shown).
  • the widget 260 can also be a software object such as an executable application or set of instructions that is executed within the procedural software framework of the widget- container 250.
  • the results of the executable application can be included and/or displayed within the procedural software framework of the widget-container 250.
  • the widget- container 250 can be configured so that the widget 260 can be processed within a portion of the widget-container 250 when the widget-container 250 is displayed on the display 242.
  • the procedural software framework that makes up the widget-container 250 can be programmed in any number of programming languages that are compiled (e.g., C++) and/or in programming languages that are interpreted (e.g., Java).
  • An executable portion (of the procedural software framework) that manages and controls service module(s) (not shown) and/or the widget 260 referenced (e.g., contained) in the widget-container 250 can be referred to as the core of the widget-container 250.
  • Metadata parameter values can be passed to the widget-container 250 and used by, for example, the core of the widget-container 250 to modify, for example, attributes of the widget-container 250 and/or widget 260 (e.g., x, y location of the widget 260, size of the widget 260, color, themes, styles, etc.).
  • attributes of the widget-container 250 and/or widget 260 e.g., x, y location of the widget 260, size of the widget 260, color, themes, styles, etc.
  • FIG. 3 is a table 300 that illustrates a set of control rules (e.g., restriction information) that are based on content aggregation point identifiers 340, according to an embodiment of the invention.
  • the table 300 illustrates that execution of widget-container A (column 310) is allowed in content aggregation points with identifiers URIl and URI2.
  • table 300 can be used in a control determination to determine that processing of widget W is restricted in content aggregation point URI2, but allowed in content aggregation point URIl .
  • the identifier of the content aggregation point 340 can be received at, for example, a widget-container host for use in a control determination at the widget-container host.
  • a request for the widget-container 310 can include the identifier of the content aggregation point 340 or a separate identifier such as a placement identifier 330 that can be used to look-up the identifier of the content aggregation point 340.
  • the identifier of the content aggregation point 340 can be retrieved from a metadata database (not shown) that can be used to associate a widget-container reference with the identifier of the content aggregation point 340.
  • a control determination can be based on one or more content aggregation point identifiers 340, in some embodiments, a control determination can be performed based on a variety of parameters that can be, for example, stored in a metadata parameter database. For example, a control determination can be based on parentage information in a metadata database (not shown) or a placement identifier 330 associated with a particular placement of a reference to a widget container 310 in a content aggregation point 345 associated with the content aggregation point identifiers 340.
  • the placement identifier 330 is included in a reference to a widget-container 310 placed in a content aggregation point 345 and can be used in a control determination.
  • a request for widget-container A can be defined to indicate the placement identifier 330 uniquely associated with the particular placement of widget- container A and included in the reference. If the widget-container A being requested is the widget-container placed in the content aggregation point X, the request can include the placement identifier Pl from the reference. The placement identifier Pl can then be used to determine based on table 300 that both widget processing and widget-container execution are permitted.
  • control information in table 300 can be used in conjunction with a default rule that processing of a widget and/or sending/execution of a widget-container is restricted unless allowed.
  • the determination can be referred to as an allowance determination.
  • a set of control rules can be defined such that processing of a widget and/or sending/execution of a widget-container is allowed unless restricted based on a control rule in a control database. In this situation, the determination can be referred to as a restriction determination.
  • widget-container 250 can also include a tracking kernel (not shown) configured to perform a tracking function.
  • the tracking kernel which can also be referred to as a tracking module, can be embedded/integrated in (e.g., programmed within) the procedural software framework of the widget-container.
  • the tracking kernel in some embodiments, may not be displayed on the display 242.
  • the tracking kernel can be used to collect tracking parameter values related to user-triggered interactions with the widget- container 250 such as basic mouse movement and clock events.
  • the tracking kernel can also be used to collect tracking parameter values related to placement information such as, for example, what web-page (e.g., content aggregation point 220) a widget-container is referenced on and/or placed on, where on the page it was placed, and/or size of the widget-container 250 (e.g., dimensional and memory). This information can be used in a control determination. For example, a tracking parameter value(s) can be used to determine whether a reference to a widget-container will trigger a portion associated with the widget-container to be processed in a portion of a web-page, such as processor readable vehicle 220, that is not allowed based on the control information 295.
  • a tracking parameter value(s) can be used to determine whether a reference to a widget-container will trigger a portion associated with the widget-container to be processed in a portion of a web-page, such as processor readable vehicle 220, that is not allowed based on the control information 295.
  • the tracking parameter value can be used to determine whether the widget-container should be processed on the web-page at all based on the control information 295. Certain user- triggered interactions based on a tracking parameter value can also trigger restriction (or allowance) of a portion associated with a widget-container from being processed and/or executed.
  • a control rule can be a complex set of rules based on one or more variables and/or an algorithm.
  • a control rule can be based on portions of multiple widget-containers placed within a particular content aggregation point that are defined as mutually exclusive portions of widget-containers (e.g., should not be displayed on the same content aggregation point, should not be displayed on a specified content aggregation point).
  • a control determination based on a complex set of rules can be performed based on tracking parameter values (e.g., parentage information) collected and/or stored in, for example, a metadata database (not shown) or the control database 290.
  • a notification can be sent to an entity associated with a component of the widget-container 250 that indicates that processing of a particular component of the widget-container 250 such as the widget 260 has been terminated.
  • the notification can be generated and sent by, for example, the widget-container server 270.
  • the notification can include statistical data that indicates, for example, one or more content aggregation points, locations, and/or processing devices where the processing of the widget 260 has been terminated or permitted.
  • the statistical data can be based on tracking parameter values and/or parentage information associated with the widget 260 of the widget- container. For example, control results for a portion associated with a widget-container with a particular genealogical lineage can be compiled and sent in a notification.
  • statistical data based on control information can be stored in, for example, the control database 290 where the statistical data can be retrieved.
  • historical termination data can be used to update, for example, control information 295 in the control database 290.
  • FIG. 4 illustrates a set of category-based control tables 400 and 490 that can be used in a control determination, according to an embodiment of the invention.
  • Table 400 illustrates that each widget 420 of the widget-containers 410 has been associated with a control category 450 and a control indicator 440.
  • Table 400 is a set of rules that indicates whether widget 420 should be processed within a content aggregation point that has been classified as a certain control category 430. For example, table 400 illustrates widget W can be processed in a content aggregation point with a control category 430 of A, but not a control category 430 of B.
  • table 400 can also be used as a set of rules to determine whether or not widget-containers 410 or service modules (not shown) should be sent to or processed within a content aggregation point that has been classified as a certain control category 430.
  • Table 490 illustrates a set of control categories 450 associated with content aggregation points identifiers 460.
  • the control categories 450 can be determined based on, for example, an assessment (e.g., content scan) of each of the content aggregation points where a widget-container 410 has been placed.
  • a regular (e.g., nightly) or random assessment of content of content aggregation points can be used to update table 490.
  • An assessment of content can be based on, for example, a scanned image of a content aggregation point.
  • the assessment of the content of a content aggregation point can be used to update control information associated with any portion associated with a widget-container.
  • content associated with a particular content aggregation point can be assessed in response to a widget-container reference associated with a widget-container being placed in the particular content aggregation point.
  • placement of a widget-container e.g., placement of a reference to a widget container
  • table 400 is a table stored at, for example, a widget-container server and table 490 is a table stored at a control database
  • the widget-container server can make a control determination by cross-referencing the control information in table 400 with the control information in table 490 accessed from the control database.
  • the widget-container server can cross-reference the information based on a determination of, for example, a content aggregation point identifier where any of the widget-containers 410 have been placed. For example, if widget-container M has been placed in content aggregation point URI3, a widget- container server can determine using tables 400 and 490 that widget W can be processed within widget-container M at URI3 because content category A is not restricted.
  • Default rules can be used in conjunction with tables 400 and 490. For example, if widget-container P were placed in URI3, a default rule may prevent processing of widget Q within the widget-container P at URI3 because an existing rule in table 400 does not cover that situation.
  • the tables 400 and 490 were illustrated as two separate blocks of information, in some embodiments, the tables 400 and 490 can be combined or portions of either of the tables 400 and/or 490 included as separate blocks of information in, for example, separate databases.
  • control categories can be, for example, location-related control categories.
  • a portion associated with a widget-container may be permitted to be processed (or prevented from processing) in only certain locations based on a control category within a control rule.
  • the location control can be defined based on, for example, an Internet Protocol (IP) address associated with a request for the widget-container.
  • IP Internet Protocol
  • the widget-container server 270 can be configured to make a control determination with respect to the widget 260 and/or widget-container 250 after the widget-container 250 is served (e.g., sent). For example, when the widget-container server 270 determines, after the widget-container 250 has been sent to the widget-container processing device 240, that sending/execution of the widget-container 250 and/or processing of the widget 260 is restricted (or allowed), the widget-container server 270 can send an indicator to the widget-container processing device 240 to stop (or start/continue/allow) execution of the widget-container 250 within the content aggregation point 220 or processing of the widget 260 within the widget-container 250.
  • the widget-container server 270 can passively permit processing if processing of the widget 260 within the widget-container 250 has already commenced and is allowed.
  • FIG. 5 is a flowchart that illustrates a control determination performed after a widget-container has been sent to a widget-container processing device, according to an embodiment of the invention.
  • the flowchart illustrates that a widget-container is produced (e.g., generated) with a valid reference to a component of the widget-container 500.
  • the valid reference can be a reference to a component of the widget-container such as a widget and/or a reference to a service module associated with the widget.
  • the widget-container can be produced in response to a request for the widget-container defined in response to a reference to the widget-container being accessed from a content aggregation point (e.g., web- page, WAP page) executed/displayed at the widget-container processing device.
  • the widget- container produced at 500 can be an instance that is, for example, generated dynamically with customized features for the content aggregation point based on a metadata parameter value.
  • the widget-container is sent to the widget-container processing device such as a cell phone at 510.
  • a control determination (e.g., restriction determination, allowance determination) is performed at 520 to determine whether processing/execution of the component of the widget-container is restricted or allowed.
  • the control determination can be based on control information that is retrieved from a memory such as a control database.
  • the control determination can be based on, for example, an identifier associated with the content aggregation point where the widget-container is to be executed and/or displayed.
  • the control determination can be based on the content of the content aggregation point or the physical location where the content aggregation point is being accessed.
  • the control determination can also be performed based on a credential or location identifier associated with an entity that is requesting the widget-container.
  • an indicator to terminate processing/execution of the component of the widget-container at the widget- container processing device is sent at 530.
  • the indicator can be sent to, for example, a widget server to cause the widget server to stop streaming a video widget that is being processed within the widget-container.
  • the indicator can be sent directly to the widget- container processing device and can be configured to cause the widget-container processing device to stop processing/executing the component of the widget-container.
  • a notification to an entity associated with the component of the widget- container that processing/execution of that component has been terminated.
  • the notification can include statistical data that indicates, for example, other content aggregation points, locations, and/or processing devices where the processing/execution of the component has been terminated.
  • the statistical data can be based on tracking and/or parentage information associated with any portion associated with the widget-container.
  • historical termination data can be used to update, for example, a control database.
  • the flowchart shown in FIG. 5 is directed towards components of widget-containers, in some embodiments, the flowchart can be modified to apply to any portion associated with the widget-container including the entire widget-container itself. In some embodiments, the flowchart can be modified such that the blocks are in any order. For example, a notification can be sent to an entity before an indicator to cause termination is generated and/or sent.
  • the widget-container server 270 can be configured to make a control determination with respect to the widget 260 and/or widget-container 250 before the widget-container 250 is served (e.g., sent). For example, when the widget- container server 270 determines that sending of the widget-container 250 is restricted (or allowed) before the widget-container 250 has been sent, the widget-container server 270 can be configured to deny (or grant) a request for the widget-container 250 and/or can halt (or continue) processing with respect to the widget-container 250.
  • the widget-container server 270 determines, before the widget-container 250 has been sent, that processing of the widget 260 is restricted, the widget-container server 270 can still send the widget-container 270.
  • the widget-container 270 can be modified, for example, by removing the widget reference 252, including a null (e.g., empty) reference (not shown), and/or a re-directing reference (e.g., to a notice that the widget 260 will not be processed) to prevent a valid request for the widget 260 from being defined and sent to the widget server 280.
  • the widget-container server 270 determines that processing of the widget 260 within the widget-container 250 is allowed before the widget-container 250 has been sent, the widget-container server 270 can send the widget-container 250 with a widget reference 252 that is valid.
  • the valid widget reference 252 or null widget reference 252 can be dynamically injected into the widget-container 250 when the widget-container 250 is generated, for example, based on an instruction in response to a request for the widget- container 250.
  • a valid widget reference 252 can be removed from the widget- container 250 when the widget-container 250 is dynamically generated.
  • the widget-container server 270 can send an indicator to the widget server 280 to cause the widget server 280 to prevent sending or halt (e.g., block) sending, if necessary, of the widget 260 to the widget-container processing device 240.
  • the widget-container server 270 can cause the widget server 280 to halt sending if sending and/or processing of the widget 260 within the widget-container 250 has already commenced.
  • the widget-container processing device 240 and/or widget- container 250 can be configured to wait for an indicator from the widget-container server 270 before processing the widget 260.
  • the widget server 260 can be configured to wait for an indicator from the widget-container server 270 before sending the widget 260 for processing within the widget-container 250.
  • the default mode of the widget-container processing device 240, widget server 260, and/or widget-container 250 can be to process and/or send the widget 260 when triggered by the widget-container server 270.
  • FIG. 6 is a flowchart that illustrates a method for restricting or allowing processing of a component associated with a widget-container before sending the widget- container for display in a content aggregation point, according to an embodiment of the invention.
  • the flowchart illustrates that an instruction defining a widget-container associated with a widget is received at 600.
  • the instruction can be used to dynamically produce the widget-container when a request for the widget-container is received.
  • a reference uniquely defined to trigger sending of an instance of the widget- container for execution within a content aggregation point is received at 610.
  • the reference can be received and stored in a database and associated with customizable parameter values (e.g., metadata parameter values) associated with the placement of the reference to the widget-container in the content aggregation point so that the customizable parameters values can be used when producing the widget-container for sending to the content aggregation point.
  • customizable parameter values e.g., metadata parameter values
  • An indicator that the reference to the widget-container has been accessed at the content aggregation point is received at 620, an identifier associated with the content aggregation point is received at 630 in response to the reference being accessed, and a control determination is performed at 640 to determine whether processing of any component (include the widget referenced above) of the widget-container is restricted or allowed.
  • the control determination can be based on control information that is retrieved from a memory such as a control database.
  • the control determination can be based on, for example, an identifier associated with the content aggregation point where the widget- container is to be executed and/or displayed.
  • an instance of the widget-container is produced with a valid reference to the component of the widget- container at 650 based on the instruction.
  • the widget-container is produced without modifying the instruction or the widget-container with respect to the reference to the component.
  • the instance of the widget-container with the valid reference is then sent to the widget-container processing device that requested the widget-container at 670.
  • the widget-container is a static object stored in a memory (e.g., not dynamically generated based on the instruction)
  • the widget-container can be retrieved from the memory and sent to the widget-container processing device. In other words, the widget- container will not be modified.
  • the widget- container can be modified and/or produced at 660 based on the control determination.
  • the widget-container can be produced based on the instruction with some modification to address the control determination.
  • the widget-container can be produced with a null reference to the component of the widget-container (or a re-directing reference) such that the component of the widget-container is not requested from, for example, a server of the component when the widget-container is executed a widget-container processing device.
  • the modified instance of the widget-container is then sent to the widget-container processing device that requested the widget-container at 670.
  • the widget-container is a static object stored in a memory (e.g., not dynamically generated based on the instruction)
  • the widget-container can be retrieved from the memory and modified to, for example, remove the reference to the component before the widget-container is sent to the widget-container processing device.
  • Some embodiments of the invention relate to a storage product with a processor- readable medium having instructions or code thereon for performing various processor- implemented operations.
  • the media and code may be those specially designed and constructed for the purposes of the invention, or they may be of the kind well known and available to those having skill in the software arts.
  • processor-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs ("CD/DVDs”), Compact Disc-Read Only Memories (“CD-ROMs”), and holographic devices; magneto-optical storage media such as floppy or optical disks; carrier wave signals; and hardware devices that are specially configured to store and execute program code, such as Application-Specific Integrated Circuits ("ASICs”), Programmable Logic Devices (“PLDs”), and ROM and RAM devices.
  • ASICs Application-Specific Integrated Circuits
  • PLDs Programmable Logic Devices
  • code examples include, but are not limited to, micro-code or micro-instructions, machine instructions, such as produced by a compiler, and files containing higher-level instructions that are executed by a processor using an interpreter.
  • code examples include, but are not limited to, control signals, encrypted code, and compressed code.
  • the present invention is related to an apparatus and methods for controlling processing of and/or distribution of static, media, and/or software objects in a procedural software framework.

Abstract

A method includes receiving an instruction used to define a widget-container containing a service module associated with a widget. The widget-container is a procedural software framework configured to be executed at a widget-container processing device in response to a reference to the widget-container being accessed from a content aggregation point. The widget-container has a portion configured for receiving the widget. The method also includes determining whether processing of the widget within the portion of the widget-container is restricted and/or allowed.

Description

METHOD AND APPARATUS FOR WIDGET AND WIDGET-CONTAINER DISTRIBUTION CONTROL BASED ON CONTENT RULES
Cross Reference to Related Application
[1001] This application is a continuation of and claims priority to U.S. Patent Application No. 11/682,639, entitled "Method and Apparatus for Widget and Widget-Container Distribution Control Based on Content Rules," filed March 6, 2007, the disclosure of which is hereby incorporated by reference in its entirety.
Background
[1002] The disclosed invention relates generally to control of distribution of content over a network, and in particular, to control of processing and/or distribution of static, media, and/or software objects in a procedural software framework.
[1003] The world wide web is a platform that has been used to exchange various forms of content including videos, text, music, etc. Often this content is distributed to users and/or computers in an ad-hoc fashion, for example, using e-mail or as files embedded in a web- page. Recently, various forms of "viral" distribution or replication of content have been developed that allow users to more easily spread content to other users than previously known ad-hoc methods. Although these viral distribution methods are more convenient than distributing content in an ad-hoc fashion, they have many shortcomings. For example, they do not provide for methods to control undesirable distribution of content based on criteria defined by, for example, an owner of the content. In other words, the spreading of content using ad-hoc methods and/or forms of viral spreading cannot be controlled in a useful way. Thus, there is a need for an apparatus and method for restricting or permitting the distribution of content.
Summary of the Invention
[1004] A method includes receiving an instruction used to define a widget-container containing a service module associated with a widget. The widget-container is a procedural software framework configured to be executed at a widget-container processing device in response to a reference to the widget-container being accessed from a content aggregation point. The widget-container has a portion configured for receiving the widget. The method also includes determining whether processing of the widget within the portion of the widget- container is restricted and/or allowed.
Brief Description of the Drawings
[1005] The present invention is described with reference to the accompanying drawings. In the drawings, identical or like reference numbers indicate identical or functionally similar elements.
[1006] FIG. 1 is a schematic block diagram of a widget-container host configured to control, configure, and coordinate the sending of widget-containers and/or components of a widget-container to widget-container processing devices based on control information, according to an embodiment of the invention.
[1007] FIG. 2 is a schematic diagram illustrating a widget-container associated with a content aggregation point being displayed at a widget-container processing device, according to an embodiment of the invention.
[1008] FIG. 3 is a table that illustrates a set of control rules that are based on content aggregation point identifiers, according to an embodiment of the invention.
[1009] FIG. 4 illustrates a set of category-based control tables that can be used in a control determination, according to an embodiment of the invention.
[1010] FIG. 5 is a flowchart that illustrates a control determination performed after a widget-container has been sent to a widget-container processing device, according to an embodiment of the invention.
[1011] FIG. 6 is a flowchart that illustrates a method for restricting or allowing processing of a component associated with a widget-container before sending the widget- container for display in a content aggregation point, according to an embodiment of the invention.
Detailed Description
[1012] A widget-container (also can be referred to as a container) is a procedural software framework that can be configured to contain a widget and/or contain at least one service module that can be associated with the widget and/or widget-container. As a procedural software framework, the widget-container can be a series of instructions that are executable (e.g., interpretable) by, for example, a processor of, for example, a computer or mobile phone. The widget and/or service module is "contained" in the widget-container when a widget and/or service module is either referenced in a widget-container or actually integrated into the procedural software framework of the widget-container. In some embodiments, the widget-container includes a portion that is configured for processing of the widget within the widget-container. The widget and/or service module when being contained in the widget-container can be referred to as being wrapped or containerized in the widget- container. In some embodiments, the widget and/or the service module (or references to the widget and/or service module) can be referred to as components or portions of the widget- container.
[1013] The widget-container is a portable framework that can be referenced in (e.g., embedded in, referenced using an embed or object tag) and/or accessed from/using a content aggregation point (e.g., web-page, wireless access protocol (WAP) page). For example, when a request for the widget-container (and a widget associated with the widget-container) is received in response to a reference to the widget-container being accessed from a content aggregation point, the widget-container can be served for execution within the content aggregation point in response to the request. The widget can be any type of object such as a static data object (e.g., text or textual document), media object (e.g., video, mp3, or image), and/or software object (e.g., javascript, Flash program) that can be contained (e.g., integrated or referenced) and/or processed in the widget-container. Components of the widget- container are processed in the widget-container when they are, for example, executed, rendered, manipulated, and/or displayed.
[1014] Placing, sending (e.g., sending and instance of, serving and instance of), and/or processing of a portion associated with a widget-container (e.g., entire widget-container) can be restricted or allowed (e.g., permitted) based on control information (e.g., restriction/blocking information, allowance/permission information) and based on parameter values/identifiers, for example, included in a request for a widget-container. This determination can be referred to generically as a control determination, or as a restriction determination or an allowance determination. The parameters/identifiers can be, for example, extracted from a reference associated with a widget-container and/or associated with a content aggregation point where a reference to the widget-container has been placed. [1015] The control information can be, for example, a control rule, a control condition, and/or a control instruction that can be associated with any portion associated with the widget-container. In some embodiments, for example, control information can be based on a metadata parameter value (e.g., tracking parameter values) associated with a portion associated with a widget-container and stored in a database such as a metadata database. More details regarding metadata parameter values as related to a widget-container are set forth in co-pending Application Serial No. 11/537,375, "Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation," which is incorporated herein by reference in its entirety.
[1016] A control determination (e.g., restriction determination, allowance determination) can be performed at various times. For example, a control determination can be performed before or in response to a widget-container being placed in a content aggregation point, before the widget-container is sent to a widget-container processing device, or after the widget-container is sent to a widget-container processing device. For example, a widget can be prevented from processing in a widget-container before the widget-container is sent to a widget-container processing device based on, for example, content included in a content aggregation point where the widget is to be processed. In some embodiments, a control determination can prevent (e.g., block) a widget-container from being placed in one or more specified content aggregation points.
[1017] A content aggregation point can be, for example, a desktop, a start page, a wireless application protocol (WAP) gallery, a gallery, a portal, a processor readable-vehicle (e.g., web-page, web site), and/or a directory. WAP galleries, web galleries, and so forth are types of content aggregation points that can be referred to as content distribution points because they can be vehicles from which content such as widgets and/or widget-containers can be distributed. A content distribution point can be a type of processor-readable vehicle. More details regarding processor-readable vehicles are set forth in co-pending Application Serial No. 11/537,362, "Method and Apparatus for Widget-Container Hosting and Generation," which is incorporated herein by reference in its entirety.
[1018] The widget-container can be defined (e.g., dynamically generated) and/or modified to control processing and/or sending associated with the widget-container in accordance with a control determination (e.g., restriction determination, allowance determination). Modifying the widget-container, for example, can enable control of the processing and/or sending of portions of a widget-container such as a widget and/or a service module even when these components are served from separate devices/locations. Statistics related to control determinations can be collected and/or processed and proactive control determinations can be performed based on the placement (e.g., parentage, tracking) of widget-containers. The statistics can be based on tracking parameters associated with a metadata database.
[1019] Although many of the embodiments within the detailed description are described with respect to portions associated with widget-containers (e.g., widget associated with a widget-container, service module associated with a widget-container, widget-container framework, entire widget-container containing a widget(s)and/or a service module(s)) a person of skill in the art, having the benefit of this disclosure, can recognize that the methods and apparatus associated with the embodiments can be applied to widgets that are not associated with a widget-container.
[1020] Referring now to the drawings, FIG. 1 is a schematic block diagram of a widget- container host 100 configured to control, configure, and/or coordinate the sending of widget- containers and/or components of a widget-container to widget-container processing devices 150 based on control information 130, according to an embodiment of the invention. A widget-container is a procedural software framework that can contain (e.g., include a reference to) one or more components such as a widget and/or a service module.
[1021] The widget-container can be executed on various platforms (e.g., mobile phone, personal computer, personal digital assistant (PDA)) and instances of references to the widget-container can be included in and/or spread to a variety of locations such as content aggregation points (e.g., web sites, WAP site) that can be content aggregation points executed (e.g., read) using the widget-container processing devices 150. The widget- container can be configured to include a portion configured for processing one or more widgets when the widget-container is executed at a widget-container processing device 150. The service module (or reference to the service module) contained in the widget-container can be a pre-defined and/or customizable (e.g., user-defined) function related to a variety of functions (e.g., tracking, placing) related to the widget-container and/or its components (e.g., widget). More details related to widget-container spreading and components are set forth in the above-identified co-pending application entitled, "Method and Apparatus for Widget- Container Hosting and Generation." [1022] The service module and/or widget can be wrapped in the widget-container, for example, at the time that the widget-container is first defined, after the widget-container has been generated before serving, dynamically when the widget-container is being served, and/or after the widget-container has been served. In some embodiments, the widget- container can be produced dynamically and/or statically for storage, for example, using a hardware and/or software generation engine (not shown) that can be included in the widget- container host 100 and/or a widget-container creation device 120. In some embodiments, the widget-container can be dynamically modified using dynamic injection (i.e., injecting data into the widget-container just before/when the widget-container is served). More details related to dynamic widget-container generation are set forth in the above-identified co- pending application entitled, "Method and Apparatus for Widget-Container Hosting and Generation."
[1023] Each of the widget-container processing devices 150 (also can be referred to as a processing device) can be any type of device that is configured to process the widget- container and a widget and/or service module that can be contained in the widget-container. Each of the widget-container processing devices 150 can be, for example, a computer, a mobile phone, a PDA, a server, and/or any other processor-based device. The widget- container can be configured such that the widget-container can be processed by each of these widget-container processing devices 150 even though the platforms (e.g., hardware, architecture, software, operating system, runtime libraries, programming languages) of the respective widget-container processing devices 150 may be different. The network 140 can be any type of network such as a local area network (LAN) and/or a wide area network (WAN) implemented as a wired and/or wireless network with one or more segments in a variety of environments such as, for example, an office complex.
[1024] The widget-container host 100 is configured to use the control information 130 to determine whether or not to allow any portion associated with a widget-container to be sent to and/or processed at one or more of the widget-container processing devices 150. For example, the widget-container host 100 can receive a request for a widget-container from a widget-container processing device 150. Based on a parameter value/identifier included in the request and based on the control information 130, sending a portion associated with a widget-container that is stored at the widget-container host 100 and/or dynamically generated at the widget-container host 100 can be restricted or allowed. In some embodiments, the parameter value/identifier can be retrieved from, for example, a metadata database (not shown) based on a value included in the request. In some embodiments, for example, the widget-container host 100 can be configured to determine whether or not one or more service modules should be contained in a widget-container based on the control information 130.
[1025] The block diagram also illustrates a widget-server 110 in communication with the widget-container processing devices 150 via network 140. Assuming that sending of a widget is permitted, the widget server 110 can be configured to store and send the widget referenced within a widget-container. For example, in response to a request for the widget, if allowed based on the control information 130, the widget server 110 can send (e.g., serve) the widget to one or more of the widget-container processing devices 150. In some embodiments, the request for the widget can be defined based on a reference to a widget being accessed from an instance of the widget-container at a widget-container processing device 150. The widget can then be sent from the widget server 110 to the widget-container processing device 150 and processed within the instance of the widget-container.
[1026] The widget-container host 100 can be configured to control sending and/or processing of any portion (e.g., widget) of a widget-container by modifying the widget- container in a variety of ways. For example, if processing of a widget within an instance of a widget-container is restricted based on the control information 130, a reference to the widget that is normally included in the widget-container can be removed when the instance of the widget-container is generated and/or served (e.g., sent). In other words, the widget-container can be modified such that processing of the widget is prevented. Because the widget server 110, for example, may not have access to the control information 130 and/or may not be configured to process the control information 130, the sending of the widget from the widget server 110 can be controlled by modifying the widget-container associated with the widget.
[1027] In some embodiments, the widget-container host 100 can modify a widget- container such that a reference to a portion that is typically included in the widget-container is not included in the widget-container when the widget-container is generated or can be removed after the widget-container is generated. In some embodiments, the widget-container host 100 can also include a null reference in place of a valid reference to a portion associated with the widget-container (e.g., widget). This can effectively prevent the portion from being sent and/or processed. The widget-container host 100, in some embodiments, can send an indicator to, for example, a widget-container processing device 150 to trigger the widget- container processing device 150 to stop processing a portion associated with a widget- container. In some embodiments, the widget-container host 100 can send an indicator to, for example, the widget server 110 to prevent the widget server 110 from sending (e.g., block streaming) a widget for processing within a widget-container.
[1028] A control determination can be based on parameters and/or identifiers included in a request for a widget-container that can be, for example, extracted from a reference associated with a widget-container as well as based on control information 130 related to the widget-container stored in a memory (e.g., database). For example, an identifier associated with a placement of a widget-container can be received at the widget-container host 100 in a request for the widget-container and used by the widget-container host 100 with reference to the control information 130 to make a control determination. The request can be defined by any of the widget-container processing devices 150. The widget-container 100 can then generate, modify, and/or send the widget-container based on a result of the control determination.
[1029] The control information 130 can be any type of information that can be used to determine whether or not to allow sending and/or processing of portions of a widget- container associated with one or more of the widget-container processing devices 150. For example, the control information 130 can include or be an instruction that specifies whether or not a particular widget, service module, and/or widget-container should be sent to a particular type of widget-container processing device 150. The control information can include information from a whitelist database (e.g., third party whitelist database, widget- container specific whitelist database) or blacklist database (e.g., third party blacklist database, widget-container specific blacklist database) associated with any portion associated with a widget-container.
[1030] The control information 130 can be stored in, for example, the memory 105 of the widget-container host 100 or a separate database (e.g., metadata database) that can be accessed by the widget-container host 100 via a network such as network 140. The control information 130 can be associated with or include metadata parameters and metadata parameter values (e.g., tracking parameter values) associated with a widget-container and/or a component of the widget-container (e.g., widget or service module). The metadata parameters and values can be used to, for example, dynamically customize or track the widget-container and/or the component of the widget-container. The control determination (e.g., restriction determination, allowance determination) can include a restriction or allowance of a customizable feature of any portion associated with the widget-container. For example, a determination can be based on a tracking history of a particular viewer of any portion associated with a widget-container, a location where any portion associated with a widget-container is viewed, a placement history of any portion associated with a widget- container.
[1031] In some embodiments, any portion associated with the widget-container can be stored and retrieved from the memory 105 of the widget-container host. The memory 105 can be, for example, a database included in the widget-container host 100. In some embodiments, any portion associated with the widget-container can be stored in and accessed from a memory device such as a database that is a remote database and/or a distributed database that can be accessed by the widget-container host 100 via network 140 or via a separate network (not shown). In some embodiments, a widget-container served from the widget-container host 100 can contain a reference to one or more service modules that are served from, for example, a service module server (not shown).
[1032] Also, as shown in FIG. 1, a widget-container creation device 120 can be connected to the container host 100 via network 140. The widget-container creation device 120 can be used to generate, define, and/or modify a widget-container. The widget-container creation device 120 can be, for example, a personal computer, a mobile device (e.g., mobile phone and/or PDA), and/or a server (e.g., back-end server, network server). In some embodiments, the widget-container creation device 120 can be configured to automatically produce instructions used to generate and/or modify widgets containers, for example, when a widget is received. In many embodiments, the widget-container creation device 120 can also store widgets and function as a widget server. Each of the widget-container processing devices 150 can also be configured to function as a widget-container creation device 120 and vice versa.
[1033] The widget-container creation device 120 can trigger the generation and/or modification of the widget-container at the widget-container host 100. In some embodiments, the widget-container creation device 120 can send an instruction from, for example, a processor (not shown) to cause the widget-container host 100 to generate and/or modify a widget-container. In some embodiments, widget-container creation device 120 can trigger the generation and/or modification of the widget-container at the widget-container host 100. [1034] Although in this embodiment, the widget-container host 100 is a centralized control/storage mechanism that manages requests received from container processing devices 150 and manages the sending of widgets containers (e.g., prompts a separate device (not shown) to send a widget-container stored in a separate database (not shown)), the functionality of the widget-container host 100 can be decentralized and/or distributed. For example, a hierarchy of widget-container hosts 100 can be arranged, for example, with management components and/or slave components that control, configure, and coordinate the sending of widget-containers to the widget-container processing devices 150.
[1035] FIG. 2 is a schematic diagram illustrating a widget-container 250 associated with a content aggregation point 220 being displayed on a display 242 at a widget-container processing device 240, according to an embodiment of the invention. The widget-container server 270 can be configured to determine whether sending/processing of the widget 260 within the widget-container 250 and/or sending/execution of the widget-container 250 are allowed based on control information 295 stored in a control database 290 (also can be referred to as a restriction database or permission database).
[1036] As shown in FIG. 2, the widget-container 250 is served from the widget-container server 270 to the widget-container processing device 240 in response to a widget-container reference 222 being accessed from the content aggregation point 220. The widget-container reference 222 is defined to trigger sending of the widget-container 250 from the widget- container server 270 for display in the content aggregation point 220, for example, when accessed. In some embodiments, the widget-container 250 can be dynamically generated based on an instruction used to define the widget-container 250 or retrieved (e.g., from a memory (not shown)) before the widget-container 250 is served (e.g., sent) to the widget- container processing device 240. The generating or retrieving of the widget-container 250 can be triggered in response to a request for the widget-container 250.
[1037] After the widget-container 250 has been received at the widget-container processing device 240, a widget 260 is served from a widget-server 280 for processing (e.g., execution) within the widget container 250 in response to a widget reference 252 being accessed from the widget-container 250. The widget 260 is served from the widget server 280 in response to a request for the widget 260 defined based on the widget reference 252. In some embodiments, the widget 260 can be requested, received, and/or processed within the widget-container 250 after the widget-container 250 is received at the content aggregation point 220.
[1038] The content aggregation point 220 can be, for example, a web-page, and the widget-container reference 222 can be, for example, an embed tag included in the content aggregation point 220. In some embodiments, the widget-container 250 is a Flash object and the content aggregation point 220 is a Flash-enabled web browser or Flash-enabled web browser page.
[1039] Although FIG. 2 illustrates a single instance of the widget-container 250/widget 260 being sent to content aggregation point 220, multiple instances of the widget-container 250/widget 260 can be synchronously or asynchronously generated (e.g., dynamically generated) and/or distributed to multiple widget-container processing devices and/or to multiple content aggregation points that each include a reference to the widget-container 250.
[1040] The widget-container server 270 can be configured to determine whether processing of the widget 260 within the widget-container 250 and/or sending/execution of the widget-container 250 are allowed based on control information 295. Although, in this embodiment, the control information 295 is stored in and accessed by the widget-container server 270 from a control database 290, in some embodiments, the control information 295 can be stored in a memory (not shown) of the widget-container server 270 or in a set of distributed memory devices (not shown) such as distributed databases. In some embodiments, the control information 295 can be generated and/or collected by the widget- container server 270 when needed. In some embodiments, the control database 290 can be a third-party database that includes control information 295 such as a white-list or a black-list.
[1041] The control information 295 can be defined by the owner of widget 260 and/or the owner/creator of the widget-container 250. Although the widget 260 and the widget- container 250 can be served from two different devices — the widget server 280 and widget- container server 270, respectively — the owner of each can be the same entity. The owner of the widget 260, for example, can define a control rule or control condition based on content (e.g., images, text) associated with content aggregation point 220 (e.g., web-page, WAP page). The owner of widget 260 may restrict (or allow) processing of widget 260 within the content aggregation point 220 because the content of content aggregation point 220 may be viewed as conflicting or incompatible with the content of widget 260. [1042] In some embodiments, the control information 295 can be based on a content rule associated with a content aggregation point. More details regarding content rules associated with content aggregation points are set forth in co-pending Application Serial No. unassigned, filed on March 6, 2007, and entitled, "Method and Apparatus for Widget- Container Platform Adaptation and Distribution" which is incorporated herein by reference in its entirety.
[1043] The control information 295 can be related to any type of information that can be used to determine whether or not to allow processing of widget 260 within the widget- container 250 and/or whether or not to allow sending of the widget-container 250 to the widget-container processing device 240 for execution within the content aggregation point 220. For example, the control information 295 can be configured such that a control determination (e.g., restriction determination, allowance determination) can be based on an identifier (e.g., uniform resource locator (URL), uniform resource identifier (URI)) associated with the content aggregation point 220 where the widget-container reference 222 is placed. The control information 295 can include, for example, a rule that indicates whether processing of widget 260 in content aggregation point 220 is allowed or restricted.
[1044] In some embodiments, a control determination can be based on a location of the widget-container processing device 240. For example, an indicator (e.g., Internet Protocol (IP) address or portion of an IP address) of the location of the widget-container processing device 240 can be used to determine whether or not to allow sending a portion associated with the widget-container 270 to the widget-container processing device 240.
[1045] In some embodiments, a control determination can be performed in response to the widget-container 250 being placed (e.g., widget-container reference 222 to the widget- container 250 being placed) in content aggregation point 220. The result of the control determination can be stored (e.g., at the widget-container host 100) and associated with a placement identifier uniquely associated with the placement of the widget-container 250 in the content aggregation point 220. If the unique placement identifier is received in a request for an instance of the widget-container 250, the result of the control determination can be immediately implemented without performing the control determination a second time. If the widget-container reference 222 is uniquely associated with the placement of the widget- container 250 in the content aggregation point 220, the widget-container reference 222 can be used as the trigger for implementing the stored control determination result. [1046] Although not illustrated in this embodiment to simplify the discussion, the widget-container 250 can also contain a service module integrated into the widget-container 250 (e.g., integrated during dynamic generation) or served from, for example, a service module server (not shown). A control determination can also be based on or related to the service module. The service module can be a pre-defined function associated with the widget 260. For example, a service module can be a metadata searching/retrieval function, a polling/categorizing function, a widget-container deployment function (e.g., using a placement service module), a transaction service function (e.g., service module for facilitating a web purchase, service module used for signing a user up for a web service, etc.), a security function (e.g., security firewall function), and/or a widget-container tracking function.
[1047] The widget 260 can be, for example, a static data object, a software object, and/or a media object. Within each of these categories, the widget can be a specific content type. For example, the widget 260 can be an processed (e.g., played) or a displayed media object such as a video file (i.e., a video content file), an mp3 file (i.e., audio content file), or an image file (i.e., image content file). The widget 260 can be a static data object that is, for example, displayed within the widget-container 250. The static data object can be, for example, a textual object such as a set of letters, a textual document, or an html based textual document. The static data object can include, for example, links to other widgets (not shown). The widget 260 can also be a software object such as an executable application or set of instructions that is executed within the procedural software framework of the widget- container 250. The results of the executable application can be included and/or displayed within the procedural software framework of the widget-container 250. The widget- container 250 can be configured so that the widget 260 can be processed within a portion of the widget-container 250 when the widget-container 250 is displayed on the display 242.
[1048] The procedural software framework that makes up the widget-container 250 can be programmed in any number of programming languages that are compiled (e.g., C++) and/or in programming languages that are interpreted (e.g., Java). An executable portion (of the procedural software framework) that manages and controls service module(s) (not shown) and/or the widget 260 referenced (e.g., contained) in the widget-container 250 can be referred to as the core of the widget-container 250. Metadata parameter values can be passed to the widget-container 250 and used by, for example, the core of the widget-container 250 to modify, for example, attributes of the widget-container 250 and/or widget 260 (e.g., x, y location of the widget 260, size of the widget 260, color, themes, styles, etc.).
[1049] FIG. 3 is a table 300 that illustrates a set of control rules (e.g., restriction information) that are based on content aggregation point identifiers 340, according to an embodiment of the invention. The table 300 illustrates that execution of widget-container A (column 310) is allowed in content aggregation points with identifiers URIl and URI2. Based on an indicator of the content aggregation point identifier 340 received in, for example, a request for widget-container A, table 300 can be used in a control determination to determine that processing of widget W is restricted in content aggregation point URI2, but allowed in content aggregation point URIl .
[1050] The identifier of the content aggregation point 340 can be received at, for example, a widget-container host for use in a control determination at the widget-container host. A request for the widget-container 310, for example, can include the identifier of the content aggregation point 340 or a separate identifier such as a placement identifier 330 that can be used to look-up the identifier of the content aggregation point 340. In some embodiments, the identifier of the content aggregation point 340 can be retrieved from a metadata database (not shown) that can be used to associate a widget-container reference with the identifier of the content aggregation point 340.
[1051] Although, a control determination can be based on one or more content aggregation point identifiers 340, in some embodiments, a control determination can be performed based on a variety of parameters that can be, for example, stored in a metadata parameter database. For example, a control determination can be based on parentage information in a metadata database (not shown) or a placement identifier 330 associated with a particular placement of a reference to a widget container 310 in a content aggregation point 345 associated with the content aggregation point identifiers 340.
[1052] For example, in some embodiments, the placement identifier 330 is included in a reference to a widget-container 310 placed in a content aggregation point 345 and can be used in a control determination. When a reference to widget-container A is accessed from a content aggregation point 345, a request for widget-container A can be defined to indicate the placement identifier 330 uniquely associated with the particular placement of widget- container A and included in the reference. If the widget-container A being requested is the widget-container placed in the content aggregation point X, the request can include the placement identifier Pl from the reference. The placement identifier Pl can then be used to determine based on table 300 that both widget processing and widget-container execution are permitted.
[1053] In some embodiments, the control information in table 300 can be used in conjunction with a default rule that processing of a widget and/or sending/execution of a widget-container is restricted unless allowed. In this situation, the determination can be referred to as an allowance determination. Conversely, a set of control rules can be defined such that processing of a widget and/or sending/execution of a widget-container is allowed unless restricted based on a control rule in a control database. In this situation, the determination can be referred to as a restriction determination.
[1054] Referring back to FIG. 2, widget-container 250 can also include a tracking kernel (not shown) configured to perform a tracking function. The tracking kernel, which can also be referred to as a tracking module, can be embedded/integrated in (e.g., programmed within) the procedural software framework of the widget-container. The tracking kernel, in some embodiments, may not be displayed on the display 242. The tracking kernel can be used to collect tracking parameter values related to user-triggered interactions with the widget- container 250 such as basic mouse movement and clock events.
[1055] The tracking kernel can also be used to collect tracking parameter values related to placement information such as, for example, what web-page (e.g., content aggregation point 220) a widget-container is referenced on and/or placed on, where on the page it was placed, and/or size of the widget-container 250 (e.g., dimensional and memory). This information can be used in a control determination. For example, a tracking parameter value(s) can be used to determine whether a reference to a widget-container will trigger a portion associated with the widget-container to be processed in a portion of a web-page, such as processor readable vehicle 220, that is not allowed based on the control information 295. The tracking parameter value can be used to determine whether the widget-container should be processed on the web-page at all based on the control information 295. Certain user- triggered interactions based on a tracking parameter value can also trigger restriction (or allowance) of a portion associated with a widget-container from being processed and/or executed. [1056] In some embodiments, a control rule can be a complex set of rules based on one or more variables and/or an algorithm. For example, a control rule can be based on portions of multiple widget-containers placed within a particular content aggregation point that are defined as mutually exclusive portions of widget-containers (e.g., should not be displayed on the same content aggregation point, should not be displayed on a specified content aggregation point). In some embodiments, a control determination based on a complex set of rules can be performed based on tracking parameter values (e.g., parentage information) collected and/or stored in, for example, a metadata database (not shown) or the control database 290.
[1057] In some embodiments, a notification can be sent to an entity associated with a component of the widget-container 250 that indicates that processing of a particular component of the widget-container 250 such as the widget 260 has been terminated. The notification can be generated and sent by, for example, the widget-container server 270. The notification can include statistical data that indicates, for example, one or more content aggregation points, locations, and/or processing devices where the processing of the widget 260 has been terminated or permitted. The statistical data can be based on tracking parameter values and/or parentage information associated with the widget 260 of the widget- container. For example, control results for a portion associated with a widget-container with a particular genealogical lineage can be compiled and sent in a notification. In some embodiments, statistical data based on control information can be stored in, for example, the control database 290 where the statistical data can be retrieved. In some embodiments, historical termination data can be used to update, for example, control information 295 in the control database 290.
[1058] FIG. 4 illustrates a set of category-based control tables 400 and 490 that can be used in a control determination, according to an embodiment of the invention. Table 400 illustrates that each widget 420 of the widget-containers 410 has been associated with a control category 450 and a control indicator 440. Table 400 is a set of rules that indicates whether widget 420 should be processed within a content aggregation point that has been classified as a certain control category 430. For example, table 400 illustrates widget W can be processed in a content aggregation point with a control category 430 of A, but not a control category 430 of B. In some embodiments, table 400 can also be used as a set of rules to determine whether or not widget-containers 410 or service modules (not shown) should be sent to or processed within a content aggregation point that has been classified as a certain control category 430.
[1059] Table 490 illustrates a set of control categories 450 associated with content aggregation points identifiers 460. The control categories 450 can be determined based on, for example, an assessment (e.g., content scan) of each of the content aggregation points where a widget-container 410 has been placed. In some embodiments, a regular (e.g., nightly) or random assessment of content of content aggregation points, for example, can be used to update table 490. An assessment of content can be based on, for example, a scanned image of a content aggregation point. The assessment of the content of a content aggregation point can be used to update control information associated with any portion associated with a widget-container. In some embodiments, content associated with a particular content aggregation point can be assessed in response to a widget-container reference associated with a widget-container being placed in the particular content aggregation point. In other words, placement of a widget-container (e.g., placement of a reference to a widget container) in a content aggregation point can trigger updating of table 490.
[1060] If table 400 is a table stored at, for example, a widget-container server and table 490 is a table stored at a control database, the widget-container server can make a control determination by cross-referencing the control information in table 400 with the control information in table 490 accessed from the control database. The widget-container server can cross-reference the information based on a determination of, for example, a content aggregation point identifier where any of the widget-containers 410 have been placed. For example, if widget-container M has been placed in content aggregation point URI3, a widget- container server can determine using tables 400 and 490 that widget W can be processed within widget-container M at URI3 because content category A is not restricted.
[1061] Default rules can be used in conjunction with tables 400 and 490. For example, if widget-container P were placed in URI3, a default rule may prevent processing of widget Q within the widget-container P at URI3 because an existing rule in table 400 does not cover that situation. Although the tables 400 and 490 were illustrated as two separate blocks of information, in some embodiments, the tables 400 and 490 can be combined or portions of either of the tables 400 and/or 490 included as separate blocks of information in, for example, separate databases. [1062] In some embodiments, control categories can be, for example, location-related control categories. For example, a portion associated with a widget-container may be permitted to be processed (or prevented from processing) in only certain locations based on a control category within a control rule. The location control can be defined based on, for example, an Internet Protocol (IP) address associated with a request for the widget-container.
[1063] Referring back to FIG. 2, the widget-container server 270 can be configured to make a control determination with respect to the widget 260 and/or widget-container 250 after the widget-container 250 is served (e.g., sent). For example, when the widget-container server 270 determines, after the widget-container 250 has been sent to the widget-container processing device 240, that sending/execution of the widget-container 250 and/or processing of the widget 260 is restricted (or allowed), the widget-container server 270 can send an indicator to the widget-container processing device 240 to stop (or start/continue/allow) execution of the widget-container 250 within the content aggregation point 220 or processing of the widget 260 within the widget-container 250. The widget-container server 270 can passively permit processing if processing of the widget 260 within the widget-container 250 has already commenced and is allowed.
[1064] FIG. 5 is a flowchart that illustrates a control determination performed after a widget-container has been sent to a widget-container processing device, according to an embodiment of the invention. The flowchart illustrates that a widget-container is produced (e.g., generated) with a valid reference to a component of the widget-container 500. The valid reference can be a reference to a component of the widget-container such as a widget and/or a reference to a service module associated with the widget. The widget-container can be produced in response to a request for the widget-container defined in response to a reference to the widget-container being accessed from a content aggregation point (e.g., web- page, WAP page) executed/displayed at the widget-container processing device. The widget- container produced at 500 can be an instance that is, for example, generated dynamically with customized features for the content aggregation point based on a metadata parameter value. After the widget-container has been produced, the widget-container is sent to the widget-container processing device such as a cell phone at 510.
[1065] After the widget-container has been sent, a control determination (e.g., restriction determination, allowance determination) is performed at 520 to determine whether processing/execution of the component of the widget-container is restricted or allowed. The control determination can be based on control information that is retrieved from a memory such as a control database. The control determination can be based on, for example, an identifier associated with the content aggregation point where the widget-container is to be executed and/or displayed. The control determination can be based on the content of the content aggregation point or the physical location where the content aggregation point is being accessed. The control determination can also be performed based on a credential or location identifier associated with an entity that is requesting the widget-container.
[1066] In response to a control determination being made at 520, an indicator to terminate processing/execution of the component of the widget-container at the widget- container processing device is sent at 530. The indicator can be sent to, for example, a widget server to cause the widget server to stop streaming a video widget that is being processed within the widget-container. The indicator can be sent directly to the widget- container processing device and can be configured to cause the widget-container processing device to stop processing/executing the component of the widget-container.
[1067] At 540, a notification to an entity associated with the component of the widget- container that processing/execution of that component has been terminated. The notification can include statistical data that indicates, for example, other content aggregation points, locations, and/or processing devices where the processing/execution of the component has been terminated. The statistical data can be based on tracking and/or parentage information associated with any portion associated with the widget-container. In some embodiments, historical termination data can be used to update, for example, a control database.
[1068] Although the flowchart shown in FIG. 5 is directed towards components of widget-containers, in some embodiments, the flowchart can be modified to apply to any portion associated with the widget-container including the entire widget-container itself. In some embodiments, the flowchart can be modified such that the blocks are in any order. For example, a notification can be sent to an entity before an indicator to cause termination is generated and/or sent.
[1069] Referring back to FIG. 2, the widget-container server 270 can be configured to make a control determination with respect to the widget 260 and/or widget-container 250 before the widget-container 250 is served (e.g., sent). For example, when the widget- container server 270 determines that sending of the widget-container 250 is restricted (or allowed) before the widget-container 250 has been sent, the widget-container server 270 can be configured to deny (or grant) a request for the widget-container 250 and/or can halt (or continue) processing with respect to the widget-container 250.
[1070] If the widget-container server 270 determines, before the widget-container 250 has been sent, that processing of the widget 260 is restricted, the widget-container server 270 can still send the widget-container 270. However, the widget-container 270 can be modified, for example, by removing the widget reference 252, including a null (e.g., empty) reference (not shown), and/or a re-directing reference (e.g., to a notice that the widget 260 will not be processed) to prevent a valid request for the widget 260 from being defined and sent to the widget server 280. These techniques will effectively prevent the widget 260 from being sent to and processed in the widget-container 250 at the widget-container processing device 240.
[1071] In contrast, if the widget-container server 270 determines that processing of the widget 260 within the widget-container 250 is allowed before the widget-container 250 has been sent, the widget-container server 270 can send the widget-container 250 with a widget reference 252 that is valid. The valid widget reference 252 or null widget reference 252 can be dynamically injected into the widget-container 250 when the widget-container 250 is generated, for example, based on an instruction in response to a request for the widget- container 250. Likewise, a valid widget reference 252 can be removed from the widget- container 250 when the widget-container 250 is dynamically generated.
[1072] Whether a control determination is made before or after the widget-container 250 is served, the widget-container server 270 can send an indicator to the widget server 280 to cause the widget server 280 to prevent sending or halt (e.g., block) sending, if necessary, of the widget 260 to the widget-container processing device 240. The widget-container server 270 can cause the widget server 280 to halt sending if sending and/or processing of the widget 260 within the widget-container 250 has already commenced.
[1073] In some embodiments, the widget-container processing device 240 and/or widget- container 250 can be configured to wait for an indicator from the widget-container server 270 before processing the widget 260. Likewise, in some embodiments, the widget server 260 can be configured to wait for an indicator from the widget-container server 270 before sending the widget 260 for processing within the widget-container 250. In other words, the default mode of the widget-container processing device 240, widget server 260, and/or widget-container 250 can be to process and/or send the widget 260 when triggered by the widget-container server 270.
[1074] FIG. 6 is a flowchart that illustrates a method for restricting or allowing processing of a component associated with a widget-container before sending the widget- container for display in a content aggregation point, according to an embodiment of the invention. The flowchart illustrates that an instruction defining a widget-container associated with a widget is received at 600. The instruction can be used to dynamically produce the widget-container when a request for the widget-container is received.
[1075] A reference uniquely defined to trigger sending of an instance of the widget- container for execution within a content aggregation point is received at 610. In some embodiments, the reference can be received and stored in a database and associated with customizable parameter values (e.g., metadata parameter values) associated with the placement of the reference to the widget-container in the content aggregation point so that the customizable parameters values can be used when producing the widget-container for sending to the content aggregation point.
[1076] An indicator that the reference to the widget-container has been accessed at the content aggregation point is received at 620, an identifier associated with the content aggregation point is received at 630 in response to the reference being accessed, and a control determination is performed at 640 to determine whether processing of any component (include the widget referenced above) of the widget-container is restricted or allowed. For example, the control determination can be based on control information that is retrieved from a memory such as a control database. The control determination can be based on, for example, an identifier associated with the content aggregation point where the widget- container is to be executed and/or displayed.
[1077] If the processing of the component of the widget-container is allowed, an instance of the widget-container is produced with a valid reference to the component of the widget- container at 650 based on the instruction. In other words, the widget-container is produced without modifying the instruction or the widget-container with respect to the reference to the component. The instance of the widget-container with the valid reference is then sent to the widget-container processing device that requested the widget-container at 670. In some embodiments, if the widget-container is a static object stored in a memory (e.g., not dynamically generated based on the instruction), the widget-container can be retrieved from the memory and sent to the widget-container processing device. In other words, the widget- container will not be modified.
[1078] If the processing of a component of the widget-container is restricted, the widget- container can be modified and/or produced at 660 based on the control determination. The widget-container can be produced based on the instruction with some modification to address the control determination. For example, the widget-container can be produced with a null reference to the component of the widget-container (or a re-directing reference) such that the component of the widget-container is not requested from, for example, a server of the component when the widget-container is executed a widget-container processing device. The modified instance of the widget-container is then sent to the widget-container processing device that requested the widget-container at 670.
[1079] In some embodiments, if the widget-container is a static object stored in a memory (e.g., not dynamically generated based on the instruction), the widget-container can be retrieved from the memory and modified to, for example, remove the reference to the component before the widget-container is sent to the widget-container processing device.
[1080] Some embodiments of the invention relate to a storage product with a processor- readable medium having instructions or code thereon for performing various processor- implemented operations. The media and code may be those specially designed and constructed for the purposes of the invention, or they may be of the kind well known and available to those having skill in the software arts. Examples of processor-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs ("CD/DVDs"), Compact Disc-Read Only Memories ("CD-ROMs"), and holographic devices; magneto-optical storage media such as floppy or optical disks; carrier wave signals; and hardware devices that are specially configured to store and execute program code, such as Application-Specific Integrated Circuits ("ASICs"), Programmable Logic Devices ("PLDs"), and ROM and RAM devices. Examples of code include, but are not limited to, micro-code or micro-instructions, machine instructions, such as produced by a compiler, and files containing higher-level instructions that are executed by a processor using an interpreter. For example, an embodiment of the invention may be implemented using Java, C++, or other object-oriented programming language and development tools. Additional examples of code include, but are not limited to, control signals, encrypted code, and compressed code.
[1081] In conclusion, the present invention is related to an apparatus and methods for controlling processing of and/or distribution of static, media, and/or software objects in a procedural software framework. Those skilled in the art can readily recognize that numerous variations and substitutions may be made in the invention, its use and its configuration to achieve substantially the same results as achieved by the embodiments described herein. Many variations, modifications and alternative constructions fall within the scope and spirit of the disclosed invention as expressed in the claims.

Claims

What is claimed is:
1. A method, comprising: receiving an instruction used to define a widget-container containing a service module associated with a widget, the widget-container being a procedural software framework configured to be executed at a widget-container processing device in response to a reference to the widget-container being accessed from a content aggregation point, the widget-container having a portion configured for receiving the widget; and determining whether processing of the widget within the portion of the widget- container is at least one of restricted or allowed.
2. The method of claim 1, further comprising: producing the widget-container based on the instruction, the producing includes incorporating a valid reference to the widget in the widget-container in response to the processing of the widget being allowed; and sending the widget-container to the widget-container processing device in response to the reference to the widget-container being accessed.
3. The method of claim 2, wherein the producing is performed at a first device, the widget-container processing device is configured to receive the widget from a second device when processing the widget within the widget-container.
4. The method of claim 1, wherein the service module is a pre-defined function associated with the widget-container, the widget is at least one of a static data object, a media object, or a software object.
5. The method of claim 1 , further comprising: producing the widget-container based on the instruction, the producing includes incorporating at a first time a reference to the widget in the widget-container; sending at a second time the widget-container to a widget-container processing device in response to the reference to the widget-container being accessed, the second time being after the first time, the determining includes determining at a third time that processing of the widget is at least one of restricted or allowed, the third time being after the second time; and sending, in response to the determining, to the widget-container processing device an indicator configured to stop processing of the widget within the widget-container.
6. The method of claim 5, wherein the determining includes determining before the reference is accessed.
7. The method of claim 1, wherein the content aggregation point is a first content aggregation point, the reference is a first reference derived from a second reference to the widget-container included in a second content aggregation point, the determining includes determining after the first reference is included in the first content aggregation point.
8. The method of claim 1, wherein the determining includes determining based on an identifier associated with the content aggregation point in response to the reference being placed in the processor readable vehicle.
9. The method of claim 1, further comprising: modifying the widget-container in response to the processing of the widget being at least one of restricted or allowed.
10. The method of claim 1, wherein the determining includes determining based on at least one of a geographic location associated with the widget-container processing device, a stored image of the content aggregation point, content included in the content aggregation point, or a preference from a control database.
11. A processor-readable medium comprising code representing instructions to cause a processor to: receive a first reference to a widget-container placed in a first content aggregation point, the first reference being derived from a second reference to the widget-container placed in a second content aggregation point, the widget-container being a procedural software framework configured to be executed at a widget-container processing device in response to the first reference to the widget-container being accessed at the widget-container processor device, the widget-container having a portion configured for receiving a component; and determine whether processing of the component within the widget-container is at least one of restricted or allowed in response to the first reference to the widget-container being accessed.
12. The processor-readable medium of claim 11 , wherein the first reference is uniquely defined to trigger sending of the widget-container for execution within a location of the first content aggregation point.
13. The processor-readable medium of claim 11, further comprising instructions to cause a processor to: retrieve an identifier associated with the content aggregation point in response to the first reference being accessed at the widget-container processing device, the code to determine including code to determine based on the identifier.
14. The processor-readable medium of claim 11, further comprising instructions to cause a processor to: generate the widget-container based on an instruction defining the widget-container in response to the first reference being accessed; incorporate at a first time a valid reference to the component in the widget-container in response to an indicator that processing of the component is allowed; and trigger at a second time sending the widget-container to the widget-container processing device, the second time being after the first time.
15. The processor-readable medium of claim 11 , wherein the determine includes code to determine based on an identifier associated with the first content aggregation point in response to the first reference being placed in the first processor readable vehicle.
16. The processor-readable medium of claim 11, further comprising instructions to cause a processor to: trigger sending a notification to an entity associated with the component, the notification including an indicator of whether processing of the component is at least one of restricted or allowed.
17. A method, comprising : receiving a request for a widget-container from a widget-container processing device in response to a reference to the widget-container being accessed from a content aggregation point at the widget-container processing device; determining in response to the request whether processing of a portion associated with the widget-container is allowed based on a preference associated with the portion associated with the widget-container and an identifier associated with the content aggregation point; and sending in response to the request the widget-container to the widget-container processing device.
18. The method of claim 17, wherein the sending includes sending after the determining.
19. The method of claim 17, wherein the determining includes determining after the sending.
20. The method of claim 17, wherein the widget-container is a procedural software framework configured to be executed at the widget-container processing device, the method further comprising: modifying the procedural software framework of the widget-container before the sending and in response to the determining.
21. The method of claim 17, wherein the preference is associated at a first time with the portion associated with the widget-container, the reference to the widget-container is associated with the content aggregation point at a second time, the second time being after the first time, the determining includes determining after the second time.
22. The method of claim 17, wherein the reference is uniquely defined to trigger sending of the widget-container for execution within a location of the first content aggregation point, the reference is from a plurality of references to the widget-container, each reference from the plurality of references is derived from a separate reference from the plurality of references.
PCT/US2008/055756 2007-03-06 2008-03-04 Method and apparatus for widget and widget-container distribution control based on content rules WO2008109581A1 (en)

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/682,639 US9009728B2 (en) 2007-03-06 2007-03-06 Method and apparatus for widget and widget-container distribution control based on content rules
US11/682,639 2007-03-06

Publications (1)

Publication Number Publication Date
WO2008109581A1 true WO2008109581A1 (en) 2008-09-12

Family

ID=39738745

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2008/055756 WO2008109581A1 (en) 2007-03-06 2008-03-04 Method and apparatus for widget and widget-container distribution control based on content rules

Country Status (2)

Country Link
US (2) US9009728B2 (en)
WO (1) WO2008109581A1 (en)

Families Citing this family (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8869066B2 (en) 2006-07-06 2014-10-21 Addthis, Llc Generic content collection systems
US8266274B2 (en) 2007-03-06 2012-09-11 Clearspring Technologies, Inc. Method and apparatus for data processing
US9009728B2 (en) 2007-03-06 2015-04-14 Addthis, Inc. Method and apparatus for widget and widget-container distribution control based on content rules
US20080229280A1 (en) * 2007-03-12 2008-09-18 Sap Ag Systems and methods for composing custom applications from software components
US7702754B2 (en) * 2007-05-23 2010-04-20 Sap Ag Enhanced widget architecture
US8209378B2 (en) 2007-10-04 2012-06-26 Clearspring Technologies, Inc. Methods and apparatus for widget sharing between content aggregation points
JP5147352B2 (en) * 2007-10-16 2013-02-20 株式会社日立製作所 Information providing method for data processing apparatus
US9600261B2 (en) * 2008-03-25 2017-03-21 Qualcomm Incorporated Apparatus and methods for widget update scheduling
US9269059B2 (en) * 2008-03-25 2016-02-23 Qualcomm Incorporated Apparatus and methods for transport optimization for widget content delivery
US9110685B2 (en) * 2008-03-25 2015-08-18 Qualcomm, Incorporated Apparatus and methods for managing widgets in a wireless communication environment
US9069575B2 (en) * 2008-03-25 2015-06-30 Qualcomm Incorporated Apparatus and methods for widget-related memory management
US9747141B2 (en) 2008-03-25 2017-08-29 Qualcomm Incorporated Apparatus and methods for widget intercommunication in a wireless communication environment
US9063740B2 (en) * 2008-09-16 2015-06-23 Oracle International Corporation Web widget component for a rapid application development tool
US8769490B2 (en) * 2008-09-16 2014-07-01 Oracle International Corporation Desktop widget engine emulator component for a rapid application development tool
US8719896B2 (en) * 2008-09-16 2014-05-06 Oracle International Corporation Widget host container component for a rapid application development tool
JP5355695B2 (en) * 2008-09-18 2013-11-27 テレフオンアクチーボラゲット エル エム エリクソン(パブル) Technology for content management using group permissions
TW201013566A (en) * 2008-09-25 2010-04-01 Zhu yu hua Business model of multi-level application tool set and the system thereof
US8266695B1 (en) * 2009-10-12 2012-09-11 Google Inc. Gadget container verification
US10713018B2 (en) * 2009-12-07 2020-07-14 International Business Machines Corporation Interactive video player component for mashup interfaces
TWI459314B (en) * 2011-11-22 2014-11-01 Univ Nat Chiao Tung A structure and method for widget personalization and inter-widgets communication
US9940014B2 (en) * 2013-05-03 2018-04-10 Adobe Systems Incorporated Context visual organizer for multi-screen display
US20160041698A1 (en) * 2014-08-05 2016-02-11 Vladimlr Tkach Enhanced Object Organization in a Container
US9733916B2 (en) 2015-11-23 2017-08-15 Business Objects Software Limited Linking customized external widgets to dashboard data

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040107125A1 (en) * 1999-05-27 2004-06-03 Accenture Llp Business alliance identification in a web architecture
US20060178918A1 (en) * 1999-11-22 2006-08-10 Accenture Llp Technology sharing during demand and supply planning in a network-based supply chain environment

Family Cites Families (186)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0718759A3 (en) * 1988-04-15 1997-05-02 Digital Equipment Corp System for managing hierarchical information in a digital data processing system
US5261002A (en) 1992-03-13 1993-11-09 Digital Equipment Corporation Method of issuance and revocation of certificates of authenticity used in public key networks and other systems
US5896532A (en) * 1992-06-15 1999-04-20 Lucent Technologies Inc. Objects with run-time classes and methods of making them
US5862377A (en) * 1994-05-26 1999-01-19 Bay Networks Groups, Inc. Technique for sharing information between applications
US5694546A (en) 1994-05-31 1997-12-02 Reisman; Richard R. System for automatic unattended electronic information transport between a server and a client by a vendor provided transport software with a manifest list
JPH08263438A (en) * 1994-11-23 1996-10-11 Xerox Corp Distribution and use control system of digital work and access control method to digital work
US7143290B1 (en) * 1995-02-13 2006-11-28 Intertrust Technologies Corporation Trusted and secure techniques, systems and methods for item delivery and execution
US5892900A (en) * 1996-08-30 1999-04-06 Intertrust Technologies Corp. Systems and methods for secure transaction management and electronic rights protection
US6658568B1 (en) 1995-02-13 2003-12-02 Intertrust Technologies Corporation Trusted infrastructure support system, methods and techniques for secure electronic commerce transaction and rights management
US7133846B1 (en) 1995-02-13 2006-11-07 Intertrust Technologies Corp. Digital certificate support system, methods and techniques for secure electronic commerce transaction and rights management
US5857102A (en) * 1995-03-14 1999-01-05 Sun Microsystems, Inc. System and method for determining and manipulating configuration information of servers in a distributed object environment
WO1996034350A1 (en) * 1995-04-24 1996-10-31 Aspect Development, Inc. Modeling of object-oriented database structures, translation to relational database structures, and dynamic searches thereon
US5781189A (en) 1995-05-05 1998-07-14 Apple Computer, Inc. Embedding internet browser/buttons within components of a network component system
US5675510A (en) 1995-06-07 1997-10-07 Pc Meter L.P. Computer use meter and analyzer
US7159116B2 (en) * 1999-12-07 2007-01-02 Blue Spike, Inc. Systems, methods and devices for trusted transactions
US6108637A (en) * 1996-09-03 2000-08-22 Nielsen Media Research, Inc. Content display monitor
US5948061A (en) 1996-10-29 1999-09-07 Double Click, Inc. Method of delivery, targeting, and measuring advertising over networks
US6233601B1 (en) 1996-11-14 2001-05-15 Mitsubishi Electric Research Laboratories, Inc. Itinerary based agent mobility including mobility of executable code
US6112238A (en) * 1997-02-14 2000-08-29 Webtrends Corporation System and method for analyzing remote traffic data in a distributed computing environment
US7062500B1 (en) * 1997-02-25 2006-06-13 Intertrust Technologies Corp. Techniques for defining, using and manipulating rights management data structures
US6233684B1 (en) * 1997-02-28 2001-05-15 Contenaguard Holdings, Inc. System for controlling the distribution and use of rendered digital works through watermaking
US5796952A (en) * 1997-03-21 1998-08-18 Dot Com Development, Inc. Method and apparatus for tracking client interaction with a network resource and creating client profiles and resource database
AU8072798A (en) 1997-06-16 1999-01-04 Doubleclick Inc. Method and apparatus for automatic placement of advertising
US5951643A (en) 1997-10-06 1999-09-14 Ncr Corporation Mechanism for dependably organizing and managing information for web synchronization and tracking among multiple browsers
US6100890A (en) * 1997-11-25 2000-08-08 International Business Machines Corporation Automatic bookmarks
US6064980A (en) * 1998-03-17 2000-05-16 Amazon.Com, Inc. System and methods for collaborative recommendations
US7035943B2 (en) 1998-05-29 2006-04-25 Yahoo! Inc. Web server content replication
US6314448B1 (en) 1998-06-04 2001-11-06 International Business Machines Corporation Method and system for inter-applet communication in a computer network
WO2000008802A2 (en) 1998-08-03 2000-02-17 Doubleclick Inc. Network for distribution of re-targeted advertising
US6317787B1 (en) 1998-08-11 2001-11-13 Webtrends Corporation System and method for analyzing web-server log files
US6266649B1 (en) * 1998-09-18 2001-07-24 Amazon.Com, Inc. Collaborative recommendations using item-to-item similarity mappings
EP0996058A1 (en) 1998-10-19 2000-04-26 International Business Machines Corporation Improved presentation scheme for communication between user stations and application programs
US7107548B2 (en) * 1998-10-28 2006-09-12 Yahoo! Inc. Method of controlling an internet browser interface and a controllable browser interface
US6466974B1 (en) 1998-12-04 2002-10-15 Sun Microsystems, Inc. Environment for creating and managing network management software objects
US6857124B1 (en) 1999-01-11 2005-02-15 Eolas Technologies, Inc. Method and system for hypermedia browser API simulation to enable use of browser plug-ins and applets as embedded widgets in script-language-based interactive programs
US6772180B1 (en) * 1999-01-22 2004-08-03 International Business Machines Corporation Data representation schema translation through shared examples
US6925442B1 (en) 1999-01-29 2005-08-02 Elijahu Shapira Method and apparatus for evaluating vistors to a web server
JP2000330858A (en) 1999-05-25 2000-11-30 Fujitsu Ltd Image processor and program storage medium
US6269361B1 (en) * 1999-05-28 2001-07-31 Goto.Com System and method for influencing a position on a search result list generated by a computer network search engine
US6584505B1 (en) * 1999-07-08 2003-06-24 Microsoft Corporation Authenticating access to a network server without communicating login information through the network server
US6636242B2 (en) * 1999-08-31 2003-10-21 Accenture Llp View configurer in a presentation services patterns environment
US6748555B1 (en) 1999-09-09 2004-06-08 Microsoft Corporation Object-based software management
US6546393B1 (en) * 1999-10-07 2003-04-08 Clickmarks, Inc. System method and article of manufacture for dynamically user-generated internet search directory based on prioritized server-sided user bookmarks
US7031932B1 (en) 1999-11-22 2006-04-18 Aquantive, Inc. Dynamically optimizing the presentation of advertising messages
WO2001067309A2 (en) * 2000-03-03 2001-09-13 Radiant Logic, Inc. System and method for providing access to databases via directories and other hierarchical structures and interfaces
US6311194B1 (en) 2000-03-15 2001-10-30 Taalee, Inc. System and method for creating a semantic web and its applications in browsing, searching, profiling, personalization and advertising
US6748447B1 (en) 2000-04-07 2004-06-08 Network Appliance, Inc. Method and apparatus for scalable distribution of information in a distributed network
US7472157B2 (en) * 2000-05-08 2008-12-30 H.E.B., Llc Architecture for a system of portable information agents
US6769010B1 (en) * 2000-05-11 2004-07-27 Howzone.Com Inc. Apparatus for distributing information over a network-based environment, method of distributing information to users, and method for associating content objects with a database wherein the content objects are accessible over a network communication medium by a user
US7062561B1 (en) 2000-05-23 2006-06-13 Richard Reisman Method and apparatus for utilizing the social usage learned from multi-user feedback to improve resource identity signifier mapping
US6701521B1 (en) 2000-05-25 2004-03-02 Palm Source, Inc. Modular configuration and distribution of applications customized for a requestor device
US6970853B2 (en) 2000-06-06 2005-11-29 Citibank, N.A. Method and system for strong, convenient authentication of a web user
US6931550B2 (en) 2000-06-09 2005-08-16 Aramira Corporation Mobile application security system and method
CN1300677C (en) 2000-06-22 2007-02-14 微软公司 Distributed computing services platform
US7076521B2 (en) 2000-06-26 2006-07-11 Vertical Computer Systems, Inc. Web-based collaborative data collection system
IL137106A0 (en) 2000-06-29 2001-06-14 Ilissos Inc A method and system for generating bursting-messages
US7099926B1 (en) 2000-07-06 2006-08-29 International Business Machines Corporation Object caching and update queuing technique to improve performance and resource utilization
US6665867B1 (en) 2000-07-06 2003-12-16 International Business Machines Corporation Self-propagating software objects and applications
AU7593601A (en) * 2000-07-14 2002-01-30 Atabok Inc Controlling and managing digital assets
US7117250B1 (en) 2000-08-01 2006-10-03 Enreach Technology, Inc. Method and system for providing a dynamic media distribution infrastructure
US7062540B2 (en) 2000-08-15 2006-06-13 I2 Technologies Us, Inc. System and method for remotely monitoring and managing applications across multiple domains
US7054900B1 (en) * 2000-08-18 2006-05-30 Netzero, Inc. Automatic, profile-free web page recommendation
US7225246B2 (en) * 2000-08-21 2007-05-29 Webtrends, Inc. Data tracking using IP address filtering over a wide area network
US8225414B2 (en) 2000-08-28 2012-07-17 Contentguard Holdings, Inc. Method and apparatus for identifying installed software and regulating access to content
US6751721B1 (en) * 2000-08-31 2004-06-15 Hewlett-Packard Development Company, L.P. Broadcast invalidate scheme
US6985929B1 (en) * 2000-08-31 2006-01-10 The United States Of America As Represented By The Secretary Of The Navy Distributed object-oriented geospatial information distribution system and method thereof
WO2002021404A1 (en) 2000-09-06 2002-03-14 Envoii Method and apparatus for a portable information account access agent
US8117281B2 (en) 2006-11-02 2012-02-14 Addnclick, Inc. Using internet content as a means to establish live social networks by linking internet users to each other who are simultaneously engaged in the same and/or similar content
US20020083188A1 (en) * 2000-11-02 2002-06-27 Webtrends Corporation Method for determining web page loading and viewing times
US7080159B2 (en) 2000-12-15 2006-07-18 Ntt Docomo, Inc. Method and system for effecting migration of application among heterogeneous devices
US20020082914A1 (en) 2000-12-26 2002-06-27 Gil Beyda Hybrid network based advertising system and method
US7089237B2 (en) 2001-01-26 2006-08-08 Google, Inc. Interface and system for providing persistent contextual relevance for commerce activities in a networked environment
US7054887B2 (en) 2001-01-30 2006-05-30 Ibm Corporation Method and system for object replication in a content management system
US7003565B2 (en) 2001-04-03 2006-02-21 International Business Machines Corporation Clickstream data collection technique
US20030014483A1 (en) * 2001-04-13 2003-01-16 Stevenson Daniel C. Dynamic networked content distribution
US20040098349A1 (en) * 2001-09-06 2004-05-20 Michael Tolson Method and apparatus for a portable information account access agent
US7103912B2 (en) 2001-06-29 2006-09-05 International Business Machines Corporation User authorization management system using a meta-password and method for same
US7421411B2 (en) * 2001-07-06 2008-09-02 Nokia Corporation Digital rights management in a mobile communications environment
US20030033403A1 (en) * 2001-07-31 2003-02-13 Rhodes N. Lee Network usage analysis system having dynamic statistical data distribution system and method
US7100054B2 (en) 2001-08-09 2006-08-29 American Power Conversion Computer network security system
US20030061482A1 (en) * 2001-08-23 2003-03-27 Efunds Corporation Software security control system and method
US7392483B2 (en) * 2001-09-28 2008-06-24 Ntt Docomo, Inc, Transformation of platform specific graphical user interface widgets migrated between heterogeneous device platforms
FR2832236B1 (en) 2001-11-13 2004-04-16 Inst Nat Rech Inf Automat SEMANTIC WEB PORTAL GRAPHIC INTERFACE
US20030105882A1 (en) 2001-11-30 2003-06-05 Ali Syed M. Transparent injection of intelligent proxies into existing distributed applications
US7117535B1 (en) 2001-12-14 2006-10-03 Microsoft Corporation Software-generated machine identifier
US20030149567A1 (en) 2002-02-04 2003-08-07 Tony Schmitz Method and system for using natural language in computer resource utilization analysis via a communications network
EP1488327A4 (en) * 2002-03-06 2008-05-07 Sidereus Technologies Inc User controllable computer presentation of interfaces and information selectively provided via a network
US20030200145A1 (en) 2002-04-18 2003-10-23 Brad Krassner Internet-based system and method for creating and distributing customized rich media marketing and sales materials via e-mail
US7003522B1 (en) 2002-06-24 2006-02-21 Microsoft Corporation System and method for incorporating smart tags in online content
US6810356B1 (en) 2002-08-30 2004-10-26 Advertising.Com Traffic estimation
US7085682B1 (en) 2002-09-18 2006-08-01 Doubleclick Inc. System and method for analyzing website activity
US7072672B1 (en) 2002-11-01 2006-07-04 Nokia Corporation Disposable mini-applications
US20040153973A1 (en) * 2002-11-21 2004-08-05 Lawrence Horwitz System and method for automatically storing and recalling application states based on application contexts
US7526545B2 (en) * 2003-01-17 2009-04-28 Relevant Media Llc Content distribution system
US7269792B2 (en) * 2003-04-24 2007-09-11 International Business Machines Corporation System and method for generating high-function browser widgets with full addressability
US20040215515A1 (en) 2003-04-25 2004-10-28 Aquantive, Inc. Method of distributing targeted Internet advertisements based on search terms
US8484073B2 (en) 2003-04-25 2013-07-09 Facebook, Inc. Method of distributing targeted internet advertisements
US20040225562A1 (en) 2003-05-09 2004-11-11 Aquantive, Inc. Method of maximizing revenue from performance-based internet advertising agreements
US20050086587A1 (en) * 2003-05-14 2005-04-21 Balz Christopher M. System and method for presenting computerized interactive forms to respondents using a client-server-systems technology based on web standards
US20050197991A1 (en) 2003-06-25 2005-09-08 Wray Robert E. Method and apparatus for providing rule-based, autonomous software agent with ontological information
US6986049B2 (en) * 2003-08-26 2006-01-10 Yahoo! Inc. Method and system for authenticating a message sender using domain keys
US20050050301A1 (en) * 2003-08-29 2005-03-03 Yahoo!, Inc. Extensible user interface
US7519689B2 (en) * 2003-09-10 2009-04-14 Mohan Prabhuram Method and system to provide message communication between different browser based applications running on a desktop
US7084014B2 (en) * 2003-10-07 2006-08-01 Endicott Interconnect Technologies, Inc. Method of making circuitized substrate
WO2005050378A2 (en) * 2003-11-18 2005-06-02 Burke Robert M Ii System for regulating access to and distributing content in a network
WO2006028488A2 (en) 2004-02-04 2006-03-16 Passmark Security, Inc. Authentication of users and computer systems
US7433876B2 (en) 2004-02-23 2008-10-07 Radar Networks, Inc. Semantic web portal and platform
US7493563B2 (en) 2004-03-05 2009-02-17 International Business Machines Corporation Using content aggregation to build administration consoles
US7467399B2 (en) * 2004-03-31 2008-12-16 International Business Machines Corporation Context-sensitive confidentiality within federated environments
US7590685B2 (en) * 2004-04-07 2009-09-15 Salesforce.Com Inc. Techniques for providing interoperability as a service
US7516158B2 (en) * 2004-04-19 2009-04-07 Pixar Customizing widget draw styles
US20050256819A1 (en) 2004-04-28 2005-11-17 Clark Tibbs Semantic adaptive framework (SAF) for enabling system self selection of actions by reasoning about self knowledge
US20050246262A1 (en) 2004-04-29 2005-11-03 Aggarwal Charu C Enabling interoperability between participants in a network
US7490094B2 (en) 2004-05-06 2009-02-10 International Buisness Machines Corporation Importance of semantic web resources and semantic associations between two resources
JP2005346434A (en) 2004-06-03 2005-12-15 Nippon Telegr & Teleph Corp <Ntt> Widget operation method, device, program and recording medium with this program recorded thereon
US8566732B2 (en) * 2004-06-25 2013-10-22 Apple Inc. Synchronization of widgets and dashboards
US7587676B2 (en) * 2004-08-31 2009-09-08 Sap Ag System and method for inhibiting interaction with malicious software
US7283499B2 (en) * 2004-10-15 2007-10-16 Nokia Corporation Simplified practical rank and mechanism, and associated method, to adapt MIMO modulation in a multi-carrier system with feedback
DE102004052075A1 (en) * 2004-10-26 2006-04-27 Jungheinrich Ag Node for a bus network, bus network and method for configuring the network
US20060106876A1 (en) 2004-11-12 2006-05-18 Macgregor Robert M Method and apparatus for re-using presentation data across templates in an ontology
EP1675022A1 (en) 2004-12-22 2006-06-28 Sap Ag A method and a system for integrating semantic web services into a existing web service infrastructure
US20060190290A1 (en) 2005-02-22 2006-08-24 Brainshield Technologies, Inc. Systems and methods for distributing electronic files
US7941544B2 (en) 2005-03-18 2011-05-10 Sap Ag Session manager for web-based applications
US20060218036A1 (en) 2005-03-23 2006-09-28 King Michael D System and method for embedding dynamic, server-based questionnaire content within online banner ads
US7302539B2 (en) 2005-04-20 2007-11-27 Hewlett-Packard Development Company, L.P. Migrating data in a storage system
US20060259462A1 (en) 2005-05-12 2006-11-16 Sybase, Inc. System and Methodology for Real-time Content Aggregation and Syndication
CN101185304B (en) * 2005-05-25 2012-08-29 艾利森电话股份有限公司 Method and device for identifying an IMS service
US20060277457A1 (en) 2005-06-07 2006-12-07 Salkind Carole T Method and apparatus for integrating video into web logging
US7702675B1 (en) * 2005-08-03 2010-04-20 Aol Inc. Automated categorization of RSS feeds using standardized directory structures
US8924869B2 (en) * 2005-08-12 2014-12-30 Barry Fellman Service for generation of customizable display widgets
KR101322515B1 (en) * 2005-09-29 2013-10-25 콘텐트가드 홀딩즈 인코포레이티드 System and method for digital rights management using advanced copy with issue rights, and managed copy tokens
US8914733B2 (en) * 2005-10-04 2014-12-16 International Business Machines Corporation User interface widget unit sharing for application user interface distribution
US9104294B2 (en) * 2005-10-27 2015-08-11 Apple Inc. Linked widgets
US8543824B2 (en) * 2005-10-27 2013-09-24 Apple Inc. Safe distribution and use of content
US7954064B2 (en) * 2005-10-27 2011-05-31 Apple Inc. Multiple dashboards
US7752556B2 (en) * 2005-10-27 2010-07-06 Apple Inc. Workflow widgets
US8145774B2 (en) * 2005-11-08 2012-03-27 Microsoft Corporation Progressively accessing data blocks related to pages
US7730082B2 (en) * 2005-12-12 2010-06-01 Google Inc. Remote module incorporation into a container document
WO2007083210A2 (en) * 2006-01-23 2007-07-26 Nokia Corporation Method and system for configuring a user interface
US20070174429A1 (en) 2006-01-24 2007-07-26 Citrix Systems, Inc. Methods and servers for establishing a connection between a client system and a virtual machine hosting a requested computing environment
US7765485B2 (en) 2006-01-30 2010-07-27 International Business Machines Corporation Extensible user interface framework for a componentized application environment
US7996783B2 (en) 2006-03-02 2011-08-09 Microsoft Corporation Widget searching utilizing task framework
US8775919B2 (en) 2006-04-25 2014-07-08 Adobe Systems Incorporated Independent actionscript analytics tools and techniques
US20070288518A1 (en) 2006-05-03 2007-12-13 Jeff Crigler System and method for collecting and distributing content
US7917858B2 (en) 2006-06-09 2011-03-29 Hewlett-Packard Development Company, L.P. Engine for rendering widgets using platform-specific attributes
US9002726B2 (en) * 2006-06-19 2015-04-07 Nokia Corporation Advertising based on widgets
US8869066B2 (en) * 2006-07-06 2014-10-21 Addthis, Llc Generic content collection systems
US20080034284A1 (en) * 2006-07-28 2008-02-07 Blue Lava Technologies Method and system for displaying multimedia content
US8869027B2 (en) 2006-08-04 2014-10-21 Apple Inc. Management and generation of dashboards
US20080034040A1 (en) * 2006-08-04 2008-02-07 Meebo, Inc. Method and system for embedded group communication
WO2008021332A2 (en) * 2006-08-11 2008-02-21 Fox Interactive Media Labs System and method for automatically updating a widget on a desktop
US7346909B1 (en) * 2006-08-28 2008-03-18 Intel Corporation Network-like communication and stack synchronization for different virtual machines on the same physical device
US20080071883A1 (en) * 2006-09-20 2008-03-20 Eric Alterman Method and Apparatus for Proliferating Adoption of Web Components
US20080082627A1 (en) * 2006-09-29 2008-04-03 Allen Stewart O Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation
US8056092B2 (en) 2006-09-29 2011-11-08 Clearspring Technologies, Inc. Method and apparatus for widget-container hosting and generation
US20080091777A1 (en) * 2006-10-12 2008-04-17 International Business Machines Corporation Method, system and program product for building collaboration applications using multiple-peer user interface libraries
WO2009099403A2 (en) * 2006-10-23 2009-08-13 Chipin Inc. Method and system for providing a widget for displaying multimedia content
US7565332B2 (en) * 2006-10-23 2009-07-21 Chipin Inc. Method and system for providing a widget usable in affiliate marketing
US20080215998A1 (en) * 2006-12-07 2008-09-04 Moore Dennis B Widget launcher and briefcase
KR100848129B1 (en) * 2006-12-07 2008-07-24 한국전자통신연구원 Method for providing a personalization service in ubiquitous environment and intelligent gadget therefor
US8117555B2 (en) * 2006-12-07 2012-02-14 Sap Ag Cooperating widgets
US20080141141A1 (en) * 2006-12-07 2008-06-12 Moore Dennis B Widget runtime engine for enterprise widgets
US20080168363A1 (en) * 2007-01-05 2008-07-10 International Business Machines Corporation Extensible mechanism for context selection in a multi-dimensional domain
US8850140B2 (en) * 2007-01-07 2014-09-30 Apple Inc. Data backup for mobile device
US10083184B2 (en) * 2007-01-07 2018-09-25 Apple Inc. Widget synchronization in accordance with synchronization preferences
US8266274B2 (en) 2007-03-06 2012-09-11 Clearspring Technologies, Inc. Method and apparatus for data processing
US20080222232A1 (en) 2007-03-06 2008-09-11 Allen Stewart O Method and Apparatus for Widget and Widget-Container Platform Adaptation and Distribution
US9009728B2 (en) 2007-03-06 2015-04-14 Addthis, Inc. Method and apparatus for widget and widget-container distribution control based on content rules
US20080232560A1 (en) 2007-03-19 2008-09-25 Sirkin Eric R Method and system to control IVR-IVR dialogue sessions
US8260687B2 (en) 2007-04-16 2012-09-04 Ebay Inc. Distributed commerce application-widget
US20100138295A1 (en) * 2007-04-23 2010-06-03 Snac, Inc. Mobile widget dashboard
US8150939B1 (en) * 2007-05-11 2012-04-03 Oracle America, Inc. Method and system for wrapping and componentizing javascript centric widgets using java components
US8275681B2 (en) 2007-06-12 2012-09-25 Media Forum, Inc. Desktop extension for readily-sharable and accessible media playlist and media
TWI345403B (en) * 2007-07-06 2011-07-11 Kat Digital Corp Embedded device and method for assisting in processing media content based on subscribed syndication feed
TW200913710A (en) * 2007-07-13 2009-03-16 Chumby Ind Inc Systems and methods for alarm tone selection, distribution, and playback in a networked audiovisual device
US9167070B2 (en) * 2007-07-31 2015-10-20 Qualcomm Incorporated Widget discovery in computing devices
US8352966B2 (en) * 2007-09-11 2013-01-08 Yahoo! Inc. System and method of inter-widget communication
US8209378B2 (en) * 2007-10-04 2012-06-26 Clearspring Technologies, Inc. Methods and apparatus for widget sharing between content aggregation points
US20090111448A1 (en) * 2007-10-31 2009-04-30 Nokia Corporation System and method for enabling widget interaction
US8059570B2 (en) * 2008-01-11 2011-11-15 Apple Inc. Mobile network device battery conservation system and methods
US20090204885A1 (en) 2008-02-13 2009-08-13 Ellsworth Thomas N Automated management and publication of electronic content from mobile nodes
US20090216634A1 (en) 2008-02-27 2009-08-27 Nokia Corporation Apparatus, computer-readable storage medium and method for providing a widget and content therefor
US9489383B2 (en) 2008-04-18 2016-11-08 Beats Music, Llc Relevant content to enhance a streaming media experience
US20090288004A1 (en) 2008-05-15 2009-11-19 Toni Peter Strandell System, method, apparatus and computer program product for providing a notification of widget availability
US20100030901A1 (en) * 2008-07-29 2010-02-04 Bryan Severt Hallberg Methods and Systems for Browser Widgets
US20100100626A1 (en) * 2008-09-15 2010-04-22 Allen Stewart O Methods and apparatus related to inter-widget interactions managed by a client-side master

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040107125A1 (en) * 1999-05-27 2004-06-03 Accenture Llp Business alliance identification in a web architecture
US20060178918A1 (en) * 1999-11-22 2006-08-10 Accenture Llp Technology sharing during demand and supply planning in a network-based supply chain environment

Also Published As

Publication number Publication date
US20080222658A1 (en) 2008-09-11
US9009728B2 (en) 2015-04-14
US20160041714A1 (en) 2016-02-11
US9495084B2 (en) 2016-11-15

Similar Documents

Publication Publication Date Title
US9495084B2 (en) Method and apparatus for widget and widget-container distribution control based on content rules
US8056092B2 (en) Method and apparatus for widget-container hosting and generation
US20210160360A1 (en) Method of enabling digital music content to be downloaded to and used on a portable wireless computing device
US20080082627A1 (en) Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation
US9544400B2 (en) Manipulating binary large objects
US7647407B2 (en) Method and system for administering a concurrent user licensing agreement on a manufacturing/process control information portal server
CN107506620B (en) Application market manages control
US9501790B2 (en) Method and system for service-enablement gateway and its service portal
US20070162400A1 (en) Method and apparatus for managing digital content in a content management system
US9805209B2 (en) Systems and methodologies for managing document access permissions
US20110119361A1 (en) System and method for managing redacted electronic documents using callback triggers
US20080222232A1 (en) Method and Apparatus for Widget and Widget-Container Platform Adaptation and Distribution
US20180129819A1 (en) Redacting restricted content in files
JP2010182319A (en) Application level access privilege to storage area on computer device
JP2007505559A (en) Method and apparatus for content protection in a wireless network
KR970700970A (en) Generic Service Coordination Mechanism
US9854030B2 (en) Searching content associated with multiple applications
US9665732B2 (en) Secure Download from internet marketplace
CN115879156A (en) Dynamic desensitization method, device, electronic equipment and storage medium
CN115174177A (en) Authority management method, device, electronic apparatus, storage medium and program product
CN114969722A (en) Government affair data privacy calculation system supporting multiple data types
WO2008042849A2 (en) Method and apparatus for widget-container hosting and generation
US8266177B1 (en) Empirical database access adjustment
CN114153354B (en) Menu display method and electronic equipment
US11169864B2 (en) Systems, methods and computer program products for application environment synchronization between remote devices and on-premise devices

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 08743662

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE

122 Ep: pct application non-entry in european phase

Ref document number: 08743662

Country of ref document: EP

Kind code of ref document: A1