The present invention relates to a management system and a control method thereof.
Conventionally, a management system for managing a plurality of image forming apparatuses (hereinafter, referred to as devices) connected via a network has been known. The management system, for example, obtains information from devices using communication by various protocols or instructs the devices to execute processing. In a case of installing an application on a device or updating firmware of a device, instead of transmitting the application or firmware to the device, there are cases where an address for obtaining the application or firmware is instructed to the device. In such cases, the device obtains content from the designated address.
Also, a method of Japanese Patent Laid-Open No. 2009-140115, for example, is cited as a technique for preventing access to a WEB server from a plurality of clients from being concentrated. Japanese Patent Laid-Open No. 2009-140115 discloses that a relay server instructs a content cache server to cache content and replace, for a client, location information of content on a WEB server with location information on the cache server.
In a case where there are many devices to be managed, there are cases where a management system is configured by one management server (manager) for performing overall management and a plurality of agents for executing processing related to a device in accordance with an instruction of the management server. In a case where application or firmware obtainment processing is performed in such a configuration, the management server needs to directly communicate with the device and decide an update file that is necessary for the device; however, from the viewpoint of security, it is desirable to limit direct communication between the manager and the device.
However, there is a problem in that in the relay server described in Japanese Patent Laid-Open No. 2009-140115, it is difficult to limit direct communication between the manager that manages software and the device.
The present invention is made in view of the foregoing problem, and provides a technique for limiting direct communication between a manager that manages software and a device.
According to one aspect of the present invention, there is provided a management system comprising: a manager apparatus configured to manage a device; and an information processing apparatus configured to function as an agent that performs communication via a network with the device based on an instruction of the manager apparatus, wherein the manager apparatus transmits an instruction of a device operation to the agent, wherein the information processing apparatus, as a function of the agent, in a case where an update of software of a device has been instructed as a device operation from the manager apparatus, transmits to that device an update request, which includes URL information that indicates a reverse proxy which operates in the information processing apparatus, and wherein by the device performing transmission of data in response to the update request to the URL information that indicates the reverse proxy, that data is transferred to the manager apparatus via the information processing apparatus.
Further features of the present invention will become apparent from the following description of exemplary embodiments (with reference to the attached drawings).
Hereinafter, embodiments will be described in detail with reference to the attached drawings. Note, the following embodiments are not intended to limit the scope of the claimed invention. Multiple features are described in the embodiments, but limitation is not made to an invention that requires all such features, and multiple such features may be combined as appropriate. Furthermore, in the attached drawings, the same reference numerals are given to the same or similar configurations, and redundant description thereof is omitted.
[System Configuration]
The manager 101 is an apparatus realized by installing a device management application in an information processing apparatus. An agent is an apparatus that is realized by installing a device agent application on an information processing apparatus. By installing both a device management application and a device agent application on one information processing apparatus, an agent function can be realized in the apparatus in addition to a manager function. In such a case, the manager manages a plurality of devices via an agent in the apparatus itself and one or more agents that are realized in another apparatus on the network.
In the following, description is given assuming that the agent 102 sets the devices 104 and 105 as monitoring targets and that the agent 103 sets the devices 106 and 107 as monitoring targets. A detailed description will be given below using the agent 102 as a representative of the agents and the device 104 as a representative of the devices. Note that other agents and devices are assumed to perform equivalent operations.
The manager 101 instructs the agent 102 to perform operation related to the device 104. The agent 102 performs processing such as transmission of a request to the device 104 in accordance with an instruction from the manager 101 and transmits a processing result thereof to the manager 101. An example of processing by the agent 102 includes obtainment of device information and operation information from the device 104. Other examples include a change in setting values for the device 104, an instruction to install an application on the device 104, and the like.
In
Also, the configuration of the network 108 that connects each device to be capable of communication is not particularly limited. Note that the network 108 may include a combination of the Internet, a Local Area Network (LAN), a Wide Area Network (WAN), and the like, that any communication standard may be used, and that the network may be wired or wireless.
[Hardware Configuration]
The RAM 202 is a volatile storage region and functions as the main memory, a work area, and the like of the CPU 201. The external storage apparatus 211 is configured by a hard disk (HD), a solid state drive (SSD), or the like. The external storage apparatus 211 stores various applications including a boot program, an operating system (OS), an authentication server, an authentication client, and the like, as well as database data, user files, and the like. As described above, in the present embodiment, the CPU 201 of the information processing apparatus 200 operating as the manager 101 executes a device management application program. In addition, the CPU 201 of the information processing apparatus 200 operating as the agent 102 or 103 executes an agent application program.
The KBDC 204 is a keyboard controller and sends, to the CPU 201, input information from an input apparatus 209 such as a keyboard or a pointing device. The VC 205 is a video controller and controls display of a display device 210 configured by an LCD or the like. The DC 206 is a disk controller and controls accesses to and from the external storage apparatus 211. The NIC 207 is a communication controller and is connected to the network 212 to control communication with external apparatuses. Note that the configuration of the information processing apparatus illustrated in
[Software Configuration]
A firmware management unit 305 performs management of firmware of devices. Note that the size of firmware of devices has increased and if the entirety of the firmware is forwarded when updating the firmware of devices, it would require a lot of time and bandwidth. In order to avoid this, configuration is taken so as to connect to a server for firmware update and instruct a device to obtain a differential file of a difference from the current firmware of the device.
A SOAP HTTP/HTTPS server 306 receives a SOAP message of a firmware update request, retrieves a function in the firmware management unit 305, and returns a result thereof to a request transmission source. Note that the HTTP/HTTPS server 304 and the SOAP HTTP/HTTPS server 306 are configured as separate elements here; however, a single HTTP/HTTPS server may provide these functions.
In the firmware management unit 305 firmware of various devices are stored. The device 104 invokes a function of the firmware management unit 305 via the HTTP/HTTPS server 304 together with product information of the device itself and version information of firmware as device information. The firmware management unit 305 returns address information (URL information) for obtaining data that is necessary for updating firmware of the device 104 from the product information and the version information in the request. The device 104, by transmitting an HTTP/HTTPS request that includes the product information of the device itself and version information of firmware to that address, receives data necessary for a firmware update and then performs a firmware update of the device itself.
An HTTP/HTTPS reverse proxy 313 transmits the received HTTP request to the SOAP HTTP/HTTPS server 306 in the manager 101 and returns a response from the SOAP HTTP/HTTPS server 306 to a transmission source of the HTTP request. Here, the HTTP request is POST and an HTTP body is a SOAP XML message.
[Data Obtainment Processing]
/cache/applications/ocr.jar
/cache/firmware/4cb89c08-76a4-4caa-8c9d-2aa1021faac5
Also, in the present embodiment, the agent 102 manages data by a table structure illustrated in the following Table 1.
In the table illustrated in Table 1, a path indicates a path passed by an argument (i.e., a path designated by a GET request that the HTTP/HTTPS server 311 received). The file name indicates the file name of a file when data indicated by the path is obtained and saved in the agent 102. The last access date and time indicates the date and time at which the data obtainment processing is invoked using the path as an argument. The content type is a character string indicating the type of data.
In step S401, the cache control unit 312 confirms whether or not data indicated by a path passed by an argument has already been cached. Here, the table illustrated in Table 1 is referenced, and in a case where there is a path passed by an argument, it is determined that data has already been cached and in a case where there is no path, it is determined that data has not been cached. In a case where the requested data has already been cached (YES in step S401), the processing advances to step S405, and in a case where the requested data has not been cached (NO in step S401), the processing advances to step S402.
In step S402, the cache control unit 312 creates a URL (Uniform Resource Locator) of the manager 101 that corresponds to the requested path. For example, in a case where the requested path is “/cache/applications/sso.jar”, the path to be created will be “/public/applications/sso.jar”. In this way, a portion of the requested path character string (cache) is replaced with another character string (public).
In step S403, the cache control unit 312 transmits to the HTTP/HTTPS server 304 of the manager 101 an HTTP or HTTPS GET request in relation to the URL created in step S402 via the HTTP/HTTPS server 311. The cache control unit 312 saves, in the file, data included in a response to the request.
In step S404, the cache control unit 312 adds to the table illustrated in Table 1 an entry related to the data obtained from the manager 101. In the addition in this case, a content type is set to be the content type indicated in the HTTP header in the response from the HTTP/HTTPS server 304 in the manager 101.
In step S405, the cache control unit 312 updates the value of the last access date and time in the table illustrated in Table 1 to the current date and time.
In step S406, the cache control unit 312 returns to the HTTP/HTTPS server 311 the data of the file indicated by the file name and content type in the table illustrated in Table 1. At this time, the HTTP/HTTPS server 311 sets the value of the content type in the HTTP header of the response to the device and also sets the corresponding data in the body of the response. Then, the HTTP/HTTPS server 311 returns the response to the caller (device) of the GET request.
[Processing Sequence]
First, the manager 101 transmits to the HTTP/HTTPS server 311 of the agent 102 a request that includes an instruction to install an application to the device 104 (step S501). In the instruction here, a URL 502 (e.g., “http://192.168.10.100/public/applications/ocr.jar”) for the device 104 to obtain an application is included. The URL in this case indicates the storage destination of program data of the application managed by the manager 101.
The HTTP/HTTPS server 311 of the agent 102, when it receives a request from the manager 101, calls the task execution unit 310 in order to execute the requested instruction. The task execution unit 310 replaces the URL 502 included in the above request with a URL 504 for cache of the agent 102 (e.g., “http://192.168.10.200/cache/applications/ocr.jar”). Here, in a case where the manager 101 and the agent 102 are operating in the same information processing apparatus, the above-described replacement is not performed. The case of operating in the same information processing apparatus corresponds to, in other words, a case where a host address portion of the URL 502 (corresponding to the IP address portion of the URL described above) is the same as the address of the host on which the agent 102 operates.
Next, the task execution unit 310 transmits a request to the device 104 (step S503). The request in this case includes an instruction for the device 104 to use the replaced URL 504 to obtain and install the application.
The device 104 that received the request from the agent 102 transmits to the agent 102 an obtainment request for obtaining an application in relation to the URL 504 included in the request (step S505).
The HTTP/HTTPS server 311 of the agent 102, when it receives the obtainment request from the device 104, invokes the data obtainment processing described in
The HTTP/HTTPS server 304 of the manager 101 returns to the agent 102 data 508 requested by the URL (step S507).
The cache control unit 312 of the agent 102 caches the data 508 obtained from the manager 101 in accordance with the processing described in
The processing in steps S521 to S523 is the same in steps S501 to S505 of
The cache control unit 312 of the agent 102 returns the cached data 508 to the device 105 by the HTTP/HTTPS server 311 (step S524). Then, the device 105 installs the application using the data 508 received from the agent 102. Then, the present processing sequence is ended.
In
In
The agent 102 may perform processing of periodically maintaining cache management information of the table illustrated in Table 1. For example, entries for which a certain amount of time has passed since being registered in the table and data thereof may be deleted. Specifically, for entries that are greater than or equal to a designated value (e.g., 24 hours) between the last access date and time and the current date and time, processing of deleting a file in the agent 102 indicated by the file path of those entries and deleting the corresponding entries in Table 1 may be performed.
As describe above, in the present embodiment, software cache function is arranged for the agent. This makes it possible to, when an application or firmware obtainment is performed, avoid concentration of accesses to the manager and lighten the burden on the manager.
[Processing Sequence]
Next,
First, an overview of a series of processing will be described. The device queries the agent for necessary firmware. The agent transfers that query to the manager and transfers a response from the manager to the device. By that transfer of a response, the manager instructs the device to obtain a firmware update file from the agent. Then, in accordance with that instruction, the device obtains a firmware update file from the agent. At that time, the agent, in a case where a firmware update file is in a cache, transmits the update file in the cache to the device. Meanwhile, in a case where there is no update file in the cache, the agent obtains an update file from the manager, saves it in the cache, and then transmits the update file to the device.
In
The HTTP/HTTPS server 311 of the agent 102 receives that request and calls the task execution unit 310 in order to execute the requested processing. The task execution unit 310 replaces the URL 602 included in that request with a URL′ 604 (e.g., “http://192.168.10.200:8080/ws/basic/”) of the HTTP/HTTPS reverse proxy 313 of the agent 102 (in the agent) and then transmits a firmware update request to the device 104 (step S603).
The device 104 receives that request and then transmits in relation to the URL′ 604 included in the request an HTTP/HTTPS request that includes a SOAP message 606, which includes product information of the device itself and version information of firmware (step S605).
The HTTP/HTTPS reverse proxy 313 of the agent 102, when it receives this request, transmits the SOAP message 606 in the request to a URL (e.g., “https://192.168.10.100:8443/ws/secure/”) of the SOAP HTTP/HTTPS server 306 of the manager 101 (step S607) as is. Here, the request from the device 104 is HTTP; however, an HTTPS protocol is used in order to improve confidentiality in the communication between the agent and the manager.
The SOAP HTTP/HTTPS server 306 in the manager 101 receives that request and invokes firmware update processing of the firmware management unit 305.
Here,
First, in step S701, the firmware management unit 305 fetches product information of the device and version information of firmware of the device 104 included in the SOAP message.
In step S702, the firmware management unit 305 decides the file necessary for updating the firmware of the device 104 based on the information fetched in step S701.
Next, in step S703, the firmware management unit 305 obtains information of the agent 102 associated with the device 104.
In step S704, the firmware management unit 305 confirms whether or not the agent 102 is operating on same host as the manager 101. As a result of confirmation, in a case where the agent 102 and the manager 101 are operating on the same host, the processing advances to step S705.
In step S705, the firmware management unit 305 designates a URL for obtaining a file from the URL of the HTTP/HTTPS server 304 of the manager 101. The URL is, for example, “https://192.168.10.100/public/firmware/ca071592-3a64-4c88-9013-cd28a73a7901”.
Meanwhile, in a case where the agent 102 and the manager 101 are operating on different hosts, the processing advances to step S706.
In step S706, the firmware management unit 305 designates a URL for obtaining a file via the cache of the agent 102. The URL here is a URL of a reverse proxy of the agent 102 and is, for example, “https://192.168.10.200/cache/firmware/ca071592-3a64-4c88-9013-cd28a73a7901”.
Lastly, in step S707, the firmware management unit 305 returns the URL decided in step S705 or S706 to a caller of processing (device).
As described above, in a case where the agent 102 and the manager 101 are operating on the same host, the cache function of the agent 102 is not used at a time of obtaining firmware data and in a case where they are operating on different hosts, the cache function is used.
Note that in the present embodiment, description is given assuming that the agent is operating on the same host as the manager. In other words, it is Yes in step S704, the processing advances to step S705, and in step S707, the URL of the manager is returned.
The series of processing in
Then, the manager 101 returns this URL″ 609 as a response to the request from the HTTP/HTTPS reverse proxy 313 of the agent 102 in step S607 (step S608).
The HTTP/HTTPS reverse proxy 313 of the agent 102 receives this response. Then, the HTTP/HTTPS reverse proxy 313 returns this response, which includes the URL″ 609 for firmware obtainment, to the device 104 as is (step S610).
The device 104, when it receives this response, transmits an HTTP/HTTPS request to the URL″ 609 included in the response received in step S610 in order to obtain data necessary for updating firmware (step S611).
The HTTP/HTTPS server 311 of the agent 102 that received this HTTP/HTTPS request invokes the data obtainment processing described in
Lastly, the device 104 that received the response in step S615 executes firmware update processing of the device itself using data 614 included in the response.
It goes without saying that here, in a case where data designated by the cache control unit 312 of the agent 102 is cached, the processing described in steps S523 to S524 of
As described above, according to the sequence of
[Modification]
There are cases where the device 104 is set so as not to permit, at the time of HTTPS communication, communication with an HTTPS server that has an untrusted certificate. Here, assume that the HTTPS server of the manager 101 is operating with an officially issued certificate but the HTTPS server of the agent 102 or the agent 103 is operating with a self-signed certificate as the main purpose is to conceal communication with the manager 101. In this case, if the self-signed certificate of the agent is not registered to the device 104, the device 104 will reject the HTTPS connection to the agent 102 from the device 104.
In a case where in such a situation, designation is performed to use the device 104 and HTTPS, the management system operates so as not to use the cache function or the HTTP/HTTPS reverse proxy 313 of the agent.
More specifically, URL replacement is not implemented in the following processing that has been described in the above embodiments.
1. step S503 of
2. step S522 of
3. step S603 of
Furthermore, the determination processing in step S704 of
Note that in the present embodiment, description was given using an example of a device firmware update; however, it goes without saying that the present invention can be widely applied for the device to obtain an update file for a software update.
By virtue of the present invention, it becomes possible to limit direct communication between a manager that manages software and a device. Accordingly, it is possible to improve security.
Embodiment(s) of the present invention can also be realized by a computer of a system or apparatus that reads out and executes computer executable instructions (e.g., one or more programs) recorded on a storage medium (which may also be referred to more fully as a ‘non-transitory computer-readable storage medium’) to perform the functions of one or more of the above-described embodiment(s) and/or that includes one or more circuits (e.g., application specific integrated circuit (ASIC)) for performing the functions of one or more of the above-described embodiment(s), and by a method performed by the computer of the system or apparatus by, for example, reading out and executing the computer executable instructions from the storage medium to perform the functions of one or more of the above-described embodiment(s) and/or controlling the one or more circuits to perform the functions of one or more of the above-described embodiment(s). The computer may comprise one or more processors (e.g., central processing unit (CPU), micro processing unit (MPU)) and may include a network of separate computers or separate processors to read out and execute the computer executable instructions. The computer executable instructions may be provided to the computer, for example, from a network or the storage medium. The storage medium may include, for example, one or more of a hard disk, a random-access memory (RAM), a read only memory (ROM), a storage of distributed computing systems, an optical disk (such as a compact disc (CD), digital versatile disc (DVD), or Blu-ray Disc (BD)™), a flash memory device, a memory card, and the like.
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application No. 2020-136379, filed Aug. 12, 2020, which is hereby incorporated by reference herein in its entirety.
Number | Date | Country | Kind |
---|---|---|---|
2020-136379 | Aug 2020 | JP | national |