[go: nahoru, domu]

US20050021772A1 - Establishing a virtual tunnel between two computer programs - Google Patents

Establishing a virtual tunnel between two computer programs Download PDF

Info

Publication number
US20050021772A1
US20050021772A1 US10/784,138 US78413804A US2005021772A1 US 20050021772 A1 US20050021772 A1 US 20050021772A1 US 78413804 A US78413804 A US 78413804A US 2005021772 A1 US2005021772 A1 US 2005021772A1
Authority
US
United States
Prior art keywords
server
data
application
client application
protocol
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US10/784,138
Other versions
US7966418B2 (en
Inventor
Felix Shedrinsky
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
PTC Inc
Original Assignee
Axeda Systems Operating Co Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Axeda Systems Operating Co Inc filed Critical Axeda Systems Operating Co Inc
Priority to US10/784,138 priority Critical patent/US7966418B2/en
Assigned to AXEDA SYSTEMS OPERATING COMPANY INC. reassignment AXEDA SYSTEMS OPERATING COMPANY INC. ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: SHEDRINSKY, FELIX
Publication of US20050021772A1 publication Critical patent/US20050021772A1/en
Assigned to AXEDA SYSTEMS OPERATING COMPANY, INC. reassignment AXEDA SYSTEMS OPERATING COMPANY, INC. CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: EMATION, INC.
Assigned to JMI EQUITY FUND V, L.P., JMI EQUITY FUND V (AI), L.P. reassignment JMI EQUITY FUND V, L.P. GRANT OF SECURITY INTEREST IN PATENTS AND TRADEMARKS Assignors: AXEDA IP, INC., AXEDA SYSTEMS OPERATING COMPANY, INC., AXEDA SYSTEMS, INC.
Assigned to LAURUS MASTER FUND, LTD. reassignment LAURUS MASTER FUND, LTD. SECURITY AGREEMENT Assignors: AXEDA SYSTEMS OPERATING COMPANY, INC.
Assigned to AXEDA IP, INC., AXEDA SYSTEMS INC., AXEDA SYSTEMS OPERATING COMPANY, INC. reassignment AXEDA IP, INC. RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS Assignors: LAURUS MATER FUND, LTD.
Assigned to AXEDA CORPORATION reassignment AXEDA CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: AXEDA SYSTEMS OPERATING COMPANY, INC.
Assigned to SILICON VALLEY BANK reassignment SILICON VALLEY BANK SECURITY AGREEMENT Assignors: AXEDA CORPORATION
Assigned to MMV FINANCE INC. reassignment MMV FINANCE INC. SECURITY AGREEMENT Assignors: AXEDA CORPORATION
Priority to US13/105,385 priority patent/US8291039B2/en
Application granted granted Critical
Publication of US7966418B2 publication Critical patent/US7966418B2/en
Assigned to AXEDA CORPORATION reassignment AXEDA CORPORATION RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: SILICON VALLEY BANK
Assigned to AXEDA CORPORATION reassignment AXEDA CORPORATION RELEASE BY SECURED PARTY (SEE DOCUMENT FOR DETAILS). Assignors: MMV CAPITAL PARTNERS INC.
Assigned to COMERICA BANK reassignment COMERICA BANK SECURITY AGREEMENT Assignors: AXEDA CORPORATION
Priority to US13/614,311 priority patent/US9002980B2/en
Assigned to AXEDA CORPORATION reassignment AXEDA CORPORATION RELEASE OF SECURITY INTEREST Assignors: COMERICA BANK
Priority to US14/678,277 priority patent/US10069939B2/en
Assigned to PTC INC. reassignment PTC INC. MERGER (SEE DOCUMENT FOR DETAILS). Assignors: AXEDA CORPORATION
Assigned to JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT reassignment JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: PTC INC.
Assigned to JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT reassignment JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT SECURITY INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: PTC INC.
Expired - Fee Related legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/02Network architectures or network communication protocols for network security for separating internal from external traffic, e.g. firewalls
    • H04L63/0281Proxies
    • 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]
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network

Definitions

  • Tunneling solutions exist that provide a diagnostic program with access to a remote application.
  • tunneling solutions require a server at each site to provide access to applications behind its firewall. Since the additional server requires additional administration and maintenance at each site, it is an additional burden to end-users or customers.
  • a server at each site that provides tunnel access to a local network also has security risks.
  • a server is addressable via the Internet, and thus is a target to break into an otherwise secure network.
  • the invention is directed to a method of transferring data via a communication session between a client application and a server application.
  • the method includes assigning an identifier to the communication session, creating at least one queue associated with the communication session, and using the identifier to store data passed between the client application and the server application in the at least one queue.
  • the client application and the server application run local protocols, and the data is passed between the client application and the server application via an intermediary protocol.
  • the intermediary protocol may be different from the local protocols or it may be the same protocol as the local protocols. This aspect may include one or more of the following.
  • a socket interface may be created to at least one of the client application and the server application.
  • the data may be transmitted through the socket interface.
  • the client application and the server application may be on networks that run the local protocols, and the method may include converting between the local protocols and the intermediary protocol when passing the data.
  • the local protocol may be TCP/IP or a serial protocol, such as RS232 and RS485.
  • the intermediary protocol may be HTTP.
  • the method may be performed by a server, and may also include performing load balancing to select the server from among plural servers.
  • the identifier may be associated with the at least one queue, and may be invalidated when the communication session terminates.
  • the communication session may be a telnet session or may be effected via a Web site.
  • a session record may be maintained, which includes an identity of a user initiating the session along with other information.
  • the method may be implemented via machine-executable instructions stored on a readable medium/media.
  • the method may be implemented via one or more processors on one or more machines executing such instructions.
  • the invention is directed to a system for transferring data via a communication session between a client application and a server application, where the client application runs on a first network and the server application runs on a second network.
  • the system includes a proxy having a socket to the client application.
  • the proxy converts data between a local protocol run on the first network to a non-local protocol.
  • An agent creates a socket to the server application.
  • the agent converts data between a local protocol run on the second network and the non-local protocol.
  • a server is in communication with the proxy and the agent.
  • the server contains a message queue dedicated to the communication session. The message queue stores data transmitted during the communication session.
  • the proxy may poll the server for data for the client application. When data is present for the client application, the proxy may retrieve the data from the message queue and pass the data to the client application.
  • the agent may poll the server for data for the server application. When data is present for the client application, the agent may retrieve the data from the message queue and pass the data to the server application.
  • FIG. 1 is a block diagram illustrating the concept of a virtual tunnel between two computer programs.
  • FIG. 2 is a block diagram of a network containing computer programs (client application and server application) that communicate via a virtual tunnel.
  • FIG. 3 is a flowchart showing a process for creating a virtual tunnel.
  • the system described herein creates a virtual communication link (called a “virtual tunnel”) between two computer programs (e.g., client and server applications) that are not able to address each other directly.
  • a virtual tunnel may occur when a client application needs to connect to a server application at a remote site.
  • the server application may be on a computer on a customer or partner's non-addressable local network (e.g., behind a firewall). As such, the client application will not be able to address the server application directly.
  • FIG. 1 illustrates the concept of a virtual tunnel 8 between client application 10 and server application 11 .
  • Virtual tunnel 8 enables client application 10 and server application 11 to communicate as if there were no firewalls between them (which, typically, there are).
  • FIG. 2 shows a client local network 14 .
  • Client local network 14 includes a device 15 , such as a computer, that contains a processor 16 , a memory 17 , and a storage medium 19 for storing, among other things, an operating system (OS) 20 , a Web browser 21 , software 22 for effecting network communications, and one or more executable applications (e.g., computer programs).
  • OS operating system
  • Web browser 21 software 22 for effecting network communications
  • client application 24 is a computer program for communicating with and diagnosing local or remote hardware and/or software.
  • a router (or modem) 25 couples client local network 14 to an external network 26 , such as the Internet/World Wide Web (Web).
  • External network 26 may run Internet Protocol (IP), HyperText Transfer Protocol (HTTP) and other suitable protocols.
  • IP Internet Protocol
  • HTTP HyperText Transfer Protocol
  • Network connections may be via Ethernet, telephone line, wireless, or other transmission media.
  • Firewall 27 is maintained between client local network 14 and external network 26 .
  • Firewall 27 may be implemented via software run on the closest “intelligent” device to external network 26 , e.g., router 25 or device 15 .
  • the firewall prevents others from directly addressing devices on client local network 14 via external network 26 . As a result of the firewall, only users on client local network 14 (or some defined subset thereof) are permitted to address device 15 directly.
  • Client local network 14 may run a local protocol, such as Transmission Control Protocol/Internet Protocol (TCP/IP), which may be the same as, or different than, the protocols that run on external network 26 .
  • TCP/IP Transmission Control Protocol/Internet Protocol
  • Examples of other protocols that may be run on client local network 14 include, but are not limited to, serial protocols, such as RS232 and RS485, and proprietary protocols.
  • Client local network 14 also includes proxy 29 , which is used to effect communication between client application 24 and a remote server application.
  • Proxy 29 may be a computer program executing on device 15 or another processing device, such as a router 25 , in client local network 14 .
  • proxy 29 performs any conversions necessary between the protocols running on external network 26 and those running on client local network 14 .
  • FIG. 2 also shows a server local network 30 .
  • Server local network 30 is depicted as being similar to client local network 14 for the sake of illustration. In reality, however, the two local networks may be very different.
  • Server local network 30 includes a device 31 , such as a server, that contains a processor 32 , a memory 34 , and a storage medium 35 for storing, among other things, an operating system (OS) 36 , software 37 for effecting network communications, and one or more executable applications (e.g., computer programs).
  • OS operating system
  • Server application 39 is a computer program that may, among other things, provide information to users via external network 26 or via local network 30 . Examples of such information include, but are not limited to, Web pages and diagnostics or operational control information pertaining to the device.
  • a router (or modem) 40 couples server local network 30 to external network 26 .
  • network connections may be via Ethernet, telephone line, wireless, or other transmission media.
  • a firewall 41 is also maintained between server local network 30 and external network 26 .
  • Firewall 41 may be implemented via software run on the closest “intelligent” device to external network 26 , e.g., router 40 or device 31 .
  • the firewall prevents others from directly addressing device 31 via external network 26 .
  • only users on server local network 30 (or some subset thereof) are permitted to address device 31 directly.
  • Server local network 30 may run a local protocol that may be the same as, or different than, protocols that run on external network 26 and/or client local network 14 .
  • protocols include, but are not limited to, TCP/IP, serial protocols, such as RS232 and RS485, and proprietary protocols.
  • Server local network 30 also includes agent 42 , which is used to effect communication between client application 24 and server application 39 .
  • Agent 42 may be a computer program executing on device 31 or another processing device, such as a router 40 , in server local network 30 .
  • agent 42 performs any conversions necessary between the protocols running on external network 26 and those running on server local network 30 .
  • Agent 42 has a local configuration of interfaces. Each interface has a name, IP (Internet Protocol) address, or other information relevant to the local protocol, such as baud rate. Local configuration of the interfaces allows a local operator to control access to applications on server local network.
  • IP Internet Protocol
  • Proxy 29 and agent 42 perform essentially the same functions (described below) which allow client application 24 and server application 39 to communicate via a virtual tunnel.
  • Proxy 29 and agent 42 may be pre-programmed into devices on respective local networks 14 and 30 .
  • one or both of proxy 29 and agent 42 may be downloaded, e.g., from external network 26 .
  • proxy 29 is an applet that is downloaded from a server 44 on external network 26 and that is installed on device 15 .
  • the applet may be included in a Web page that is provided by server 44 , and that is accessed by a user when establishing a virtual tunnel between client application 24 and server application 39 . This process is described in more detail below.
  • External network 26 contains server 44 , which is a computer or any other processing device. Other devices (not shown) are also located on external network 26 .
  • external network 26 may contain routers, switches, and the like (not shown), which receive data packets and which forward the data packets along paths to their intended destinations.
  • Other servers, personal computers, mainframes, and processing devices may also be on, and/or have access to, external network 26 .
  • Server 44 acts as an intermediary for communications between client application 24 and server application 39 in the manner described below.
  • Server 44 runs HTTP (Hypertext Transfer Protocol) and is “visible” to other devices, such as device 15 , via external network 26 .
  • HTTP Hypertext Transfer Protocol
  • server 44 is used in passing data between client application 24 and server application 39 because these applications cannot address each other directly. That is, since both applications are on local networks, they do not have universally-recognized network addresses. As such, the client and server applications cannot address one another without the aid of server 44 .
  • Server 44 includes a controller, such as a microprocessor, for executing software (machine-executable instructions) stored in a memory to perform the functions described below. To avoid confusion in terminology, the following reads as though those functions are performed by server 44 , even though software in server 44 , namely virtual tunneling application 45 , performs the functions.
  • a controller such as a microprocessor
  • software machine-executable instructions
  • server 44 contains a processor 46 , a memory 47 , and a storage medium 49 for storing, among other things, an operating system (OS) 50 , software 51 for effecting network communication, and one or more applications.
  • OS operating system
  • Processor 46 may execute software, including the applications, out of memory 47 .
  • tunneling application 45 is a software application that is accessed by the applications.
  • Tunneling application 45 creates a virtual tunnel between client application 24 on client local network 14 and server application 39 on server local network 30 .
  • Tunneling application 45 includes process 54 ( FIG. 3 ) to establish the virtual tunnel, as described below.
  • the virtual tunnel allows client application 24 and server application 39 to communicate even though they are both behind firewalls and cannot directly address each other.
  • the virtual tunnel is also advantageous because it preserves the protocols running on local networks 14 and 30 . That is, data is transferred through the virtual tunnel via an intermediary protocol, such as HTTP, that is run on external network 26 .
  • the protocols running on local networks 14 and 30 are essentially transmitted via the protocol of external network.
  • Proxy 29 and agent 42 are both capable of converting between a local protocol and the intermediary protocol.
  • the intermediary protocol may be the same as, or different from, the local protocols.
  • FIG. 3 shows process 54 that is performed by proxy 29 , server 44 , and agent 42 to set-up a virtual tunnel for a communication session between client application 24 and server application 39 .
  • Agent corresponds to functions performed by agent 42 ;
  • Proxy corresponds to functions performed by proxy 29 ; and
  • the section of FIG. 3 labeled “Server” corresponds to functions performed by tunneling application 45 (on server 44 ).
  • agent 42 sends ( 60 ), to server 44 , interface information, including, but not limited to, interface names and port numbers of agent 42 associated with server application 39 .
  • the interface information may be sent, e.g., in response to installing agent 42 on local network 30 .
  • Server 44 receives ( 61 ) the interface information and stores the interface information in a database (not shown).
  • the database is associated with agent 42 .
  • Information in the database may be made accessible to a user, e.g., at device 15 via a Web browser.
  • the information may be made accessible via a Web page (not shown) provided by server 44 .
  • the Web page may contain a list of devices on local network 30 that may be accessed via virtual tunneling.
  • the identities of the devices, which may be provided to server 44 along with the interface information, are associated with software interfaces to such devices.
  • a user who wants to connect to a device on local network from client application 24 logs into server 44 via a Web page (not shown). The user then selects a device (and, thus, an interface) to begin a communication session with that device.
  • Server 44 receives ( 62 ) the input from the Web page.
  • the Web page may contain an applet that comprises proxy 29 . In this case, when the user selects a device and enters the selection, the applet may be installed on device 15 as proxy 29 .
  • Server 44 may control access to agents and interfaces through a predefined security (access) policy. For example, server 44 may allow some users, but not others, access to devices on local network 30 . Likewise, users may be restricted as to which devices they may access. Server 44 may control access based on user IDs (identifiers) and/or passwords assigned to system users. For example, server 44 may maintain a database of user IDs and/or passwords corresponding to devices that are accessible via those user IDs and/or passwords. If a user attempts to establish a communication session with a device for which he has not been permitted access, server 44 may provide that user with an error message or the like.
  • access access policy. For example, server 44 may allow some users, but not others, access to devices on local network 30 . Likewise, users may be restricted as to which devices they may access. Server 44 may control access based on user IDs (identifiers) and/or passwords assigned to system users. For example, server 44 may maintain a database of user IDs and/or passwords corresponding to devices
  • server 44 creates ( 63 ) a session object for the current communication session.
  • the session object contains message queues. The message queues are used to store data that is passed between client application 24 and server application 39 .
  • the session object contains two message queues (other embodiments may contain more, or less, message queues).
  • One message queue is for data going from client application 24 to server application 39 and the other message queue is for data going from server application 39 to client application 24 .
  • the session object also has an associated session identifier, referred to as a “sessionID” string.
  • the sessionID string may be a unique alphanumeric identifier that identifies communications associated with a particular communication session. As described below, all data transfers associated with a communication session between client application 24 and server application 39 pass through server 44 .
  • the sessionID string is used by server 44 (in particular, by tunneling application 45 ) to store the data in the appropriate message queues(s).
  • server 44 sends ( 64 ) the sessionID string and selected interface name to agent 42 .
  • Agent 42 receives ( 65 ) this message and creates ( 66 ) a socket using the port and IP address that correspond to the selected interface name.
  • Agent 42 connects ( 67 ) the socket to server application 39 . If connection fails, agent 42 reports an error to server 44 .
  • sockets are used in this embodiment because they are a well-known way of communicating. Other means of communication may be used, including proxies, pipes, serial communications, etc.
  • server 44 also sends ( 64 ) the sessionID string and port or other protocol parameters to proxy 29 .
  • Proxy 29 receives ( 68 ) this message and creates ( 69 ) a socket using the port that corresponds to client application 24 .
  • Proxy 29 then provides ( 70 ) an “accept” instruction on that socket. The accept instruction enables proxy 29 to accept data from client application 24 .
  • Both proxy 29 and agent 42 execute a software thread to poll ( 71 , 72 ) for data on their respective sockets, and also to poll for data from server 44 .
  • proxy 29 appends the appropriate sessionID string to the data and passes the data to server 44 .
  • the sessionID string enables server 44 to identify the data as belonging to a particular communication session, and to store the data in the appropriate message queue.
  • Agent 42 polls for data from server 44 , meaning that it searches for data from server 44 that is stored in message queues for agent 42 . If there is data present, agent 42 retrieves the data, identifies the communication session using the sessionID string associated with the data, and passes the data to server application 39 via the established socket.
  • server application 39 The converse occurs for data passed from server application 39 to client application 24 . More specifically, data from server application 24 is received on a socket of agent 42 . Agent 42 appends the sessionID string for the current communication session to the data and passes the data to server 44 . Proxy 29 polls for data from server 44 . If there is data present in an appropriate message queue, proxy 29 retrieves the data, identifies the communication session using the sessionID string, and passes the data to client application 24 .
  • a select or “recv” (receive) instruction determines if there is data to read.
  • the data may be sent to server 44 (by proxy 29 or agent 42 ) as the body of an HTTP POST command.
  • Data in server 44 may be polled (by proxy 29 or agent 42 ) using an HTTP GET command. If there is data in server 44 , the data is passed in a reply to the GET command. This data is then written to the appropriate socket.
  • server 44 has a session object that contains two message queues. Data sent from proxy 29 is stored in one message queue and delivered when agent 42 issues a GET command. The other message queue contains data being passed from agent 42 to proxy 29 .
  • Proxy 29 and agent 42 may encrypt communications sent to server 44 .
  • Examples of encryption that may be used include Secure Sockets Layer (SSL) and Hyper Text Transfer Protocol Secure sockets (HTTPS).
  • SSL Secure Sockets Layer
  • HTTPS Hyper Text Transfer Protocol Secure sockets
  • the recipient e.g., proxy 29 or agent 42 ) should have sufficient capabilities to perform any necessary decryption.
  • the session may end when either client application 24 or server application 39 closes its socket.
  • client application 24 or server application 39 closes its socket.
  • some applications open and close sockets during the normal course of communications.
  • the user may terminate the session manually when the applications are finished running.
  • the user may choose a termination scenario when creating the session.
  • Server 44 may maintain an audit log (i.e., record) of communication sessions.
  • the audit log may identify the user, time, duration, agent, interface, and number of bytes transferred in a communication session.
  • the actual data may be stored as human-readable text or in another format. Audit logs are particularly advantageous in diagnostic and repair scenarios, where it is often necessary to identify device modifications and repairs after the fact.
  • Server 44 may be associated with multiple servers, one or more of which may act as a load balancing server to distribute communications amongst other servers.
  • the session object when a session object is created, the session object may be created on a server that has the most (or greater than a predetermined amount of) resources available and/or a server that is located closest to (or within a predetermined location of) agent 42 .
  • the Uniform Resource Locator (URL) of the server that is being used to effect communication is sent to agent 42 and proxy 29 , along with the sessionID. In all subsequent communications, proxy 29 and agent 42 include the URL of the server. This ensures that a single server handles a single communication session.
  • URL Uniform Resource Locator
  • the virtual tunnel system described herein is not limited to use with the hardware/software configuration of FIGS. 2 and 3 ; it may find applicability in any computing or processing environment.
  • the functionality of the virtual tunnel system including, but not limited to, the functions performed by proxy 29 , server 44 , and agent 42 , may be implemented in hardware (e.g., an ASIC ⁇ Application-Specific Integrated Circuit ⁇ and/or an FPGA ⁇ Field Programmable Gate Array ⁇ ), software, or a combination of hardware and software.
  • the virtual tunnel system may find applicability in any computing or processing environment and with any type of machine that is capable of running machine-readable instructions, such as one or more computer programs.
  • the virtual tunnel system can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them.
  • the virtual tunnel system can be implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine-readable medium or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers.
  • a computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment.
  • a computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
  • Method steps implemented to effect virtual tunneling can be performed by one or more programmable processors executing one or more computer programs to perform functions described herein by operating on input data and generating output. Method steps can also be performed by, and the virtual tunnel system can be implemented as, special purpose logic circuitry.
  • processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer.
  • a processor will receive instructions and data from a read- only memory or a random access memory or both.
  • Elements of a computer include a processor for executing instructions and one or more memory devices for storing instructions and data.
  • a computer will also include, or be operatively coupled to receive data from, or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
  • Information carriers suitable for embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
  • semiconductor memory devices e.g., EPROM, EEPROM, and flash memory devices
  • magnetic disks e.g., internal hard disks or removable disks
  • magneto-optical disks e.g., CD-ROM and DVD-ROM disks.
  • the processor and the memory can be supplemented by, or incorporated in special purpose logic circuitry.
  • the virtual tunnel system can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with the virtual tunneling system, or any combination of such back-end, middleware, or front-end components.
  • the components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (WAN”), e.g., the Internet.
  • LAN local area network
  • WAN wide area network
  • the computing system can include clients and servers.
  • a client and server are generally remote from each other and typically interact through a communication network.
  • the relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
  • client application 24 and server application 39 may communicate directly when a direct connection can be achieved (e.g., if they are on the same network).
  • server application 39 creates a socket on a specific port.
  • Client application 24 also creates a socket and connects to this port.
  • server application 39 runs on another computer, client application 24 also specifies the network address of that computer. At this point, the client and server are connected and begin communicating.
  • the local protocols run on local networks 14 , 30 may be TCP/IP or a serial protocol, such as RS232 or RS485.
  • the protocol run on external network 26 may be HTTP.
  • the virtual tunnel may comprise a telnet session (e.g., the tunnel is implemented during the telnet session).
  • more than one agent may be present on local network 30 and more than one proxy may be present on local network 14 .
  • a single proxy may service different devices and, likewise, a single agent may service different devices.
  • multiple proxies may service the same device and multiple agents may service the same device.
  • the sessionID string may expire after a predetermined period of time, necessitating a new communication session. For example, the sessionID may expire after a period during which no communications are exchanged. This period may be programmed into server 44 . Similarly, the sessionID string expires when a communication session terminates.

Landscapes

  • Engineering & Computer Science (AREA)
  • Signal Processing (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • General Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • Computing Systems (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Hardware Design (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer And Data Communications (AREA)

Abstract

A system transfers data via a communication session between a client application and a server application, where the client application runs on a first network and the server application runs on a second network. The system includes a proxy having a socket to the client application. The proxy converts data between a local protocol run on the first network to a non-local protocol. An agent creates a socket to the server application. The agent converts data between a local protocol run on the second network and the non-local protocol. A server is in communication with the proxy and the agent. The server contains a message queue dedicated to the communication session. The message queue stores data transmitted during the communication session.

Description

    CROSS-REFERENCE TO RELATED APPLICATION
  • This application claims priority to U.S. Provisional Application No. 60/449,213, filed on Feb. 21, 2003, the contents of which are incorporated herein by reference.
  • BACKGROUND
  • Many products, both hardware and software, have diagnostic tools or applications for communicating with them. When such products are located at customer sites, there is no way to use these tools except to send a service technician on-site to diagnose and repair any problems.
  • Tunneling solutions exist that provide a diagnostic program with access to a remote application. However, such tunneling solutions require a server at each site to provide access to applications behind its firewall. Since the additional server requires additional administration and maintenance at each site, it is an additional burden to end-users or customers.
  • Furthermore, and perhaps more significantly, installing a server at each site that provides tunnel access to a local network also has security risks. For example, such a server is addressable via the Internet, and thus is a target to break into an otherwise secure network.
  • SUMMARY
  • In general, in one aspect, the invention is directed to a method of transferring data via a communication session between a client application and a server application. The method includes assigning an identifier to the communication session, creating at least one queue associated with the communication session, and using the identifier to store data passed between the client application and the server application in the at least one queue. The client application and the server application run local protocols, and the data is passed between the client application and the server application via an intermediary protocol. The intermediary protocol may be different from the local protocols or it may be the same protocol as the local protocols. This aspect may include one or more of the following.
  • A socket interface may be created to at least one of the client application and the server application. The data may be transmitted through the socket interface. The client application and the server application may be on networks that run the local protocols, and the method may include converting between the local protocols and the intermediary protocol when passing the data.
  • The local protocol may be TCP/IP or a serial protocol, such as RS232 and RS485. The intermediary protocol may be HTTP. The method may be performed by a server, and may also include performing load balancing to select the server from among plural servers. The identifier may be associated with the at least one queue, and may be invalidated when the communication session terminates.
  • The communication session may be a telnet session or may be effected via a Web site. A session record may be maintained, which includes an identity of a user initiating the session along with other information.
  • The method may be implemented via machine-executable instructions stored on a readable medium/media. The method may be implemented via one or more processors on one or more machines executing such instructions.
  • In general, in another aspect, the invention is directed to a system for transferring data via a communication session between a client application and a server application, where the client application runs on a first network and the server application runs on a second network. The system includes a proxy having a socket to the client application. The proxy converts data between a local protocol run on the first network to a non-local protocol. An agent creates a socket to the server application. The agent converts data between a local protocol run on the second network and the non-local protocol. A server is in communication with the proxy and the agent. The server contains a message queue dedicated to the communication session. The message queue stores data transmitted during the communication session. This aspect may include one or more of the following features.
  • The proxy may poll the server for data for the client application. When data is present for the client application, the proxy may retrieve the data from the message queue and pass the data to the client application. The agent may poll the server for data for the server application. When data is present for the client application, the agent may retrieve the data from the message queue and pass the data to the server application.
  • Other features and advantages of the invention will become apparent from the following description, including the claims and drawings.
  • DESCRIPTION OF THE DRAWINGS
  • FIG. 1 is a block diagram illustrating the concept of a virtual tunnel between two computer programs.
  • FIG. 2 is a block diagram of a network containing computer programs (client application and server application) that communicate via a virtual tunnel.
  • FIG. 3 is a flowchart showing a process for creating a virtual tunnel.
  • DESCRIPTION
  • The system described herein creates a virtual communication link (called a “virtual tunnel”) between two computer programs (e.g., client and server applications) that are not able to address each other directly. This situation may occur when a client application needs to connect to a server application at a remote site. The server application may be on a computer on a customer or partner's non-addressable local network (e.g., behind a firewall). As such, the client application will not be able to address the server application directly.
  • A virtual tunnel may be used to provide the client application access to the server application. FIG. 1 illustrates the concept of a virtual tunnel 8 between client application 10 and server application 11. Virtual tunnel 8 enables client application 10 and server application 11 to communicate as if there were no firewalls between them (which, typically, there are).
  • FIG. 2 shows a client local network 14. Client local network 14 includes a device 15, such as a computer, that contains a processor 16, a memory 17, and a storage medium 19 for storing, among other things, an operating system (OS) 20, a Web browser 21, software 22 for effecting network communications, and one or more executable applications (e.g., computer programs). Among these applications is client application 24. Client application 24 is a computer program for communicating with and diagnosing local or remote hardware and/or software.
  • A router (or modem) 25 couples client local network 14 to an external network 26, such as the Internet/World Wide Web (Web). External network 26 may run Internet Protocol (IP), HyperText Transfer Protocol (HTTP) and other suitable protocols. Network connections may be via Ethernet, telephone line, wireless, or other transmission media.
  • A firewall 27 is maintained between client local network 14 and external network 26. Firewall 27 may be implemented via software run on the closest “intelligent” device to external network 26, e.g., router 25 or device 15. The firewall prevents others from directly addressing devices on client local network 14 via external network 26. As a result of the firewall, only users on client local network 14 (or some defined subset thereof) are permitted to address device 15 directly.
  • Client local network 14 may run a local protocol, such as Transmission Control Protocol/Internet Protocol (TCP/IP), which may be the same as, or different than, the protocols that run on external network 26. Examples of other protocols that may be run on client local network 14 include, but are not limited to, serial protocols, such as RS232 and RS485, and proprietary protocols.
  • Client local network 14 also includes proxy 29, which is used to effect communication between client application 24 and a remote server application. Proxy 29 may be a computer program executing on device 15 or another processing device, such as a router 25, in client local network 14. In addition to the functions described below, proxy 29 performs any conversions necessary between the protocols running on external network 26 and those running on client local network 14.
  • FIG. 2 also shows a server local network 30. Server local network 30 is depicted as being similar to client local network 14 for the sake of illustration. In reality, however, the two local networks may be very different.
  • Server local network 30 includes a device 31, such as a server, that contains a processor 32, a memory 34, and a storage medium 35 for storing, among other things, an operating system (OS) 36, software 37 for effecting network communications, and one or more executable applications (e.g., computer programs). Among these applications is server application 39. Server application 39 is a computer program that may, among other things, provide information to users via external network 26 or via local network 30. Examples of such information include, but are not limited to, Web pages and diagnostics or operational control information pertaining to the device.
  • A router (or modem) 40 couples server local network 30 to external network 26. As above, network connections may be via Ethernet, telephone line, wireless, or other transmission media. A firewall 41 is also maintained between server local network 30 and external network 26. Firewall 41 may be implemented via software run on the closest “intelligent” device to external network 26, e.g., router 40 or device 31. The firewall prevents others from directly addressing device 31 via external network 26. As above, only users on server local network 30 (or some subset thereof) are permitted to address device 31 directly.
  • Server local network 30 may run a local protocol that may be the same as, or different than, protocols that run on external network 26 and/or client local network 14. Examples of such protocols include, but are not limited to, TCP/IP, serial protocols, such as RS232 and RS485, and proprietary protocols.
  • Server local network 30 also includes agent 42, which is used to effect communication between client application 24 and server application 39. Agent 42 may be a computer program executing on device 31 or another processing device, such as a router 40, in server local network 30. In addition to the functions described below, agent 42 performs any conversions necessary between the protocols running on external network 26 and those running on server local network 30.
  • Agent 42 has a local configuration of interfaces. Each interface has a name, IP (Internet Protocol) address, or other information relevant to the local protocol, such as baud rate. Local configuration of the interfaces allows a local operator to control access to applications on server local network.
  • Proxy 29 and agent 42 perform essentially the same functions (described below) which allow client application 24 and server application 39 to communicate via a virtual tunnel. Proxy 29 and agent 42 may be pre-programmed into devices on respective local networks 14 and 30. Alternatively, one or both of proxy 29 and agent 42 may be downloaded, e.g., from external network 26. For example, in one embodiment, proxy 29 is an applet that is downloaded from a server 44 on external network 26 and that is installed on device 15. The applet may be included in a Web page that is provided by server 44, and that is accessed by a user when establishing a virtual tunnel between client application 24 and server application 39. This process is described in more detail below.
  • External network 26 contains server 44, which is a computer or any other processing device. Other devices (not shown) are also located on external network 26. For example, external network 26 may contain routers, switches, and the like (not shown), which receive data packets and which forward the data packets along paths to their intended destinations. Other servers, personal computers, mainframes, and processing devices (not shown) may also be on, and/or have access to, external network 26.
  • Server 44 acts as an intermediary for communications between client application 24 and server application 39 in the manner described below. Server 44 runs HTTP (Hypertext Transfer Protocol) and is “visible” to other devices, such as device 15, via external network 26.
  • In more detail, server 44 is used in passing data between client application 24 and server application 39 because these applications cannot address each other directly. That is, since both applications are on local networks, they do not have universally-recognized network addresses. As such, the client and server applications cannot address one another without the aid of server 44.
  • Server 44 includes a controller, such as a microprocessor, for executing software (machine-executable instructions) stored in a memory to perform the functions described below. To avoid confusion in terminology, the following reads as though those functions are performed by server 44, even though software in server 44, namely virtual tunneling application 45, performs the functions.
  • In this embodiment, server 44 contains a processor 46, a memory 47, and a storage medium 49 for storing, among other things, an operating system (OS) 50, software 51 for effecting network communication, and one or more applications. Processor 46 may execute software, including the applications, out of memory 47. Among these applications is tunneling application 45.
  • Tunneling application 45 creates a virtual tunnel between client application 24 on client local network 14 and server application 39 on server local network 30. Tunneling application 45 includes process 54 (FIG. 3) to establish the virtual tunnel, as described below. The virtual tunnel allows client application 24 and server application 39 to communicate even though they are both behind firewalls and cannot directly address each other.
  • The virtual tunnel is also advantageous because it preserves the protocols running on local networks 14 and 30. That is, data is transferred through the virtual tunnel via an intermediary protocol, such as HTTP, that is run on external network 26. The protocols running on local networks 14 and 30 are essentially transmitted via the protocol of external network. When data reaches its destination, e.g., at local network 14 or 30, the local protocol is thus recovered by either proxy 29 or agent 42, thereby enabling the same protocol to be used at both the source and destination local networks. Proxy 29 and agent 42 are both capable of converting between a local protocol and the intermediary protocol. In this regard, it is noted that the intermediary protocol may be the same as, or different from, the local protocols.
  • FIG. 3 shows process 54 that is performed by proxy 29, server 44, and agent 42 to set-up a virtual tunnel for a communication session between client application 24 and server application 39. The section of FIG. 3 labeled “Agent” corresponds to functions performed by agent 42; the section of FIG. 3 labeled “Proxy” corresponds to functions performed by proxy 29; and the section of FIG. 3 labeled “Server” corresponds to functions performed by tunneling application 45 (on server 44).
  • Referring to FIG. 3, agent 42 sends (60), to server 44, interface information, including, but not limited to, interface names and port numbers of agent 42 associated with server application 39. The interface information may be sent, e.g., in response to installing agent 42 on local network 30. Server 44 receives (61) the interface information and stores the interface information in a database (not shown). The database is associated with agent 42.
  • Information in the database may be made accessible to a user, e.g., at device 15 via a Web browser. The information may be made accessible via a Web page (not shown) provided by server 44. The Web page may contain a list of devices on local network 30 that may be accessed via virtual tunneling. The identities of the devices, which may be provided to server 44 along with the interface information, are associated with software interfaces to such devices. When a user selects a device to connect to, the user is, in effect, selecting an interface of agent 42.
  • A user who wants to connect to a device on local network from client application 24 logs into server 44 via a Web page (not shown). The user then selects a device (and, thus, an interface) to begin a communication session with that device. Server 44 receives (62) the input from the Web page. As noted above, the Web page may contain an applet that comprises proxy 29. In this case, when the user selects a device and enters the selection, the applet may be installed on device 15 as proxy 29.
  • Server 44 may control access to agents and interfaces through a predefined security (access) policy. For example, server 44 may allow some users, but not others, access to devices on local network 30. Likewise, users may be restricted as to which devices they may access. Server 44 may control access based on user IDs (identifiers) and/or passwords assigned to system users. For example, server 44 may maintain a database of user IDs and/or passwords corresponding to devices that are accessible via those user IDs and/or passwords. If a user attempts to establish a communication session with a device for which he has not been permitted access, server 44 may provide that user with an error message or the like.
  • Assuming that the user has access to the requested device, in process 54, server 44 creates (63) a session object for the current communication session. The session object contains message queues. The message queues are used to store data that is passed between client application 24 and server application 39.
  • In this embodiment, the session object contains two message queues (other embodiments may contain more, or less, message queues). One message queue is for data going from client application 24 to server application 39 and the other message queue is for data going from server application 39 to client application 24.
  • The session object also has an associated session identifier, referred to as a “sessionID” string. The sessionID string may be a unique alphanumeric identifier that identifies communications associated with a particular communication session. As described below, all data transfers associated with a communication session between client application 24 and server application 39 pass through server 44. The sessionID string is used by server 44 (in particular, by tunneling application 45) to store the data in the appropriate message queues(s).
  • In process 54, server 44 sends (64) the sessionID string and selected interface name to agent 42. Agent 42 receives (65) this message and creates (66) a socket using the port and IP address that correspond to the selected interface name. Agent 42 connects (67) the socket to server application 39. If connection fails, agent 42 reports an error to server 44. It is noted that sockets are used in this embodiment because they are a well-known way of communicating. Other means of communication may be used, including proxies, pipes, serial communications, etc.
  • In process 54, server 44 also sends (64) the sessionID string and port or other protocol parameters to proxy 29. Proxy 29 receives (68) this message and creates (69) a socket using the port that corresponds to client application 24. Proxy 29 then provides (70) an “accept” instruction on that socket. The accept instruction enables proxy 29 to accept data from client application 24.
  • Both proxy 29 and agent 42 execute a software thread to poll (71, 72) for data on their respective sockets, and also to poll for data from server 44. When data from client application 24 is received on a socket of proxy 29, proxy 29 appends the appropriate sessionID string to the data and passes the data to server 44. The sessionID string enables server 44 to identify the data as belonging to a particular communication session, and to store the data in the appropriate message queue. Agent 42 polls for data from server 44, meaning that it searches for data from server 44 that is stored in message queues for agent 42. If there is data present, agent 42 retrieves the data, identifies the communication session using the sessionID string associated with the data, and passes the data to server application 39 via the established socket.
  • The converse occurs for data passed from server application 39 to client application 24. More specifically, data from server application 24 is received on a socket of agent 42. Agent 42 appends the sessionID string for the current communication session to the data and passes the data to server 44. Proxy 29 polls for data from server 44. If there is data present in an appropriate message queue, proxy 29 retrieves the data, identifies the communication session using the sessionID string, and passes the data to client application 24.
  • On each socket, a select or “recv” (receive) instruction (command) determines if there is data to read. When data is read from a socket, the data may be sent to server 44 (by proxy 29 or agent 42) as the body of an HTTP POST command. Data in server 44 may be polled (by proxy 29 or agent 42) using an HTTP GET command. If there is data in server 44, the data is passed in a reply to the GET command. This data is then written to the appropriate socket. When an HTTP command is sent, its URL parameters include a “session=SSS” parameter, where “SSS” is the sessionID for a communication session.
  • As noted above, server 44 has a session object that contains two message queues. Data sent from proxy 29 is stored in one message queue and delivered when agent 42 issues a GET command. The other message queue contains data being passed from agent 42 to proxy 29.
  • Proxy 29 and agent 42 may encrypt communications sent to server 44. Examples of encryption that may be used include Secure Sockets Layer (SSL) and Hyper Text Transfer Protocol Secure sockets (HTTPS). The recipient (e.g., proxy 29 or agent 42) should have sufficient capabilities to perform any necessary decryption.
  • In this embodiment, there are two ways to end a communication session (i.e., terminate a virtual tunnel). The session may end when either client application 24 or server application 39 closes its socket. However, some applications open and close sockets during the normal course of communications. For applications such as these, the user may terminate the session manually when the applications are finished running. The user may choose a termination scenario when creating the session.
  • Server 44 may maintain an audit log (i.e., record) of communication sessions. The audit log may identify the user, time, duration, agent, interface, and number of bytes transferred in a communication session. The actual data may be stored as human-readable text or in another format. Audit logs are particularly advantageous in diagnostic and repair scenarios, where it is often necessary to identify device modifications and repairs after the fact.
  • Server 44 may be associated with multiple servers, one or more of which may act as a load balancing server to distribute communications amongst other servers. In this case, when a session object is created, the session object may be created on a server that has the most (or greater than a predetermined amount of) resources available and/or a server that is located closest to (or within a predetermined location of) agent 42. In this case, the Uniform Resource Locator (URL) of the server that is being used to effect communication is sent to agent 42 and proxy 29, along with the sessionID. In all subsequent communications, proxy 29 and agent 42 include the URL of the server. This ensures that a single server handles a single communication session.
  • The virtual tunnel system described herein is not limited to use with the hardware/software configuration of FIGS. 2 and 3; it may find applicability in any computing or processing environment. The functionality of the virtual tunnel system, including, but not limited to, the functions performed by proxy 29, server 44, and agent 42, may be implemented in hardware (e.g., an ASIC {Application-Specific Integrated Circuit} and/or an FPGA {Field Programmable Gate Array}), software, or a combination of hardware and software.
  • The virtual tunnel system may find applicability in any computing or processing environment and with any type of machine that is capable of running machine-readable instructions, such as one or more computer programs.
  • The virtual tunnel system can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations of them. The virtual tunnel system can be implemented as a computer program product, i.e., a computer program tangibly embodied in an information carrier, e.g., in a machine-readable medium or in a propagated signal, for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a communication network.
  • Method steps implemented to effect virtual tunneling can be performed by one or more programmable processors executing one or more computer programs to perform functions described herein by operating on input data and generating output. Method steps can also be performed by, and the virtual tunnel system can be implemented as, special purpose logic circuitry.
  • Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read- only memory or a random access memory or both. Elements of a computer include a processor for executing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from, or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks. Information carriers suitable for embodying computer program instructions and data include all forms of non-volatile memory, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in special purpose logic circuitry.
  • The virtual tunnel system can be implemented in a computing system that includes a back-end component, e.g., as a data server, or that includes a middleware component, e.g., an application server, or that includes a front-end component, e.g., a client computer having a graphical user interface or a Web browser through which a user can interact with the virtual tunneling system, or any combination of such back-end, middleware, or front-end components. The components of the system can be interconnected by any form or medium of digital data communication, e.g., a communication network. Examples of communication networks include a local area network (“LAN”) and a wide area network (WAN”), e.g., the Internet.
  • The computing system can include clients and servers. A client and server are generally remote from each other and typically interact through a communication network. The relationship of client and server arises by virtue of computer programs running on the respective computers and having a client-server relationship to each other.
  • The process described above is not limited to the implementations set forth herein. For example, the process is not limited to use with the virtual tunnel system described herein, but rather may be implemented in any type of network-based communication system.
  • It is noted that client application 24 and server application 39 may communicate directly when a direct connection can be achieved (e.g., if they are on the same network). To effect direct communication, if client application 24 and server application 39 use TCP/IP, server application 39 creates a socket on a specific port. Client application 24 also creates a socket and connects to this port. If server application 39 runs on another computer, client application 24 also specifies the network address of that computer. At this point, the client and server are connected and begin communicating.
  • The local protocols run on local networks 14, 30 may be TCP/IP or a serial protocol, such as RS232 or RS485. The protocol run on external network 26 may be HTTP. The virtual tunnel may comprise a telnet session (e.g., the tunnel is implemented during the telnet session).
  • It is noted that more than one agent may be present on local network 30 and more than one proxy may be present on local network 14. There may be a one-to-one correspondence between devices and agents and between devices and proxies. Alternatively, a single proxy may service different devices and, likewise, a single agent may service different devices. Similarly, multiple proxies may service the same device and multiple agents may service the same device.
  • The sessionID string may expire after a predetermined period of time, necessitating a new communication session. For example, the sessionID may expire after a period during which no communications are exchanged. This period may be programmed into server 44. Similarly, the sessionID string expires when a communication session terminates.
  • Other embodiments not described herein are also within the scope of the following claims.

Claims (20)

1. A method of transferring data via a communication session between a client application and a server application, the method comprising:
assigning an identifier to the communication session;
creating at least one queue associated with the communication session; and
storing data passed between the client application and the server application in the at least one queue, the data being stored using the identifier;
wherein the client application and the server application run local protocols, and the data is passed between the client application and the server application via an intermediary protocol.
2. The method of claim 1, further comprising:
creating a socket interface to at least one of the client application and the server application, the data being transmitted through the socket interface.
3. The method of claim 1, wherein the client application and the server application are on networks that run local protocols, and the method further comprises:
converting between the local protocols and the intermediary protocol when passing the data.
4. The method of claim 3, wherein the local protocol comprises at least one of TCP/IP and a serial protocol, the serial protocol comprising one of RS232 and RS485.
5. The method of claim 3 wherein the intermediary protocol comprises HTTP.
6. The method of claim 1, wherein the identifier is associated with the at least one queue.
7. The method of claim 1, wherein the method is performed by a server, and further comprises:
performing load balancing to select the server from among plural servers.
8. The method of claim 1, wherein the identifier is invalidated when the communication session terminates.
9. The method of claim 1, wherein the communication session comprises a telnet session.
10. The method of claim 1, wherein the communication session is effected via a Web site.
11. The method of claim 1, further comprising maintaining a session record, the session record including an identity of a user initiating the session.
12. A system for transferring data via a communication session between a client application and a server application, the client application running on a first network and the server application running on a second network, the system comprising:
a proxy having a socket to the client application, the proxy converting data between a local protocol run on the first network to a non-local protocol;
an agent that creates a socket to the server application, the agent converting data between a local protocol run on the second network and the non-local protocol; and
a server in communication with the proxy and the agent, the server containing a message queue dedicated to the communication session, the message queue for storing data transmitted during the communication session.
13. The system of claim 12, wherein the proxy polls the server for data for the client application.
14. The system of claim 13, wherein, when data is present for the client application, the proxy retrieves the data from the message queue and passes the data to the client application.
15. The system of claim 12, wherein the agent polls the server for data for the server application.
16. The system of claim 15, wherein, when data is present for the client application, the agent retrieves the data from the message queue and passes the data to the server application.
17. A machine-readable medium that stores instructions for use in transferring data via a communication session between a client application and a server application, the instructions causing a machine to:
assign an identifier to the communication session;
create at least one queue associated with the communication session; and
store data passed between the client application and the server application in the at least one queue, the data being stored using the identifier;
wherein the client application and the server application run local protocols, and the data is passed between the client application and the server application via an intermediary protocol.
18. The machine-readable medium of claim 17, wherein the intermediary protocol is different from the local protocols.
19. The method of claim 1, wherein the intermediary protocol is different from the local protocols.
20. The method of claim 1, wherein the intermediary protocol is a same protocol as the local protocols.
US10/784,138 2003-02-21 2004-02-20 Establishing a virtual tunnel between two computer programs Expired - Fee Related US7966418B2 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
US10/784,138 US7966418B2 (en) 2003-02-21 2004-02-20 Establishing a virtual tunnel between two computer programs
US13/105,385 US8291039B2 (en) 2003-02-21 2011-05-11 Establishing a virtual tunnel between two computer programs
US13/614,311 US9002980B2 (en) 2003-02-21 2012-09-13 Establishing a virtual tunnel between two computer programs
US14/678,277 US10069939B2 (en) 2003-02-21 2015-04-03 Establishing a virtual tunnel between two computers

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US44921303P 2003-02-21 2003-02-21
US10/784,138 US7966418B2 (en) 2003-02-21 2004-02-20 Establishing a virtual tunnel between two computer programs

Related Child Applications (1)

Application Number Title Priority Date Filing Date
US13/105,385 Continuation US8291039B2 (en) 2003-02-21 2011-05-11 Establishing a virtual tunnel between two computer programs

Publications (2)

Publication Number Publication Date
US20050021772A1 true US20050021772A1 (en) 2005-01-27
US7966418B2 US7966418B2 (en) 2011-06-21

Family

ID=34082966

Family Applications (4)

Application Number Title Priority Date Filing Date
US10/784,138 Expired - Fee Related US7966418B2 (en) 2003-02-21 2004-02-20 Establishing a virtual tunnel between two computer programs
US13/105,385 Expired - Fee Related US8291039B2 (en) 2003-02-21 2011-05-11 Establishing a virtual tunnel between two computer programs
US13/614,311 Expired - Fee Related US9002980B2 (en) 2003-02-21 2012-09-13 Establishing a virtual tunnel between two computer programs
US14/678,277 Expired - Fee Related US10069939B2 (en) 2003-02-21 2015-04-03 Establishing a virtual tunnel between two computers

Family Applications After (3)

Application Number Title Priority Date Filing Date
US13/105,385 Expired - Fee Related US8291039B2 (en) 2003-02-21 2011-05-11 Establishing a virtual tunnel between two computer programs
US13/614,311 Expired - Fee Related US9002980B2 (en) 2003-02-21 2012-09-13 Establishing a virtual tunnel between two computer programs
US14/678,277 Expired - Fee Related US10069939B2 (en) 2003-02-21 2015-04-03 Establishing a virtual tunnel between two computers

Country Status (1)

Country Link
US (4) US7966418B2 (en)

Cited By (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20020116550A1 (en) * 2000-09-22 2002-08-22 Hansen James R. Retrieving data from a server
US20040133563A1 (en) * 2002-08-08 2004-07-08 Matthew Harvey Maintaining independent states for multiple web browser instances
US20050245741A1 (en) * 2002-07-08 2005-11-03 Nafizal Hossain Novel tricyclic spiropiperidines or spiropyrrolidines
US20050267947A1 (en) * 2004-05-21 2005-12-01 Bea Systems, Inc. Service oriented architecture with message processing pipelines
US20050264581A1 (en) * 2004-05-21 2005-12-01 Bea Systems, Inc. Dynamic program modification
US20050267892A1 (en) * 2004-05-21 2005-12-01 Patrick Paul B Service proxy definition
US20050270970A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Failsafe service oriented architecture
US20050273516A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Dynamic routing in a service oriented architecture
US20050273521A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Dynamically configurable service oriented architecture
US20050273847A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Programmable message processing stage for a service oriented architecture
US20050273518A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Co-located service oriented architecture
US20050273502A1 (en) * 2004-05-21 2005-12-08 Patrick Paul B Service oriented architecture with message processing stages
US20050278374A1 (en) * 2004-05-21 2005-12-15 Bea Systems, Inc. Dynamic program modification
US20060005063A1 (en) * 2004-05-21 2006-01-05 Bea Systems, Inc. Error handling for a service oriented architecture
US20060007918A1 (en) * 2004-05-21 2006-01-12 Bea Systems, Inc. Scaleable service oriented architecture
US20060026168A1 (en) * 2004-05-20 2006-02-02 Bea Systems, Inc. Data model for occasionally-connected application server
US20060031930A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Dynamically configurable service oriented architecture
US20060031353A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Dynamic publishing in a service oriented architecture
US20060031433A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Batch updating for a service oriented architecture
US20060031354A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Service oriented architecture
US20060031432A1 (en) * 2004-05-21 2006-02-09 Bea Systens, Inc. Service oriented architecture with message processing pipelines
US20060031481A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Service oriented architecture with monitoring
US20060036463A1 (en) * 2004-05-21 2006-02-16 Patrick Paul B Liquid computing
US20060034237A1 (en) * 2004-05-21 2006-02-16 Bea Systems, Inc. Dynamically configurable service oriented architecture
US20060069791A1 (en) * 2004-05-21 2006-03-30 Bea Systems, Inc. Service oriented architecture with interchangeable transport protocols
US20060080419A1 (en) * 2004-05-21 2006-04-13 Bea Systems, Inc. Reliable updating for a service oriented architecture
US20060117073A1 (en) * 2004-05-20 2006-06-01 Bea Systems, Inc. Occasionally-connected application server
US20060136555A1 (en) * 2004-05-21 2006-06-22 Bea Systems, Inc. Secure service oriented architecture
US20060212593A1 (en) * 2004-05-21 2006-09-21 Bea Systems, Inc. Dynamic service composition and orchestration
US20060259604A1 (en) * 2005-04-15 2006-11-16 Uri Kotchavi Apparatus and method for managing a network of intelligent devices
US20070011295A1 (en) * 2000-07-28 2007-01-11 Axeda Corporation, A Massachusetts Corporation Reporting the state of an apparatus to a remote computer
US20070078976A1 (en) * 2001-12-20 2007-04-05 Questra Corporation Adaptive device-initiated polling
US20070150903A1 (en) * 2002-04-17 2007-06-28 Axeda Corporation XML Scripting of SOAP Commands
US20070198661A1 (en) * 2000-09-22 2007-08-23 Axeda Corporation Retrieving data from a server
US20070245412A1 (en) * 2006-04-13 2007-10-18 Directpacket Research, Inc. System and method for a communication system
US20080082657A1 (en) * 2006-10-03 2008-04-03 Questra Corporation A System and Method for Dynamically Grouping Devices Based on Present Device Conditions
US20080154957A1 (en) * 2006-12-26 2008-06-26 Questra Corporation Managing configurations of distributed devices
US7424736B2 (en) 2004-03-10 2008-09-09 Combrio, Inc. Method for establishing directed circuits between parties with limited mutual trust
US20080270612A1 (en) * 2007-04-30 2008-10-30 Microsoft Corporation Enabling secure remote assistance using a terminal services gateway
US20080288304A1 (en) * 2007-05-18 2008-11-20 Bea Systems, Inc. System and Method for Enabling Decision Activities in a Process Management and Design Environment
US20080298366A1 (en) * 2007-05-31 2008-12-04 Microsoft Corporation Agnostic Network Architecture
US20090006167A1 (en) * 2007-06-28 2009-01-01 Bea Systems, Inc. System and Method for Integrating a Business Process Management System with an Enterprise Service Bus
US20090006612A1 (en) * 2007-06-27 2009-01-01 Arito Asai Communication system, proxy server, method of controlling same and control program therefor
US20090172395A1 (en) * 2007-12-31 2009-07-02 International Business Machines Corporation System and Method for Service Virtualization Using a MQ Proxy Network
US20100042722A1 (en) * 2008-08-18 2010-02-18 Sun Microsystems, Inc. Method for sharing data
US7685292B1 (en) 2005-04-07 2010-03-23 Dell Marketing Usa L.P. Techniques for establishment and use of a point-to-point tunnel between source and target devices
US20100177786A1 (en) * 2006-04-13 2010-07-15 Directpacket Research, Inc. System and method for multimedia communication across disparate networks
US8291039B2 (en) 2003-02-21 2012-10-16 Axeda Corporation Establishing a virtual tunnel between two computer programs
US20130145375A1 (en) * 2010-07-01 2013-06-06 Neodana, Inc. Partitioning processes across clusters by process type to optimize use of cluster specific configurations
US8478861B2 (en) 2007-07-06 2013-07-02 Axeda Acquisition Corp. Managing distributed devices with limited connectivity
US8555371B1 (en) * 2009-07-17 2013-10-08 Directpacket Research, Inc. Systems and methods for management of nodes across disparate networks
US8645973B2 (en) 2006-09-22 2014-02-04 Oracle International Corporation Mobile applications
US20150355946A1 (en) * 2014-06-10 2015-12-10 Dan-Chyi Kang “Systems of System” and method for Virtualization and Cloud Computing System
CN107135279A (en) * 2017-07-07 2017-09-05 网宿科技股份有限公司 It is a kind of to handle the method and apparatus that request is set up in long connection
CN109660562A (en) * 2019-01-30 2019-04-19 苏州德锐特成像技术有限公司 A kind of system and client synchronous for big data
US20200301818A1 (en) * 2019-03-21 2020-09-24 Sling Media Pvt Ltd Systems and methods for remote debugging

Families Citing this family (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050194456A1 (en) 2004-03-02 2005-09-08 Tessier Patrick C. Wireless controller with gateway
JP4575219B2 (en) * 2005-04-12 2010-11-04 株式会社東芝 Security gateway system and method and program thereof
US8458344B2 (en) * 2011-05-05 2013-06-04 Blue Coat Systems, Inc. Establishing tunnels between selective endpoint devices along communication paths
US8909641B2 (en) 2011-11-16 2014-12-09 Ptc Inc. Method for analyzing time series activity streams and devices thereof
US9576046B2 (en) 2011-11-16 2017-02-21 Ptc Inc. Methods for integrating semantic search, query, and analysis across heterogeneous data types and devices thereof
US9098312B2 (en) 2011-11-16 2015-08-04 Ptc Inc. Methods for dynamically generating an application interface for a modeled entity and devices thereof
US8406155B1 (en) 2012-03-19 2013-03-26 Google Inc. Cloud based contact center platform powered by individual multi-party conference rooms
JP6187053B2 (en) * 2012-09-18 2017-08-30 株式会社リコー Information processing system, information processing apparatus, and program
JP6285010B2 (en) 2013-03-15 2018-02-28 ピーティーシー インコーポレイテッド Method and apparatus for managing applications using semantic modeling and tagging
US9350791B2 (en) 2014-03-21 2016-05-24 Ptc Inc. System and method of injecting states into message routing in a distributed computing environment
US9462085B2 (en) 2014-03-21 2016-10-04 Ptc Inc. Chunk-based communication of binary dynamic rest messages
US10025942B2 (en) 2014-03-21 2018-07-17 Ptc Inc. System and method of establishing permission for multi-tenancy storage using organization matrices
WO2015143416A1 (en) 2014-03-21 2015-09-24 Ptc Inc. Systems and methods for developing and using real-time data applications
US9467533B2 (en) 2014-03-21 2016-10-11 Ptc Inc. System and method for developing real-time web-service objects
US10313410B2 (en) 2014-03-21 2019-06-04 Ptc Inc. Systems and methods using binary dynamic rest messages
US9762637B2 (en) 2014-03-21 2017-09-12 Ptc Inc. System and method of using binary dynamic rest messages
US9350812B2 (en) 2014-03-21 2016-05-24 Ptc Inc. System and method of message routing using name-based identifier in a distributed computing environment
US9961058B2 (en) 2014-03-21 2018-05-01 Ptc Inc. System and method of message routing via connection servers in a distributed computing environment
US9560170B2 (en) 2014-03-21 2017-01-31 Ptc Inc. System and method of abstracting communication protocol using self-describing messages
US10735426B2 (en) * 2017-02-09 2020-08-04 Salesforce.Com, Inc. Secure asynchronous retrieval of data behind a firewall
EP4164176A1 (en) 2017-05-18 2023-04-12 F. Hoffmann-La Roche AG Methods and systems for processing data of an analytical instrument for analyzing biological samples
US11012495B1 (en) 2018-01-09 2021-05-18 EMC IP Holding Company LLC Remote service credentials for establishing remote sessions with managed devices
CN112565425B (en) * 2020-12-03 2021-08-06 南京机敏软件科技有限公司 Method for copying and pasting among cloud application programs of multiple cross-cloud server host machine sessions

Citations (97)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4497037A (en) * 1980-11-26 1985-01-29 Nippondenso Co., Ltd. Apparatus for managing a group of copying machines
US4996703A (en) * 1986-04-21 1991-02-26 Gray William F Remote supervisory monitoring and control apparatus connected to monitored equipment
US5084875A (en) * 1989-12-13 1992-01-28 Joseph Weinberger System for automatically monitoring copiers from a remote location
US5184179A (en) * 1988-05-17 1993-02-02 Monitel Products Corp. Photocopy monitoring system and method for monitoring copiers
US5282127A (en) * 1989-11-20 1994-01-25 Sanyo Electric Co., Ltd. Centralized control system for terminal device
US5384622A (en) * 1991-11-18 1995-01-24 Minolta Camera Kabushiki Kaisha System of controlling a plurality of copying machines interconnnected through a private branch exchange
US5386271A (en) * 1991-08-30 1995-01-31 Minolta Camera Kabushiki Kaisha Centralized control system for an image forming apparatus which employs fuzzy logic to identify abnormal conditions
US5392095A (en) * 1993-12-02 1995-02-21 Xerox Corporation Customer feedback device on a machine console
US5485142A (en) * 1994-04-08 1996-01-16 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Remote monitor alarm system
US5488454A (en) * 1991-04-18 1996-01-30 Canon Kabushiki Kaisha Control of equipment and of communication with plural units of equipment
US5491535A (en) * 1990-04-10 1996-02-13 Minolta Camera Kabushiki Kaisha Control appartus of copying machine with improved communication function for centralized control
US5493364A (en) * 1991-04-18 1996-02-20 Canon Kabushiki Kaisha Equipment control apparatus having means to communicate with a centralized control apparatus
US5594529A (en) * 1994-11-30 1997-01-14 Exedy Corporation Imaging device with stock supervision means
US5600301A (en) * 1993-03-11 1997-02-04 Schrader Automotive Inc. Remote tire pressure monitoring system employing coded tire identification and radio frequency transmission, and enabling recalibration upon tire rotation or replacement
US5600403A (en) * 1993-12-24 1997-02-04 Canon Kabushiki Kaisha Monitor system for monitoring state of image forming device
US5603060A (en) * 1989-12-13 1997-02-11 Joseph Weinberger Method of controlling copy machines from a remote location
US5603323A (en) * 1996-02-27 1997-02-18 Advanced Technology Laboratories, Inc. Medical ultrasonic diagnostic system with upgradeable transducer probes and other features
US5708908A (en) * 1990-06-22 1998-01-13 Minolta Co., Ltd. Copying machine control system with improved reliability of communication function among copying machiines and centralized control unit
US5708909A (en) * 1995-09-12 1998-01-13 Mita Industrial Co., Ltd. Equipment management system
US5715393A (en) * 1993-08-16 1998-02-03 Motorola, Inc. Method for remote system process monitoring
US5715496A (en) * 1995-01-19 1998-02-03 Ricoh Company, Ltd. Remote service system for image forming apparatuses
US5715823A (en) * 1996-02-27 1998-02-10 Atlantis Diagnostics International, L.L.C. Ultrasonic diagnostic imaging system with universal access to diagnostic information and images
US5720015A (en) * 1996-04-22 1998-02-17 Lexmark International, Inc. Method and apparatus for providing remote printer resource management
US5857207A (en) * 1993-05-12 1999-01-05 Apple Computer, Inc. Storage manager for computer system
US5857967A (en) * 1997-07-09 1999-01-12 Hewlett-Packard Company Universally accessible healthcare devices with on the fly generation of HTML files
US5862404A (en) * 1997-02-12 1999-01-19 Toshiba America Information Systems, Inc. Network device discovery and status information distribution using independent information distribution processes
US5862348A (en) * 1996-02-09 1999-01-19 Citrix Systems, Inc. Method and apparatus for connecting a client node to a server node based on load levels
US5865745A (en) * 1996-11-27 1999-02-02 Eastman Kodak Company Remote health care information input apparatus
US5873009A (en) * 1995-11-06 1999-02-16 Mita Industrial Co., Ltd. Equipment management system that issues a warning when the lifetime of a component has been exceeded and disables the warning when such a warning is to be generated for a different component
US5872635A (en) * 1995-04-27 1999-02-16 Canon Kabushiki Kaisha Image forming apparatus and method which transmits information on internal conditions to an image processor
US5872928A (en) * 1995-02-24 1999-02-16 Cabletron Systems, Inc. Method and apparatus for defining and enforcing policies for configuration management in communications networks
US5873659A (en) * 1996-04-24 1999-02-23 Edwards; Steve Michael Method and apparatus for providing a printer having internal queue job management
US6012088A (en) * 1996-12-10 2000-01-04 International Business Machines Corporation Automatic configuration for internet access device
US6014694A (en) * 1997-06-26 2000-01-11 Citrix Systems, Inc. System for adaptive video/audio transport over a network
US6014631A (en) * 1998-04-02 2000-01-11 Merck-Medco Managed Care, Llc Computer implemented patient medication review system and process for the managed care, health care and/or pharmacy industry
US6014691A (en) * 1996-12-06 2000-01-11 Bef Corporation Distributed data collection system for remote photographic processing equipment
US6016535A (en) * 1995-10-11 2000-01-18 Citrix Systems, Inc. Method for dynamically and efficiently caching objects by subdividing cache memory blocks into equally-sized sub-blocks
US6021284A (en) * 1995-02-22 2000-02-01 Canon Kabushiki Kaisha Image forming apparatus, apparatus for supplying image data to image forming apparatus, and method of interfacing two apparatuses
US6022315A (en) * 1993-12-29 2000-02-08 First Opinion Corporation Computerized medical diagnostic and treatment advice system including network access
US6023722A (en) * 1996-12-07 2000-02-08 International Business Machines Corp. High-availability WWW computer server system with pull-based load balancing using a messaging and queuing unit in front of back-end servers
US6023507A (en) * 1997-03-17 2000-02-08 Sun Microsystems, Inc. Automatic remote computer monitoring system
US6023749A (en) * 1997-01-07 2000-02-08 Citrix Systems, Inc. Object and method for providing efficient multi-user access to shared operating system kernal code using instancing
US6023721A (en) * 1997-05-14 2000-02-08 Citrix Systems, Inc. Method and system for allowing a single-user application executing in a multi-user environment to create objects having both user-global and system global visibility
US6023223A (en) * 1999-03-18 2000-02-08 Baxter, Jr.; John Francis Early warning detection and notification network for environmental conditions
US6025925A (en) * 1995-06-23 2000-02-15 Lexmark International, Inc. Method and apparatus for providing job accounting information to a host computer from a printer
US6031964A (en) * 1996-06-20 2000-02-29 Apple Computer, Inc. System and method for using a unified memory architecture to implement a digital camera device
US6172683B1 (en) * 1996-06-12 2001-01-09 Citrix Systems, Inc. Method for the lossless compression of lines in a distributed computer system
US6175866B1 (en) * 1997-11-24 2001-01-16 International Business Machines Corporation Method and system for generating unsupported network monitoring objects
US6181331B1 (en) * 1992-09-23 2001-01-30 Siemens Power Transmission & Distribution, Inc. Man-machine interface
US6189113B1 (en) * 1998-09-25 2001-02-13 Xerox Corporation Auditron data format for remote maintenance of a machine such as a copier
US6336135B1 (en) * 1996-05-24 2002-01-01 International Business Machines Corporation Gateway for converting synchronous client/server protocols into asynchronous messaging protocols and storing session state information at the client
US6338086B1 (en) * 1998-06-11 2002-01-08 Placeware, Inc. Collaborative object architecture
US20020006790A1 (en) * 1998-10-21 2002-01-17 Werner Blumenstock System and method for remote maintenance and/or remote diagnosis of an automation system by means of electronic mail
US6343320B1 (en) * 1998-06-09 2002-01-29 Compaq Information Technologies Group, L.P. Automatic state consolidation for network participating devices
US20020019844A1 (en) * 2000-07-06 2002-02-14 Kurowski Scott J. Method and system for network-distributed computing
US20020026514A1 (en) * 2000-02-01 2002-02-28 Ellis Raymond Walter Automated tool management in a multi-protocol environment
US20030014733A1 (en) * 2001-07-10 2003-01-16 Ringseth Paul F. System and methods for providing a declarative syntax for specifying SOAP-based web services
US6510350B1 (en) * 1999-04-09 2003-01-21 Steen, Iii Henry B. Remote data access and system control
US20030023957A1 (en) * 2001-07-02 2003-01-30 David Bau Annotation based development platform for stateful web services
US20030025931A1 (en) * 2001-08-01 2003-02-06 Gregory Dorfman Content management in a broadband printing system
US6523013B2 (en) * 1998-07-24 2003-02-18 Neopost, Inc. Method and apparatus for performing automated fraud reporting
US6523130B1 (en) * 1999-03-11 2003-02-18 Microsoft Corporation Storage system having error detection and recovery
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
US20030037148A1 (en) * 1997-05-14 2003-02-20 Citrix Systems, Inc. System and method for transmitting data from a server application to more than one client node
US6681349B2 (en) * 1998-01-06 2004-01-20 Seiko Epson Corporation System and method for monitoring the state of a plurality of machines connected via a computer network
US6681344B1 (en) * 2000-09-14 2004-01-20 Microsoft Corporation System and method for automatically diagnosing a computer problem
US6684259B1 (en) * 1995-10-11 2004-01-27 Citrix Systems, Inc. Method for providing user global object name space in a multi-user operating system
US6687848B1 (en) * 2000-05-31 2004-02-03 Sun Microsystems, Inc. Techniques for preventing information loss in a business to business message in an enterprise computer system
US6687873B1 (en) * 2000-03-09 2004-02-03 Electronic Data Systems Corporation Method and system for reporting XML data from a legacy computer system
US6686838B1 (en) * 2000-09-06 2004-02-03 Xanboo Inc. Systems and methods for the automatic registration of devices
US6691157B2 (en) * 1995-11-13 2004-02-10 Citrix Systems, Inc. Method and apparatus for making a hypermedium interactive
US6691154B1 (en) * 1998-11-18 2004-02-10 Webex Communications, Inc. Instantaneous remote control of an unattended server
US20040027373A1 (en) * 2002-08-07 2004-02-12 Jacquot Bryan Joseph Linked screen demonstration program for computer application programs
US20050005152A1 (en) * 2003-07-01 2005-01-06 Navjot Singh Security vulnerability monitor
US6842903B1 (en) * 1999-05-19 2005-01-11 Sun Microsystems, Inc. System and method for providing dynamic references between services in a computer system
US20050015501A1 (en) * 2003-01-13 2005-01-20 Kaplan Scott P. On-location electronics troubleshooting services system
US20050033588A1 (en) * 2003-08-04 2005-02-10 Mario Ruiz Information system comprised of synchronized software application moduless with individual databases for implementing and changing business requirements to be automated
US6857013B2 (en) * 1999-01-29 2005-02-15 Intermec Ip.Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US6983020B2 (en) * 2002-03-25 2006-01-03 Citrix Online Llc Method and apparatus for fast block motion detection
US20060002315A1 (en) * 2004-04-15 2006-01-05 Citrix Systems, Inc. Selectively sharing screen data
US6986040B1 (en) * 2000-11-03 2006-01-10 Citrix Systems, Inc. System and method of exploiting the security of a secure communication channel to secure a non-secure communication channel
US6985779B2 (en) * 2000-03-10 2006-01-10 Smiths Detection, Inc. Monitoring system for an industrial process using one or more multidimensional variables
US20060015740A1 (en) * 2004-07-02 2006-01-19 Citrix Systems, Inc. A system and method for executing interactive applications with minimal privileges
US6990395B2 (en) * 1994-12-30 2006-01-24 Power Measurement Ltd. Energy management device and architecture with multiple security levels
US20060031237A1 (en) * 1998-03-30 2006-02-09 Deanna Robert System for development, management and operation of distributed clients and servers
US20060029063A1 (en) * 2004-07-23 2006-02-09 Citrix Systems, Inc. A method and systems for routing packets from a gateway to an endpoint
US20060031476A1 (en) * 2004-08-05 2006-02-09 Mathes Marvin L Apparatus and method for remotely monitoring a computer network
US7158483B1 (en) * 1998-06-30 2007-01-02 Kabushiki Kaisha Toshiba Communication node and communication terminal
US20070005736A1 (en) * 2002-04-19 2007-01-04 Axeda Corporation, A Massachusetts Corporation Configuring a network gateway
US7162628B2 (en) * 2002-07-23 2007-01-09 Cisco Technology, Inc. Method, system, apparatus and program product for temporary personalization of a computer terminal
US7162315B2 (en) * 1998-12-18 2007-01-09 Placeware, Inc. Digital audio compensation
US20070011295A1 (en) * 2000-07-28 2007-01-11 Axeda Corporation, A Massachusetts Corporation Reporting the state of an apparatus to a remote computer
US20070011356A1 (en) * 2005-05-26 2007-01-11 Citrix Systems, Inc. A method and system for synchronizing presentation of a dynamic data set to a plurality of nodes
US20070022159A1 (en) * 2002-03-28 2007-01-25 Webex Communications, Inc. conference recording system
US20080005321A1 (en) * 2006-06-29 2008-01-03 Lin Ma Monitoring and Managing Distributed Devices
US20090013064A1 (en) * 2007-07-06 2009-01-08 Questra Corporation Managing distributed devices with limited connectivity
US20090019226A1 (en) * 2007-07-11 2009-01-15 Citrix Systems, Inc. Methods and systems for providing a level of access to a computing device

Family Cites Families (613)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4086434A (en) 1976-09-07 1978-04-25 Leo P. Christiansen Remote condition reporting system
US4583834A (en) 1977-09-16 1986-04-22 Ricoh Company, Ltd. Copying apparatus
US4412292A (en) 1981-02-17 1983-10-25 The Coca-Cola Company System for the remote monitoring of vending machines
JPS60263163A (en) 1984-06-12 1985-12-26 Ricoh Co Ltd Data control device for copying machine
JPS60263162A (en) 1984-06-12 1985-12-26 Ricoh Co Ltd Copying system
GB8608431D0 (en) 1986-04-07 1986-05-14 Crosfield Electronics Ltd Monitoring digital image processing equipment
US4853946A (en) 1986-11-14 1989-08-01 Picker International, Inc. Diagonostic service system for CT scanners
US4964065A (en) 1987-03-12 1990-10-16 Decibel Products, Inc. Computer-controlled electronic system monitor
US5216596A (en) 1987-04-30 1993-06-01 Corabi International Telemetrics, Inc. Telepathology diagnostic network
US5909493A (en) 1996-10-16 1999-06-01 Ricoh Company, Ltd. Method and system for diagnosis and control of machines using connectionless modes of communication
US5887216A (en) 1997-03-19 1999-03-23 Ricoh Company, Ltd. Method and system to diagnos a business office device based on operating parameters set by a user
US6581092B1 (en) 1999-09-29 2003-06-17 Ricoh Co., Ltd. Method and system for remote diagnostic, control and information collection based on various communication modes for sending messages to users
US5819110A (en) 1995-06-05 1998-10-06 Ricoh Company, Ltd. System for determining whether connection or connectionless modes of communication should be used to transmit information between devices in accordance with priorities of events
US5818603A (en) 1996-03-29 1998-10-06 Ricoh Company, Ltd. Method and system for controlling and communicating with machines using multiple communication formats
JPS6461842A (en) 1987-09-01 1989-03-08 Nec Corp Message exchange processor
GB8801343D0 (en) 1988-01-21 1988-02-17 Al Madina Marketing Ltd Display card/mount
US5077582A (en) 1988-05-17 1991-12-31 Monitel Products Corp. Photocopy monitoring system
US5261061A (en) 1988-08-31 1993-11-09 Samsung Electronics Co., Ltd. Remote maintenance and administration method in a switchboard system
US5038319A (en) 1989-04-24 1991-08-06 Xerox Corporation System for recording and remotely accessing operating data in a reproduction machine
US5061837A (en) 1989-05-02 1991-10-29 Webex, Inc. Method and apparatus for selectively demetallizing a metallized film
US4962368A (en) 1989-05-04 1990-10-09 General Signal Corporation Reliability and workability test apparatus for an environmental monitoring system
US5224157A (en) 1989-05-22 1993-06-29 Minolta Camera Kabushiki Kaisha Management system for managing maintenance information of image forming apparatus
US5214772A (en) 1989-12-13 1993-05-25 Joseph Weinberger System for automatically monitoring copiers from a remote location
US6009284A (en) 1989-12-13 1999-12-28 The Weinberger Group, L.L.C. System and method for controlling image processing devices from a remote location
US5347346A (en) 1989-12-25 1994-09-13 Minolta Camera Kabushiki Kaisha Image forming apparatus with improved efficiency of maintenance control
US5335048A (en) 1990-01-30 1994-08-02 Minolta Camera Kabushiki Kaisha Efficient control system of image forming apparatus
CA2075048C (en) 1990-01-30 1999-08-17 Gregory A. Pascucci Networked facilities management system
US5303005A (en) 1990-01-31 1994-04-12 Minolta Camera Kabushiki Kaisha Image forming apparatus with improved maintenance control
US5243382A (en) 1990-01-31 1993-09-07 Minolta Camera Kabushiki Kaisha Image forming apparatus capable of efficient maintenance work
US5163151A (en) 1990-03-22 1992-11-10 Square D Company System for processing and prioritizing alarms from devices on data communications network
JP3019358B2 (en) 1990-04-10 2000-03-13 ミノルタ株式会社 Copier management device
US5631724A (en) 1990-04-10 1997-05-20 Sanyo Electric Co., Ltd Centralized control system for terminal device
US5424808A (en) 1990-04-10 1995-06-13 Minolta Camera Kabushiki Kaisha Control apparatus for copying machine with improved communication function for centralized control unit
US5300980A (en) 1990-04-10 1994-04-05 Minolta Camera Kabushiki Kaisha Control apparatus of copying machine with improved communication function for centralized control unit
JPH0662130B2 (en) 1990-04-19 1994-08-17 東亜機工株式会社 Wrapping machine and bag making machine
US5057866A (en) 1990-05-04 1991-10-15 Xerox Corporation Remotely accessible copier calculator
JP3121002B2 (en) 1990-07-06 2000-12-25 株式会社リコー Printer systems, printers and external devices
US5212645A (en) 1990-07-19 1993-05-18 General Electric Company Flexible real-time, multi-tasking architecture for tool condition monitoring
US5216461A (en) 1990-07-31 1993-06-01 Minolta Camera Kabushiki Kaisha Control system for copying machine with improved communication function to centralized control unit
US5220380A (en) 1990-08-10 1993-06-15 Minolta Camera Kabushiki Kaisha Control system for copying machines with improved communication function for centralized control unit
US5129080A (en) 1990-10-17 1992-07-07 International Business Machines Corporation Method and system increasing the operational availability of a system of computer programs operating in a distributed system of computers
JPH0783412B2 (en) 1991-02-12 1995-09-06 富士ゼロックス株式会社 Recording device management system
EP0509530B1 (en) 1991-04-18 2007-02-28 Canon Kabushiki Kaisha Communication apparatus and method
EP1225483A3 (en) 1991-04-18 2002-08-28 Canon Kabushiki Kaisha Machine managing apparatus
EP0513549A3 (en) 1991-04-18 1993-12-15 Canon Kk Equipment control apparatus
US5138377A (en) 1991-05-23 1992-08-11 Xerox Corporation Internal expert system to aid in servicing
JPH0774984B2 (en) 1991-06-10 1995-08-09 インターナショナル・ビジネス・マシーンズ・コーポレイション System resource utilization measurement method and data processing system
US5446522A (en) 1991-09-30 1995-08-29 Canon Kabushiki Kaisha Image forming apparatus for forming images in accordance with process steps received from an external device
US5619716A (en) 1991-11-05 1997-04-08 Hitachi, Ltd. Information processing system having a configuration management system for managing the software of the information processing system
JP3227744B2 (en) 1991-11-06 2001-11-12 ミノルタ株式会社 Image forming apparatus management system
US5369471A (en) 1991-11-20 1994-11-29 Sharp Kabushiki Kaisha Communication system for implementing maintenance of copying machine
JP3227750B2 (en) 1991-12-10 2001-11-12 ミノルタ株式会社 Copier
US5530899A (en) 1991-12-18 1996-06-25 Dmi, Inc. Archival and retrieval system accessing an external storage by polling internal queues from remote terminals minimizing interruption of a host processor
US6601159B1 (en) 1991-12-31 2003-07-29 Xerox Corporation Dynamically-switched supplemental information support system for a copier system
US5339168A (en) 1991-12-31 1994-08-16 Xerox Corporation Copier/duplicator network
US5586254A (en) 1992-02-13 1996-12-17 Hitachi Software Engineering Co., Ltd. System for managing and operating a network by physically imaging the network
JP3281080B2 (en) 1992-03-13 2002-05-13 株式会社リコー Copier management system and facsimile machine
JP2875926B2 (en) 1992-05-15 1999-03-31 シャープ株式会社 Image forming device communication system
JPH05328122A (en) 1992-05-19 1993-12-10 Minolta Camera Co Ltd Picture processor
DE69226436T2 (en) 1992-06-17 1998-12-03 Hewlett-Packard Co., Palo Alto, Calif. NETWORK MONITORING METHOD AND DEVICE
JPH0662130A (en) 1992-08-14 1994-03-04 Toshiba Corp Remote diagnosis system for medical device
JPH0670047A (en) 1992-08-19 1994-03-11 Minolta Camera Co Ltd Image forming device
JP3215174B2 (en) 1992-09-01 2001-10-02 キヤノン株式会社 Image processing apparatus and its control method, and information processing apparatus and its method
US5204699A (en) 1992-09-14 1993-04-20 Xerox Corporation Apparatus for estimating toner usage
US5428551A (en) 1992-09-23 1995-06-27 Siemens Energy & Automation, Inc. Tap changer monitor apparatus and method
US5367667A (en) 1992-09-25 1994-11-22 Compaq Computer Corporation System for performing remote computer system diagnostic tests
US5732212A (en) 1992-10-23 1998-03-24 Fox Network Systems, Inc. System and method for remote monitoring and operation of personal computers
US5305199A (en) 1992-10-28 1994-04-19 Xerox Corporation Consumable supplies monitoring/ordering system for reprographic equipment
US5307263A (en) 1992-11-17 1994-04-26 Raya Systems, Inc. Modular microprocessor-based health monitoring system
US5636008A (en) 1992-11-17 1997-06-03 Xerox Corporation Remote/shared system user interface
US5325156A (en) 1992-11-20 1994-06-28 Xerox Corporation Service call initiation and feedback interface for a reprographic machine
US5369472A (en) 1992-12-04 1994-11-29 Xerox Corporation Microprocessor controlled high voltage power supply
JP3347781B2 (en) 1992-12-11 2002-11-20 株式会社リコー Image forming device management system
US5305055A (en) 1992-12-16 1994-04-19 Xerox Corporation Automatic call to selected remote operators in response to predetermined machine conditions
US5398257A (en) 1993-01-11 1995-03-14 Groenteman; Frank S. Copier and monitoring network
JP3075499B2 (en) 1993-01-12 2000-08-14 キヤノン株式会社 Medical workstation
JP3125505B2 (en) 1993-02-16 2001-01-22 ミノルタ株式会社 Office machine management system
FR2702579B1 (en) * 1993-03-12 1995-05-24 Bull Sa Communication device between at least one client and at least one server, method of using the device and use of the device.
AU687045B2 (en) 1993-03-31 1998-02-19 Luma Corporation Managing information in an endoscopy system
US5696903A (en) 1993-05-11 1997-12-09 Norand Corporation Hierarchical communications system using microlink, data rate switching, frequency hopping and vehicular local area networking
JP3597545B2 (en) 1993-05-19 2004-12-08 株式会社リコー Image forming apparatus management system
US5917405A (en) 1993-06-08 1999-06-29 Joao; Raymond Anthony Control apparatus and methods for vehicles
US7082426B2 (en) 1993-06-18 2006-07-25 Cnet Networks, Inc. Content aggregation method and apparatus for an on-line product catalog
US5369469A (en) 1993-07-09 1994-11-29 Xerox Corporation Voice of the customer acquistion system
US5442541A (en) 1993-07-23 1995-08-15 Xerox Corporation Enabling features over common communication channel
JP3426293B2 (en) 1993-07-26 2003-07-14 株式会社リコー Communication control device
US5365310A (en) 1993-07-30 1994-11-15 Xerox Corporation Remote diagnosis of copy quality defects
US5878746A (en) 1993-08-25 1999-03-09 Lemelson; Jerome H. Computerized medical diagnostic system
US5748907A (en) 1993-10-25 1998-05-05 Crane; Harold E. Medical facility and business: automatic interactive dynamic real-time management
JPH07147639A (en) 1993-11-22 1995-06-06 Canon Inc Device and system for forming image
US5809237A (en) 1993-11-24 1998-09-15 Intel Corporation Registration of computer-based conferencing system
US5469353A (en) 1993-11-26 1995-11-21 Access Radiology Corp. Radiological image interpretation apparatus and method
US5414494A (en) 1993-12-06 1995-05-09 Xerox Corporation Automatic call to selected remote operators in response to predetermined machine conditions
US5342037A (en) 1993-12-17 1994-08-30 Xerox Corporation Feed roll wear compensation scheme
JP3238817B2 (en) 1993-12-28 2001-12-17 キヤノン株式会社 Image forming apparatus management apparatus and image forming apparatus
US5935060A (en) 1996-07-12 1999-08-10 First Opinion Corporation Computerized medical diagnostic and treatment advice system including list based processing
JP3428711B2 (en) 1993-12-29 2003-07-22 キヤノン株式会社 Information processing system
US5835911A (en) 1994-02-08 1998-11-10 Fujitsu Limited Software distribution and maintenance system and method
US6292828B1 (en) 1994-02-23 2001-09-18 David L. Williams Trans-modal animated information processing with selective engagement
JPH07287679A (en) 1994-04-19 1995-10-31 Canon Inc Network managing device and controlling method for the same
AU2365695A (en) 1994-04-26 1995-11-16 Raya Systems, Inc. Modular microprocessor-based diagnostic measurement system for psychological conditions
US5619656A (en) 1994-05-05 1997-04-08 Openservice, Inc. System for uninterruptively displaying only relevant and non-redundant alert message of the highest severity for specific condition associated with group of computers being managed
JP3322756B2 (en) 1994-05-31 2002-09-09 京セラミタ株式会社 Communication management device for image forming network
US5638427A (en) 1994-07-01 1997-06-10 Xerox Corporation Operator-controlled interactive communication device
EP0697661B1 (en) 1994-08-04 1997-11-19 Siemens Aktiengesellschaft Apparatus for technical diagnosis of errors in a medical system, in particular a dentist's system
JP3534331B2 (en) 1994-08-09 2004-06-07 ゼロックス コーポレイション How to build multi-segment print jobs from a variety of local and remote sources using a network interface
US5637845A (en) 1994-12-12 1997-06-10 Usa Technologies, Inc. Credit and bank issued debit card operated system and method for controlling a prepaid card encoding/dispensing machine
US5528691A (en) 1994-10-04 1996-06-18 Motorola, Inc. Method for automatically assigning enctyption information to a group of radios
US5555191A (en) 1994-10-12 1996-09-10 Trustees Of Columbia University In The City Of New York Automated statistical tracker
US5812882A (en) 1994-10-18 1998-09-22 Lanier Worldwide, Inc. Digital dictation system having a central station that includes component cards for interfacing to dictation stations and transcription stations and for processing and storing digitized dictation segments
FR2725982B1 (en) 1994-10-24 1996-12-20 Rhone Poulenc Chimie PROCESS FOR THE PREPARATION OF ISOVANILLIN
US5845061A (en) 1994-10-31 1998-12-01 Hitachi, Ltd. Redundant client server system
US5786994A (en) 1994-11-23 1998-07-28 Imation Corp. Performance monitoring system and method for a laser medical imager
US20050086172A1 (en) 1994-11-23 2005-04-21 Contentguard Holdings, Inc. Method, system and device for providing educational content
US5642202A (en) 1994-12-01 1997-06-24 Xerox Corporation Scan image target locator system for calibrating a printing system
US5550957A (en) 1994-12-07 1996-08-27 Lexmark International, Inc. Multiple virtual printer network interface
US5619024A (en) 1994-12-12 1997-04-08 Usa Technologies, Inc. Credit card and bank issued debit card operated system and method for controlling and monitoring access of computer and copy equipment
US5640495A (en) 1994-12-20 1997-06-17 Lexmark International, Inc. Computer-printer interface control for bidirectional/undirectional data communications
US5636333A (en) 1994-12-20 1997-06-03 Lexmark International, Inc. Multi-protocol network interface
US5787278A (en) 1994-12-28 1998-07-28 Pitney Bowes Inc. Method and system for generating and mailing a system performance report, utilizing a report template with predetermined control commands for controlling the printer
US5677775A (en) 1994-12-29 1997-10-14 Minolta Co., Ltd. Image forming apparatus provided with a device for controlling communication with a central supervisory apparatus
US6792337B2 (en) * 1994-12-30 2004-09-14 Power Measurement Ltd. Method and system for master slave protocol communication in an intelligent electronic device
US5764918A (en) 1995-01-23 1998-06-09 Poulter; Vernon C. Communications node for transmitting data files over telephone networks
US6119934A (en) 1995-01-31 2000-09-19 Usa Technologies, Inc. Credit card, smart card and bank issued debit card operated system and method for processing electronic transactions
US5699494A (en) 1995-02-24 1997-12-16 Lexmark International, Inc. Remote replication of printer operator panel
US5673190A (en) 1995-03-22 1997-09-30 Atrix International, Inc. Multipurpose remote office machine management system
US5727135A (en) 1995-03-23 1998-03-10 Lexmark International, Inc. Multiple printer status information indication
US5798738A (en) 1995-03-25 1998-08-25 Ricoh Company, Ltd. Printing manager system for a copier in a network
US5905906A (en) 1995-03-31 1999-05-18 Lexmark International, Inc. Method and apparatus for configuring multiple printers on a network
US5659794A (en) 1995-03-31 1997-08-19 Unisys Corporation System architecture for improved network input/output processing
US5790793A (en) 1995-04-04 1998-08-04 Higley; Thomas Method and system to create, transmit, receive and process information, including an address to further information
US5517491A (en) 1995-05-03 1996-05-14 Motorola, Inc. Method and apparatus for controlling frequency deviation of a portable transceiver
GB2305819B (en) 1995-06-05 1997-11-05 Ricoh Kk Method and system for diagnosis and control of machines using connection and connectionless modes of communication
US5745268A (en) 1995-06-07 1998-04-28 Toshiba America Medical Systems, Inc. Vascular portable assistant computer system
US6487513B1 (en) 1995-06-07 2002-11-26 Toshiba America Medical Systems, Inc. Diagnostic test unit network and system
JPH0990826A (en) 1995-09-28 1997-04-04 Mita Ind Co Ltd Maintenance control device for image forming equipment
JPH0990825A (en) 1995-09-28 1997-04-04 Mita Ind Co Ltd Image forming device
US6081623A (en) 1995-10-11 2000-06-27 Citrix Systems, Inc. Method for lossless bandwidth compression of a series of glyphs
US5826027A (en) 1995-10-11 1998-10-20 Citrix Systems, Inc. Method for supporting an extensible and dynamically bindable protocol stack in a distrubited process system
US5913060A (en) 1995-10-11 1999-06-15 Citrix Systems, Inc. Method for deadlock avoidance in a distributed process system using a synchronous procedure call
JP3146237B2 (en) 1995-11-10 2001-03-12 キヤノン株式会社 Image forming device
US6437803B1 (en) 1998-05-29 2002-08-20 Citrix Systems, Inc. System and method for combining local and remote windows into a single desktop environment
US6950991B2 (en) 1995-11-13 2005-09-27 Citrix Systems, Inc. Interacting with software applications displayed in a web page
US6370552B1 (en) 1997-05-14 2002-04-09 Citrix Systems, Inc. Apparatus and method for displaying application output in an HTML document
US7555529B2 (en) 1995-11-13 2009-06-30 Citrix Systems, Inc. Interacting with software applications displayed in a web page
US5787149A (en) 1995-11-16 1998-07-28 Equitrac Corporation Method and apparatus for managing remotely located document producing machines by using cellular radios
US5694528A (en) 1995-11-22 1997-12-02 Xerox Corporation Apparatus and method for diagnosing printing machine operation with facsimile transmitted dialog screens
JPH09146880A (en) 1995-11-29 1997-06-06 Mita Ind Co Ltd Equipment management system
US6003061A (en) 1995-12-07 1999-12-14 Microsoft Corporation Method and system for scheduling the use of a computer system resource using a resource planner and a resource provider
JPH09163008A (en) 1995-12-08 1997-06-20 Toyo Kanetsu Kk Remote maintenance device
US5845230A (en) 1996-01-30 1998-12-01 Skf Condition Monitoring Apparatus and method for the remote monitoring of machine condition
US5736965A (en) 1996-02-07 1998-04-07 Lutron Electronics Co. Inc. Compact radio frequency transmitting and receiving antenna and control device employing same
US5774052A (en) 1996-02-08 1998-06-30 Pacific Bank Technology, Inc. Monitoring and alerting system for buildings
US6209048B1 (en) 1996-02-09 2001-03-27 Ricoh Company, Ltd. Peripheral with integrated HTTP server for remote access using URL's
US6324576B1 (en) * 1996-02-15 2001-11-27 Telefonaktiebolaget Lm Ericsson (Publ) Management interworking unit and a method for producing such a unit
US6377971B1 (en) 1996-02-23 2002-04-23 Citrix Systems, Inc. Method and apparatus for installing and executing a single user task in a multi-user environment
AUPN828396A0 (en) 1996-02-23 1996-03-14 Queensland Rail Remote monitoring system
US6167432A (en) 1996-02-29 2000-12-26 Webex Communications, Inc., Method for creating peer-to-peer connections over an interconnected network to facilitate conferencing among users
US5752917A (en) 1996-03-19 1998-05-19 Siemens Medical Systems, Inc. Network connectivity for a portable patient monitor
US5748892A (en) 1996-03-25 1998-05-05 Citrix Systems, Inc. Method and apparatus for client managed flow control on a limited memory computer system
US5968116A (en) 1996-03-27 1999-10-19 Intel Corporation Method and apparatus for facilitating the management of networked devices
US6098116A (en) 1996-04-12 2000-08-01 Fisher-Rosemont Systems, Inc. Process control system including a method and apparatus for automatically sensing the connection of devices to a network
US6049671A (en) 1996-04-18 2000-04-11 Microsoft Corporation Method for identifying and obtaining computer software from a network computer
DE19615694C1 (en) 1996-04-19 1997-07-03 Siemens Ag Piezo-actuator based on monolithic multi-layer structure
US6560656B1 (en) 1998-02-26 2003-05-06 Sun Microsystems, Inc. Apparatus and method for providing downloadable code for use in communicating with a device in a distributed system
JPH09305407A (en) 1996-05-10 1997-11-28 Ricoh Co Ltd Communication system
US6246485B1 (en) 1996-05-23 2001-06-12 Lexmark International, Inc. Printer communication system and method
US6940405B2 (en) 1996-05-30 2005-09-06 Guardit Technologies Llc Portable motion detector and alarm system and method
US5805442A (en) 1996-05-30 1998-09-08 Control Technology Corporation Distributed interface architecture for programmable industrial control systems
US5835724A (en) * 1996-07-03 1998-11-10 Electronic Data Systems Corporation System and method for communication information using the internet that receives and maintains information concerning the client and generates and conveys the session data to the client
GB9616783D0 (en) 1996-08-09 1996-09-25 Apm Ltd Method and apparatus
US5772585A (en) 1996-08-30 1998-06-30 Emc, Inc System and method for managing patient medical records
US5880677A (en) 1996-10-15 1999-03-09 Lestician; Guy J. System for monitoring and controlling electrical consumption, including transceiver communicator control apparatus and alternating current control apparatus
US5956487A (en) 1996-10-25 1999-09-21 Hewlett-Packard Company Embedding web access mechanism in an appliance for user interface functions including a web server and web browser
JPH10145569A (en) 1996-11-07 1998-05-29 Minolta Co Ltd Image forming device management system
WO1998020439A1 (en) 1996-11-08 1998-05-14 Roman Linda L System for providing comprehensive health care and support
US6003078A (en) 1996-11-15 1999-12-14 Canon Information Systems, Inc. Automatic service requests over the world wide web
US5901286A (en) 1996-11-15 1999-05-04 Canon Information Systems, Inc. Method and apparatus for communicating with a network peripheral
US5970149A (en) 1996-11-19 1999-10-19 Johnson; R. Brent Combined remote access and security system
US7266526B1 (en) 1996-11-27 2007-09-04 Diebold, Incorporated Automated banking machine system with multiple browsers
US6139177A (en) 1996-12-03 2000-10-31 Hewlett Packard Company Device access and control using embedded web access functionality
US5822221A (en) 1996-12-04 1998-10-13 Groenteman; Frank S. Office machine monitoring device
US6009274A (en) 1996-12-13 1999-12-28 3Com Corporation Method and apparatus for automatically updating software components on end systems over a network
JPH10190922A (en) 1996-12-19 1998-07-21 Hitachi Telecom Technol Ltd Facsimile adaptor remote maintenance equipment
US5801964A (en) 1997-01-08 1998-09-01 Mccarthy; Harold Electronic monitoring apparatus for cyclic machines
AU6043098A (en) 1997-01-27 1998-08-18 Dsc Telecom L.P. System and method for monitoring and management of telecommunications equipment using enhanced internet access
JP3094934B2 (en) 1997-01-31 2000-10-03 日本電気株式会社 Remote maintenance diagnosis method
US5790977A (en) 1997-02-06 1998-08-04 Hewlett-Packard Company Data acquisition from a remote instrument via the internet
US6108492A (en) 1997-02-14 2000-08-22 Toshiba America Information Systems Remote monitoring system
US6003070A (en) 1997-02-25 1999-12-14 Intervvoice Limited Partnership E-mail system and interface for equipment monitoring and control
AU6443698A (en) 1997-03-03 1998-09-22 Quinton Instrument Company Open architecture cardiology information system
US5923842A (en) 1997-03-06 1999-07-13 Citrix Systems, Inc. Method and apparatus for simultaneously providing anonymous user login for multiple users
US6256613B1 (en) 1997-03-14 2001-07-03 Health Resources And Technology Inc. Medical consultation management system
US6446153B2 (en) 1997-03-14 2002-09-03 Intel Corporation Shared embedded microcontroller interface
JPH10268712A (en) 1997-03-26 1998-10-09 Ricoh Co Ltd Image forming device control system
US6307570B1 (en) 1997-03-31 2001-10-23 Citrix Systems, Inc. Virtual input device
US6260148B1 (en) 1997-04-04 2001-07-10 Microsoft Corporation Methods and systems for message forwarding and property notifications using electronic subscriptions
US6041041A (en) 1997-04-15 2000-03-21 Ramanathan; Srinivas Method and system for managing data service systems
US5974234A (en) 1997-04-15 1999-10-26 Xerox Corporation Centralized print server for interfacing one or more network clients with a plurality of printing devices
US6161145A (en) 1997-05-08 2000-12-12 International Business Machines Corporation Updating server-related data at a client
US5961586A (en) 1997-05-14 1999-10-05 Citrix Systems, Inc. System and method for remotely executing an interpretive language application
US6157944A (en) 1997-05-14 2000-12-05 Citrix Systems, Inc. System and method for replicating a client/server data exchange to additional client notes connecting to the server
JPH10319802A (en) 1997-05-16 1998-12-04 Minolta Co Ltd Copying device
US6553490B1 (en) 1997-06-30 2003-04-22 Sun Microsystems, Inc. Computer system including local computer with capability to automatically update operating system or application program from network server
JPH1145195A (en) 1997-07-28 1999-02-16 N T T Data:Kk Computer system, abnormality detector and recording medium
US5956698A (en) 1997-07-31 1999-09-21 Xerox Corporation Information broker for printing system
US5991810A (en) 1997-08-01 1999-11-23 Novell, Inc. User name authentication for gateway clients accessing a proxy cache server
US6042111A (en) 1997-08-18 2000-03-28 Xerox Corporation Method and apparatus for detecting slip in a sheet transport system
US6304895B1 (en) 1997-08-22 2001-10-16 Apex Inc. Method and system for intelligently controlling a remotely located computer
US6115489A (en) 1997-09-02 2000-09-05 General Electric Company System and method for performing image-based diagnosis
US6282454B1 (en) 1997-09-10 2001-08-28 Schneider Automation Inc. Web interface to a programmable controller
US6308206B1 (en) 1997-09-17 2001-10-23 Hewlett-Packard Company Internet enabled computer system management
US6453127B2 (en) 1997-09-26 2002-09-17 Nexpress Solutions Llc Establishment at a remote location of an internet/intranet user interface to a copier/printer
CA2306704A1 (en) 1997-10-16 1999-04-29 John Slaby An apparatus and method for controlling access to a service over a communications system
US6298457B1 (en) 1997-10-17 2001-10-02 International Business Machines Corporation Non-invasive networked-based customer support
US6457066B1 (en) 1997-11-10 2002-09-24 Microsoft Corporation Simple object access protocol
EP0917119A3 (en) 1997-11-12 2001-01-10 Citicorp Development Center, Inc. Distributed network based electronic wallet
US6415392B1 (en) 1997-12-08 2002-07-02 Ricoh Company, Ltd. Remote diagnosis system and method
JPH11203079A (en) 1998-01-09 1999-07-30 Casio Electron Mfg Co Ltd Printing system
US6088718A (en) 1998-01-15 2000-07-11 Microsoft Corporation Methods and apparatus for using resource transition probability models for pre-fetching resources
JP3488617B2 (en) 1998-02-10 2004-01-19 シャープ株式会社 Remote fault management system using the Internet
US6101407A (en) 1998-02-13 2000-08-08 Eastman Kodak Company Method and system for remotely viewing and configuring output from a medical imaging device
US6295527B1 (en) 1998-02-13 2001-09-25 Cisco Technology, Inc. Real-time user-defined creation of network device information collections
JPH11238043A (en) 1998-02-20 1999-08-31 Fujitsu Ltd Host data association device for equipment management
US6457038B1 (en) 1998-03-19 2002-09-24 Isochron Data Corporation Wide area network operation's center that sends and receives data from vending machines
US7028312B1 (en) 1998-03-23 2006-04-11 Webmethods XML remote procedure call (XML-RPC)
EP1073957B1 (en) 1998-03-23 2003-05-21 Microsoft Corporation Application program interfaces in an operating system
US6125363A (en) 1998-03-30 2000-09-26 Buzzeo; Eugene Distributed, multi-user, multi-threaded application development method
JP3604898B2 (en) 1998-03-31 2004-12-22 キヤノン株式会社 Network device management apparatus and method, recording medium
JPH11296453A (en) 1998-04-13 1999-10-29 Ddi Corp Downloading method
AU3878699A (en) 1998-05-04 1999-11-23 Intermec Ip Corporation Automatic data collection device having a network communications capability
US6549612B2 (en) 1998-05-06 2003-04-15 Telecommunications Premium Services, Inc. Unified communication services via e-mail
EP1084576B1 (en) 1998-05-07 2005-07-27 Samsung Electronics Co., Ltd. Method and apparatus for universally accessible command and control information in a network
US6054987A (en) 1998-05-29 2000-04-25 Hewlett-Packard Company Method of dynamically creating nodal views of a managed network
US6289461B1 (en) 1998-06-09 2001-09-11 Placeware, Inc. Bi-directional process-to-process byte stream protocol
US6167448A (en) 1998-06-11 2000-12-26 Compaq Computer Corporation Management event notification system using event notification messages written using a markup language
US6437692B1 (en) 1998-06-22 2002-08-20 Statsignal Systems, Inc. System and method for monitoring and controlling remote devices
US6449663B1 (en) 1998-07-08 2002-09-10 International Business Machines Corporation Method and apparatus for adjusting an interval of polling a network printer based on changes in working status of the network printer
US6205466B1 (en) 1998-07-17 2001-03-20 Hewlett-Packard Company Infrastructure for an open digital services marketplace
US6338149B1 (en) 1998-07-31 2002-01-08 Westinghouse Electric Company Llc Change monitoring system for a computer system
US6471521B1 (en) 1998-07-31 2002-10-29 Athenium, L.L.C. System for implementing collaborative training and online learning over a computer network and related techniques
US6286038B1 (en) 1998-08-03 2001-09-04 Nortel Networks Limited Method and apparatus for remotely configuring a network device
US7769620B1 (en) 1998-09-01 2010-08-03 Dennis Fernandez Adaptive direct transaction for networked client group
US6226650B1 (en) 1998-09-17 2001-05-01 Synchrologic, Inc. Database synchronization and organization system and method
US6317848B1 (en) 1998-09-24 2001-11-13 Xerox Corporation System for tracking and automatically communicating printer failures and usage profile aspects
US6636899B1 (en) 1998-09-24 2003-10-21 Xerox Corporation Architecture for software for remote maintenance of a machine such as a copier
JP2000112863A (en) 1998-10-05 2000-04-21 Canon Inc Information processing system, peripheral device, its initializing method, and storage medium
US6560611B1 (en) 1998-10-13 2003-05-06 Netarx, Inc. Method, apparatus, and article of manufacture for a network monitoring system
JP2000122952A (en) 1998-10-16 2000-04-28 Fuji Xerox Co Ltd Information processor
JP3935276B2 (en) 1998-10-21 2007-06-20 キヤノン株式会社 Network device management method, apparatus, storage medium, and transmission apparatus
ATE273538T1 (en) 1998-10-28 2004-08-15 Verticalone Corp APPARATUS AND METHOD FOR AUTOMATIC AGGREGATION AND SUPPLY OF ELECTRONIC PERSONAL INFORMATION OR DATA
US6799270B1 (en) 1998-10-30 2004-09-28 Citrix Systems, Inc. System and method for secure distribution of digital information to a chain of computer system nodes in a network
US6308099B1 (en) 1998-11-13 2001-10-23 Intermedics Inc. Implantable device and programmer system which permits multiple programmers
JP3537332B2 (en) 1998-11-18 2004-06-14 理想科学工業株式会社 Interface device
US6381557B1 (en) 1998-11-25 2002-04-30 Ge Medical Systems Global Technology Company, Llc Medical imaging system service evaluation method and apparatus
US6377162B1 (en) 1998-11-25 2002-04-23 Ge Medical Systems Global Technology Company, Llc Medical diagnostic field service method and apparatus
US6434572B2 (en) 1998-11-25 2002-08-13 Ge Medical Technology Services, Inc. Medical diagnostic system management method and apparatus
US6598011B1 (en) 1998-11-25 2003-07-22 Ianne Mae Howards Koritzinsky Medical diagnostic system services interface
JP2000163283A (en) 1998-11-30 2000-06-16 Kobelco Systems Corp Remote site computer monitor system
JP2000194583A (en) 1998-12-25 2000-07-14 Nissin Electric Co Ltd Monitor and control system and recording medium where program thereof is recorded
US6928469B1 (en) 1998-12-29 2005-08-09 Citrix Systems, Inc. Apparatus and method for determining a program neighborhood for a client node in a client-server network using markup language techniques
US6643690B2 (en) 1998-12-29 2003-11-04 Citrix Systems, Inc. Apparatus and method for determining a program neighborhood for a client node in a client-server network
US6060994A (en) 1999-01-20 2000-05-09 Tempa Communication Inc. Method for controlling united home security system
US6415023B2 (en) 1999-01-22 2002-07-02 Pointset Corporation Method and apparatus for setting programmable features of an appliance
US6256378B1 (en) 1999-01-22 2001-07-03 Pointset Corporation Method and apparatus for setting programmable features of an appliance
JP2000210800A (en) 1999-01-27 2000-08-02 Komatsu Ltd Method for monitoring industrial machine and device therefor
US6356949B1 (en) 1999-01-29 2002-03-12 Intermec Ip Corp. Automatic data collection device that receives data output instruction from data consumer
US6327594B1 (en) 1999-01-29 2001-12-04 International Business Machines Corporation Methods for shared data management in a pervasive computing environment
US6591272B1 (en) 1999-02-25 2003-07-08 Tricoron Networks, Inc. Method and apparatus to make and transmit objects from a database on a server computer to a client computer
US6397212B1 (en) 1999-03-04 2002-05-28 Peter Biffar Self-learning and self-personalizing knowledge search engine that delivers holistic results
US6426798B1 (en) 1999-03-04 2002-07-30 Canon Kabushiki Kaisha Data structure for printer description file
US6646655B1 (en) 1999-03-09 2003-11-11 Webex Communications, Inc. Extracting a time-sequence of slides from video
JP2000270384A (en) 1999-03-12 2000-09-29 Omron Corp Sensor, controller and sensor system
US6370436B1 (en) 1999-03-26 2002-04-09 Emware, Inc. Distributed objects for a computer system
JP4017282B2 (en) 1999-03-29 2007-12-05 日立造船株式会社 Operation monitoring device and remote monitoring system
JP3645443B2 (en) 1999-03-30 2005-05-11 株式会社リコー Remote image forming apparatus management system, monitoring terminal apparatus and control method
JP3834452B2 (en) 1999-04-01 2006-10-18 セイコーエプソン株式会社 Device management system, management server, and computer-readable recording medium
US7844492B2 (en) 1999-11-17 2010-11-30 Ipf, Inc. Internet-based E-commerce network for enabling commission-based E-commerce transactions along the fabric of the world wide web (WWW) using server-side driven multi-mode virtual kiosks (MMVKS) and transaction and commission tracking servers
JP2000309145A (en) 1999-04-28 2000-11-07 Ricoh Co Ltd Control method for image forming apparatus
US6421671B1 (en) 1999-04-30 2002-07-16 Dell Products L.P. Method and system for automated distribution of software
AU5289100A (en) 1999-05-24 2000-12-12 Heat Timer Corporation Electronic message delivery system utilizable in the monitoring oe remote equipment and method of same
US6370582B1 (en) 1999-05-28 2002-04-09 Adc Technologies International Pte Ltd. Method and system for providing cross-platform remote control, monitoring, and up-dating of a facility access controller
US6312378B1 (en) 1999-06-03 2001-11-06 Cardiac Intelligence Corporation System and method for automated collection and analysis of patient information retrieved from an implantable medical device for remote patient care
US6446192B1 (en) 1999-06-04 2002-09-03 Embrace Networks, Inc. Remote monitoring and control of equipment over computer networks using a single web interfacing chip
US6725281B1 (en) 1999-06-11 2004-04-20 Microsoft Corporation Synchronization of controlled device state using state table and eventing in data-driven remote device control model
WO2000078001A2 (en) 1999-06-11 2000-12-21 Microsoft Corporation General api for remote control of devices
US6594700B1 (en) * 1999-06-14 2003-07-15 International Business Machines Corporation System and method for implementing a universal service broker interchange mechanism
US6553336B1 (en) 1999-06-25 2003-04-22 Telemonitor, Inc. Smart remote monitoring system and method
US6381712B1 (en) 1999-06-30 2002-04-30 Sun Microsystems, Inc. Method and apparatus for providing an error messaging system
JP3805951B2 (en) 1999-07-01 2006-08-09 株式会社リコー Image forming apparatus management system and management method
US6754664B1 (en) 1999-07-02 2004-06-22 Microsoft Corporation Schema-based computer system health monitoring
US6405310B1 (en) 1999-07-09 2002-06-11 Hewlett-Packard Company System and method for peripheral system management using operation object interfaces for device control
US20010027439A1 (en) 1999-07-16 2001-10-04 Holtzman Henry N. Method and system for computerized form completion
US6538667B1 (en) 1999-07-23 2003-03-25 Citrix Systems, Inc. System and method for providing immediate visual response to user input at a client system connected to a computer system by a high-latency connection
US6221011B1 (en) 1999-07-26 2001-04-24 Cardiac Intelligence Corporation System and method for determining a reference baseline of individual patient status for use in an automated collection and analysis patient care system
US6449633B1 (en) 1999-07-26 2002-09-10 Microsoft Corporation Access source control of resources within standard request-response protocols
US6282711B1 (en) 1999-08-10 2001-08-28 Hewlett-Packard Company Method for more efficiently installing software components from a remote server source
US6574729B1 (en) 1999-08-26 2003-06-03 Lucent Technologies Inc. System for remotely identifying and providing information of unknown software on remote network node by comparing the unknown software with software audit file maintained on server
US6972676B1 (en) 1999-09-01 2005-12-06 Nettalon Security Systems, Inc. Method and apparatus for remotely monitoring a site
US6494831B1 (en) 1999-09-03 2002-12-17 Ge Medical Technology Services, Inc. Medical diagnostic system service connectivity method and apparatus
US6711618B1 (en) 1999-09-03 2004-03-23 Cisco Technology, Inc. Apparatus and method for providing server state and attribute management for voice enabled web applications
US6356933B2 (en) 1999-09-07 2002-03-12 Citrix Systems, Inc. Methods and apparatus for efficiently transmitting interactive application data between a client and a server using markup language
US6559965B1 (en) 1999-09-09 2003-05-06 Hewlett-Packard Company Method and apparatus for establishing two-way communication with a remote printer
US6493871B1 (en) 1999-09-16 2002-12-10 Microsoft Corporation Method and system for downloading updates for software installation
US6834298B1 (en) 1999-09-21 2004-12-21 Siemens Information And Communication Networks, Inc. System and method for network auto-discovery and configuration
EP1087575A1 (en) * 1999-09-24 2001-03-28 BRITISH TELECOMMUNICATIONS public limited company Packet network interfacing
US6442433B1 (en) 1999-10-26 2002-08-27 Medtronic, Inc. Apparatus and method for remote troubleshooting, maintenance and upgrade of implantable device systems
US6230199B1 (en) 1999-10-29 2001-05-08 Mcafee.Com, Inc. Active marketing based on client computer configurations
US6710893B1 (en) 1999-11-02 2004-03-23 Ricoh Co., Ltd. Automated system and method of testing a facsimile machine
US6581094B1 (en) 1999-11-02 2003-06-17 Sun Microsystems, Inc. Apparatus and method for identifying a digital device based on the device's uniform device descriptor file that specifies the attributes of the device in a XML document in a networked environment
US6406426B1 (en) 1999-11-03 2002-06-18 Criticare Systems Medical monitoring and alert system for use with therapeutic devices
US6609108B1 (en) 1999-11-05 2003-08-19 Ford Motor Company Communication schema of online system and method of ordering consumer product having specific configurations
US7103357B2 (en) 1999-11-05 2006-09-05 Lightsurf Technologies, Inc. Media spooler system and methodology providing efficient transmission of media content from wireless devices
US6654726B1 (en) 1999-11-05 2003-11-25 Ford Motor Company Communication schema of online system and method of status inquiry and tracking related to orders for consumer product having specific configurations
US6785015B1 (en) 1999-11-12 2004-08-31 Hewlett-Packard Development Company, L.P. System and method for monitoring a computer system process or peripheral
US6368284B1 (en) 1999-11-16 2002-04-09 Cardiac Intelligence Corporation Automated collection and analysis patient care system and method for diagnosing and monitoring myocardial ischemia and outcomes thereof
US6789119B1 (en) 1999-11-24 2004-09-07 Webex Communication, Inc. Emulating a persistent connection using http
JP4104799B2 (en) 1999-11-25 2008-06-18 株式会社山武 Network system and communication method
US6325540B1 (en) 1999-11-29 2001-12-04 General Electric Company Method and apparatus for remotely configuring and servicing a field replaceable unit in a medical diagnostic system
US6665425B1 (en) 1999-12-16 2003-12-16 Xerox Corporation Systems and methods for automated image quality based diagnostics and remediation of document processing systems
US6467084B1 (en) 1999-12-16 2002-10-15 Emware, Inc. Systems and methods for reprogramming an embedded device with program code using relocatable program code
JP4083360B2 (en) 1999-12-20 2008-04-30 エスアイアイ・ナノテクノロジー株式会社 Thermal analyzer
US6654032B1 (en) 1999-12-23 2003-11-25 Webex Communications, Inc. Instant sharing of documents on a remote server
JP4365019B2 (en) 1999-12-28 2009-11-18 株式会社リコー Customer support system, customer support method, customer support center, customer information utilization system, and equipment arranged at customer
US6598083B1 (en) 1999-12-30 2003-07-22 Intel Corporation System and method for communicating over a non-continuous connection with a device on a network
US20010025377A1 (en) 1999-12-30 2001-09-27 Hinderks Larry W. High bandwidth transmission system and method having local insertion, delay play and demand play
AU2001243270A1 (en) 2000-02-25 2001-09-03 Saba Software, Inc. Method for enterprise workforce planning
US6249281B1 (en) 2000-02-28 2001-06-19 Presenter.Com On-demand presentation graphical user interface
CA2299824C (en) 2000-03-01 2012-02-21 Spicer Corporation Network resource control system
CN1197297C (en) * 2000-03-10 2005-04-13 黎明网络有限公司 A platform information switch
US6651190B1 (en) 2000-03-14 2003-11-18 A. Worley Independent remote computer maintenance device
US6904593B1 (en) 2000-03-24 2005-06-07 Hewlett-Packard Development Company, L.P. Method of administering software components using asynchronous messaging in a multi-platform, multi-programming language environment
US6560641B1 (en) 2000-03-29 2003-05-06 Unisys Corporation System, method, and adapter card for remote console emulation including remote control of a peripheral device
WO2001076146A1 (en) 2000-04-04 2001-10-11 Koninklijke Philips Electronics N.V. Accessing an in home network through the internet
EP1360619A2 (en) 2000-04-07 2003-11-12 The Procter & Gamble Company Method and apparatus for monitoring the effective velocity of items through a store or warehouse
US7032005B2 (en) 2000-04-14 2006-04-18 Slam Dunk Networks, Inc. System for handling information and information transfers in a computer network
US6670810B2 (en) 2000-04-25 2003-12-30 Airak, Inc. System and method for distributed monitoring of surroundings using telemetry of data from remote sensors
CA2378060C (en) 2000-04-27 2007-07-24 Medtronic, Inc. Component architecture for medical device system networks
AU2001261258A1 (en) 2000-05-05 2001-11-20 Aprisma Management Technologies, Inc. Help desk systems and methods for use with communications networks
US6785713B1 (en) 2000-05-08 2004-08-31 Citrix Systems, Inc. Method and apparatus for communicating among a network of servers utilizing a transport mechanism
US6789112B1 (en) 2000-05-08 2004-09-07 Citrix Systems, Inc. Method and apparatus for administering a server having a subsystem in communication with an event channel
US6785726B1 (en) 2000-05-08 2004-08-31 Citrix Systems, Inc. Method and apparatus for delivering local and remote server events in a similar fashion
US6922724B1 (en) 2000-05-08 2005-07-26 Citrix Systems, Inc. Method and apparatus for managing server load
US6643650B1 (en) 2000-05-09 2003-11-04 Sun Microsystems, Inc. Mechanism and apparatus for using messages to look up documents stored in spaces in a distributed computing environment
US20030158897A1 (en) 2000-05-09 2003-08-21 Viryanet Ltd. Networked platform for creating and supporting communities
US6654720B1 (en) 2000-05-09 2003-11-25 International Business Machines Corporation Method and system for voice control enabling device in a service discovery network
US7016966B1 (en) 2000-05-09 2006-03-21 Sun Microsystems, Inc. Generating results gates in a distributed computing environment
US6691106B1 (en) 2000-05-23 2004-02-10 Intel Corporation Profile driven instant web portal
US6799209B1 (en) 2000-05-25 2004-09-28 Citrix Systems, Inc. Activity monitor and resource manager in a network environment
US6751794B1 (en) 2000-05-25 2004-06-15 Everdream Corporation Intelligent patch checker
JP3688186B2 (en) 2000-05-25 2005-08-24 シャープ株式会社 Multifunction device version upgrade device
US20020029285A1 (en) 2000-05-26 2002-03-07 Henry Collins Adapting graphical data, processing activity to changing network conditions
JP2001344129A (en) 2000-05-31 2001-12-14 Yaskawa Electric Corp Remote maintenance system
US20030154284A1 (en) 2000-05-31 2003-08-14 James Bernardin Distributed data propagator
US6738798B1 (en) 2000-06-01 2004-05-18 Ge Medical Technology Services, Inc. Automated monitoring of collection of operational data from medical imaging devices
US6611863B1 (en) 2000-06-05 2003-08-26 Intel Corporation Automatic device assignment through programmable device discovery for policy based network management
US6763501B1 (en) 2000-06-09 2004-07-13 Webex Communications, Inc. Remote document serving
JP2001358867A (en) 2000-06-15 2001-12-26 Murata Mach Ltd Image processor
JP3859591B2 (en) * 2000-06-16 2006-12-20 富士通株式会社 Communication device including VPN accommodation function
US6711593B1 (en) 2000-06-26 2004-03-23 Camstar Systems, Inc. System and method for live update of a manufacturing system
US7113988B2 (en) 2000-06-29 2006-09-26 International Business Machines Corporation Proactive on-line diagnostics in a manageable network
US6804712B1 (en) 2000-06-30 2004-10-12 Cisco Technology, Inc. Identifying link failures in a network
AUPQ849500A0 (en) 2000-06-30 2000-07-27 Canon Kabushiki Kaisha Hash compact xml parser
US6477117B1 (en) 2000-06-30 2002-11-05 International Business Machines Corporation Alarm interface for a smart watch
US6832239B1 (en) 2000-07-07 2004-12-14 International Business Machines Corporation Systems for managing network resources
JP2002027567A (en) 2000-07-12 2002-01-25 Hitachi Kokusai Electric Inc Remote operation system of semiconductor manufacturing apparatus, semiconductor manufacturing apparatus, and remote operation device
US7020773B1 (en) 2000-07-17 2006-03-28 Citrix Systems, Inc. Strong mutual authentication of devices
US6757714B1 (en) 2000-07-28 2004-06-29 Axeda Systems Operating Company, Inc. Reporting the state of an apparatus to a remote computer
US7315830B1 (en) * 2000-08-11 2008-01-01 Nexus Company, Ltd. Method, system and computer program product for ordering merchandise in a global computer network environment
WO2002015519A2 (en) 2000-08-17 2002-02-21 Mobileum, Inc. Method and system for wireless voice channel/data channel integration
US7032002B1 (en) 2000-09-06 2006-04-18 Xanboo, Inc. Service broker for processing data from a data network
WO2002021239A2 (en) 2000-09-06 2002-03-14 Xanboo, Inc. Adaptively controlled resource and method for controlling the behavior of same
US7080046B1 (en) 2000-09-06 2006-07-18 Xanboo, Inc. Method for amortizing authentication overhead
US6621827B1 (en) 2000-09-06 2003-09-16 Xanboo, Inc. Adaptive method for polling
US6479792B1 (en) 2000-09-06 2002-11-12 Illinois Tool Works Inc. Welding machine, system and method therefor
EP1189159A1 (en) 2000-09-19 2002-03-20 Niels Mache System for processing like-kind exchange transactions
US8108543B2 (en) 2000-09-22 2012-01-31 Axeda Corporation Retrieving data from a server
US7194526B2 (en) 2000-09-22 2007-03-20 Kyocera Corporation Network device management method, and network devices
US7185014B1 (en) 2000-09-22 2007-02-27 Axeda Corporation Retrieving data from a server
US6651110B1 (en) 2000-09-28 2003-11-18 Rockwell Automation Technologies, Inc. Configurable object for industrial control and monitoring networks
US6886038B1 (en) 2000-10-24 2005-04-26 Microsoft Corporation System and method for restricting data transfers and managing software components of distributed computers
US7003574B1 (en) * 2000-11-01 2006-02-21 Microsoft Corporation Session load balancing and use of VIP as source address for inter-cluster traffic through the use of a session identifier
US7051084B1 (en) 2000-11-02 2006-05-23 Citrix Systems, Inc. Methods and apparatus for regenerating and transmitting a partial page
US7346842B1 (en) 2000-11-02 2008-03-18 Citrix Systems, Inc. Methods and apparatus for incorporating a partial page on a client
US6766333B1 (en) 2000-11-08 2004-07-20 Citrix Systems, Inc. Method and apparatus for synchronizing a user interface element displayed on a client and a software application component executing on a web server
US6317570B1 (en) 2000-11-09 2001-11-13 Ricoh Company, Ltd. Field service system for image forming devices
US20020059489A1 (en) 2000-11-14 2002-05-16 Davis Ray Charles Remote printing
US6832373B2 (en) 2000-11-17 2004-12-14 Bitfone Corporation System and method for updating and distributing information
US7149792B1 (en) 2000-11-20 2006-12-12 Axeda Corporation Device registration mechanism
US7290061B2 (en) 2000-12-05 2007-10-30 Citrix Systems, Inc. System and method for internet content collaboration
US7197513B2 (en) 2000-12-08 2007-03-27 Aol Llc Distributed image storage architecture
US7194743B2 (en) 2000-12-12 2007-03-20 Citrix Systems, Inc. Methods and apparatus for communicating changes between a user interface and an executing application using property paths
JP2002182866A (en) 2000-12-13 2002-06-28 Fujitsu Ltd Printing control method in network environment, print server, client, and storage medium
US6823397B2 (en) 2000-12-18 2004-11-23 International Business Machines Corporation Simple liveness protocol using programmable network interface cards
US6567813B1 (en) 2000-12-29 2003-05-20 Webex Communications, Inc. Quality of service maintenance for distributed collaborative computing
US7069298B2 (en) 2000-12-29 2006-06-27 Webex Communications, Inc. Fault-tolerant distributed system for collaborative computing
US6925645B2 (en) 2000-12-29 2005-08-02 Webex Communications, Inc. Fault tolerant server architecture for collaborative computing
US6901448B2 (en) 2000-12-29 2005-05-31 Webex Communications, Inc. Secure communications system for collaborative computing
US7203755B2 (en) 2000-12-29 2007-04-10 Webex—Communications, Inc. System and method for application sharing in collaborative setting
US7130883B2 (en) 2000-12-29 2006-10-31 Webex Communications, Inc. Distributed network system architecture for collaborative computing
US7215777B2 (en) 2001-01-16 2007-05-08 Microsoft Corporation Sending notification through a firewall over a computer network
DE60235870D1 (en) 2001-01-26 2010-05-20 Microsoft Corp METHOD AND DEVICE FOR AUTOMATICALLY DETERMINING A SUITABLE TRANSMISSION PROCESS IN A NETWORK
US7461377B2 (en) 2001-02-22 2008-12-02 Electronics For Imaging, Inc. Method and apparatus for automatically managing capabilities in a virtual printer group
US7085824B2 (en) 2001-02-23 2006-08-01 Power Measurement Ltd. Systems for in the field configuration of intelligent electronic devices
US6725219B2 (en) 2001-03-13 2004-04-20 Seiko Epson Corporation Internet presentation system
US20020078135A1 (en) * 2001-03-15 2002-06-20 Ibm Corporation Method and apparatus for improving the operation of an application layer proxy
US20020133753A1 (en) 2001-03-19 2002-09-19 Thomas Mayberry Component/Web services Tracking
JP2002278906A (en) 2001-03-21 2002-09-27 Nec Corp Update managing system, update client device, update server device and program
US6453129B1 (en) 2001-03-23 2002-09-17 Hewlett-Packard Company System and method for providing job assurance
US20020178241A1 (en) 2001-04-03 2002-11-28 Par Eriksson Framework for a dynamic management system
US7089567B2 (en) 2001-04-09 2006-08-08 International Business Machines Corporation Efficient RPC mechanism using XML
US20020157090A1 (en) 2001-04-20 2002-10-24 Anton, Jr. Francis M. Automated updating of access points in a distributed network
US7031342B2 (en) 2001-05-15 2006-04-18 Webex Communications, Inc. Aligning data packets/frames for transmission over a network channel
US6810488B2 (en) 2001-05-22 2004-10-26 Webex Communications, Inc. Adaptive selective retransmission of packets
US7072946B2 (en) 2001-05-31 2006-07-04 Juniper Networks, Inc. Network router management interface with API invoked via login stream
US6816616B2 (en) 2001-05-31 2004-11-09 Webex Communications, Inc. Header compression for image data stream
US7100200B2 (en) 2001-06-13 2006-08-29 Citrix Systems, Inc. Method and apparatus for transmitting authentication credentials of a user across communication sessions
US7562146B2 (en) 2003-10-10 2009-07-14 Citrix Systems, Inc. Encapsulating protocol for session persistence and reliability
US20050198379A1 (en) 2001-06-13 2005-09-08 Citrix Systems, Inc. Automatically reconnecting a client across reliable and persistent communication sessions
US6671695B2 (en) 2001-06-18 2003-12-30 The Procter & Gamble Company Dynamic group generation and management
US6886046B2 (en) 2001-06-26 2005-04-26 Citrix Systems, Inc. Methods and apparatus for extendible information aggregation and presentation
CN1194316C (en) 2001-06-28 2005-03-23 华为技术有限公司 Remote network monitor method for computer network
US6925335B2 (en) 2001-07-05 2005-08-02 Isochron, Llc Real-time alert mechanism for monitoring and controlling field assets via wireless and internet technologies
US7043677B1 (en) 2001-07-19 2006-05-09 Webex Communications, Inc. Apparatus and method for separating corrupted data from non-corrupted data within a packet
US7774492B2 (en) 2001-07-26 2010-08-10 Citrix Systems, Inc. System, method and computer program product to maximize server throughput while avoiding server overload by controlling the rate of establishing server-side net work connections
WO2003021464A2 (en) 2001-09-05 2003-03-13 Rubenstein, Allen, I. Secure remote access between peers
US6493517B1 (en) 2001-09-10 2002-12-10 Hewlett-Packard Company Integration of self-determined consumable usage model in pigmentation material low/out forecast
US7216172B2 (en) 2001-09-25 2007-05-08 Webex Communications, Inc. Systems and methods for establishing quasi-persistent HTTP connections
US7065576B2 (en) 2001-09-27 2006-06-20 Matsushita Electric Industrial Co., Ltd. Dynamic multicast grouping for vehicles and other mobile objects
US7321437B2 (en) 2001-09-28 2008-01-22 Hewlett-Packard Development Company, L.P. E-mail to job retention
US7330872B2 (en) 2001-10-02 2008-02-12 Citrix Systems, Inc. Method for distributed program execution with web-based file-type association
US6952714B2 (en) 2001-10-02 2005-10-04 Citrix Systems, Inc. Method for distributed program execution with server-based file type association
US7117243B2 (en) 2001-10-02 2006-10-03 Citrix Systems, Inc. Methods for distributed program execution with file-type association in a client-server network
US7000238B2 (en) 2001-10-10 2006-02-14 Borland Software Corporation Development system providing extensible remoting architecture
US6757899B2 (en) 2001-10-11 2004-06-29 Harris Corporation Dynamic CORBA gateway for CORBA and non-CORBA clients and services
US20030072027A1 (en) 2001-10-11 2003-04-17 Haines Robert E. Unique identifier for customer account and method
JP2003140991A (en) 2001-10-31 2003-05-16 Ntt Power & Building Facilities Inc Remote monitoring system and communication method for the system
US9332058B2 (en) 2001-11-01 2016-05-03 Benhov Gmbh, Llc Local agent for remote file access system
US7254601B2 (en) 2001-12-20 2007-08-07 Questra Corporation Method and apparatus for managing intelligent assets in a distributed environment
JP2003223603A (en) 2002-01-30 2003-08-08 National Maintenance:Kk Centralized control system for preventing office abnormality
US20030158919A1 (en) 2002-02-20 2003-08-21 Sun Microsystems, Inc., A Delaware Corporation Method for deploying version control system server software having remote access capability
US7661129B2 (en) * 2002-02-26 2010-02-09 Citrix Systems, Inc. Secure traversal of network components
US7984157B2 (en) 2002-02-26 2011-07-19 Citrix Systems, Inc. Persistent and reliable session securely traversing network components using an encapsulating protocol
GB0204530D0 (en) * 2002-02-27 2002-04-10 Eastman Kodak Co Method and system for client-based adaptive networking system
US20030167223A1 (en) * 2002-03-01 2003-09-04 Financial Fusion, Inc., A Wholly-Owned Subsidiary Of Sybase, Inc. System with methodology for improved transmission of financial information
US6831555B1 (en) 2002-03-05 2004-12-14 Advanced Micro Devices, Inc. Method and apparatus for dynamically monitoring system components in an advanced process control (APC) framework
US7376695B2 (en) 2002-03-14 2008-05-20 Citrix Systems, Inc. Method and system for generating a graphical display for a remote terminal session
US7091846B2 (en) 2002-03-18 2006-08-15 Siemens Communications, Inc. Methods and apparatus for handling information regarding an alarm for a communication network
US20030229785A1 (en) 2002-03-18 2003-12-11 Daseke Michael J. Dynamic hierarchies system and method for thin devices
US7057724B1 (en) 2002-03-21 2006-06-06 Institute Of Critical Care Medicine Particulate info to field units
US7636754B2 (en) 2002-03-21 2009-12-22 Cisco Technology, Inc. Rich multi-media format for use in a collaborative computing system
US7178149B2 (en) 2002-04-17 2007-02-13 Axeda Corporation XML scripting of soap commands
US7146427B2 (en) 2002-04-23 2006-12-05 Lsi Logic Corporation Polling-based mechanism for improved RPC timeout handling
US7506048B1 (en) 2002-06-05 2009-03-17 Ricoh Co. Ltd. Method and system for monitoring network connected devices and displaying device status
US7020706B2 (en) 2002-06-17 2006-03-28 Bmc Software, Inc. Method and system for automatically updating multiple servers
WO2004003724A2 (en) 2002-06-27 2004-01-08 Axeda Systems Operating Company, Inc. Screen sharing
US7080267B2 (en) 2002-08-01 2006-07-18 Texas Instruments Incorporated Methodology for managing power consumption in an application
US20040027376A1 (en) 2002-08-08 2004-02-12 Calder Dale E. Displaying information over multiple user interface (UI) views
US7353253B1 (en) 2002-10-07 2008-04-01 Webex Communicatons, Inc. Peer-to-peer messaging system
US20040260947A1 (en) * 2002-10-21 2004-12-23 Brady Gerard Anthony Methods and systems for analyzing security events
US7542471B2 (en) 2002-10-30 2009-06-02 Citrix Systems, Inc. Method of determining path maximum transmission unit
US7013331B2 (en) 2002-12-20 2006-03-14 Nokia, Inc. Automated bulk configuration of network devices
WO2004059447A2 (en) 2002-12-24 2004-07-15 Simdesk Technologies, Inc. Internet-based messaging system
US7523184B2 (en) 2002-12-31 2009-04-21 Time Warner Cable, Inc. System and method for synchronizing the configuration of distributed network management applications
US7305481B2 (en) * 2003-01-07 2007-12-04 Hexago Inc. Connecting IPv6 devices through IPv4 network and network address translator (NAT) using tunnel setup protocol
US20040260801A1 (en) 2003-02-12 2004-12-23 Actiontec Electronics, Inc. Apparatus and methods for monitoring and controlling network activity using mobile communications devices
US20040158630A1 (en) 2003-02-12 2004-08-12 Chang Tsung-Yen Dean Monitoring and controlling network activity in real-time
US7966418B2 (en) 2003-02-21 2011-06-21 Axeda Corporation Establishing a virtual tunnel between two computer programs
US20080219122A1 (en) 2003-03-18 2008-09-11 Roger Detzler Dead on demand technology
WO2004084470A2 (en) 2003-03-18 2004-09-30 Ensconce Data Technology Dead on demand disk technology
US7142839B2 (en) 2003-03-31 2006-11-28 Lucent Technologies Inc. Dynamic grouping of wireless terminal
US20040215605A1 (en) 2003-04-25 2004-10-28 Detroit Diesel Corporation System and method for managing a distributed equipment unit service reporting function over a network
US7398307B2 (en) 2003-04-30 2008-07-08 Hewlett-Packard Development Company, L.P. Method and system for managing a network
US8640234B2 (en) 2003-05-07 2014-01-28 Trustwave Holdings, Inc. Method and apparatus for predictive and actual intrusion detection on a network
US7234943B1 (en) 2003-05-19 2007-06-26 Placeware, Inc. Analyzing cognitive involvement
WO2004107132A2 (en) 2003-05-28 2004-12-09 Caymas Systems, Inc. Method, system and software for state signing of internet resources
US7334119B2 (en) 2003-07-23 2008-02-19 Cisco Technology, Inc. Method, system, apparatus, and program product for temporary personalization of a computer terminal
US7656799B2 (en) 2003-07-29 2010-02-02 Citrix Systems, Inc. Flow control system architecture
US8694620B2 (en) 2003-09-08 2014-04-08 Microsoft Corporation System and method for an OMA DM extension to manage mobile device configuration settings
US20050080897A1 (en) 2003-09-29 2005-04-14 Capital One Financial Corporation Remote management utility
US7594018B2 (en) 2003-10-10 2009-09-22 Citrix Systems, Inc. Methods and apparatus for providing access to persistent application sessions
KR20070026331A (en) 2003-11-11 2007-03-08 사이트릭스 게이트웨이즈, 아이엔씨. System, apparatus and method for establishing a secured communications link to form a virtual private network at a network protocol layer other than that at which packets are filtered
FR2864392A1 (en) 2003-12-17 2005-06-24 France Telecom Intrusion sensing probe alarm set classifying process for use in information security system, involves constructing lattice for each alarm originated from intrusion sensing probes, and merging lattices to form general lattice
TWI272534B (en) 2003-12-31 2007-02-01 Asustek Comp Inc Firmware update processing method and application program
US7164907B2 (en) 2004-01-13 2007-01-16 Qualcomm Inc. Automated over the air plug-in device recognition and software driver download
US20050190769A1 (en) 2004-01-28 2005-09-01 Smith B. S. System and method for securing remote access to a remote system
US7617531B1 (en) 2004-02-18 2009-11-10 Citrix Systems, Inc. Inferencing data types of message components
US7702756B2 (en) 2004-02-27 2010-04-20 Microsoft Corporation Numerousity and latency driven dynamic computer grouping
US20050196023A1 (en) 2004-03-01 2005-09-08 Eastman Kodak Company Method for real-time remote diagnosis of in vivo images
US20050198245A1 (en) 2004-03-06 2005-09-08 John Burgess Intelligent modular remote server management system
US7079010B2 (en) 2004-04-07 2006-07-18 Jerry Champlin System and method for monitoring processes of an information technology system
US20060031779A1 (en) 2004-04-15 2006-02-09 Citrix Systems, Inc. Selectively sharing screen data
US7680885B2 (en) 2004-04-15 2010-03-16 Citrix Systems, Inc. Methods and apparatus for synchronization of data set representations in a bandwidth-adaptive manner
US7827139B2 (en) 2004-04-15 2010-11-02 Citrix Systems, Inc. Methods and apparatus for sharing graphical screen data in a bandwidth-adaptive manner
TW200535697A (en) 2004-04-30 2005-11-01 Hon Hai Prec Ind Co Ltd System and method for automatic updating program
US7366589B2 (en) 2004-05-13 2008-04-29 General Motors Corporation Method and system for remote reflash
US20050256923A1 (en) 2004-05-14 2005-11-17 Citrix Systems, Inc. Methods and apparatus for displaying application output on devices having constrained system resources
EP1751916A1 (en) 2004-05-21 2007-02-14 Cablesedge Software Inc. Remote access system and method and intelligent agent therefor
US7496910B2 (en) 2004-05-21 2009-02-24 Desktopstandard Corporation System for policy-based management of software updates
US20060069753A1 (en) 2004-06-18 2006-03-30 Limin Hu Automatic web-based client-server application program update system
KR100474235B1 (en) 2004-07-21 2005-03-14 엔에이치엔(주) An event alerting method using a dynamic local grouping, and a method thereof
WO2006012610A2 (en) 2004-07-23 2006-02-02 Citrix Systems, Inc. Systems and methods for optimizing communications between network nodes
US7562121B2 (en) 2004-08-04 2009-07-14 Kimberco, Inc. Computer-automated system and method of assessing the orientation, awareness and responses of a person with reduced capacity
US7546601B2 (en) 2004-08-10 2009-06-09 International Business Machines Corporation Apparatus, system, and method for automatically discovering and grouping resources used by a business process
JP2008510232A (en) 2004-08-13 2008-04-03 サイトリックス システムズ, インコーポレイテッド How to maintain process consistency across multiple remote access servers
US7797724B2 (en) 2004-08-31 2010-09-14 Citrix Systems, Inc. Methods and apparatus for secure online access on a client device
US20060077941A1 (en) 2004-09-20 2006-04-13 Meyyappan Alagappan User interface system and method for implementation on multiple types of clients
US7756984B2 (en) 2004-09-27 2010-07-13 Citrix Systems, Inc. Systems and methods for virtual host name roaming
US7984192B2 (en) 2004-09-27 2011-07-19 Citrix Systems, Inc. System and method for assigning unique identifiers to each remote display protocol session established via an intermediary device
US7712110B2 (en) 2004-09-28 2010-05-04 Citrix Systems, Inc. System and method for remoting twain function calls from a user session to a client system
US7702750B2 (en) 2004-09-29 2010-04-20 Citrix Systems, Inc. System and method for event detection and re-direction over a network using a presentation level protocol
US7680758B2 (en) 2004-09-30 2010-03-16 Citrix Systems, Inc. Method and apparatus for isolating execution of software applications
US8613048B2 (en) 2004-09-30 2013-12-17 Citrix Systems, Inc. Method and apparatus for providing authorized remote access to application sessions
US7752600B2 (en) 2004-09-30 2010-07-06 Citrix Systems, Inc. Method and apparatus for providing file-type associations to multiple applications
US7711835B2 (en) 2004-09-30 2010-05-04 Citrix Systems, Inc. Method and apparatus for reducing disclosure of proprietary data in a networked environment
US20060075114A1 (en) 2004-09-30 2006-04-06 Citrix Systems, Inc. In-line modification of protocol handshake by protocol aware proxy
US7748032B2 (en) 2004-09-30 2010-06-29 Citrix Systems, Inc. Method and apparatus for associating tickets in a ticket hierarchy
US20060069662A1 (en) 2004-09-30 2006-03-30 Citrix Systems, Inc. Method and apparatus for remapping accesses to virtual system resources
US8117559B2 (en) 2004-09-30 2012-02-14 Citrix Systems, Inc. Method and apparatus for virtualizing window information
US20060100972A1 (en) 2004-10-19 2006-05-11 Ge Medical Systems Technology Llc Automated software-based hardware tracking system
US7408441B2 (en) 2004-10-25 2008-08-05 Electronic Data Systems Corporation System and method for analyzing user-generated event information and message information from network devices
US7408440B2 (en) 2004-10-25 2008-08-05 Electronics Data Systems Corporation System and method for analyzing message information from diverse network devices
US8903827B2 (en) 2004-10-29 2014-12-02 Ebay Inc. Method and system for categorizing items automatically
US7440768B2 (en) 2004-12-20 2008-10-21 Motorola, Inc. Monitoring availability of selective call radios in a half-duplex radio communication system
US7593514B1 (en) 2004-12-28 2009-09-22 Webex Communications, Inc. Methods and apparatuses for communicating between messaging and telephony systems
US7831728B2 (en) 2005-01-14 2010-11-09 Citrix Systems, Inc. Methods and systems for real-time seeking during real-time playback of a presentation layer protocol data stream
US8340130B2 (en) 2005-01-14 2012-12-25 Citrix Systems, Inc. Methods and systems for generating playback instructions for rendering of a recorded computer session
US7996549B2 (en) 2005-01-14 2011-08-09 Citrix Systems, Inc. Methods and systems for recording and real-time playback of presentation layer protocol data
US8145777B2 (en) 2005-01-14 2012-03-27 Citrix Systems, Inc. Method and system for real-time seeking during playback of remote presentation protocols
US20060161671A1 (en) 2005-01-14 2006-07-20 Citrix Systems, Inc. Method and systems for capture and replay of remote presentation protocol data
US20060236385A1 (en) 2005-01-14 2006-10-19 Citrix Systems, Inc. A method and system for authenticating servers in a server farm
US7562226B2 (en) 2005-01-14 2009-07-14 Citrix Systems, Inc. System and method for permission-based access using a shared account
US8230096B2 (en) 2005-01-14 2012-07-24 Citrix Systems, Inc. Methods and systems for generating playback instructions for playback of a recorded computer session
US8042165B2 (en) 2005-01-14 2011-10-18 Citrix Systems, Inc. Method and system for requesting and granting membership in a server farm
US20060159432A1 (en) 2005-01-14 2006-07-20 Citrix Systems, Inc. System and methods for automatic time-warped playback in rendering a recorded computer session
US7581005B2 (en) 2005-01-20 2009-08-25 Citrix Systems, Inc. Systems and methods for preserving transport layer protocol options
US7661131B1 (en) 2005-02-03 2010-02-09 Sun Microsystems, Inc. Authentication of tunneled connections
US7565526B1 (en) 2005-02-03 2009-07-21 Sun Microsystems, Inc. Three component secure tunnel
US7730157B2 (en) 2005-02-03 2010-06-01 The Trustees Of Columbia University In The City Of New York Methods, media, and systems for displaying information on a thin-client in communication with a network
US7543020B2 (en) 2005-02-10 2009-06-02 Cisco Technology, Inc. Distributed client services based on execution of service attributes and data attributes by multiple nodes in resource groups
EP1866789B8 (en) 2005-02-28 2020-04-15 McAfee, LLC Mobile data security system and methods
US7590653B2 (en) 2005-03-02 2009-09-15 Cassatt Corporation Automated discovery and inventory of nodes within an autonomic distributed computing system
US20060200307A1 (en) 2005-03-04 2006-09-07 Lockheed Martin Corporation Vehicle identification and tracking system
US8423673B2 (en) 2005-03-14 2013-04-16 Citrix Systems, Inc. Method and apparatus for updating a graphical display in a distributed processing environment using compression
US8171169B2 (en) 2005-03-14 2012-05-01 Citrix Systems, Inc. Method and apparatus for updating a graphical display in a distributed processing environment
ATE418836T1 (en) 2005-03-21 2009-01-15 Hewlett Packard Development Co MOBILE CLIENT DEVICE AND SYSTEM SUPPORTING REMOTE MANAGEMENT DEVICES
US7831833B2 (en) 2005-04-22 2010-11-09 Citrix Systems, Inc. System and method for key recovery
US7444071B2 (en) 2005-04-28 2008-10-28 Carestream Health, Inc. Method for diagnosing disease from tongue image
US20060271877A1 (en) 2005-05-25 2006-11-30 Citrix Systems, Inc. A system and methods for selective sharing of an application window
US20060271875A1 (en) 2005-05-26 2006-11-30 Citrix Systems, Inc. A method and system for providing visual annotation in a shared display environment
US20090119408A1 (en) 2005-06-17 2009-05-07 France Telecom Method for managing execution by a server of an application providing at least one interactive multimedia service to at least one terminal, corresponding computer program product and server
US20070056009A1 (en) 2005-08-23 2007-03-08 Michael Spilo System and method for viewing and controlling a personal computer using a networked television
US8782201B2 (en) 2005-10-28 2014-07-15 Bank Of America Corporation System and method for managing the configuration of resources in an enterprise
US7613131B2 (en) 2005-11-10 2009-11-03 Citrix Systems, Inc. Overlay network infrastructure
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
AU2006333118B2 (en) 2005-12-15 2011-06-09 Barclays Capital Inc System and method for secure remote desktop access
US20070156923A1 (en) 2005-12-29 2007-07-05 Webex Communications, Inc. Methods and apparatuses for tracking progress of an invited participant
US7921153B2 (en) 2005-12-29 2011-04-05 Webex Communications, Inc. Methods and apparatuses for selectively displaying information to an invited participant
US7783985B2 (en) 2006-01-04 2010-08-24 Citrix Systems, Inc. Systems and methods for transferring data between computing devices
US20070174454A1 (en) 2006-01-23 2007-07-26 Mitchell David C Method and apparatus for accessing Web services and URL resources for both primary and shared users over a reverse tunnel mechanism
US20070174429A1 (en) 2006-01-24 2007-07-26 Citrix Systems, Inc. Methods and servers for establishing a connection between a client system and a virtual machine hosting a requested computing environment
US7756828B2 (en) 2006-02-28 2010-07-13 Microsoft Corporation Configuration management database state model
JP2006277752A (en) 2006-04-10 2006-10-12 Horizon Digital Enterprise Inc Computer remote-managing method
US20070282623A1 (en) 2006-04-24 2007-12-06 Jon Dattorro Process for protecting children from online predators
US20070294237A1 (en) 2006-06-13 2007-12-20 Mariam John Enterprise-Wide Configuration Management Database Searches
US8244883B2 (en) 2006-08-03 2012-08-14 Citrix Systems, Inc. Systems and methods of for providing multi-mode transport layer compression
US8869262B2 (en) 2006-08-03 2014-10-21 Citrix Systems, Inc. Systems and methods for application based interception of SSL/VPN traffic
US8392977B2 (en) 2006-08-03 2013-03-05 Citrix Systems, Inc. Systems and methods for using a client agent to manage HTTP authentication cookies
US8108525B2 (en) 2006-08-03 2012-01-31 Citrix Systems, Inc. Systems and methods for managing a plurality of user sessions in a virtual private network environment
US7953889B2 (en) 2006-08-03 2011-05-31 Citrix Systems, Inc. Systems and methods for routing VPN traffic around network disruption
US7843912B2 (en) 2006-08-03 2010-11-30 Citrix Systems, Inc. Systems and methods of fine grained interception of network communications on a virtual private network
US8626946B2 (en) 2006-08-03 2014-01-07 Citrix Systems, Inc. Systems and methods for hierarchical global load balancing
US8566925B2 (en) 2006-08-03 2013-10-22 Citrix Systems, Inc. Systems and methods for policy based triggering of client-authentication at directory level granularity
US8495181B2 (en) 2006-08-03 2013-07-23 Citrix Systems, Inc Systems and methods for application based interception SSI/VPN traffic
US8677007B2 (en) 2006-08-03 2014-03-18 Citrix Systems, Inc. Systems and methods for bypassing an appliance
US8141164B2 (en) 2006-08-21 2012-03-20 Citrix Systems, Inc. Systems and methods for dynamic decentralized load balancing across multiple sites
US7769869B2 (en) 2006-08-21 2010-08-03 Citrix Systems, Inc. Systems and methods of providing server initiated connections on a virtual private network
US8451806B2 (en) 2006-08-21 2013-05-28 Citrix Sysrems, Inc. Systems and methods for pinging a user's intranet IP address
US8213393B2 (en) 2006-08-21 2012-07-03 Citrix Systems, Inc. Methods for associating an IP address to a user via an appliance
US8694684B2 (en) 2006-08-21 2014-04-08 Citrix Systems, Inc. Systems and methods of symmetric transport control protocol compression
US8230214B2 (en) 2006-08-21 2012-07-24 Citrix Systems, Inc. Systems and methods for optimizing SSL handshake processing
US8095787B2 (en) 2006-08-21 2012-01-10 Citrix Systems, Inc. Systems and methods for optimizing SSL handshake processing
US8418243B2 (en) 2006-08-21 2013-04-09 Citrix Systems, Inc. Systems and methods of providing an intranet internet protocol address to a client on a virtual private network
US8769522B2 (en) 2006-08-21 2014-07-01 Citrix Systems, Inc. Systems and methods of installing an application without rebooting
US8352728B2 (en) 2006-08-21 2013-01-08 Citrix Systems, Inc. Systems and methods for bulk encryption and decryption of transmitted data
US8116207B2 (en) 2006-08-21 2012-02-14 Citrix Systems, Inc. Systems and methods for weighted monitoring of network services
US8493858B2 (en) 2006-08-22 2013-07-23 Citrix Systems, Inc Systems and methods for providing dynamic connection spillover among virtual servers
US20080065757A1 (en) 2006-09-08 2008-03-13 Tetsuro Motoyama System, method, and computer program product using the HTTP protocol to extract information from remote devices
US8054241B2 (en) 2006-09-14 2011-11-08 Citrix Systems, Inc. Systems and methods for multiple display support in remote access software
US7791559B2 (en) 2006-09-14 2010-09-07 Citrix Systems, Inc. System and method for multiple display support in remote access software
US8078972B2 (en) 2006-09-15 2011-12-13 Citrix Systems, Inc. Methods and interfaces for displaying performance data related to a current remote access session
US7898968B2 (en) 2006-09-15 2011-03-01 Citrix Systems, Inc. Systems and methods for selecting efficient connection paths between computing devices
US7978617B2 (en) 2006-09-15 2011-07-12 Citrix Systems, Inc. Methods for providing performance improvement recommendations
US8370479B2 (en) 2006-10-03 2013-02-05 Axeda Acquisition Corporation System and method for dynamically grouping devices based on present device conditions
WO2008067075A2 (en) 2006-10-20 2008-06-05 Citrix Systems, Inc. Systems and methods for responding to the occurrence of an event
US8533846B2 (en) 2006-11-08 2013-09-10 Citrix Systems, Inc. Method and system for dynamically associating access rights with a resource
US20080126978A1 (en) 2006-11-28 2008-05-29 Likun Bai System and method of enhancing computer security by using dual desktop technologies
US8065397B2 (en) 2006-12-26 2011-11-22 Axeda Acquisition Corporation Managing configurations of distributed devices
US7664857B2 (en) 2007-01-26 2010-02-16 Citrix Systems, Inc. Systems and methods of using an IP ID field for automatic WAN/LAN detection
US7584294B2 (en) 2007-03-12 2009-09-01 Citrix Systems, Inc. Systems and methods for prefetching objects for caching using QOS
US7532134B2 (en) 2007-03-12 2009-05-12 Citrix Systems, Inc. Systems and methods for sharing compression histories between multiple devices
US7453379B2 (en) 2007-03-12 2008-11-18 Citrix Systems, Inc. Systems and methods for identifying long matches of data in a compression history
US7619545B2 (en) 2007-03-12 2009-11-17 Citrix Systems, Inc. Systems and methods of using application and protocol specific parsing for compression
US7460038B2 (en) 2007-03-12 2008-12-02 Citrix Systems, Inc. Systems and methods of clustered sharing of compression histories
US7583189B2 (en) 2007-03-20 2009-09-01 Canosa John T Methods for managing remote devices over an instant messaging network and systems thereof
WO2008143870A1 (en) 2007-05-14 2008-11-27 Kopin Corporation Mobile wireless display for accessing data from a host and method for controlling
US8825468B2 (en) 2007-07-31 2014-09-02 Kopin Corporation Mobile wireless display providing speech to speech translation and avatar simulating human attributes
WO2009026247A1 (en) 2007-08-16 2009-02-26 Shellshadow, Llc Terminal client collaboration and relay systems and methods
US8744238B2 (en) 2007-08-22 2014-06-03 Citrix Systems, Inc. Method and apparatus for automated content marking
US20090064134A1 (en) 2007-08-30 2009-03-05 Citrix Systems,Inc. Systems and methods for creating and executing files
US7886050B2 (en) 2007-10-05 2011-02-08 Citrix Systems, Inc. Systems and methods for monitoring components of a remote access server farm
US8024407B2 (en) 2007-10-17 2011-09-20 Citrix Systems, Inc. Methods and systems for providing access, from within a virtual world, to an external resource
US8850070B2 (en) 2008-03-07 2014-09-30 Citrix Systems, Inc. Systems and methods for content injection

Patent Citations (99)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4497037A (en) * 1980-11-26 1985-01-29 Nippondenso Co., Ltd. Apparatus for managing a group of copying machines
US4996703A (en) * 1986-04-21 1991-02-26 Gray William F Remote supervisory monitoring and control apparatus connected to monitored equipment
US5184179A (en) * 1988-05-17 1993-02-02 Monitel Products Corp. Photocopy monitoring system and method for monitoring copiers
US5282127A (en) * 1989-11-20 1994-01-25 Sanyo Electric Co., Ltd. Centralized control system for terminal device
US5084875A (en) * 1989-12-13 1992-01-28 Joseph Weinberger System for automatically monitoring copiers from a remote location
US5603060A (en) * 1989-12-13 1997-02-11 Joseph Weinberger Method of controlling copy machines from a remote location
US5491535A (en) * 1990-04-10 1996-02-13 Minolta Camera Kabushiki Kaisha Control appartus of copying machine with improved communication function for centralized control
US5708908A (en) * 1990-06-22 1998-01-13 Minolta Co., Ltd. Copying machine control system with improved reliability of communication function among copying machiines and centralized control unit
US5488454A (en) * 1991-04-18 1996-01-30 Canon Kabushiki Kaisha Control of equipment and of communication with plural units of equipment
US5493364A (en) * 1991-04-18 1996-02-20 Canon Kabushiki Kaisha Equipment control apparatus having means to communicate with a centralized control apparatus
US5386271A (en) * 1991-08-30 1995-01-31 Minolta Camera Kabushiki Kaisha Centralized control system for an image forming apparatus which employs fuzzy logic to identify abnormal conditions
US5384622A (en) * 1991-11-18 1995-01-24 Minolta Camera Kabushiki Kaisha System of controlling a plurality of copying machines interconnnected through a private branch exchange
US6181331B1 (en) * 1992-09-23 2001-01-30 Siemens Power Transmission & Distribution, Inc. Man-machine interface
US5600301A (en) * 1993-03-11 1997-02-04 Schrader Automotive Inc. Remote tire pressure monitoring system employing coded tire identification and radio frequency transmission, and enabling recalibration upon tire rotation or replacement
US5857207A (en) * 1993-05-12 1999-01-05 Apple Computer, Inc. Storage manager for computer system
US5715393A (en) * 1993-08-16 1998-02-03 Motorola, Inc. Method for remote system process monitoring
US5392095A (en) * 1993-12-02 1995-02-21 Xerox Corporation Customer feedback device on a machine console
US5600403A (en) * 1993-12-24 1997-02-04 Canon Kabushiki Kaisha Monitor system for monitoring state of image forming device
US6022315A (en) * 1993-12-29 2000-02-08 First Opinion Corporation Computerized medical diagnostic and treatment advice system including network access
US5485142A (en) * 1994-04-08 1996-01-16 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Remote monitor alarm system
US5594529A (en) * 1994-11-30 1997-01-14 Exedy Corporation Imaging device with stock supervision means
US6990395B2 (en) * 1994-12-30 2006-01-24 Power Measurement Ltd. Energy management device and architecture with multiple security levels
US5715496A (en) * 1995-01-19 1998-02-03 Ricoh Company, Ltd. Remote service system for image forming apparatuses
US6021284A (en) * 1995-02-22 2000-02-01 Canon Kabushiki Kaisha Image forming apparatus, apparatus for supplying image data to image forming apparatus, and method of interfacing two apparatuses
US5872928A (en) * 1995-02-24 1999-02-16 Cabletron Systems, Inc. Method and apparatus for defining and enforcing policies for configuration management in communications networks
US5872635A (en) * 1995-04-27 1999-02-16 Canon Kabushiki Kaisha Image forming apparatus and method which transmits information on internal conditions to an image processor
US6025925A (en) * 1995-06-23 2000-02-15 Lexmark International, Inc. Method and apparatus for providing job accounting information to a host computer from a printer
US5708909A (en) * 1995-09-12 1998-01-13 Mita Industrial Co., Ltd. Equipment management system
US6016535A (en) * 1995-10-11 2000-01-18 Citrix Systems, Inc. Method for dynamically and efficiently caching objects by subdividing cache memory blocks into equally-sized sub-blocks
US6684259B1 (en) * 1995-10-11 2004-01-27 Citrix Systems, Inc. Method for providing user global object name space in a multi-user operating system
US5873009A (en) * 1995-11-06 1999-02-16 Mita Industrial Co., Ltd. Equipment management system that issues a warning when the lifetime of a component has been exceeded and disables the warning when such a warning is to be generated for a different component
US6691157B2 (en) * 1995-11-13 2004-02-10 Citrix Systems, Inc. Method and apparatus for making a hypermedium interactive
US5862348A (en) * 1996-02-09 1999-01-19 Citrix Systems, Inc. Method and apparatus for connecting a client node to a server node based on load levels
US5603323A (en) * 1996-02-27 1997-02-18 Advanced Technology Laboratories, Inc. Medical ultrasonic diagnostic system with upgradeable transducer probes and other features
US5715823A (en) * 1996-02-27 1998-02-10 Atlantis Diagnostics International, L.L.C. Ultrasonic diagnostic imaging system with universal access to diagnostic information and images
US5720015A (en) * 1996-04-22 1998-02-17 Lexmark International, Inc. Method and apparatus for providing remote printer resource management
US5873659A (en) * 1996-04-24 1999-02-23 Edwards; Steve Michael Method and apparatus for providing a printer having internal queue job management
US6336135B1 (en) * 1996-05-24 2002-01-01 International Business Machines Corporation Gateway for converting synchronous client/server protocols into asynchronous messaging protocols and storing session state information at the client
US6172683B1 (en) * 1996-06-12 2001-01-09 Citrix Systems, Inc. Method for the lossless compression of lines in a distributed computer system
US6031964A (en) * 1996-06-20 2000-02-29 Apple Computer, Inc. System and method for using a unified memory architecture to implement a digital camera device
US5865745A (en) * 1996-11-27 1999-02-02 Eastman Kodak Company Remote health care information input apparatus
US6014691A (en) * 1996-12-06 2000-01-11 Bef Corporation Distributed data collection system for remote photographic processing equipment
US6023722A (en) * 1996-12-07 2000-02-08 International Business Machines Corp. High-availability WWW computer server system with pull-based load balancing using a messaging and queuing unit in front of back-end servers
US6012088A (en) * 1996-12-10 2000-01-04 International Business Machines Corporation Automatic configuration for internet access device
US6023749A (en) * 1997-01-07 2000-02-08 Citrix Systems, Inc. Object and method for providing efficient multi-user access to shared operating system kernal code using instancing
US5862404A (en) * 1997-02-12 1999-01-19 Toshiba America Information Systems, Inc. Network device discovery and status information distribution using independent information distribution processes
US6023507A (en) * 1997-03-17 2000-02-08 Sun Microsystems, Inc. Automatic remote computer monitoring system
US6023721A (en) * 1997-05-14 2000-02-08 Citrix Systems, Inc. Method and system for allowing a single-user application executing in a multi-user environment to create objects having both user-global and system global visibility
US20030037148A1 (en) * 1997-05-14 2003-02-20 Citrix Systems, Inc. System and method for transmitting data from a server application to more than one client node
US6014694A (en) * 1997-06-26 2000-01-11 Citrix Systems, Inc. System for adaptive video/audio transport over a network
US5857967A (en) * 1997-07-09 1999-01-12 Hewlett-Packard Company Universally accessible healthcare devices with on the fly generation of HTML files
US6175866B1 (en) * 1997-11-24 2001-01-16 International Business Machines Corporation Method and system for generating unsupported network monitoring objects
US6681349B2 (en) * 1998-01-06 2004-01-20 Seiko Epson Corporation System and method for monitoring the state of a plurality of machines connected via a computer network
US20060031237A1 (en) * 1998-03-30 2006-02-09 Deanna Robert System for development, management and operation of distributed clients and servers
US6014631A (en) * 1998-04-02 2000-01-11 Merck-Medco Managed Care, Llc Computer implemented patient medication review system and process for the managed care, health care and/or pharmacy industry
US6343320B1 (en) * 1998-06-09 2002-01-29 Compaq Information Technologies Group, L.P. Automatic state consolidation for network participating devices
US6338086B1 (en) * 1998-06-11 2002-01-08 Placeware, Inc. Collaborative object architecture
US7158483B1 (en) * 1998-06-30 2007-01-02 Kabushiki Kaisha Toshiba Communication node and communication terminal
US6523013B2 (en) * 1998-07-24 2003-02-18 Neopost, Inc. Method and apparatus for performing automated fraud reporting
US6189113B1 (en) * 1998-09-25 2001-02-13 Xerox Corporation Auditron data format for remote maintenance of a machine such as a copier
US20020006790A1 (en) * 1998-10-21 2002-01-17 Werner Blumenstock System and method for remote maintenance and/or remote diagnosis of an automation system by means of electronic mail
US6691154B1 (en) * 1998-11-18 2004-02-10 Webex Communications, Inc. Instantaneous remote control of an unattended server
US7162315B2 (en) * 1998-12-18 2007-01-09 Placeware, Inc. Digital audio compensation
US6857013B2 (en) * 1999-01-29 2005-02-15 Intermec Ip.Corp. Remote anomaly diagnosis and reconfiguration of an automatic data collection device platform over a telecommunications network
US6523130B1 (en) * 1999-03-11 2003-02-18 Microsoft Corporation Storage system having error detection and recovery
US6023223A (en) * 1999-03-18 2000-02-08 Baxter, Jr.; John Francis Early warning detection and notification network for environmental conditions
US6510350B1 (en) * 1999-04-09 2003-01-21 Steen, Iii Henry B. Remote data access and system control
US6842903B1 (en) * 1999-05-19 2005-01-11 Sun Microsystems, Inc. System and method for providing dynamic references between services in a computer system
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
US20020026514A1 (en) * 2000-02-01 2002-02-28 Ellis Raymond Walter Automated tool management in a multi-protocol environment
US6687873B1 (en) * 2000-03-09 2004-02-03 Electronic Data Systems Corporation Method and system for reporting XML data from a legacy computer system
US6985779B2 (en) * 2000-03-10 2006-01-10 Smiths Detection, Inc. Monitoring system for an industrial process using one or more multidimensional variables
US6687848B1 (en) * 2000-05-31 2004-02-03 Sun Microsystems, Inc. Techniques for preventing information loss in a business to business message in an enterprise computer system
US20020019844A1 (en) * 2000-07-06 2002-02-14 Kurowski Scott J. Method and system for network-distributed computing
US20070011295A1 (en) * 2000-07-28 2007-01-11 Axeda Corporation, A Massachusetts Corporation Reporting the state of an apparatus to a remote computer
US6686838B1 (en) * 2000-09-06 2004-02-03 Xanboo Inc. Systems and methods for the automatic registration of devices
US6681344B1 (en) * 2000-09-14 2004-01-20 Microsoft Corporation System and method for automatically diagnosing a computer problem
US6986040B1 (en) * 2000-11-03 2006-01-10 Citrix Systems, Inc. System and method of exploiting the security of a secure communication channel to secure a non-secure communication channel
US20030023957A1 (en) * 2001-07-02 2003-01-30 David Bau Annotation based development platform for stateful web services
US20030014733A1 (en) * 2001-07-10 2003-01-16 Ringseth Paul F. System and methods for providing a declarative syntax for specifying SOAP-based web services
US20030025931A1 (en) * 2001-08-01 2003-02-06 Gregory Dorfman Content management in a broadband printing system
US6983020B2 (en) * 2002-03-25 2006-01-03 Citrix Online Llc Method and apparatus for fast block motion detection
US20070022159A1 (en) * 2002-03-28 2007-01-25 Webex Communications, Inc. conference recording system
US20070005736A1 (en) * 2002-04-19 2007-01-04 Axeda Corporation, A Massachusetts Corporation Configuring a network gateway
US7162628B2 (en) * 2002-07-23 2007-01-09 Cisco Technology, Inc. Method, system, apparatus and program product for temporary personalization of a computer terminal
US20040027373A1 (en) * 2002-08-07 2004-02-12 Jacquot Bryan Joseph Linked screen demonstration program for computer application programs
US20050015501A1 (en) * 2003-01-13 2005-01-20 Kaplan Scott P. On-location electronics troubleshooting services system
US20050005152A1 (en) * 2003-07-01 2005-01-06 Navjot Singh Security vulnerability monitor
US20050033588A1 (en) * 2003-08-04 2005-02-10 Mario Ruiz Information system comprised of synchronized software application moduless with individual databases for implementing and changing business requirements to be automated
US20060002315A1 (en) * 2004-04-15 2006-01-05 Citrix Systems, Inc. Selectively sharing screen data
US20060015740A1 (en) * 2004-07-02 2006-01-19 Citrix Systems, Inc. A system and method for executing interactive applications with minimal privileges
US20060029064A1 (en) * 2004-07-23 2006-02-09 Citrix Systems, Inc. A method and systems for routing packets from an endpoint to a gateway
US20060029062A1 (en) * 2004-07-23 2006-02-09 Citrix Systems, Inc. Methods and systems for securing access to private networks using encryption and authentication technology built in to peripheral devices
US20060029063A1 (en) * 2004-07-23 2006-02-09 Citrix Systems, Inc. A method and systems for routing packets from a gateway to an endpoint
US20060031476A1 (en) * 2004-08-05 2006-02-09 Mathes Marvin L Apparatus and method for remotely monitoring a computer network
US20070011356A1 (en) * 2005-05-26 2007-01-11 Citrix Systems, Inc. A method and system for synchronizing presentation of a dynamic data set to a plurality of nodes
US20080005321A1 (en) * 2006-06-29 2008-01-03 Lin Ma Monitoring and Managing Distributed Devices
US20090013064A1 (en) * 2007-07-06 2009-01-08 Questra Corporation Managing distributed devices with limited connectivity
US20090019226A1 (en) * 2007-07-11 2009-01-15 Citrix Systems, Inc. Methods and systems for providing a level of access to a computing device

Cited By (106)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8898294B2 (en) 2000-07-28 2014-11-25 Axeda Corporation Reporting the state of an apparatus to a remote computer
US8055758B2 (en) 2000-07-28 2011-11-08 Axeda Corporation Reporting the state of an apparatus to a remote computer
US20070011295A1 (en) * 2000-07-28 2007-01-11 Axeda Corporation, A Massachusetts Corporation Reporting the state of an apparatus to a remote computer
US20070198661A1 (en) * 2000-09-22 2007-08-23 Axeda Corporation Retrieving data from a server
US20020116550A1 (en) * 2000-09-22 2002-08-22 Hansen James R. Retrieving data from a server
US7937370B2 (en) 2000-09-22 2011-05-03 Axeda Corporation Retrieving data from a server
US10069937B2 (en) 2000-09-22 2018-09-04 Ptc Inc. Retrieving data from a server
US8108543B2 (en) 2000-09-22 2012-01-31 Axeda Corporation Retrieving data from a server
US8762497B2 (en) 2000-09-22 2014-06-24 Axeda Corporation Retrieving data from a server
US8406119B2 (en) 2001-12-20 2013-03-26 Axeda Acquisition Corporation Adaptive device-initiated polling
US9674067B2 (en) 2001-12-20 2017-06-06 PTC, Inc. Adaptive device-initiated polling
US9170902B2 (en) 2001-12-20 2015-10-27 Ptc Inc. Adaptive device-initiated polling
US20070078976A1 (en) * 2001-12-20 2007-04-05 Questra Corporation Adaptive device-initiated polling
US20070288629A2 (en) * 2001-12-20 2007-12-13 Questra Corporation Adaptive device-initiated polling
US8060886B2 (en) 2002-04-17 2011-11-15 Axeda Corporation XML scripting of SOAP commands
US8752074B2 (en) 2002-04-17 2014-06-10 Axeda Corporation Scripting of soap commands
US9591065B2 (en) 2002-04-17 2017-03-07 Ptc Inc. Scripting of SOAP commands
US20070150903A1 (en) * 2002-04-17 2007-06-28 Axeda Corporation XML Scripting of SOAP Commands
US10708346B2 (en) 2002-04-17 2020-07-07 Ptc Inc. Scripting of soap commands
US20050245741A1 (en) * 2002-07-08 2005-11-03 Nafizal Hossain Novel tricyclic spiropiperidines or spiropyrrolidines
US9479613B2 (en) 2002-08-08 2016-10-25 Ptc Inc. Maintaining independent states for multiple web browser instances
US20040133563A1 (en) * 2002-08-08 2004-07-08 Matthew Harvey Maintaining independent states for multiple web browser instances
US8635254B2 (en) 2002-08-08 2014-01-21 Axeda Corporation Maintaining independent states for multiple web browser instances
US8291039B2 (en) 2003-02-21 2012-10-16 Axeda Corporation Establishing a virtual tunnel between two computer programs
US9002980B2 (en) 2003-02-21 2015-04-07 Axeda Corporation Establishing a virtual tunnel between two computer programs
US10069939B2 (en) 2003-02-21 2018-09-04 Ptc Inc. Establishing a virtual tunnel between two computers
US7424736B2 (en) 2004-03-10 2008-09-09 Combrio, Inc. Method for establishing directed circuits between parties with limited mutual trust
US7650432B2 (en) 2004-05-20 2010-01-19 Bea Systems, Inc. Occasionally-connected application server
US20060053368A1 (en) * 2004-05-20 2006-03-09 Bea Systems, Inc. Conduit manager for occasionally-connected application server
US20060030292A1 (en) * 2004-05-20 2006-02-09 Bea Systems, Inc. Client programming for mobile client
US20060026168A1 (en) * 2004-05-20 2006-02-02 Bea Systems, Inc. Data model for occasionally-connected application server
US20060117073A1 (en) * 2004-05-20 2006-06-01 Bea Systems, Inc. Occasionally-connected application server
US20060031256A1 (en) * 2004-05-20 2006-02-09 Bea Systems, Inc. Template language for mobile client
US20060031264A1 (en) * 2004-05-20 2006-02-09 Bea Systems, Inc. Synchronization protocol for occasionally-connected application server
US20060031228A1 (en) * 2004-05-20 2006-02-09 Bea Systems, Inc. Adaptive user interface for occasionally-connected application server
US20060036463A1 (en) * 2004-05-21 2006-02-16 Patrick Paul B Liquid computing
US20050278374A1 (en) * 2004-05-21 2005-12-15 Bea Systems, Inc. Dynamic program modification
US20060212593A1 (en) * 2004-05-21 2006-09-21 Bea Systems, Inc. Dynamic service composition and orchestration
US20060136555A1 (en) * 2004-05-21 2006-06-22 Bea Systems, Inc. Secure service oriented architecture
US20050273516A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Dynamic routing in a service oriented architecture
US20060080419A1 (en) * 2004-05-21 2006-04-13 Bea Systems, Inc. Reliable updating for a service oriented architecture
US7310684B2 (en) 2004-05-21 2007-12-18 Bea Systems, Inc. Message processing in a service oriented architecture
US20080034367A1 (en) * 2004-05-21 2008-02-07 Bea Systems, Inc. Message processing in a service oriented architecture
US20050273521A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Dynamically configurable service oriented architecture
US20050267892A1 (en) * 2004-05-21 2005-12-01 Patrick Paul B Service proxy definition
US20060069791A1 (en) * 2004-05-21 2006-03-30 Bea Systems, Inc. Service oriented architecture with interchangeable transport protocols
US20050273847A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Programmable message processing stage for a service oriented architecture
US20050273518A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Co-located service oriented architecture
US20050273502A1 (en) * 2004-05-21 2005-12-08 Patrick Paul B Service oriented architecture with message processing stages
US20050270970A1 (en) * 2004-05-21 2005-12-08 Bea Systems, Inc. Failsafe service oriented architecture
US20060005063A1 (en) * 2004-05-21 2006-01-05 Bea Systems, Inc. Error handling for a service oriented architecture
US20060007918A1 (en) * 2004-05-21 2006-01-12 Bea Systems, Inc. Scaleable service oriented architecture
US20060034237A1 (en) * 2004-05-21 2006-02-16 Bea Systems, Inc. Dynamically configurable service oriented architecture
US7653008B2 (en) 2004-05-21 2010-01-26 Bea Systems, Inc. Dynamically configurable service oriented architecture
US20050267947A1 (en) * 2004-05-21 2005-12-01 Bea Systems, Inc. Service oriented architecture with message processing pipelines
US8615601B2 (en) 2004-05-21 2013-12-24 Oracle International Corporation Liquid computing
US20050264581A1 (en) * 2004-05-21 2005-12-01 Bea Systems, Inc. Dynamic program modification
US7774485B2 (en) 2004-05-21 2010-08-10 Bea Systems, Inc. Dynamic service composition and orchestration
US20060031930A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Dynamically configurable service oriented architecture
US20060031481A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Service oriented architecture with monitoring
US20060031432A1 (en) * 2004-05-21 2006-02-09 Bea Systens, Inc. Service oriented architecture with message processing pipelines
US20060031354A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Service oriented architecture
US20060031353A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Dynamic publishing in a service oriented architecture
US20060031433A1 (en) * 2004-05-21 2006-02-09 Bea Systems, Inc. Batch updating for a service oriented architecture
US7685292B1 (en) 2005-04-07 2010-03-23 Dell Marketing Usa L.P. Techniques for establishment and use of a point-to-point tunnel between source and target devices
US9032091B2 (en) 2005-04-15 2015-05-12 Esprida Corporation Apparatus and method for managing a network of intelligent devices
US20060259604A1 (en) * 2005-04-15 2006-11-16 Uri Kotchavi Apparatus and method for managing a network of intelligent devices
US20100177786A1 (en) * 2006-04-13 2010-07-15 Directpacket Research, Inc. System and method for multimedia communication across disparate networks
US20070245412A1 (en) * 2006-04-13 2007-10-18 Directpacket Research, Inc. System and method for a communication system
US8605730B2 (en) 2006-04-13 2013-12-10 Directpacket Research, Inc. System and method for multimedia communication across disparate networks
US8560828B2 (en) 2006-04-13 2013-10-15 Directpacket Research, Inc. System and method for a communication system
US8645973B2 (en) 2006-09-22 2014-02-04 Oracle International Corporation Mobile applications
US10212055B2 (en) 2006-10-03 2019-02-19 Ptc Inc. System and method for dynamically grouping devices based on present device conditions
US8370479B2 (en) 2006-10-03 2013-02-05 Axeda Acquisition Corporation System and method for dynamically grouping devices based on present device conditions
US9491071B2 (en) 2006-10-03 2016-11-08 Ptc Inc. System and method for dynamically grouping devices based on present device conditions
US20080082657A1 (en) * 2006-10-03 2008-04-03 Questra Corporation A System and Method for Dynamically Grouping Devices Based on Present Device Conditions
US8769095B2 (en) 2006-10-03 2014-07-01 Axeda Acquisition Corp. System and method for dynamically grouping devices based on present device conditions
US9491049B2 (en) 2006-12-26 2016-11-08 Ptc Inc. Managing configurations of distributed devices
US8065397B2 (en) 2006-12-26 2011-11-22 Axeda Acquisition Corporation Managing configurations of distributed devices
US9712385B2 (en) 2006-12-26 2017-07-18 PTC, Inc. Managing configurations of distributed devices
US8788632B2 (en) 2006-12-26 2014-07-22 Axeda Acquisition Corp. Managing configurations of distributed devices
US20080154957A1 (en) * 2006-12-26 2008-06-26 Questra Corporation Managing configurations of distributed devices
US20080270612A1 (en) * 2007-04-30 2008-10-30 Microsoft Corporation Enabling secure remote assistance using a terminal services gateway
US9438662B2 (en) * 2007-04-30 2016-09-06 Microsoft Technology Licensing, Llc Enabling secure remote assistance using a terminal services gateway
US20080288304A1 (en) * 2007-05-18 2008-11-20 Bea Systems, Inc. System and Method for Enabling Decision Activities in a Process Management and Design Environment
US8996394B2 (en) 2007-05-18 2015-03-31 Oracle International Corporation System and method for enabling decision activities in a process management and design environment
US20080298366A1 (en) * 2007-05-31 2008-12-04 Microsoft Corporation Agnostic Network Architecture
US20090006612A1 (en) * 2007-06-27 2009-01-01 Arito Asai Communication system, proxy server, method of controlling same and control program therefor
US7783751B2 (en) * 2007-06-27 2010-08-24 Fujifilm Corporation Communication system, proxy server, method of controlling same and control program therefor
US8185916B2 (en) 2007-06-28 2012-05-22 Oracle International Corporation System and method for integrating a business process management system with an enterprise service bus
US20090006167A1 (en) * 2007-06-28 2009-01-01 Bea Systems, Inc. System and Method for Integrating a Business Process Management System with an Enterprise Service Bus
US8478861B2 (en) 2007-07-06 2013-07-02 Axeda Acquisition Corp. Managing distributed devices with limited connectivity
US20090172395A1 (en) * 2007-12-31 2009-07-02 International Business Machines Corporation System and Method for Service Virtualization Using a MQ Proxy Network
US8505031B2 (en) * 2008-08-18 2013-08-06 Oracle America, Inc. Method for sharing data
US20100042722A1 (en) * 2008-08-18 2010-02-18 Sun Microsystems, Inc. Method for sharing data
US8555371B1 (en) * 2009-07-17 2013-10-08 Directpacket Research, Inc. Systems and methods for management of nodes across disparate networks
US9477524B2 (en) * 2010-07-01 2016-10-25 Neodana, Inc. Partitioning processes across clusters by process type to optimize use of cluster specific configurations
US9959139B2 (en) 2010-07-01 2018-05-01 Dan C. Kang Partitioning processes across clusters by process type to optimize use of cluster specific configurations
US20130145375A1 (en) * 2010-07-01 2013-06-06 Neodana, Inc. Partitioning processes across clusters by process type to optimize use of cluster specific configurations
US10579426B2 (en) 2010-07-01 2020-03-03 Neodana, Inc. Partitioning processes across clusters by process type to optimize use of cluster specific configurations
US20150355946A1 (en) * 2014-06-10 2015-12-10 Dan-Chyi Kang “Systems of System” and method for Virtualization and Cloud Computing System
CN107135279A (en) * 2017-07-07 2017-09-05 网宿科技股份有限公司 It is a kind of to handle the method and apparatus that request is set up in long connection
CN109660562A (en) * 2019-01-30 2019-04-19 苏州德锐特成像技术有限公司 A kind of system and client synchronous for big data
US20200301818A1 (en) * 2019-03-21 2020-09-24 Sling Media Pvt Ltd Systems and methods for remote debugging
US11829277B2 (en) * 2019-03-21 2023-11-28 Dish Network Technologies India Private Limited Systems and methods for remote debugging
US20240045789A1 (en) * 2019-03-21 2024-02-08 Dish Network Technologies India Private Limited Systems and methods for remote debugging

Also Published As

Publication number Publication date
US7966418B2 (en) 2011-06-21
US10069939B2 (en) 2018-09-04
US20130067031A1 (en) 2013-03-14
US8291039B2 (en) 2012-10-16
US20150281403A1 (en) 2015-10-01
US20110276654A1 (en) 2011-11-10
US9002980B2 (en) 2015-04-07

Similar Documents

Publication Publication Date Title
US10069939B2 (en) Establishing a virtual tunnel between two computers
EP3471375B1 (en) Method and apparatus for managing field device based on cloud server
US9467327B2 (en) Server-mediated setup and maintenance of peer-to-peer client computer communications
JP4237754B2 (en) Personal remote firewall
US8239520B2 (en) Network service operational status monitoring
CN102356620B (en) Web application access
US8547874B2 (en) Method and system for learning network information
US20060031407A1 (en) System and method for remote network access
US11528326B2 (en) Method of activating processes applied to a data session
US11196833B1 (en) Proxy server synchronizer
KR20060050749A (en) Method and system in an ip network for using a network address translation(nat) with any type of application
US20090043889A1 (en) Communication system, data processing apparatus, server, data processing method, program that executes the data processing method, and recording medium to record the program
CN110661858A (en) Websocket-based intranet penetration method and system
JP4914479B2 (en) Remote access device, remote access program, remote access method, and remote access system
CN113114643B (en) Operation and maintenance access method and system of operation and maintenance auditing system
US7975005B2 (en) Using a proxy to redirect downloads
EP2169561B1 (en) communications system providing shared client-server communications interface and related methods
JP2017010388A (en) Http server and control method for the same, image forming apparatus, and program
Cisco Setting Up Devices in the VPN Solutions Center IPsec Environment
US20030212750A1 (en) Remotely controlling a computer over a network
Chang et al. Transport layer proxy for stateful UDP packet filtering
Fowler Cloud network engineering
Palakollu et al. Socket Programming
CN113923032B (en) Access method for application access control
Tan et al. Optimizing tunneled grid connectivity across firewalls

Legal Events

Date Code Title Description
AS Assignment

Owner name: AXEDA SYSTEMS OPERATING COMPANY INC., MASSACHUSETT

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SHEDRINSKY, FELIX;REEL/FRAME:014846/0983

Effective date: 20040630

AS Assignment

Owner name: AXEDA SYSTEMS OPERATING COMPANY, INC., MASSACHUSET

Free format text: CHANGE OF NAME;ASSIGNOR:EMATION, INC.;REEL/FRAME:015634/0483

Effective date: 20020211

AS Assignment

Owner name: JMI EQUITY FUND V, L.P.,MARYLAND

Free format text: GRANT OF SECURITY INTEREST IN PATENTS AND TRADEMARKS;ASSIGNORS:AXEDA SYSTEMS, INC.;AXEDA SYSTEMS OPERATING COMPANY, INC.;AXEDA IP, INC.;REEL/FRAME:016274/0846

Effective date: 20050708

Owner name: JMI EQUITY FUND V (AI), L.P.,MARYLAND

Free format text: GRANT OF SECURITY INTEREST IN PATENTS AND TRADEMARKS;ASSIGNORS:AXEDA SYSTEMS, INC.;AXEDA SYSTEMS OPERATING COMPANY, INC.;AXEDA IP, INC.;REEL/FRAME:016274/0846

Effective date: 20050708

Owner name: JMI EQUITY FUND V, L.P., MARYLAND

Free format text: GRANT OF SECURITY INTEREST IN PATENTS AND TRADEMARKS;ASSIGNORS:AXEDA SYSTEMS, INC.;AXEDA SYSTEMS OPERATING COMPANY, INC.;AXEDA IP, INC.;REEL/FRAME:016274/0846

Effective date: 20050708

Owner name: JMI EQUITY FUND V (AI), L.P., MARYLAND

Free format text: GRANT OF SECURITY INTEREST IN PATENTS AND TRADEMARKS;ASSIGNORS:AXEDA SYSTEMS, INC.;AXEDA SYSTEMS OPERATING COMPANY, INC.;AXEDA IP, INC.;REEL/FRAME:016274/0846

Effective date: 20050708

AS Assignment

Owner name: LAURUS MASTER FUND, LTD.,NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA SYSTEMS OPERATING COMPANY, INC.;REEL/FRAME:016551/0813

Effective date: 20050831

Owner name: LAURUS MASTER FUND, LTD., NEW YORK

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA SYSTEMS OPERATING COMPANY, INC.;REEL/FRAME:016551/0813

Effective date: 20050831

AS Assignment

Owner name: AXEDA SYSTEMS OPERATING COMPANY, INC.,MASSACHUSETT

Free format text: RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS;ASSIGNOR:LAURUS MATER FUND, LTD.;REEL/FRAME:016871/0043

Effective date: 20051202

Owner name: AXEDA IP, INC.,MASSACHUSETTS

Free format text: RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS;ASSIGNOR:LAURUS MATER FUND, LTD.;REEL/FRAME:016871/0043

Effective date: 20051202

Owner name: AXEDA SYSTEMS INC.,MASSACHUSETTS

Free format text: RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS;ASSIGNOR:LAURUS MATER FUND, LTD.;REEL/FRAME:016871/0043

Effective date: 20051202

Owner name: AXEDA SYSTEMS INC., MASSACHUSETTS

Free format text: RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS;ASSIGNOR:LAURUS MATER FUND, LTD.;REEL/FRAME:016871/0043

Effective date: 20051202

Owner name: AXEDA IP, INC., MASSACHUSETTS

Free format text: RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS;ASSIGNOR:LAURUS MATER FUND, LTD.;REEL/FRAME:016871/0043

Effective date: 20051202

Owner name: AXEDA SYSTEMS OPERATING COMPANY, INC., MASSACHUSET

Free format text: RELEASE OF SECURITY INTEREST IN TRADEMARKS AND PATENTS;ASSIGNOR:LAURUS MATER FUND, LTD.;REEL/FRAME:016871/0043

Effective date: 20051202

AS Assignment

Owner name: AXEDA CORPORATION,MASSACHUSETTS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:AXEDA SYSTEMS OPERATING COMPANY, INC.;REEL/FRAME:016875/0827

Effective date: 20051202

Owner name: AXEDA CORPORATION, MASSACHUSETTS

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:AXEDA SYSTEMS OPERATING COMPANY, INC.;REEL/FRAME:016875/0827

Effective date: 20051202

AS Assignment

Owner name: SILICON VALLEY BANK,CALIFORNIA

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA CORPORATION;REEL/FRAME:018420/0790

Effective date: 20061011

Owner name: SILICON VALLEY BANK, CALIFORNIA

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA CORPORATION;REEL/FRAME:018420/0790

Effective date: 20061011

AS Assignment

Owner name: MMV FINANCE INC., CANADA

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA CORPORATION;REEL/FRAME:023355/0619

Effective date: 20090924

Owner name: MMV FINANCE INC.,CANADA

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA CORPORATION;REEL/FRAME:023355/0619

Effective date: 20090924

STCF Information on status: patent grant

Free format text: PATENTED CASE

CC Certificate of correction
AS Assignment

Owner name: AXEDA CORPORATION, MASSACHUSETTS

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:SILICON VALLEY BANK;REEL/FRAME:028558/0744

Effective date: 20120713

AS Assignment

Owner name: AXEDA CORPORATION, MASSACHUSETTS

Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:MMV CAPITAL PARTNERS INC.;REEL/FRAME:028563/0446

Effective date: 20120713

AS Assignment

Owner name: COMERICA BANK, MICHIGAN

Free format text: SECURITY AGREEMENT;ASSIGNOR:AXEDA CORPORATION;REEL/FRAME:028629/0538

Effective date: 20120713

AS Assignment

Owner name: AXEDA CORPORATION, MASSACHUSETTS

Free format text: RELEASE OF SECURITY INTEREST;ASSIGNOR:COMERICA BANK;REEL/FRAME:033608/0704

Effective date: 20140822

FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: PTC INC., MASSACHUSETTS

Free format text: MERGER;ASSIGNOR:AXEDA CORPORATION;REEL/FRAME:036481/0543

Effective date: 20150309

AS Assignment

Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT, ILLINOIS

Free format text: SECURITY INTEREST;ASSIGNOR:PTC INC.;REEL/FRAME:037046/0930

Effective date: 20151104

Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT

Free format text: SECURITY INTEREST;ASSIGNOR:PTC INC.;REEL/FRAME:037046/0930

Effective date: 20151104

FEPP Fee payment procedure

Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

AS Assignment

Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT, ILLINOIS

Free format text: SECURITY INTEREST;ASSIGNOR:PTC INC.;REEL/FRAME:047480/0888

Effective date: 20180913

Owner name: JPMORGAN CHASE BANK, N.A., AS ADMINISTRATIVE AGENT

Free format text: SECURITY INTEREST;ASSIGNOR:PTC INC.;REEL/FRAME:047480/0888

Effective date: 20180913

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 8

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20230621