US20120227060A1 - Method and apparatus for widget-container hosting and generation - Google Patents

Method and apparatus for widget-container hosting and generation Download PDF

Info

Publication number
US20120227060A1
US20120227060A1 US13/290,192 US201113290192A US2012227060A1 US 20120227060 A1 US20120227060 A1 US 20120227060A1 US 201113290192 A US201113290192 A US 201113290192A US 2012227060 A1 US2012227060 A1 US 2012227060A1
Authority
US
United States
Prior art keywords
widget
container
processor
service module
user
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US13/290,192
Inventor
Stewart O. Allen
Scott F. Cosby
John A. Fath
Dylan J. Greene
Matthew J. Keesan
Hooman Radfar
Cyrus B. Radfar
Carlos F. Reverte
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Clearspring Tech Inc
Original Assignee
Clearspring Tech 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 Tech Inc filed Critical Clearspring Tech Inc
Priority to US13/290,192 priority Critical patent/US20120227060A1/en
Assigned to CLEARSPRING TECHNOLOGIES, INC. reassignment CLEARSPRING TECHNOLOGIES, INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: ALLEN, STEWART O., FATH, JOHN A., GREENE, DYLAN A., RADFAR, CYRUS B., REVERTE, CARLOS F., COSBY, SCOTT F., KEESAN, MATTHEW J., RADFAR, HOOMAN
Publication of US20120227060A1 publication Critical patent/US20120227060A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5005Allocation of resources, e.g. of the central processing unit [CPU] to service a request
    • G06F9/5027Allocation of resources, e.g. of the central processing unit [CPU] to service a request the resource being a machine, e.g. CPUs, Servers, Terminals
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/958Organisation or management of web site content, e.g. publishing, maintaining pages or automatic linking
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/30Creation or generation of source code
    • G06F8/38Creation or generation of source code for implementing user interfaces
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/465Distributed object oriented systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/54Interprogram communication
    • G06F9/541Interprogram communication via adapters, e.g. between incompatible applications
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/50Indexing scheme relating to G06F9/50
    • G06F2209/5017Task decomposition
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2209/00Indexing scheme relating to G06F9/00
    • G06F2209/54Indexing scheme relating to G06F9/54
    • G06F2209/541Client-server

Definitions

  • a method includes receiving at least one of a widget or a reference to a widget, where the widget can be at least one of a static data object, a media object, or a software object.
  • At least a portion of a widget container which is a procedural software framework containing a service module associated with the widget and the widget, is generated.
  • the service module can be a pre-defined function associated with the widget container before the widget container is generated.
  • the widget container can be configured to be executed at a widget-container processing device in response to a reference to the widget container being accessed from a processor-readable vehicle.
  • FIG. 2 is a schematic diagram illustrating a widget container being executed/displayed within a framework of a processor-readable vehicle, according to an embodiment of the invention.
  • FIG. 3 is a flow chart that illustrates a method for generating a widget container, according to an embodiment of the invention.
  • FIG. 5 is a schematic diagram that illustrates a widget-container host sending instances of a widget container for execution within several processor-readable vehicles, according to an embodiment of the invention.
  • FIG. 10 is a flow chart that illustrates a method for dynamically modifying a widget container, according to an embodiment of the invention.
  • FIG. 11 is a flow chart that illustrates a method for retrieving a widget using metadata parameter values, according to an embodiment of the invention.
  • 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 personal digital assistant (PDA), and/or a server.
  • the widget container can be configured so 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 130 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 in a variety of environments such as, for example, an office complex.
  • LAN local area network
  • WAN wide area network
  • a widget that is contained (e.g., referenced or integrated) in the widget container is stored in and served from the memory 105 of the widget-container host 100 to one of the widget-container processing devices 150 .
  • the widget container and/or the components of the widget container are stored in the memory 105 and sent to a widget-container processing device 150 over the network 130 in response to a request for the widget container from the widget-container processing device 150 .
  • a widget container served from the widget-container host 100 can contain a reference to one or more widgets that are served from, for example, a widget server (not shown).
  • 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.
  • the widget-container creation device 120 can also be configured to locally define, generate, and/or modify the widget container.
  • the widget-container creation device 120 can access a user-interface served by the widget-container host 100 that can be used to define a widget container.
  • the user-interface can be, for example, a widget-container generation engine served from an application server (not shown) controlled and/or integrated into the widget-container host 100 and accessed using a web browser.
  • 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 .
  • the service module 254 can also have a set of pre-defined features that can receive customizable (e.g., unique) information.
  • the service module 254 can be configured so that the service module 254 can accept and use information input by a user such as an e-mail address. If the service module 254 , for example, is configured to provide weather information to a user viewing the widget container 250 , the service module 254 can be configured to accept location information (e.g., zip code) so that a weather forecast that is of interest to the user can be provided by the service module 254 .
  • location information e.g., zip code
  • Widget container 250 can also include a tracking kernel 256 configured to perform a tracking function.
  • the tracking kernel 256 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 256 in many embodiments, is not displayable on the display 230 .
  • the tracking kernel 256 and/or features associated with the tracking kernel 256 can also be contained in the widget container 250 as a service module 254 .
  • the tracking kernel 256 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 256 can be configured to count the number of times that a user (e.g., viewer of the widget container 250 ) moves a mouse over a particular widget 252 or service module 254 .
  • the tracking kernel 256 can also be configured to track impressions, widget container visitor profiles, domain names of the processor-readable vehicle 220 , container processing device 240 information such as browser type and operating system type.
  • the tracking service level can be dynamically injected into, for example, widget container 250 using a dynamic injection technique.
  • the tracking kernel of widget container 250 can be configured to request a tracking service level from, for example, the widget-container host 200 .
  • the widget container 250 can dynamically load (e.g., just before the widget container 250 is served to the widget-container-processing device 240 ) the tracking service level represented by an image/data (e.g., composite bit field) with a defined width and height.
  • An image of one size can trigger the tracking kernel 256 of the widget container 250 , for example, to be turned off altogether. Other image sizes can enable or disable behavioral tracking, placement tracking, etc. in any combination.
  • Tracking kernels 256 associated with different widget containers 250 can be individually configured dynamically on an instance by instance basis to minimize load and bandwidth cost where necessary as determined by, for example, threshold conditions.
  • the widget-container host 200 for example, can proactively dynamically inject data into the widget container 250 based on a policy without the data first being requested by the widget container 250 .
  • the user-interface can be provided via an application server controlled by the widget-container host.
  • the user-interface can be associated with a remote server (e.g., separate computer/server) that is configured to cause a generation engine associated with a separate widget-container generation host to generate the widget container in response to, for example, an application program interface (API) call.
  • a computer/server can be configured to automatically (or in response to an instruction from a user) send an API call to cause a remote widget-container generation host to generate a widget container.
  • the policy used to define a set of service modules can be dependent on the type of the widget being containerized. For example a certain set of service modules can be allowed for containerization in a widget container based on the widget being a video content widget. A different set of service modules can be provided to a user for containerization in a widget container based on the widget being an audio content widget.
  • a reference (e.g., link) to a user-created service module can be provided by the user to, for example, a widget generation engine via a user-interface so that the user-created service module can be wrapped into the widget container.
  • a user or computer system
  • a user can be allowed, in some embodiments, to insert a user-created service module only when the user has been authenticated and/or the user-created service module has been approved for use in the widget container.
  • the user-created service module can be approved based on a policy that is, for example, included in and enforced by a widget-container generation engine.
  • the parentage information can be used to associate tracking parameter values associated with instances of widget containers to create collective tracking parameters.
  • tracking parameter values associated with an instance of the widget container 505 sent to processor-readable vehicle 540 and an instance of the widget container sent to processor-readable vehicle 550 can be statistically combined/compiled (e.g., averaged, summed) and stored in, for example, a metadata database.
  • the tracking parameter values associated with each of the instances of widget container 505 can be associated using parentage information. Tracking parameter values of multiple instances of the widget container 505 sent to a single processor-readable vehicle such as, for example, processor-readable vehicle 530 at different times can also be statistically combined and/or compiled.
  • collective tracking parameters can be used for monetization purposes.
  • the placement ID's, 536 , 546 , 556 , and 566 can be stored in, for example, a metadata database such that the placement ID's, 536 , 546 , 556 , and 566 , can be associated with their respective processor readable vehicles, 530 , 540 , 550 , and 560 , even if, for example, an identifier associated with any one of the processor readable vehicles, 530 , 540 , 550 , and 560 , changes.
  • processor readable vehicle 550 is a webpage
  • the placement ID 556 can be associated with each web address that can be used to request processor-readable vehicle 550 .
  • a service module within the widget container can be used to generate the second placement identifier and associate the second placement identifier with the second instance of the reference.
  • a separate host can be triggered, for example, by the widget-container host and/or a placement service module to generate the second placement identifier and associate the second placement identifier with the second instance of the reference.
  • the placement ID's 830 e.g., P 2
  • vehicle identifiers for the processor-readable vehicles 840 e.g., URL 2
  • these unique identifier that are combinations of the placement ID's 830 and the processor-readable vehicles 840 can be used as pointers to the widget containers 820 , for example, when included in a reference (e.g., embed tag) of a processor-readable vehicle 840 .
  • These unique combined identifiers can be encrypted and/or encoded using an algorithm and un-encrypted and/or decoded using the algorithm (or a different algorithm) when used by, for example, a widget container host.
  • Metadata stored within the metadata database 800 can be collected and/or generated using, for example, one or more service modules 870 contained in any of the widget containers 820 .
  • a preference which can be stored as metadata, for a particular configuration of widget container A (e.g., theme or style) can be collected from a user via a service module J that includes a feature that allows a user to select a theme.
  • a weather related service module can collect a zip code so that weather related to an area relevant to the user can be displayed in, for example, widget container B.
  • the sip code can be stored as a metadata parameter value.
  • an identifier e.g., username, placer identifier
  • a placement ID 830 An identifier (e.g., username, viewer identifier) of a viewer can be associated with a particular tracking parameter 880 and/or a session ID 850 .
  • the session can be triggered by a particular widget-container viewer.
  • an identifier e.g., username, originator identifier
  • an originator can be included in the metadata database 800 as author information.
  • the placer metadata can be referred to as local metadata because, for example, preferences of a placer stored as metadata can be associated only with the placement of a reference to the widget-container in a specific processor-readable vehicle.
  • the widget container can be modified according to the preferences of the placer when the widget container is served to the processor-readable vehicle associated with (e.g., owned by) the placer.
  • the placer metadata can, in some embodiments, also be global metadata that can cause changes to all instances of widget containers.
  • a viewer metadata parameter value can be associated with a widget container no matter how many instances of the widget container are served and/or regardless of which processor-readable vehicles the widget container is served to.
  • the viewer metadata can be associated with an instance of the widget container based on the credentials (e.g., viewer identifier, username/password) of the viewer.
  • the credentials can be collected when the widget container is requested from, for example, a processor-readable vehicle.
  • the credentials of the viewer can then be used to find viewer metadata that can later be used to dynamically modify the widget container when the widget container is served.
  • viewer metadata can be configured as local or global metadata.
  • the widget container 950 can include a core framework that has at least some portions that are defined by metadata parameter values stored in the metadata database 910 (or received in a request for the widget container 950 ).
  • the size/color/theme of the widget container 950 , the widget 952 and/or service module 954 contained in the widget container 950 , etc. can be defined using metadata parameter values stored in the metadata 910 .
  • the metadata parameter values that are used to define the widget container 950 can be retrieved just before an instance of the widget container 950 is served to the widget-container processing device 940 (e.g., for execution within the framework of the processor-readable vehicle 920 ).
  • the widget container 950 can be generated (or regenerated) based on the defined metadata parameter values.
  • Metadata parameter values can be used to search for and/or identify a portion of a widget container.
  • a metadata parameter value search can be used to identify a widget, service module, and/or widget container, for example, for execution or display within a processor readable vehicle.

Abstract

A method includes receiving at least one of a widget or a reference to a widget, where the widget can be at least one of a static data object, a media object, or a software object. At least a portion of a widget container, which is a procedural software framework containing a service module associated with the widget and the widget, is generated. The service module can be a pre-defined function associated with the widget container before the widget container is generated. The widget container can be configured to be executed at a widget-container processing device in response to a reference to the widget container being accessed from a processor-readable vehicle.

Description

    CROSS-REFERENCE TO RELATED APPLICATION
  • This application is a continuation of U.S. patent application Ser. No. 11/537,362, filed Sep. 29, 2006, and entitled “Method and Apparatus for Widget-Container Hosting and Generation,” which is incorporated herein by reference in its entirety.
  • BACKGROUND
  • The disclosed invention relates generally to distribution of content over a network, and in particular, to containerization 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. Recently, primitive 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 primitive methods are more convenient than distributing content in an ad-hoc fashion, they have many shortcomings. For example, they do not provide for the ability to easily add services related to the content and services, if any exist, cannot be dynamically modified. The spreading of content using ad-hoc methods and/or primitive forms of viral spreading cannot be tracked as a service in a useful way. Content also cannot be readily shared with users of different platforms (e.g., personal digital assistant to personal computer). Thus, there is a need for an apparatus and method for combining content with services.
  • SUMMARY OF THE INVENTION
  • A method includes receiving at least one of a widget or a reference to a widget, where the widget can be at least one of a static data object, a media object, or a software object. At least a portion of a widget container, which is a procedural software framework containing a service module associated with the widget and the widget, is generated. The service module can be a pre-defined function associated with the widget container before the widget container is generated. The widget container can be configured to be executed at a widget-container processing device in response to a reference to the widget container being accessed from a processor-readable vehicle.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • 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.
  • FIG. 1 is a block diagram of a widget-container host connected via a network to several widget-container processing devices, according to an embodiment of the invention.
  • FIG. 2 is a schematic diagram illustrating a widget container being executed/displayed within a framework of a processor-readable vehicle, according to an embodiment of the invention.
  • FIG. 3 is a flow chart that illustrates a method for generating a widget container, according to an embodiment of the invention.
  • FIG. 4 is a flow chart that illustrates a method for sending a widget container to a container processing device, according to an embodiment of the invention.
  • FIG. 5 is a schematic diagram that illustrates a widget-container host sending instances of a widget container for execution within several processor-readable vehicles, according to an embodiment of the invention.
  • FIG. 6 is a flow chart that illustrates an example method for placing a reference and generating a placement identifier that can be used to generate parentage information, according to an embodiment of the invention.
  • FIG. 7 is a schematic diagram of a widget container that contains a widget and a placement service module, according to an embodiment of the invention.
  • FIG. 8 is an example metadata database that illustrates some of the metadata parameters and values that can be generated for and associated with widget containers, according to an embodiment of the invention.
  • FIG. 9 is a schematic diagram illustrating a widget-container host accessing metadata parameter values from a metadata database, according to an embodiment of the invention.
  • FIG. 10 is a flow chart that illustrates a method for dynamically modifying a widget container, according to an embodiment of the invention.
  • FIG. 11 is a flow chart that illustrates a method for retrieving a widget using metadata parameter values, according to an embodiment of the invention.
  • DETAILED DESCRIPTION
  • A widget container (also can be referred to as a container) is a procedural software framework that contains a widget and/or contains at least one service module that can be associated with the widget. As a procedural software framework, the widget container can be a series of instructions that are executable or interpretable by, for example, a computer processor. 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 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 container is a portable framework that can be embedded in (e.g., referenced using an embed or object tag) and/or accessed from/using a processor-readable vehicle (e.g., webpage). 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 applet) that can be contained (e.g., integrated or referenced) in the widget container. In many embodiments, the widget and/or the service module (or references to the widget and/or service module) can be referred to as components of the widget container.
  • 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. The service module and/or widget can be wrapped in the container, for example, at the time that the widget container is first generated, after the widget container has been generated, and/or dynamically when the widget container is being served. The widget container can be created using a widget generation engine that is implemented in hardware and/or software (e.g., using a user-interface). In some embodiments, the widget-container generation engine can be included in a widget-container host and/or a widget-container creation device. 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). Dynamic injection is discussed in more detail in connection with tracking parameter values and in connection with FIG. 4.
  • The widget container can be sent from a widget-container host to a widget-container processing device such as, for example, a computer or mobile phone when a reference to the widget container is accessed from, for example, a webpage. The widget container can be executed on various platforms and instances of references to the widget container can be included in and/or spread to a variety of processor-readable vehicles that can be read using various widget-container processing devices. Also, metadata can be associated with the widget container and/or a component of the widget container (e.g., widget), so that the widget container and/or component of the widget container can be, for example, dynamically customized and/or tracked.
  • Referring now to the drawings, FIG. 1 is a block diagram of a widget-container host 100 connected via a network 130 to several widget-container processing devices 150. The widget-container host 100 is a centralized management component that controls, configures, and coordinates the sending of widget containers to the container processing devices 150. For example, an instance of a widget container that is stored at the widget-container host can be sent from the widget-container host 100 to one or more of the widget-container processing devices 150 in response to one or more requests for the widget container received from the widget-container processing devices 150. A widget container is a procedural software framework that contains a widget and/or a service module. In some embodiments, the service module can be associated with the widget.
  • 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 personal digital assistant (PDA), and/or a server. The widget container can be configured so 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 130 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 in a variety of environments such as, for example, an office complex.
  • The widget-container host 100, in response to a request to access, modify, and/or define a widget container, retrieves a widget container from a memory 105 where one or more widget containers are stored. The memory 105 can be, for example, a database included in the widget-container host 100. In some embodiments, 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 130 or via a separate network (not shown).
  • In this embodiment, a widget that is contained (e.g., referenced or integrated) in the widget container is stored in and served from the memory 105 of the widget-container host 100 to one of the widget-container processing devices 150. In other words, the widget container and/or the components of the widget container are stored in the memory 105 and sent to a widget-container processing device 150 over the network 130 in response to a request for the widget container from the widget-container processing device 150. In many embodiments, a widget container served from the widget-container host 100 can contain a reference to one or more widgets that are served from, for example, a widget server (not shown). Likewise, 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). The widget server and/or service module server can be connected to the widget-container processing devices 150 and/or widget-container host 100 via network 130 or via a separate network (not shown).
  • The memory 105, in some embodiments can also be configured to store metadata parameters and metadata parameter values (e.g., tracking parameter values) associated with widget containers 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. Metadata parameter value storage, manipulation, and usage are described in more detail in connection with FIGS. 8-11.
  • FIG. 1 also shows that a widget-container creation device 120 can be connected to the container host 100 via network 130. 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. In some embodiments, the widget-container creation device 120 can be configured to automatically 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.
  • 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.
  • The widget-container creation device 120 can also be configured to locally define, generate, and/or modify the widget container. In some embodiments, the widget-container creation device 120 can access a user-interface served by the widget-container host 100 that can be used to define a widget container. The user-interface can be, for example, a widget-container generation engine served from an application server (not shown) controlled and/or integrated into the widget-container host 100 and accessed using a web browser.
  • If the widget container is generated at the widget-container creation device 120 using, for example, a locally executed widget-container generation engine, the widget container can be sent to the widget-container host 100 for storage and distribution to one or more of the container processing devices 150. The widget container can also locally modify the widget-container creation device 120 by, for example, receiving the widget container from the widget-container host 100, modifying the widget container locally, and sending the widget container back to the widget-container host 100. More details related to the generation and modification of a widget container are described in connection with FIG. 3 and FIG. 10, respectively.
  • 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.
  • FIG. 2 is a schematic diagram illustrating a widget container 250 executing within a framework of a processor-readable vehicle 220 and/or being displayed on a display 230 of a container processing device 240, according to an embodiment of the invention. The widget container 250 includes a widget 252 served from a widget server 210 over a network 280 to the container processing device 240 for, for example, display within the procedural software framework of the widget container 250. The widget 252 is served to the container processing device 240 and displayed/executed within the widget container 250 in response to a reference to the widget 252 being accessed from the widget container 250. In some embodiments, the widget container 250 is a Flash object and the processor-readable vehicle 220 is a Flash-enabled web browser.
  • The widget 252 can be categorized into one of three categories of widgets, static data objects, software objects, and media objects. Within each category, the widget can be a specific content type. For example, the widget 252 can be an executed (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 252 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 252 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 252. 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 252 can be executed/displayed in any portion of the widget container 250 when the widget container 250 is displayed on the display 230.
  • In some embodiments, the widget 252 can be modified for display/execution within the widget container 250. For example, the dimensions of an image object can be modified by, for example, metadata parameter values defined within or used to define the widget container 250. In some embodiments, the widget container 250 can be configured so that the executing/display of the widget 252 within the widget container 250 is performed at specified times. For example, the display of the widget 252 can be delayed or performed at a certain time in response to an instruction triggered by a user, for example, through the service module 254.
  • The widget container 250 is served to the container processing device 240 from a widget-container host 200 when a reference to the widget container is accessed/read from the processor-readable vehicle 220. In many embodiments, the widget-container 250 is automatically executed when received at the widget-container processing device 240. The reference can include a pointer to the widget container 250 (e.g., pointer to unique ID associated with the widget container 250). An instance of a reference to the widget container 250 can be included in any portion of the processor-readable vehicle 220.
  • In many embodiments, the processor-readable vehicle 220 is a readable framework that can be used to describe a structure for displaying information without being executed as a series of instructions such as a hyper-text markup language (html) web-page or a wireless application protocol (WAP) site. If the processor-readable vehicle 220 is a web-page, the reference can be, for example, an embed tag or an object tag that serves as a link to the widget container 250.
  • 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., Javascript). An executable portion (of the procedural software framework) that manages and controls the service module(s) 254 and/or widget(s) 252 included 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 (e.g., x, y location of the widget 252, size of the widget 252, color, themes, styles, etc.).
  • The service module 254 included in the widget container 250 can be a pre-defined function associated with one or more widgets 252, another service module (not shown), and/or the widget container 250. For example, the service module 254 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. The service module 254 can also be a referral service function (e.g., a service used to refer a viewer to a widget container), an advertisement service function (e.g., a service module that includes an advertisement), or a directory service function (e.g., a service module used for searching in a directory).
  • In this embodiment, the service module 254 is served from a service module server 270 in response to a reference to the service module 254 being accessed/read from the widget container 250. In some embodiments, the service module 254 is an integrated component of the widget container 250 (e.g., compiled within the widget container 250). In some embodiments, the service module 254 and/or widget 252 can be stored on and dynamically served from the widget-container host 200 when the widget container 250 is requested. The widget-container host 200 can also be configured to prompt the widget server 210 and/or service module server 270 to send the widget 252 and/or the service module 254 to the container processing device 240 when a request for the widget container 250 is received from the container processing device 240.
  • Although this figure shows only a single service module 254 and a single widget 252, multiple service modules 254 and/or widgets 252 can be integrated into and/or referenced within a widget container 250. The widget(s) 252 and/or service module(s) 254 can be configured to interact with one another.
  • In many embodiments, the service module 254 can be configured with a pre-defined functionality/feature that cannot be modified (e.g., an e-mail distribution service module). The pre-defined features can be referred to as components. In some embodiments, the service module 254 can be a pre-defined service module 254 that includes a finite set of pre-defined options/features that can be selected by a user. For example, the service module 254 can be a security service module that has a pre-defined set of security levels that can be selected for use within a widget container.
  • In some embodiments, a pre-defined option within the service module 254 can be used to customize the service module 254. For example, a pre-defined service module 254 can include a pre-defined feature that allows a user to select a certain theme or color scheme for the service module 254.
  • The service module 254 can also have a set of pre-defined features that can receive customizable (e.g., unique) information. For example, the service module 254 can be configured so that the service module 254 can accept and use information input by a user such as an e-mail address. If the service module 254, for example, is configured to provide weather information to a user viewing the widget container 250, the service module 254 can be configured to accept location information (e.g., zip code) so that a weather forecast that is of interest to the user can be provided by the service module 254.
  • In some embodiments, the service module 254 can be a service module 254 created by and selected for use in the widget container 250 by a user. In other words, a user can define a user-created service module 254 that is not selected from a library of pre-defined service modules 254. The user-created service module 254 can have a unique functionality and can be wrapped into the widget container 250.
  • In some embodiments, the service module 254 can be a security service module that can function as a widget firewall. For example, if the widget container 250 is configured to be executed using, for example, a flash player, the widget container 250 can be configured to intercept network calls before the flash player executes them. The widget container 250 can provide a single point of entry into, for example, external javascript calls, and thereby filter them according to a policy implemented by, for example, the widget-container host 200. The widget-container host 200 can also be configured to write payloads (e.g., secret keys, sessions ID's, or one-time pads) into the widget container 250 when it is served/executed to facilitate secure communication.
  • Widget container 250 can also include a tracking kernel 256 configured to perform a tracking function. The tracking kernel 256, 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 256, in many embodiments, is not displayable on the display 230. The tracking kernel 256 and/or features associated with the tracking kernel 256 can also be contained in the widget container 250 as a service module 254.
  • The tracking kernel 256 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. For example, the tracking kernel 256 can be configured to count the number of times that a user (e.g., viewer of the widget container 250) moves a mouse over a particular widget 252 or service module 254. The tracking kernel 256 can also be configured to track impressions, widget container visitor profiles, domain names of the processor-readable vehicle 220, container processing device 240 information such as browser type and operating system type.
  • The tracking kernel 256 can also be used to collect tracking parameter values related to placement information such as, for example, what webpage (e.g., processor-readable vehicle 220) a widget container is referenced and/or placed on, where on the page it was placed, and/or size of the widget container 250 (e.g., dimensional and memory). In some embodiments, the tracking kernel can be coupled with a supporting javascript library.
  • Tracking parameter values collected using the tracking kernel 256 can be sent as, for example, a serialized string of data (or packets) and/or as one or more bursts of tracking packets to a tracking server 260 that can be configured to collect/store tracking parameter values. In some embodiments, the tracking parameter values can be sent to the widget container host 200 for storage in a metadata database (not shown) as metadata. The widget container host 200, in some embodiments, can include the functionality of the tracking server 260.
  • In some embodiments, the widget container 250 can be configured to transmit tracking parameter values to a certain tracking server 260 while another widget container can be configured to transmit tracking parameter values to a different tracking server (not shown). These configurations can be implemented dynamically (e.g., using dynamic injection techniques) when the widget containers are served. The tracking parameter values can be allocated to these different tracking servers based on, for example, widget container type, tracking information, etc. In some embodiments, a single widget container such as widget container 250 can be configured to transmit a first type of tracking parameter value to tracking server 260 and a second type of tracking parameter value to a different tracking server (not shown).
  • The tracking parameter values that can be collected when a widget container 250 is being executed can be transmitted from the widget container 250 at various times and using various combinations of methods. For example, the tracking parameter values can be continually transmitted (e.g., streamed) and/or transmitted when the widget container is closed (e.g., no longer being executed). In some embodiments, tracking parameter values are stored using the tracking kernel 256 (or tracking service module) and transmitted to, for example, the tracking server 260 at periodic intervals and/or random intervals (e.g., transmitted in random and/or periodic bursts). The tracking parameters values can be transmitted from the widget container 250 when a specified threshold of tracking parameter values has been collected and/or when a cache that temporarily stores the tracking parameter values reaches a threshold capacity value.
  • In some embodiments, the tracking of data using the widget container 250 can be throttled on a per-widget container basis to prevent, for example, overly popular widget containers from flooding, for example, the widget container host 200 (or tracking server) with tracking packets and/or tracking parameter values. The tracking kernel 256 can be throttled according to a tracking service level that indicates, for example, that only certain numbers and/or types of user-triggered interactions should be tracked for, for example, widget container 250.
  • The tracking service level can be dynamically injected into, for example, widget container 250 using a dynamic injection technique. For example, the tracking kernel of widget container 250 can be configured to request a tracking service level from, for example, the widget-container host 200. The widget container 250 can dynamically load (e.g., just before the widget container 250 is served to the widget-container-processing device 240) the tracking service level represented by an image/data (e.g., composite bit field) with a defined width and height. An image of one size can trigger the tracking kernel 256 of the widget container 250, for example, to be turned off altogether. Other image sizes can enable or disable behavioral tracking, placement tracking, etc. in any combination. Tracking kernels 256 associated with different widget containers 250 can be individually configured dynamically on an instance by instance basis to minimize load and bandwidth cost where necessary as determined by, for example, threshold conditions. In some embodiments, the widget-container host 200, for example, can proactively dynamically inject data into the widget container 250 based on a policy without the data first being requested by the widget container 250.
  • In some embodiments, the widget container 250 can include one or more other widget containers (not shown). The one or more other widget containers can be referenced in the widget container 250. In some embodiments, the tracking data can be associated, for example, with a unique identifier (e.g., globally unique identifier (GUID)) associated with a specific widget container. The association of tracking data with the widget container (and other metadata parameter values) is discussed in more detail in connection with FIG. 8.
  • FIG. 3 is a flow chart that illustrates a method for generating a widget container, according to an embodiment of the invention. The method of generating a widget container by including a reference to a widget and/or a reference to a service module or integrating a widget and/or service module in a procedural software framework can be referred to as wrapping or containerization.
  • The flow chart shows that a widget and/or a reference to a widget is received at 300. If the widget container is being generated using, for example, a widget-container generation engine at a widget-container generation host, the reference to the widget and the reference to the service module can be selected and/or provided to the widget-container host via a user-interface used to define a widget container. The widget container user-interface can be linked to or can be a component of the widget-container generation engine. The user-interface can include for example, a field that allows a user to select (e.g., using a “browse” button) and/or input a reference to the widget to be added to the widget container.
  • In some implementations, the user-interface can be provided via an application server controlled by the widget-container host. In some embodiments, the user-interface can be associated with a remote server (e.g., separate computer/server) that is configured to cause a generation engine associated with a separate widget-container generation host to generate the widget container in response to, for example, an application program interface (API) call. In some embodiments, a computer/server can be configured to automatically (or in response to an instruction from a user) send an API call to cause a remote widget-container generation host to generate a widget container.
  • The flow chart shows that a service module and/or a reference to a service module is then received at 310 by, for example, a device configured to define the widget container (e.g., a centralized widget-container host or a widget-container creation device) using, for example, a widget-container generation engine. Similar to the reference to the widget, the reference to the service module can be selected and/or provided using a user-interface configured for defining a widget container.
  • In many embodiments, the user-interface can be configured to provide a set of pre-defined service modules that can be selected by a user for containerization in a widget container. The set can be an entire library of service modules or a selected set of service modules from a library of pre-defined service modules. For example, a user can be prompted via the user-interface to select one of two possible service modules for containerization in the widget container. In some situations the user can be provided with an option not to include a service module in the widget container. The library of service modules can be stored in a location where a service module (or reference) selected from the library of service modules can be accessed for wrapping in the widget container when the widget container is generated.
  • In some embodiments, a set of service modules can be selected/defined based on a library of service modules based on a policy or a threshold condition. For example, a policy can be created such that only a certain type of service module (e.g., polling type service modules) be allowed as an option for containerization in a widget container for a particular user or group of users. In some embodiments, a user and/or group of users can be limited to a certain number of service modules based on a threshold condition. If the widget container is to be generated using a widget-container host in response to a definition provided via a user-interface, the policy can be stored on and enforced by the widget-container host via the user-interface.
  • In some embodiments, the policy used to define a set of service modules can be dependent on the type of the widget being containerized. For example a certain set of service modules can be allowed for containerization in a widget container based on the widget being a video content widget. A different set of service modules can be provided to a user for containerization in a widget container based on the widget being an audio content widget.
  • In some embodiments, a reference (e.g., link) to a user-created service module can be provided by the user to, for example, a widget generation engine via a user-interface so that the user-created service module can be wrapped into the widget container. In some embodiments, a user (or computer system) can be restricted from providing a reference to a user-created service module for wrapping (i.e., containerization) in a widget container. A user can be allowed, in some embodiments, to insert a user-created service module only when the user has been authenticated and/or the user-created service module has been approved for use in the widget container. The user-created service module can be approved based on a policy that is, for example, included in and enforced by a widget-container generation engine.
  • In some embodiments, the service module can be explicitly associated with the widget because the service module performs a function related to the widget. For example, the service module can be a polling service module that is used to collect a user's opinion of a widget. As another example, the service module can be a service module that modifies, for example, the display and/or execution of the widget. The widget can be associated with the service module when the service module is selected and/or provided to a widget-container generation engine. The service module can be explicitly associated with the service module or automatically associated with the widget.
  • After the widget and/or reference to the widget is received at 300 and the service module and/or reference to the service module are received at 310, a widget container that contains the widget and the service module is generated in response to an instruction from a processor at 320. The widget container is a procedural software framework that can be generated as a set of instructions in any number of programming languages that are compiled (e.g., C++) and/or in programming languages that are interpreted (e.g., Java). If the widget container is generated using a set of instructions in a compiled programming language, the generating can include compiling the widget container.
  • The instruction to generate the widget container can be received from a processor in, for example, a widget-container generation host or a widget-container creation device. In some embodiments, the instruction to generate the widget container can be prompted via a user-interface that is associated with a widget generation engine. For example, the user-interface can include a button, that when selected at a remote PDA of a user, triggers the generation of the widget container at a widget-container generation host.
  • A core of the procedural software framework of the widget container manages and controls the service module and/or the widget that is contained in the widget container. The widget container can be configured so that metadata parameter values can be passed to the widget container and used by, for example, the core of the widget container to modify, for example, the general layout (e.g., x, y location and size of the widget) and/or attributes of the widget container (e.g., color, themes, styles, etc.). The metadata parameter values can be stored at and accessed from, for example, a memory associated with a widget-container generation host.
  • When the widget container is generated, a widget-container identifier is associated with the widget container at 330. The widget-container identifier can be an identifier used to uniquely identify the widget container for later retrieval. In some embodiments, the widget container identifier can be, for example, a GUID or an identifier derived from a GUID. The widget is stored for later distribution at 340 on, for example, a widget-container host.
  • In some embodiments, a widget container can be automatically generated by a separate computer and/or server. Also, in some embodiments, the steps identified in FIG. 3 can be performed in a different order. For example, a widget can be received before a service module is received.
  • In some embodiments, different parts of the flow chart can be performed on difference devices. For example, the generating can be performed on a widget-container generation host while the associating can be performed on a different device such as a widget-container creation device. Also, in some embodiments, the widget container can be generated to contain only a service module or a widget.
  • FIG. 4 is a flow chart that illustrates a method for sending a widget container to a widget-container processing device, according to an embodiment of the invention. The flow chart shows that a request for the widget container is received in response to an instance of a reference to the widget container being accessed from a processor-readable vehicle at 400. The request can be defined, for example, when the reference is accessed/read from the processor-readable vehicle at a widget-container processing device. The request can include information from the reference such as a pointer to a unique identifier that can be used to identify the widget container that is being requested. In some embodiments the pointer is a link that can be used to retrieve the widget container or is a widget-container identifier that can be used to identify the widget container. If the processor-readable vehicle is a web-page, for example, the reference can be an embed tag or an object tag that serves as a link to the widget container.
  • Using the information in the request, the widget container is retrieved from a memory at 410. The widget container is, in many embodiments, retrieved so that the widget container can later be sent/served to a container-processing device. For example, the request for a widget container can be received at a widget-container host and the widget container can be retrieved from a memory of the widget-container host based on the request.
  • In some embodiments, the widget container can be dynamically modified at 420 before the widget container is sent/served at 430. For example, data can be dynamically injected into the widget container and used by the widget container to customize, for example, a service module of the widget container (e.g., customize a tracking feature). The data can be, for example, a segment of data that replaces a known segment of data within the widget container. The data can trigger, as another example, the disabling of a service module within the widget container. The widget container can, in some embodiments, be configured to search for and/or request the data before the widget container is served. The data can, in some embodiments, be metadata that is defined by a widget-container originator (e.g., creator or owner), a widget-container placer and/or a widget-container viewer and can be stored at, for example, a widget-container host. In some embodiments, a widget-container host can, for example, dynamically inject data into a widget container based on a policy.
  • The widget container can be sent to a widget-container processing device in response to the request at 430. The sending can also be referred to as serving. For example, if the request is received from a widget-container processing device such as a mobile phone, the widget container is retrieved and sent to the mobile phone for processing and/or display. In some embodiments, the widget container is compiled when served. The widget container can also be generated (or regenerated) when served. In many embodiments, the device that requests the widget container will also be the same device that receives the widget container for processing and/or display.
  • The widget container can be configured so that instances of the widget container can be sent to two or more different widget-container processing devices that each operate based on a different platform. For example, an instance of the widget container can be sent to and executed within a first processor-readable vehicle on a mobile phone and sent to and executed within a second processor-readable vehicle on a personal computer. In some embodiments, the first processor-readable vehicle and the second processor-readable vehicle can be two different instances of the same processor-readable vehicle.
  • FIG. 5 is a schematic diagram that illustrates a widget-container host 500 sending instances of a widget container 505 for execution within the framework of several processor-readable vehicles 530, 540, 550, and 560, according to an embodiment of the invention. The widget container 505 is sent from a memory 510 of the widget-container host 500 over a network 520.
  • Each of the processor-readable vehicles, 530, 540, 550, and 560, include a reference, 532, 542, 552, and 562, respectively, to the widget container 505. Each of the references 532, 542, 552, and 562 can be referred to as an instance. Reference 532 (as an example of the references 532, 542, 552, and 562 included in the processor readable vehicles, 530, 540, 550, and 560, respectively) includes a widget-container (W-C) pointer 534 and a placement identifier (ID) 536. The widget-container pointer 534 is a pointer that is used to identify and request the widget container 505 from the widget-container host 500. The placement ID 536 is used to uniquely identify the placement of reference 532 (instance 532) in processor readable vehicle 530. When one of the references, 532, 542, 552, and 562, is accessed from its respective processor readable vehicle, 530, 540, 550, and 560, at a widget-container processing device (not shown) an instance of the widget container 505 can be sent to the respective processor readable vehicle, 530, 540, 550, and 560.
  • The arrows between the references, 532, 542, 552, and 562, indicate a parentage of the references, 532, 542, 552, and 562. For example, the arrow between reference 532 in processor-readable vehicle 530 and reference 542 in processor-readable vehicle 540 indicates that reference 542 was derived from reference 532. Likewise, reference 552 in processor-readable vehicle 550 was derived from reference 542 in processor-readable vehicle 540.
  • The placement ID's, 536, 546, 556, and 566, associated with the references, 532, 542, 552, and 562, respectively, can be associated with one another as parentage information. Reference 542 (and placement ID 546), for example, can be identified as a child reference to reference 532 (and placement ID 536) in, for example, a parentage table.
  • In some embodiments, the placement ID's, 536, 546, 556, and 566, can be generated using a placement service module 504 included in the widget container 505. When the widget container 505 is executed within processor-readable vehicle 530, for example, after being received at processor-readable vehicle 530 in response to reference 532 being accessed, the placement service module 504 can be used to place an instance of reference 532 in processor-readable vehicle 540. The placement service module 504 can also be used to generate placement ID 546 that identifies the placement of the new instance of the reference 542 within the processor-readable vehicle 540. The placement service module 504 can send an indicator that associates placement ID 536 with placement ID 546. This association can be stored at, for example, the widget-container host 500 and used as parentage information to identify that the instance of the reference 542 was derived from reference 532.
  • The parentage information can be used to associate tracking parameter values associated with instances of widget containers to create collective tracking parameters. For example, tracking parameter values associated with an instance of the widget container 505 sent to processor-readable vehicle 540 and an instance of the widget container sent to processor-readable vehicle 550 can be statistically combined/compiled (e.g., averaged, summed) and stored in, for example, a metadata database. The tracking parameter values associated with each of the instances of widget container 505 can be associated using parentage information. Tracking parameter values of multiple instances of the widget container 505 sent to a single processor-readable vehicle such as, for example, processor-readable vehicle 530 at different times can also be statistically combined and/or compiled. In some embodiments, collective tracking parameters can be used for monetization purposes.
  • In some embodiments, the placement ID's, 536, 546, 556, and 566, can be stored in, for example, a metadata database such that the placement ID's, 536, 546, 556, and 566, can be associated with their respective processor readable vehicles, 530, 540, 550, and 560, even if, for example, an identifier associated with any one of the processor readable vehicles, 530, 540, 550, and 560, changes. For example, if processor readable vehicle 550 is a webpage, the placement ID 556 can be associated with each web address that can be used to request processor-readable vehicle 550.
  • FIG. 6 is a flow chart that illustrates an example method for placing a reference and generating a placement identifier that can be used to generate parentage information, according to an embodiment of the invention. A first instance of a reference to a widget container that contains a first placement identifier is included in a first processor-readable vehicle at 600. The widget container can contain a placement service module that can be used to place a second instance of the reference in a second-processor readable vehicle.
  • The first instance of the reference to the widget container is accessed from the first processor-readable vehicle at a widget-container processing device 610. The widget-container processing device can be, for example, a personal computer. An instance of the widget container is then sent to and executed at the widget-container processing device in response to the first instance of the reference being accessed at 620. The widget container is executed such that the placement service module can be used to place a second instance of the reference in a second processor-readable vehicle. For example, the widget container can be sent to and executed on a personal computer from a database controlled by a widget container host.
  • After the widget container has been executed at the widget-container processing device at 620, a request can be sent to a widget-container host to place a second instance of the reference to the widget container in a second processor-readable vehicle using the placement service module at 630. For example, a user can use the placement service module to request that the second instance of the reference be placed in the second processor-readable vehicle. The widget-container host can then generate and associate a second placement identifier with the second instance of the reference at 640. The first placement identifier and the second placement identifier can both be, for example, GUID's.
  • In some embodiments, a service module (e.g., service placement module) within the widget container can be used to generate the second placement identifier and associate the second placement identifier with the second instance of the reference. In some embodiments, a separate host can be triggered, for example, by the widget-container host and/or a placement service module to generate the second placement identifier and associate the second placement identifier with the second instance of the reference.
  • The second instance of the reference (with the second placement identifier) can then be placed in the second-processor readable vehicle at 650. In some embodiments, the widget container host negotiates with a host server (e.g., using a series of scripted hypertext transfer protocol (HTTP) requests) of the second-processor readable vehicle to place the second instance of the reference (with the second placement identifier) in the second-processor readable vehicle. If the second-processor readable vehicle requires authentication before the second instance of the reference can be placed, the information necessary for authentication (e.g., username, password, etc.) can be securely collected via the placement service module and transmitted to the widget-container host.
  • The first placement identifier and the second placement identifier can be associated as parentage information at 660. The first placement identifier and the second placement identifier can be associated at the widget-container host. For example, the placement service module can be configured to send the first placement identifier (and associated first processor-readable vehicle information) to the widget-container host so that when the widget-container host generates the second placement identifier and places the second instance of the reference in the second processor-readable vehicle the first placement identifier and the second placement identifier can be associated. The first placement identifier can be identified as a parent identifier and the second placement identifier can be identified as a child identifier. Likewise, the first instance of the reference can be identified as a parent reference and the second instance of the reference can be identified as a child reference. This parentage information can be stored in the widget-container host where the parentage information can be used.
  • In some embodiments, the placement service module can be used to place an instance of a reference from a first processor-readable vehicle that is used on a first platform (e.g., personal computer platform) in a second processor-readable vehicle that is used on a second and different platform (e.g., mobile phone platform).
  • FIG. 7 is a schematic diagram of a widget container 700 that contains a widget 710 and a placement service module 720, according to an embodiment of the invention. The placement service module 720 has a dropdown menu 722 that can be used to place an instance of a reference to the widget container in one of several webpages 724.
  • In some embodiments of the invention, metadata parameter values are stored and associated with widget containers, components of widget containers, and other information associated with widget containers (e.g., sessions established during the transmission of widget containers). FIG. 8 is an example metadata database 800 that illustrates some of the metadata parameters and values that can be generated for and associated with widget containers 820, according to an embodiment of the invention. Specifically, this metadata database 800 includes metadata associated with widget containers A and B.
  • The placement ID column 830 includes the placement ID's of instances of references to the widget containers A and B placed in processor-readable vehicles indicated in the processor-readable vehicle column 840. For example, a reference to widget container A has been placed in processor-readable vehicles URL1 and URL2 as indicated in the processor-readable vehicle column 840. Each of these placements has been assigned a unique placement ID as indicated by the placement ID's P1 and P2 included in the placement ID column 830. This metadata database 800 shows that only one placement ID 830 is associated with a single placement in a processor-readable vehicle 840. Multiple identifiers (not shown), however, can be used to identify a single processor-readable vehicle from column 840 (e.g., multiple variations of a single webpage address that point to a single webpage). The identifiers for a processor-readable vehicle can be referred to as vehicle identifiers. Thus, a placement ID 830 can be associated with multiple vehicle identifiers for a single processor-readable vehicle from column 840.
  • In some embodiments, the placement ID's 830 (e.g., P2) and vehicle identifiers for the processor-readable vehicles 840 (e.g., URL2) can be combined to create unique identifiers for the placement ID and processor-readable vehicle combinations. These unique identifier that are combinations of the placement ID's 830 and the processor-readable vehicles 840 can be used as pointers to the widget containers 820, for example, when included in a reference (e.g., embed tag) of a processor-readable vehicle 840. These unique combined identifiers can be encrypted and/or encoded using an algorithm and un-encrypted and/or decoded using the algorithm (or a different algorithm) when used by, for example, a widget container host.
  • Also this exemplary embodiment shows that URL2 includes two different widget containers A and B. Each of the widget containers A and B are associated with unique placement ID's P2 and P3, respectively. Unique metadata (e.g., viewer preferences) can be associated with each of these placements (i.e., instances).
  • The session ID column 850 indicates the unique session ID's of sessions that have been established and used for sending, for example, widget container A to the processor-readable vehicle URL1 associated with placement ID P1. The metadata database 800 shows that an instance of widget container A has been sent using a session with session ID 1 in response to the reference associated with placement ID P1 being accessed from processor-readable vehicle URL1.
  • The widget column 860 includes data that indicates the widgets 860 that have been contained in the widget containers 820. In this embodiment, only a single widget 860 is contained in each of the widget containers 820. In some embodiments, the widget containers 820 can include more than one widget 820. For example, the widget container A can include two widgets, for example, for a specific placement ID 830.
  • The service module column 870 includes data that indicates the service modules that are contained in the widget containers 820 for each of the placement ID's 830. For example, the metadata database 800 shows that widget container A for placement ID P1 contains service module J while the widget container B contains service modules J and L for placement ID P2 during both session ID's 2 and 3.
  • A tracking parameter column 880 includes tracking parameter values that can be associated with any of the metadata in the metadata database 800 (e.g., placement ID 830 data, processor-readable vehicle 840 data, session ID 850 data, widget 860 data, and/or service module 870 data, etc.). A value of the tracking parameter 880 can be collected and/or generated using, for example, a module, such as a tracking kernel/module, integrated into the procedural software framework of the widget container. A value of the tracking parameter 880 can indicate, for example, the number of times that a particular user has interacted with (e.g., moused over, clicked on) widget container B during a particular session ID 850.
  • A widget-container attribute column 890 includes widget-container attribute metadata can be associated with, for example, the widget containers 820. In some embodiments, the widget-container attribute data can be associated with a particular placement ID 830. The widget-container attribute metadata can be associated with, for example, the size of a widget 860 when displayed, widget container behavior (animation action). The widget-container attribute 890 metadata can be passed to the core of the widget container when the widget container is served. The widget-container attribute 890 metadata which can define the widget container can be used to generate a widget container when served.
  • The metadata shown in FIG. 8 is an example of the types of metadata that can be stored in a metadata database 800. A metadata database 800 can be configured to include a variety of metadata that can be associated with widget containers 820 and/or widget container related information (e.g., sessions, placement ID's). For example, a database such as metadata database 800 can be modified to include parentage information that shows whether an instance of the reference associated with placement ID P2 is derived from an instance of the reference associated with placement ID P1. In some embodiments, author information (e.g., actual name and/or username, profile) of an entity that created a particular widget container 820 can also be collected and stored in metadata database 800. In some embodiments, author information can be collected specifically for the placement ID's 830. Placer information (e.g., profile) of an entity that placed a reference to, for example, widget container A in processor-readable vehicle URL2 can also be stored. In some embodiments, login information can be stored for each session ID 850.
  • Metadata stored within the metadata database 800 can be collected and/or generated using, for example, one or more service modules 870 contained in any of the widget containers 820. For example, a preference, which can be stored as metadata, for a particular configuration of widget container A (e.g., theme or style) can be collected from a user via a service module J that includes a feature that allows a user to select a theme. As another example, a weather related service module can collect a zip code so that weather related to an area relevant to the user can be displayed in, for example, widget container B. The sip code can be stored as a metadata parameter value.
  • In some embodiments, comments made by a user using a service module can be collected and associated with a widget container 820, placement ID 830, processor-readable vehicle 840, etc. The comments made by a user can be stored as metadata parameter value in the metadata database 800. In some embodiments, rating/polling information (e.g., opinion of a widget on a scale of 1 to 10) collected using a service module can be stored as a metadata parameter value in the metadata database 800. In some embodiments, tagging and/or categorization data (e.g., user-defined tagging/categorization of widgets) collected using a service module can also be stored as metadata in the metadata database 800.
  • Metadata within a metadata database 800 can be further included in at least one of three categories: widget-container originator (“originator”) metadata, widget-container placer (“placer”) metadata, and/or widget-container viewer (“viewer”) metadata. An originator is an entity (e.g., user) that triggers the generation of a widget container and/or owns (e.g., retains administrative read, write, and execute rights over the widget container) the widget container. A widget-container placer is an entity that can place a widget in a particular processor-readable vehicle. Often a widget-container placer can have control (e.g., owner) of the processor-readable vehicle where a reference to the widget container is placed. A viewer is an entity (e.g., computer or user) that views and/or interacts with a widget container via a processor-readable vehicle (e.g., one that is owned by the widget-container placer).
  • For example, an identifier (e.g., username, placer identifier) of a widget-container placer can be associated with a placement ID 830. An identifier (e.g., username, viewer identifier) of a viewer can be associated with a particular tracking parameter 880 and/or a session ID 850. In some embodiments, the session can be triggered by a particular widget-container viewer. In many embodiments, an identifier (e.g., username, originator identifier) associated with an originator can be included in the metadata database 800 as author information.
  • The rights (e.g., read, write, execute, etc.) associated with a widget-container and/or its components can also be assigned and/or delegated based on, for example, a username. An originator, as an administrative owner of a particular widget container, can delegate rights to widget-container placers and/or widget-container viewers. The rights can include not only interaction rights (e.g., rights to access or execute certain portions of a widget container), but also rights to create certain types of metadata. The rights of the originator can, in some embodiments, be limited by a policy implemented by, for example, a widget-container generation engine. For example, a specific originator may not be granted rights (e.g., not authorized via an authentication process) to containerize a specific type of widget in a widget container.
  • An originator can containerize, for example, a service module in a widget container that allows a widget-container placer and/or viewer to perform a specific function. For example, an originator can include a placement service module in a widget container that allows a placer to place a widget container while only allowing a viewer rights only to execute and/or view a widget container. As another example, a widget originator can include a service module in a widget container that allows a viewer to modify a theme of the widget container. In some embodiments, a placer can delegate rights to a viewer within the scope of rights delegated from an originator and/or based on rights granted by a widget-container generation engine when a widget container is generated. A person of ordinary skill in the art should appreciate that rights can be assigned in a variety of hierarchies and/or using a variety of methods.
  • The widget-container originator metadata can be referred to as global metadata because changes made to a widget container by a originator can be propagated to all instances of widget containers when served for viewing within a processor-readable vehicle. For example, a change to a widget container by the widget-container originator to a theme of the widget container can be propagated to all instances of widget containers when executed with a processor-readable vehicle.
  • The placer metadata can be referred to as local metadata because, for example, preferences of a placer stored as metadata can be associated only with the placement of a reference to the widget-container in a specific processor-readable vehicle. The widget container can be modified according to the preferences of the placer when the widget container is served to the processor-readable vehicle associated with (e.g., owned by) the placer. The placer metadata can, in some embodiments, also be global metadata that can cause changes to all instances of widget containers.
  • The viewer metadata and metadata parameter values can be quasi-local metadata because, for example, preferences of a viewer stored as metadata can be associated with one or more placements of a reference to the widget-container. The viewer metadata parameter values can be used to configure (or dynamically configure) one or more widget containers. For example, a first viewer metadata parameter value associated with a viewer can be used to configure a first widget container served to a processor-readable vehicle while a second viewer metadata parameter value associated with the same viewer can be used to configure a second widget-container served to the same processor-readable vehicle. In some embodiments, a first viewer metadata parameter value associated with a viewer can be associated with a first placement of a widget and a second viewer metadata parameter value associated with the same viewer can be associated with a second placement of the same widget. The first placement and the second placement can be included in a single processor-readable vehicle.
  • In some embodiments, a viewer metadata parameter value can be associated with a widget container no matter how many instances of the widget container are served and/or regardless of which processor-readable vehicles the widget container is served to. The viewer metadata can be associated with an instance of the widget container based on the credentials (e.g., viewer identifier, username/password) of the viewer. The credentials can be collected when the widget container is requested from, for example, a processor-readable vehicle. The credentials of the viewer can then be used to find viewer metadata that can later be used to dynamically modify the widget container when the widget container is served. In some embodiments, viewer metadata can be configured as local or global metadata.
  • The metadata parameter values stored in the metadata database 800 can be retrieved and used by, for example, a widget-container host when serving a widget container in response to a request for the widget container from a widget-container processing device. FIG. 9 is a schematic diagram illustrating a widget-container host 900 accessing metadata from a metadata database 910, according to an embodiment of the invention. The widget-container host 900 can be configured to retrieve and/or write metadata to the metadata database 910 at various times.
  • For example, the widget-container host 900 can be configured to store metadata when the widget container 950 is first generated and store metadata when the widget container 950 is executed and/or accessed. In some embodiments, the widget-container host 900 can receive a metadata parameter value via a service module 954 of the widget container 950 and the widget-container host 900 can store the metadata parameter value in the metadata database 910. In some embodiments, the widget-container host 900 can receive a metadata parameter value such as a tracking parameter value in response to a user-triggered interaction with the widget container 950 and can store the tracking parameter value in the metadata database 910. In some embodiments, tracking parameter values are not sent from the widget container until the widget container 950 is closed (e.g., no longer being executed).
  • In some embodiments, the widget-container host 900 can be configured to retrieve information to dynamically modify a widget container when serving the widget container 950 and/or after the widget container 950 has been served. For example, a preference stored as a metadata parameter value in the metadata database can be retrieved and used to configured the widget container 950 before a widget container 950 is sent over a network 980 for execution within a framework of a processor-readable vehicle 920 in response to a reference to the widget container 950 being accessed from the processor-readable vehicle 920. The preference can be stored as a local metadata parameter value, global metadata parameter value, an originator metadata parameter value, placer metadata parameter value, and/or viewer metadata parameter value.
  • For example, the preference can be a local metadata preference (e.g., style, location) associated with an instance of a reference associated with the processor-readable vehicle 920 or a preference associated with a separate instance of the reference in a different processor-readable vehicle (not shown). The preference can be retrieved, for example, after receiving a request for the widget container 950 and used by the widget-container host 900 to modify the widget container 950 just before an instance of the widget container 950 is served to the container processing device 940.
  • In some embodiments, the metadata database 910 is a single database or set of databases included in the widget-container host 900. The metadata database 910 can also be accessed by the widget-container host 900 via a network such as network 980.
  • In some embodiments, the widget container 950 can include a core framework that has at least some portions that are defined by metadata parameter values stored in the metadata database 910 (or received in a request for the widget container 950). For example, the size/color/theme of the widget container 950, the widget 952 and/or service module 954 contained in the widget container 950, etc. can be defined using metadata parameter values stored in the metadata 910. The metadata parameter values that are used to define the widget container 950 can be retrieved just before an instance of the widget container 950 is served to the widget-container processing device 940 (e.g., for execution within the framework of the processor-readable vehicle 920). The widget container 950 can be generated (or regenerated) based on the defined metadata parameter values.
  • FIG. 10 is a flow chart that illustrates a method for dynamically modifying a widget container, according to an embodiment of the invention. The flow chart shows that a widget container that contains a widget and a service module is generated at 1000. A metadata parameter value associated with the widget container is received at 1010. The metadata parameter value can be a local metadata parameter value and/or global metadata parameter value associated with, for example, an originator, placer, and/or viewer.
  • A request for the widget container is received when an instance of a reference to the widget container is accessed from a processor-readable vehicle at 1020. The widget container is modified based on the metadata parameter value at 1030. The widget container can be modified at, for example, a widget-container host according to a metadata parameter value accessed from a metadata database. The metadata parameter value can also be a metadata parameter value included in the request for the widget container.
  • After the widget container has been modified at 1030, the modified widget container is sent to the widget-container processing device in response to the request at 1040. Although the flow chart shows that the metadata parameter value is received at 1010 before a request for the widget container is received at 1020, the metadata parameter value can be received at any time before the widget container is modified. Also, the modifying of the widget container includes defining the widget container according to the metadata parameter values.
  • The widget container can also be modified after the widget container has been served at 1050 to the widget-container processing device. For example, a viewer, originator (e.g., creator/owner), and/or placer of the widget container can modify and/or define a parameter, for example, that can be used to modify the widget container. In some embodiments, the parameter can be modified and/or defined at the widget-container processing device using, for example, a service module included in the widget container (i.e., user-triggered interaction). In some embodiments, the parameter can be sent to a widget container host that defines an instruction that can then be sent to the widget-container processing device so that the widget-container processing device can modify the widget container according to the instruction.
  • In some embodiments of the invention, metadata parameter values can be used to search for and/or identify a portion of a widget container. For example, a metadata parameter value search can be used to identify a widget, service module, and/or widget container, for example, for execution or display within a processor readable vehicle.
  • FIG. 11 is a flow chart that illustrates a method for retrieving a widget using metadata parameter values, according to an embodiment of the invention. The flow chart shows that a widget container that contains a first widget is sent to a widget-container processing device at 1100. The widget container can be sent to the widget-container processing device from a widget-container host in response to a reference to the widget container being accessed at a processor-readable vehicle.
  • A request for a second widget based on the first widget is received via a service module at 1110. The request can be received at, for example, a widget-container host from the widget-container processing device. The request can be, for example, a request to retrieve a second widget similar in content to (e.g., like) the first widget.
  • A metadata parameter value associated with the first widget is received in response to the request at 1120. The parameters of the request, when received at, for example, a widget-container host, can be used to retrieve a metadata parameter value associated with the first widget. The metadata parameter value associated with the first widget can then be used to retrieve a second widget. For example, if the request is for a second widget containing content like the first widget, a metadata parameter value that describes the content of the first widget can be retrieved.
  • The metadata parameter value associated with the first widget is associated with a metadata parameter value of the second widget at 1130. The metadata parameter value associated with the first widget is used, for example, to search for and retrieve the metadata parameter value of the second widget from a metadata database. The associating of the metadata parameter values can be based on a threshold criteria (e.g., policy) within a search engine. In this embodiment, the second widget is of a different content type than the first widget (e.g., the first widget is a video widget and the second widget is an image widget or software widget). In some embodiments, the second widget is the same content type as the first widget.
  • Finally, after the second widget is identified using the metadata parameter value from the first widget, the second widget is sent to the widget-container processing device at 1140. The second widget can be, for example, executed and/or displayed within the procedural software framework of the widget container.
  • In conclusion, the present invention provides an apparatus and methods for containerization 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 (32)

1.-23. (canceled)
24. A method, comprising:
receiving at a widget-container host a widget or a reference to the widget;
generating, at a first time, at least a portion of a widget container, the widget container being a procedural software framework including the widget or the reference to the widget and a first service module configured to provide a first service associated with the widget, the widget container configured to be executed at a widget-container processing device in response to a user-initiated request; and
regenerating, at a second time different than the first time, the widget container such that the widget container includes a second service module configured to provide a second service associated with the widget, the second service being different from the first service.
25. The method of claim 24, wherein the widget is at least one of a static data object, a media object, or a software object.
26. The method of claim 24, further comprising:
receiving a request for the widget container from the widget-container processing device, the generating being in response to the receiving the request.
27. The method of claim 24, wherein the generating includes compiling the widget container as a discrete portable module.
28. The method of claim 24, wherein the reference to the widget is provided to the widget-container host via a widget-container generation engine, and the first service module is selected via a widget-container generation user-interface associated with the widget-container generation engine.
29. The method of claim 24, wherein the first service module is configured to perform at least one of a metadata searching function, a metadata retrieval function, a polling function, a widget container deployment function, a transaction service function, a widget container tracking function, a referral service function, an advertisement service function, or a directory service function.
30. The method of claim 24, wherein the user-initiated request is a first user initiated request, the regenerating being in response to a second user-initiated request, the method further comprising:
sending an indication of the second user-initiated request to a tracking server.
31. The method of claim 24, wherein the generating is in response to a user-initiated request from a webpage containing a reference to the widget container, the reference to the widget container being an embed tag or an object tag on the webpage that is configured to serve as a link to the widget container.
32. The method of claim 24, wherein the widget container includes a series of instructions configured to be executed by the widget-container processing device to provide an executable environment for the widget.
33. The method of claim 24, further comprising:
selecting, before the generating, the first service module from a library of service modules based on a policy.
34. The method of claim 24, wherein the widget has a content type,
the method further comprising:
selecting, before the generating, the first service module from a library of service modules based the content type.
35. The method of claim 24, wherein the widget container is configured to be executed within a webpage at the widget-container processing device.
36. The method of claim 24, wherein the reference to the widget container is a first reference, the widget container is configured to be executed within a first webpage, the first service module being a placement service module associated with placing a second reference to the widget container in a second webpage.
37. A method, comprising:
receiving at a widget-container host a request for a widget container, the request being defined in response to a first reference to the widget container being accessed via a processor-readable vehicle;
defining the widget container, the widget container being a procedural software framework including a widget or a reference to the widget, the widget container including an identifier indicating that the widget container was derived from a second reference to the widget container; and
sending, from the widget-container host, the widget container to the widget-container processing device.
38. The method of claim 37, wherein the widget is at least one of a static data object, a media object, or a software object.
39. The method of claim 37, wherein the widget container includes a service module configured to generate the identifier in response to a user-initiated request associated with the second reference to the widget container being accessed.
40. The method of claim 37, wherein the sending includes sending the widget container based on a unique widget container identifier included in the request.
41. The method of claim 37, wherein the widget container is configured to be executed at the widget-container processing device.
42. The method of claim 37, wherein,
the reference to the widget is configured such that the widget is served into the widget container from a widget server independent from the widget-container host in response to the reference to the widget being accessed at the widget-container processing device.
43. The method of claim 37, wherein the widget-container processing device is a first widget-container processing device, the defining includes establishing a session between a second widget-container processing device and the widget-container host,
the method further comprising:
associating with the session a global metadata parameter value or a local metadata parameter value; and
modifying the widget container based on the global metadata parameter value or the local metadata parameter value.
44. The method of claim 37, wherein the widget-container processing device is a first widget-container processing device, the defining includes establishing a session between a second widget-container processing device and the widget-container host, the receiving includes receiving at a first time, the sending includes sending at a second time, the second time being after the first time,
the method further comprising:
associating with the session a global metadata parameter value or a local metadata parameter value; and
modifying the widget container based on the global metadata parameter value or the local metadata parameter value at an intermediate time by injecting a segment of data into a specified location of the widget container, the intermediate time being before the second time and after the first time.
45. A non-transitory processor-readable medium storing code representing instructions to be executed by a processor, the code comprising code to cause the processor to:
place a first reference to a widget container in a first processor-readable vehicle;
receive a first user-initiated request for the widget container from a widget-container processing device in response to the first reference being accessed;
send the widget container to the widget-container processing device in response to the first user-initiated request, the widget container including a placement service module;
receive, from the widget-container processing device, a second user-initiated request in response to the placement service module being accessed;
generate, in response to the second user-initiated request a second reference to the widget container and a placement identifier;
place the second reference to the widget container in a second processor-readable vehicle; and
associate the placement identifier with an identifier associated with the first reference.
46. The non-transitory processor-readable medium of claim 45, wherein the widget container includes a widget or a reference to the widget, the widget being at least one of a static data object, a media object, or a software object.
47. The non-transitory processor-readable medium of claim 45, wherein the widget container is a discrete portable module.
48. The non-transitory processor-readable medium of claim 45, wherein the widget container includes a series of instructions configured to be executed by the widget-container processing device to provide an executable environment for a widget.
49. The non-transitory processor-readable medium of claim 45, wherein at least one of the first processor-readable vehicle or the second processor-readable vehicle is a webpage.
50. The non-transitory processor-readable medium of claim 45, wherein the first processor-readable vehicle is a webpage, the first reference being an embed tag or an object tag on the webpage that serves as a link to the widget container.
51. The non-transitory processor-readable medium of claim 45, wherein the code to cause the processor to receive the second user-initiated request includes code to cause the processor to receive the second user-initiated request at a first time, the code to cause the processor to place the second reference including code to cause the processor to place the second reference at a second time, the second time being after the first time,
the processor-readable medium further comprising code to cause the processor to:
modify at an intermediate time the widget container by injecting a segment of data into a specified location of the widget container, the intermediate time being before the second time and after the first time.
52. The non-transitory processor-readable medium of claim 45, wherein the code to cause the processor to receive the second user-initiated request includes code to cause the processor to receive the second user-initiated request at a first time, the code to cause the processor to place the second reference including code to cause the processor to place the second reference at a second time, the second time being after the first time,
the processor-readable medium further comprising code to cause the processor to:
modify at an intermediate time the widget container by injecting a segment of data associated with the first user-initiated request or the second user initiated request into a specified location of the widget container, the intermediate time being before the second time and after the first time.
53. The non-transitory processor-readable medium of claim 45 further comprising code to cause the processor to:
generate, before the placing of the first reference, the widget container and the placement service module.
54. The non-transitory processor-readable medium of claim 45, wherein the first reference is a reference to a first instance of the widget container, the second reference being a reference to a second instance of the widget container,
the processor-readable medium further comprising code to cause the processor to:
generate, before the placing of the first reference, the first instance of the widget container and the placement service module; and
generate, before the placing of the second reference, the second instance of the widget container.
US13/290,192 2006-09-29 2011-11-07 Method and apparatus for widget-container hosting and generation Abandoned US20120227060A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US13/290,192 US20120227060A1 (en) 2006-09-29 2011-11-07 Method and apparatus for widget-container hosting and generation

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US11/537,362 US8056092B2 (en) 2006-09-29 2006-09-29 Method and apparatus for widget-container hosting and generation
US13/290,192 US20120227060A1 (en) 2006-09-29 2011-11-07 Method and apparatus for widget-container hosting and generation

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US11/537,362 Continuation US8056092B2 (en) 2006-09-29 2006-09-29 Method and apparatus for widget-container hosting and generation

Publications (1)

Publication Number Publication Date
US20120227060A1 true US20120227060A1 (en) 2012-09-06

Family

ID=39529203

Family Applications (2)

Application Number Title Priority Date Filing Date
US11/537,362 Active 2029-06-16 US8056092B2 (en) 2006-09-29 2006-09-29 Method and apparatus for widget-container hosting and generation
US13/290,192 Abandoned US20120227060A1 (en) 2006-09-29 2011-11-07 Method and apparatus for widget-container hosting and generation

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US11/537,362 Active 2029-06-16 US8056092B2 (en) 2006-09-29 2006-09-29 Method and apparatus for widget-container hosting and generation

Country Status (1)

Country Link
US (2) US8056092B2 (en)

Cited By (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20130117132A1 (en) * 2011-11-04 2013-05-09 Ashay Vinayak Padwal System for inserting services in a software application
US20130132809A1 (en) * 2011-11-22 2013-05-23 National Chiao Tung University Structure and method for widget personalization and widget interaction
US20130167073A1 (en) * 2011-12-22 2013-06-27 SAP Portals Israel Ltd., a German corporation Smart and flexible layout context manager
US20140229297A1 (en) * 2013-02-08 2014-08-14 Nicholas Naveen Rau Methods and apparatus for efficient execution of modules
WO2015048375A1 (en) 2013-09-27 2015-04-02 Cinsay, Inc. N-level replication of supplemental content
US9113214B2 (en) 2008-05-03 2015-08-18 Cinsay, Inc. Method and system for generation and playback of supplemented videos
US9332302B2 (en) 2008-01-30 2016-05-03 Cinsay, Inc. Interactive product placement system and method therefor
US9451010B2 (en) 2011-08-29 2016-09-20 Cinsay, Inc. Containerized software for virally copying from one endpoint to another
US9495084B2 (en) 2007-03-06 2016-11-15 Oracle International Corporation Method and apparatus for widget and widget-container distribution control based on content rules
US9552433B2 (en) 2006-07-06 2017-01-24 Oracle International Corporation Generic content collection systems
US9607330B2 (en) 2012-06-21 2017-03-28 Cinsay, Inc. Peer-assisted shopping
US9875489B2 (en) 2013-09-11 2018-01-23 Cinsay, Inc. Dynamic binding of video content
US10055768B2 (en) 2008-01-30 2018-08-21 Cinsay, Inc. Interactive product placement system and method therefor
US10701127B2 (en) 2013-09-27 2020-06-30 Aibuy, Inc. Apparatus and method for supporting relationships associated with content provisioning
US10789631B2 (en) 2012-06-21 2020-09-29 Aibuy, Inc. Apparatus and method for peer-assisted e-commerce shopping
CN112256384A (en) * 2020-09-22 2021-01-22 杭州指令集智能科技有限公司 Service set processing method and device based on container technology and computer equipment
US11227315B2 (en) 2008-01-30 2022-01-18 Aibuy, Inc. Interactive product placement system and method therefor

Families Citing this family (62)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP5235665B2 (en) * 2005-08-01 2013-07-10 ノキア コーポレイション Method, apparatus and computer program product for automatically obtaining custom interface elements by querying a remote repository upon UI theme change
US8150939B1 (en) * 2007-05-11 2012-04-03 Oracle America, Inc. Method and system for wrapping and componentizing javascript centric widgets using java components
US8578330B2 (en) * 2007-06-11 2013-11-05 Sap Ag Enhanced widget composition platform
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
US20090235149A1 (en) * 2008-03-17 2009-09-17 Robert Frohwein Method and Apparatus to Operate Different Widgets From a Single Widget Controller
US9720554B2 (en) * 2008-07-23 2017-08-01 Robert J. Frohwein Method and apparatus to operate different widgets from a single widget controller
US20100037157A1 (en) * 2008-08-05 2010-02-11 International Business Machines Corp. Proactive machine-aided mashup construction with implicit and explicit input from user community
US8719896B2 (en) * 2008-09-16 2014-05-06 Oracle International Corporation Widget host container component for a rapid application development tool
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
US20100115438A1 (en) * 2008-11-05 2010-05-06 Yu-Chung Chu Method for creating multi-level widgets and system thereof
US9542700B2 (en) * 2008-11-05 2017-01-10 Yu-Hua Chu Business model based on multi-level application widgets and system thereof
KR20100078137A (en) * 2008-12-30 2010-07-08 삼성전자주식회사 Method and apparatus for providing widget service in portable terminal
US8495566B2 (en) * 2009-07-28 2013-07-23 International Business Machines Corporation Widget combos: a widget programming model
US20110047449A1 (en) * 2009-08-23 2011-02-24 Bank Of America Corporation Widget Framework
US9201665B2 (en) * 2009-08-23 2015-12-01 Bank Of America Corporation Outputting presentation code updated for a particular user in response to receiving a page identifier
US9032368B2 (en) * 2009-08-23 2015-05-12 Bank Of America Corporation Dynamic configuration system
US20110078678A1 (en) * 2009-09-30 2011-03-31 Open Kernel Labs Methods and apparatus for producing cross-platform software applications
US9513882B2 (en) * 2010-04-15 2016-12-06 Microsoft Technology Licensing, Llc Platform independent presentation composition
US10733540B2 (en) 2010-05-26 2020-08-04 Automation Anywhere, Inc. Artificial intelligence and knowledge based automation enhancement
US9462042B2 (en) * 2010-05-26 2016-10-04 Tethys Solutions LLC System and method for enabling application discovery by automation needs
US10430180B2 (en) 2010-05-26 2019-10-01 Automation Anywhere, Inc. System and method for resilient automation upgrade
WO2012054786A1 (en) 2010-10-20 2012-04-26 Playspan Inc. Flexible monetization service apparatuses, methods and systems
US8972873B2 (en) * 2010-11-30 2015-03-03 International Business Machines Corporation Multi-environment widget assembly, generation, and operation
US10438176B2 (en) 2011-07-17 2019-10-08 Visa International Service Association Multiple merchant payment processor platform apparatuses, methods and systems
US20130030922A1 (en) * 2011-07-26 2013-01-31 Google Inc. System and method for syndicating a conversation
US9064111B2 (en) * 2011-08-03 2015-06-23 Samsung Electronics Co., Ltd. Sandboxing technology for webruntime system
US10318941B2 (en) * 2011-12-13 2019-06-11 Visa International Service Association Payment platform interface widget generation apparatuses, methods and systems
US8893225B2 (en) 2011-10-14 2014-11-18 Samsung Electronics Co., Ltd. Method and apparatus for secure web widget runtime system
WO2013090611A2 (en) * 2011-12-13 2013-06-20 Visa International Service Association Dynamic widget generator apparatuses, methods and systems
US9953378B2 (en) * 2012-04-27 2018-04-24 Visa International Service Association Social checkout widget generation and integration apparatuses, methods and systems
CA2899022A1 (en) * 2013-01-23 2014-07-31 Cardinalcommerce Corporation Framed implementation for payment widgets
US20160041698A1 (en) * 2014-08-05 2016-02-11 Vladimlr Tkach Enhanced Object Organization in a Container
US9448972B2 (en) * 2014-10-09 2016-09-20 Wrap Media, LLC Wrap package of cards supporting transactional advertising
US11216468B2 (en) 2015-02-08 2022-01-04 Visa International Service Association Converged merchant processing apparatuses, methods and systems
WO2019003246A1 (en) 2017-06-26 2019-01-03 Nasdaq, Inc. Systems and methods for enterprise web application dashboard management
US11775814B1 (en) 2019-07-31 2023-10-03 Automation Anywhere, Inc. Automated detection of controls in computer applications with region based detectors
US10853097B1 (en) 2018-01-29 2020-12-01 Automation Anywhere, Inc. Robotic process automation with secure recording
US10769427B1 (en) 2018-04-19 2020-09-08 Automation Anywhere, Inc. Detection and definition of virtual objects in remote screens
US10733329B1 (en) * 2018-04-20 2020-08-04 Automation Anywhere, Inc. Robotic process automation system and method with secure credential vault
US10908950B1 (en) 2018-04-20 2021-02-02 Automation Anywhere, Inc. Robotic process automation system with queue orchestration and task prioritization
US11354164B1 (en) 2018-04-20 2022-06-07 Automation Anywhere, Inc. Robotic process automation system with quality of service based automation
US10778646B2 (en) * 2018-05-07 2020-09-15 Cisco Technology, Inc. Globally deployable context aware VPN headends in scale through namespaces
US11693923B1 (en) 2018-05-13 2023-07-04 Automation Anywhere, Inc. Robotic process automation system with hybrid workflows
US10747552B2 (en) * 2018-06-04 2020-08-18 Sap Se Context framework
US11226727B2 (en) * 2018-11-12 2022-01-18 Citrix Systems, Inc. Systems and methods for live tiles for SaaS
US11556362B2 (en) 2019-03-31 2023-01-17 Automation Anywhere, Inc. Robotic process automation system with device user impersonation
US11301224B1 (en) 2019-04-30 2022-04-12 Automation Anywhere, Inc. Robotic process automation system with a command action logic independent execution environment
US11113095B2 (en) 2019-04-30 2021-09-07 Automation Anywhere, Inc. Robotic process automation system with separate platform, bot and command class loaders
US11614731B2 (en) 2019-04-30 2023-03-28 Automation Anywhere, Inc. Zero footprint robotic process automation system
US11243803B2 (en) 2019-04-30 2022-02-08 Automation Anywhere, Inc. Platform agnostic robotic process automation
US11481304B1 (en) 2019-12-22 2022-10-25 Automation Anywhere, Inc. User action generated process discovery
US10911546B1 (en) 2019-12-30 2021-02-02 Automation Anywhere, Inc. Robotic process automation with automated user login for multiple terminal server hosted user sessions
US11348353B2 (en) 2020-01-31 2022-05-31 Automation Anywhere, Inc. Document spatial layout feature extraction to simplify template classification
US11514154B1 (en) 2020-01-31 2022-11-29 Automation Anywhere, Inc. Automation of workloads involving applications employing multi-factor authentication
US11086614B1 (en) 2020-01-31 2021-08-10 Automation Anywhere, Inc. Robotic process automation system with distributed download
US11182178B1 (en) 2020-02-21 2021-11-23 Automation Anywhere, Inc. Detection of user interface controls via invariance guided sub-control learning
US11734061B2 (en) 2020-11-12 2023-08-22 Automation Anywhere, Inc. Automated software robot creation for robotic process automation
US11782734B2 (en) 2020-12-22 2023-10-10 Automation Anywhere, Inc. Method and system for text extraction from an application window for robotic process automation
US11820020B2 (en) 2021-07-29 2023-11-21 Automation Anywhere, Inc. Robotic process automation supporting hierarchical representation of recordings
US11556351B1 (en) * 2021-10-13 2023-01-17 International Business Machines Corporation Facilitation of application containerization

Family Cites Families (133)

* 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
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
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
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
US5892900A (en) * 1996-08-30 1999-04-06 Intertrust Technologies Corp. Systems and methods for secure transaction management and electronic rights protection
US7143290B1 (en) * 1995-02-13 2006-11-28 Intertrust Technologies Corporation Trusted and secure techniques, systems and methods for item delivery and execution
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
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
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
US6721713B1 (en) * 1999-05-27 2004-04-13 Andersen Consulting Llp Business alliance identification in a web architecture framework
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
US7130807B1 (en) * 1999-11-22 2006-10-31 Accenture Llp Technology sharing during demand and supply planning in a network-based supply chain environment
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
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
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
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
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
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
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
US7467399B2 (en) * 2004-03-31 2008-12-16 International Business Machines Corporation Context-sensitive confidentiality within federated environments
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
US8566732B2 (en) * 2004-06-25 2013-10-22 Apple Inc. Synchronization of widgets and dashboards
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
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
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
US8543824B2 (en) * 2005-10-27 2013-09-24 Apple Inc. Safe distribution and use of content
US9104294B2 (en) * 2005-10-27 2015-08-11 Apple Inc. Linked 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
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
WO2008021332A2 (en) * 2006-08-11 2008-02-21 Fox Interactive Media Labs System and method for automatically updating a widget on a desktop
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
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
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
US8275681B2 (en) * 2007-06-12 2012-09-25 Media Forum, Inc. Desktop extension for readily-sharable and accessible media playlist and media

Cited By (48)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US9552433B2 (en) 2006-07-06 2017-01-24 Oracle International Corporation Generic content collection systems
US9495084B2 (en) 2007-03-06 2016-11-15 Oracle International Corporation Method and apparatus for widget and widget-container distribution control based on content rules
US9344754B2 (en) 2008-01-30 2016-05-17 Cinsay, Inc. Interactive product placement system and method therefor
US10055768B2 (en) 2008-01-30 2018-08-21 Cinsay, Inc. Interactive product placement system and method therefor
US9986305B2 (en) 2008-01-30 2018-05-29 Cinsay, Inc. Interactive product placement system and method therefor
US9351032B2 (en) 2008-01-30 2016-05-24 Cinsay, Inc. Interactive product placement system and method therefor
US9674584B2 (en) 2008-01-30 2017-06-06 Cinsay, Inc. Interactive product placement system and method therefor
US10425698B2 (en) 2008-01-30 2019-09-24 Aibuy, Inc. Interactive product placement system and method therefor
US9332302B2 (en) 2008-01-30 2016-05-03 Cinsay, Inc. Interactive product placement system and method therefor
US9338499B2 (en) 2008-01-30 2016-05-10 Cinsay, Inc. Interactive product placement system and method therefor
US9338500B2 (en) 2008-01-30 2016-05-10 Cinsay, Inc. Interactive product placement system and method therefor
US10438249B2 (en) 2008-01-30 2019-10-08 Aibuy, Inc. Interactive product system and method therefor
US11227315B2 (en) 2008-01-30 2022-01-18 Aibuy, Inc. Interactive product placement system and method therefor
US10986412B2 (en) 2008-05-03 2021-04-20 Aibuy, Inc. Methods and system for generation and playback of supplemented videos
US9210472B2 (en) 2008-05-03 2015-12-08 Cinsay, Inc. Method and system for generation and playback of supplemented videos
US10225614B2 (en) 2008-05-03 2019-03-05 Cinsay, Inc. Method and system for generation and playback of supplemented videos
US9113214B2 (en) 2008-05-03 2015-08-18 Cinsay, Inc. Method and system for generation and playback of supplemented videos
US9813770B2 (en) 2008-05-03 2017-11-07 Cinsay, Inc. Method and system for generation and playback of supplemented videos
US9451010B2 (en) 2011-08-29 2016-09-20 Cinsay, Inc. Containerized software for virally copying from one endpoint to another
US10171555B2 (en) 2011-08-29 2019-01-01 Cinsay, Inc. Containerized software for virally copying from one endpoint to another
US11005917B2 (en) 2011-08-29 2021-05-11 Aibuy, Inc. Containerized software for virally copying from one endpoint to another
US20130117132A1 (en) * 2011-11-04 2013-05-09 Ashay Vinayak Padwal System for inserting services in a software application
US20130132809A1 (en) * 2011-11-22 2013-05-23 National Chiao Tung University Structure and method for widget personalization and widget interaction
US20130167079A1 (en) * 2011-12-22 2013-06-27 SAP Portals Israel Ltd., a German corporation Smart and flexible layout context manager
US20130167073A1 (en) * 2011-12-22 2013-06-27 SAP Portals Israel Ltd., a German corporation Smart and flexible layout context manager
US10726458B2 (en) 2012-06-21 2020-07-28 Aibuy, Inc. Peer-assisted shopping
US9607330B2 (en) 2012-06-21 2017-03-28 Cinsay, Inc. Peer-assisted shopping
US10789631B2 (en) 2012-06-21 2020-09-29 Aibuy, Inc. Apparatus and method for peer-assisted e-commerce shopping
US10810634B2 (en) * 2013-02-08 2020-10-20 The Nielsen Company (Us), Llc Methods and apparatus for efficient execution of modules
CN109360023A (en) * 2013-02-08 2019-02-19 尼尔森(美国)有限公司 The method and apparatus performed effectively for module
US20220188878A1 (en) * 2013-02-08 2022-06-16 The Nielsen Company (Us), Llc Methods and apparatus for efficient execution of modules
US11270356B2 (en) * 2013-02-08 2022-03-08 The Nielsen Company (Us), Llc Methods and apparatus for efficient execution of modules
US20140229297A1 (en) * 2013-02-08 2014-08-14 Nicholas Naveen Rau Methods and apparatus for efficient execution of modules
US9875489B2 (en) 2013-09-11 2018-01-23 Cinsay, Inc. Dynamic binding of video content
US11763348B2 (en) 2013-09-11 2023-09-19 Aibuy, Inc. Dynamic binding of video content
US10559010B2 (en) 2013-09-11 2020-02-11 Aibuy, Inc. Dynamic binding of video content
US11074620B2 (en) 2013-09-11 2021-07-27 Aibuy, Inc. Dynamic binding of content transactional items
US9953347B2 (en) 2013-09-11 2018-04-24 Cinsay, Inc. Dynamic binding of live video content
EP3049954A1 (en) * 2013-09-27 2016-08-03 Cinsay, Inc. N-level replication of supplemental content
CN105579997A (en) * 2013-09-27 2016-05-11 辛赛股份有限公司 Substrate for heat sink-equipped power module, and production method for same
WO2015048375A1 (en) 2013-09-27 2015-04-02 Cinsay, Inc. N-level replication of supplemental content
US11017362B2 (en) 2013-09-27 2021-05-25 Aibuy, Inc. N-level replication of supplemental content
US10701127B2 (en) 2013-09-27 2020-06-30 Aibuy, Inc. Apparatus and method for supporting relationships associated with content provisioning
JP2017501507A (en) * 2013-09-27 2017-01-12 シンセイ、インコーポレイテッド N level replication of supplemental content
US10268994B2 (en) 2013-09-27 2019-04-23 Aibuy, Inc. N-level replication of supplemental content
EP3049954A4 (en) * 2013-09-27 2017-04-05 Cinsay, Inc. N-level replication of supplemental content
US9697504B2 (en) 2013-09-27 2017-07-04 Cinsay, Inc. N-level replication of supplemental content
CN112256384A (en) * 2020-09-22 2021-01-22 杭州指令集智能科技有限公司 Service set processing method and device based on container technology and computer equipment

Also Published As

Publication number Publication date
US20080148283A1 (en) 2008-06-19
US8056092B2 (en) 2011-11-08

Similar Documents

Publication Publication Date Title
US8056092B2 (en) Method and apparatus for widget-container hosting and generation
US20080082627A1 (en) Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation
US11025629B2 (en) Secure component-based web applications
US20200258133A1 (en) Installable web applications
US9495084B2 (en) Method and apparatus for widget and widget-container distribution control based on content rules
US8332878B2 (en) User scriptable server initiated user interface creation
JP6318266B2 (en) System for managing extension changes to web pages
EP2207333B1 (en) Method and system for modifying the execution of a native application running on a portable eletronic device
US9535967B2 (en) Method and system for providing efficient and complex database functionality to a mobile device
CN101939736B (en) System and method for developing rich internet applications for remote computing devices
US9026918B2 (en) Enabling a user device to access enterprise data
US20110113090A1 (en) Dynamic mobile client
US10116660B2 (en) Security modes for a component-based web security model
US11232223B2 (en) Providing web application components within remote systems
US20080028037A1 (en) Presenting video content within a web page
AU2006326623A1 (en) Remote module incorporation into a container document
US20170364330A1 (en) Method for late binding identity to account
US20170310784A1 (en) Systems and Methods for Hosted Application Marketplaces
US11640307B2 (en) Process initiation
US10114628B2 (en) Architectures and techniques for record protection and field management
CN110213105A (en) It is a kind of cross-platform micro- using creation method
KR101265164B1 (en) System for providing shorten URL browsing with branding , method thereof, and web client thereof
WO2008042849A2 (en) Method and apparatus for widget-container hosting and generation
JP2006285714A (en) Web content browsing/editing system, web content browsing/editing method and web content browsing/editing program
KR101229222B1 (en) Information providing system and the method using dynamic shortcut

Legal Events

Date Code Title Description
AS Assignment

Owner name: CLEARSPRING TECHNOLOGIES, INC., VIRGINIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ALLEN, STEWART O.;COSBY, SCOTT F.;FATH, JOHN A.;AND OTHERS;SIGNING DATES FROM 20061010 TO 20061023;REEL/FRAME:027260/0511

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION