The subject matter disclosed herein generally relates to processing and storing electronic messages. More specifically, the present disclosure describes systems and methods for the temporary back-end storage and automatic deletion of certain “ephemeral” messages, e.g., messages that may only be viewed by recipients for a specified period of time and are deleted afterwards.
Electronic communications, such as e-mail or text messages, images, video, multimedia, etc., over networks, such as the Internet, can be a very convenient means of communication. However, security concerns can limit the appeal of such communications. For example, while encryption may provide a degree of privacy and security for a message while in transit, once the message is received by recipients, the sender of the message typically loses control over how the message is dealt with by the recipients. For example, a message sender may only wish the recipient to be in possession of the message for a specific period of time, but the recipient may choose to retain the message in his or her message store beyond that period. Ephemeral messages set to be automatically deleted after a specific trigger event or a specified period of time may be used to address this concern, and therefore efficient systems and methods for processing and storing the temporary data of such ephemeral messages are desirable.
The present disclosure is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings, in which:
Although the present disclosure is described with reference to specific example embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the disclosure. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense.
A messaging system may provide a message sender with additional control over electronic messages, such as text messages or photos, after they have been received by a recipient. The embodiments described herein provide systems and methods for processing and storing ephemeral messages intended for automatic deletion after receipt or upon consumption of the message by a recipient. These embodiments will be described in relation to mobile wireless communication devices, hereafter referred to as client devices, for sending and receiving electronic messages such as text messages, photos or videos, and associated servers for receiving and forwarding messages to and from the client devices. It will be appreciated by those skilled in the art, however, that this description is not intended to limit the scope of the described embodiments to the communication devices described below or to any specific electronic message formats. The methods and systems described herein may be applied to any appropriate communication or data processing device and to any appropriate electronic communication format.
Overview
When the storage controller 120 receives a message from the client device 115A, it may then determine a logical disk of the storage 130 in which to store the message. The storage controller 120 may first determine an estimated deletion time for the message. e.g., based on message parameters such as the sender or the message size as described below. The message can then be stored in a logical disk of storage 130 that has an assigned future time that is the best match for the estimated deletion time of the electronic message based on a comparison of the assigned future times and the estimated deletion time. A future time may be determined to be the best match for the estimated deletion time of the electronic message based on the comparison revealing that the assigned future time is the closest, of the assigned future times, to the estimated deletion time (e.g., a minimum distance from the estimated deletion time of the electronic message and the assigned future time of the logical disk). Alternatively the future may be determined to be the best match for the estimated deletion time of the electronic message based on the comparison revealing that the assigned future time is the closest, of the assigned future times, to the estimated deletion time without being earlier in time than the estimated deletion time so that the message is stored in a logical disk where it is likely to be deleted just before the assigned future time of said logical disk. In this way the message may never have to be copied to another logical disk of storage 130, as explained below, thus avoiding further storage and processing overhead and also minimizing disk fragmentation in storage 130. For example, if the storage controller 120 deletes all (or almost all) of the messages stored on a logical disk of storage 130 based on the detection of triggering events for each of the messages before the future time assigned to the logical disk, then the disk may be wiped clean and repurposed for storing a new set of messages with little effort, as explained below.
Once the storage controller 120 has deleted a sufficient number or amount of stored messages from a logical disk that has been designated as unavailable so that the logical disk has more than a threshold amount of unused storage capacity (e.g., 500 megabytes or 95% of total capacity), then the storage controller 120 may copy each of the electronic messages still stored in the unavailable logical disk to a logical disk that is available for writing. In this way, remaining messages may also be deleted from the unavailable logical disk so that the unavailable designation can be removed from the logical disk and it can be assigned a new future time in order to resume storing messages that are expected to be received. The basic reasoning being that, if a deletion triggering event is expected to be received for all of the stored messages in a unavailable logical disk just prior to the future time assigned to the logical disk, then the system 100 can rely on the storage capacity of the logical disk being available at the assigned future time with little additional processing overhead while minimizing disk fragmentation in storage 130 by reducing the number of write and delete operations. In an embodiment, the future time assigned to each logical disk may be specified by a system administrator instead of being dynamically determined based on system parameters as described above.
In an embodiment, the storage controller 120 is configured to copy each of the electronic messages stored in the unavailable logical disk to a logical disk available for writing by first determining a new estimated deletion time for the electronic message and then storing the electronic message in a logical disk of storage 130 with an assigned future time that is the best match for the new estimated deletion time of the electronic message. For example, the new estimated deletion time for each electronic message stored in the unavailable logical disk to be stored in a logical disk is determined based on the number of times each message has been copied by storage controller 120 from a logical disk of storage 130.
In an embodiment, the estimated deletion time for an electronic message from the sender 110A to a recipient 110B is specified based on parameters of the electronic message (e.g., type of message or size of message) or based on historical information regarding the behavior of the recipient 110B (e.g., recipient 110B usually reads messages quickly). For example, the historical information regarding the behavior of recipient 110B may include information regarding the behavior of the recipient 110B in regard to: electronic messages from the sender 110A, electronic messages including a type of electronic media, electronic messages received at a specific time, electronic messages received at a specific location, electronic messages received with a specific device, or electronic messages of a particular size (e.g., greater than a specific size). In this way the storage controller 120 may generate an accurate estimate of the time when a deletion triggering event for the electronic message will be received. In an embodiment, the historical information regarding the behavior of recipient 110B includes information regarding the behavior of the recipient 110B in regard to electronic messages from users of the network system 100 determined to be similar to the sender 110A, for example, based on: user location, user device or user behavior. In an embodiment, the historical information regarding the behavior of recipient 110B includes information regarding the behavior of the recipient 110B in regard to electronic messages including content determined to be similar to the content of the electronic message, for example, based on: image recognition, semantic analysis, tools used to create the content or user interface provided to view the content.
In an embodiment, the remote storage controller 120 transmits the message from the client device 115A to a client device 115B associated with a recipient 110B of the message upon receipt of a request from said client device 115B. The request could, for example, be automatic upon launching a messaging application on the client device 115B. The remote storage controller 120 may insert instructions in the message to instruct the client device 115B to store the message in memory for only a specified time period and/or to display the message for only a specified time period (e.g., specified by a messaging application on the client device 115A) so that the messages are “ephemeral” messages. The remote storage controller 120 may then delete the message from whichever of the logical disks of storage 130 it is currently stored on based on the detection of a triggering event. In some embodiments, the message may also be stored on the client device 115B but then subsequently deleted based on the detection of a triggering event. In an embodiment, the triggering event for deleting a message comprises responding to the message at the client device 115B prior to the expiration of the specified time period, for example, by sending a return message prior to the expiration of the specified time period without closing the messaging application.
System Architecture
A data exchange platform 202, in an example, includes a user messaging module 220 and a storage controller module 222, and may provide server-side functionality via a network 204 (e.g., the Internet) to one or more clients. Although described as residing on a server (e.g., application server(s) 218) in some embodiments, in other embodiments some or all of the functions of user messaging module 220 and a storage controller module 222 may be provided by a client device. The one or more clients may include users that use the network system 200 to exchange data over the network 204. These operations may include transmitting, receiving (communicating), and processing data to, from, and regarding content and users of the network system 200. The data may include, but is not limited to, content and user data such as user profiles, messaging content, messaging attributes, client device information, and geolocation information, among others.
In various embodiments, the data exchanges within the network system 200 may be dependent upon user-selected functions available through one or more client or user interfaces (UIs). The UIs may be associated with a client machine, such as client devices 210, 212 using a programmatic client 206, such as a client application. The programmatic client 206 may be in communication with the user messaging module 220 (and storage controller module 222) via an application server 218. The client devices 210, 212 may comprise mobile devices with wireless communication components and applications for sending specific types of electronic messages (e.g., ephemeral messages) over network 204 (e.g., via a messaging application 207).
Turning specifically to the user messaging module 220 and storage controller module 222, an application program interface (API) server 214 is coupled to, and provides programmatic interface to, one or more application server(s) 218 that host the user messaging module 220 and storage controller module 222. The application server(s) 218 is, in turn, shown to be coupled to storage in the form of one or more database(s) 224, 226, 228 and 230. The one or more database(s) 224, 226, 228 and 230 may include durable storage (e.g., non-volatile memory) and non-durable storage (e.g., volatile memory).
The API server 214 communicates and receives data pertaining to messages, among other things, via various user input tools. For example, the API server 214 may send and receive data to and from an application (e.g., via the programmatic client 206) running on another client machine (e.g., client devices 210, 212 or a third party server).
In one example embodiment, the user messaging module 220 provides messaging functionality for users of the client devices 210, 212 to send and receive ephemeral messages that automatically disappear after a triggering event has been detected, such as, for example the messages having been viewed by the recipient for a specified period of time. The client devices 210, 212 can access and view the messages via the application server(s) 218, which may access the message content from, for example, the database 230.
In an embodiment, one or more application server 218 includes or acts as a storage controller module 222 for database 230 that may include non-durable (e.g., volatile) and durable (e.g., non-volatile) memories for storing ephemeral messages received from a client device 210 or 212. The messages may be stored in a partition of the database 230 for a time period before being deleted or copied to another partition of the database 230. The messages may be deleted based on detection of a triggering event, such as the message being read by a recipient (e.g., recipient 110B via client device 212) of the message, responded to by a recipient of the message or copied to a storage device by a recipient of the message. For example, messages that are quickly read by the recipients (e.g., within the time period) may simply be deleted from the database 230 without having been copied to another partition of the database 230. The client device may be the client device 210 (e.g., a mobile device) of a user (e.g., sender 110A) of data exchange platform 202. The storage controller module 222 may partition the database 230 into logical disks for storing the electronic messages processed by user messaging module 220. The storage controller module 222 may then designate a logical disk as unavailable based on the capacity of the logical disk being fully used. For example, the logical disk may be designated as unavailable based on the available storage capacity of the logical disk being less than a specified threshold amount. In an embodiment, the threshold amount may be specified as the amount needed to store another electronic message of average expected size. The storage controller module 222 may then assign a future time (e.g., an hour later, a day later, a week later, etc.) to each logical disk that is available for writing (e.g., the logical disk is not designated as unavailable) based on the available storage capacity of the logical disk and estimated message storage requirements. For example, if the data exchange platform 202 expects to receive, within the next 23 hours, 300 messages, each of which is estimated to be deleted within one day, then a logical disk with a storage capacity that would be fully used (e.g., would then be designated as unavailable) by storing the 300 messages (of average expected size) may be assigned the future time one day later. In this way, the logical disk should first become unavailable by storing as many of the expected 300 messages as it can (e.g., within the first 23 hours), and then shortly thereafter (e.g., within the next hour) the logical disk should be nearly emptied as the stored ephemeral messages are deleted based on the detection of the expected triggering events (e.g., recipient 110B reads the electronic message).
When the storage controller module 222 receives a message from client device 210, it may then determine a logical disk of the database 230 in which to store the message. The storage controller module 222 may first determine an estimated deletion time for the message, e.g., based on message parameters such as the sender or the message size or based on historical behavior of a message recipient in regard to messages with similar parameters as described below with respect to databases(s) 224, 226 and 228. The message can then be stored in a logical disk of database 230 that has an assigned future time that is the best match for the estimated deletion time of the electronic message based on a comparison of the assigned future times and the estimated deletion time. A future time may be determined to be the best match for the estimated deletion time of the electronic message based on the comparison revealing that the assigned future time is the closest, of the assigned future times, to the estimated deletion time (e.g., a minimum distance from the estimated deletion time of the electronic message and the assigned future time of the logical disk). Alternatively the future may be determined to be the best match for the estimated deletion time of the electronic message based on the comparison revealing that the assigned future time is the closest, of the assigned future times, to the estimated deletion time without being earlier in time than the estimated deletion time so that the message is stored in a logical disk where it is likely to be deleted just before the assigned future time of said logical disk. In this way the message may message may never have to be copied to another logical disk of database 230, thus avoiding further storage and processing overhead and also minimizing disk fragmentation in database 230. For example, if the storage controller module 222 deletes all (or almost all) of the messages stored on a logical disk of database 230 based on the detection of triggering events for each of the messages before the future time assigned to the logical disk, then the logical disk may be wiped clean and repurposed for storing a new set of messages with little effort by the data exchange platform 202.
Once the storage controller module 222 has deleted a sufficient number or amount of stored messages from a logical disk that has previously been designated as unavailable, so that the logical disk has more than a threshold amount of unused storage capacity (e.g., 500 megabytes or 95% of capacity), then the storage controller module 222 may copy each of the electronic messages still stored in the unavailable logical disk to a logical disk that is available for writing. In this way, these remaining messages may also be deleted from the unavailable logical disk so that the unavailable designation can be removed from the logical disk and it can be assigned a new future time in order to resume storing messages that are expected to be received. The basic reasoning being that, if a deletion triggering event is expected to be received for all of the stored messages in a unavailable logical disk just prior to the future time assigned to the logical disk, then the system 200 can rely on the storage capacity of the logical disk being available at the assigned future time with little additional processing overhead while minimizing disk fragmentation in database 230 by reducing the number of write and delete operations. In an embodiment, the future time assigned to each logical disk may be specified by a system administrator instead of being dynamically determined based on system parameters as described above.
In an embodiment, the storage controller module 222 is configured to copy each of the electronic messages stored in the unavailable logical disk to a logical disk available for writing by first determining a new estimated deletion time for the electronic message and then storing the electronic message in a logical disk of database 230 (e.g., that is available for writing based on its available storage capacity and the size of the electronic message) with an assigned future time that is the best match for the new estimated deletion time of the electronic message. For example, the new estimated deletion time for each of the electronic messages stored in the unavailable logical disk to be stored in a logical disk is determined based on the number of times each electronic message has been copied by the storage controller module 222 from a logical disk of database 230.
In an embodiment, the estimated deletion time for an electronic message from a client device 210 (e.g., sender 110A) to a client device 212 (e.g., recipient 110B) is specified based on parameters of the electronic message (e.g., type of message or size of message) or based on historical information regarding the behavior of the recipient 110B (e.g., recipient 110B usually reads messages quickly). For example, the historical information regarding the behavior of the recipient 110B (e.g., in any of: activity and behavior data (database 228), social graph data (database 226) and profile data (database 224)) may include information regarding the behavior of the recipient 110B in regard to: electronic messages from the sender 110A, electronic messages including a type of electronic media, electronic messages received at a specific time, electronic messages received at a specific location, electronic messages received with a specific device, or electronic messages of a particular size (e.g., greater than a specific size). In this way the storage controller module 222 may generate an accurate estimate of the time when a deletion triggering event for the electronic message will be received. In an embodiment, the historical information regarding the recipient's behavior (e.g., in any of databases(s) 224, 226 and 228) includes information regarding the behavior of the recipient 110B in regard to electronic messages from users of the data exchange platform 202 determined to be similar to the sender 110A, for example, based on: user location, user device or user behavior. In an embodiment, the historical information regarding the behavior of the recipient 110B includes information regarding the behavior of the recipient 110B in regard to electronic messages including content determined to be similar to the content of the electronic message, for example, based on: image recognition, semantic analysis, tools used to create the content or user interface provided to view the content.
In an embodiment, the application server(s) 218 transmit (e.g., via user messaging module 220) the message from the client device 210 to a client device 212 associated with a recipient 110B of the message upon receipt of a request from said client device 212. The request could, for example, be automatic upon launching a messaging application 207 on the client device 212. The application server(s) 218 may insert instructions in the message to instruct the client device 212 to store the message in memory for only a specified time period and/or to display the message for only a specified time period (e.g., specified by the messaging application 207 of the client device 210) so that the messages are “ephemeral” messages. The application server(s) 218 may then delete the message from whichever of the logical disks of database 230 it is currently stored on based on the detection of a triggering event. In some embodiments, the message may also be stored on the client device 212 but then subsequently deleted based on the detection of a triggering event. In an embodiment, the triggering event for deleting a message comprises responding to the message at the client device 212 prior to the expiration of the specified time period. e.g., by sending a return message prior to the expiration of the time period without closing the messaging application 207.
User Interface
In the example of
In the example of
Data Flow
At operation 422, the storage controller 404 returns the requested message file to the requesting client device 212 of client device(s) 402. The storage controller 404 inserts instructions in the message so that the client device 212 of client device(s) 402 stores the message only for a specified time period and/or displays the message for only a specified period of time. At operation 424, requesting client device 212 of client device(s) 402 may read (e.g., view for at most the specified period of time) the received message. Finally, at operation 426 the storage controller 404 may delete the message from the logical disk A 406 or the logical disk B 408 based on the message having been read by all the recipients, in this case read by the client device 212 of client device(s) 402.
Methods
Modules, Components and Logic
Certain embodiments are described herein as including logic or a number of components, modules, or mechanisms. Modules may constitute either software modules (e.g., code embodied (1) on a non-transitory machine-readable medium or (2) in a transmission signal) or hardware-implemented modules. A hardware-implemented module is a tangible unit capable of performing certain operations and may be configured or arranged in a certain manner. In example embodiments, one or more computer systems (e.g., a standalone, client, or server computer system) or one or more processors may be configured by software (e.g., an application or application portion) as a hardware-implemented module that operates to perform certain operations as described herein.
In various embodiments, a hardware-implemented module may be implemented mechanically or electronically. For example, a hardware-implemented module may comprise dedicated circuitry or logic that is permanently configured (e.g., as a special-purpose processor, such as a field programmable gate array (FPGA) or an application-specific integrated circuit (ASIC)) to perform certain operations. A hardware-implemented module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software to perform certain operations. It will be appreciated that the decision to implement a hardware-implemented module mechanically, in dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by cost and time considerations.
Accordingly, the term “hardware-implemented module” should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily or transitorily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. Considering embodiments in which hardware-implemented modules are temporarily configured (e.g., programmed), each of the hardware-implemented modules need not be configured or instantiated at any one instance in time. For example, where the hardware-implemented modules comprise a general-purpose processor configured using software, the general-purpose processor may be configured as respectively different hardware-implemented modules at different times. Software may, accordingly, configure a processor, for example, to constitute a particular hardware-implemented module at one instance of time and to constitute a different hardware-implemented module at a different instance of time.
Hardware-implemented modules can provide information to, and receive information from, other hardware-implemented modules. Accordingly, the described hardware-implemented modules may be regarded as being communicatively coupled. Where multiples of such hardware-implemented modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses that connect the hardware-implemented modules). In embodiments in which multiple hardware-implemented modules are configured or instantiated at different times, communications between such hardware-implemented modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple hardware-implemented modules have access. For example, one hardware-implemented module may perform an operation, and store the output of that operation in a memory device to which it is communicatively coupled. A further hardware-implemented module may then, at a later time, access the memory device to retrieve and process the stored output. Hardware-implemented modules may also initiate communications with input or output devices, and can operate on a resource (e.g., a collection of information).
The various operations of example methods described herein may be performed, at least partially, by one or more processors that are temporarily configured (e.g., by software) or permanently configured to perform the relevant operations. Whether temporarily or permanently configured, such processors may constitute processor-implemented modules that operate to perform one or more operations or functions. The modules referred to herein may, in some example embodiments, comprise processor-implemented modules.
Similarly, the methods described herein may be at least partially processor-implemented. For example, at least some of the operations of a method may be performed by one or more processors or processor-implemented modules. The performance of certain of the operations may be distributed among the one or more processors, not only residing within a single machine, but deployed across a number of machines. In some example embodiments, the processor or processors may be located in a single location (e.g., within a home environment, an office environment, or a server farm), while in other embodiments the processors may be distributed across a number of locations.
The one or more processors may also operate to support performance of the relevant operations in a “cloud computing” environment or as a “software as a service” (SaaS). For example, at least some of the operations may be performed by a group of computers (as examples of machines including processors), with these operations being accessible via the network 105 or network 204 (e.g., the Internet) and via one or more appropriate interfaces (e.g., APIs).
Electronic Apparatus and System
Example embodiments may be implemented in digital electronic circuitry, or in computer hardware, firmware, or software, or in combinations of them. Example embodiments may be implemented using a computer program product (e.g., a computer program tangibly embodied in an information carrier, e.g., in a machine-readable medium for execution by, or to control the operation of, data processing apparatus. e.g., a programmable processor, a computer, or multiple computers).
A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a standalone program or as a module, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
In example embodiments, operations may be performed by one or more programmable processors executing a computer program to perform functions by operating on input data and generating output. Method operations can also be performed by, and apparatus of example embodiments may be implemented as, special purpose logic circuitry (e.g., an FPGA or an ASIC).
The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other. In embodiments deploying a programmable computing system, it will be appreciated that both hardware and software architectures merit consideration. Specifically, it will be appreciated that the choice of whether to implement certain functionality in permanently configured hardware (e.g., an ASIC), in temporarily configured hardware (e.g., a combination of software and a programmable processor), or in a combination of permanently and temporarily configured hardware may be a design choice. Below are set out hardware (e.g., machine) and software architectures that may be deployed in various example embodiments.
Example Computer System
The example computer system 700 includes a processor 702 (e.g., a central processing unit (CPU), a graphics processing unit (GPU), or both), a main memory 704, and a static memory 706, which communicate with each other via a bus 708. The computer system 700 may further include a video display unit 710 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)). The computer system 700 also includes an alphanumeric input device 712 (e.g., a keyboard), a UI navigation device 714 (e.g., a mouse), a drive unit 716, a signal generation device 718 (e.g., a speaker), and a network interface device 720.
The drive unit 716 includes a computer-readable medium 722 on which is stored one or more sets of data structures and instructions 724 (e.g., software) embodying or used by any one or more of the methodologies or functions described herein. The instructions 724 may also reside, completely or at least partially, within the main memory 704 or within the processor 702 during execution thereof by the computer system 700, with the main memory 704 and the processor 702 also constituting machine-readable.
The instructions 724 may further be transmitted or received over a network 726 via the network interface device 720 utilizing any one of a number of well-known transfer protocols (e.g., HTTP).
While the computer-readable medium 722 is shown in an example embodiment to be a single medium, the term “computer-readable medium” should be taken to include a single medium or multiple photo (e.g., a centralized or distributed database, and/or associated caches and servers) that store the one or more sets of instructions 724. The term “computer-readable medium” shall also be taken to include any medium that is capable of storing, encoding, or carrying a set of instructions 724 for execution by the machine that cause the machine to perform any one or more of the methodologies of the present disclosure, or that is capable of storing, encoding, or carrying data structures used by or associated with such a set of instructions 724. The term “computer-readable medium” shall, accordingly, be taken to include, but not be limited to, solid-state memories, optical photo, and magnetic photo.
Furthermore, the computer-readable medium 722 is non-transitory in that it does not embody a propagating signal. However, labeling the tangible computer-readable medium 722 “non-transitory” should not be construed to mean that the medium 722 is incapable of movement—the medium 722 should be considered as being transportable from one physical location to another. Additionally, since the computer-readable medium 722 is tangible, the medium 722 may be considered to be a machine-readable device.
Example Mobile Device
Although an embodiment has been described with reference to specific example embodiments, it will be evident that various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of the present disclosure. Accordingly, the specification and drawings are to be regarded in an illustrative rather than a restrictive sense. The accompanying drawings that form a part hereof show by way of illustration, and not of limitation, specific embodiments in which the subject matter may be practiced. The embodiments illustrated are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed herein. Other embodiments may be used and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. This Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.
As used herein, the term “or” may be construed in either an inclusive or exclusive sense. Moreover, plural instances may be provided for resources, operations, or structures described herein as a single instance. Additionally, boundaries between various resources, operations, modules, engines, and data stores are somewhat arbitrary, and particular operations are illustrated in a context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within a scope of various embodiments of the present invention. In general, structures and functionality presented as separate resources in the example configurations may be implemented as a combined structure or resource. Similarly, structures and functionality presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within a scope of embodiments of the present invention as represented by the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Such embodiments of the inventive subject matter may be referred to herein, individually or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is in fact disclosed. Thus, although specific embodiments have been illustrated and described herein, it should be appreciated that any arrangement calculated to achieve the same purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all adaptations or variations of various embodiments. Combinations of the above embodiments, and other embodiments not specifically described herein, will be apparent to those of skill in the art upon reviewing the above description.
The Abstract of the Disclosure is provided to comply with 37 C.F.R. § 1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus, the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate embodiment.
This application is a continuation of, and claims priority to, U.S. patent application Ser. No. 14/740,786, filed Jun. 16, 2015, and entitled “STORAGE MANAGEMENT FOR EPHEMERAL MESSAGES.” The content of this prior application is considered part of this application, and is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5754939 | Herz et al. | May 1998 | A |
6038295 | Mattes | Mar 2000 | A |
6158044 | Tibbetts | Dec 2000 | A |
6167435 | Druckenmiller et al. | Dec 2000 | A |
6205432 | Gabbard et al. | Mar 2001 | B1 |
6310694 | Okimoto et al. | Oct 2001 | B1 |
6484196 | Maurille | Nov 2002 | B1 |
6487586 | Ogilvie et al. | Nov 2002 | B2 |
6665531 | Soderbacka et al. | Dec 2003 | B1 |
6701347 | Ogilvie | Mar 2004 | B1 |
6711608 | Ogilvie | Mar 2004 | B1 |
6757713 | Ogilvie et al. | Jun 2004 | B1 |
6980909 | Root et al. | Dec 2005 | B2 |
7124164 | Chemtob | Oct 2006 | B1 |
7149893 | Leonard et al. | Dec 2006 | B1 |
7173651 | Knowles | Feb 2007 | B1 |
7243163 | Friend et al. | Jul 2007 | B1 |
7278168 | Chaudhury et al. | Oct 2007 | B1 |
7356564 | Hartselle et al. | Apr 2008 | B2 |
7376715 | Cunningham et al. | May 2008 | B2 |
7411493 | Smith | Aug 2008 | B2 |
7478402 | Christensen et al. | Jan 2009 | B2 |
7496347 | Puranik | Feb 2009 | B2 |
7519670 | Hagale et al. | Apr 2009 | B2 |
7535890 | Rojas | May 2009 | B2 |
7607096 | Oreizy et al. | Oct 2009 | B2 |
7703140 | Nath et al. | Apr 2010 | B2 |
7912896 | Wolovitz et al. | Mar 2011 | B2 |
8131597 | Hudetz | Mar 2012 | B2 |
8170957 | Richard | May 2012 | B2 |
8199747 | Rojas et al. | Jun 2012 | B2 |
8214443 | Hamburg | Jul 2012 | B2 |
8238947 | Lottin et al. | Aug 2012 | B2 |
8244593 | Klinger et al. | Aug 2012 | B2 |
8312097 | Siegel et al. | Nov 2012 | B1 |
8332475 | Rosen et al. | Dec 2012 | B2 |
8570907 | Garcia, Jr. et al. | Oct 2013 | B2 |
8718333 | Wolf et al. | May 2014 | B2 |
8724622 | Rojas | May 2014 | B2 |
8745132 | Obradovich | Jun 2014 | B2 |
8874677 | Rosen et al. | Oct 2014 | B2 |
8909679 | Roote et al. | Dec 2014 | B2 |
8909714 | Agarwal et al. | Dec 2014 | B2 |
8909725 | Sehn | Dec 2014 | B1 |
8914752 | Spiegel | Dec 2014 | B1 |
8995433 | Rojas | Mar 2015 | B2 |
9040574 | Wang et al. | May 2015 | B2 |
9055416 | Rosen et al. | Jun 2015 | B2 |
9083770 | Drose et al. | Jul 2015 | B1 |
9094137 | Sehn et al. | Jul 2015 | B1 |
9100806 | Rosen et al. | Aug 2015 | B2 |
9100807 | Rosen et al. | Aug 2015 | B2 |
9113301 | Spiegel et al. | Aug 2015 | B1 |
9148424 | Yang | Sep 2015 | B1 |
9191776 | Root et al. | Nov 2015 | B2 |
9204252 | Root | Dec 2015 | B2 |
9225805 | Kujawa et al. | Dec 2015 | B2 |
9225897 | Sehn et al. | Dec 2015 | B1 |
9237202 | Sehn | Jan 2016 | B1 |
9264463 | Rubinstein et al. | Feb 2016 | B2 |
9276886 | Samaranayake | Mar 2016 | B1 |
9294425 | Son | Mar 2016 | B1 |
9385983 | Sehn | Jul 2016 | B1 |
9396354 | Murphy et al. | Jul 2016 | B1 |
9407712 | Sehn | Aug 2016 | B1 |
9407816 | Sehn | Aug 2016 | B1 |
9430783 | Sehn | Aug 2016 | B1 |
9443227 | Evans et al. | Sep 2016 | B2 |
9482882 | Hanover et al. | Nov 2016 | B1 |
9482883 | Meisenholder | Nov 2016 | B1 |
9489661 | Evans et al. | Nov 2016 | B2 |
9491134 | Rosen et al. | Nov 2016 | B2 |
9532171 | Allen et al. | Dec 2016 | B2 |
9537811 | Allen et al. | Jan 2017 | B2 |
9560006 | Prado et al. | Jan 2017 | B2 |
9563681 | Patiejunas | Feb 2017 | B1 |
9628950 | Noeth et al. | Apr 2017 | B1 |
9652896 | Jurgenson et al. | May 2017 | B1 |
9659244 | Anderton et al. | May 2017 | B2 |
9693191 | Sehn | Jun 2017 | B2 |
9705831 | Spiegel | Jul 2017 | B2 |
9742713 | Spiegel et al. | Aug 2017 | B2 |
9785796 | Murphy et al. | Oct 2017 | B1 |
9825898 | Sehn | Nov 2017 | B2 |
9854219 | Sehn | Dec 2017 | B2 |
9906479 | Son | Feb 2018 | B1 |
9961520 | Brooks et al. | May 2018 | B2 |
20020047868 | Miyazawa | Apr 2002 | A1 |
20020144154 | Tomkow | Oct 2002 | A1 |
20030052925 | Daimon et al. | Mar 2003 | A1 |
20030126215 | Udell et al. | Jul 2003 | A1 |
20030217106 | Adar et al. | Nov 2003 | A1 |
20040203959 | Coombes | Oct 2004 | A1 |
20050097176 | Schatz et al. | May 2005 | A1 |
20050198128 | Anderson | Sep 2005 | A1 |
20050223066 | Buchheit et al. | Oct 2005 | A1 |
20060041619 | Gusler | Feb 2006 | A1 |
20060221988 | Geyer | Oct 2006 | A1 |
20060242239 | Morishima et al. | Oct 2006 | A1 |
20060270419 | Crowley et al. | Nov 2006 | A1 |
20070038715 | Collins et al. | Feb 2007 | A1 |
20070064899 | Boss et al. | Mar 2007 | A1 |
20070073823 | Cohen et al. | Mar 2007 | A1 |
20070214216 | Carrer et al. | Sep 2007 | A1 |
20070233801 | Eren et al. | Oct 2007 | A1 |
20080055269 | Lemay et al. | Mar 2008 | A1 |
20080120409 | Sun et al. | May 2008 | A1 |
20080207176 | Brackbill et al. | Aug 2008 | A1 |
20080270938 | Carlson | Oct 2008 | A1 |
20080306826 | Kramer et al. | Dec 2008 | A1 |
20080313346 | Kujawa et al. | Dec 2008 | A1 |
20090042588 | Lottin et al. | Feb 2009 | A1 |
20090132453 | Hangartner et al. | May 2009 | A1 |
20100082427 | Burgener et al. | Apr 2010 | A1 |
20100131880 | Lee et al. | May 2010 | A1 |
20100185665 | Horn et al. | Jul 2010 | A1 |
20100306669 | Della Pasqua | Dec 2010 | A1 |
20110099507 | Nesladek et al. | Apr 2011 | A1 |
20110145564 | Moshir et al. | Jun 2011 | A1 |
20110202598 | Evans et al. | Aug 2011 | A1 |
20110213845 | Logan et al. | Sep 2011 | A1 |
20110286586 | Saylor et al. | Nov 2011 | A1 |
20110320373 | Lee et al. | Dec 2011 | A1 |
20120028659 | Whitney et al. | Feb 2012 | A1 |
20120066742 | Tsuruga | Mar 2012 | A1 |
20120079096 | Cowan | Mar 2012 | A1 |
20120184248 | Speede | Jul 2012 | A1 |
20120209921 | Adafin et al. | Aug 2012 | A1 |
20120209924 | Evans et al. | Aug 2012 | A1 |
20120254325 | Majeti et al. | Oct 2012 | A1 |
20120278692 | Shi | Nov 2012 | A1 |
20120304080 | Wormald et al. | Nov 2012 | A1 |
20130071093 | Hanks et al. | Mar 2013 | A1 |
20130194301 | Robbins et al. | Aug 2013 | A1 |
20130290443 | Collins et al. | Oct 2013 | A1 |
20140032682 | Prado | Jan 2014 | A1 |
20140122787 | Shalvi et al. | May 2014 | A1 |
20140201527 | Krivorot | Jul 2014 | A1 |
20140244961 | Burckart | Aug 2014 | A1 |
20140282096 | Rubinstein et al. | Sep 2014 | A1 |
20140325383 | Brown et al. | Oct 2014 | A1 |
20140359024 | Spiegel | Dec 2014 | A1 |
20140359032 | Spiegel et al. | Dec 2014 | A1 |
20150199082 | Scholler et al. | Jul 2015 | A1 |
20150227602 | Ramu | Aug 2015 | A1 |
20160085773 | Chang et al. | Mar 2016 | A1 |
20160085863 | Allen et al. | Mar 2016 | A1 |
20160086670 | Gross et al. | Mar 2016 | A1 |
20160099901 | Allen et al. | Apr 2016 | A1 |
20160164816 | Bhagwan | Jun 2016 | A1 |
20160180887 | Sehn | Jun 2016 | A1 |
20160277419 | Allen et al. | Sep 2016 | A1 |
20160321708 | Sehn | Nov 2016 | A1 |
20160359957 | Laliberte | Dec 2016 | A1 |
20160359987 | Laliberte | Dec 2016 | A1 |
20170161382 | Ouimet et al. | Jun 2017 | A1 |
20170263029 | Yan et al. | Sep 2017 | A1 |
20170287006 | Azmoodeh et al. | Oct 2017 | A1 |
20170295250 | Samaranayake et al. | Oct 2017 | A1 |
20170374003 | Allen et al. | Dec 2017 | A1 |
20170374508 | Davis et al. | Dec 2017 | A1 |
Number | Date | Country |
---|---|---|
2887596 | Jul 2015 | CA |
WO-2012000107 | Jan 2012 | WO |
WO-2013008251 | Jan 2013 | WO |
WO-2014194262 | Dec 2014 | WO |
WO-2015192026 | Dec 2015 | WO |
WO-2016054562 | Apr 2016 | WO |
WO-2016065131 | Apr 2016 | WO |
WO-2016112299 | Jul 2016 | WO |
WO-2016179166 | Nov 2016 | WO |
WO-2016179235 | Nov 2016 | WO |
WO-2017176739 | Oct 2017 | WO |
WO-2017176992 | Oct 2017 | WO |
WO-2018005644 | Jan 2018 | WO |
Entry |
---|
“U.S. Appl. No. 14/740,786, Non Final Office Action dated Jun. 2, 2017”, 16 pgs. |
“U.S. Appl. No. 14/740,786, Notice of Allowance dated Oct. 13, 2017”, 11 pgs. |
“U.S. Appl. No. 14/740,786, Response filed Sep. 1, 2017 to Non Final Office Action dated Jun. 2, 2017”, 15 pgs. |
Castelluccia, Claude, et al., “EphPub: Toward robust Ephemeral Publishing”, Network Protocols (ICNP), 2011 19th IEEE International Conference on, IEEE, (Oct. 17, 2011), 18 pgs. |
Fajman, “An Extensible Message Format for Message Disposition Notifications”, Request for Comments: 2298, National Institutes of Health, (Mar. 1998), 28 pgs. |
Leyden, John, “This SMS will self-destruct in 40 seconds”, [Online]. Retrieved from the Internet: <http://www.theregister.co.uk/2005/12/12/stealthtext/, (Dec. 12, 2005), 1 pg. |
Melanson, Mike, “This text message will self destruct in 60 seconds”, [Online]. Retrieved from the Internet: <http://readwrite.com/2011/02/11/this_text_message_will_self_destruct_in_60_seconds>, (Feb. 18, 2015), 4 pgs. |
Sawers, Paul, “Snapchat for iOS Lets You Send Photos to Friends and Set How long They're Visible for”, [Online]. Retrieved from the Internet: <http:/ /thenextweb.com/apps/2012/05/07/Snapchat-for-ios-lets-you-send-photos-to-friends-and-set-how-long-theyre-visiblefor/#!xCjrp>,(May 7, 2012), 5 pgs. |
Sawers, Paul, “Snapchat for ios lets you send photos to friends and set how long they're visible for”, http ://thenextweb.com/apps/2012/05/07/ snapchat-for-ios-lets-you-send-photos-to-f riends-and-set-how-long-theyre-visible-for, (May 2012), 1-3 pgs. |
Shein, Esther, “Ephemeral Data”, Communications of the ACM vol. 56 | No. 9, (Sep. 2013), 20-22. |
Vaas, Lisa, “StealthText, Should You Choose to Accept It”, [Online]. Retrieved from the Internet: <URL: http://www.eweek.com/print/c/a/MessagingandCollaboration/StealthTextShouldYouChoosetoAcceptIt>, (Dec. 13, 2005), 2 pgs. |
Number | Date | Country | |
---|---|---|---|
Parent | 14740786 | Jun 2015 | US |
Child | 15877037 | US |