This disclosure relates to security systems and more particularly to access control systems.
Access control systems are installed in buildings to restrict access only to individuals that are authorized to enter specified areas. For example, some access control systems require presentation of employee access badges to a card reader before entering a facility and before entering certain areas within a facility.
When such systems are installed, a technician configures the features of the system according to the operational requirements of the facility.
Some very old and/or inexpensive systems were configured using an alpha-numeric panel located at the access point. Currently, due to the complex requirements imposed on access control systems these systems are configured by the technician setting dip switches and/or using a computer and/or remote software, via a computer. Due to the complex input requirements of such access control systems and the codes that need to be entered, configurations of complex access control systems take significant time to complete.
According to an aspect a system includes a facility supporting, an access controller, at least one ingress card reader and an auto-enrollment type controller including a front panel having a single button, a controller board, a terminal block for connecting at least the one ingress card reader to the auto-enrollment type controller board and to connect the auto-enrollment type controller to door locks, and a mounting plate, with the auto-enrollment type controller being configured by a user according to operational requirements of the facility by the user asserting the button for a defined period of time.
According to an additional aspect an auto-enrollment type access controller includes a front panel having a single button, a controller board, a terminal block for connecting at least one card reader and door locks to the auto-enrollment type controller board; and a mounting plate, the controller board comprising a process and memory configured to execute an auto-enrollment process by assertion of the button for defined period of time.
According to an additional aspect a method of enrolling auto-enrollment type access controller for access control includes asserting a button for on the auto-enrollment type access controller for a specified duration to enter an auto-enrollment process, entering by the auto-enrollment type access controller an enroll mode that transmits to a gateway an enroll broadcast to cause the gateway to add the auto-enrollment type access controller's credentials to an unassigned controller table, receiving an enrollment confirmation from the gateway, acknowledging by access controller at confirmation receipt, receiving via the gateway assignment information including IP configuration information designating the controller as a master controller.
One or more of the above aspects may provide one or more of the following advantages.
Systems employing these techniques have a simplified programming techniques such that configuration of an access control system for a card reader is simplified in terms of function and architectural design. When such systems are installed by a technician these aspects greatly simplify configuration and avoid using an alpha-numeric panel or meeting complex requirements by the technician setting dip switches and/or using a computer and/or remote software, via a computer thus minimizing the time to complete.
The details of one or more embodiments of the invention are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the invention will be apparent from the description and drawings, and from the claims.
Referring now to
Referring now to
During installation of an access control system 30, the access controllers, whether the legacy access controllers 32, 34 or the auto-enrollment type controllers 36 features of the access controllers 32, 34 and 36 and the access control system 30 are configured by a technician according to operational requirements of the facility 10. While the legacy access controllers 32, 34 are configured by a technician entering information using an alpha-numeric panel located at the access point (for very old and/or inexpensive system) or using dip switches and/or remote software for more complex legacy systems, the auto-enrollment type controllers 36 feature an auto-enrollment process 40 (
Referring now to
Referring now to
The control starts 52 when the button is pressed 54. Depending on the duration of the button being pressed certain actions are performed. For example, when the auto-enrollment type access controller 36 has been in communication with the software at least once, the controller will cause diagnostic LED to light and report diagnostics, when the button is asserted for 3 seconds. The controller 36 broadcasts 56 a report message to the server 39, connects 58 to the server 39 and when a connection is established 60 with the server 39, the auto-enrollment type access controller 36 reports 60 diagnostics to the server 39.
When auto-enrollment type access controller 36 has not established communication with the server 39, e.g. was not programmed and is asserted for at least 6 seconds it will stay on for 10 minutes unless the front button is pressed again. The button 38 is used as an enrollment button, when pressed for, e.g., 6 seconds. The auto-enrollment type access controller 36 sends an enrollment broadcast message every 30 seconds for a period of 10 minutes in order to access the server 39 and will cause an LED to flash when the broadcast has been received from the server 39 or the auto-enrollment type access controller 36 can cause a transducer to produce a noise, e.g., a beep to tell an installer that the server 39 has received the information correctly and the auto-enrollment type access controller 36 is ready to be programmed.
Referring now to
While the button is pressed for here six seconds, the auto-enrollment process for the auto-enrollment type access controller 36 broadcasts 72 during a 10 minute period at interval of 30 seconds. If the auto-enrollment type access controller 36 was not programmed, it receives a broadcast confirmation and waits to be programmed. The server 39 sends a broadcast every, e.g., minute.
Six of such scenarios include enrollment of the auto-enrollment type access controller as a master over an IP connection; enrollment of the auto-enrollment type access controller as a master over an IP connection over a wide area network using the “call home” process; enrollment as a slave auto-enrollment type access controller over an IP connection; enrollment as slave auto-enrollment type access controller over an IP connection without call home; enrollment as a slave auto-enrollment type access controller over an IP connection without operator assistance; and enrollment as a slave auto-enrollment type access controller over an RS-485 connection without an operator. The auto-enrollment type access controller 38 has several modes used during various enrollment actions.
Mode 1 (Enroll mode), the auto-enrollment process for the auto-enrollment type access controller goes into this mode when unit in factory default and the button is pressed for a period of 6 seconds. While in this mode the unit sends an enroll broadcast message every 30 seconds for a period of 10 minutes. An LED turns on to signal entry into this mode, e.g., a white flashing every 2 seconds and there can be an audible signal from an onboard transducer. It is possible to leave the enroll mode before the 10 minute time-out by holding the button for another 6 seconds.
If auto-enrollment type access controller is set with a call home IP/Hostname, the auto-enrollment type access controller transmits a “Network Pulse” along with the Broadcast including IP Address (xxx.xxx.xxx.xxx), Subnet Mask (xxx.xxx.xxx.xxx), Model, Serial Number and MAC Address (media access control address a unique identifier assigned to network interfaces for communications on the physical network layer. MAC addresses are used as a network address for most IEEE 802 network technologies, including Ethernet.) In addition, in some implementations optionally values for some of the following characteristics are also sent with the Network Pulse:
Mode 2 (Enrollment Acknowledged): When auto-enrollment process for the auto-enrollment type access controller received an ACK “acknowledge”, the transducer beeps 4 times and the LED flash 2.5 sec burst with a pink color, emits an audible 2.5 second burst through the onboard piezoelectric speaker and goes back to factory default mode.
Mode 3 (Prioritize Enroll Slave): Enrollment Mode is auto-enrollment process for the auto-enrollment type access controller that is configured as master and an established communication. While master controller is in master enrollment mode (button held for 6 seconds), any slave broadcast received will be added to the existing connection automatically. While in this mode the LED turns WHITE and flashes every 2 seconds. The Controller will go out of mode 3 after 10 minutes if it has not received any “Enroll” request. It is possible to enter mode 3 as many times as needed. If Controller is programmed with Call Home, a “Network Pulse” is sent to the server 39 at the IP/Hostname every minute. The auto-enrollment process for the auto-enrollment type access controller broadcasts the unit's credentials including model, serial number and MAC address to the server 39.
In some implementations the auto-enrollment process for the auto-enrollment type access controller automatically sends the credentials to the server 39 without the need of writing the model, s/n or MAC addresses, in order to limit the amount of traffic on the customer's network to produce a new connection using pre-loaded credentials of the auto-enrollment type access controller. This can occur while the auto-enrollment type access controller 1 is in factory default, and it has not been programmed in the server 39 and the auto-enrollment type access controller is connected to a network with DHCP (Dynamic Host Configuration Protocol (DHCP) is a standardized networking protocol used on Internet Protocol (IP) networks for dynamically distributing network configuration parameters, such as IP addresses for interfaces and services).
Installer presses and holds 70 the button for 6 seconds, the auto-enrollment process for the auto-enrollment type access controller goes into Mode 1 (Enroll) 72. The gateway 37 receives 74 the broadcast (Enroll), adds 76 the auto-enrollment type access controller's credentials to the “unassigned controller table” and sends enrollment confirmation. The auto-enrollment type access controller goes 78 into Mode 2 (Acknowledged) at the confirmation receipt.
An operator 80 at a workstation at the server 39 produces a new connection in the workstation and selects an auto-enrollment type access controller from the “Unassigned controller table” and assigns 84 the controller 36 as a master controller into the new connection. The gateway 37 sends 86 a broadcast to the auto-enrollment type access controller 36, and saves 88 the configuration. The auto-enrollment type access controller 36 receives 90 the IP configuration, reboots 92, and connects 94 back to the gateway 37 so it is now on-line 94. The gateway 37 sends configuration to the auto-enrollment type access controller 96. Only one auto-enrollment type access controller needs to be enrolled as master per U\IP connection.
Referring now to
When another auto-enrollment type access controller 36 is already enrolled as master and connected to the gateway 37, other auto-enrollment type access controllers 36 can be configured through the master. These other auto-enrollment type access controller (s) 36 can be enrolled as a slave controller to another master controller by the installer pressing and holding the button 38 on that auto-enrollment type access controller 36 for 6 seconds.
From the technician's point of view the process is the same, as depicted in
When another auto-enrollment type access controller is already enrolled as master and connected to the gateway, other auto-enrollment type access controllers can be configured through the master with entering call home mode, by the installer pressing and holding the button for 6 seconds at which point the other auto-enrollment type access controller(s) are configured through the master. One or many master auto-enrollment type access controller(s) on various IP connections receives the broadcast and forwards slave's credentials to one or many Gateway(s). The gateway(s) adds the slave auto-enrollment type access controller credentials to the “Unassigned controller table” and sends enrollment confirmation to the master auto-enrollment type access controller.
At the confirmation receipt, the master auto-enrollment type access controller sends enrollment confirmation to the slave auto-enrollment type access controller. The slave auto-enrollment type access controller goes into Mode 2 (Acknowledged) at the confirmation receipt. The operator selects the auto-enrollment type access controller from the “Unassigned controller table” and assigns it as a slave controller in an existing connection. The master auto-enrollment type access controller sends broadcast to slave auto-enrollment type access controller; the slave auto-enrollment type access controller receives the IP configuration, reboots and connects back to the master auto-enrollment type access controller. Both auto-enrollment type access controller (master and slave) are on same Local Area Network. If multiple master auto-enrollment type access controller receives the broadcast, each will attempt to add the auto-enrollment type access controller to the “Unassigned controller table” and the server 39 will automatically purge duplicate entries.
Referring now to
The process from the installer point of view is similar to that in
Only one master auto-enrollment type access controller can be in Mode 3 at a time. The Enrollment mode is entered when controller is set as master and Online with Gateway. If multiple master auto-enrollment type access controller or Gateways receive the broadcast, each will attempt to add the auto-enrollment type access controller to the “Unassigned controller table”. The server 39 will not accept duplicate entries unless one of masters sends a credential that includes the “Prioritize” flag.
Similar as in
The Head Controller, i.e., master/slave configuration approach using IP communication with controllers is suitable for a one-door, dual card reader controller such as the auto-enrollment type access controller. Rather, than define one site for each door the master/slave configuration becomes more efficient. The auto-enrollment type access controller supports POE, thus having to connect ‘slaves controllers’ to an RS-485 connection makes the auto-enrollment type access controller less attractive and sometimes even restrictive. A solution is to add a new communication ‘Path’ between the server 39 and the controllers, via this master controller.
A Traditional Communication Architecture had a head controller connect to a server 39 using an IP connection and have other slave controllers connect in a serial fashion to the head controller by a last one of the slave controllers connecting to a preceding slave controller, and so forth until a first one the slave controllers connect to the master. The master controller (Defined at position 0 in the server 39 site definition) communicates using UDP/IP (user datagram protocol over Internet Protocol) or TCP/IP (transmission control protocol over Internet Protocol) communication, and discovers slave controllers using UDP/IP and transfer data both ways, via a router.
Hybrid connectivity combines both of the above solutions all together at once. Slave controllers defined at positions 1˜31 in the server can be connected either on the RS-485 connector or on the same IP network as the master controller. The server 39 issues a start poll′ to the ‘Head Controller’, and looks into its controller table for defined controllers that could be connected through IP. The ‘Head Controller’ broadcasts on its local subnet mask using a command ‘IP_CMD_KTBROADCAST_USING_SERIAL’ command. This command is used in lieu of a command that relies on the presence of MAC addresses in the Head Controller, as the head controller does not possess the MAC addresses of its eventual slave controllers, as the server 39 does. But the head controller does have the slave controller serial numbers that are also unique (at production level) and are used to discover the new devices through broadcast.
The slave controller is not connected directly to the server 39 but to the slave it appears that it is, the slave controller reboots after receiving its configuration from the ‘Head Controller’ and is instructed to communicate to with the server 39 an address corresponding to the IP address of the ‘Head Controller’. The server 39 is also instructed to poll only one controller: itself. Shortly after the ‘Head Controller’ establishes initial communication with the server 39 all of the ‘slave IP controllers’ reboot at site initialization and until a factory default is performed on the slave controllers.
For protocols with minimal support where packets that were sent to over an RS-485 connection and were ‘wrapped’ into an IP command and then unwrapped by the ‘Head Controller’ and sent to the slave BUS rather than having the ‘Head Controller’ at position 0 and the slave controllers at other positions and thus requiring all slaves IP controllers to be mapped at position 0, the master controller is permitted to reside at any device position.
Referring now to
Memory stores program instructions and data used by the processor of the access controller and/or server, smart phone, tablet and other computer systems. The memory may be a suitable combination of random access memory and read-only memory, and may host suitable program instructions (e.g. firmware or operating software), and configuration and operating data and may be organized as a file system or otherwise. The stored program instruction may include one or more authentication processes for authenticating one or more users. The program instructions stored in the memory of the panel may further store software components allowing network communications and establishment of connections to the data network. The software components may, for example, include an internet protocol (IP) stack, as well as driver components for the various interfaces, including the interfaces and for some of the systems a keypad/keyboard. Other software components suitable for establishing a connection and communicating across network will be apparent to those of ordinary skill.
Program instructions stored in the memory, along with configuration data may Control overall operation of the panel.
The server includes one or more processing devices (e.g., microprocessors), a network interface and a memory (all not illustrated). The server may physically take the form of a rack mounted card and may be in communication with one or more operator terminals (not shown). Each server address may be static, and thus always identify a particular server. Alternatively, dynamic addresses could be used, and associated with static domain names, resolved through a domain name service.
The network interface card interfaces with the network to receive in incoming signals, and may for example take the form of an Ethernet network interface card (NIC). The servers may be computers, thin-clients, or the like and have access to a subscriber database that includes a database under control of a database engine. The database may contain entries corresponding to the various subscriber devices/processes.
All or part of the processes described herein and their various modifications (hereinafter referred to as “the processes”) can be implemented, at least in part, via a computer program product, i.e., a computer program tangibly embodied in one or more tangible, physical hardware storage devices that are computer and/or machine-readable storage devices for execution by, or to control the operation of, data processing apparatus, e.g., a programmable processor, a computer, or multiple computers. A computer program can be written in any form of programming language, including compiled or interpreted languages, and it can be deployed in any form, including as a stand-alone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program can be deployed to be executed on one computer or on multiple computers at one site or distributed across multiple sites and interconnected by a network.
Actions associated with implementing the processes can be performed by one or more programmable processors executing one or more computer programs to perform the functions of the calibration process. All or part of the processes can be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) and/or ASIC (application-specific integrated circuit).
Processors suitable for the execution of a computer program include, by way of example, both general and special purpose microprocessors, and any one or more processors of any kind of digital computer. Generally, a processor will receive instructions and data from a read-only storage area or a random access storage area or both. Elements of a computer (including a server) include one or more processors for executing instructions and one or more storage area devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from, or transfer data to, or both, one or more machine-readable storage media, such as mass storage devices for storing data, e.g., magnetic, magneto-optical disks, or optical disks.
Tangible, physical hardware storage devices that are suitable for embodying computer program instructions and data include all forms of non-volatile storage, including by way of example, semiconductor storage area devices, e.g., EPROM, EEPROM, and flash storage area devices; magnetic disks, e.g., internal hard disks or removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks and volatile computer memory, e.g., RAM such as static and dynamic RAM, as well as erasable memory, e.g., flash memory.
In addition, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. In addition, other actions may be provided, or actions may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Likewise, actions depicted in the figures may be performed by different entities or consolidated.
Elements of different embodiments described herein may be combined to form other embodiments not specifically set forth above. Elements may be left out of the processes, computer programs, Web pages, etc. described herein without adversely affecting their operation. Furthermore, various separate elements may be combined into one or more individual elements to perform the functions described herein.
A number of embodiments of the invention have been described. Nevertheless, it will be understood that various modifications may be made without departing from the spirit and scope of the invention. Accordingly, other embodiments are within the scope of the following claims.