WO2012060979A1 - Physically secured authorization for utility applications - Google Patents

Physically secured authorization for utility applications Download PDF

Info

Publication number
WO2012060979A1
WO2012060979A1 PCT/US2011/055705 US2011055705W WO2012060979A1 WO 2012060979 A1 WO2012060979 A1 WO 2012060979A1 US 2011055705 W US2011055705 W US 2011055705W WO 2012060979 A1 WO2012060979 A1 WO 2012060979A1
Authority
WO
WIPO (PCT)
Prior art keywords
permit
command
data center
hardware security
security module
Prior art date
Application number
PCT/US2011/055705
Other languages
French (fr)
Inventor
Raj Vaswani
Wilson Chuen Yew Yeung
Cristina Seibert
Nelson Bruce Bolyard
Benjamin N. Damm
Michael C. Stjohns
Original Assignee
Silver Spring Networks, 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 Silver Spring Networks, Inc. filed Critical Silver Spring Networks, Inc.
Priority to SG2013034319A priority Critical patent/SG190152A1/en
Priority to EP20154897.1A priority patent/EP3684007B1/en
Priority to CA2816989A priority patent/CA2816989C/en
Priority to CN201180059505.XA priority patent/CN103430183B/en
Priority to BR112013011804A priority patent/BR112013011804A2/en
Priority to JP2013537679A priority patent/JP2014501955A/en
Priority to EP20154890.6A priority patent/EP3664367B1/en
Priority to KR1020137014246A priority patent/KR101430376B1/en
Priority to AU2011323917A priority patent/AU2011323917B2/en
Priority to EP11838427.0A priority patent/EP2635994B1/en
Publication of WO2012060979A1 publication Critical patent/WO2012060979A1/en

Links

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/30Authentication, i.e. establishing the identity or authorisation of security principals
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04WWIRELESS COMMUNICATION NETWORKS
    • H04W12/00Security arrangements; Authentication; Protecting privacy or anonymity
    • H04W12/08Access security
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F15/00Digital computers in general; Data processing equipment in general
    • G06F15/16Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/30Authentication, i.e. establishing the identity or authorisation of security principals
    • G06F21/31User authentication
    • G06F21/33User authentication using certificates
    • 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/602Providing cryptographic facilities or services
    • 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/62Protecting access to data via a platform, e.g. using keys or access control rules
    • G06F21/629Protecting access to data via a platform, e.g. using keys or access control rules to features or functions of an application
    • GPHYSICS
    • G07CHECKING-DEVICES
    • G07CTIME OR ATTENDANCE REGISTERS; REGISTERING OR INDICATING THE WORKING OF MACHINES; GENERATING RANDOM NUMBERS; VOTING OR LOTTERY APPARATUS; ARRANGEMENTS, SYSTEMS OR APPARATUS FOR CHECKING NOT PROVIDED FOR ELSEWHERE
    • G07C9/00Individual registration on entry or exit
    • G07C9/20Individual registration on entry or exit involving the use of a pass
    • G07C9/22Individual registration on entry or exit involving the use of a pass in combination with an identity check of the pass holder
    • 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
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/20Network architectures or network communication protocols for network security for managing network security; network security policies in general
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/08Key distribution or management, e.g. generation, sharing or updating, of cryptographic keys or passwords
    • H04L9/0894Escrow, recovery or storing of secret information, e.g. secret key escrow or cryptographic key storage
    • H04L9/0897Escrow, recovery or storing of secret information, e.g. secret key escrow or cryptographic key storage involving additional devices, e.g. trusted platform module [TPM], smartcard or USB
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3263Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving certificates, e.g. public key certificate [PKC] or attribute certificate [AC]; Public key infrastructure [PKI] arrangements
    • H04L9/3268Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving certificates, e.g. public key certificate [PKC] or attribute certificate [AC]; Public key infrastructure [PKI] arrangements using certificate validation, registration, distribution or revocation, e.g. certificate revocation list [CRL]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06QINFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
    • G06Q50/00Systems or methods specially adapted for specific business sectors, e.g. utilities or tourism
    • G06Q50/06Electricity, gas or water supply
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y04INFORMATION OR COMMUNICATION TECHNOLOGIES HAVING AN IMPACT ON OTHER TECHNOLOGY AREAS
    • Y04SSYSTEMS INTEGRATING TECHNOLOGIES RELATED TO POWER NETWORK OPERATION, COMMUNICATION OR INFORMATION TECHNOLOGIES FOR IMPROVING THE ELECTRICAL POWER GENERATION, TRANSMISSION, DISTRIBUTION, MANAGEMENT OR USAGE, i.e. SMART GRIDS
    • Y04S40/00Systems for electrical power generation, transmission, distribution or end-user application management characterised by the use of communication or information technologies, or communication or information technology specific aspects supporting them
    • Y04S40/20Information technology specific aspects, e.g. CAD, simulation, modelling, system security

Definitions

  • This disclosure pertains to the management and control of operations associated with utility companies, and more particularly to the security of the systems that manage and control such operations.
  • FIG. 1 is a general block diagram of some of the components that might be found in a typical management and control system for a utility company that supplies electric power to customers, and possibly other commodities such as gas, water, etc.
  • the back office 10 of the system comprises a number of individual subsystems associated with various operations of the utility, for example a customer information system (CIS) 12, a customer relations module (CRM) 14, an outage management system (OMS) 16, a GPS information system 18, a billing system 20, a grid stability module 22, and a user interface 24.
  • CIS customer information system
  • CRM customer relations module
  • OMS outage management system
  • the back office server may communicate with individual meters 26 located at customers' premises to obtain consumption data for billing purposes, and command the meters to selectively disconnect, or re-connect, the customer from or to the supply of one or more of the commodities provided by the utility company.
  • Other commands from the back office server to individual meters may include commands to accept outbound energy flow from the customers.
  • the meters constitute endpoint nodes that communicate with the back office by means of a local area network 30 having access points 32 that provide egress into and out of the network.
  • the local area network can be a wireless mesh network.
  • the access points 32 communicate with servers at the back office 10 by means of a wide area network 34 or a dedicated communications link.
  • bunker a physically secure environment
  • Examples of a bunker include a restricted access room or container, e.g. a locked room, and a tamper-proof shell or enclosure around a protected system.
  • the bunker severely restricts physical access to the hardware devices on which the systems, or protected portions of the systems, are executing.
  • the systems within the bunker export very limited logical access.
  • this solution still presents a
  • Figure 1 is a general block diagram of a utility management and control system
  • Figure 2 is a block diagram of a utility back office system with bunkered components
  • Figure 3 is a block diagram schematically depicting the flow of data when a message is sent to a meter
  • Figure 4 is a block diagram of the configuration of a hardware security module
  • Figure 5 is a block diagram of a multi-stage buffer that counts cryptographic operations over a sliding window
  • Figure 6 illustrates an example of a system and procedure for issuing permits for commands
  • Figure 7 is a block diagram of an exemplary format of a permit payload
  • Figure 8 is a block diagram of a utility control and management system implemented in multiple data centers.
  • Figure 2 illustrates an example of a data center 40 in which the concepts of the invention are implemented.
  • the data center contains a number of physical servers on which various applications 12, 14, 16 are executed. Although only a few representative applications are illustrated in the figure, it will be appreciated that a larger number of such applications could be implemented within the data center. Conversely, the functions performed by any two or more of the applications may be integrated into a single, comprehensive program.
  • a physical bunker 42 having limited physical access, such as a locked room with reinforced walls.
  • the bunker may be, in addition to or instead of being locked, an area that is closely watched or protected using security cameras, motion detectors, etc.
  • the bunker may be
  • the bunker may be logically secured such as by using securely executing software and/or firmware whose functionality is secured from physical tampering, such as self-destructive packaging.
  • the bunker need not be a room but, for example, may be a physically secure box.
  • One or more additional server devices having an associated hardware security module 44 are located within the bunker, for the implementation of an authorization engine 46 having software modules that perform security- related operations such as authorization, authentication and accounting.
  • the hardware security module contains private and other secret keys in a secure fashion. It may also contain public certificates that are linked to the private keys.
  • the hardware security module preferably uses a robust security algorithm such as elliptic curve cryptography or another highly secure cryptographic method to perform cryptographic operations.
  • One example of hardware security modules that are suitable for the applications described herein is the SafeGuard CryptoServer line of hardware security modules from Utimaco Safeware AG.
  • Secure access to the bunker, and the server devices located within it, can be enforced with bio-sensor technology, e.g. fingerprint detection, physical keys or tokens, and/or password protection.
  • bio-sensor technology e.g. fingerprint detection, physical keys or tokens, and/or password protection.
  • a hierarchical, layered security system can be employed to maximize protection. If one layer of security fails, for example passwords are accidentally revealed or stolen, a higher-level security mechanism can be activated, such as a key or token actuated deadbolt lock, to maintain the physical security of the overall system.
  • an operation When an operation is initiated that causes a command to be generated, it may be signed or otherwise authenticated by the authorization engine 46, and then forwarded to an application programming interface (API) associated with the appropriate application external to the bunker 42.
  • API application programming interface
  • the command may be signed by a private key stored within the hardware security module 44.
  • an external application e.g. one of the applications 12-16 or an application running in one of the meters 26, it is verified by means of a public key to which the application has access. Once verified as having originated from within the bunker, the command is executed by the external application.
  • a policy module 48 is implemented within the bunker.
  • the policy module may be a separate software or firmware component, as depicted in Figure 2, or be logically incorporated into the hardware security module, as described hereinafter.
  • the policy module 48 may be reconfigured or reprogrammed in a secure manner, such as by commands entered from inside the bunker. This module contains business logic that examines a requested action and determines whether it will be permitted to be carried out.
  • re-connect commands are issued in a sequence, or with relative timing, that could disrupt the stability of the power distribution grid, they can be blocked by the policy and not passed on to the authorization engine for signature.
  • policy flags can be raised and appropriate actions taken, such as disconnecting an entity issuing commands, when certain conditions are detected. These conditions can include, for example: 1 .
  • a large number of remote disconnect commands are issued at one time, e.g. within a predetermined time interval, indicating a possible intent to maliciously disconnect users from the power distribution grid;
  • Commands are issued in a suspicious order, such as a sequence of repetitive connect and disconnect commands that are associated with the same customer, or commands that are inconsistent with the current status of a customer, e.g., issuing a disconnect command to a user who is not already connected to the power grid;
  • a requesting application fails to provide necessary credentials, or otherwise be authenticated
  • a requesting application is not among a set of approved
  • the bunker may contain a proxy 50 for the application programming interfaces (APIs) of the applications that are external to the bunker.
  • APIs application programming interfaces
  • the proxy consults utility business logic in the policy module 48 that may be needed to authorize the request, and has the request signed by the appropriate business logic. The request is then passed on to the
  • authorization engine 46 for signature. Once authorized, the proxy invokes the normal API for the called application that is external to the bunker, and passes along the authorized call.
  • the bunker 42 may not include a proxy.
  • a request may be made directly to the API of an external application.
  • the external application calls the authorization engine within the bunker if it determines the requested operation requires a signature.
  • all requests could be passed into the bunker for authorization, to avoid the need for any determination by the external application.
  • the requests submitted to the bunker are first checked and signed by the policy module, and then passed to the authorization engine 46. Once a request is authorized, the called application acts upon the request.
  • the hardware security module 44 included in the bunker 42 can operate at two levels. Examples are described hereinafter in connection with operations that are performed at the meters 26.
  • the utility company might institute a policy that all communications between an application at the back office 10 and a meter 26, or any other component of the network 30, must be encrypted and signed.
  • the implementation of this policy is depicted in the example of Figure 3.
  • a meter management application 52 has a message, e.g. a command, to send to one or more of the meters 26. This message is constructed in a meter command and interface module 54 of the application, and forwarded to the hardware security module 44 in the bunker 42, with a request to perform the appropriate encryption and signing of the message.
  • the policy module 48 may first check to confirm that the request originated from an authorized source. If so, it is passed along to the hardware security module.
  • the hardware security module 44 performs the requested operation on the message, using appropriate keys associated with the application, and returns the encrypted and signed data.
  • the command and interface module 54 of the meter management application then creates a data packet incorporating the encrypted and signed message, and transmits it to the meter via the network 30.
  • the hardware security module For messages received from nodes in the network 30 by the application 52, they are first forwarded to the hardware security module, to be decrypted.
  • the module 48 can also perform any appropriate verification of the authenticity of the sender of the received message, and integrity of the data. The verified and decrypted message is then returned to the hardware security module.
  • FIG. 4 depicts an example of the internal configuration of a hardware security module.
  • the module is configured with a number of slots. Each slot contains a collection of private keys,
  • the different slots are associated with different security contexts, and contain the keys, certificates and other information pertinent to their respective contexts.
  • Performing a cryptographic service on a command with the hardware security module, such as signing it with a private key enables the recipient of the command, e.g. a node 26, to authenticate the source of the command, using an associated public key.
  • the policy module 48 makes the initial determination whether a requested command is allowed to be presented to the hardware security module for one or more cryptographic services.
  • Each slot can be selectively configured with one or more rate limits, for example by means of a command line administration tool, to enforce desired business logic.
  • a command to configure a slot is as follows:
  • Such a command configures Slot 2 with a maximum rate limit of 10,000 cryptographic operations per 24-hour sliding window. If more than this allotted number of cryptographic operations occurs within the preceding 24 hours, the slot halts all further cryptographic operations. Thereafter, it will be necessary for an administrator to reset the slot by sending a reset command.
  • a slot can be configured with more than one rate, as follows:
  • a slot is configured with a rate limit
  • all cryptographic operations executed in the slot are counted against the allotted limit over a sliding window. In the example given above, if there are more than 40,000 cryptographic operations in the past 24 hours, or more than 2000 cryptographic operations in the last 60 minutes, the slot halts any further cryptographic operations.
  • the accounting for threshold violations can be performed in 5-minute increments.
  • Figure 5 illustrates an example in which a slot has been configured with a limit of 800 cryptographic operations in a 25-minute sliding window.
  • the sliding window can be implemented as a multi-stage buffer 56.
  • the illustrated buffer comprises five stages 58, each of which represents a 5-minute interval of time. Each stage contains a count of the number of cryptographic operations performed by the slot during its corresponding time interval.
  • the following table provides a snapshot of the data contained in the buffer at a given point in time.
  • a warning mechanism can be implemented to notify administrative personnel prior to the time that operations are halted. For instance, a first warning might be generated when the total count exceeds 80% of a rate limit, and a second warning if it reaches 90% of the limit.
  • each slot can be selectively configured with its own rate limits, flexibility is provided in the implementation of the business logic. For instance, as described hereinafter, certain critical commands may require an explicit type of authentication, hereinafter referred to as a "permit", before they can be executed. These commands might be mapped to a security context that is associated with a slot that carries out the permission procedures, and have particularly stringent rate limits. Other types of commands might be mapped to different security contexts and be encrypted and/or signed via a different slot having less stringent rate limits.
  • a higher level of security may be appropriate such as approval by multiple parties, each of which must be authenticated at the receiving node. From the standpoint of network efficiency, however, it is desirable if the node, to which the command is directed, only needs to be contacted once to execute the command. In one aspect of the invention, these objectives can be achieved by means of a permitting system that provides all required information to enable the node to authenticate a command. In essence, every critical command that is sent to an application, such as a disconnect command to a meter, may be required to be accompanied by a permit. As noted above, different types of commands can be mapped to different security contexts.
  • the issuing application checks the security context of the command. If encryption is required, the command is forwarded to an appropriate slot of the hardware security module for such an operation. If a determination is made that the security context requires a permit, the command is forwarded to a
  • the function of the permission server can be implemented by a slot in the hardware security module.
  • FIG. 6 One example of an arrangement and procedure for issuing permits is illustrated in Figure 6, with reference to a command to disconnect a premises from the power distribution grid.
  • one of the business modules in the back office 10 e.g., an accounting system
  • issues a command to the meter management application 52 to disconnect the premises associated with an account.
  • the meter management application may schedule the disconnect operation for a particular time, and then sends a message to a load manager module 59 over a secure link, requesting permission to issue the command.
  • the load manager is a component of the business logic that is located within the bunker 42 and determines whether load changes to the distribution grid may be detrimental.
  • the load manager functions as one implementation of a permission server.
  • the load manager can reject the request if a determination is made that the requested change may be detrimental, defer the request for a period of time, e.g. if too many requests are currently outstanding, or approve the request.
  • the request to the load manager may include information such as the target node, the scheduled operation time, and the size of the time window needed to complete the execution of the command.
  • the load manager creates a permit that can be recognized by the node to which the command is to be directed. Before the permit is returned to the meter management application 52, it is signed with a key associated with the load manager.
  • the permission server i.e. load manager 59 is separate from the hardware security module 44. In this case, therefore, the permit is sent to the hardware security module to be signed with the private key of the load manager. The signed permit is them returned to the load manager, to be forwarded on to the meter management application 52.
  • the meter management application Upon receiving the signed permit, the meter management application sends the authorized command to the node 26 that is associated with the premises to be disconnected, together with the signed permit.
  • the node can then verify the permit, for example by following a chain of certificates from the permit , through the load manager's credentials, to a root authority associated with the system operator for the power distribution grid. The node also verifies that the time values within the permit are consistent with the current time. If all information is correct and verified, the node executes the command and sends a signed receipt to the meter management application 52, indicating completion of the command. A copy of the receipt may be sent to the load manager 59, to enable it to keep track of
  • the meter management application 52 can also sign the payload of the packet that is sent to the node, to provide two separate authorizations for the command that are issued by different control entities, namely the meter management application and the load manager. Both forms of authorization need to be verified by the node before it executes the command.
  • the permission server e.g. load manager
  • the permission server does not possess the credentials needed to communicate directly with the node 26. Rather, it provides credentials to another control entity, in this case the meter management application 52, for the execution of the authorized command.
  • the business logic for determining whether to approve a command can be relatively simple, e.g. a leaky bucket algorithm in which an initial burst of a predetermined number of disconnect operations is permitted, followed by a smaller number of operations per unit of time.
  • the function of the load manager might be implemented within a slot of the hardware security module, using the rate control described previously.
  • Another, more complex algorithm can be based on the state of the power distribution network, e.g. tracking actual power loads and making determinations based on projections of power requirements. This latter embodiment may be performed outside of the hardware security module, as depicted in Figure 6, for example within a dedicated physical system, a virtualized server or an application on a shared system.
  • the first field 60 of the permit payload indicates an inception time, namely the time at which the permit becomes valid.
  • the node compares the inception time to its current time. If the inception time is later than the current time plus a predetermined increment, e.g. five minutes, the node rejects the permit as invalid.
  • the second field 62 of the permit payload indicates a duration window during which the permit remains valid.
  • This field contains a value indicating the number of predetermined time intervals, e.g. five minute blocks, beyond the inception time that the permit is valid. If the node's current time is greater than the permit inception time plus the product of the predetermined interval and the window value, the permit is rejected as invalid. For instance, if the inception time is 1 :00:00, the window value is 2, and the current time is 1 :12:38, the permit will be rejected as having expired.
  • the next field 64 of the permit payload indicates the operation that is permitted to be carried out. For example, this field may contain a value that indicates a power disconnect operation, or a power reconnect operation. Multiple operations can be associated with a single permit.
  • the target type field 66 indicates the format for the target field 68 that follows.
  • the target field 68 designates the node, or device, that is to perform the permitted operation. For example, the target could be the MAC address of the node.
  • the target type field 66 indicates the format in which this address is expressed, e.g. a DER octet string.
  • a constraint may be imposed that a disconnect or reconnect command can only be issued for one meter at a time.
  • the load manager may check to ensure that the target address for the device is associated with a single device, and is not a group or broadcast address.
  • the permit payload can be signed by the private key associated with a certificate having privileges for the indicated operation.
  • the node Upon receiving the data packet containing the permit payload, the node first checks to see whether the indicated operation requires a permit. If a permit is required, the node confirms that the certificate and private key that were used to sign the permit have the necessary privileges to execute the requested operation.
  • the node verifies the authenticity of the signed permit, as having been signed by the corresponding private key of the indicated certificate. The node then verifies that the target designation identifies the node itself. Finally, the node examines the inception time and window values, relative to its current time, to confirm that the permit has not expired.
  • the operation is executed, and a response is returned to confirm successful execution. If any of the verification steps fails, the permit is rejected, and an error message is returned. As soon as all of the operations in the data packet have been completed, or an error message is returned, the permit is discarded and not retained further.
  • a suitable form of remedial action may be implemented.
  • One such solution is to provide a logical or physical panic button that is associated with a bunker.
  • This panic button can be activated (such as by a person depressing a physical button or activating a user interface element, or by logic that makes an appropriate determination automatically) to inform the management system that the bunker associated with the panic button is compromised, and should no longer be trusted. For example, any requests for remote disconnect services that are signed by a compromised bunker should be ignored.
  • the panic button can be implemented in a variety of ways. Suitable examples include control signals that are sent via a wireless or wired communication system, physical push buttons at suitable locations, e.g., on employee desks, that are connected to a local or wide area network, and/or wearable devices with audio command capabilities and wireless connectivity.
  • Figure 8 illustrates an example of a system in which the functionality of a panic button can be implemented.
  • the utility in this example, the utility
  • each data center 70 and 72 might contain a complete instance of the various management and control subsystems, for redundancy.
  • Each data center contains an associated bunker, respectively labeled "bunkerl” and "bunker2".
  • Each bunker has a certificate with a certificate chain whose root is in a known authority. The certificates for the two bunkers are different from one another.
  • Each of the nodes in the control network e.g., access points 32 and endpoint nodes 26, has the ability to store and install a certificate revocation list.
  • the access points 32 also have the ability to filter source addresses.
  • a panic button associated with bunkerl is activated, and the resulting panic signal is sent to a server in bunker2 that implements the panic button function.
  • This panic signal includes an appropriate indication of the authentication of the device from which it is sent. For example, it might include a signature associated with the device, or be accompanied by a hash value generated according to a predetermined algorithm.
  • the server in bunker2 Upon receipt of an authenticated panic signal, the server in bunker2 issues commands to configure a firewall rule for all of the access points 32, which instructs them to drop packets that originate from data center 70.
  • the server in bunker2 also issues commands to configure a certificate revocation list on all of the access points, which indicates that the certificate associated with bunkerl is no longer valid.
  • the server in bunker2 also sends a message to every endpoint node, instructing it to reload its certificate revocation list from an access point.
  • firewall filter on the access point By configuring the firewall filter on the access point to drop packets from data center 70, a would-be attacker may be slowed down a period of time sufficient to enable the certificate revocation lists to be propagated to all of the endpoint nodes. In order to recover bunkerl after a potential breach has occurred, a new certificate must be installed, and new associations with that certificate are made and propagated to all of the nodes in the control network.
  • the disclosed invention provides a variety of security features to reduce the risk of malicious or otherwise inappropriate actions associated with the delivery of commodities provided by utilities.
  • Critical commands that have the potential to disrupt the stability of a utility distribution network are secured through the mechanism of a physical bunker that limits access to sensitive components of the back office management system, in conjunction with the use of a hardware security module for authenticating, signing and encrypting such commands.
  • a permit-based authorization framework provides a finer-grained level of security for a particularly critical commands.
  • the hardware security module can also be configured to limit the rate at which commands are executed, to further impede attempts to issue improper sequences of commands.

Abstract

To provide overall security to a utility management system, critical command and control messages that are issued to components of the system are explicitly approved by a secure authority. The explicit approval authenticates the requested action and authorizes the performance of the specific action indicated in a message. Key components of the utility management and control system that are associated with access control are placed in a physical bunker. With this approach, it only becomes necessary to bunker those subsystems that are responsible for approving network actions. Other management modules can remain outside the bunker, thereby avoiding the need to partition them into bunkered and non-bunkered components. Access to critical components of each of the non-bunkered subsystems is controlled through the bunkered approval system.

Description

PHYSICALLY SECURED AUTHORIZATION
FOR UTILITY APPLICATIONS
Technical Field
This disclosure pertains to the management and control of operations associated with utility companies, and more particularly to the security of the systems that manage and control such operations.
Background
Utility companies have complex, highly interconnected systems, which execute on physical servers that run a multitude of associated software modules for managing and controlling the operations of the utility company. Figure 1 is a general block diagram of some of the components that might be found in a typical management and control system for a utility company that supplies electric power to customers, and possibly other commodities such as gas, water, etc. The back office 10 of the system comprises a number of individual subsystems associated with various operations of the utility, for example a customer information system (CIS) 12, a customer relations module (CRM) 14, an outage management system (OMS) 16, a GPS information system 18, a billing system 20, a grid stability module 22, and a user interface 24. Although not illustrated in Figure 1 , additional functional modules can be present in the back office 10. Some of these subsystems may have the ability to communicate with devices in the distribution network for the commodity being supplied, and remotely control operations associated with those devices. For example, the back office server may communicate with individual meters 26 located at customers' premises to obtain consumption data for billing purposes, and command the meters to selectively disconnect, or re-connect, the customer from or to the supply of one or more of the commodities provided by the utility company. Other commands from the back office server to individual meters may include commands to accept outbound energy flow from the customers. In the example of Figure 1 , the meters constitute endpoint nodes that communicate with the back office by means of a local area network 30 having access points 32 that provide egress into and out of the network. In one embodiment, the local area network can be a wireless mesh network. The access points 32 communicate with servers at the back office 10 by means of a wide area network 34 or a dedicated communications link.
In a system of this type, one issue of concern is the secure
management of remote disconnects and reconnects, which might occur when a customer vacates a premises or defaults on payments, or when a new customer takes possession of the premises, respectively. Malicious and/or erroneously issued commands to remotely disconnect and/or reconnect premises may have the potential to destabilize the electric power distribution grid. Unauthorized reconnects could also result in the theft of distributed power. To limit such possibilities, efforts must be made to ensure that command and control operations take place in a secure manner, and only by entities that are authorized to undertake such operations. However, since the back office of a typical utility consists of a variety of interconnected systems, enforcement of secure access becomes difficult. Many different groups within the utility need access to all or part of the software system, which complicates the ability to limit logical and/or physical access to individual subsystems.
One possible solution to this issue is to place certain systems, or parts of such systems, within a physically secure environment, referred to hereinafter as a bunker. Examples of a bunker include a restricted access room or container, e.g. a locked room, and a tamper-proof shell or enclosure around a protected system. The bunker severely restricts physical access to the hardware devices on which the systems, or protected portions of the systems, are executing. In addition, the systems within the bunker export very limited logical access. However, this solution still presents a
challenging problem, in that it is difficult to refactor utility software systems to determine which portions need to be within the bunker, and which portions can remain outside of it to provide more flexible access to those who need it. Summary
To provide overall security to a utility management system, critical command and control messages that are issued to components of the system are required to be explicitly approved by a secure authority. The explicit approval authenticates the requested action and authorizes the performance of the specific action indicated in a message. Key components of the utility management and control system that are associated with access control are placed in a physically secure environment. With this approach, it only becomes necessary to physically secure those subsystems that are responsible for approving network actions, for example by means of a bunker. In other words, most of the management modules, such as the CIS, CRM, OMS, Billing, etc. can remain outside the bunker, thereby avoiding the need to partition those subsystems into bunkered and non-bunkered components. Access to critical components of each of the non-bunkered subsystems is controlled through the bunkered approval system.
Brief Description of the Figures
Figure 1 is a general block diagram of a utility management and control system;
Figure 2 is a block diagram of a utility back office system with bunkered components;
Figure 3 is a block diagram schematically depicting the flow of data when a message is sent to a meter;
Figure 4 is a block diagram of the configuration of a hardware security module;
Figure 5 is a block diagram of a multi-stage buffer that counts cryptographic operations over a sliding window;
Figure 6 illustrates an example of a system and procedure for issuing permits for commands;
Figure 7 is a block diagram of an exemplary format of a permit payload; and Figure 8 is a block diagram of a utility control and management system implemented in multiple data centers.
Detailed Description
To facilitate an understanding of the principles upon which the present invention is based, it is described hereinafter with reference to the secure control of remote connect and disconnect commands in an electric power distribution system. It will be appreciated, however, that such an example is not the only practical application of these principles. Rather, they can be employed in connection with any type of critical command which, if improperly or erroneously issued, could have the potential to severely disrupt or damage a system. Likewise, they can be used in conjunction with all commands and control messages sent to a critical component of the system whose proper operation is essential at all times.
Figure 2 illustrates an example of a data center 40 in which the concepts of the invention are implemented. As is conventional, the data center contains a number of physical servers on which various applications 12, 14, 16 are executed. Although only a few representative applications are illustrated in the figure, it will be appreciated that a larger number of such applications could be implemented within the data center. Conversely, the functions performed by any two or more of the applications may be integrated into a single, comprehensive program.
Also located within the data center is a physical bunker 42 having limited physical access, such as a locked room with reinforced walls. As another example, the bunker may be, in addition to or instead of being locked, an area that is closely watched or protected using security cameras, motion detectors, etc. As yet another example, the bunker may be
physically distributed, with a security relationship having been established among the distributed parts. As yet another example, the bunker may be logically secured such as by using securely executing software and/or firmware whose functionality is secured from physical tampering, such as self-destructive packaging. The bunker need not be a room but, for example, may be a physically secure box.
One or more additional server devices having an associated hardware security module 44 are located within the bunker, for the implementation of an authorization engine 46 having software modules that perform security- related operations such as authorization, authentication and accounting. The hardware security module contains private and other secret keys in a secure fashion. It may also contain public certificates that are linked to the private keys. The hardware security module preferably uses a robust security algorithm such as elliptic curve cryptography or another highly secure cryptographic method to perform cryptographic operations. One example of hardware security modules that are suitable for the applications described herein is the SafeGuard CryptoServer line of hardware security modules from Utimaco Safeware AG.
Secure access to the bunker, and the server devices located within it, can be enforced with bio-sensor technology, e.g. fingerprint detection, physical keys or tokens, and/or password protection. In one implementation, a hierarchical, layered security system can be employed to maximize protection. If one layer of security fails, for example passwords are accidentally revealed or stolen, a higher-level security mechanism can be activated, such as a key or token actuated deadbolt lock, to maintain the physical security of the overall system.
Certain types of commands from non-bunkered back office
applications 12-16, etc. are restricted, such that they will not be executed unless they are individually authenticated. For example, remote disconnect and re-connect commands are one category of these restricted commands, due to the potential that they present for serious disruption of the stability of the power distribution grid. To enforce security pertaining to these types of operations, the applications that carry them out may only accept commands to do so if they originate from a console within the bunker 42, or are otherwise authenticated by a permission issued from within the bunker 42. Thus, only personnel who have authority to issue those commands, and who possess the necessary means for access into the bunker, e.g. password, key, fingerprint, etc., will be able to issue the restricted commands to the application.
When an operation is initiated that causes a command to be generated, it may be signed or otherwise authenticated by the authorization engine 46, and then forwarded to an application programming interface (API) associated with the appropriate application external to the bunker 42. For instance, the command may be signed by a private key stored within the hardware security module 44. Upon receipt of the signed command at an external application, e.g. one of the applications 12-16 or an application running in one of the meters 26, it is verified by means of a public key to which the application has access. Once verified as having originated from within the bunker, the command is executed by the external application.
In some situations, it may not be practical for an entity that issues remote disconnect commands to be physically present within the bunker. If remote generation of such commands is supported, however, such commands could be issued maliciously by users impersonating authorized entities. To limit the possibility of such occurrences, in accordance with the invention a policy module 48 is implemented within the bunker. The policy module may be a separate software or firmware component, as depicted in Figure 2, or be logically incorporated into the hardware security module, as described hereinafter. The policy module 48 may be reconfigured or reprogrammed in a secure manner, such as by commands entered from inside the bunker. This module contains business logic that examines a requested action and determines whether it will be permitted to be carried out. For instance, if re-connect commands are issued in a sequence, or with relative timing, that could disrupt the stability of the power distribution grid, they can be blocked by the policy and not passed on to the authorization engine for signature. In addition, policy flags can be raised and appropriate actions taken, such as disconnecting an entity issuing commands, when certain conditions are detected. These conditions can include, for example: 1 . A large number of remote disconnect commands are issued at one time, e.g. within a predetermined time interval, indicating a possible intent to maliciously disconnect users from the power distribution grid;
2. Commands are issued in a suspicious order, such as a sequence of repetitive connect and disconnect commands that are associated with the same customer, or commands that are inconsistent with the current status of a customer, e.g., issuing a disconnect command to a user who is not already connected to the power grid;
3. A requesting application fails to provide necessary credentials, or otherwise be authenticated;
4. A requesting application is not among a set of approved
applications having permission to issue certain operations; and
5 The state of the distribution network, based upon actual power loads and projected power requirements.
To implement this functionality, the bunker may contain a proxy 50 for the application programming interfaces (APIs) of the applications that are external to the bunker. In operation, when a call is made to the API for one of these "external" applications, the call is directed to the proxy 50 within the bunker. The proxy consults utility business logic in the policy module 48 that may be needed to authorize the request, and has the request signed by the appropriate business logic. The request is then passed on to the
authorization engine 46 for signature. Once authorized, the proxy invokes the normal API for the called application that is external to the bunker, and passes along the authorized call.
In an alternative implementation, the bunker 42 may not include a proxy. In this case, a request may be made directly to the API of an external application. In turn, the external application calls the authorization engine within the bunker if it determines the requested operation requires a signature. As a default, all requests could be passed into the bunker for authorization, to avoid the need for any determination by the external application. The requests submitted to the bunker are first checked and signed by the policy module, and then passed to the authorization engine 46. Once a request is authorized, the called application acts upon the request.
The hardware security module 44 included in the bunker 42 can operate at two levels. Examples are described hereinafter in connection with operations that are performed at the meters 26. At the first level of operation, the utility company might institute a policy that all communications between an application at the back office 10 and a meter 26, or any other component of the network 30, must be encrypted and signed. The implementation of this policy is depicted in the example of Figure 3. In this example, a meter management application 52 has a message, e.g. a command, to send to one or more of the meters 26. This message is constructed in a meter command and interface module 54 of the application, and forwarded to the hardware security module 44 in the bunker 42, with a request to perform the appropriate encryption and signing of the message. The policy module 48 may first check to confirm that the request originated from an authorized source. If so, it is passed along to the hardware security module. The hardware security module 44 performs the requested operation on the message, using appropriate keys associated with the application, and returns the encrypted and signed data. The command and interface module 54 of the meter management application then creates a data packet incorporating the encrypted and signed message, and transmits it to the meter via the network 30.
For messages received from nodes in the network 30 by the application 52, they are first forwarded to the hardware security module, to be decrypted. The module 48 can also perform any appropriate verification of the authenticity of the sender of the received message, and integrity of the data. The verified and decrypted message is then returned to the
application 52.
For critical operations, such as remote connects and disconnects, the hardware security module can operate at a second level to enforce a rate limit on such operations. Figure 4 depicts an example of the internal configuration of a hardware security module. The module is configured with a number of slots. Each slot contains a collection of private keys,
certificates, secret keys and access privileges, to perform cryptographic services such as signing, encryption, decryption, etc. The different slots are associated with different security contexts, and contain the keys, certificates and other information pertinent to their respective contexts. Performing a cryptographic service on a command with the hardware security module, such as signing it with a private key, enables the recipient of the command, e.g. a node 26, to authenticate the source of the command, using an associated public key. The policy module 48 makes the initial determination whether a requested command is allowed to be presented to the hardware security module for one or more cryptographic services.
Each slot can be selectively configured with one or more rate limits, for example by means of a command line administration tool, to enforce desired business logic. An example of a command to configure a slot is as follows:
HSM_configure slot=2 rate-name- 'ratel" window=24h count=10000
Such a command configures Slot 2 with a maximum rate limit of 10,000 cryptographic operations per 24-hour sliding window. If more than this allotted number of cryptographic operations occurs within the preceding 24 hours, the slot halts all further cryptographic operations. Thereafter, it will be necessary for an administrator to reset the slot by sending a reset command.
A slot can be configured with more than one rate, as follows:
HSM_configure slot=2 rate-name- 'ratel" window=24h count=40000
HSM_configure slot=2 rate-name="rate2" window=60m count=2000
These two commands configure Slot 2 with two rate limit windows, one for 40,000 cryptographic operations over a 24-hour sliding window, and another for 2000 cryptographic operations over a 60-minute sliding window.
If a slot is configured with a rate limit, all cryptographic operations executed in the slot are counted against the allotted limit over a sliding window. In the example given above, if there are more than 40,000 cryptographic operations in the past 24 hours, or more than 2000 cryptographic operations in the last 60 minutes, the slot halts any further cryptographic operations.
In one embodiment, the accounting for threshold violations can be performed in 5-minute increments. Figure 5 illustrates an example in which a slot has been configured with a limit of 800 cryptographic operations in a 25-minute sliding window. The sliding window can be implemented as a multi-stage buffer 56. The illustrated buffer comprises five stages 58, each of which represents a 5-minute interval of time. Each stage contains a count of the number of cryptographic operations performed by the slot during its corresponding time interval. The following table provides a snapshot of the data contained in the buffer at a given point in time.
Figure imgf000011_0001
If the sum of all of the counts, in this case 15+0+7+1 +6 = 29, exceeds the threshold, then the slot halts all further cryptographic operations until it is administratively reset. A warning mechanism can be implemented to notify administrative personnel prior to the time that operations are halted. For instance, a first warning might be generated when the total count exceeds 80% of a rate limit, and a second warning if it reaches 90% of the limit.
The stage associated with the most recent interval, in this case Stage 5, keeps a running count of each new cryptographic operation. At the end of each 5-minute interval, the stored counts are shifted to the next-oldest stage The latest stage is reset to zero, and begins to count the cryptographic operations anew for the next 5-minute interval. Since each slot can be selectively configured with its own rate limits, flexibility is provided in the implementation of the business logic. For instance, as described hereinafter, certain critical commands may require an explicit type of authentication, hereinafter referred to as a "permit", before they can be executed. These commands might be mapped to a security context that is associated with a slot that carries out the permission procedures, and have particularly stringent rate limits. Other types of commands might be mapped to different security contexts and be encrypted and/or signed via a different slot having less stringent rate limits.
For critical commands, such as remote disconnect and reconnect commands, a higher level of security, may be appropriate such as approval by multiple parties, each of which must be authenticated at the receiving node. From the standpoint of network efficiency, however, it is desirable if the node, to which the command is directed, only needs to be contacted once to execute the command. In one aspect of the invention, these objectives can be achieved by means of a permitting system that provides all required information to enable the node to authenticate a command. In essence, every critical command that is sent to an application, such as a disconnect command to a meter, may be required to be accompanied by a permit. As noted above, different types of commands can be mapped to different security contexts. When a command is to be issued, either automatically by an application or through a user interface, the issuing application checks the security context of the command. If encryption is required, the command is forwarded to an appropriate slot of the hardware security module for such an operation. If a determination is made that the security context requires a permit, the command is forwarded to a
permission server in the bunkerthe-that issues the permits. In one
embodiment, the function of the permission server can be implemented by a slot in the hardware security module.
One example of an arrangement and procedure for issuing permits is illustrated in Figure 6, with reference to a command to disconnect a premises from the power distribution grid. In this example, one of the business modules in the back office 10, e.g., an accounting system, issues a command to the meter management application 52, to disconnect the premises associated with an account. Upon receipt of this command, the meter management application may schedule the disconnect operation for a particular time, and then sends a message to a load manager module 59 over a secure link, requesting permission to issue the command. The load manager is a component of the business logic that is located within the bunker 42 and determines whether load changes to the distribution grid may be detrimental. In this example, the load manager functions as one implementation of a permission server. The load manager can reject the request if a determination is made that the requested change may be detrimental, defer the request for a period of time, e.g. if too many requests are currently outstanding, or approve the request. The request to the load manager may include information such as the target node, the scheduled operation time, and the size of the time window needed to complete the execution of the command.
If the request is approved, the load manager creates a permit that can be recognized by the node to which the command is to be directed. Before the permit is returned to the meter management application 52, it is signed with a key associated with the load manager. In the illustrated example, the permission server, i.e. load manager 59 is separate from the hardware security module 44. In this case, therefore, the permit is sent to the hardware security module to be signed with the private key of the load manager. The signed permit is them returned to the load manager, to be forwarded on to the meter management application 52.
Upon receiving the signed permit, the meter management application sends the authorized command to the node 26 that is associated with the premises to be disconnected, together with the signed permit. The node can then verify the permit, for example by following a chain of certificates from the permit , through the load manager's credentials, to a root authority associated with the system operator for the power distribution grid. The node also verifies that the time values within the permit are consistent with the current time. If all information is correct and verified, the node executes the command and sends a signed receipt to the meter management application 52, indicating completion of the command. A copy of the receipt may be sent to the load manager 59, to enable it to keep track of
outstanding requests.
The meter management application 52 can also sign the payload of the packet that is sent to the node, to provide two separate authorizations for the command that are issued by different control entities, namely the meter management application and the load manager. Both forms of authorization need to be verified by the node before it executes the command. In this example, the permission server, e.g. load manager, does not possess the credentials needed to communicate directly with the node 26. Rather, it provides credentials to another control entity, in this case the meter management application 52, for the execution of the authorized command.
The business logic for determining whether to approve a command can be relatively simple, e.g. a leaky bucket algorithm in which an initial burst of a predetermined number of disconnect operations is permitted, followed by a smaller number of operations per unit of time. In this case, the function of the load manager might be implemented within a slot of the hardware security module, using the rate control described previously. Another, more complex algorithm can be based on the state of the power distribution network, e.g. tracking actual power loads and making determinations based on projections of power requirements. This latter embodiment may be performed outside of the hardware security module, as depicted in Figure 6, for example within a dedicated physical system, a virtualized server or an application on a shared system.
In addition to remote disconnects and reconnects, other types of commands can be required to have a permit, such as load limiting
commands that are directed to a customer's premises to reduce
consumption for a specified period of time. Furthermore, if the secure operation of a particular type of device in the system is critical to system stability, such as a distribution automation component, all commands issued to that device may be required to have a permit. Whenever a back office module issues a command to such a device, it forwards the command to the permission server, to obtain the necessary permit.
An exemplary format for a permit that is contained within the payload of a message is depicted in Figure 7. The first field 60 of the permit payload indicates an inception time, namely the time at which the permit becomes valid. When a message containing a permit payload is received at a node, the node compares the inception time to its current time. If the inception time is later than the current time plus a predetermined increment, e.g. five minutes, the node rejects the permit as invalid.
The second field 62 of the permit payload indicates a duration window during which the permit remains valid. This field contains a value indicating the number of predetermined time intervals, e.g. five minute blocks, beyond the inception time that the permit is valid. If the node's current time is greater than the permit inception time plus the product of the predetermined interval and the window value, the permit is rejected as invalid. For instance, if the inception time is 1 :00:00, the window value is 2, and the current time is 1 :12:38, the permit will be rejected as having expired.
The next field 64 of the permit payload indicates the operation that is permitted to be carried out. For example, this field may contain a value that indicates a power disconnect operation, or a power reconnect operation. Multiple operations can be associated with a single permit. The target type field 66 indicates the format for the target field 68 that follows. The target field 68 designates the node, or device, that is to perform the permitted operation. For example, the target could be the MAC address of the node. The target type field 66 indicates the format in which this address is expressed, e.g. a DER octet string.
To further increase security, a constraint may be imposed that a disconnect or reconnect command can only be issued for one meter at a time. Before issuing a permit, the load manager may check to ensure that the target address for the device is associated with a single device, and is not a group or broadcast address. The permit payload can be signed by the private key associated with a certificate having privileges for the indicated operation. Upon receiving the data packet containing the permit payload, the node first checks to see whether the indicated operation requires a permit. If a permit is required, the node confirms that the certificate and private key that were used to sign the permit have the necessary privileges to execute the requested operation. If the confirmation is affirmative, the node verifies the authenticity of the signed permit, as having been signed by the corresponding private key of the indicated certificate. The node then verifies that the target designation identifies the node itself. Finally, the node examines the inception time and window values, relative to its current time, to confirm that the permit has not expired.
If all of the verification checks are successful, the operation is executed, and a response is returned to confirm successful execution. If any of the verification steps fails, the permit is rejected, and an error message is returned. As soon as all of the operations in the data packet have been completed, or an error message is returned, the permit is discarded and not retained further.
In the event that access to the bunker is compromised, a suitable form of remedial action may be implemented. One such solution is to provide a logical or physical panic button that is associated with a bunker. This panic button can be activated (such as by a person depressing a physical button or activating a user interface element, or by logic that makes an appropriate determination automatically) to inform the management system that the bunker associated with the panic button is compromised, and should no longer be trusted. For example, any requests for remote disconnect services that are signed by a compromised bunker should be ignored.
The panic button can be implemented in a variety of ways. Suitable examples include control signals that are sent via a wireless or wired communication system, physical push buttons at suitable locations, e.g., on employee desks, that are connected to a local or wide area network, and/or wearable devices with audio command capabilities and wireless connectivity.
Figure 8 illustrates an example of a system in which the functionality of a panic button can be implemented. In this example, the utility
management and control system is housed within two data centers 70 and 72. For instance, each data center might contain a complete instance of the various management and control subsystems, for redundancy. Each data center contains an associated bunker, respectively labeled "bunkerl" and "bunker2". Each bunker has a certificate with a certificate chain whose root is in a known authority. The certificates for the two bunkers are different from one another.
Each of the nodes in the control network, e.g., access points 32 and endpoint nodes 26, has the ability to store and install a certificate revocation list. The access points 32 also have the ability to filter source addresses.
An exemplary operation will be described for a situation in which access to bunkerl has been compromised. A panic button associated with bunkerl is activated, and the resulting panic signal is sent to a server in bunker2 that implements the panic button function. This panic signal includes an appropriate indication of the authentication of the device from which it is sent. For example, it might include a signature associated with the device, or be accompanied by a hash value generated according to a predetermined algorithm. Upon receipt of an authenticated panic signal, the server in bunker2 issues commands to configure a firewall rule for all of the access points 32, which instructs them to drop packets that originate from data center 70. The server in bunker2 also issues commands to configure a certificate revocation list on all of the access points, which indicates that the certificate associated with bunkerl is no longer valid. The server in bunker2 also sends a message to every endpoint node, instructing it to reload its certificate revocation list from an access point.
By configuring the firewall filter on the access point to drop packets from data center 70, a would-be attacker may be slowed down a period of time sufficient to enable the certificate revocation lists to be propagated to all of the endpoint nodes. In order to recover bunkerl after a potential breach has occurred, a new certificate must be installed, and new associations with that certificate are made and propagated to all of the nodes in the control network.
In summary, the disclosed invention provides a variety of security features to reduce the risk of malicious or otherwise inappropriate actions associated with the delivery of commodities provided by utilities. Critical commands that have the potential to disrupt the stability of a utility distribution network are secured through the mechanism of a physical bunker that limits access to sensitive components of the back office management system, in conjunction with the use of a hardware security module for authenticating, signing and encrypting such commands. A permit-based authorization framework provides a finer-grained level of security for a particularly critical commands. The hardware security module can also be configured to limit the rate at which commands are executed, to further impede attempts to issue improper sequences of commands.
It will be appreciated by those of ordinary skill in the art that the disclosed concepts can be embodied in other specific forms without departing from the spirit or essential characteristics thereof. The presently disclosed embodiments are considered in all respects to be illustrative, and not restrictive. The scope of the invention is indicated by the appended claims, rather than the foregoing description, and all changes that come within the meaning and range of equivalents thereof are intended to be embraced therein.

Claims

WHAT IS CLAIMED IS:
1. A data center for utility applications, comprising:
a physically secure environment;
at least one server external to said physically secure environment, configured to execute one or more application programs associated with operations of a utility, at least some of said application programs having an interface for receiving remote requests from locations outside of the data center to perform functions pertaining to the operations of the utility;
a hardware security module located within said physically secure environment and storing a secret key;
an authorization engine, located within said physically secure environment, configured to receive remote requests directed to said application programs and to provide authorized requests, that are signed in accordance with said secret key; and
a policy module, located within said physically secure environment, configured to process the remote requests in accordance with business logic associated with said application programs and to selectively enable the requests to be authorized by said authorization engine.
2. The data center of claim 1 , further including a proxy for said interface, located within said physically secure environment, said proxy operating to receive remote requests that are received at said data center and that are intended for said application programs, and to forward said received requests to said policy module.
3. The data center of claim 1 , wherein said application programs are configured to redirect remote requests, which are received by said
application programs, to said policy module.
4. The data center of claim 1 , wherein the policy module is configured to determine whether a number of remote requests containing commands to disconnect electrical power, that are issued within a predetermined time period, exceeds a limit value, and to block the commands from being executed if the number of requests exceeds the limit value.
5. The data center of claim 1 , wherein the policy module is configured to determine whether a sequence of remote requests containing commands to disconnect and reconnect electrical power are associated with the same customer, and to block the commands from being executed if they meet such a condition.
6. The data center of claim 1 , wherein the policy module is configured to determine whether a remote request containing a command to disconnect or reconnect electrical power is inconsistent with the current status of a customer, and to block the command from being executed if it is
inconsistent.
7. The data center of claim 1 , wherein the policy module is configured to determine whether a remote request is received from an authenticated source, and to block the request from being processed if the source is not authenticated.
8. The data center of claim 1 , wherein the policy module is configured to determine whether a remote request to perform an operation is received from an application having permission to request such operation, and to block the request from being processed if the requesting application does not have such permission.
9. The data center of claim 1 , wherein the policy module is
reconfigurable by commands entered from within the physically secure environment.
10. A utility control and communications network, comprising:
a plurality of endpoint nodes;
a data center including:
a physically secure environment having an associated certificate of authentication ;
at least one server configured to execute one or more application programs associated with operations of a utility, at least some of said application programs having an interface for receiving remote requests from locations outside of the data center to perform functions pertaining to the operations of the utility;
a hardware security module located within said physically secure environment and storing a cryptographic key; and
an authorization engine, located within said physically secure environment, configured to receive remote requests directed to said application programs and to provide authorized requests that are signed in accordance with said cryptographic key;
at least one access point via which said endpoint nodes communicate with the application programs located in said data center; and
a server that, in response to an indication that the security of the physically secure environment at the data center has been compromised, issues a command to access points to configure a certificate revocation list indicating that the certificate associated with the physically secure environment, whose security is compromised, is invalid, and issues a command to said endpoint nodes to load the certificate revocation list from an access point.
1 1. The network of claim 10, wherein said server further issues a command to the access points to disregard communications originating from the data center whose physically secure environment has been
compromised, in response to an indication that the security of the physically secure environment at a data center has been compromised.
12. The network of claim 10, wherein the endpoint nodes are configured to determine whether a received command is authorized by using a public key associated with the cryptographic key.
13. A method for controlling devices in a utility network, comprising: generating a command for an operation to be carried out by a device in the utility network;
forwarding the command to a hardware security module;
within the hardware security module, executing the following functions:
performing a cryptographic service on the command that enables a recipient of the command, upon which the service has been performed, to authenticate the command as one that the recipient is permitted to execute,
counting the number of cryptographic services performed by the hardware security module in a specified time period, and if the counted number of cryptographic services performed within the specified time period exceeds a threshold limit, terminating the performance of further cryptographic services on received commands; and
transmitting the command, upon which the cryptographic service has been performed, to a device in the utility network to carry out the operation.
14. The method of claim 13, wherein the counting of the number of cryptographic services is performed over a sliding time window of the specified period.
15. The method of claim 14, wherein the counting of the number of cryptographic services is performed with respect to a plurality of sliding time windows, each of which is associated with a different respective length of time and threshold limit.
16. The method of claim 13, wherein the cryptographic service is encryption of the command.
17. The method of claim 3, wherein the cryptographic service is signing the command.
18. The method of claim 13, further including the step of generating a warning when the counted number of cryptographic services reaches a predetermined value less than said threshold limit.
19. The method of claim 13, wherein the hardware security module comprises a plurality of slots, and wherein said functions are executed in one of the slots.
20. The method of claim 19, wherein said functions are also executed in a second slot, using a different respective threshold limit.
21 . The method of claim 13, wherein the device is configured to determine whether a received command is authorized by using a public key associated with the cryptographic service.
22. A method for controlling devices in a utility network, comprising:
generating a command for an operation to be carried out by a device in the utility network;
determining whether the generated command requires a permit;
if the generated command requires a permit, forwarding the command to a permission server;
within the permission server, generating a permit that specifies (i) a period for which the permit is valid, (ii) the operation to be performed, and (iii) the device that is to perform the operation;
transmitting a data packet containing the permit to a device in the utility network; upon receiving the data packet at the device, determining whether the specified operation requires a permit, and if so whether the permit is currently valid; and
performing the specified operation if the permit is currently valid,
23. The method of claim 22, wherein the permit contains an inception value that indicates when the permit becomes valid, and a duration value that indicates the length of time that the permit remains valid from the inception value.
24. The method of claim 22, wherein the permit includes a first field that contains an identification of the device that is to perform the operation, and a second field that indicates the format for the first field.
25. The method of claim 24, wherein the identification contained in the first field comprises a MAC address of the device.
26. The method of claim 24, wherein the format is a DER octet string.
27. The method of claim 22, wherein the permit is signed with a key associated with the permission server, and the device verifies the signature of the permit.
28. The method of claim 22, wherein the permission server is
implemented within a hardware security module.
29. The method of claim 28, wherein the hardware security module executes the following functions:
counting the number of permits generated by the hardware security module in a specified time period, and if the counted number of permits generated within the specified time period exceeds a threshold limit, terminating the generation of further permits for received commands.
30. The method of claim 29, wherein the counting of the number of generated permits is performed over a sliding time window of the specified period.
31 . The method of claim 30, wherein the counting of the number of generated permits is performed with respect to a plurality of sliding time windows, each of which is associated with a different respective length of time and threshold limit.
32. An authentication system for a utility network, comprising:
a permission server configured to receive a command for an operation to be carried out by a device in the utility network, and to generate a permit that specifies (i) a period for which the permit is valid, (ii) the operation to be performed, and (iii) the device that is to perform the operation; and
a communication interface configured to transmit a data packet containing the permit to a device in the utility network.
33. The authentication system of claim 32, wherein the permit contains an inception value that indicates when the permit becomes valid, and a duration value that indicates the length of time that the permit remains valid from the inception value.
34. The authentication system of claim 32, wherein the permission server is implemented in a hardware security module.
35. The authentication system of claim 34, wherein the hardware security module is configured to execute the following functions: count the number of permits generated by the hardware security module in a specified time period, and
if the counted number of permits generated within the specified time period exceeds a threshold limit, terminate the generation of further permits for received commands.
36. The authentication system of claim 35, wherein the counting of the number of generated permits is performed over a sliding time window of the specified period.
37. The authentication system of claim 36, wherein the counting of the number of generated permits is performed with respect to a plurality of sliding time windows, each of which is associated with a different respective length of time and threshold limit.
38. The authentication system of claim 32, further including a physically secure environment in which the permission server is housed.
39. A utility network, comprising:
a permission server configured to receive a command for an operation to be carried out by a device in the utility network, and to generate a permit that specifies (i) a period for which the permit is valid, (ii) the operation to be performed, and (iii) the device that is to perform the operation;
a communication interface configured to transmit a data packet containing the permit via the utility network; and
a plurality of devices connected to the utility network for receiving data packets, each of said devices being configured to:
determine whether an operation specified in a received data packet requires a permit,
if so, determine whether the permit is currently valid; and perform the specified operation if the permit is currently valid.
40. The utility network of claim 39, wherein the permit contains an inception value that indicates when the permit becomes valid, and a duration value that indicates the length of time that the permit remains valid from the inception value.
41. The utility network of claim 39, wherein the permission server is configured to sign the permit using a key, and the device is configured to verify the signature of the permit.
42. The utility network of claim 39, wherein the permission server is implemented in a hardware security module.
43. The utility network of claim 42, wherein the hardware security module is configured to execute the following functions:
count the number of permits generated by the hardware security module in a specified time period, and
if the counted number of permits generated within the specified time period exceeds a threshold limit, terminate the generation of further permits for received commands.
44. The utility network of claim 43, wherein the counting of the number of generated permits is performed over a sliding time window of the specified period.
45. The utility network of claim 44, wherein the counting of the number of generated permits is performed with respect to a plurality of sliding time windows, each of which is associated with a different respective length of time and threshold limit.
PCT/US2011/055705 2010-11-04 2011-10-11 Physically secured authorization for utility applications WO2012060979A1 (en)

Priority Applications (10)

Application Number Priority Date Filing Date Title
SG2013034319A SG190152A1 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications
EP20154897.1A EP3684007B1 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications
CA2816989A CA2816989C (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications
CN201180059505.XA CN103430183B (en) 2010-11-04 2011-10-11 For the physical security mandate of utility application
BR112013011804A BR112013011804A2 (en) 2010-11-04 2011-10-11 physically secure authorization for utility applications
JP2013537679A JP2014501955A (en) 2010-11-04 2011-10-11 Physically secure authorization for utility applications
EP20154890.6A EP3664367B1 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications
KR1020137014246A KR101430376B1 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications
AU2011323917A AU2011323917B2 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications
EP11838427.0A EP2635994B1 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US12/939,702 US9961550B2 (en) 2010-11-04 2010-11-04 Physically secured authorization for utility applications
US12/939,702 2010-11-04

Publications (1)

Publication Number Publication Date
WO2012060979A1 true WO2012060979A1 (en) 2012-05-10

Family

ID=46020394

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2011/055705 WO2012060979A1 (en) 2010-11-04 2011-10-11 Physically secured authorization for utility applications

Country Status (14)

Country Link
US (3) US9961550B2 (en)
EP (3) EP2635994B1 (en)
JP (2) JP2014501955A (en)
KR (1) KR101430376B1 (en)
CN (1) CN103430183B (en)
AU (1) AU2011323917B2 (en)
BR (1) BR112013011804A2 (en)
CA (2) CA2816989C (en)
DK (2) DK3664367T3 (en)
ES (2) ES2932380T3 (en)
MY (1) MY168385A (en)
SG (1) SG190152A1 (en)
TW (1) TWI536285B (en)
WO (1) WO2012060979A1 (en)

Cited By (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20140229739A1 (en) 2013-02-12 2014-08-14 Amazon Technologies, Inc. Delayed data access
JP2016515235A (en) * 2013-02-12 2016-05-26 アマゾン テクノロジーズ インコーポレイテッド Policy enforcement with relevant data
US9608993B1 (en) 2016-02-01 2017-03-28 International Business Machines Corporation Credential abuse prevention and efficient revocation with oblivious third party
US9705674B2 (en) 2013-02-12 2017-07-11 Amazon Technologies, Inc. Federated key management
US9832171B1 (en) 2013-06-13 2017-11-28 Amazon Technologies, Inc. Negotiating a session with a cryptographic domain
US9866392B1 (en) 2014-09-15 2018-01-09 Amazon Technologies, Inc. Distributed system web of trust provisioning
US9942036B2 (en) 2014-06-27 2018-04-10 Amazon Technologies, Inc. Supporting a fixed transaction rate with a variably-backed logical cryptographic key
US10055594B2 (en) 2012-06-07 2018-08-21 Amazon Technologies, Inc. Virtual service provider zones
US10075471B2 (en) 2012-06-07 2018-09-11 Amazon Technologies, Inc. Data loss prevention techniques
US10075295B2 (en) 2013-02-12 2018-09-11 Amazon Technologies, Inc. Probabilistic key rotation
US10084818B1 (en) 2012-06-07 2018-09-25 Amazon Technologies, Inc. Flexibly configurable data modification services
US10211977B1 (en) 2013-02-12 2019-02-19 Amazon Technologies, Inc. Secure management of information using a security module
CN109636116A (en) * 2018-11-14 2019-04-16 遵义华正电缆桥架有限公司 A kind of equipment of security power construction
US10404670B2 (en) 2013-02-12 2019-09-03 Amazon Technologies, Inc. Data security service
US10467422B1 (en) 2013-02-12 2019-11-05 Amazon Technologies, Inc. Automatic key rotation
US10721075B2 (en) 2014-05-21 2020-07-21 Amazon Technologies, Inc. Web of trust management in a distributed system
US11036869B2 (en) 2013-02-12 2021-06-15 Amazon Technologies, Inc. Data security with a security module

Families Citing this family (28)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US8635036B2 (en) * 2011-01-04 2014-01-21 General Electric Company Systems, methods, and apparatus for providing energy management utilizing a power meter
US8880883B2 (en) * 2013-03-15 2014-11-04 Silver Spring Networks, Inc. Secure end-to-end permitting system for device operations
US9712530B2 (en) 2012-01-06 2017-07-18 Optio Labs, Inc. Systems and methods for enforcing security in mobile computing
US9609020B2 (en) 2012-01-06 2017-03-28 Optio Labs, Inc. Systems and methods to enforce security policies on the loading, linking, and execution of native code by mobile applications running inside of virtual machines
US9787681B2 (en) 2012-01-06 2017-10-10 Optio Labs, Inc. Systems and methods for enforcing access control policies on privileged accesses for mobile devices
US9672574B2 (en) 2012-03-20 2017-06-06 Facebook, Inc. Bypass login for applications on mobile devices
US9154568B2 (en) * 2012-03-20 2015-10-06 Facebook, Inc. Proxy bypass login for applications on mobile devices
US9363670B2 (en) 2012-08-27 2016-06-07 Optio Labs, Inc. Systems and methods for restricting access to network resources via in-location access point protocol
US9773107B2 (en) * 2013-01-07 2017-09-26 Optio Labs, Inc. Systems and methods for enforcing security in mobile computing
US20140283136A1 (en) 2013-03-13 2014-09-18 Optio Labs, Inc. Systems and methods for securing and locating computing devices
DE102013227184A1 (en) * 2013-12-27 2015-07-02 Robert Bosch Gmbh Method for securing a system-on-a-chip
US20150288183A1 (en) 2014-04-06 2015-10-08 CleanSpark Technologies LLC Establishing communication and power sharing links between components of a distributed energy system
US10015164B2 (en) 2014-05-07 2018-07-03 Cryptography Research, Inc. Modules to securely provision an asset to a target device
MX2018016420A (en) * 2014-06-02 2021-08-13 Schlage Lock Co Llc Electronic credental management system.
CN104181886B (en) * 2014-08-13 2017-08-08 惠州Tcl移动通信有限公司 A kind of intelligent domestic system and control method
US10062226B2 (en) * 2014-12-02 2018-08-28 Carrier Corporation Access control system with automatic mobile credentialing service hand-off
JP6492667B2 (en) * 2015-01-07 2019-04-03 東京電力ホールディングス株式会社 Equipment control system
US10712126B2 (en) 2015-08-25 2020-07-14 Axon Enterprise, Inc. Systems and methods for cooperation among weapons, holsters, and recorders
US20180198620A1 (en) * 2017-01-11 2018-07-12 Raptor Engineering, LLC Systems and methods for assuring data on leased computing resources
WO2018140420A1 (en) * 2017-01-24 2018-08-02 Honeywell International, Inc. Voice control of an integrated room automation system
US10542072B1 (en) * 2017-10-04 2020-01-21 Parallels International Gmbh Utilities toolbox for remote session and client architecture
DE102018003061A1 (en) * 2018-02-03 2019-08-08 Diehl Metering Systems Gmbh Method for the secure operation of an electronic consumption data module and consumption data module
GB2575250B (en) * 2018-06-28 2021-04-21 Arm Ip Ltd Methods for delivering an authenticatable management activity to remote devices
CN108879963B (en) * 2018-08-01 2023-10-20 南方电网科学研究院有限责任公司 Power load management device and method
CN112308354A (en) * 2019-07-31 2021-02-02 中兴通讯股份有限公司 System overload control method and device
US11429401B2 (en) * 2020-03-04 2022-08-30 Landis+Gyr Innovations, Inc. Navigating a user interface of a utility meter with touch-based interactions
US20230205935A1 (en) * 2021-12-28 2023-06-29 Ati Technologies Ulc Software assisted acceleration in cryptographic queue processing
US20230370445A1 (en) * 2022-05-12 2023-11-16 Itron, Inc. Secured authorization for demand response

Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20080222714A1 (en) * 2007-03-09 2008-09-11 Mark Frederick Wahl System and method for authentication upon network attachment
US20100044433A1 (en) * 2008-08-19 2010-02-25 Wankmueller John R Methods and systems to remotely issue proximity payment devices
US7770789B2 (en) * 2007-05-17 2010-08-10 Shift4 Corporation Secure payment card transactions
US20100275016A1 (en) * 2004-10-20 2010-10-28 Zimmer Vincent J Data security

Family Cites Families (18)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7761910B2 (en) * 1994-12-30 2010-07-20 Power Measurement Ltd. System and method for assigning an identity to an intelligent electronic device
AUPP471098A0 (en) 1998-07-16 1998-08-06 United Technology Pty Ltd Internet utility interconnect method and means
US6587032B2 (en) * 2000-11-28 2003-07-01 International Business Machines Corporation System and method for controlling access to a computer resource
EP1360814B1 (en) * 2001-02-06 2007-04-11 Certicom Corp. Mobile certificate distribution in a public key infrastructure
US20020162019A1 (en) * 2001-04-25 2002-10-31 Berry Michael C. Method and system for managing access to services
JP3822475B2 (en) 2001-09-14 2006-09-20 三菱電機株式会社 Power system management method and power system management system
JP2003111156A (en) * 2001-09-27 2003-04-11 Toshiba Corp Digital household electric appliance
US7058807B2 (en) 2002-04-15 2006-06-06 Intel Corporation Validation of inclusion of a platform within a data center
US7464272B2 (en) 2003-09-25 2008-12-09 Microsoft Corporation Server control of peer to peer communications
US20060095454A1 (en) * 2004-10-29 2006-05-04 Texas Instruments Incorporated System and method for secure collaborative terminal identity authentication between a wireless communication device and a wireless operator
US7231280B2 (en) 2004-12-14 2007-06-12 Costa Enterprises, L.L.C. Dynamic control system for power sub-network
CN101467131A (en) 2005-07-20 2009-06-24 美国唯美安视国际有限公司 Network user authentication system and method
CN201118607Y (en) 2007-11-19 2008-09-17 上海久隆电力科技有限公司 Uniform identity authentication platform system
US8321915B1 (en) * 2008-02-29 2012-11-27 Amazon Technologies, Inc. Control of access to mass storage system
AU2010217154A1 (en) * 2009-02-27 2011-09-15 Certicom Corp. System and method for securely communicating with electronic meters
US8918842B2 (en) * 2010-02-19 2014-12-23 Accenture Global Services Limited Utility grid command filter system
US8600575B2 (en) * 2010-09-24 2013-12-03 Synapsense Corporation Apparatus and method for collecting and distributing power usage data from rack power distribution units (RPDUs) using a wireless sensor network
US8670946B2 (en) * 2010-09-28 2014-03-11 Landis+Gyr Innovations, Inc. Utility device management

Patent Citations (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20100275016A1 (en) * 2004-10-20 2010-10-28 Zimmer Vincent J Data security
US20080222714A1 (en) * 2007-03-09 2008-09-11 Mark Frederick Wahl System and method for authentication upon network attachment
US7770789B2 (en) * 2007-05-17 2010-08-10 Shift4 Corporation Secure payment card transactions
US20100044433A1 (en) * 2008-08-19 2010-02-25 Wankmueller John R Methods and systems to remotely issue proximity payment devices

Cited By (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10055594B2 (en) 2012-06-07 2018-08-21 Amazon Technologies, Inc. Virtual service provider zones
US10834139B2 (en) 2012-06-07 2020-11-10 Amazon Technologies, Inc. Flexibly configurable data modification services
US10474829B2 (en) 2012-06-07 2019-11-12 Amazon Technologies, Inc. Virtual service provider zones
US10084818B1 (en) 2012-06-07 2018-09-25 Amazon Technologies, Inc. Flexibly configurable data modification services
US10075471B2 (en) 2012-06-07 2018-09-11 Amazon Technologies, Inc. Data loss prevention techniques
US10666436B2 (en) 2013-02-12 2020-05-26 Amazon Technologies, Inc. Federated key management
US11036869B2 (en) 2013-02-12 2021-06-15 Amazon Technologies, Inc. Data security with a security module
US11695555B2 (en) 2013-02-12 2023-07-04 Amazon Technologies, Inc. Federated key management
US11372993B2 (en) 2013-02-12 2022-06-28 Amazon Technologies, Inc. Automatic key rotation
US10075295B2 (en) 2013-02-12 2018-09-11 Amazon Technologies, Inc. Probabilistic key rotation
US9705674B2 (en) 2013-02-12 2017-07-11 Amazon Technologies, Inc. Federated key management
US10211977B1 (en) 2013-02-12 2019-02-19 Amazon Technologies, Inc. Secure management of information using a security module
US10210341B2 (en) 2013-02-12 2019-02-19 Amazon Technologies, Inc. Delayed data access
JP2016515235A (en) * 2013-02-12 2016-05-26 アマゾン テクノロジーズ インコーポレイテッド Policy enforcement with relevant data
US20140229739A1 (en) 2013-02-12 2014-08-14 Amazon Technologies, Inc. Delayed data access
US10382200B2 (en) 2013-02-12 2019-08-13 Amazon Technologies, Inc. Probabilistic key rotation
US10404670B2 (en) 2013-02-12 2019-09-03 Amazon Technologies, Inc. Data security service
US10467422B1 (en) 2013-02-12 2019-11-05 Amazon Technologies, Inc. Automatic key rotation
US9832171B1 (en) 2013-06-13 2017-11-28 Amazon Technologies, Inc. Negotiating a session with a cryptographic domain
US10601789B2 (en) 2013-06-13 2020-03-24 Amazon Technologies, Inc. Session negotiations
US10313312B2 (en) 2013-06-13 2019-06-04 Amazon Technologies, Inc. Key rotation techniques
US11470054B2 (en) 2013-06-13 2022-10-11 Amazon Technologies, Inc. Key rotation techniques
US11323479B2 (en) 2013-07-01 2022-05-03 Amazon Technologies, Inc. Data loss prevention techniques
US10721075B2 (en) 2014-05-21 2020-07-21 Amazon Technologies, Inc. Web of trust management in a distributed system
US10587405B2 (en) 2014-06-27 2020-03-10 Amazon Technologies, Inc. Supporting a fixed transaction rate with a variably-backed logical cryptographic key
US9942036B2 (en) 2014-06-27 2018-04-10 Amazon Technologies, Inc. Supporting a fixed transaction rate with a variably-backed logical cryptographic key
US11368300B2 (en) 2014-06-27 2022-06-21 Amazon Technologies, Inc. Supporting a fixed transaction rate with a variably-backed logical cryptographic key
US11626996B2 (en) 2014-09-15 2023-04-11 Amazon Technologies, Inc. Distributed system web of trust provisioning
US9866392B1 (en) 2014-09-15 2018-01-09 Amazon Technologies, Inc. Distributed system web of trust provisioning
US9608993B1 (en) 2016-02-01 2017-03-28 International Business Machines Corporation Credential abuse prevention and efficient revocation with oblivious third party
CN109636116A (en) * 2018-11-14 2019-04-16 遵义华正电缆桥架有限公司 A kind of equipment of security power construction

Also Published As

Publication number Publication date
ES2911500T3 (en) 2022-05-19
CA2816989A1 (en) 2012-05-10
EP2635994A4 (en) 2016-12-28
US20180234850A1 (en) 2018-08-16
ES2932380T3 (en) 2023-01-18
EP3684007B1 (en) 2022-10-19
CA3077012C (en) 2022-07-12
SG190152A1 (en) 2013-06-28
US10455420B2 (en) 2019-10-22
CN103430183A (en) 2013-12-04
TWI536285B (en) 2016-06-01
US10609562B2 (en) 2020-03-31
CA3077012A1 (en) 2012-05-10
JP2016194931A (en) 2016-11-17
JP6349347B2 (en) 2018-06-27
AU2011323917A1 (en) 2013-05-30
DK3664367T3 (en) 2022-04-11
US9961550B2 (en) 2018-05-01
EP3664367A1 (en) 2020-06-10
JP2014501955A (en) 2014-01-23
DK3684007T3 (en) 2022-12-19
EP2635994A1 (en) 2013-09-11
US20160249220A1 (en) 2016-08-25
EP3664367B1 (en) 2022-03-23
CA2816989C (en) 2020-05-26
EP2635994B1 (en) 2020-03-04
US20120116602A1 (en) 2012-05-10
BR112013011804A2 (en) 2016-11-01
MY168385A (en) 2018-10-31
KR101430376B1 (en) 2014-08-13
KR20130101107A (en) 2013-09-12
EP3684007A1 (en) 2020-07-22
AU2011323917B2 (en) 2016-02-25
TW201229932A (en) 2012-07-16
CN103430183B (en) 2016-04-20

Similar Documents

Publication Publication Date Title
US10609562B2 (en) Physically secured authorization for utility applications
US8918639B2 (en) Smarter leveraging of the power grid to substantially improve security of distributed systems via a control plane data communication network over the smart power grid
US8971537B2 (en) Access control protocol for embedded devices
CN110753344B (en) NB-IoT-based smart meter secure access system
AU2014238118A1 (en) Secure end-to-end permitting system for device operations
US20220191693A1 (en) Remote management of hardware security modules
CN105991524A (en) Family information security system
US20030200322A1 (en) Autonomic system for selective administation isolation of a secure remote management of systems in a computer network
CN100440190C (en) Surrogate mode safety remote access technology
CN102412962B (en) The distribution method and device of group secure connection joint ciphering key AK
CN110661803A (en) Gate encryption control system and method
JP2001350652A (en) Operation log accumulating device and operation log accumulation control method
KR102160453B1 (en) Protection system and method of electric power systems
KR102423178B1 (en) Agent based cryptographic module interworking system and its method
Edgar et al. Cryptographic Trust Management System Design Document
Asavachivanthornkul Best practices and research for handling demand response security issues in the smart grid

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 201180059505.X

Country of ref document: CN

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

Ref document number: 11838427

Country of ref document: EP

Kind code of ref document: A1

ENP Entry into the national phase

Ref document number: 2816989

Country of ref document: CA

NENP Non-entry into the national phase

Ref country code: DE

ENP Entry into the national phase

Ref document number: 2013537679

Country of ref document: JP

Kind code of ref document: A

WWE Wipo information: entry into national phase

Ref document number: 2011838427

Country of ref document: EP

ENP Entry into the national phase

Ref document number: 2011323917

Country of ref document: AU

Date of ref document: 20111011

Kind code of ref document: A

ENP Entry into the national phase

Ref document number: 20137014246

Country of ref document: KR

Kind code of ref document: A

REG Reference to national code

Ref country code: BR

Ref legal event code: B01A

Ref document number: 112013011804

Country of ref document: BR

ENP Entry into the national phase

Ref document number: 112013011804

Country of ref document: BR

Kind code of ref document: A2

Effective date: 20130506