WO2008042849A2 - procédé et appareil pour l'hébergement et la génération d'un contenant de gadget logiciel - Google Patents

procédé et appareil pour l'hébergement et la génération d'un contenant de gadget logiciel Download PDF

Info

Publication number
WO2008042849A2
WO2008042849A2 PCT/US2007/080086 US2007080086W WO2008042849A2 WO 2008042849 A2 WO2008042849 A2 WO 2008042849A2 US 2007080086 W US2007080086 W US 2007080086W WO 2008042849 A2 WO2008042849 A2 WO 2008042849A2
Authority
WO
WIPO (PCT)
Prior art keywords
widget
container
service module
parameter value
instance
Prior art date
Application number
PCT/US2007/080086
Other languages
English (en)
Other versions
WO2008042849A3 (fr
Inventor
Stewart O. Allen
Scott F. Cosby
John A. Fath
Dylan J. Greene
Matthew J. Keesan
Hooman Radfar
Cyrus B. Radfar
Carlos F. Reverte
Original Assignee
Clearspring Technologies, Inc.
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Priority claimed from US11/537,375 external-priority patent/US20080082627A1/en
Priority claimed from US11/537,362 external-priority patent/US8056092B2/en
Application filed by Clearspring Technologies, Inc. filed Critical Clearspring Technologies, Inc.
Priority to EP07843614A priority Critical patent/EP2078257A4/fr
Publication of WO2008042849A2 publication Critical patent/WO2008042849A2/fr
Publication of WO2008042849A3 publication Critical patent/WO2008042849A3/fr

Links

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/44Arrangements for executing specific programs
    • 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

Definitions

  • 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.
  • ad-hoc fashion for example, using e-mail or as files embedded in a web page.
  • 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.
  • 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.
  • 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. 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.
  • FIG. 12 is a schematic diagram illustrating a widget configured to trigger one or more functions, according to an embodiment of the invention.
  • 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.
  • 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.
  • 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).
  • the widget-container generation engine can be included in a widget-container host and/or a widget-container creation device.
  • 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.
  • a widget-container processing device can be referred to as a container processing device or as a processing device.
  • 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.
  • 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.
  • 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.
  • 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 network and/or wireless network (e.g., cellular/mobile network, wi-fi, wireless LAN) in a variety of environments such as, for example, an office complex.
  • LAN local area network
  • WAN wide area network
  • wireless network e.g., cellular/mobile network, wi-fi, wireless LAN
  • 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.
  • 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).
  • 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).
  • 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.
  • the widget-container creation device 120 can be configured to automatically generate and/or modify widgets containers, for example, when a widget is received.
  • the widget-container creation device 120 can also store widgets and function as a widget server.
  • Each of the widget- container processing devices 150 can also be configured to function as a widget-container creation device 120 and vice versa.
  • the widget-container creation device 120 can trigger the generation and/or modification of the widget container at the widget-container host 100.
  • the widget-container creation device 120 can send an instruction from, for example, a processor (not shown) to cause the widget-container host 100 to generate and/or modify a widget container.
  • 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 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.
  • the widget-container host 100 is a centralized control/storage mechanism that manages requests received from container processing devices 150 and manages the sending of widgets containers (e.g., prompts a separate device (not shown) to send a widget container stored in a separate database (not shown)), the functionality of the widget-container host 100 can be decentralized and/or distributed.
  • a hierarchy of widget-container hosts 100 can be arranged, for example, with management components and/or slave components that control, configure, and coordinate the sending of widget containers to the widget-container processing devices 150.
  • FIG. 2 is a schematic diagram illustrating a widget container 250 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.
  • 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 or more 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.
  • the widget 252 can be modified for display/execution within the widget container 250.
  • 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.
  • 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.
  • 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.
  • 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.
  • 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.
  • html hyper-text markup language
  • WAP wireless application protocol
  • 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.
  • 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).
  • 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
  • a directory service function e.g., a service module used for searching in a directory.
  • 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.
  • the service module 254 is an integrated component of the widget container 250 (e.g., compiled within the widget container 250).
  • 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.
  • 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.
  • the service module 254 can be configured with a predefined functionality/feature that cannot be modified (e.g., an e-mail distribution service module).
  • the pre-defined features can be referred to as components.
  • 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.
  • 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.
  • a pre-defined option within the service module 254 can be used to customize the service module 254.
  • 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.
  • 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
  • the service module 254 can be a service module 254 created by and selected for use in the widget container 250 by a user.
  • 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.
  • the service module 254 can be a security service module that can function as a widget firewall.
  • 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.
  • 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).
  • 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.
  • 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.
  • 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.
  • 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).
  • 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.
  • 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.
  • 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 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.
  • the tracking data can be associated, for example, with a unique identifier (e.g., globally unique identifier (GUID)) associated with a specific widget container.
  • GUID globally unique identifier
  • the widget container 250 can be configured without a service module 254 and/or without a tracking kernel 256.
  • a portion of the widget 252 can be configured to invoke service module functions and/or tracking kernel functions based on an application programming interface (API) (e.g., API associated with the service module server 270).
  • API application programming interface
  • the widget 252 can be configured to invoke directly the functionality of the widget container 250 via an API.
  • the widget 252 can be configured to invoke a deployment function and/or a transaction service function (functions that can be performed by a service module) at the widget container 250 through an API call (e.g., API request) to the service module server 270 based on an API associated with the service module server 270.
  • the widget 252 can also be configured, for example, to invoke a tracking kernel function at the widget container 250 through an API call to the tracking server 260 based on an API associated with the tracking server 260.
  • the widget 252 can be configured to invoke functions associated with the widget container 250 based on an API associated with the widget- container host 200.
  • the widget-container 250 can be a portable framework that can be referenced in (e.g., embedded in, referenced using an embed or object tag) and/or accessed from/using a content aggregation point (not shown) rather than a processor-readable vehicle 220.
  • a request for the widget-container 250 (and the widget associated 252 with the widget-container) is received in response to a reference to the widget- container being accessed from the content aggregation point
  • the widget-container can be served for execution within the content aggregation point in response to the request.
  • a content aggregation point can be, for example, a desktop, a start page, a wireless application protocol (WAP) gallery, a gallery, a portal, and/or a directory.
  • WAP wireless application protocol
  • Some processor-readable vehicles, such as galleries, can be a type of content aggregation point.
  • WAP galleries, web galleries, and so forth are types of content aggregation points that can be referred to as content distribution points because they can be vehicles from which content such as widgets and/or widget-containers can be distributed.
  • 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.
  • 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.
  • 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 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 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.
  • 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.
  • the reference to the service module can be selected and/or provided using a user- interface configured for defining a widget container.
  • 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.
  • a set of service modules can be selected/defined based on a library of service modules based on a policy or a threshold condition.
  • 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.
  • 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.
  • 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 service module can be explicitly associated with the widget because the service module performs a function related to the widget.
  • the service module can be a polling service module that is used to collect a user's opinion of a widget.
  • 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.
  • 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.
  • the instruction to generate the widget container can be prompted via a user-interface that is associated with a widget generation engine.
  • 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.
  • 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.
  • 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.
  • 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. [0072] 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.
  • 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.
  • 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.
  • 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.
  • the widget container can be dynamically modified at 420 before the widget container is sent/served at 430.
  • 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.
  • 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.
  • 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.
  • the widget container is compiled when served.
  • the widget container can also be generated (or regenerated) when served.
  • 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.
  • 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.
  • 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.
  • reference 552 in processor-readable vehicle 550 was derived from reference 542 in processor-readable vehicle 540.
  • Reference 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.
  • the placement ID's, 536, 546, 556, and 566 can be generated using a placement service module 504 included in the widget container 505.
  • 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.
  • 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.
  • 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.
  • the widget container can be sent to and executed on a personal computer from a database controlled by a widget container host.
  • 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.
  • 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.
  • 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 second instance of the reference (with the second placement identifier) can then be placed in the second-processor readable vehicle at 650.
  • 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.
  • HTTP hypertext transfer protocol
  • 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.
  • 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.
  • 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.
  • 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).
  • a first platform e.g., personal computer platform
  • 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.
  • 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 URLl 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 Pl 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.
  • a placement ID 830 can be associated with multiple vehicle identifiers for a single processor-readable vehicle from column 840.
  • the placement ID's 830 e.g., P2
  • vehicle identifiers for the processor-readable vehicles 840 e.g., URL2
  • the placement ID's 830 and the processor-readable vehicles 840 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
  • 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
  • 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
  • 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 URLl associated with placement ID Pl .
  • 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 Pl being accessed from processor- readable vehicle URLl.
  • 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.
  • the metadata database 800 shows that widget container A for placement ID Pl 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.
  • 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).
  • 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 Pl .
  • author information e.g., actual name and/or username, profile
  • 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.
  • 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.
  • a preference which can be stored as metadata
  • a particular configuration of widget container A e.g., theme or style
  • 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.
  • 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.
  • rating/polling information e.g., opinion of a widget on a scale of 1 to 10
  • tagging and/or categorization data e.g., user-defined tagging/categorization of widgets
  • tagging and/or categorization data e.g., user-defined tagging/categorization of widgets
  • 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).
  • 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. In some embodiments, 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 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.
  • 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.
  • a widget originator can include a service module in a widget container that allows a viewer to modify a theme of the widget container.
  • 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.
  • 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 metatdata 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.
  • 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.
  • 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 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.
  • 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.
  • 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.
  • 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.
  • tracking parameter values are not sent from the widget container until the widget container 950 is closed (e.g., no longer being executed).
  • 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.
  • 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.
  • 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.
  • 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.
  • 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.
  • 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.
  • the modified widget container is sent to the widget-container processing device in response to the request at 1040.
  • 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.
  • 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.
  • 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.
  • 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).
  • 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.
  • 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.
  • 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.
  • 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.
  • 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.
  • FIG. 12 is a schematic diagram illustrating a widget 1252 configured to trigger one or more functions, according to an embodiment of the invention.
  • the widget 1252 is being executed (e.g., displayed) within a content aggregation point 1220 that is being displayed on a display 1230 of a processing device 1240.
  • the widget 1252 is served from a widget server 1210 over a network 1280 to the processing device 1240.
  • the widget 1252 can be served to the processing device 1240 and displayed/executed within the widget container 1250 in response to a reference to the widget 1252 being accessed from the content aggregation point 1220.
  • the widget 1252 is a non-displayable widget that can be, for example, a static data object, a software object, and/or a media object.
  • the widget 1252 is configured to invoke (e.g., trigger) one or more functions based on API 1290, API 1292, and/or API 1294.
  • the APIs 1290, 1292 and/or 1294 define interfaces for invoking (e.g., triggering) one or more functions associated with a widget- container host 1250, a tracking server 1260, and/or a service module server 1270, respectively.
  • widget 1252 can be configured to invoke directly one or more functions associated with the widget-container host 1250 based on an API call associated with API 1290.
  • the widget 1252 can be configured to invoke one or more functions that could be associated with (e.g., included in), for example, a widget container (not included) through an API call to the widget-container host 1250.
  • the widget 1252 can be configured to invoke directly one or more functions (e.g., a function that can be included in a service module) through an API call to the service module server 1270 based on API 1294.
  • the widget 1252 can be configured to invoke directly one or more functions (e.g., a function that can be included in a tracking kernel) through an API call to the tracking server 1270 based on API 1292.
  • widget 1252 can be stored on and dynamically served from the widget-container host 1250, rather than the widget server 1210, when the widget 1252 is requested.
  • the widget-container host 1250 can also be configured to prompt the widget server 1210 and/or service module server 1270 to send the widget 1252 to the processing device 1240 when a request for the widget 1252 is received from the processing device 1240.
  • the functions associated with the widget-container host 1250, the tracking server 1260, and/or the service module server 1270 can be included in one or more servers/hosts (not shown).
  • An API (not shown) that defines an interface for invoking functions associated with the one or more servers/hosts can be used by the widget 1252 as described herein.
  • the widget 1252 can be configured to access a separate widget (not shown) and/or a separate widget container (not shown) based on an API (not shown) associated with the separate widget and/or the separate widget container.
  • the widget 1252 can be configured to access and/or invoke a function associated with the separate widget and/or the separate widget container based on an API (e.g., via an API call) associated with the separate widget and/or the separate widget container.
  • widget 1252 can be configured to access information (e.g., data, metadata, tracking data) associated with the separate widget and/or the separate widget container based on an API associated with the separate widget and/or the separate widget container. The information can be generated at the separate widget and/or the separate widget container (e.g., polling data, a game score).
  • widget 1252 can be configured to share information (e.g., data, metadata, tracking data, data generated at the widget 1252) with the separate widget and/or the separate widget container based on the API.
  • the widget 1252 can be configured to trigger the separate widget and/or the separate widget container to perform a function based on an API. For example, the widget 1252 can trigger the separate widget and/or the separate widget container to collect and/or send information.
  • the separate widget and/or the separate widget container can be an implementation of an API such as a standard API.
  • the separate widget and/or the separate widget container can be included in (e.g., executing within) the content aggregation point 1220.
  • the API associated with the separate widget and/or the separate widget container can be associated with and/or can be used to invoke functionality consistent with any of the APIs shown in FIG. 12 (e.g., API 1290, API 1292).
  • a first widget container can be configured to communicate with and/or invoke a function associated with a second widget container based on an API associated with the second widget container.
  • the first widget container and the second widget container can be included in (e.g., executing within) the same content aggregation point (e.g., content aggregation point 1220).
  • Some embodiments relate to a computer storage product with a computer-readable medium (also can be referred to as a processor-readable medium) having instructions or computer code thereon for performing various computer-implemented operations.
  • the media and computer code also can be referred to as code
  • Examples of computer-readable media include, but are not limited to: magnetic storage media such as hard disks, floppy disks, and magnetic tape; optical storage media such as Compact Disc/Digital Video Discs (CD/DVDs), Compact Disc-Read Only Memories (CD-ROMs), and holographic devices; magneto-optical storage media such as optical disks; carrier wave signals; and hardware devices that are specially configured to store and execute program code, such as Application-Specific Integrated Circuits (ASICs), Programmable Logic Devices (PLDs), and ROM and RAM devices.
  • Examples of computer code include, but are not limited to, micro-code or microinstructions, machine instructions, such as produced by a compiler, and files containing higher-level instructions that are executed by a computer using an interpreter.
  • an embodiment of the invention may be implemented using Java, C++, or other object- oriented programming language and development tools. Additional examples of computer code include, but are not limited to, control signals, encrypted code, and compressed code.
  • 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.
  • the various functions associated with a widget- container host, a service module server, and/or a tracking server can be combined into a single server/host or set of distributed servers/hosts.

Landscapes

  • Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Stored Programmes (AREA)

Abstract

L'invention concerne un procédé comprenant la réception d'au moins un parmi un gadget logiciel ou une référence à un gadget logiciel, le gadget logiciel pouvant être au moins un parmi un objet de données statique, un objet multimédia ou un objet logiciel. Au moins une partie d'un contenant de gadget logiciel, qui est un cadre logiciel procédural contenant un module de service associé au gadget logiciel et le gadget logiciel, est générée. Le module de service peut être une fonction prédéfinie associée au contenant de gadget logiciel avant la génération du contenant de gadget logiciel. Le contenant de gadget logiciel peut être configuré pour être exécuté au niveau d'un dispositif de traitement de contenant de gadget logiciel en réponse à une référence au contenant de gadget logiciel dont on a accès à partir d'un véhicule lisible par un processeur.
PCT/US2007/080086 2006-09-29 2007-10-01 procédé et appareil pour l'hébergement et la génération d'un contenant de gadget logiciel WO2008042849A2 (fr)

Priority Applications (1)

Application Number Priority Date Filing Date Title
EP07843614A EP2078257A4 (fr) 2006-09-29 2007-10-01 Procédé et appareil pour l'hébergement et la génération d'un contenant de gadget logiciel

Applications Claiming Priority (4)

Application Number Priority Date Filing Date Title
US11/537,375 US20080082627A1 (en) 2006-09-29 2006-09-29 Method and Apparatus for Widget Container/Widget Tracking and Metadata Manipulation
US11/537,362 2006-09-29
US11/537,375 2006-09-29
US11/537,362 US8056092B2 (en) 2006-09-29 2006-09-29 Method and apparatus for widget-container hosting and generation

Publications (2)

Publication Number Publication Date
WO2008042849A2 true WO2008042849A2 (fr) 2008-04-10
WO2008042849A3 WO2008042849A3 (fr) 2008-07-03

Family

ID=39269140

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2007/080086 WO2008042849A2 (fr) 2006-09-29 2007-10-01 procédé et appareil pour l'hébergement et la génération d'un contenant de gadget logiciel

Country Status (2)

Country Link
EP (1) EP2078257A4 (fr)
WO (1) WO2008042849A2 (fr)

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI679580B (zh) * 2018-11-23 2019-12-11 中華電信股份有限公司 快速提供容器化軟體服務之系統及其方法
WO2022117243A1 (fr) * 2020-12-01 2022-06-09 Welect GmbH Système de publicité à la demande

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6636242B2 (en) * 1999-08-31 2003-10-21 Accenture Llp View configurer in a presentation services patterns environment
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
US20040153973A1 (en) * 2002-11-21 2004-08-05 Lawrence Horwitz System and method for automatically storing and recalling application states based on application contexts
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
CA2555465A1 (fr) * 2004-02-04 2006-03-16 Passmark Security, Inc. Procede et appareil d'authentification d'utilisateurs et de communications recues de systemes informatiques
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

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See references of EP2078257A4 *

Cited By (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
TWI679580B (zh) * 2018-11-23 2019-12-11 中華電信股份有限公司 快速提供容器化軟體服務之系統及其方法
WO2022117243A1 (fr) * 2020-12-01 2022-06-09 Welect GmbH Système de publicité à la demande

Also Published As

Publication number Publication date
EP2078257A4 (fr) 2010-09-29
EP2078257A2 (fr) 2009-07-15
WO2008042849A3 (fr) 2008-07-03

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
US9495084B2 (en) Method and apparatus for widget and widget-container distribution control based on content rules
US9544400B2 (en) Manipulating binary large objects
EP2207333B1 (fr) Procédé et système pour modifier l'exécution d'une application native fonctionnant sur un dispositif électronique portable
EP2184668B1 (fr) Procédé, système et interface utilisateur graphique pour permettre à un utilisateur d'accéder à des données d'entreprise sur un dispositif électronique portable
JP6318266B2 (ja) ウェブページへの拡張機能変更を管理するシステム
US8255494B1 (en) Installable web applications
US8332878B2 (en) User scriptable server initiated user interface creation
CN101939736B (zh) 远程计算设备的开发富互联网应用的系统和方法
US20170364330A1 (en) Method for late binding identity to account
FR2814828A1 (fr) Procede d'optimisation, par une terminal, de la consultation de donnees
US11119749B2 (en) Architectures and techniques for record protection and field management
WO2008042849A2 (fr) procédé et appareil pour l'hébergement et la génération d'un contenant de gadget logiciel
Vavru et al. Android programming: Complete application programming guide
AU2012258338B2 (en) Method and system for modifying the execution of a native application running on a portable electronic device
AU2012258448B2 (en) Method, system and graphical user interface for enabling a user to access enterprise data on a portable electronic device
AU2014233648B2 (en) Method and system for modifying the execution of a native application running on a portable electronic device
WO2012067618A1 (fr) Création d'interface utilisateur à l'initiative d'un serveur scriptable par l'utilisateur
JP2002183034A (ja) Webページ作成装置、Webページ作成システム、Webページ作成方法及びWebページ作成プログラムを記録した記録媒体
Wagner Beginning IOS Application Development with HTML and JavaScript
CA2533920A1 (fr) Telechargement d'objets multiples

Legal Events

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

Ref document number: 07843614

Country of ref document: EP

Kind code of ref document: A2

NENP Non-entry into the national phase in:

Ref country code: DE

WWE Wipo information: entry into national phase

Ref document number: 2007843614

Country of ref document: EP