[go: nahoru, domu]

WO2000065833A1 - Method for context-sensitive help in a web based application - Google Patents

Method for context-sensitive help in a web based application Download PDF

Info

Publication number
WO2000065833A1
WO2000065833A1 PCT/US2000/010152 US0010152W WO0065833A1 WO 2000065833 A1 WO2000065833 A1 WO 2000065833A1 US 0010152 W US0010152 W US 0010152W WO 0065833 A1 WO0065833 A1 WO 0065833A1
Authority
WO
WIPO (PCT)
Prior art keywords
document
server
presenter
conference
conferencing
Prior art date
Application number
PCT/US2000/010152
Other languages
French (fr)
Inventor
Rune A. Skarbo
Cameron J. Clitheroe
Christopher C. Lawless
Puneet Kukkal
Stephen D. Hochman
Original Assignee
Intel Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corporation filed Critical Intel Corporation
Priority to CA002371243A priority Critical patent/CA2371243C/en
Priority to EP00922233A priority patent/EP1173977B1/en
Priority to AU42451/00A priority patent/AU4245100A/en
Priority to DE60029774T priority patent/DE60029774T2/en
Publication of WO2000065833A1 publication Critical patent/WO2000065833A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q10/00Administration; Management
    • G06Q10/10Office automation; Time management
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/90Details of database functions independent of the retrieved data types
    • G06F16/95Retrieval from the web
    • G06F16/955Retrieval from the web using information identifiers, e.g. uniform resource locators [URL]
    • G06F16/9566URL specific, e.g. using aliases, detecting broken or misspelled links
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N7/00Television systems
    • H04N7/14Systems for two-way working
    • H04N7/15Conference systems

Definitions

  • the field of the invention generally relates to data collaboration during video conferences, and more particularly to robustly providing such data to a conference participant's videoconference equipment.
  • conferencing equipment is typically running an exclusive application program that prevents a presenter from manipulating the underlying operating system of the conference equipment in order to effect the drive mapping.
  • a document-collaboration videoconferencing system between a first and a second conference attendee comprises a document server, a local presenter computing system, and a conferencing computing system.
  • the local presenter computing system transfers a document to the document server over a network, and the first conferencing system copies such document over the network from the document server.
  • FIG. 1A illustrates a typical configuration of computing devices used to effect collaborative data sharing during a video conference.
  • FIG. 1 B illustrates an information flow diagram for FIG. 1A.
  • FIG. 2 illustrates starting and ending a data collaboration conference.
  • FIG. 3 illustrates a form for uploading data to a document server.
  • FIG. 4 illustrates information flow in web pages from the document server.
  • FIG. 5 illustrates communication between a document server and a presenter.
  • FIG. 6 illustrates securing access to documents on the document server.
  • FIG. 7 illustrates viewing documents on conference equipment.
  • FIG. 8 shows a viewer application integrated with conference equipment.
  • FIG. 9 illustrates E-mail based document transfer.
  • FIG. 10 shows an example operating environment for claimed embodiments of the invention.
  • FIG. 1 illustrates a typical configuration of computing devices used to effect collaborative data sharing during a video conference.
  • a document server 100 there is a document server 100, a conferencing installation (videoconferencing equipment 102), and two conference participants, presenter 1 104, and presenter 2 106.
  • the server 100 and videoconferencing equipment 102 may be incorporated into a single computing device.
  • Each of these computing devices is interconnected by a network 108.
  • the network is a Transmission Control Protocol/Internet Protocol (TCP/IP) network, since TCP/IP has strong guarantees of data integrity.
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • the network 108 may be a single physical link, or a logical structure crafted from a combination of physical and non-physical data pathways (e.g., analog or digital dialup connections, satellite links, etc.).
  • the document server comprises the combination of web-client software on each client device (e.g., a presenter) 104, 106, and web-server software on the server 100.
  • client device e.g., a presenter
  • the presenters 104, 106 can utilize web browsers and receive active HTML content (or Java, JavaScript, JScript, ActiveX, Visual Basic, Active Server Page (ASP) files, and the like) to interact with the server; and the server can incorporate web-server extensions (e.g., DLLs 112 (FIG. 1 B), databases 114 (FIG. 1 B), etc.) or a complete server installation (e.g., an Apache web server).
  • DLLs 112 FIG. 1 B
  • databases 114 databases 114
  • a complete server installation e.g., an Apache web server
  • the document server 100 makes conference documents available to videoconferencing equipment 102.
  • Each conference attendee utilizes a videoconferencing equipment to participate in the conference.
  • the conference installation can download a copy of the documents from the document server.
  • the conference installation can then return any modified documents back to the document server.
  • each attendee's system may retrieve a copy of the documents, or only be given a view onto the documents, depending on the nature of the collaboration configuration.
  • the conference included sharing a word processing document
  • a first is to have all participants obtain a copy of the document, work on it locally, while the conference software automatically propagates changes to the other participant's copies.
  • a second is to open the document on the presenter's machine, and to mimic a view of the document on other attendee's machines.
  • a presenter's mouse, keyboard and other windowing events are captured and forwarded to the other attendees.
  • their attempts to work with the copy will cause the events to be forwarded to the presenter, where the edits are actually performed and an updated screen image sent back to the other attendees. In effect, this transparently emulates local editing of documents located on the presenter's machine.
  • FIG. 1 B illustrates an information flow diagram for the FIG. 1A configuration.
  • conference presenter 1 104 utilizes a web browser 110 to communicate with the document server 100 in order to submit all conference documents to the document server. Since a web browser is used to submit documents to the server 100, any browser in communication with the server can be used.
  • the document server 100 provides a user inter ace including web pages and active content displayed by a web browser 110.
  • the presenter 104 attends the conference and begins utilizing videoconferencing equipment 102. With this equipment 102, the presenter contacts the document server 100 and retrieves the conference documents. (Any videoconferencing equipment can retrieve the documents.)
  • embedded HTTP functionality HTML access module 116) within the videoconferencing equipment is used to cause transfer of the document server documents to the presenter's 104 videoconferencing equipment 102.
  • the document server is implemented on a server as a combination of web page templates 118, extension DLL(s) 112, and server scripts 120. Scripting can be implemented using ActiveX, Java script, VBScript, or the like.
  • the document server extension DLL(s) 112 provide the necessary Internet Server API (ISAPI) entry points to interface with web servers that require ISAPI.
  • ISAPI is a programming interface allowing web pages to invoke programs written as DLLs on a web server, and is an alternative to Common Gateway Interface (CGI) scripts; ISAPI can be used to access data in a database.
  • Microsoft's Internet Information Server (IIS) provides a DLL for embedding queries to access ODBC-compliant databases.
  • the ISAPI entry points are GetExtensionVersion(), HttpExtensionProc(), and TerminateExtension().
  • the GetExtensionVersion() API is called when the server loads the extension DLL and TerminateExtensionO is called when the DLL is unloading. These APIs will contain standard implementations.
  • the HttpExtensionProc() API will determine the action required by the document server and call the appropriate common document server service API.
  • Microsoft Corporation's Visual C++ 5.0 provides an MFC CHttpServer class which handles most of the standard extension DLL functionality; other compiler environments offer equivalent HTTP support.
  • the database 114 stores each user / presenter's 104, 106 account information and document information.
  • the database will be accessed from the extension DLL 112 using ODBC drivers on the server 100.
  • ODBC extension DLLs called Internet Database Connectors are also available to provide easier database access from the extension DLL.
  • These DLLs are usable by a NetScape API (NSAPI) / ISAPI implemented extension DLL.
  • NSAPI is by Netscape Communications Co. of Mountain View, CA, and essentially parallels ISAPI.
  • the database format can be any format accessible through DLLs, such as Microsoft Access, Inprise's DBase, and SQL formats (e.g., an SQL database by Oracle Corporation of Redwood Shores, CA).
  • ODBC the database 114 will allow the sharing of the database amongst multiple document server servers.
  • FIG. 2 is a flowchart illustrating starting and ending a data collaboration conference.
  • the first step 130 is initializing document servers to be used during the conference session.
  • a public access directory can be used to list accessible document servers according to certain criteria, e.g., geographic location, or processing ability.
  • Initialization of a document server includes obtaining a presenter's local files and copying them to the document server.
  • HTML Hypertext Markup Language
  • SMGL Standard Generalized Markup Language
  • FIG. 3 illustrates a sample form that can be sent to a presenter seeking to upload conference material to a document server.
  • a title bar 150 in which is contained the name 152 of a document server (here the server's name is "document server").
  • the server's name is "document server”
  • the left column 154 can be presented various interface options, such as help support, etc.
  • a first element is a document name entry field 156 in which a presenter can enter (or browse for) a name for a document to send to the document server.
  • a second element is a submission button 158 that causes the named file to be uploaded to the document server. (Due to HTML security models, the web page cannot directly request file data; a user must actively submit a form to which is attached the file data. This restriction is not present in other page description formats utilizing ActiveX (or equivalent) controls.)
  • a third element is a file list 160 which indicates all files that the presenter has already identified and sent to the document server. Associated with each uploaded file are attributes 162, such as file size and modification date, that allow the server to identify post-conference which files were modified during the conference. Also present are remove controls 164 that allow erroneously uploaded files to be removed from the document server. Documents may also be removed after a presenter's local copy of a document has been updated after a conference has ended.
  • FIG. 3 shows a list format for the files
  • a hierarchical folder view may be used instead.
  • the left column 154 could contain commands for opening, closing, moving, renaming, creating and deleting a selected folder.
  • mouse operations or keyboard selection
  • the next step is to initialize the conference installations 132 (e.g. attendees utilizing videoconferencing equipment 102 of FIG. 1 ).
  • the conference installations 132 e.g. attendees utilizing videoconferencing equipment 102 of FIG. 1
  • one of the conference installations corresponds to the presenter, unless the presenter's conference installation and the document server are implemented on the same computing device.
  • each participant connects to the document server and retrieves the working documents for the collaborative conference event.
  • the next step 134 is to hold the conference itself.
  • a typical video conference is taking place, within which document collaboration is taking place. Since video conferencing without document collaboration is well known (see, e.g., the H.320 standard), the details of the video portions of the conferencing will not be discussed at length herein. However, to perform document sharing during such a conference, several events must occur.
  • T.120 International Telecommunications Union
  • T.120 is a general reference to a series of related protocols, e.g., T.121 -T.133, T.RES, T.Share, and T.TUD.
  • An exemplary application supporting the T.120 protocol is the Microsoft® NetMeeting software, which is a point to point telephony and videophone program supporting whiteboard and application sharing.
  • the presenter opens an application program 140 in accord with standard sharing conventions. For example, the presenter could click on a file name in a graphical user interface on the presenter's conferencing equipment, causing the files related application to be loaded with the identified file. Then the presenter actively elects to share 142 the opened application in accord with document sharing conventions.
  • the conference attendees can engage in a typical collaborative videoconferencing arrangement, until such point as the presenter signals the end of the conference and stops sharing 144 the application (e.g., closes the application).
  • the next step is to update the document server 136 with any changes that were made to the documents during the conference sharing 142.
  • the presenter can then return to the local machine containing the original documents, and update 146 them as well.
  • a form is displayed to the conference presenter indicating which files have changed (according to attributes 162, FIG. 3). The presenter is then requested to submit the form (with appropriate confirmations) to cause the changed documents to be sent to the document server.
  • a windowing environment dialog box can be displayed on a presenter's videoconferencing equipment, prompting the presenter to update the document server.
  • the document server incorporates a revision control system to allow a history of documents to be maintained on the server.
  • the server can present a list of a current document version as well as previous versions. Different versions can be stored as separate files, or as delta-files containing difference data over previous document versions.
  • FIG. 4 illustrates the information flow in web pages sent by the document server. That is, as discussed above, the document server interface leads a user through a hierarchy of HTML web pages designed to accomplish the primary goal of uploading presentation documents to a web serverand/or viewing the documents stored on the server. This browser interface may also be accessed from the video conferencing PC in order to give a presentation in the video conferencing room. In this scenario, the browser may be shared within a conference.
  • the illustrated information flow takes the user through a login or account setup page to a presentation page built dynamically for each user. The user can then add, remove, update, or view presentation documents.
  • the first web page accessed by a user is a Login page 180 presenting login name 182 and password 184 fields, as well as a link to a new user account setup 186. Selecting this option generates a form 188 containing input entries for the new user's name 190, password 192, and password entry confirmation 194.
  • a Create Account 196 may be selected to create the new user account. Account creation may be governed by access control data local to conferencing equipment, or accounts may be automatically created by successful domain authentication. Creating the account takes the new user (or logged in user from form 180) to a user presentation page 198. This page contains a document list object 200 which will display a list of the documents that the user has uploaded to the web server as discussed above.
  • the list will show a document icon, name, and modification flag for each document.
  • the user may select and highlight a document on the list and then perform an action.
  • the actions will be in the form of buttons to view 202, remove 204, update 206, or add 208 a document.
  • the list may show multiple entries for each document to identify different formats for a document, allowing the user to select a document of a specific format.
  • the document list object 200 can be implemented as a Java object that displays the list of presentation documents and provides the capability to select one of the documents in preparation to performing an action on the document.
  • An alternate implementation utilizes an ActiveX object.
  • the data used to populate the presentation list can be downloaded as a separate data fHe for use by the object, or embedded directly into the web page as input data for the object. Creation of this data file, or embedding of the data into the web page is performed by a server side extension DLL 112. Alternatively, the file list can be generated with an ActiveX control and ASP files.
  • Add Document button 208 with an associated input entry box 210 and Browse button 212.
  • Selection of the Browse button will open the Windows 95 (or equivalent) common file browse dialog for the user to find and select the document file to upload.
  • this browse dialog may need to provide selection of a folder. Closing of this dialog will fill in the input entry box with the file path and name. The user may also type in the file path and name directly.
  • selecting the Add Document button will perform the actual file upload and cause the page to refresh with the new file listed as one of the user's stored documents.
  • the Add Document button will link to the server extension DLL, passing arguments that include the file name and action to perform.
  • an ActiveX control can be implemented to provide a multiple-file upload capability, where each file can be uploaded with a designated file format.
  • Other proprietary controls can be used as well to control file uploads.
  • HTML web based
  • selection of a document and subsequent selection of this button will execute software (e.g., Net-It Now! by Net-It Now Web Design of Brussels, Belgium) to dynamically generate a presentation of the document using HTML web pages.
  • creation of the HTML based presentation occurs automatically in the background when a document is uploaded to the document server.
  • the Presentation page 198 also contains several user maintenance links, such as an option to change one's password 214 which links to a Change Password page 216. There is also a link 218 to remove the user account which can be handled by an extension DLL 112 (FIG. 1 B) action to delete all user documents and remove the user directory from the document server. There can also be additional Maintenance Pages 220 for other administrative options, such as selecting auto-document deletion after n days, displaying user access rates, and resources used.
  • maintenance actions 220 will be links to server extension DLLs 112 to perform the action or retrieve data.
  • the Login 180, Create Account 196, and Change Password 214 options will utilize a Java script (or equivalent) to verify the form entries and then link to a server extension DLL 112 to perform the action.
  • the communication between the document server 100 and videoconferencing equipment 102 and HTTP access module 116 can now be more fully described.
  • the video conferencing software of the conference equipment utilizes ActiveX controls to access the server 100.
  • the HTTP access module can use several available COM interfaces, such as IMoniker to optimize the server access. The majority of document server actions performed can be accomplished by requesting an extension DLL Uniform Resource Locator (URL) and passing parameters identifying the action.
  • URL Uniform Resource Locator
  • the routine can make a request to an extension DLL 112 to return a list of registered user names.
  • an extension DLL 112 can interface with a document server to locate data files stored on the server.
  • This list will be returned as a plain or formatted text file, and may contain a flag indicating whether or not each user name requires a password to login to the document server.
  • the videoconferencing equipment 102 can request an extension DLL 112 that can be identical or similar to the login request that occurs from the browser Login page 180 (FIG. 4).
  • HTTP data for the browser Presentation Page 198 (returned from successful login or account creation) is returned by the extension DLL, and includes a list of the user documents stored on the document server.
  • the video conferencing software can check to verify that an associated application exists on the computing device for each file.
  • the associated application may be provided by the invention, or provided by a third-party file viewer. If no related application exists, the user can be prompted whether to add the document anyway. (If the user tries to preview or launch this document, a standard windows dialog asking for an associated application will pop up.)
  • HTTP is technically a stateless protocol (absent usage of keep- alive or equivalent options)
  • HTTP "cookies” are used.
  • a cookie is set in the returned page containing the user name. This cookie is sent by the browser to the server for each subsequent HTML page accessed from the document server.
  • the server extension DLLs 112 (FIG. 1B) will use the cookie to identify the user name for each request. The cookie will be deleted if the Remove Account action is requested, when the conference terminates, if the browser is closed / exited, or a logoff request received.
  • FIG. 5 is a flowchart illustrating data communication between the document server 100 (FIG. 1A) and a user / presenter (e.g., presenter 1 104).
  • the document server first receives a connection request 250 from a presenter. As discussed above, it is presumed that communication is web based, and therefore the user is utilizing a web browser 110 (FIG. 1 B) that has been directed at the document server's internal HTTP server / extensions 112 (FIG. 1 B).
  • the server 100 sends 252 the user's browser 110 a log in form encoded in HTML or other format (e.g., Java, ActiveX, etc.).
  • the user fills the form out and the server receives 254 the filled out form.
  • the server uses the form data to authenticate 256 the user's access to the server.
  • Authentication may be by any desired format, such as Windows NT challenge/response, basic authentication, and HTTPS user/password form, local lookup through a server access list, and the like.
  • Authentication can also be performed through another server, such as a Windows NT Domain Server, Novell server, or Kereberos authentication server.
  • the server 100 accesses 258 the user's local server storage, and sends 260 a list of stored documents to the user.
  • the storage contains the data that the user intends to share during a conference. On initial contact, the list will probably be empty unless the document server is configured to supply default documents.
  • the server 100 then waits to receive 262 further requests from the user.
  • requests can include add a document 264, remove a document or folder (if hierarchical folder-views are presented to the user instead of a simple list) 266, create a folder 268, and open/close 270 a folder (expand/collapse a hierarchy level).
  • processing 274 these requests is handled through generation of HTML forms, and/or Microsoft ASP forms.
  • Another request is a "download" 272 option, which links to a file to download to a machine (e.g., to copy something back to presenter 1 's local machine (104, FIG. 1 A)). Processing 274 of the link will be according to the conventions of the user's browser / Internet application 110 (FIG. 1 B).
  • selecting a file to download may open a local application program, run a browser "helper" application, prompt for further information, etc. (Note that a general processing box 274 is indicated to represent the corresponding execution of the related task, even though processing may be performed by separate program subroutines.)
  • FIG. 6 illustrates one method for securing access to documents stored on the document server 100 (FIG. 1A).
  • the document server 100 simplifies the process of getting conference documents to the videoconferencing equipment 102 by temporarily storing the documents for retrieval by the conferencing equipment.
  • the stored documents should be secured against unauthorized access by other users of the conferencing equipment. For example, let us assume that both presenters 104, 106 of FIG. 1 have uploaded conference documents to the document server 100 for use videoconferencing equipment 102. It is desirable that presenter 2 be unable to access documents prepared by presenter 1.
  • file system security permissions can be applied to the files.
  • file system security permissions can be applied to the files.
  • the videoconferencing equipment 102 utilizes the Windows NT operating system
  • different NT users can be added to the system, and local files designated as only readable by a particular user.
  • a problem with this approach is that it is not trivial to properly add and remove users to an NT environment, and such operations are usually performed manually. Given that most conference user accounts are transitory, manual user administration would be very cumbersome.
  • a more efficient URL hiding method can be employed. (Note that domain authentication, e.g., with Windows NT domain accounts, can be used to authenticate users.)
  • documents stored on the document server are secured against two different methods of unauthorized access.
  • security features of the host operating system can be used. Rather than creating accounts for each conference user, instead only an administrator account 300 and a generic conference equipment user account 302 is created. The properties of all document server files, including user uploaded files, have their access read, write, execute permissions set so that only the administrator account may utilize 304 the files. Consequently, any other access attempts 306 by non-privileged accounts is prevented by file-level access security 310 provided by the host operating system. Users other than the administrator 300 can only access the document server 100 documents using a web browser 308 or other interface provided by conferencing equipment.
  • the document server 100 implements URL redirection 312 and randomization 314 of document locations within the local storage of the server 100.
  • the document server can protect against identifying actual URL addresses by listing a fictitious (virtual) URL in the document list shown to the browser client.
  • a fictitious URL can be of the form "HTTP://- hostname/ShowUsers/usemame/documentname.”
  • This virtual URL is requested 316 by a browser 308, received by the web server, recognized as a virtual address, and then redirected 312 to a real document location 318.
  • redirection is effected by redirecting the access attempt to the document server 100 (FIG. 1A) HTTP extensions 112 (FIG. 1 B), and passing to the server the document name and user name obtained from the original URL.
  • the document server 100 then instructs the web server 112 to return the actual document 318 using the document's actual URL. But, since the browser 308 receives a data stream in response to the original URL request 316, the browser client (and hence its user) never becomes aware of the actual URL used.
  • An actual document URL can be of the form "HTTP://hostname/- ShowServer/UsersXXX/usemame/docname.”
  • the "XXX" portion of "UsersXXX” can be periodically renamed 314 to a random combination of alphanumeric characters (here an exemplary 3-character sequence is randomized). Renaming can be scheduled to occur according to elapsed time (e.g., perhaps daily with an operating system scheduler such as "cron" or "at”), and/or according to every n th document server access.
  • the server 100 instructs the HTTP server extensions 112 to return the actual document
  • the existence of the document referenced in the URL is first verified. This forestalls the HTTP server 112 presenting an "error 104 not found" result which would include the actual URL 318 that could not be located. If verification indicates that the document does not exist, the server can return a different error document in response to the request 316 to indicated that the document is unavailable.
  • FIG. 7 illustrates viewing documents without a corresponding document application program installed on the videoconferencing equipment 102 (FIG. 1A). Instead of requiring each conference attendee to have a document's creating application, a viewer application (e.g., a program that supports displaying a wide variety of different file types) is used to display a conference document. In one embodiment, the viewing application is integrated into the videoconferencing equipment 102.
  • a viewer application e.g., a program that supports displaying a wide variety of different file types
  • the viewing application is integrated into the videoconferencing equipment 102.
  • a document is retrieved from a document server 100, and displayed by a document viewer 348 as follows.
  • a user of the conference equipment requests 350 the document from document server 100 using the HTTP (or other) protocol as discussed above.
  • the document server returns 352 the requested document to the browser (which is stored in a browser cache).
  • the conference equipment stores the document onto local disk storage 354, and accesses 356 a document registry 358 (stored within a system registry) to identify an associated application for the document (e.g., Microsoft Word, etc.).
  • conference equipment then launches 364 the viewer application 348 to display the document.
  • the viewer application accesses 366 viewer filters 360 to load and format the document, and then loads 362 the document from the local disk storage 354.
  • a formatted version of document for display is returned 368 for display by the viewer application (e.g., in a display window associated with the viewer application; see FIG. 8).
  • Installation of the viewer application 348 requires registering the application to handle all file types (e.g., into the document registry 358). Assuming that the conference equipment resides on a Windows NT system, registration includes adding the document registry 358 entries into the general system registry to associate each file type with the viewer application 348. Provision can be made for pre-existing registrations, e.g., to leave such registrations alone, or prompt regarding replacement, so that improved viewers can be utilized as necessary or desired.
  • the system 102 When pre-loading a conference document within videoconferencing equipment 102 (e.g., as performed by the TeamStation), the system 102 is searched for an associated application. This search will identify the viewer application. The conference equipment then launches the associated viewer application to display the document either before or during a conference. Preferably, the viewer interface is integrated into the conference application's interface.
  • FIG. 8 illustrates an exemplary viewer application that has been integrated into the environment for the videoconferencing equipment 102 (FIG. 1A).
  • a conference participant 400 is sharing some documents 402 during a video conference.
  • a parent viewing window 404 is displayed.
  • This window 404 contains a simple menu 406 having basic File and Edit operations such as Save, Save As, Open, Close, and copy to clipboard.
  • a child viewing pane 410 displays the contents of viewed file.
  • the pane 410 includes scroll bars 412 if the document content does not fit within the viewer pane.
  • the viewing window 404 also includes sizeable borders to allow positioning and sizing of the viewing window 404.
  • Displaying documents in the viewing pane 410 can be achieved by using document filters 360 (FIG. 7) that can interpret the document file format and render a displayable image.
  • document filters 360 FIG. 7
  • the filters may also provide additional user interface features within the viewer window that are unique to the document being viewed, such as right mouse-click context sensitive menus, document navigation controls, full-screen viewing, and the like.
  • FIG. 9 shows one embodiment of the invention in which documents to be shared during a videoconference are transferred through E-mail. For example, at the conclusion of a conference session, shared documents can be automatically transmitted to the videoconference participants. Distribution of shared conferencing documents is integrated into the overall video conferencing scheme discussed above.
  • a conference attendee 450 stores documents on a document server 452 in preparation for an upcoming video conference.
  • the document server may operate as an independent machine, or as illustrated, in combination with the videoconferencing equipment 454 where the conference is to be held, or on other conferencing equipment entirely.
  • the physical location is unimportant, since communication with the document server is made over a Local Area Network (LAN) or a Wide Area Network (WAN) with a location independent protocol, e.g., HTTP.
  • LAN Local Area Network
  • WAN Wide Area Network
  • the attendee can use a network scheduling server 456 to arrange for the conference.
  • This scheduler may reside on conferencing equipment, or as shown, may be an independent machine reachable over a network link. It may also be based on or integrated with a public-access server providing scheduling services to customers, e.g., the "Yahoo! Calendar” by Yahoo! Inc. of Santa Clara, CA (http://calendar.yahoo.com).
  • the scheduler may also be integrated into the document server 452.
  • the scheduler 456 records conference attendees 450, 458, 460, 462 and a list of all documents or data that was shared during the conference.
  • a mail server 464 (shown as integrated with the scheduler) can distribute an advance-warning of the conference to all conference participants. This message contains a meeting agenda, an indication of documents to share, and other conference-related information.
  • any modified documents are sent back to the document server 452 to update its stored copy of the conference documents.
  • These documents are also distributed by the document server or hosting conferencing equipment 454 to all conference attendees 450, 458, 460, 462 by interfacing with the electronic mail server 464.
  • An electronic mail message is composed containing an optional digest or summary of the conference, a list of conference attendees and their contact information, along with all shared documents saved as attachments to the message. The message will also contain the date, time, and duration of the conference. This message is then submitted to the mail server 464 for delivery.
  • traditional mail services can be advantageously integrated into collaborative videoconferencing, to further facilitate the transfer of conference documents to appropriate parties.
  • FIG. 10 and the following discussion are intended to provide a brief, general description of a suitable computing environment in which the invention may be implemented.
  • the invention may be described by reference to different high-level program modules and/or low-level hardware contexts. Those skilled in the art will realize that program module references can be interchanged with low-level instructions.
  • Program modules include procedures, functions, programs, components, data structures, and the like, that perform particular tasks or implement particular abstract data types.
  • the modules may be incorporated into single and multi-processor computing systems, as well as hand-held devices and controllable consumer devices. It is understood that modules may be implemented on a single computing device, or processed over a distributed network environment, where modules can be located in both local and remote memory storage devices.
  • An exemplary system for implementing the invention includes a computing device 502 having system bus 504 for coupling together various components within the computing device.
  • the system 504 bus may be any of several types of bus structure including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of conventional bus architectures such as PCI, AGP, VESA, MicroChannel, ISA and EISA, to name a few. Note that only a single bus is illustrated, although plural buses typically achieve performance benefits.
  • attached to the bus 502 are a processor 506, a memory 508, storage devices (e.g., fixed 510, removable 512, optical/laser 514), a video interface 516, input/output interface ports 518, and a network interface 520.
  • the processor 506 may be any of various commercially available processors, including Intel processors, or the DEC Alpha, PowerPC, programmable gate arrays, signal processors, or the like. Dual, quad processors, and other multi-processor architectures also can be used.
  • the system memory includes random access memory (RAM) 522, and static or reprogrammable read only memory (ROM) 524.
  • RAM random access memory
  • ROM static or reprogrammable read only memory
  • BIOS basic input/output system
  • BIOS stored in ROM, contains routines for information transfer between device 502 components or device initialization.
  • the fixed storage 510 generally refers to hard drive and other semi-permanently attached media
  • removable storage 512 generally refers to a device-bay into which removable media such as a floppy diskette is removably inserted.
  • the optical/laser storage 514 include devices based on CD-ROM, DVD, or CD-RW technology, and are usually coupled to the system bus 504 through a device interface 526, 528, 530.
  • the storage systems and associated computer-readable media provide storage of data and executable instructions for the computing device 502. Note that other storage options include magnetic cassettes, tapes, flash memory cards, memory sticks, digital video disks, and the like.
  • the exemplary computing device 502 can store and execute a number of program modules within the RAM 522, ROM 524, and storage devices 510, 512, 514.
  • Typical program modules include an operating system 532, application programs 534 (e.g., a web browser or network application program), etc., and application data 536.
  • Program module or other system output can be processed by the video system 516 (e.g., a 2D and/or 3D graphics rendering device), which is coupled to the system bus 504 and an output device 538.
  • Typical output devices include monitors, flat-panels displays, liquid-crystal displays, and recording devices such as video-cassette recorders.
  • a user of the computing device 502 is typically a person interacting with the computing device through manipulation of an input device 540.
  • Common input devices include a keyboard, mouse, tablet, touch-sensitive surface, digital pen, joystick, microphone, game pad, satellite dish, etc.
  • the computing device 502 is expected to operate in a networked environment using logical connections to one or more remote computing devices.
  • One such remote computing device 542 may be a web server or other program module utilizing a network application protocol (e.g., HTTP, File Transfer Protocol (FTP), Gopher, Wide Area Information Server (WAIS)), a router, a peer device or other common network node, and typically includes many or all of the elements discussed for the computing device 502.
  • the computing device 502 has a network interface 520 (e.g., an Ethernet card) coupled to the system bus 504, to allow communication with the remote device 542.
  • a network interface 520 e.g., an Ethernet card
  • Both the local computing device 502 and the remote computing device 542 can be communicatively coupled to a network 544 such as a WAN, LAN, Gateway, Internet, or other public or private data-pathway. It will be appreciated that other communication links between the computing devices, such as through a modem 546 coupled to an interface port 518, may also be used.
  • a network 544 such as a WAN, LAN, Gateway, Internet, or other public or private data-pathway.
  • the present invention is described with reference to acts and symbolic representations of operations that are sometimes referred to as being computer-executed. It will be appreciated that the acts and symbolically represented operations include the manipulation by the processor 506 of electrical signals representing data bits which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in the memory 508 and storage systems 510, 512, 514, so as to reconfigure or otherwise alter the computer system's operation and/or processing of signals.
  • the memory locations where data bits are maintained are physical locations having particular electrical, magnetic, or optical properties corresponding to the data bits.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Business, Economics & Management (AREA)
  • Entrepreneurship & Innovation (AREA)
  • Databases & Information Systems (AREA)
  • General Physics & Mathematics (AREA)
  • Physics & Mathematics (AREA)
  • Strategic Management (AREA)
  • Human Resources & Organizations (AREA)
  • Data Mining & Analysis (AREA)
  • Signal Processing (AREA)
  • General Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Economics (AREA)
  • Marketing (AREA)
  • Operations Research (AREA)
  • Quality & Reliability (AREA)
  • Tourism & Hospitality (AREA)
  • General Business, Economics & Management (AREA)
  • Information Transfer Between Computers (AREA)
  • Two-Way Televisions, Distribution Of Moving Picture Or The Like (AREA)

Abstract

A document-collaboration videoconferencing system between a first and a second conference attendee. In one embodiment, the system comprises a document server, a local presenter computing system, and a conferencing computing system. In this embodiment, the local presenter computing system transfers a document to the document server over a network, and the first conferencing system copies such document over the network from the document server.

Description

Method for Context-Sensitive Help in a Web Based Application
Field of the Invention
The field of the invention generally relates to data collaboration during video conferences, and more particularly to robustly providing such data to a conference participant's videoconference equipment.
Background
In recent years, much progress has been made towards providing efficient and convenient methods for engaging in videoconferences in which conference participants can share and collaborate on program data files. However, due to the cost and complexity of the conferencing equipment, businesses typically have few (if any) videoconferencing configurations on premises. It is also common to have to go to third-party providers of - conferencing equipment in order to complete a videoconference session.
Since the goal of collaborative videoconferencing is the sharing of data, a fundamental requirement is that the data be brought to the conferencing premises. Unfortunately, getting the data to the conferencing equipment is not a simple task. Generally, the data can be quite large, and there are few easily portable resources that also have capacity to hold large data. In addition, even if the data fits on certain large capacity portable media, there is no guarantee that the conference location will support the media. In addition, media is frequently lost or damaged in transit to the conference.
One alternative to manually carrying presentation data to a conference has been to map, over a network, a local drive letter on the conferencing equipment to a source computer (e.g., a presenter's desktop computer containing presentation files). Then one can use normal operating system commands to copy the requisite data to the conference equipment. However, this solution is problematic, since managing networking connections can be difficult, and the conference curtailed or derailed if improper permissions or other issues prevent the mapping. In addition, for security purposes, conferencing equipment is typically running an exclusive application program that prevents a presenter from manipulating the underlying operating system of the conference equipment in order to effect the drive mapping.
What is needed, then, is a way to reliably get conferencing data to conference participants, while utilizing standard applications.
Summary
A document-collaboration videoconferencing system between a first and a second conference attendee. In one embodiment, the system comprises a document server, a local presenter computing system, and a conferencing computing system. In this embodiment, the local presenter computing system transfers a document to the document server over a network, and the first conferencing system copies such document over the network from the document server.
Brief Description of the Drawings
FIG. 1A illustrates a typical configuration of computing devices used to effect collaborative data sharing during a video conference.
FIG. 1 B illustrates an information flow diagram for FIG. 1A.
FIG. 2 illustrates starting and ending a data collaboration conference.
FIG. 3 illustrates a form for uploading data to a document server.
FIG. 4 illustrates information flow in web pages from the document server.
FIG. 5 illustrates communication between a document server and a presenter.
FIG. 6 illustrates securing access to documents on the document server.
FIG. 7 illustrates viewing documents on conference equipment.
FIG. 8 shows a viewer application integrated with conference equipment.
FIG. 9 illustrates E-mail based document transfer. FIG. 10 shows an example operating environment for claimed embodiments of the invention.
Detailed Description
FIG. 1 illustrates a typical configuration of computing devices used to effect collaborative data sharing during a video conference. As shown, there is a document server 100, a conferencing installation (videoconferencing equipment 102), and two conference participants, presenter 1 104, and presenter 2 106. (Note that the server 100 and videoconferencing equipment 102 may be incorporated into a single computing device.) Each of these computing devices is interconnected by a network 108. For simplicity, it is presumed that the network is a Transmission Control Protocol/Internet Protocol (TCP/IP) network, since TCP/IP has strong guarantees of data integrity. However, other networking protocols such as the Internet Control Message Protocol (ICMP) extension to TCP/IP, Internetwork Packet exchange (IPX), Sequenced Packet Exchange (SPX), AppleTalk, or the like can also be used. The network 108 may be a single physical link, or a logical structure crafted from a combination of physical and non-physical data pathways (e.g., analog or digital dialup connections, satellite links, etc.).
In one embodiment, the document server comprises the combination of web-client software on each client device (e.g., a presenter) 104, 106, and web-server software on the server 100. For example, the presenters 104, 106 can utilize web browsers and receive active HTML content (or Java, JavaScript, JScript, ActiveX, Visual Basic, Active Server Page (ASP) files, and the like) to interact with the server; and the server can incorporate web-server extensions (e.g., DLLs 112 (FIG. 1 B), databases 114 (FIG. 1 B), etc.) or a complete server installation (e.g., an Apache web server).
In a typical configuration, the document server 100 makes conference documents available to videoconferencing equipment 102. (Each conference attendee utilizes a videoconferencing equipment to participate in the conference.) For example, as a conference is started, the conference installation can download a copy of the documents from the document server. After the conference is completed, the conference installation can then return any modified documents back to the document server. During the conference, each attendee's system may retrieve a copy of the documents, or only be given a view onto the documents, depending on the nature of the collaboration configuration.
For example, if the conference included sharing a word processing document, there are several methods of sharing the document. A first is to have all participants obtain a copy of the document, work on it locally, while the conference software automatically propagates changes to the other participant's copies. A second is to open the document on the presenter's machine, and to mimic a view of the document on other attendee's machines. In this configuration, a presenter's mouse, keyboard and other windowing events are captured and forwarded to the other attendees. Similarly, their attempts to work with the copy will cause the events to be forwarded to the presenter, where the edits are actually performed and an updated screen image sent back to the other attendees. In effect, this transparently emulates local editing of documents located on the presenter's machine.
FIG. 1 B illustrates an information flow diagram for the FIG. 1A configuration. As shown, conference presenter 1 104 utilizes a web browser 110 to communicate with the document server 100 in order to submit all conference documents to the document server. Since a web browser is used to submit documents to the server 100, any browser in communication with the server can be used. (The document server 100 provides a user inter ace including web pages and active content displayed by a web browser 110.) After this has been completed, the presenter 104 attends the conference and begins utilizing videoconferencing equipment 102. With this equipment 102, the presenter contacts the document server 100 and retrieves the conference documents. (Any videoconferencing equipment can retrieve the documents.) As illustrated, in one embodiment, embedded HTTP functionality (HTTP access module 116) within the videoconferencing equipment is used to cause transfer of the document server documents to the presenter's 104 videoconferencing equipment 102.
In one configuration, the document server is implemented on a server as a combination of web page templates 118, extension DLL(s) 112, and server scripts 120. Scripting can be implemented using ActiveX, Java script, VBScript, or the like. The document server extension DLL(s) 112 provide the necessary Internet Server API (ISAPI) entry points to interface with web servers that require ISAPI. (ISAPI is a programming interface allowing web pages to invoke programs written as DLLs on a web server, and is an alternative to Common Gateway Interface (CGI) scripts; ISAPI can be used to access data in a database. Microsoft's Internet Information Server (IIS), for example, provides a DLL for embedding queries to access ODBC-compliant databases.)
In one embodiment, the ISAPI entry points are GetExtensionVersion(), HttpExtensionProc(), and TerminateExtension(). The GetExtensionVersion() API is called when the server loads the extension DLL and TerminateExtensionO is called when the DLL is unloading. These APIs will contain standard implementations. The HttpExtensionProc() API will determine the action required by the document server and call the appropriate common document server service API. Microsoft Corporation's Visual C++ 5.0 provides an MFC CHttpServer class which handles most of the standard extension DLL functionality; other compiler environments offer equivalent HTTP support.
In one configuration, the database 114 stores each user / presenter's 104, 106 account information and document information. The database will be accessed from the extension DLL 112 using ODBC drivers on the server 100. (A set of ODBC extension DLLs called Internet Database Connectors are also available to provide easier database access from the extension DLL.) These DLLs are usable by a NetScape API (NSAPI) / ISAPI implemented extension DLL. (NSAPI is by Netscape Communications Co. of Mountain View, CA, and essentially parallels ISAPI.) The database format can be any format accessible through DLLs, such as Microsoft Access, Inprise's DBase, and SQL formats (e.g., an SQL database by Oracle Corporation of Redwood Shores, CA). Through ODBC, the database 114 will allow the sharing of the database amongst multiple document server servers.
FIG. 2 is a flowchart illustrating starting and ending a data collaboration conference. As shown, the first step 130 is initializing document servers to be used during the conference session. For simplicity, it is assumed herein that there is only a single document server, however multiple servers may be used in a distributed context. For example, a public access directory can be used to list accessible document servers according to certain criteria, e.g., geographic location, or processing ability. Initialization of a document server includes obtaining a presenter's local files and copying them to the document server.
Since the document server is presumed to incorporate a web server or server extensions for its operating system, it is expected that Hypertext Markup Language (HTML) tags (or equivalents) are used to cause transfer of local presenter documents to the document server. (HTML is a document format based on the Standard Generalized Markup Language (SMGL) that uses "tags" to flag formatting, structure, data access, etc.) Thus, to cause copying of local files to the document server, a web form can be presented to a user, in which is embedded a file copy tag. When the user submits the form back to the server, file data is sent along with it.
For example, FIG. 3 illustrates a sample form that can be sent to a presenter seeking to upload conference material to a document server. As shown, there is a title bar 150 in which is contained the name 152 of a document server (here the server's name is "document server"). Along the left column 154 can be presented various interface options, such as help support, etc. Within the form itself are several form elements.
A first element is a document name entry field 156 in which a presenter can enter (or browse for) a name for a document to send to the document server. A second element is a submission button 158 that causes the named file to be uploaded to the document server. (Due to HTML security models, the web page cannot directly request file data; a user must actively submit a form to which is attached the file data. This restriction is not present in other page description formats utilizing ActiveX (or equivalent) controls.) A third element is a file list 160 which indicates all files that the presenter has already identified and sent to the document server. Associated with each uploaded file are attributes 162, such as file size and modification date, that allow the server to identify post-conference which files were modified during the conference. Also present are remove controls 164 that allow erroneously uploaded files to be removed from the document server. Documents may also be removed after a presenter's local copy of a document has been updated after a conference has ended.
It will be understood by one skilled in the art that even though FIG. 3 shows a list format for the files, a hierarchical folder view may be used instead. For example, in such a configuration, the left column 154 could contain commands for opening, closing, moving, renaming, creating and deleting a selected folder. In addition, as is customary in windowing environments, mouse operations (or keyboard selection) can be used to indicate operation of such commands.
Continuing now with FIG. 2, after initializing the document server 130, the next step is to initialize the conference installations 132 (e.g. attendees utilizing videoconferencing equipment 102 of FIG. 1 ). Typically, one of the conference installations corresponds to the presenter, unless the presenter's conference installation and the document server are implemented on the same computing device. Among other conference initialization operations, each participant connects to the document server and retrieves the working documents for the collaborative conference event.
The next step 134 is to hold the conference itself. As noted above, it is presumed that a typical video conference is taking place, within which document collaboration is taking place. Since video conferencing without document collaboration is well known (see, e.g., the H.320 standard), the details of the video portions of the conferencing will not be discussed at length herein. However, to perform document sharing during such a conference, several events must occur.
First, a connection must be made with all other conference participants 138. This requires that each participant support an appropriate data conferencing protocol, such as the International Telecommunications Union (ITU) T.120 protocol for efficient real-time distribution of files and graphical information. (Note T.120 is a general reference to a series of related protocols, e.g., T.121 -T.133, T.RES, T.Share, and T.TUD.) An exemplary application supporting the T.120 protocol is the Microsoft® NetMeeting software, which is a point to point telephony and videophone program supporting whiteboard and application sharing.
After all parties are connected, the presenter opens an application program 140 in accord with standard sharing conventions. For example, the presenter could click on a file name in a graphical user interface on the presenter's conferencing equipment, causing the files related application to be loaded with the identified file. Then the presenter actively elects to share 142 the opened application in accord with document sharing conventions.
At this point, the conference attendees can engage in a typical collaborative videoconferencing arrangement, until such point as the presenter signals the end of the conference and stops sharing 144 the application (e.g., closes the application). Once the conference has ended, the next step is to update the document server 136 with any changes that were made to the documents during the conference sharing 142. The presenter can then return to the local machine containing the original documents, and update 146 them as well.
In the context of using HTML forms to communicate with the document server, a form is displayed to the conference presenter indicating which files have changed (according to attributes 162, FIG. 3). The presenter is then requested to submit the form (with appropriate confirmations) to cause the changed documents to be sent to the document server. Alternatively, a windowing environment dialog box can be displayed on a presenter's videoconferencing equipment, prompting the presenter to update the document server.
If the document already exists on the server, the presenter is prompted to confirm overwriting files already present on the server. In one embodiment, the document server incorporates a revision control system to allow a history of documents to be maintained on the server. In this embodiment, for example, when retrieving files from the server, the server can present a list of a current document version as well as previous versions. Different versions can be stored as separate files, or as delta-files containing difference data over previous document versions.
FIG. 4 illustrates the information flow in web pages sent by the document server. That is, as discussed above, the document server interface leads a user through a hierarchy of HTML web pages designed to accomplish the primary goal of uploading presentation documents to a web serverand/or viewing the documents stored on the server. This browser interface may also be accessed from the video conferencing PC in order to give a presentation in the video conferencing room. In this scenario, the browser may be shared within a conference. The illustrated information flow takes the user through a login or account setup page to a presentation page built dynamically for each user. The user can then add, remove, update, or view presentation documents.
The first web page accessed by a user is a Login page 180 presenting login name 182 and password 184 fields, as well as a link to a new user account setup 186. Selecting this option generates a form 188 containing input entries for the new user's name 190, password 192, and password entry confirmation 194. Once this information is filled in, a Create Account 196 may be selected to create the new user account. Account creation may be governed by access control data local to conferencing equipment, or accounts may be automatically created by successful domain authentication. Creating the account takes the new user (or logged in user from form 180) to a user presentation page 198. This page contains a document list object 200 which will display a list of the documents that the user has uploaded to the web server as discussed above. In one embodiment, the list will show a document icon, name, and modification flag for each document. The user may select and highlight a document on the list and then perform an action. The actions will be in the form of buttons to view 202, remove 204, update 206, or add 208 a document. The list may show multiple entries for each document to identify different formats for a document, allowing the user to select a document of a specific format.
The document list object 200 can be implemented as a Java object that displays the list of presentation documents and provides the capability to select one of the documents in preparation to performing an action on the document. An alternate implementation utilizes an ActiveX object. The data used to populate the presentation list can be downloaded as a separate data fHe for use by the object, or embedded directly into the web page as input data for the object. Creation of this data file, or embedding of the data into the web page is performed by a server side extension DLL 112. Alternatively, the file list can be generated with an ActiveX control and ASP files.
To upload a document, there is an Add Document button 208 with an associated input entry box 210 and Browse button 212. Selection of the Browse button will open the Windows 95 (or equivalent) common file browse dialog for the user to find and select the document file to upload. To provide support for multiple file documents, this browse dialog may need to provide selection of a folder. Closing of this dialog will fill in the input entry box with the file path and name. The user may also type in the file path and name directly.
As discussed above (see FIG. 3), selecting the Add Document button will perform the actual file upload and cause the page to refresh with the new file listed as one of the user's stored documents. The input entry box will be an HTML input tag with type=File. The Add Document button will link to the server extension DLL, passing arguments that include the file name and action to perform. Alternatively, an ActiveX control can be implemented to provide a multiple-file upload capability, where each file can be uploaded with a designated file format. Other proprietary controls can be used as well to control file uploads.
In one embodiment, that is also an additional action button (not shown) to create a web based (HTML) presentation for the document. Selection of a document and subsequent selection of this button will execute software (e.g., Net-It Now! by Net-It Now Web Design of Brussels, Belgium) to dynamically generate a presentation of the document using HTML web pages. In an alternate embodiment, creation of the HTML based presentation occurs automatically in the background when a document is uploaded to the document server.
The Presentation page 198 also contains several user maintenance links, such as an option to change one's password 214 which links to a Change Password page 216. There is also a link 218 to remove the user account which can be handled by an extension DLL 112 (FIG. 1 B) action to delete all user documents and remove the user directory from the document server. There can also be additional Maintenance Pages 220 for other administrative options, such as selecting auto-document deletion after n days, displaying user access rates, and resources used.
In one embodiment, maintenance actions 220 will be links to server extension DLLs 112 to perform the action or retrieve data. Similarly, the Login 180, Create Account 196, and Change Password 214 options will utilize a Java script (or equivalent) to verify the form entries and then link to a server extension DLL 112 to perform the action.
Returning now to FIG. 1 B, the communication between the document server 100 and videoconferencing equipment 102 and HTTP access module 116 can now be more fully described. In one embodiment, the video conferencing software of the conference equipment utilizes ActiveX controls to access the server 100. For example, the HTTP access module can use several available COM interfaces, such as IMoniker to optimize the server access. The majority of document server actions performed can be accomplished by requesting an extension DLL Uniform Resource Locator (URL) and passing parameters identifying the action.
Thus, assuming the videoconferencing equipment 102 executes a routine to possibly browse for, and retrieve, required documents from the document server 100, the routine can make a request to an extension DLL 112 to return a list of registered user names. (For example, see the "Prepare Wizard" of the Intel TeamStation videoconferencing apparatus by Intel Corporation of Santa Clara, CA. This Wizard can interface with a document server to locate data files stored on the server.) This list will be returned as a plain or formatted text file, and may contain a flag indicating whether or not each user name requires a password to login to the document server.
To login to the document server, the videoconferencing equipment 102 can request an extension DLL 112 that can be identical or similar to the login request that occurs from the browser Login page 180 (FIG. 4). HTTP data for the browser Presentation Page 198 (returned from successful login or account creation) is returned by the extension DLL, and includes a list of the user documents stored on the document server. Before a document is allowed into the presentation file list (e.g., the list of files to use during the conference) from the document server file list, the video conferencing software can check to verify that an associated application exists on the computing device for each file. The associated application may be provided by the invention, or provided by a third-party file viewer. If no related application exists, the user can be prompted whether to add the document anyway. (If the user tries to preview or launch this document, a standard windows dialog asking for an associated application will pop up.)
Since HTTP is technically a stateless protocol (absent usage of keep- alive or equivalent options), in order to link user actions together as a single session, HTTP "cookies" are used. Upon successful login or account creation, a cookie is set in the returned page containing the user name. This cookie is sent by the browser to the server for each subsequent HTML page accessed from the document server. The server extension DLLs 112 (FIG. 1B) will use the cookie to identify the user name for each request. The cookie will be deleted if the Remove Account action is requested, when the conference terminates, if the browser is closed / exited, or a logoff request received.
FIG. 5 is a flowchart illustrating data communication between the document server 100 (FIG. 1A) and a user / presenter (e.g., presenter 1 104).
The document server first receives a connection request 250 from a presenter. As discussed above, it is presumed that communication is web based, and therefore the user is utilizing a web browser 110 (FIG. 1 B) that has been directed at the document server's internal HTTP server / extensions 112 (FIG. 1 B).
In response the server 100 sends 252 the user's browser 110 a log in form encoded in HTML or other format (e.g., Java, ActiveX, etc.). The user fills the form out and the server receives 254 the filled out form. The server uses the form data to authenticate 256 the user's access to the server. Authentication may be by any desired format, such as Windows NT challenge/response, basic authentication, and HTTPS user/password form, local lookup through a server access list, and the like. Authentication can also be performed through another server, such as a Windows NT Domain Server, Novell server, or Kereberos authentication server.
Once the user has been properly authenticated, the server 100 accesses 258 the user's local server storage, and sends 260 a list of stored documents to the user. As discussed above, the storage contains the data that the user intends to share during a conference. On initial contact, the list will probably be empty unless the document server is configured to supply default documents.
The server 100 then waits to receive 262 further requests from the user. Such requests can include add a document 264, remove a document or folder (if hierarchical folder-views are presented to the user instead of a simple list) 266, create a folder 268, and open/close 270 a folder (expand/collapse a hierarchy level). In one embodiment, processing 274 these requests is handled through generation of HTML forms, and/or Microsoft ASP forms. Another request is a "download" 272 option, which links to a file to download to a machine (e.g., to copy something back to presenter 1 's local machine (104, FIG. 1 A)). Processing 274 of the link will be according to the conventions of the user's browser / Internet application 110 (FIG. 1 B). For example, selecting a file to download may open a local application program, run a browser "helper" application, prompt for further information, etc. (Note that a general processing box 274 is indicated to represent the corresponding execution of the related task, even though processing may be performed by separate program subroutines.)
FIG. 6 illustrates one method for securing access to documents stored on the document server 100 (FIG. 1A). As discussed above, the document server 100 simplifies the process of getting conference documents to the videoconferencing equipment 102 by temporarily storing the documents for retrieval by the conferencing equipment. However, since the document server is generally available on a network, the stored documents should be secured against unauthorized access by other users of the conferencing equipment. For example, let us assume that both presenters 104, 106 of FIG. 1 have uploaded conference documents to the document server 100 for use videoconferencing equipment 102. It is desirable that presenter 2 be unable to access documents prepared by presenter 1.
There are two general approaches to the problem. In the first approach, file system security permissions can be applied to the files. For example, if the videoconferencing equipment 102 utilizes the Windows NT operating system, then different NT users can be added to the system, and local files designated as only readable by a particular user. A problem with this approach, however, is that it is not trivial to properly add and remove users to an NT environment, and such operations are usually performed manually. Given that most conference user accounts are transitory, manual user administration would be very cumbersome. Thus, unless tools are provided to script or otherwise automate adding and removing user accounts, a more efficient URL hiding method can be employed. (Note that domain authentication, e.g., with Windows NT domain accounts, can be used to authenticate users.)
In this second approach of URL hiding, documents stored on the document server are secured against two different methods of unauthorized access. First, access to documents can be attempted from anywhere on the network 108 (FIG. 1 A) using a browser or other network application. Second, access to documents may also be attempted by users of the conferencing equipment itself. That is, if the document server 100 resides on the videoconferencing equipment 102, then video conferencing participants have direct access to the system hard drive containing the stored documents. (When the document server 100 is separate from the videoconferencing equipment 102, then the document server can be placed in a physically secure location.)
Assuming that the server 100 and videoconferencing equipment 102 are combined, and a user has direct access to the document server 100, security features of the host operating system can be used. Rather than creating accounts for each conference user, instead only an administrator account 300 and a generic conference equipment user account 302 is created. The properties of all document server files, including user uploaded files, have their access read, write, execute permissions set so that only the administrator account may utilize 304 the files. Consequently, any other access attempts 306 by non-privileged accounts is prevented by file-level access security 310 provided by the host operating system. Users other than the administrator 300 can only access the document server 100 documents using a web browser 308 or other interface provided by conferencing equipment.
Under the traditional HTTP file-access paradigm, in order for the document server's web server components 112 (FIG. 1 B) to serve stored documents to a browser 308 (or equivalent) application, the documents must be stored in a location that can be accessed by any anonymous web browser client. However, since available documents are presented to a user 308 as a list (or folder view) of document URLs, a user can inspect the URLs to determine naming conventions and then attempt to access privileged documents of another user. To avoid this, in one embodiment, the document server 100 implements URL redirection 312 and randomization 314 of document locations within the local storage of the server 100.
The document server can protect against identifying actual URL addresses by listing a fictitious (virtual) URL in the document list shown to the browser client. For example, a fictitious URL can be of the form "HTTP://- hostname/ShowUsers/usemame/documentname." This virtual URL is requested 316 by a browser 308, received by the web server, recognized as a virtual address, and then redirected 312 to a real document location 318. In one embodiment, redirection is effected by redirecting the access attempt to the document server 100 (FIG. 1A) HTTP extensions 112 (FIG. 1 B), and passing to the server the document name and user name obtained from the original URL. The document server 100 then instructs the web server 112 to return the actual document 318 using the document's actual URL. But, since the browser 308 receives a data stream in response to the original URL request 316, the browser client (and hence its user) never becomes aware of the actual URL used.
An actual document URL can be of the form "HTTP://hostname/- ShowServer/UsersXXX/usemame/docname." As extra protection against a browser client determining the actual document URL, the "XXX" portion of "UsersXXX" can be periodically renamed 314 to a random combination of alphanumeric characters (here an exemplary 3-character sequence is randomized). Renaming can be scheduled to occur according to elapsed time (e.g., perhaps daily with an operating system scheduler such as "cron" or "at"), and/or according to every nth document server access.
As an additional measure of protection, before the server 100 instructs the HTTP server extensions 112 to return the actual document, the existence of the document referenced in the URL is first verified. This forestalls the HTTP server 112 presenting an "error 104 not found" result which would include the actual URL 318 that could not be located. If verification indicates that the document does not exist, the server can return a different error document in response to the request 316 to indicated that the document is unavailable.
FIG. 7 illustrates viewing documents without a corresponding document application program installed on the videoconferencing equipment 102 (FIG. 1A). Instead of requiring each conference attendee to have a document's creating application, a viewer application (e.g., a program that supports displaying a wide variety of different file types) is used to display a conference document. In one embodiment, the viewing application is integrated into the videoconferencing equipment 102.
As shown, a document is retrieved from a document server 100, and displayed by a document viewer 348 as follows. First, a user of the conference equipment requests 350 the document from document server 100 using the HTTP (or other) protocol as discussed above. The document server returns 352 the requested document to the browser (which is stored in a browser cache). The conference equipment stores the document onto local disk storage 354, and accesses 356 a document registry 358 (stored within a system registry) to identify an associated application for the document (e.g., Microsoft Word, etc.). Then conference equipment then launches 364 the viewer application 348 to display the document.
The viewer application accesses 366 viewer filters 360 to load and format the document, and then loads 362 the document from the local disk storage 354. A formatted version of document for display is returned 368 for display by the viewer application (e.g., in a display window associated with the viewer application; see FIG. 8).
Installation of the viewer application 348 requires registering the application to handle all file types (e.g., into the document registry 358). Assuming that the conference equipment resides on a Windows NT system, registration includes adding the document registry 358 entries into the general system registry to associate each file type with the viewer application 348. Provision can be made for pre-existing registrations, e.g., to leave such registrations alone, or prompt regarding replacement, so that improved viewers can be utilized as necessary or desired.
When pre-loading a conference document within videoconferencing equipment 102 (e.g., as performed by the TeamStation), the system 102 is searched for an associated application. This search will identify the viewer application. The conference equipment then launches the associated viewer application to display the document either before or during a conference. Preferably, the viewer interface is integrated into the conference application's interface.
FIG. 8 illustrates an exemplary viewer application that has been integrated into the environment for the videoconferencing equipment 102 (FIG. 1A). As shown, a conference participant 400 is sharing some documents 402 during a video conference. On selecting one of the documents, a parent viewing window 404 is displayed. This window 404 contains a simple menu 406 having basic File and Edit operations such as Save, Save As, Open, Close, and copy to clipboard. There is also a title bar 408 containing the name of the document being viewed. A child viewing pane 410 displays the contents of viewed file. The pane 410 includes scroll bars 412 if the document content does not fit within the viewer pane. The viewing window 404 also includes sizeable borders to allow positioning and sizing of the viewing window 404.
Displaying documents in the viewing pane 410 can be achieved by using document filters 360 (FIG. 7) that can interpret the document file format and render a displayable image. Several such filters exist as commercial software APIs that can be integrated into the viewer application. The filters may also provide additional user interface features within the viewer window that are unique to the document being viewed, such as right mouse-click context sensitive menus, document navigation controls, full-screen viewing, and the like.
FIG. 9 shows one embodiment of the invention in which documents to be shared during a videoconference are transferred through E-mail. For example, at the conclusion of a conference session, shared documents can be automatically transmitted to the videoconference participants. Distribution of shared conferencing documents is integrated into the overall video conferencing scheme discussed above.
For example, a conference attendee 450 stores documents on a document server 452 in preparation for an upcoming video conference. The document server may operate as an independent machine, or as illustrated, in combination with the videoconferencing equipment 454 where the conference is to be held, or on other conferencing equipment entirely. The physical location is unimportant, since communication with the document server is made over a Local Area Network (LAN) or a Wide Area Network (WAN) with a location independent protocol, e.g., HTTP.
The attendee can use a network scheduling server 456 to arrange for the conference. This scheduler may reside on conferencing equipment, or as shown, may be an independent machine reachable over a network link. It may also be based on or integrated with a public-access server providing scheduling services to customers, e.g., the "Yahoo! Calendar" by Yahoo! Inc. of Santa Clara, CA (http://calendar.yahoo.com). The scheduler may also be integrated into the document server 452. The scheduler 456 records conference attendees 450, 458, 460, 462 and a list of all documents or data that was shared during the conference. A mail server 464 (shown as integrated with the scheduler) can distribute an advance-warning of the conference to all conference participants. This message contains a meeting agenda, an indication of documents to share, and other conference-related information.
At conclusion of the conference, any modified documents are sent back to the document server 452 to update its stored copy of the conference documents. These documents are also distributed by the document server or hosting conferencing equipment 454 to all conference attendees 450, 458, 460, 462 by interfacing with the electronic mail server 464. An electronic mail message is composed containing an optional digest or summary of the conference, a list of conference attendees and their contact information, along with all shared documents saved as attachments to the message. The message will also contain the date, time, and duration of the conference. This message is then submitted to the mail server 464 for delivery. Thus, traditional mail services can be advantageously integrated into collaborative videoconferencing, to further facilitate the transfer of conference documents to appropriate parties.
FIG. 10 and the following discussion are intended to provide a brief, general description of a suitable computing environment in which the invention may be implemented. The invention may be described by reference to different high-level program modules and/or low-level hardware contexts. Those skilled in the art will realize that program module references can be interchanged with low-level instructions.
Program modules include procedures, functions, programs, components, data structures, and the like, that perform particular tasks or implement particular abstract data types. The modules may be incorporated into single and multi-processor computing systems, as well as hand-held devices and controllable consumer devices. It is understood that modules may be implemented on a single computing device, or processed over a distributed network environment, where modules can be located in both local and remote memory storage devices.
An exemplary system for implementing the invention includes a computing device 502 having system bus 504 for coupling together various components within the computing device. The system 504 bus may be any of several types of bus structure including a memory bus or memory controller, a peripheral bus, and a local bus using any of a variety of conventional bus architectures such as PCI, AGP, VESA, MicroChannel, ISA and EISA, to name a few. Note that only a single bus is illustrated, although plural buses typically achieve performance benefits. Typically, attached to the bus 502 are a processor 506, a memory 508, storage devices (e.g., fixed 510, removable 512, optical/laser 514), a video interface 516, input/output interface ports 518, and a network interface 520.
The processor 506 may be any of various commercially available processors, including Intel processors, or the DEC Alpha, PowerPC, programmable gate arrays, signal processors, or the like. Dual, quad processors, and other multi-processor architectures also can be used. The system memory includes random access memory (RAM) 522, and static or reprogrammable read only memory (ROM) 524. A basic input/output system (BIOS), stored in ROM, contains routines for information transfer between device 502 components or device initialization.
The fixed storage 510 generally refers to hard drive and other semi-permanently attached media, whereas removable storage 512 generally refers to a device-bay into which removable media such as a floppy diskette is removably inserted. The optical/laser storage 514 include devices based on CD-ROM, DVD, or CD-RW technology, and are usually coupled to the system bus 504 through a device interface 526, 528, 530. The storage systems and associated computer-readable media provide storage of data and executable instructions for the computing device 502. Note that other storage options include magnetic cassettes, tapes, flash memory cards, memory sticks, digital video disks, and the like.
The exemplary computing device 502 can store and execute a number of program modules within the RAM 522, ROM 524, and storage devices 510, 512, 514. Typical program modules include an operating system 532, application programs 534 (e.g., a web browser or network application program), etc., and application data 536. Program module or other system output can be processed by the video system 516 (e.g., a 2D and/or 3D graphics rendering device), which is coupled to the system bus 504 and an output device 538. Typical output devices include monitors, flat-panels displays, liquid-crystal displays, and recording devices such as video-cassette recorders.
A user of the computing device 502 is typically a person interacting with the computing device through manipulation of an input device 540. Common input devices include a keyboard, mouse, tablet, touch-sensitive surface, digital pen, joystick, microphone, game pad, satellite dish, etc. One can also provide input through manipulation of a virtual reality environment, or through processing the output from a data file or another computing device.
The computing device 502 is expected to operate in a networked environment using logical connections to one or more remote computing devices. One such remote computing device 542 may be a web server or other program module utilizing a network application protocol (e.g., HTTP, File Transfer Protocol (FTP), Gopher, Wide Area Information Server (WAIS)), a router, a peer device or other common network node, and typically includes many or all of the elements discussed for the computing device 502. The computing device 502 has a network interface 520 (e.g., an Ethernet card) coupled to the system bus 504, to allow communication with the remote device 542. Both the local computing device 502 and the remote computing device 542 can be communicatively coupled to a network 544 such as a WAN, LAN, Gateway, Internet, or other public or private data-pathway. It will be appreciated that other communication links between the computing devices, such as through a modem 546 coupled to an interface port 518, may also be used.
In accordance with the practices of persons skilled in the art of computer hardware and software programming, the present invention is described with reference to acts and symbolic representations of operations that are sometimes referred to as being computer-executed. It will be appreciated that the acts and symbolically represented operations include the manipulation by the processor 506 of electrical signals representing data bits which causes a resulting transformation or reduction of the electrical signal representation, and the maintenance of data bits at memory locations in the memory 508 and storage systems 510, 512, 514, so as to reconfigure or otherwise alter the computer system's operation and/or processing of signals. The memory locations where data bits are maintained are physical locations having particular electrical, magnetic, or optical properties corresponding to the data bits.
Having described and illustrated the principles of the invention with reference to illustrated embodiments, it will be recognized that the illustrated embodiments can be modified in arrangement and detail without departing from such principles.
For example, while the foregoing description focused ~ for expository convenience -- on collaborative videoconferencing based in part on a document server utilizing database and HTTP / HTML protocols, it will be recognized that the same techniques and analyses can be applied to different database configurations, such as remote or distributed database, and alternate communication protocols. Consequently, in view of the wide variety of networks and protocol options, the detailed embodiments are intended to be illustrative only, and should not be taken as limiting the scope of the invention. What is claimed as the invention, is all such modifications as may come within the scope and spirit of the following claims and equivalents thereto.

Claims

What is claimed is:
1. A document-collaboration videoconferencing system between a first and a second conference attendee, the system comprising: a document server; a local presenter computing system; and a first conferencing computing system; wherein the local presenter computing system transfers a document to the document server over a network, and the first conferencing system copies such document over the network from the document server.
2. The system of claim 1 , further comprising: a second conferencing computing system which copies the document over the network from the document server; wherein the document server and the first conferencing computing system are integrated into a single computer.
3. A system according to claim 1 , in which the document server comprises: a web server in communication with the first and second conferencing systems; and a database to store the document; wherein web pages are transmitted by the web server to cause transfer of the document from the document server to each conferencing system.
4. A system according to claim 3, in which each conferencing computing system comprises: an HTTP access module in communication with the document server over the network.
5. In a videoconferencing system, a method for providing documents for collaborative sharing, the method comprising: initializing an at least one document server with at least one document to share during a document-collaborative videoconference; initializing plural conferencing computing devices to obtain a local copy of the at least one document ; holding a document-collaborative videoconference with conference attendees; and updating the document server with a revised copy of the at least one document.
6. A method according to claim 5, wherein holding the document-collaborative videoconference comprises: connecting each conference attendee; opening an application program associated with the at least one document to share; and sharing the application program with each conference attendee.
7. A computer readable medium having computer instructions encoded thereon capable of causing a processor to perform the steps of claim 6.
8. A method according to claim 6, wherein sharing the application program for a shared document comprises: opening a document viewer application; locating a viewing filter for the shared document; and displaying the shared document according to the viewing filter; wherein the document viewer application removes need for an originating application for the shared document being installed on a conferencing device.
9. A method according to claim 5, wherein initializing the at least one document server comprises: receiving a connection request from a presenter computing device; receiving a login form from the presenter device, such completed form including presenter user data; authorizing the presenter user data; accessing user storage; and sending a stored documents list to the presenter device.
10. A computer readable medium having computer instructions encoded thereon capable of causing a processor to perform the steps of claim 9.
11. A method according to claim 9, further comprising: receiving a command request from the presenter computing device; wherein such command is a selected one of select a file, add a file, move a file, copy a file, remove a file, download a selected file to the presenter device, add a folder, move a folder, copy a folder, remove a folder, create a folder, expand a folder, collapse a folder, and download a selected folder to the presenter device.
12. A method according to claim 5, wherein initializing a conferencing computing device with a document server comprises: receiving a URL request for a document stored on the document server; and redirecting the URL to a protected URL location; transmitting data at the protected URL location to the conferencing computing device so that such device is unaware of redirection.
13. A computer readable medium having computer instructions encoded thereon capable of causing a processor to perform the steps of claim 12.
14. A method according to claim 12, the method further comprising: embedding a random alphanumeric sequence into the protected URL; and periodically changing the embedded random alphanumeric sequence.
15. A videoconferencing system for providing documents for collaborative sharing, comprising: means for initializing an at least one document server with at least one document to share during a document-collaborative videoconference; means for initializing plural conferencing computing devices to obtain a local copy of the at least one document ; means for holding a document-collaborative videoconference with conference attendees; and means for updating the document server with a revised copy of the at least one document.
16. A system according to claim 15, wherein means for holding the document-collaborative videoconference comprises: means for connecting conference each conference attendee; means for opening an application program associated with the at least one document to share; and means for sharing the application program with each conference attendee.
17. A system according to claim 16, wherein means for sharing the application program comprises: means for opening a document viewer application; means for locating a viewing filter for the shared document; and means for displaying the shared document according to the viewing filter.
18. A system according to claim 15, wherein means for initializing the at least one document server comprises: means for receiving a connection request from a presenter computing device; means for receiving a login form from the presenter device, such completed form including presenter user data; means for authorizing the presenter user data; means for accessing user storage; and means for sending a stored documents list to the presenter device.
19. A method according to claim 15, wherein means for initializing a conferencing computing device to obtain a local copy of the at least one document, comprises: means for receiving a URL request for a document stored on the document server; means for redirecting the URL to a protected URL location; means for embedding a random alphanumeric sequence into the protected URL; and means for periodically changing the embedded random alphanumeric sequence.
PCT/US2000/010152 1999-04-26 2000-04-13 Method for context-sensitive help in a web based application WO2000065833A1 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
CA002371243A CA2371243C (en) 1999-04-26 2000-04-13 Method for context-sensitive help in a web based application
EP00922233A EP1173977B1 (en) 1999-04-26 2000-04-13 Video conferencing system
AU42451/00A AU4245100A (en) 1999-04-26 2000-04-13 Method for context-sensitive help in a web based application
DE60029774T DE60029774T2 (en) 1999-04-26 2000-04-13 VIDEO CONFERENCE SYSTEM

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US09/299,808 US6317777B1 (en) 1999-04-26 1999-04-26 Method for web based storage and retrieval of documents
US09/299,808 1999-04-26

Publications (1)

Publication Number Publication Date
WO2000065833A1 true WO2000065833A1 (en) 2000-11-02

Family

ID=23156388

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2000/010152 WO2000065833A1 (en) 1999-04-26 2000-04-13 Method for context-sensitive help in a web based application

Country Status (6)

Country Link
US (1) US6317777B1 (en)
EP (1) EP1173977B1 (en)
AU (1) AU4245100A (en)
CA (1) CA2371243C (en)
DE (1) DE60029774T2 (en)
WO (1) WO2000065833A1 (en)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002075618A1 (en) * 2001-03-20 2002-09-26 The Department Of Natural Resources And Environment For And On Behalf Of The Crown In Right Of The State Of Victoria Data storage system
FR2855354A1 (en) * 2003-05-21 2004-11-26 France Telecom Videoconferencing system for network e.g. Internet, has session establishing module of videoconferencing server to establish session between client terminals on programmed date after notifying each registered user
WO2008043657A1 (en) * 2006-10-12 2008-04-17 International Business Machines Corporation Method, system and program product for building collaboration applications
US20120278408A1 (en) * 2011-04-29 2012-11-01 Crestron Electronics Inc. Meeting Management System Including Automated Equipment Setup
US20120293605A1 (en) * 2011-04-29 2012-11-22 Crestron Electronics, Inc. Meeting Management System Including Automated Equipment Setup
FR3038764A1 (en) * 2015-07-06 2017-01-13 Speakplus METHOD OF SHARING FILE BETWEEN TWO CLIENT POSITIONS OF A COMPUTER NETWORK WITHOUT A SPECIFIC SOFTWARE TO BE INSTALLED
US10044871B2 (en) 2011-04-29 2018-08-07 Crestron Electronics, Inc. Conference system including automated equipment setup
WO2019027458A1 (en) * 2017-08-02 2019-02-07 Intuit Inc. Integrating real-time personalized documents into a video conference session
US10673642B2 (en) 2017-08-02 2020-06-02 Intuit, Inc. Integrating real-time personalized documents into a video conference session
US10692020B2 (en) 2011-04-29 2020-06-23 Crestron Electronics, Inc. Real-time automatic meeting room reservation based on the number of actual participants

Families Citing this family (264)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8352400B2 (en) 1991-12-23 2013-01-08 Hoffberg Steven M Adaptive pattern recognition based controller apparatus and method and human-factored interface therefore
US5694546A (en) 1994-05-31 1997-12-02 Reisman; Richard R. System for automatic unattended electronic information transport between a server and a client by a vendor provided transport software with a manifest list
US6911987B1 (en) 1995-07-05 2005-06-28 Microsoft Corporation Method and system for transmitting data for a shared application
JP3592004B2 (en) * 1996-10-31 2004-11-24 キヤノン株式会社 Information sharing management system and information sharing system management apparatus and method
US7447738B1 (en) * 1997-03-14 2008-11-04 International Business Machines Corporation Component download selection mechanism for web browsers
US6374274B1 (en) 1998-09-16 2002-04-16 Health Informatics International, Inc. Document conversion and network database system
US6693661B1 (en) * 1998-10-14 2004-02-17 Polycom, Inc. Conferencing system having an embedded web server, and method of use thereof
US7904187B2 (en) 1999-02-01 2011-03-08 Hoffberg Steven M Internet appliance system and method
US6529952B1 (en) * 1999-04-02 2003-03-04 Nielsen Media Research, Inc. Method and system for the collection of cookies and other information from a panel
US6643779B1 (en) * 1999-04-15 2003-11-04 Brian Leung Security system with embedded HTTP server
US6817028B1 (en) 1999-06-11 2004-11-09 Scientific-Atlanta, Inc. Reduced screen control system for interactive program guide
US7010801B1 (en) 1999-06-11 2006-03-07 Scientific-Atlanta, Inc. Video on demand system with parameter-controlled bandwidth deallocation
US7992163B1 (en) 1999-06-11 2011-08-02 Jerding Dean F Video-on-demand navigational system
US7533146B1 (en) * 1999-06-14 2009-05-12 Epiphany, Inc. Shared web browser apparatus and method for interactive communications
SG121851A1 (en) * 1999-06-30 2006-05-26 Silverbrook Res Pty Ltd Method and system for conferencing using processing sensor
US6675216B1 (en) 1999-07-06 2004-01-06 Cisco Technolgy, Inc. Copy server for collaboration and electronic commerce
US6895402B1 (en) * 1999-08-25 2005-05-17 International Business Machines Corporation Detecting framing of a network resource identified by a target uniform resource locator
US6523063B1 (en) 1999-08-30 2003-02-18 Zaplet, Inc. Method system and program product for accessing a file using values from a redirect message string for each change of the link identifier
US6457045B1 (en) 1999-08-30 2002-09-24 Zaplet, Inc. System and method for group choice making
US6691153B1 (en) 1999-08-30 2004-02-10 Zaplet, Inc. Method and system for process interaction among a group
US6505233B1 (en) * 1999-08-30 2003-01-07 Zaplet, Inc. Method for communicating information among a group of participants
US6507865B1 (en) 1999-08-30 2003-01-14 Zaplet, Inc. Method and system for group content collaboration
US7640318B1 (en) * 1999-09-17 2009-12-29 Ricoh Co., Ltd. Method and apparatus for publishing documents over a network
US6598074B1 (en) * 1999-09-23 2003-07-22 Rocket Network, Inc. System and method for enabling multimedia production collaboration over a network
US6748420B1 (en) 1999-11-23 2004-06-08 Cisco Technology, Inc. Methods and apparatus for providing shared access to an application
US6751618B1 (en) * 1999-11-24 2004-06-15 Unisys Corporation Method and apparatus for a web application server to upload multiple files and invoke a script to use the files in a single browser request
US6928655B1 (en) * 1999-12-16 2005-08-09 Microsoft Corporation Live presentation searching
US7865545B1 (en) 1999-12-28 2011-01-04 International Business Machines Corporation System and method for independent room security management
US6732148B1 (en) 1999-12-28 2004-05-04 International Business Machines Corporation System and method for interconnecting secure rooms
US7012627B1 (en) 1999-12-28 2006-03-14 International Business Machines Corporation System and method for presentation of room navigation
US6594664B1 (en) * 2000-01-04 2003-07-15 International Business Machines Corporation System and method for online/offline uninterrupted updating of rooms in collaboration space
US7050079B1 (en) * 2000-01-04 2006-05-23 International Business Machines Corporation System and method for dynamically generating viewable graphics
US7237002B1 (en) * 2000-01-04 2007-06-26 International Business Machines Corporation System and method for dynamic browser management of web site
US6728762B1 (en) 2000-01-04 2004-04-27 International Business Machines Corporation System and method for browser definition of workflow documents
US6636889B1 (en) 2000-01-04 2003-10-21 International Business Machines Corporation System and method for client replication of collaboration space
US6748425B1 (en) 2000-01-04 2004-06-08 International Business Machines Corporation System and method for browser creation and maintenance of forms
US6772393B1 (en) 2000-01-04 2004-08-03 International Business Machines Corporation System and method for room decoration and inheritance
US7165060B2 (en) * 2000-02-14 2007-01-16 Lockheed Martin Corporation Information access, collaboration and integration system and method
US6760750B1 (en) * 2000-03-01 2004-07-06 Polycom Israel, Ltd. System and method of monitoring video and/or audio conferencing through a rapid-update web site
US8516525B1 (en) 2000-06-09 2013-08-20 Dean F. Jerding Integrated searching system for interactive media guide
US7200857B1 (en) 2000-06-09 2007-04-03 Scientific-Atlanta, Inc. Synchronized video-on-demand supplemental commentary
US7975277B1 (en) 2000-04-03 2011-07-05 Jerding Dean F System for providing alternative services
US6976090B2 (en) * 2000-04-20 2005-12-13 Actona Technologies Ltd. Differentiated content and application delivery via internet
US7934232B1 (en) 2000-05-04 2011-04-26 Jerding Dean F Navigation paradigm for access to television services
US7386614B2 (en) * 2000-05-19 2008-06-10 Treetop Ventures Llc Method allowing persistent links to web-pages
US8069259B2 (en) 2000-06-09 2011-11-29 Rodriguez Arturo A Managing removal of media titles from a list
US6618730B1 (en) * 2000-06-16 2003-09-09 Ge Capital Commercial Finance, Inc. Methods and systems for managing workflow
US7587497B1 (en) * 2000-06-20 2009-09-08 Palmsource Inc. Information exchange between a handheld device and another computer system using an exchange manager and uniform resource locator (URL) strings
US7437660B1 (en) * 2000-06-23 2008-10-14 Microsoft Corporation Editable dynamically rendered web pages
US7962370B2 (en) 2000-06-29 2011-06-14 Rodriguez Arturo A Methods in a media service system for transaction processing
CA2313802A1 (en) * 2000-07-11 2002-01-11 Michael Corcoran Dynamic web page caching system and method
US7299403B1 (en) 2000-10-11 2007-11-20 Cisco Technology, Inc. Methods and apparatus for obtaining a state of a browser
US6845390B1 (en) * 2000-11-10 2005-01-18 Hewlett-Packard Development Company, L.P. Server-side state replication among collaborating world wide web servers
US7340759B1 (en) 2000-11-10 2008-03-04 Scientific-Atlanta, Inc. Systems and methods for adaptive pricing in a digital broadband delivery system
US6973618B2 (en) 2000-12-29 2005-12-06 International Business Machines Corporation Method and system for importing MS office forms
US6950981B2 (en) * 2000-12-29 2005-09-27 International Business Machines Corporation Method and system for providing task information in a place
US6791582B2 (en) 2000-12-29 2004-09-14 International Business Machines Corporation Method and system for identifying and displaying information that is new or has been updated in a place
US6996780B2 (en) * 2000-12-29 2006-02-07 International Business Machines Corporation Method and system for creating a place type to be used as a template for other places
US7222291B2 (en) * 2000-12-29 2007-05-22 International Business Machines Corporation Method and system for importing HTML forms
US7028262B2 (en) * 2000-12-29 2006-04-11 International Business Machines Corporation Method and system for designing a theme and associating it with a collaboration space user interface
US7127676B2 (en) 2000-12-29 2006-10-24 International Business Machines Corporation Method and system for providing a separate browser window with information from the main window in a simpler format
US6744447B2 (en) 2000-12-29 2004-06-01 International Business Machines Corporation Method and system for compiling and using placebot agents for automatically accessing, processing, and managing the data in a place
US7020686B2 (en) 2000-12-29 2006-03-28 International Business Machines Corporation Method and system for providing synchronous communication and person awareness in a place
US20040205644A1 (en) * 2000-12-29 2004-10-14 International Business Machines Corporation Method and system for allowing in place editing of office documents in a place
US7386792B1 (en) 2001-03-07 2008-06-10 Thomas Layne Bascom System and method for collecting, storing, managing and providing categorized information related to a document object
US7158971B1 (en) 2001-03-07 2007-01-02 Thomas Layne Bascom Method for searching document objects on a network
US20020133547A1 (en) * 2001-03-15 2002-09-19 Coretex Limited Method and system for real time net communication under the basis of documents
US6820055B2 (en) * 2001-04-26 2004-11-16 Speche Communications Systems and methods for automated audio transcription, translation, and transfer with text display software for manipulating the text
US6727930B2 (en) 2001-05-18 2004-04-27 Hewlett-Packard Development Company, L.P. Personal digital assistant with streaming information display
US7231423B1 (en) 2001-05-23 2007-06-12 Jens Horstmann Interactive wireless device communication system for meetings and conferences
US7103644B1 (en) * 2001-06-29 2006-09-05 Bellsouth Intellectual Property Corp. Systems for an integrated data network voice-oriented service and non-voice-oriented service converged creation and execution environment
US7512964B2 (en) 2001-06-29 2009-03-31 Cisco Technology System and method for archiving multiple downloaded recordable media content
US7496945B2 (en) 2001-06-29 2009-02-24 Cisco Technology, Inc. Interactive program guide for bidirectional services
US7526788B2 (en) 2001-06-29 2009-04-28 Scientific-Atlanta, Inc. Graphic user interface alternate download options for unavailable PRM content
US6981263B1 (en) * 2001-06-29 2005-12-27 Bellsouth Intellectual Property Corp. Methods and systems for converged service creation and execution environment applications
US8006262B2 (en) 2001-06-29 2011-08-23 Rodriguez Arturo A Graphic user interfaces for purchasable and recordable media (PRM) downloads
US7743109B2 (en) 2001-08-01 2010-06-22 Cisco Technology, Inc. Reducing round trips across a wide area network for resource locking by extended locking and delayed unlocking
US6944868B2 (en) * 2001-08-08 2005-09-13 Hewlett-Packard Development Company, L.P. Imaging extension API for isolating web content from user resources and services
US7191448B2 (en) * 2001-08-08 2007-03-13 Hewlett-Packard Development Company, L.P. Web based imaging page redirector system for accessing a redirector reference that directs a browser to a redirector software
US7447608B1 (en) 2001-09-28 2008-11-04 Infocus Corporation Method and apparatus for a collaborative meeting room system
US20030097410A1 (en) * 2001-10-04 2003-05-22 Atkins R. Travis Methodology for enabling multi-party collaboration across a data network
US20030070072A1 (en) * 2001-10-09 2003-04-10 Nick Nassiri System and method of identity and signature and document authentication using a video conference
US20030086122A1 (en) * 2001-11-06 2003-05-08 Parry Travis J. Imaging device communication via email
US7380120B1 (en) 2001-12-12 2008-05-27 Guardian Data Storage, Llc Secured data format for access control
US8006280B1 (en) 2001-12-12 2011-08-23 Hildebrand Hal S Security system for generating keys from access rules in a decentralized manner and methods therefor
US7783765B2 (en) 2001-12-12 2010-08-24 Hildebrand Hal S System and method for providing distributed access control to secured documents
USRE41546E1 (en) 2001-12-12 2010-08-17 Klimenty Vainstein Method and system for managing security tiers
US7260555B2 (en) 2001-12-12 2007-08-21 Guardian Data Storage, Llc Method and architecture for providing pervasive security to digital assets
US7178033B1 (en) 2001-12-12 2007-02-13 Pss Systems, Inc. Method and apparatus for securing digital assets
US10033700B2 (en) 2001-12-12 2018-07-24 Intellectual Ventures I Llc Dynamic evaluation of access rights
US6948062B1 (en) * 2001-12-12 2005-09-20 Intel Corporation Location dependent encryption and/or decryption
US7921450B1 (en) 2001-12-12 2011-04-05 Klimenty Vainstein Security system using indirect key generation from access rules and methods therefor
US7921288B1 (en) 2001-12-12 2011-04-05 Hildebrand Hal S System and method for providing different levels of key security for controlling access to secured items
US8065713B1 (en) * 2001-12-12 2011-11-22 Klimenty Vainstein System and method for providing multi-location access management to secured items
US7681034B1 (en) 2001-12-12 2010-03-16 Chang-Ping Lee Method and apparatus for securing electronic data
US7921284B1 (en) 2001-12-12 2011-04-05 Gary Mark Kinghorn Method and system for protecting electronic data in enterprise environment
US7930756B1 (en) 2001-12-12 2011-04-19 Crocker Steven Toye Multi-level cryptographic transformations for securing digital assets
US7565683B1 (en) 2001-12-12 2009-07-21 Weiqing Huang Method and system for implementing changes to security policies in a distributed security system
US10360545B2 (en) 2001-12-12 2019-07-23 Guardian Data Storage, Llc Method and apparatus for accessing secured electronic data off-line
US7950066B1 (en) 2001-12-21 2011-05-24 Guardian Data Storage, Llc Method and system for restricting use of a clipboard application
US7334251B2 (en) 2002-02-11 2008-02-19 Scientific-Atlanta, Inc. Management of television advertising
US8176334B2 (en) 2002-09-30 2012-05-08 Guardian Data Storage, Llc Document security system that permits external users to gain access to secured files
US20030172164A1 (en) * 2002-03-11 2003-09-11 Coughlin Chesley B. server persistence using a session identifier
US20050132412A1 (en) * 2002-03-20 2005-06-16 Richardson John W. Videoconference system architecture
ES2260346T3 (en) * 2002-03-27 2006-11-01 Siemens Aktiengesellschaft DYNAMIC MONITORING OF WEB CONFERENCES THROUGH A CONTINUOUS TRANSMISSION MECHANISM.
US7418664B2 (en) * 2002-04-03 2008-08-26 Microsoft Corporation Application sharing single document sharing
US7028266B2 (en) * 2002-04-05 2006-04-11 Microsoft Corporation Processing occluded windows during application sharing
US7668901B2 (en) * 2002-04-15 2010-02-23 Avid Technology, Inc. Methods and system using a local proxy server to process media data for local area users
US7454760B2 (en) 2002-04-22 2008-11-18 Rosebud Lms, Inc. Method and software for enabling n-way collaborative work over a network of computers
US8613102B2 (en) 2004-03-30 2013-12-17 Intellectual Ventures I Llc Method and system for providing document retention using cryptography
US8756513B1 (en) 2002-04-23 2014-06-17 Microsoft Corporation Document viewing mechanism for document sharing environment
US20040015546A1 (en) * 2002-07-22 2004-01-22 Web.De Ag Communications environment having communications between portals
US20040148392A1 (en) * 2003-01-29 2004-07-29 Web.De Ag Website having an event identification element
US20050182824A1 (en) * 2002-04-30 2005-08-18 Pierre-Alain Cotte Communications web site
US20040148351A1 (en) * 2003-01-29 2004-07-29 Web.De Ag Communications web site
US20040015541A1 (en) * 2002-07-22 2004-01-22 Web.De Ag Communications environment having a portal
US20040146048A1 (en) * 2003-01-29 2004-07-29 Web.De Ag Web site having a caller recognition element
US7293243B1 (en) 2002-05-22 2007-11-06 Microsoft Corporation Application sharing viewer presentation
US7356563B1 (en) 2002-06-06 2008-04-08 Microsoft Corporation Methods of annotating a collaborative application display
US7568004B2 (en) * 2002-06-20 2009-07-28 Linda Gottfried Method and system for sharing brand information
US6691155B2 (en) 2002-06-20 2004-02-10 Linda Gottfried Multimedia system for sharing brand information keeps history of modifications of production information by consumers to allow recreating multimedia interface in its previous formats
US20040044648A1 (en) * 2002-06-24 2004-03-04 Xmyphonic System As Method for data-centric collaboration
US20110119353A1 (en) 2002-08-06 2011-05-19 Tsao Sheng Tai Ted Method and Apparatus for information exchange over a web based environment
US8577839B2 (en) 2002-08-06 2013-11-05 Sheng Tai (Ted) Tsao Method and apparatus of dynamic updating web portals
US20080091761A1 (en) * 2002-08-06 2008-04-17 Stt Webos, Inc. Method and apparatus for information exchange over a web based environment
US7512810B1 (en) 2002-09-11 2009-03-31 Guardian Data Storage Llc Method and system for protecting encrypted files transmitted over a network
US20040075866A1 (en) * 2002-10-18 2004-04-22 Thormodsen Arne D. Poster preparation system and method
AU2003301634A1 (en) * 2002-10-21 2004-05-13 Applied Global Technologies, Inc. System and method for sharing, viewing, and controlling mutliple information systems
US7818678B2 (en) 2002-10-31 2010-10-19 Litera Technology Llc Collaborative document development and review system
US7836310B1 (en) 2002-11-01 2010-11-16 Yevgeniy Gutnik Security system that uses indirect password-based encryption
US7716312B2 (en) 2002-11-13 2010-05-11 Avid Technology, Inc. Method and system for transferring large data files over parallel connections
US7761505B2 (en) 2002-11-18 2010-07-20 Openpeak Inc. System, method and computer program product for concurrent performance of video teleconference and delivery of multimedia presentation and archiving of same
US20040117374A1 (en) * 2002-12-16 2004-06-17 Hung Lup Cheong Patrick Customized design portfolio integrating IP libraries and technology documents
US20040107214A1 (en) * 2002-11-29 2004-06-03 Hung Lup Cheong Patrick Customized document portfolio system integrating IP libraries and technology documents
US20040107197A1 (en) * 2002-11-29 2004-06-03 Shen Yu Yong System, method and user interface allowing customized portfolio management
US7386539B2 (en) 2002-11-29 2008-06-10 Taiwan Semiconductor Manufacturing Company, Ltd. System, method, and user interface providing customized document portfolio management
US7890990B1 (en) 2002-12-20 2011-02-15 Klimenty Vainstein Security system with staging capabilities
US7613773B2 (en) * 2002-12-31 2009-11-03 Rensselaer Polytechnic Institute Asynchronous network audio/visual collaboration system
WO2004068376A1 (en) * 2003-01-30 2004-08-12 Christoph Burkhard Method for organizing teamwork in a project group or development group comprising several participants
WO2004072804A2 (en) * 2003-02-10 2004-08-26 Raindance Communications, Inc. Methods and apparatus for providing egalitarian control in a multimedia collaboration session
US7627552B2 (en) 2003-03-27 2009-12-01 Microsoft Corporation System and method for filtering and organizing items based on common elements
US7421438B2 (en) 2004-04-29 2008-09-02 Microsoft Corporation Metadata editing control
US7240292B2 (en) 2003-04-17 2007-07-03 Microsoft Corporation Virtual address bar user interface control
US7823077B2 (en) * 2003-03-24 2010-10-26 Microsoft Corporation System and method for user modification of metadata in a shell browser
US7925682B2 (en) * 2003-03-27 2011-04-12 Microsoft Corporation System and method utilizing virtual folders
WO2004100429A2 (en) * 2003-05-01 2004-11-18 James, Long Network download system
US8707034B1 (en) 2003-05-30 2014-04-22 Intellectual Ventures I Llc Method and system for using remote headers to secure electronic files
US20050004986A1 (en) * 2003-07-03 2005-01-06 Aoki Norihiro Edwin Remote population of computer clipboard via a messaging system
US7599938B1 (en) 2003-07-11 2009-10-06 Harrison Jr Shelton E Social news gathering, prioritizing, tagging, searching, and syndication method
US20050060382A1 (en) * 2003-09-15 2005-03-17 Alex Spector On-Demand Electronic Documents Processing and Sharing
US8127366B2 (en) 2003-09-30 2012-02-28 Guardian Data Storage, Llc Method and apparatus for transitioning between states of security policies used to secure electronic documents
US7703140B2 (en) 2003-09-30 2010-04-20 Guardian Data Storage, Llc Method and system for securing digital assets using process-driven security policies
US8024335B2 (en) 2004-05-03 2011-09-20 Microsoft Corporation System and method for dynamically generating a selectable search extension
IL159838A0 (en) 2004-01-13 2004-06-20 Yehuda Binder Information device
US8161388B2 (en) 2004-01-21 2012-04-17 Rodriguez Arturo A Interactive discovery of display device characteristics
EP1723777A1 (en) * 2004-01-30 2006-11-22 Combots Product GmbH & Co.KG Establishment of links with the aid of contact elements
US20050192920A1 (en) * 2004-02-17 2005-09-01 Hodge Philip C. Real time data management apparatus, system and mehtod
US20090019061A1 (en) * 2004-02-20 2009-01-15 Insignio Technologies, Inc. Providing information to a user
US10417298B2 (en) * 2004-12-02 2019-09-17 Insignio Technologies, Inc. Personalized content processing and delivery system and media
US20050234961A1 (en) * 2004-04-16 2005-10-20 Pinnacle Systems, Inc. Systems and Methods for providing a proxy for a shared file system
US8707209B2 (en) 2004-04-29 2014-04-22 Microsoft Corporation Save preview representation of files being created
US7005957B2 (en) * 2004-05-29 2006-02-28 Tsung-Mou Yu Mechanism for trip-free of the bimetallic plate of a safety switch device
US7437364B1 (en) * 2004-06-30 2008-10-14 Google Inc. System and method of accessing a document efficiently through multi-tier web caching
US8224964B1 (en) 2004-06-30 2012-07-17 Google Inc. System and method of accessing a document efficiently through multi-tier web caching
US8676922B1 (en) 2004-06-30 2014-03-18 Google Inc. Automatic proxy setting modification
US8296562B2 (en) 2004-07-15 2012-10-23 Anakam, Inc. Out of band system and method for authentication
US8528078B2 (en) * 2004-07-15 2013-09-03 Anakam, Inc. System and method for blocking unauthorized network log in using stolen password
US7676834B2 (en) * 2004-07-15 2010-03-09 Anakam L.L.C. System and method for blocking unauthorized network log in using stolen password
US8533791B2 (en) 2004-07-15 2013-09-10 Anakam, Inc. System and method for second factor authentication services
ES2420158T3 (en) * 2004-07-15 2013-08-22 Anakam, Inc. System and method to block an unauthorized network login using a stolen password
US7707427B1 (en) 2004-07-19 2010-04-27 Michael Frederick Kenrich Multi-level file digests
US7707498B2 (en) 2004-09-30 2010-04-27 Microsoft Corporation Specific type content manager in an electronic document
US7912973B2 (en) * 2004-12-03 2011-03-22 Microsoft Corporation Message exchange protocol extension negotiation
US7945590B2 (en) 2005-01-06 2011-05-17 Microsoft Corporation Programmability for binding data
US7730394B2 (en) 2005-01-06 2010-06-01 Microsoft Corporation Data binding in a word-processing application
US7617234B2 (en) * 2005-01-06 2009-11-10 Microsoft Corporation XML schema for binding data
US7668873B2 (en) * 2005-02-25 2010-02-23 Microsoft Corporation Data store for software application documents
US7752224B2 (en) * 2005-02-25 2010-07-06 Microsoft Corporation Programmability for XML data store for documents
JP4736816B2 (en) * 2005-04-28 2011-07-27 富士ゼロックス株式会社 Reading document management program, reading document management system, and reading document management method
US20060259490A1 (en) * 2005-04-28 2006-11-16 Kazunori Horikiri Document management system, document management method, and recording medium storing program for document management
US7665028B2 (en) 2005-07-13 2010-02-16 Microsoft Corporation Rich drag drop user interface
US8189472B2 (en) 2005-09-07 2012-05-29 Mcdonald James F Optimizing bandwidth utilization to a subscriber premises
US7953696B2 (en) 2005-09-09 2011-05-31 Microsoft Corporation Real-time synchronization of XML data between applications
US20070120969A1 (en) * 2005-09-15 2007-05-31 Alpha Omega International Audio visual communication system and method
US7987251B2 (en) * 2005-09-16 2011-07-26 Microsoft Corporation Validation of domain name control
DE602006014192D1 (en) 2005-12-02 2010-06-17 Citrix Systems Inc CERTIFICATION CERTIFICATES FROM A PROXY SERVER FOR A VIRTUALIZED CALCULATION ENVIRONMENT TO ACCESS A REMOTE RESOURCE
US20070139189A1 (en) * 2005-12-05 2007-06-21 Helmig Kevin S Multi-platform monitoring system and method
US7818660B2 (en) 2006-01-29 2010-10-19 Litera Technology Llc Method of compound document comparison
EP1835689B1 (en) * 2006-03-13 2014-06-04 Alcatel Lucent Context enriched communication system and method
US7783018B1 (en) * 2006-06-24 2010-08-24 Goldberg Mark S Directory display and configurable entry system
US8458283B1 (en) * 2006-06-28 2013-06-04 Insors Integrated Communications Methods and program products for efficient communication of shared file modifications during a collaboration event
US8023437B1 (en) 2006-06-28 2011-09-20 Insors Integrated Communications Methods, systems and program products for a distributed communications configuration
US8395652B1 (en) * 2006-06-28 2013-03-12 Insors Integrated Communications Data network collaboration systems having a shared file
US8144632B1 (en) 2006-06-28 2012-03-27 Insors Integrated Communications Methods, systems and program products for efficient communications during data sharing event
US8516050B1 (en) 2006-06-28 2013-08-20 Insors Integrated Communications Methods and program products for communicating file modifications during a collaboration event
US8412773B1 (en) 2006-06-28 2013-04-02 Insors Integrated Communications Methods, systems and program products for initiating a process on data network
US8121990B1 (en) 2006-06-28 2012-02-21 Insors Integrated Communications Methods, systems and program products for communicating file modification information
US20080065999A1 (en) * 2006-09-13 2008-03-13 Majors Kenneth D Conferencing system with document access
US20080086463A1 (en) * 2006-10-10 2008-04-10 Filenet Corporation Leveraging related content objects in a records management system
US20080120371A1 (en) * 2006-11-16 2008-05-22 Rajat Gopal Relational framework for non-real-time audio/video collaboration
JP5114932B2 (en) * 2006-11-30 2013-01-09 富士ゼロックス株式会社 Document processing apparatus and document processing program
US20080172606A1 (en) * 2006-12-27 2008-07-17 Generate, Inc. System and Method for Related Information Search and Presentation from User Interface Content
US7895276B2 (en) 2007-01-29 2011-02-22 Litera Technology Llc Method of managing metadata in attachments to e-mails in a network environment
US8812651B1 (en) 2007-02-15 2014-08-19 Google Inc. Systems and methods for client cache awareness
US20090003368A1 (en) * 2007-06-27 2009-01-01 Novell, Inc. System and method for graphically representing and managing computer network connections
US8190904B2 (en) * 2007-07-23 2012-05-29 Jesse Andrew Hatter System for executing remote electronic notarization and signatory verification and authentication
US8195700B2 (en) * 2007-09-28 2012-06-05 Microsoft Corporation Distributed storage for collaboration servers
US8200520B2 (en) 2007-10-03 2012-06-12 International Business Machines Corporation Methods, systems, and apparatuses for automated confirmations of meetings
US7925694B2 (en) 2007-10-19 2011-04-12 Citrix Systems, Inc. Systems and methods for managing cookies via HTTP content layer
US7941399B2 (en) 2007-11-09 2011-05-10 Microsoft Corporation Collaborative authoring
US8028229B2 (en) 2007-12-06 2011-09-27 Microsoft Corporation Document merge
US8825758B2 (en) 2007-12-14 2014-09-02 Microsoft Corporation Collaborative authoring modes
US8769660B2 (en) 2008-01-26 2014-07-01 Citrix Systems, Inc. Systems and methods for proxying cookies for SSL VPN clientless sessions
CN101918921B (en) 2008-01-27 2013-12-04 思杰系统有限公司 Methods and systems for remoting three dimensional graphics
US8301588B2 (en) 2008-03-07 2012-10-30 Microsoft Corporation Data storage for file updates
US8352870B2 (en) 2008-04-28 2013-01-08 Microsoft Corporation Conflict resolution
US8429753B2 (en) 2008-05-08 2013-04-23 Microsoft Corporation Controlling access to documents using file locks
US8825594B2 (en) 2008-05-08 2014-09-02 Microsoft Corporation Caching infrastructure
US8417666B2 (en) 2008-06-25 2013-04-09 Microsoft Corporation Structured coauthoring
US8286171B2 (en) 2008-07-21 2012-10-09 Workshare Technology, Inc. Methods and systems to fingerprint textual information using word runs
US8675833B2 (en) * 2008-10-22 2014-03-18 CentruryLink Intellectual Property LLC System and method for managing messages
WO2010059747A2 (en) 2008-11-18 2010-05-27 Workshare Technology, Inc. Methods and systems for exact data match filtering
US10685177B2 (en) 2009-01-07 2020-06-16 Litera Corporation System and method for comparing digital data in spreadsheets or database tables
CN101814021B (en) * 2009-02-24 2014-08-06 易保网络技术(上海)有限公司 Method and system for displaying user interface on remote equipment
US8136031B2 (en) 2009-03-17 2012-03-13 Litera Technologies, LLC Comparing the content of tables containing merged or split cells
US9159075B2 (en) 2009-04-24 2015-10-13 Reza Jalili System and method for distribution and redistribution of electronic content
US8346768B2 (en) 2009-04-30 2013-01-01 Microsoft Corporation Fast merge support for legacy documents
US20110125581A1 (en) * 2009-11-23 2011-05-26 Reza Jalili System and method for improving e-commerce with on-demand advertising
US9461834B2 (en) * 2010-04-22 2016-10-04 Sharp Laboratories Of America, Inc. Electronic document provision to an online meeting
US10025759B2 (en) 2010-11-29 2018-07-17 Workshare Technology, Inc. Methods and systems for monitoring documents exchanged over email applications
US10783326B2 (en) 2013-03-14 2020-09-22 Workshare, Ltd. System for tracking changes in a collaborative document editing environment
US11030163B2 (en) 2011-11-29 2021-06-08 Workshare, Ltd. System for tracking and displaying changes in a set of related electronic documents
US10963584B2 (en) * 2011-06-08 2021-03-30 Workshare Ltd. Method and system for collaborative editing of a remotely stored document
US9170990B2 (en) 2013-03-14 2015-10-27 Workshare Limited Method and system for document retrieval with selective document comparison
US10574729B2 (en) 2011-06-08 2020-02-25 Workshare Ltd. System and method for cross platform document sharing
US10880359B2 (en) 2011-12-21 2020-12-29 Workshare, Ltd. System and method for cross platform document sharing
US9613340B2 (en) 2011-06-14 2017-04-04 Workshare Ltd. Method and system for shared document approval
US8866872B2 (en) * 2011-06-21 2014-10-21 Mitel Networks Corporation Conferencing and collaboration system and methods thereof
US9348802B2 (en) 2012-03-19 2016-05-24 Litéra Corporation System and method for synchronizing bi-directional document management
EP2909796A1 (en) 2012-10-05 2015-08-26 Citrix Systems Inc. Capturing and sharing visual content via an application
US9626066B2 (en) * 2012-11-19 2017-04-18 Adobe Systems Incorporated Video playback analytics collection
US11567907B2 (en) 2013-03-14 2023-01-31 Workshare, Ltd. Method and system for comparing document versions encoded in a hierarchical representation
US9483451B2 (en) 2013-03-14 2016-11-01 Scribestar Ltd. System and method for handling user editing history based on spawning, merging data structures of directed acyclic graph
US10547664B2 (en) 2013-03-21 2020-01-28 Oracle International Corporation Enable uploading and submitting multiple files
US10025782B2 (en) 2013-06-18 2018-07-17 Litera Corporation Systems and methods for multiple document version collaboration and management
US10911492B2 (en) 2013-07-25 2021-02-02 Workshare Ltd. System and method for securing documents prior to transmission
US9350774B2 (en) * 2013-12-16 2016-05-24 Dropbox, Inc. Automatic sharing of digital multimedia
US10931721B2 (en) 2013-12-27 2021-02-23 T-Mobile Usa, Inc. User account-based access to real-time communications
US20150188956A1 (en) 2013-12-27 2015-07-02 T-Mobile Usa, Inc. Unified Communication Device
KR101553848B1 (en) * 2014-02-17 2015-09-17 네이버 주식회사 Method for offering result of search and system for executing the method
JP6287335B2 (en) * 2014-02-28 2018-03-07 株式会社リコー Terminal device, information processing system, information transmission method, and program
US9756002B2 (en) 2014-03-21 2017-09-05 Litera Technologies, LLC Systems and methods for email attachments management
DE102014106084B4 (en) * 2014-04-30 2016-08-04 Stanko & Partner Gesellschaft Für Media, Marketing Mbh Method for presenting digital pictures and digital texts
JP6405790B2 (en) * 2014-08-25 2018-10-17 株式会社リコー CONFERENCE MANAGEMENT DEVICE, MATERIAL REGISTRATION METHOD, PROGRAM, AND CONFERENCE SYSTEM
US10015214B2 (en) * 2014-09-30 2018-07-03 Adobe Systems Incorporated Method and apparatus for sharing viewable content with conference participants through automated identification of content to be shared
US10133723B2 (en) 2014-12-29 2018-11-20 Workshare Ltd. System and method for determining document version geneology
US11182551B2 (en) 2014-12-29 2021-11-23 Workshare Ltd. System and method for determining document version geneology
US20160292456A1 (en) * 2015-04-01 2016-10-06 Abbvie Inc. Systems and methods for generating longitudinal data profiles from multiple data sources
US11763013B2 (en) 2015-08-07 2023-09-19 Workshare, Ltd. Transaction document management system and method
US10536408B2 (en) 2015-09-16 2020-01-14 Litéra Corporation Systems and methods for detecting, reporting and cleaning metadata from inbound attachments
US11271763B2 (en) * 2018-06-19 2022-03-08 Ricoh Company, Ltd. Information processing system, information processing apparatus, and information processing method
CN110287719B (en) * 2019-06-28 2021-08-06 维沃移动通信有限公司 File encryption method and mobile terminal
US11714526B2 (en) 2021-09-29 2023-08-01 Dropbox Inc. Organize activity during meetings
US20230154497A1 (en) * 2021-11-18 2023-05-18 Parrot AI, Inc. System and method for access control, group ownership, and redaction of recordings of events

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0319232A2 (en) * 1987-12-02 1989-06-07 Xerox Corporation A multi-user data communication system
EP0473960A2 (en) * 1990-09-07 1992-03-11 Xerox Corporation Hierarchical shared books with database
US5446842A (en) * 1993-02-26 1995-08-29 Taligent, Inc. Object-oriented collaboration system
EP0874323A1 (en) * 1997-04-23 1998-10-28 International Business Machines Corporation Web-browser-based conference system
EP0891063A2 (en) * 1997-06-30 1999-01-13 Sun Microsystems, Inc. A method and apparatus for dynamic loading of a transport mechanism in a multipoint data delivery system

Family Cites Families (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5351276A (en) * 1991-02-11 1994-09-27 Simpact Associates, Inc. Digital/audio interactive communication network
US5689641A (en) * 1993-10-01 1997-11-18 Vicor, Inc. Multimedia collaboration system arrangement for routing compressed AV signal through a participant site without decompressing the AV signal
JP3658422B2 (en) * 1994-09-21 2005-06-08 株式会社日立製作所 Electronic circulation system and electronic circulation method
JPH09101767A (en) * 1995-07-31 1997-04-15 Canon Inc Terminal device, control method for terminal, conference system, and computer readable memory
US5781732A (en) * 1996-06-20 1998-07-14 Object Technology Licensing Corp. Framework for constructing shared documents that can be collaboratively accessed by multiple users
US5923845A (en) * 1996-07-26 1999-07-13 Nec Corporation Integrated electronic information system
US5974446A (en) * 1996-10-24 1999-10-26 Academy Of Applied Science Internet based distance learning system for communicating between server and clients wherein clients communicate with each other or with teacher using different communication techniques via common user interface
US5916302A (en) * 1996-12-06 1999-06-29 International Business Machines Corporation Multimedia conferencing using parallel networks
US6144991A (en) * 1998-02-19 2000-11-07 Telcordia Technologies, Inc. System and method for managing interactions between users in a browser-based telecommunications network
US6105055A (en) * 1998-03-13 2000-08-15 Siemens Corporate Research, Inc. Method and apparatus for asynchronous multimedia collaboration
US6119147A (en) * 1998-07-28 2000-09-12 Fuji Xerox Co., Ltd. Method and system for computer-mediated, multi-modal, asynchronous meetings in a virtual space
US6155840A (en) * 1998-09-18 2000-12-05 At Home Corporation System and method for distributed learning

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP0319232A2 (en) * 1987-12-02 1989-06-07 Xerox Corporation A multi-user data communication system
EP0473960A2 (en) * 1990-09-07 1992-03-11 Xerox Corporation Hierarchical shared books with database
US5446842A (en) * 1993-02-26 1995-08-29 Taligent, Inc. Object-oriented collaboration system
EP0874323A1 (en) * 1997-04-23 1998-10-28 International Business Machines Corporation Web-browser-based conference system
EP0891063A2 (en) * 1997-06-30 1999-01-13 Sun Microsystems, Inc. A method and apparatus for dynamic loading of a transport mechanism in a multipoint data delivery system

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
JACOBS S ET AL: "Filling HTML forms simultaneously: CoWeb - architecture and functionality", COMPUTER NETWORKS AND ISDN SYSTEMS,NL,NORTH HOLLAND PUBLISHING. AMSTERDAM, vol. 28, no. 11, 1 May 1996 (1996-05-01), pages 1385 - 1395, XP004018236, ISSN: 0169-7552 *

Cited By (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO2002075618A1 (en) * 2001-03-20 2002-09-26 The Department Of Natural Resources And Environment For And On Behalf Of The Crown In Right Of The State Of Victoria Data storage system
FR2855354A1 (en) * 2003-05-21 2004-11-26 France Telecom Videoconferencing system for network e.g. Internet, has session establishing module of videoconferencing server to establish session between client terminals on programmed date after notifying each registered user
WO2008043657A1 (en) * 2006-10-12 2008-04-17 International Business Machines Corporation Method, system and program product for building collaboration applications
US20120278408A1 (en) * 2011-04-29 2012-11-01 Crestron Electronics Inc. Meeting Management System Including Automated Equipment Setup
US20120293605A1 (en) * 2011-04-29 2012-11-22 Crestron Electronics, Inc. Meeting Management System Including Automated Equipment Setup
US9294723B2 (en) * 2011-04-29 2016-03-22 Creston Electronics, Inc. Meeting management system including automated equipment setup
US9998503B2 (en) 2011-04-29 2018-06-12 Crestron Electronics, Inc. Meeting management system including automated equipment setup
US10044871B2 (en) 2011-04-29 2018-08-07 Crestron Electronics, Inc. Conference system including automated equipment setup
US10692020B2 (en) 2011-04-29 2020-06-23 Crestron Electronics, Inc. Real-time automatic meeting room reservation based on the number of actual participants
FR3038764A1 (en) * 2015-07-06 2017-01-13 Speakplus METHOD OF SHARING FILE BETWEEN TWO CLIENT POSITIONS OF A COMPUTER NETWORK WITHOUT A SPECIFIC SOFTWARE TO BE INSTALLED
WO2019027458A1 (en) * 2017-08-02 2019-02-07 Intuit Inc. Integrating real-time personalized documents into a video conference session
US10673642B2 (en) 2017-08-02 2020-06-02 Intuit, Inc. Integrating real-time personalized documents into a video conference session

Also Published As

Publication number Publication date
CA2371243C (en) 2009-01-06
EP1173977B1 (en) 2006-08-02
DE60029774T2 (en) 2007-08-02
CA2371243A1 (en) 2000-11-02
AU4245100A (en) 2000-11-10
US6317777B1 (en) 2001-11-13
EP1173977A1 (en) 2002-01-23
DE60029774D1 (en) 2006-09-14

Similar Documents

Publication Publication Date Title
US6317777B1 (en) Method for web based storage and retrieval of documents
US6489980B1 (en) Software apparatus for immediately posting sharing and maintaining objects on a web page
US10798127B2 (en) Enhanced document and event mirroring for accessing internet content
EP1568189B1 (en) Session-return enabling stateful web applications
JP3594231B2 (en) Information control system, information processing support server, information processing terminal, information processing method, and storage medium
US8250141B2 (en) Real-time event notification for collaborative computing sessions
US9336213B2 (en) Active file system
US6192394B1 (en) Inter-program synchronous communications using a collaboration software system
US7277912B2 (en) Browser environment using multiple browser instantiations
US7774857B2 (en) Method and system for protection of electronic digital content
US20050010639A1 (en) Network meeting system
US7676675B2 (en) Architecture for connecting a remote client to a local client desktop
US6212535B1 (en) Browser-based electronic messaging
US20170142116A1 (en) Dynamic encryption of a universal resource locator
EP1298886A2 (en) Information providing server, information providing system, and control method for terminal apparatus
US20030163566A1 (en) Data access in a distributed environment
US20040015729A1 (en) Sensitive display system
US20030084169A1 (en) System and method for accessing a target computer from a remote location using a remote computer
US20020038346A1 (en) Method for screen image sharing
US20060294187A1 (en) Integrated web communications system
US7797442B2 (en) Rerouting media to selected media applications
WO2009066233A2 (en) Co-browsing (java) scripted html documents
US7562113B2 (en) Method and system for automatically creating and storing shortcuts to web sites/pages
CA2355178A1 (en) Remote e-mail management and communication system
US20050097186A1 (en) Method, system, and computer program product for managing interaction between remote devices and server resources

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY CA CH CN CR CU CZ DE DK DM DZ EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX NO NZ PL PT RO RU SD SE SG SI SK SL TJ TM TR TT TZ UA UG US UZ VN YU ZA ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): GH GM KE LS MW SD SL SZ TZ UG ZW AM AZ BY KG KZ MD RU TJ TM AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE BF BJ CF CG CI CM GA GN GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
ENP Entry into the national phase

Ref document number: 2371243

Country of ref document: CA

Ref country code: CA

Ref document number: 2371243

Kind code of ref document: A

Format of ref document f/p: F

WWE Wipo information: entry into national phase

Ref document number: 2000922233

Country of ref document: EP

WWP Wipo information: published in national office

Ref document number: 2000922233

Country of ref document: EP

REG Reference to national code

Ref country code: DE

Ref legal event code: 8642

NENP Non-entry into the national phase

Ref country code: JP

WWG Wipo information: grant in national office

Ref document number: 2000922233

Country of ref document: EP