Many types of software entities can expose a user to undesirable activities as a result of the user's interaction with the entity. Yet, most if not all of these software entities do not provide an integrated way to deal with the undesirable activity once the user is at or near a point of vulnerability.
Various embodiments provide integrated solutions for detecting and treating undesirable activities. Detection and treatment solutions are integrated with software entities, such as applications, DLLs and the like, and provide status notifications for the user as to the status of the detection and treatment activities. In at least some embodiments, an integrated user interface is provided and gives the user the option to provide input and affect at least some of the treatment options.
Overview
In the examples given below, various types of software entities can utilize the principles described in this document. For example, software entities such as various applications 106 and/or DLLs 108 can utilize the principles described below. Some types of applications include, by way of example and not limitation, email applications 110, browser applications 112, messenger applications 114, RSS aggregators 116, content sharing applications 118 such as photo-, music- and/or video-sharing applications, as well as a host of other applications 120 which, from a practical standpoint, are too numerous to list. Some types of DLLs that can utilize the principles described in this document include, by way of example and not limitation, file open dialog DLLs 122 which are typically called by various applications to open files, as well as a host of other DLLs 124 which, for the sake of brevity, are not listed here.
One characteristic of applications that can utilize the principles described in this document is that such applications typically provide or otherwise expose a list of items for a user. The items can comprise any suitable items and the list can comprise any suitable type of list. For example, one type of list is a log or a log activity list that can expose log items to a user. Log items might include files that a user has received or sent, email messages that the user has received or sent and the like.
In at least some of the illustrated and described embodiments, the software entity is configured to take steps associated with remedying an undesirable activity and, through user interface that is presented to a user, provide the user with status or state information associated with the remedial action that the software entity either performs or has performed on its behalf. Examples of undesirable activities can include by way of example and not limitation, receiving or otherwise being exposed to malware or spyware, receiving spam, and/or receiving or otherwise being exposed to virus-carrying files, messages, or content. Remedial actions that can be performed by the software entity or on its behalf can include by way of example and not limitation, deleting content, scanning and/or fixing virus-carrying content, and/or providing a user with an option to select one or more remedial activities that are to be performed.
To provide some tangible context for the reader to appreciate how the principles described in this document can be applied, an example is provided below in which an application in the form of a messenger application, such as an instant messenger application, is employed. The undesirable activity that is addressed and treated by the messenger application pertains to receiving potentially virus-carrying files or content. It is to be appreciated and understood that this constitutes but one example and is not to be used to limit application of the claimed subject matter to this particular environment. Rather, as noted above, the principles described in this document can be employed in other contexts without departing from the spirit and scope of the claimed subject matter.
Example User Interface
In accordance with one embodiment, user interface component 202 presents to the user a user interface that has multiple different portions. In this particular example, the user interface has two portions-a primary portion 204 that can be considered as being dedicated to at least some messenging or file sharing functionality provided by the messenger application, and a secondary or ancillary portion 206 which includes at least a portion that is dedicated to activity logging and to anti-virus scanning functionality. Secondary or ancillary portion 206 can also include user interface elements that are associated with a messenging functionality.
More generally, in this example as well as others in which the application is different from the specifically illustrated one, the application (i.e. the messenger application) can be considered as one that is not primarily concerned with an anti-virus scanning functionality. Rather, the application is primarily concerned with providing messenging functionality for the user. In this regard, the application is configured to provide a user interface experience that is not primarily associated with anti-virus scanning or, more generally, remedying an undesirable activity. So, in this example, content that is primarily associated with a messenging functionality is presented to the user in portion 204, and content that is associated with activity logging and anti-virus scanning activities can be presented to the user in portion 206.
With respect to the content that can be presented to the user that pertains to activity logging and anti-virus scanning activities, consider the following.
Such content can include state or status information that informs the user as to the state or status of scanning activities. For example, consider that user interface portion 206 is utilized to display a list of items that have been messaged to the user. Such list, which might be considered as a normal part of the messaging application, can include portions that provide the status on whether such items have been scanned or not, and if scanned, the status of the items (i.e. either safe or infected).
Alternately or additionally, user interface portion 206 can provide user interface elements that enable the user to interact in some way with the anti-virus functionality. For example, a user can be given an option to scan particular files and/or to fix or delete infected files. An example of this is provided below in the section entitled “Implementation Example”.
Accordingly, the
Specifically, using the folder or file sharing functionality, users can set up so-called replicating “Sharing Folders” with one another in order to share and edit files. In some embodiments, sharing can take place on a one-to-one basis, one-to-many basis or many-to-many basis (also referred to as a circle-share). So, in this particular implementation example, a user can create a “Sharing Folder” with a contact on his or her Messenger list, and the contact will receive an invitation to accept/decline the Sharing Folder. Once both users have set up the Sharing Folder with each other, they will have equal read/write access to it, and any file that they add, edit, or delete will be propagated to the other side. The Sharing Folders on both sides will always remain in-sync, so long as both users are signed into the Messenger service.
Accordingly,
Notice also that visual indicia, indicated at 404, is provided to show the user that the particular files are safe.
Exemplary System
In this particular example, application 700 includes a user interface component 704, such as the one shown and described above, an item transfer/access logic component 706 and an item status component 708.
Item transfer/access logic component 706 is configured to transfer or otherwise access items such as files. For example, in the context of the sharing folders application, component 706 transfers or accesses items in the form of files. In other contexts, such as when application 700 is instead a DLL, component 706 may be used to simply access items such as folders or files. Another example of item transfer/access logic is the file download logic in a browser, with its user interface counterpart being the file download status window or status user interface.
Of course, application 700 can contain other elements. However, for the sake of brevity, these have not been illustrated.
Item status component 708 allows the application to persistently store the anti-virus scanning status of its items, so that this status can be maintained, e.g. across applications or system restarts.
Anti-virus solution 702 includes a repair component 710 and a scan component 712. In practice, the repair component and scan component can utilize standard virus scanning and repair techniques. As such techniques will be known and appreciated by the skilled artisan, such are not described in detail here.
In this particular example, components 710, 712 can be invoked from the application through any existing mechanism offered by the underlying platform such as, for example, by calling a procedure that is part of a DLL, by running a process from the application, by calling into a COM interface, or by issuing an RPC call. The invocation of these components will typically have a number of arguments (e.g. to indicate what item needs to be scanned), and will return status information to the application. Note that in a particular embodiment, the scan component and the repair component may or may not be separate. In the latter case, the desired functionality can be specified by the application via one of the parameters.
Item store 714 comprises a store that is utilized to store items such as files and the like. The item store can be embodied in the file system or can comprise some other type of store. For example, such store may be the store used by an email client to keep received emails. In a particular embodiment, item store 714 and item status component 708 may or may not be separate.
The operation of the system of
First, the item transfer/access logic 706 adds a new item (at “1”) to the item store 714, or modifies one of the existing items. At this point, logic 706 may also notify the user interface 704 of the new or modified item. The user interface 704 can reflect the fact that the item has not yet been scanned (for instance, by using a different background color or an icon overlay). An example of this was provided above in
Next, at “2”, the item transfer/access logic 706 requests a scan on the new or modified item by invoking the scan component 712 of the anti-virus solution 702. In practice, logic 706 passes as an argument the location of the item in the item store 714 (e.g. if the item is a file, then it passes the file path). In an alternate embodiment, item transfer/access logic 706 may pass a copy of the entire item when invoking the scan component 712.
The scan component, at “3”, scans the item to determine whether it is infected with a virus, is “clean”, or is in some intermediate state of varying potential for infection. Based on its scan, scan component 712 returns the scan status, at “4”, to the item transfer/access logic 706. Next, the item transfer/access logic 706 persists, at “5”, the item status in the item status store or component 708.
The item transfer/access logic 706 notifies the user interface component 704, at “6”, on the item status. Upon receipt of the notification, the user interface component 704 can or should reflect the new status of the item for the user (i.e. “clean”, “infected”, or varying level of potential for infection) by means of some type of visually displayed indicia, examples of which are provided above. For example, the status may be reflected by a different background color that encompasses the affected item, by an icon overlay, or an infection probability rating.
If or when the user notices that one or more items have been flagged as “infected”, the user has the option to either ignore this notification, fix the items, or delete the items. If the user chooses to either fix or delete the items by selecting one of the appropriate user interface elements (such as elements 400, 402 in
Upon completion of its task, the repair component 710 can return, at “9”the fix/delete status to the user interface component 704. The user interface component 704 can then update, at “10” the item status in the item status store 708 and reflect the new status visually for the user, thus providing feedback to the user that the item(s) has been fixed or deleted.
Note that at step 6 above, the user interface component 704 may not currently display when an infected item is detected. For instance, if the application is an email client, it may receive an infected email while the application user interface is minimized. In that case, an application-specific way can be used to attract the user's attention to the fact that infected items have been found. Such application-specific can include, by way of example and not limitation, the following. The application's icon can be changed to attract the user's attention and prompt him or her to open the user interface. Alternately or additionally, the application's user interface can be opened directly. Alternately or additionally, a balloon can be used to inform the user that the application has detected infected items.
In addition, in at least some embodiments, the application may selectively treat items based on a computed infection rating. For example, if infected, the application may block the item from being opened. In the case of files, the infected files could be locked by the application. If an infection probability is greater than an application-specific threshold, as determined by applying heuristic rules, the application could display a mild warning in its activity log. If a new virus has been identified after the item was scanned with an out-of-date anti-virus signature file, the item can be re-scanned.
In the sharing folders implementation shown in
In
At this point, the item transfer/access logic 706 notifies the user interface component 704 of the new or modified item and records it in the Sharing Log. Because the item has not yet been scanned, it can be highlighted in yellow and marked as “Waiting for Scan” as shown in
The item transfer/access logic requests, at “2”, a scan on the new or modified item by invoking the scan component 712 of the anti-virus solution. To do so, it passes as an argument the file path of the file to be scanned.
The scan component 712 accesses the item at “3” and scans the item to determine whether it is infected with a virus, is “clean”, or could not be scanned at the moment. The scan component 712 then returns, at “4”, the scan status to the item transfer/access logic 706.
The item transfer/access logic 706 persists, at “5”, the item status in the item status component 708. The item transfer/access logic 706 next notifies, at “6” the user interface component 704 on the item's status. Upon receipt of the notification, the user interface component 704 can reflect the new status by means of a different background color (yellow for not scanned, red for infected), an icon instead of the file type icon, and text in the status column (“Waiting for Scan” or “Infected”), as shown in
When the user notices that one or more items have been flagged as “infected”, the user is provided, via the user interface, with the option to either ignore this notification, fix the items, or delete the items. The two “Fix Infected Files” and “Delete Infected Files” buttons in
Upon completion, the repair component returns, at “9”, the fix/delete status to the user interface component 704. The user interface component 704 can then update, at “10” the item's status in the item status store 708 and reflect the new status visually by clearing the background colors and returning the status text to normal, or by marking the item as deleted in the log, thus providing feedback to the user that the item(s) have been fixed or deleted, respectively.
Accordingly, in this particular embodiment, the user interface is able to provide a visual indication of the anti-virus scanning status for the items displayed or logged by the messenger application. This indication allows the user to determine which items have been scanned, and whether the scanned items have been found to be free from infection, are believed to be infected, or have a varying probability of being infected. Further, this particular embodiment can provide a way for the user of the application to select how to resolve potential infections by allowing the user to either ignore the infection, delete the infected items, or ask the anti-virus scanner to fix the items by removing the infection. Moreover, this embodiment can provide a way for the application to chose how to selectively treat the files based on their level of infection or potential infection. In addition, this embodiment can provide a visual indication that an infection has been resolved, i.e. the infected items have been deleted or fixed.
Hence, this embodiment can provide a rich visual feedback to the user regarding the current status of the items that are being handled by the application. The user can tell at a glance what the anti-virus scanning status of the items is without having to switch to a different user interface. Further, this and other embodiments can provide a clear indication to the user of where the infection originated from. For example, if the application is a file transfer application, then the infection may have originated from one of the received files; for an email application, the infection may have originated in one of the received email messages; for a browser download window, the infection may have been caused by one of the downloaded files.
Further, providing a way to control the resolution of infections is completely integrated into the user interface of the application which, in the embodiments described above, is an application that is not primarily dedicated to anti-virus activities. In particular, this allows the user to easily disable the offending functionality (at least temporarily) or change their behavior to avoid future infections. For example, if the infection is pinpointed to downloading a file from a particular website, the user may want to avoid visiting that website in the future.
Exemplary Methods
Step 800 exposes, via a user interface, a list of items. Examples of user interfaces and items are given above. In at least one embodiment, the user interface comprises part of a software entity that does not primarily pertain to anti-virus scanning. Examples of such entities are given above. Step 802 causes one or more of the items to be virus-scanned. Examples of how this can be done are given above. Step 804 updates the user, via the user interface, on the status or outcome of scanned items. Again, examples of how this can be done are given above.
Step 900 exposes a user interface that does not primarily pertain to remedying an undesirable activity that can be encountered via an application of which the user interface comprises a part. Examples of user interfaces and undesirable activities are given above. Step 902 allows a user, via the user interface, to select a remedial action that is to be performed relative to an undesirable activity that is encountered via the application. Examples of remedial actions are given above. Step 904 displays, via the user interface, status information pertaining to items that are exposed via the user interface. Examples of how this can be done are given above.
Step 1000 exposes an application's user interface to a user. In at least one embodiment, the user interface comprises part of a file-sharing user interface. Examples of file-sharing user interfaces are given above. Step 1002 displays, via the user interface, a log of files associated with file-sharing activities. Examples of logs are given above. Step 1004 provides, as part of the log, at least one portion that provides status information that pertains to whether individual files have been virus-scanned and the status of any files that have been virus-scanned. Examples of how this can be done are given above. Step 1006 displays, via the user interface, one or more user interface elements that permit a user to select an action with regard to any files that have been scanned. Examples of user interface elements and actions that can be selected using the user interface elements are given above.
Other Areas of Applicability
As noted in the discussion of
For example, an email client can display an infection status of email messages that are received in a mail visualization pane. For example, a user can look at their inbox and be able to see, at a glance, whether all of their incoming messages have been scanned and whether any of these messages has been found to be infected. Scanning of the messages may include both scanning the email body as well as any attachments to the message.
A browser download window can show the progress and history of the file downloads, and display an infection status for downloaded files.
A file open dialog can show the anti-virus scanning status of the files on disk and can thus offer the user a visual cue of whether it is safe to open the files from a given application. Since open file dialogs are generally shared among applications, this can provide uniform benefits to a large number of applications that would not have to be modified to include this anti-virus functionality.
An RSS aggregator (or any like application that subscribes to content feeds) can show the infection status of the feeds or particular files that it aggregates, and allow the user to clean files, block feeds, etc.
A photo-sharing, video-sharing, or music-sharing application can automatically block any respective photos, videos, or music content (whether downloaded or streamed) that are found to contain viruses.
A newsgroup reader application can scan the displayed postings to detect infected ones.
Conclusion
Various embodiments provide integrated solutions for detecting and treating undesirable activities. Detection and treatment solutions are integrated with software entities, such as applications, DLLs and the like, and provide status notifications for the user as to the status of the detection and treatment activities. In at least some embodiments, an integrated user interface is provided and gives the user the option to provide input and affect at least some of the treatment options.
Although the invention has been described in language specific to structural features and/or methodological steps, it is to be understood that the invention defined in the appended claims is not necessarily limited to the specific features or steps described. Rather, the specific features and steps are disclosed as preferred forms of implementing the claimed invention.