WO2020145100A1 - 更新装置および更新方法 - Google Patents

更新装置および更新方法 Download PDF

Info

Publication number
WO2020145100A1
WO2020145100A1 PCT/JP2019/050224 JP2019050224W WO2020145100A1 WO 2020145100 A1 WO2020145100 A1 WO 2020145100A1 JP 2019050224 W JP2019050224 W JP 2019050224W WO 2020145100 A1 WO2020145100 A1 WO 2020145100A1
Authority
WO
WIPO (PCT)
Prior art keywords
file
package
access
package including
source file
Prior art date
Application number
PCT/JP2019/050224
Other languages
English (en)
French (fr)
Inventor
健一郎 武藤
中津留 毅
和巳 木下
公洋 山越
Original Assignee
日本電信電話株式会社
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 日本電信電話株式会社 filed Critical 日本電信電話株式会社
Priority to EP19909433.5A priority Critical patent/EP3889814B1/en
Priority to CN201980088321.2A priority patent/CN113272808B/zh
Priority to AU2019420941A priority patent/AU2019420941B2/en
Priority to US17/421,719 priority patent/US11809580B2/en
Publication of WO2020145100A1 publication Critical patent/WO2020145100A1/ja

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/604Tools and structures for managing or administering access control systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/51Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems at application loading time, e.g. accepting, rejecting, starting or inhibiting executable software based on integrity or source reliability
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/50Monitoring users, programs or devices to maintain the integrity of platforms, e.g. of processors, firmware or operating systems
    • G06F21/57Certifying or maintaining trusted computer platforms, e.g. secure boots or power-downs, version controls, system software checks, secure updates or assessing vulnerabilities
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F8/00Arrangements for software engineering
    • G06F8/60Software deployment
    • G06F8/65Updates
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/10Network architectures or network communication protocols for network security for controlling access to devices or network resources
    • H04L63/101Access control lists [ACL]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F2221/00Indexing scheme relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/21Indexing scheme relating to G06F21/00 and subgroups addressing additional information or applications relating to security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F2221/2141Access rights, e.g. capability lists, access control lists, access tables, access matrices

Definitions

  • the present invention relates to an updating device and an updating method.
  • access control technology for controlling permission/prohibition of access to files has been studied in control communication devices such as servers. For example, based on a preset access control list (hereinafter, also referred to as ACL (Access Control List)), a technology has been proposed that permits execution only for access to an executable file whose integrity has been confirmed (non- See Patent Document 1).
  • ACL Access Control List
  • An access control technique has also been proposed in which a process that permits access to a file is set in advance, the process that accesses the file is monitored, and the access to the file is limited to a specific process.
  • an ACL of an access control policy that confirms the integrity of a file is set based on the matching of hash values of the file.
  • an access control technique is applied in which a process that permits access to the file is set in advance and the process that accesses the file is limited. However, if the execution file of the process that accesses such a file has been tampered with, access from the tampered process may be permitted.
  • the ACL of an inappropriate access control policy may be set. For example, when the operator himself creates an access control policy and updates the ACL during system operation, an access control policy that does not need to be set may be created and applied carelessly. Further, when the ACL is updated by utilizing the access control policy created by a third party when installing software, the access control policy may be diverted without noticing it as a malicious access control policy. .. In either case, the security level of the ACL is lowered, which may cause a security hole.
  • the present invention has been made in view of the above, and an object thereof is to limit the addition of an inappropriate access control policy and appropriately set an access control list.
  • an update device includes a correspondence between a file and a package including the file, and information indicating presence/absence of a dependency between a plurality of packages.
  • a storage unit that stores the package management information, an access control list including a correspondence between a file and an access source file that is permitted to access the file, and a combination of the file and the access source file are specified.
  • a specifying unit that specifies a package including the file and a package including the access source file, a package including the specified file and the access source file
  • an adding unit that adds the specified combination to the access control list when the included packages have the same or mutually dependent relationship.
  • FIG. 1 is a diagram for explaining the processing outline of the access control device.
  • FIG. 2 is a schematic diagram illustrating the schematic configuration of the update device of the present embodiment.
  • FIG. 3 is a diagram illustrating a data configuration of package management information.
  • FIG. 4 is a diagram illustrating the data structure of the ACL.
  • FIG. 5 is a diagram for explaining the processing of the adding unit.
  • FIG. 6 is a diagram for explaining the processing of the adding unit.
  • FIG. 7 is a flowchart showing the update processing procedure.
  • FIG. 8 is a diagram illustrating an example of a computer that executes the update program.
  • FIG. 1 is a diagram for explaining a processing outline of the access control device. As shown in FIG. 1, when the access control device detects a process that accesses an access destination file targeted for access control, based on the ACL representing the access control policy, the access control device accesses the access destination file. Access control is performed to control permission/prohibition.
  • the access control device permits access to the access destination file by this process only when the executable file of the detected process is set in the preset ACL as the access source file for the access destination file. Based on this ACL, the access control device confirms the integrity of both the access destination file and the access source file and permits the access.
  • the update device of this embodiment performs update processing for updating the ACL of the access control device.
  • the security level is lowered, which may cause a security hole.
  • package management information such as Linux (registered trademark) RPM (RPM Package Manager) is known.
  • the package management information is information for collectively managing execution files, setting files, library files, and the like. Each package contains at least the executable files included during installation. It may include files generated after installation.
  • the package management information includes a dependency relationship between packages, which is assumed by the package developer of the software, which package software requires which package software, that is, which package depends on which package. Is included.
  • the update device of the present embodiment uses the package management information to consider whether the access between files is assumed by the package developer of the software, and at least restricts the addition of ACL to unnecessary ACL. Execute the update process.
  • the updating device 10 is a device mounted on hardware different from the access control device, but may be a device incorporated in the access control device.
  • FIG. 2 is a schematic diagram illustrating the schematic configuration of the update device of the present embodiment.
  • the update device 10 is realized by a general-purpose computer such as a personal computer, and includes an input unit 11, an output unit 12, a communication control unit 13, a storage unit 14, and a control unit 15.
  • the input unit 11 is realized by using an input device such as a keyboard and a mouse, and inputs various instruction information such as processing start to the control unit 15 in response to an input operation by an operator.
  • the output unit 12 is realized by a display device such as a liquid crystal display and a printing device such as a printer.
  • the communication control unit 13 is realized by an NIC (Network Interface Card) or the like, and controls communication between an external device and a control unit 15 via a telecommunication line such as a LAN (Local Area Network) or the Internet.
  • the communication control unit 13 may be an external device such as a management device that manages package management information used in the update process described later, an access control device that manages the ACL subject to the update process, or a file management system that manages a large number of files. It controls communication between the device and the control unit 15.
  • the storage unit 14 is realized by a semiconductor memory device such as a RAM (Random Access Memory) or a flash memory (Flash Memory), or a storage device such as a hard disk or an optical disk.
  • the storage unit 14 stores the package management information 14a and the ACL 14b.
  • the storage unit 14 may be configured to communicate with the control unit 15 via the communication control unit 13.
  • FIG. 3 is a diagram illustrating the package management information 14a.
  • the package management information 14a includes correspondence between files and packages including the files, and information indicating presence/absence of dependency among a plurality of packages.
  • Each package includes at least an executable file included at the time of installation and a file generated after the installation.
  • the package management information 14a is information in which an existing destination package and a file included in the own package are associated with each other for each package.
  • the dependent package needs the dependent package in order for the package to function.
  • the package “openssl” includes the files “/.../openssl”, “/.../openssl.conf”, and the like.
  • the packages of the dependency destination that has the package “mod_ssl” as the dependency source are “openssl” and “httpd”.
  • "/.../” is a notation in which the file path is omitted.
  • the package “openssl” it is illustrated that there is no dependent package assumed by the software package developer.
  • the update device 10 acquires the package management information 14 a via the input unit 11 or the communication control unit 13 in advance and stores it in the storage unit 14 prior to the update processing described later.
  • FIG. 4 is a diagram illustrating the ACL 14b.
  • the ACL 14b includes a correspondence between a file and an access source file that is permitted to access the file. That is, as described above, the ACL 14b is a white list that specifies access source files that are permitted to access the access destination file.
  • the update device 10 acquires the ACL 14b of the access control device via the input unit 11 or the communication control unit 13 in advance and stores it in the storage unit 14 prior to the update processing described later.
  • the control unit 15 is realized by using a CPU (Central Processing Unit) or the like and executes a processing program stored in the memory. Thereby, the control unit 15 functions as the specifying unit 15a and the adding unit 15b, as illustrated in FIG.
  • a CPU Central Processing Unit
  • the control unit 15 functions as the specifying unit 15a and the adding unit 15b, as illustrated in FIG.
  • the identifying unit 15a refers to the package management information 14a and identifies the package including the access destination file and the package including the access source file. ..
  • the specifying unit 15a specifies a package including each of the specified access destination file and access source file.
  • the identifying unit 15a determines that the package of the access destination file is “ openssl”. The identifying unit 15a also identifies the package "mod_ssl" of the access source file.
  • the adding unit 15b adds the specified combination to the ACL 14b when the package including the specified file and the package including the access source file have the same or mutual dependency.
  • FIG. 5 and FIG. 6 are explanatory diagrams for explaining the processing of the adding unit 15b.
  • the addition unit 15b adds the specified combination to the ACL 14b when the package of the access source file and the package of the access destination file are the same, as indicated by the arrow a in FIG.
  • the adding unit 15b when the package of the access source file and the package of the access destination file have a mutual dependency relationship, that is, when they correspond to the package of the dependency source or the dependency destination, the addition unit 15b sets the specified combination in the ACL 14b. Add to.
  • the combination indicated by the arrow b in FIG. 5 is regarded as an access control policy necessary for cooperation between the dependent package and the dependent package, and is added to the ACL 14b.
  • the adding unit 15b may further output a warning when the package including the access destination file and the package including the access source file are different and have a mutual dependency relationship. Further, when the package including the access destination file and the package including the access source file are different from each other and there is a mutual dependency relationship, the adding unit 15b replaces the specified combination with the ACL 14b. The addition may be rejected or an instruction as to whether or not the addition can be accepted.
  • the adding unit 15b outputs a warning to inquire whether the combination indicated by the arrow b in FIG. 5 is against the access control policy, or requests the operator to approve whether the addition to the ACL 14b is possible. You may Alternatively, the addition unit 15b may uniformly reject addition to the ACL 14b according to the operation policy.
  • the adding unit 15b determines that the package including the access destination file and the package including the access source file are different from each other, have no mutual dependency, and have no dependency via another package, The specified combination is added to the ACL 14b.
  • the combination indicated by the arrow c in FIG. 5 is an access control policy between independent packages having no mutual dependency relationship, which is outside the assumption of the software package developer, but between the files required by the operator. It may be access. Therefore, the adding unit 15b adds this combination to the ACL 14b.
  • the combination shown by the arrow d in FIG. 6 cannot be traced between the access source package and the access destination package through another package. Therefore, since the combination indicated by the arrow d in FIG. 6 is an access control policy between independent packages and may be a necessary file-to-file access, like the combination indicated by the arrow c in FIG.
  • the addition unit 15b is added to the ACL 14b.
  • the adding unit 15b determines that the package including the access destination file and the package including the access source file are different from each other, have no mutual dependency, and have no dependency via another package. It also outputs a warning.
  • the adding unit 15b outputs a warning so as to leave the judgment to the operator. For example, the adding unit 15b outputs a warning to inquire whether this combination violates the access control policy.
  • the adding unit 15b determines that the package including the access destination file and the package including the access source file are different from each other, have no mutual dependency, and have no dependency via another package, Instead of adding the specified combination to the ACL 14b, the addition may be rejected or an instruction as to whether or not the addition can be accepted. That is, the adding unit 15b may request the operator to approve whether the addition to the ACL 14b is possible. Alternatively, the addition unit 15b may uniformly reject addition to the ACL 14b for this combination.
  • the addition unit 15b uses a combination other than the above, that is, a combination in which the package including the access destination file and the package including the access source file have a dependency relationship via another package, which is indicated by an arrow e in FIG. Does not add to the ACL 14b. If there is no direct mutual dependency between the package including the access destination file and the package including the access source file, it is likely that the access is not expected by the software package developer. If such access is carelessly permitted, the security level of the ACL 14b may decrease. Therefore, the adding unit 15b regards such a combination as addition of an unnecessary access policy and does not add it to the ACL 14b.
  • the dependency in the package management information may be omitted or may be missed.
  • the adding unit 15b notifies the operator. You may request approval of permission to add to the ACL 14b. Alternatively, it may be added uniformly and a warning for leaving the judgment to the operator may be output. As a result, when there is an indirect dependency between packages, addition is not rejected uniformly, and if the definition of package management information is omitted or missed, it is added to the ACL 14b. be able to.
  • the addition unit 13b outputs the ACL 14b updated by the update process to the access control device.
  • the access control device can apply the updated ACL 14b to control permission/prohibition of access between files.
  • FIG. 7 is a flowchart showing the update processing procedure.
  • the flowchart of FIG. 7 starts, for example, at the timing when the user performs an operation input instructing the start.
  • the identifying unit 15a receives an input designating a combination of an access destination file and an access source file. Further, the identifying unit 15a refers to the package management information 14a and identifies the package including the access destination file and the package including the access source file.
  • the adding unit 15b confirms whether the package including the specified access destination file is the same as the package including the access source file (step S1).
  • the adding unit 15b adds the specified combination to the ACL 14b (step S6). ..
  • the adding unit 15b confirms whether the package including the specified file and the package including the access source file have a mutual dependency relationship. .. First, the adding unit 15b confirms whether the package including the specified access destination file is a dependency destination of the package including the access source file (step S2). The adding unit 15b determines that the package including the access destination file is a dependency destination of the package including the access source file (step S2, Yes). The specified combination is added to the ACL 14b (step S6).
  • the adding unit 15b determines that the package including the access source file includes the access destination file. It is confirmed whether or not the package is a dependence destination of the package (step S3).
  • the adding unit 15b adds the specified combination to the ACL 14b (step S6).
  • the adding unit 15b specifies Instead of adding the created combination to the ACL 14b, an instruction as to whether or not the addition is possible may be received. That is, even if the addition unit 15b outputs a warning to inquire whether the specified combination violates the access control policy or requests the operator to approve whether the addition to the ACL 14b is permitted. Good. Alternatively, the addition unit 15b may uniformly reject addition to the ACL 14b according to the operation policy.
  • the adding unit 15b includes the package including the access destination file and the access source file. Check if there is a dependency with another package via another package.
  • the adding unit 15b confirms whether or not the package of the access destination file is reached by tracing the package of the access destination file dependent (step S4).
  • the adding unit 15b determines that the access of the specified combination is not performed by the software package developer. It is not added to the ACL 14b (step S7).
  • step S4 if the addition unit 15b does not reach the package of the access destination file by tracing the package of the dependence destination of the access source file (step S4, No), the adding unit 15b traces the package of the dependence destination of the access destination file by the access source. It is confirmed whether the file package can be reached (step S5).
  • step S5 When the package of the access source file is reached by tracing the package of the dependence destination of the access destination file (Yes in step S5), the adding unit 15b determines that the combination of the designated combination is the access that the package developer of the software does not assume. It is not added to the ACL 14b (step S7).
  • the adding unit 15b is designated as the access control policy between independent packages. The combination is added to the ACL 14b (step S8). Further, the adding unit 15b outputs a warning for entrusting the operator with the determination.
  • the adding unit 15b outputs a warning to inquire whether this combination violates the access control policy.
  • the adding unit 15b may request the operator to approve whether the addition to the ACL 14b is possible.
  • the addition unit 15b may uniformly reject addition to the ACL 14b for this combination.
  • step S7 instead of uniformly rejecting the addition, the operator may be requested to approve whether or not the addition to the ACL 14b is possible. Alternatively, it may be added uniformly and a warning for leaving the judgment to the operator may be output. Accordingly, if the definition of the package management information is omitted or missed, the package management information can be added to the ACL 14b.
  • the update device 10 can update the ACL 14b by limiting at least addition of an inappropriate access control policy. Therefore, the relaxation of the security level of the ACL 14b can be minimized.
  • the storage unit 14 includes a package including a file and a package including the file, and information indicating whether there is a dependency relationship between the plurality of packages.
  • the management information 14a and the ACL 14b including the correspondence between the access destination file and the access source file that is permitted to access the access destination file are stored.
  • the identifying unit 15a refers to the package management information 14a and identifies the package including the access destination file and the package including the access source file. Identify.
  • the adding unit 15b adds the specified combination to the ACL 14b when the package including the specified access destination file and the package including the access source file are the same or have a mutual dependency relationship.
  • the update device 10 restricts addition of at least an inappropriate access control policy by adding the ACL 14b to the ACL 14b on condition that the combination of accesses has a dependency relationship assumed by the software package developer.
  • the ACL 14b can be updated. Therefore, the relaxation of the security level of the ACL 14b can be minimized. In this way, the update device 10 can appropriately set the ACL.
  • the adding unit 15b may further output a warning when the package including the access destination file is different from the package including the access source file and there is a mutual dependency.
  • the adding unit 15b may change the addition of the designated combination to the ACL 14b, and reject the addition, or accept an instruction as to whether or not the addition is possible. As a result, it becomes possible to entrust the operator's decision as to whether or not to add to the ACL 14b.
  • the adding unit 15b determines that the package including the access destination file and the package including the access source file are different from each other, have no mutual dependency, and have no dependency via another package, The specified combination is added to the ACL 14b.
  • the adding unit 15b further outputs a warning.
  • the adding unit 15b may change the addition of the designated combination to the ACL 14b and reject the addition or accept an instruction of whether or not the addition is possible. As a result, it becomes possible to entrust the operator's decision as to whether or not to add to the ACL 14b.
  • the addition unit 15b restricts addition of a combination other than the above to the ACL 14b in which the package including the access destination file and the package including the access source file have a dependency relationship via another package. be able to. In other words, it is possible to restrict the addition of unnecessary access to the ACL 14b that has no direct mutual dependency between packages and is likely to be an access that is not expected by the software package developer.
  • the update device 10 can be implemented by installing an update program that executes the above update processing as package software or online software in a desired computer.
  • the information processing apparatus can be caused to function as the updating apparatus 10 by causing the information processing apparatus to execute the above update program.
  • the information processing apparatus referred to here includes a desktop or notebook personal computer.
  • the information processing device includes in its category a smartphone, a mobile communication terminal such as a mobile phone or a PHS (Personal Handyphone System), and a slate terminal such as a PDA (Personal Digital Assistant).
  • FIG. 8 is a diagram illustrating an example of a computer that executes the update program.
  • the computer 1000 has, for example, a memory 1010, a CPU 1020, a hard disk drive interface 1030, a disk drive interface 1040, a serial port interface 1050, a video adapter 1060, and a network interface 1070. These units are connected by a bus 1080.
  • the memory 1010 includes a ROM (Read Only Memory) 1011 and a RAM 1012.
  • the ROM 1011 stores, for example, a boot program such as BIOS (Basic Input Output System).
  • BIOS Basic Input Output System
  • the hard disk drive interface 1030 is connected to the hard disk drive 1031.
  • the disk drive interface 1040 is connected to the disk drive 1041.
  • a removable storage medium such as a magnetic disk or an optical disk is inserted into the disk drive 1041.
  • a mouse 1051 and a keyboard 1052 are connected to the serial port interface 1050, for example.
  • a display 1061 is connected to the video adapter 1060, for example.
  • the hard disk drive 1031 stores, for example, an OS 1091, an application program 1092, a program module 1093, and program data 1094. Each information described in the above embodiment is stored in, for example, the hard disk drive 1031 or the memory 1010.
  • the update program is stored in the hard disk drive 1031 as a program module 1093 in which a command executed by the computer 1000 is described, for example.
  • the program module 1093 in which each process executed by the updating device 10 described in the above embodiment is described is stored in the hard disk drive 1031.
  • the data used for information processing by the update program is stored as program data 1094 in, for example, the hard disk drive 1031.
  • the CPU 1020 reads the program module 1093 and the program data 1094 stored in the hard disk drive 1031 into the RAM 1012 as necessary, and executes the above-described procedures.
  • the program module 1093 and the program data 1094 related to the update program are not limited to being stored in the hard disk drive 1031.
  • the program module 1093 or the program data 1094 may be stored in a removable storage medium and read by the CPU 1020 via the disk drive 1041 or the like. May be done.
  • the program module 1093 and program data 1094 related to the update program are stored in another computer connected via a network such as LAN or WAN (Wide Area Network) and read by the CPU 1020 via the network interface 1070. May be.

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • General Engineering & Computer Science (AREA)
  • Software Systems (AREA)
  • Computer Hardware Design (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Automation & Control Theory (AREA)
  • Health & Medical Sciences (AREA)
  • Bioethics (AREA)
  • General Health & Medical Sciences (AREA)
  • Computing Systems (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
  • Stored Programmes (AREA)

Abstract

記憶部(14)が、ファイルと該ファイルを含むパッケージとの対応付けと、複数のパッケージ間の依存関係の有無を示す情報とを含むパッケージ管理情報(14a)と、アクセス先ファイルと該アクセス先ファイルへのアクセスが許可されているアクセス元ファイルとの対応付けを含むACL(14b)と、を記憶する。特定部(15a)が、アクセス先ファイルとアクセス元ファイルとの組み合わせが指定された場合に、パッケージ管理情報(14a)を参照し、アクセス先ファイルが含まれるパッケージと、アクセス元ファイルが含まれるパッケージとを特定する。追加部(15b)が、特定されたアクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが同一、または相互に依存関係がある場合に、指定された組み合わせをACL(14b)に追加する。

Description

更新装置および更新方法
 本発明は、更新装置および更新方法に関する。
 従来、サーバ等の制御通信機器において、ファイルへのアクセスの許否を制御するアクセス制御技術が検討されている。例えば、予め設定されたアクセス制御リスト(以下、ACL(Access Control List)とも記す。)に基づいて、完全性が確認された実行ファイルに対するアクセスのみ、実行を許可する技術が提案されている(非特許文献1参照)。また、ファイルへのアクセスを許可するプロセスを予め設定しておき、ファイルにアクセスするプロセスを監視して、ファイルへのアクセスを特定のプロセスに限定するアクセス制御技術も提案されている。
"AppLocker 規則条件の種類について"、[online]、2015年10月26日、MSDNライブラリ、[2018年11月28日検索]、インターネット<URL:https://msdn.microsoft.com/ja-jp/library/ee460959(v=ws.11).aspx>
 しかしながら、従来の技術では、アクセス制御ポリシを表すACLの適切な設定が困難な場合がある。例えば、従来の技術では、ファイルのハッシュ値の一致性に基づいてファイルの完全性を確認するアクセス制御ポリシのACLが設定される。一方、予めハッシュ値を定義することが困難なファイルに対しては、ファイルへのアクセスを許可するプロセスを予め設定しておき、ファイルにアクセスするプロセスを限定するアクセス制御技術が適用される。しかしながら、このようなファイルにアクセスするプロセスの実行ファイルが改ざんされていた場合には、改ざんされたプロセスからのアクセスを許可してしまう場合がある。
 そこで、アクセス制御の対象とするアクセス先ファイルごとに、このファイルへのアクセスを許可するプロセスの実行ファイルをアクセス元ファイルとして、アクセス先ファイルとアクセス元ファイルとをACLに設定する技術が提案されている。
 ここで、このようにアクセス先ファイルとアクセス元ファイルとを用いたACLの設定を行う際には、不適切なアクセス制御ポリシのACLを設定してしまう場合がある。例えば、システム運用中に運用者自身がアクセス制御ポリシを作成してACLを更新する場合には、設定する必要がないアクセス制御ポリシを作成して不用意に適用してしまう場合がある。また、ソフトウェアをインストールする際等に第三者が作成したアクセス制御ポリシを活用してACLを更新する場合には、悪意のあるアクセス制御ポリシとは気づかずにこれを流用してしまう場合がある。いずれの場合にも、ACLのセキュリティレベルが低下して、セキュリティホールの要因となってしまうおそれがある。
 本発明は、上記に鑑みてなされたものであって、不適切なアクセス制御ポリシの追加を制限して、アクセス制御リストを適切に設定することを目的とする。
 上述した課題を解決し、目的を達成するために、本発明に係る更新装置は、ファイルと該ファイルを含むパッケージとの対応付けと、複数のパッケージ間の依存関係の有無を示す情報とを含むパッケージ管理情報と、ファイルと該ファイルへのアクセスが許可されているアクセス元ファイルとの対応付けを含むアクセス制御リストと、を記憶する記憶部と、ファイルとアクセス元ファイルとの組み合わせが指定された場合に、前記パッケージ管理情報を参照し、前記ファイルが含まれるパッケージと、前記アクセス元ファイルが含まれるパッケージとを特定する特定部と、特定された前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが同一、または相互に依存関係がある場合に、指定された前記組み合わせを前記アクセス制御リストに追加する追加部と、を備えることを特徴とする。
 本発明によれば、不適切なアクセス制御ポリシの追加を制限して、アクセス制御リストを適切に設定することが可能となる。
図1は、アクセス制御装置の処理概要を説明するための図である。 図2は、本実施形態の更新装置の概略構成を例示する模式図である。 図3は、パッケージ管理情報のデータ構成を例示する図である。 図4は、ACLのデータ構成を例示する図である。 図5は、追加部の処理を説明するための図である。 図6は、追加部の処理を説明するための図である。 図7は、更新処理手順を示すフローチャートである。 図8は、更新プログラムを実行するコンピュータの一例を示す図である。
 以下、図面を参照して、本発明の一実施形態を詳細に説明する。なお、この実施形態により本発明が限定されるものではない。また、図面の記載において、同一部分には同一の符号を付して示している。
[アクセス制御装置の処理概要]
 本実施形態の更新装置は、アクセス制御装置のアクセス制御に用いられるACLを更新する更新処理を行うものである。まず、図1は、アクセス制御装置の処理概要を説明するための図である。図1に示すように、アクセス制御装置は、アクセス制御の対象とするアクセス先ファイルにアクセスするプロセスを検知した場合に、アクセス制御ポリシを表すACLに基づいて、このプロセスによるこのアクセス先ファイルへの許否を制御するアクセス制御を行う。
 例えば、アクセス制御装置は、検知したプロセスの実行ファイルが、予め設定されたACLにアクセス先ファイルに対するアクセス元ファイルとして設定されている場合にのみ、このプロセスによるアクセス先ファイルへのアクセスを許可する。アクセス制御装置は、このACLに基づいて、アクセス先ファイルとアクセス元ファイルとの双方の完全性を確認し、アクセスを許可している。
 本実施形態の更新装置は、アクセス制御装置のACLを更新する更新処理を行う。ここで、不要なファイル間のアクセスの許可を不用意にACLに追加すると、セキュリティレベルが低下して、セキュリティホールの要因となるおそれがある。
 なお、Linux(登録商標)のRPM(RPM Package Manager)等のパッケージ管理情報が知られている。パッケージ管理情報は、実行ファイルや設定ファイルやライブラリファイル等を一括にして管理する情報である。各パッケージには、少なくとも、インストール時に含まれる実行ファイルが含まれる。インストール後に生成されるファイルが含まれていてもよい。パッケージ管理情報には、各パッケージにつき、どのパッケージのソフトウェアにどのパッケージのソフトウェアが必要か、つまりどのパッケージがどのパッケージに依存しているのかという、ソフトウェアのパッケージ開発者が想定したパッケージ間の依存関係を表す情報が含まれる。
 そこで、本実施形態の更新装置は、パッケージ管理情報を用いて、ソフトウェアのパッケージ開発者が想定するファイル間のアクセスか否かを考慮して、少なくとも不必要なACLへの追加を制限するACLの更新処理を実行する。
 なお、以下の説明では、更新装置10は、アクセス制御装置とは異なるハードウェアに実装される装置としているが、アクセス制御装置に組み込まれた装置であってもよい。
[更新装置の構成]
 図2は、本実施形態の更新装置の概略構成を例示する模式図である。図2に例示するように、更新装置10は、パソコン等の汎用コンピュータで実現され、入力部11、出力部12、通信制御部13、記憶部14、および制御部15を備える。
 入力部11は、キーボードやマウス等の入力デバイスを用いて実現され、操作者による入力操作に対応して、制御部15に対して処理開始などの各種指示情報を入力する。出力部12は、液晶ディスプレイなどの表示装置、プリンター等の印刷装置等によって実現される。
 通信制御部13は、NIC(Network Interface Card)等で実現され、LAN(Local Area Network)やインターネットなどの電気通信回線を介した外部の装置と制御部15との通信を制御する。例えば、通信制御部13は、後述する更新処理に用いられるパッケージ管理情報を管理する管理装置、更新処理の対象のACLを管理するアクセス制御装置、多数のファイルを管理するファイル管理システム等の外部の装置と制御部15との通信を制御する。
 記憶部14は、RAM(Random Access Memory)、フラッシュメモリ(Flash Memory)等の半導体メモリ素子、または、ハードディスク、光ディスク等の記憶装置によって実現される。本実施形態において、記憶部14は、パッケージ管理情報14aと、ACL14bとを記憶する。なお、記憶部14は、通信制御部13を介して制御部15と通信する構成でもよい。
 図3は、パッケージ管理情報14aを例示する図である。パッケージ管理情報14aは、ファイルと該ファイルを含むパッケージとの対応付けと、複数のパッケージ間の依存関係の有無を示す情報とを含む。各パッケージには、少なくとも、インストール時に含まれる実行ファイルと、インストール後に生成されるファイルとが含まれる。
 具体的には、図3に示すように、パッケージ管理情報14aは、パッケージごとに、既存先のパッケージと、自パッケージに含まれるファイルとが対応付けられた情報である。依存元のパッケージは、当該パッケージを機能させるためには、依存先のパッケージを必要とする。図3に示す例では、例えば、パッケージ「openssl」には、ファイル「/…/openssl」「/…/openssl.conf」等が含まれていることが例示されている。また、パッケージ「mod_ssl」を依存元とする依存先のパッケージが「openssl」「httpd」であることが例示されている。ここで、「/…/」は、ファイルパスを省略した表記である。また、パッケージ「openssl」については、ソフトウェアのパッケージ開発者が想定する依存先のパッケージがないことが例示されている。
 本実施形態において、更新装置10は、後述する更新処理に先立って予め、入力部11あるいは通信制御部13を介して、パッケージ管理情報14aを取得して、記憶部14に記憶させる。
 また、図4は、ACL14bを例示する図である。ACL14bは、ファイルと該ファイルへのアクセスが許可されているアクセス元ファイルとの対応付けを含む。すなわち、ACL14bは、上記のとおり、アクセス先ファイルへのアクセスが許可されているアクセス元ファイルを指定するホワイトリストである。
 図4に示す例では、例えば、アクセス先ファイル「/…/openssl.conf」に対して、アクセス元ファイル「/…/openssl」からのアクセスが許可されることが示されている。
 本実施形態において、更新装置10は、後述する更新処理に先立って予め、入力部11あるいは通信制御部13を介して、アクセス制御装置のACL14bを取得して、記憶部14に記憶させる。
 制御部15は、CPU(Central Processing Unit)等を用いて実現され、メモリに記憶された処理プログラムを実行する。これにより、制御部15は、図4に例示するように、特定部15aおよび追加部15bとして機能する。
 特定部15aは、アクセス先ファイルとアクセス元ファイルとの組み合わせが指定された場合に、パッケージ管理情報14aを参照し、アクセス先ファイルが含まれるパッケージと、アクセス元ファイルが含まれるパッケージとを特定する。
 具体的には、運用者がACL14bに追加したいアクセス制御ポリシとして、入力部11あるいは通信制御部13を介してアクセス先ファイルとアクセス元ファイルとの組み合わせを指定した場合に、まず、特定部15aは、パッケージ管理情報14aを参照する。そして、特定部15aは、指定されたアクセス先ファイルとアクセス元ファイルとのそれぞれが含まれるパッケージを特定する。
 例えば、図3に示した例では、アクセス先ファイル「/…/openssl」とアクセス元ファイル「/…/mod_ssl」との組み合わせが指定された場合に、特定部15aは、アクセス先ファイルのパッケージ「openssl」を特定する。また、特定部15aは、アクセス元ファイルのパッケージ「mod_ssl」を特定する。
 追加部15bは、特定されたファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが同一、または相互に依存関係がある場合に、指定された組み合わせをACL14bに追加する。
 ここで、図5および図6は、追加部15bの処理を説明するための説明図である。追加部15bは、図5に矢印aで示すように、アクセス元ファイルのパッケージとアクセス先ファイルのパッケージとが同一の場合に、指定された組み合わせをACL14bに追加する。
 また、追加部15bは、アクセス元ファイルのパッケージとアクセス先ファイルのパッケージとが相互の依存関係がある場合、すなわち、互いに依存元または依存先のパッケージに該当する場合に、指定された組み合わせをACL14bに追加する。例えば、図5に矢印bで示す組み合わせは、依存元パッケージと依存先パッケージとの連携に必要なアクセス制御ポリシとみなして、ACL14bに追加する。
 なお、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がある場合に、さらに警告を出力してもよい。また、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がある場合に、指定された組み合わせのACL14bへの追加に変えて、追加を拒否、または追加の可否の指示を受け付けてもよい。
 つまり、依存関係のあるファイルについての誤ったアクセス制御ポリシは、セキュリティレベルを低下させるおそれがある。そこで、追加部15bは、図5に矢印bで示す組み合わせは、アクセス制御の方針に反していないかを照会するよう警告を出力したり、運用者にACL14bへの追加の可否の承認を要求したりしてもよい。あるいは、追加部15bは、運用方針に従って一律にACL14bへの追加を拒否するようにしてもよい。
 また、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、指定された組み合わせをACL14bに追加する。
 例えば、図5に矢印cで示す組み合わせは、相互に依存関係がない独立したパッケージ間のアクセス制御ポリシであって、ソフトウェアのパッケージ開発者の想定外ではあるものの、運用者が必要とするファイル間アクセスである可能性がある。そのため、追加部15bは、この組み合わせをACL14bに追加する。
 また、図6に矢印dで示す組み合わせは、アクセス元のパッケージとアクセス先のパッケージとが他のパッケージを介しても辿ることができない。そこで、図6に矢印dで示す組み合わせは、図5に矢印cで示した組み合わせと同様に、独立したパッケージ間のアクセス制御ポリシであって、必要なファイル間アクセスである可能性があるため、追加部15bは、ACL14bに追加する。
 なお、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、さらに警告を出力する。
 例えば、図5に矢印cで示した組み合わせおよび図6に矢印dで示す組み合わせについては、誤ったアクセス制御ポリシではないと断定することはできない。そこで追加部15bは、運用者に判断を委ねるよう、警告を出力する。例えば、追加部15bは、この組み合わせがアクセス制御の方針に反していないかを照会するよう警告を出力する。
 また、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、指定された組み合わせのACL14bへの追加に変えて、追加を拒否、または追加の可否の指示を受け付けてもよい。すなわち、追加部15bは、運用者にACL14bへの追加の可否の承認を要求したりしてもよい。あるいは、追加部15bは、この組み合わせについては、一律にACL14bへの追加を拒否するようにしてもよい。
 また、追加部15bは、上記以外の組み合わせ、すなわち図6に矢印eで示した、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが他のパッケージを介して依存関係がある組み合わせは、ACL14bへの追加を行わない。アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとの間に相互に直接の依存関係がない場合には、ソフトウェアのパッケージ開発者が想定しないアクセスである可能性が高い。このようなアクセスを不用意に許可すると、ACL14bのセキュリティレベルが低下するおそれがある。したがって、追加部15bは、このような組み合わせは不要なアクセスポリシの追加とみなし、ACL14bへの追加は行わない。
 ただし、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが、相互に直接の依存関係がなく、他のパッケージを介して依存関係がある場合には、パッケージ管理情報における依存関係の定義の省略あるいは定義もれである場合もある。
 そこで、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが、相互に直接の依存関係がなく、他のパッケージを介して依存関係がある場合に、運用者にACL14bへの追加の可否の承認を要求してもよい。あるいは、一律に追加して、運用者に判断を委ねる警告を出力するようにしてもよい。これにより、パッケージ間に間接的な依存関係がある場合に一律に追加を拒否することなく、パッケージ管理情報の定義の省略あるいは定義もれである場合には、ACL14bへの追加を行うようにすることができる。
 なお、追加部13bは、更新処理により更新されたACL14bをアクセス制御装置に出力する。これにより、アクセス制御装置は、更新されたACL14bを適用してファイル間のアクセスの許否を制御することが可能となる。
[更新処理]
 次に、図7を参照して、本実施形態に係る更新装置10による更新処理について説明する。図7は、更新処理手順を示すフローチャートである。図7のフローチャートは、例えば、ユーザが開始を指示する操作入力を行ったタイミングで開始される。
 まず、特定部15aが、アクセス先ファイルとアクセス元ファイルとの組み合わせを指定する入力を受け付ける。また、特定部15aは、パッケージ管理情報14aを参照し、アクセス先ファイルが含まれるパッケージと、アクセス元ファイルが含まれるパッケージとを特定する。
 そして、追加部15bは、特定されたアクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが同一か否かを確認する(ステップS1)。追加部15bは、特定されたアクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが同一である場合に(ステップS1,Yes)、指定された組み合わせをACL14bに追加する(ステップS6)。
 一方、同一ではない場合には(ステップS1,No)、追加部15bは、特定されたファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが相互に依存関係があるか否かを確認する。まず、追加部15bは、特定されたアクセス先ファイルが含まれるパッケージが、アクセス元ファイルが含まれるパッケージの依存先であるか否かを確認する(ステップS2)。追加部15bは、アクセス先ファイルが含まれるパッケージが、アクセス元ファイルが含まれるパッケージの依存先である場合には(ステップS2,Yes)。指定された組み合わせをACL14bに追加する(ステップS6)。
 一方、追加部15bは、アクセス先ファイルが含まれるパッケージがアクセス元ファイルが含まれるパッケージの依存先でない場合には(ステップS2,No)、アクセス元ファイルが含まれるパッケージが、アクセス先ファイルが含まれるパッケージの依存先であるか否かを確認する(ステップS3)。追加部15bは、アクセス元ファイルが含まれるパッケージが、アクセス先ファイルが含まれるパッケージの依存先である場合には(ステップS3,Yes)、指定された組み合わせをACL14bに追加する(ステップS6)。
 なお、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がある場合には(ステップS2でYes、ステップS3でYes)、指定された組み合わせのACL14bへの追加に変えて、追加の可否の指示を受け付けてもよい。つまり、追加部15bは、指定された組み合わせが、アクセス制御の方針に反していないかを照会するよう警告を出力したり、運用者にACL14bへの追加の可否の承認を要求したりしてもよい。あるいは、追加部15bは、運用方針に従って一律にACL14bへの追加を拒否するようにしてもよい。
 一方、追加部15bは、アクセス元ファイルが含まれるパッケージが、アクセス先ファイルが含まれるパッケージの依存先でない場合には(ステップS3,No)、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが、他のパッケージを介して依存関係がないかを確認する。
 まず、追加部15bは、アクセス元ファイルの依存先のパッケージを辿ってアクセス先ファイルのパッケージに辿り着くか否かを確認する(ステップS4)。追加部15bは、アクセス元ファイルの依存先のパッケージを辿ってアクセス先ファイルのパッケージに辿り着く場合には(ステップS4,Yes)、ソフトウェアのパッケージ開発者の想定しないアクセスとして、指定された組み合わせのACL14bへの追加を行わない(ステップS7)。
 一方、追加部15bは、アクセス元ファイルの依存先のパッケージを辿ってアクセス先ファイルのパッケージに辿り着かない場合には(ステップS4,No)、アクセス先ファイルの依存先のパッケージを辿ってアクセス元ファイルのパッケージに辿り着くか否かを確認する(ステップS5)。追加部15bは、アクセス先ファイルの依存先のパッケージを辿ってアクセス元ファイルのパッケージに辿り着く場合には(ステップS5,Yes)、ソフトウェアのパッケージ開発者の想定しないアクセスとして、指定された組み合わせのACL14bへの追加を行わない(ステップS7)。
 一方、追加部15bは、アクセス先ファイルの依存先のパッケージを辿ってアクセス元ファイルのパッケージに辿り着かない場合には(ステップS5,No)、独立したパッケージ間のアクセス制御ポリシとして、指定された組み合わせをACL14bに追加する(ステップS8)。また、追加部15bは、運用者に判断を委ねるための警告を出力する。
 例えば、追加部15bは、この組み合わせがアクセス制御の方針に反していないかを照会するよう警告を出力する。また、追加部15bは、運用者にACL14bへの追加の可否の承認を要求したりしてもよい。あるいは、追加部15bは、この組み合わせについては、一律にACL14bへの追加を拒否するようにしてもよい。
 また、ステップS7の処理において、一律に追加を拒否する代わりに、運用者にACL14bへの追加の可否の承認を要求してもよい。あるいは、一律に追加して、運用者に判断を委ねる警告を出力するようにしてもよい。これにより、パッケージ管理情報の定義の省略あるいは定義もれである場合には、ACL14bへの追加を行うようにすることができるようになる。
 以上により、一連の更新処理が終了する。その結果、更新装置10は、少なくとも不適切なアクセス制御ポリシの追加を制限してACL14bを更新することができる。したがって、ACL14bのセキュリティレベルの緩和を最小限に留めることが可能となる。
 以上、説明したように、本実施形態の更新装置10において、記憶部14が、ファイルと該ファイルを含むパッケージとの対応付けと、複数のパッケージ間の依存関係の有無を示す情報とを含むパッケージ管理情報14aと、アクセス先ファイルと該アクセス先ファイルへのアクセスが許可されているアクセス元ファイルとの対応付けを含むACL14bと、を記憶する。また、特定部15aが、アクセス先ファイルとアクセス元ファイルとの組み合わせが指定された場合に、パッケージ管理情報14aを参照し、アクセス先ファイルが含まれるパッケージと、アクセス元ファイルが含まれるパッケージとを特定する。また、追加部15bが、特定されたアクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが同一、または相互に依存関係がある場合に、指定された組み合わせをACL14bに追加する。
 このように、更新装置10は、ソフトウェアのパッケージ開発者の想定した依存関係がある組み合わせのアクセスであることを条件に、ACL14bに追加することにより、少なくとも不適切なアクセス制御ポリシの追加を制限してACL14bを更新することができる。したがって、ACL14bのセキュリティレベルの緩和を最小限に留めることが可能となる。このように、更新装置10は、ACLを適切に設定することが可能となる。
 また、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がある場合に、さらに警告を出力してもよい。または、追加部15bは、指定された組み合わせのACL14bへの追加に変えて、追加を拒否、または追加の可否の指示を受け付けてもよい。これにより、ACL14bへの追加の可否を運用者の判断に委ねることが可能となる。
 また、追加部15bは、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、指定された組み合わせをACL14bに追加する。
 これにより、独立したパッケージ間のアクセス制御ポリシであって、必要なファイル間アクセスである可能性がある、独立したパッケージ間のアクセス制御ポリシをACL14bに追加することができる。
 その際に、追加部15bは、さらに警告を出力する。あるいは、追加部15bは、指定された組み合わせのACL14bへの追加に変えて、追加を拒否、または追加の可否の指示を受け付けてもよい。これにより、ACL14bへの追加の可否を運用者の判断に委ねることが可能となる。
 また、これにより、追加部15bは、上記以外の、アクセス先ファイルが含まれるパッケージとアクセス元ファイルが含まれるパッケージとが他のパッケージを介して依存関係がある組み合わせのACL14bへの追加を制限することができる。つまり、パッケージ間に相互に直接の依存関係がない、ソフトウェアのパッケージ開発者が想定しないアクセスである可能性が高い不要なアクセスのACL14bへの追加を制限することができる。
[プログラム]
 上記実施形態に係る更新装置10が実行する処理をコンピュータが実行可能な言語で記述したプログラムを作成することもできる。一実施形態として、更新装置10は、パッケージソフトウェアやオンラインソフトウェアとして上記の更新処理を実行する更新プログラムを所望のコンピュータにインストールさせることによって実装できる。例えば、上記の更新プログラムを情報処理装置に実行させることにより、情報処理装置を更新装置10として機能させることができる。ここで言う情報処理装置には、デスクトップ型またはノート型のパーソナルコンピュータが含まれる。また、その他にも、情報処理装置にはスマートフォン、携帯電話機やPHS(Personal Handyphone System)などの移動体通信端末、さらには、PDA(Personal Digital Assistant)などのスレート端末などがその範疇に含まれる。また、更新装置10の機能を、クラウドサーバに実装してもよい。
 図8は、更新プログラムを実行するコンピュータの一例を示す図である。コンピュータ1000は、例えば、メモリ1010と、CPU1020と、ハードディスクドライブインタフェース1030と、ディスクドライブインタフェース1040と、シリアルポートインタフェース1050と、ビデオアダプタ1060と、ネットワークインタフェース1070とを有する。これらの各部は、バス1080によって接続される。
 メモリ1010は、ROM(Read Only Memory)1011およびRAM1012を含む。ROM1011は、例えば、BIOS(Basic Input Output System)等のブートプログラムを記憶する。ハードディスクドライブインタフェース1030は、ハードディスクドライブ1031に接続される。ディスクドライブインタフェース1040は、ディスクドライブ1041に接続される。ディスクドライブ1041には、例えば、磁気ディスクや光ディスク等の着脱可能な記憶媒体が挿入される。シリアルポートインタフェース1050には、例えば、マウス1051およびキーボード1052が接続される。ビデオアダプタ1060には、例えば、ディスプレイ1061が接続される。
 ここで、ハードディスクドライブ1031は、例えば、OS1091、アプリケーションプログラム1092、プログラムモジュール1093およびプログラムデータ1094を記憶する。上記実施形態で説明した各情報は、例えばハードディスクドライブ1031やメモリ1010に記憶される。
 また、更新プログラムは、例えば、コンピュータ1000によって実行される指令が記述されたプログラムモジュール1093として、ハードディスクドライブ1031に記憶される。具体的には、上記実施形態で説明した更新装置10が実行する各処理が記述されたプログラムモジュール1093が、ハードディスクドライブ1031に記憶される。
 また、更新プログラムによる情報処理に用いられるデータは、プログラムデータ1094として、例えば、ハードディスクドライブ1031に記憶される。そして、CPU1020が、ハードディスクドライブ1031に記憶されたプログラムモジュール1093やプログラムデータ1094を必要に応じてRAM1012に読み出して、上述した各手順を実行する。
 なお、更新プログラムに係るプログラムモジュール1093やプログラムデータ1094は、ハードディスクドライブ1031に記憶される場合に限られず、例えば、着脱可能な記憶媒体に記憶されて、ディスクドライブ1041等を介してCPU1020によって読み出されてもよい。あるいは、更新プログラムに係るプログラムモジュール1093やプログラムデータ1094は、LANやWAN(Wide Area Network)等のネットワークを介して接続された他のコンピュータに記憶され、ネットワークインタフェース1070を介してCPU1020によって読み出されてもよい。
 以上、本発明者によってなされた発明を適用した実施形態について説明したが、本実施形態による本発明の開示の一部をなす記述および図面により本発明は限定されることはない。すなわち、本実施形態に基づいて当業者等によりなされる他の実施形態、実施例および運用技術等は全て本発明の範疇に含まれる。
 10 更新装置
 11 入力部
 12 出力部
 13 通信制御部
 14 記憶部
 14a パッケージ管理情報
 14b アクセス制御リスト(ACL)
 15 制御部
 15a 特定部
 15b 追加部

Claims (7)

  1.  ファイルと該ファイルを含むパッケージとの対応付けと、複数のパッケージ間の依存関係の有無を示す情報とを含むパッケージ管理情報と、ファイルと該ファイルへのアクセスが許可されているアクセス元ファイルとの対応付けを含むアクセス制御リストと、を記憶する記憶部と、
     ファイルとアクセス元ファイルとの組み合わせが指定された場合に、前記パッケージ管理情報を参照し、前記ファイルが含まれるパッケージと、前記アクセス元ファイルが含まれるパッケージとを特定する特定部と、
     特定された前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが同一、または相互に依存関係がある場合に、指定された前記組み合わせを前記アクセス制御リストに追加する追加部と、
     を備えることを特徴とする更新装置。
  2.  前記追加部は、前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がある場合に、さらに警告を出力することを特徴とする請求項1に記載の更新装置。
  3.  前記追加部は、前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がある場合に、指定された前記組み合わせの前記アクセス制御リストへの追加に変えて、追加を拒否、または追加の可否の指示を受け付けることを特徴とする請求項1に記載の更新装置。
  4.  前記追加部は、前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、指定された前記組み合わせを前記アクセス制御リストに追加することを特徴とする請求項1に記載の更新装置。
  5.  前記追加部は、前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、さらに警告を出力することを特徴とする請求項4に記載の更新装置。
  6.  前記追加部は、前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが異なり、かつ、相互に依存関係がなく、かつ、他のパッケージを介して依存関係がない場合に、指定された前記組み合わせの前記アクセス制御リストへの追加に変えて、追加を拒否、または追加の可否の指示を受け付けることを特徴とする請求項4に記載の更新装置。
  7.  更新装置で実行される更新方法であって、
     前記更新装置は、ファイルと該ファイルを含むパッケージとの対応付けと、複数のパッケージ間の依存関係の有無を示す情報とを含むパッケージ管理情報と、ファイルと該ファイルへのアクセスが許可されているアクセス元ファイルとの対応付けを含むアクセス制御リストと、を記憶する記憶部を備え、
     ファイルとアクセス元ファイルとの組み合わせが指定された場合に、前記パッケージ管理情報を参照し、前記ファイルが含まれるパッケージと、前記アクセス元ファイルが含まれるパッケージとを特定する特定工程と、
     特定された前記ファイルが含まれるパッケージと前記アクセス元ファイルが含まれるパッケージとが同一、または相互に依存関係がある場合に、指定された前記組み合わせを前記アクセス制御リストに追加する追加工程と、
     を含んだことを特徴とする更新方法。
PCT/JP2019/050224 2019-01-11 2019-12-20 更新装置および更新方法 WO2020145100A1 (ja)

Priority Applications (4)

Application Number Priority Date Filing Date Title
EP19909433.5A EP3889814B1 (en) 2019-01-11 2019-12-20 Update device and update method
CN201980088321.2A CN113272808B (zh) 2019-01-11 2019-12-20 更新装置及更新方法
AU2019420941A AU2019420941B2 (en) 2019-01-11 2019-12-20 Update device and update method
US17/421,719 US11809580B2 (en) 2019-01-11 2019-12-20 Update device and update method

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
JP2019003731A JP7040467B2 (ja) 2019-01-11 2019-01-11 更新装置および更新方法
JP2019-003731 2019-01-11

Publications (1)

Publication Number Publication Date
WO2020145100A1 true WO2020145100A1 (ja) 2020-07-16

Family

ID=71520335

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/JP2019/050224 WO2020145100A1 (ja) 2019-01-11 2019-12-20 更新装置および更新方法

Country Status (6)

Country Link
US (1) US11809580B2 (ja)
EP (1) EP3889814B1 (ja)
JP (1) JP7040467B2 (ja)
CN (1) CN113272808B (ja)
AU (1) AU2019420941B2 (ja)
WO (1) WO2020145100A1 (ja)

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5761669A (en) * 1995-06-06 1998-06-02 Microsoft Corporation Controlling access to objects on multiple operating systems
JP2013206173A (ja) * 2012-03-28 2013-10-07 Fujitsu Ltd 情報処理装置、制御方法及び制御プログラム
US20150178495A1 (en) * 2011-09-09 2015-06-25 Microsoft Technology Licensing, Llc Pervasive Package Identifiers
US20180268156A1 (en) * 2017-03-20 2018-09-20 Zhigang Luo Methods and apparatus for containerized secure computing resources

Family Cites Families (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2002278839A (ja) * 2001-03-15 2002-09-27 Sony Corp データアクセス管理システム、メモリ搭載デバイス、およびデータアクセス管理方法、並びにプログラム記憶媒体
CN100481013C (zh) * 2004-08-03 2009-04-22 索芙特瑞斯提股份有限公司 用于经由上下文策略控制来控制应用程序间关联的系统和方法
JP2008021247A (ja) * 2006-07-14 2008-01-31 Nec Software Kyushu Ltd 情報処理装置、ファイルアクセス制御方法、及びプログラム
US8950007B1 (en) * 2008-04-07 2015-02-03 Lumension Security, Inc. Policy-based whitelisting with system change management based on trust framework
US8533844B2 (en) * 2008-10-21 2013-09-10 Lookout, Inc. System and method for security data collection and analysis
US8788655B2 (en) * 2008-12-19 2014-07-22 Openpeak Inc. Systems for accepting and approving applications and methods of operation of same
CN101615236B (zh) * 2009-07-24 2011-07-20 北京工业大学 一种基于强制访问控制技术的可信应用环境构建方法
US20140032733A1 (en) * 2011-10-11 2014-01-30 Citrix Systems, Inc. Policy-Based Application Management
US9454670B2 (en) * 2012-12-03 2016-09-27 International Business Machines Corporation Hybrid file systems
JP5750497B2 (ja) * 2013-12-11 2015-07-22 株式会社アイキュエス アクセス制御装置、プログラム及びアクセス制御システム
US9875121B2 (en) * 2014-09-17 2018-01-23 International Business Machines Corporation API server
JP6088714B2 (ja) * 2014-10-14 2017-03-01 日本電信電話株式会社 特定装置、特定方法および特定プログラム
JP6529304B2 (ja) * 2015-03-25 2019-06-12 株式会社日立ソリューションズ アクセス制御システム及びアクセス制御方法
US10270778B2 (en) * 2016-03-21 2019-04-23 Google Llc Methods and systems for dynamic creation of access control lists
CN108108633B (zh) * 2017-12-20 2021-07-13 中国科学院深圳先进技术研究院 一种数据文件及其访问方法、装置及设备

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5761669A (en) * 1995-06-06 1998-06-02 Microsoft Corporation Controlling access to objects on multiple operating systems
US20150178495A1 (en) * 2011-09-09 2015-06-25 Microsoft Technology Licensing, Llc Pervasive Package Identifiers
JP2013206173A (ja) * 2012-03-28 2013-10-07 Fujitsu Ltd 情報処理装置、制御方法及び制御プログラム
US20180268156A1 (en) * 2017-03-20 2018-09-20 Zhigang Luo Methods and apparatus for containerized secure computing resources

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
"Understanding AppLocker rule condition types", 26 October 2015, MSDN LIBRARY

Also Published As

Publication number Publication date
CN113272808A (zh) 2021-08-17
US20220092195A1 (en) 2022-03-24
CN113272808B (zh) 2024-01-30
EP3889814A1 (en) 2021-10-06
EP3889814B1 (en) 2023-04-19
AU2019420941B2 (en) 2023-06-08
US11809580B2 (en) 2023-11-07
JP7040467B2 (ja) 2022-03-23
EP3889814A4 (en) 2022-08-17
JP2020113072A (ja) 2020-07-27
AU2019420941A1 (en) 2021-07-22

Similar Documents

Publication Publication Date Title
US7516477B2 (en) Method and system for ensuring that computer programs are trustworthy
US11237817B2 (en) Operating system update management for enrolled devices
US9390241B2 (en) Method for executing an application in a restricted operating environment
US9767280B2 (en) Information processing apparatus, method of controlling the same, information processing system, and information processing method
US7792964B2 (en) Running internet applications with low rights
TWI420338B (zh) 安全之瀏覽器基礎應用程式
US20200242251A1 (en) Providing application security, validation and profiling to an application
US20210303694A1 (en) Dynamic application deployment in trusted code environments
TWI659328B (zh) Computer system and file access control method
US9774605B2 (en) Temporary authorizations to access a computing system based on user skills
JP2018018495A (ja) 保護されたアプリケーションへのアクセスを阻止するシステム及び方法
US20150058926A1 (en) Shared Page Access Control Among Cloud Objects In A Distributed Cloud Environment
KR20170059447A (ko) 신뢰가능 플랫폼 모듈에서의 운영 체제 컨텍스트 표현 기법
US11301228B2 (en) Managing removal and modification of installed programs on a computer device
WO2020145100A1 (ja) 更新装置および更新方法
WO2021014595A1 (ja) 検証情報作成システム、検証情報作成方法、および、検証情報作成プログラム
JP6253333B2 (ja) 情報処理装置、情報処理システムおよび情報処理方法
JP5126495B2 (ja) 安全度評価と連動するセキュリティの方針設定装置、そのプログラムおよびその方法
US20230214479A1 (en) Method and system for detecting and preventing unauthorized access to a computer
US20230198997A1 (en) Access control systems and methods
GB2561861A (en) Computer device and method for isolating untrusted content
WO2020261438A1 (ja) 実行制御システム、実行制御方法、及びプログラム
WO2020261340A1 (ja) 情報処理装置、制御方法及び制御プログラム

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 19909433

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2019909433

Country of ref document: EP

Effective date: 20210701

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 2019420941

Country of ref document: AU

Date of ref document: 20191220

Kind code of ref document: A