1. Field of the Invention
The present invention relates to access control systems, and more particularly to a feed protocol used to report status and event information in a physical access control system.
2. Description of the Related Art
A physical access control system includes one or more access controllers which are used to restrict access to one or more physical locations by controlling physical barriers, such as doors, turnstiles, elevators, gates, etc. A physical access control system is distinguished from logical access control systems, such as used to restrict access to data or information on a computer system or the like. A physical access control system may further include local controllers and servers for managing message communications, where such messages include event information, status information, alarm information, etc. Conventional physical access control systems used a proprietary or specialized event reporting communication application or messaging service since there was no standard format or syntax for alarm or event reporting. Management technologies, therefore, have been tied directly to the event source since the message format had to be decided upon beforehand to ensure conformance with the syntax. The relationship with the reporter, or producer, and the receiver, or consumer, had to be tightly coupled because it was based on push technology in which the producer asynchronously transmitted the data to the consumer. The tight coupling had to be established before any messages could be sent. The specialized and proprietary nature of conventional physical access control systems along with requisite tight coupling between information producers and consumers made integration very difficult. Integration concerns expanding an existing system such as adding additional controllers or servers or management consoles or the like.
It is desired to provide a messaging service in an access control system that facilitates integration.
The benefits, features, and advantages of the present invention will become better understood with regard to the following description, and accompanying drawings where:
The following description is presented to enable one of ordinary skill in the art to make and use the present invention as provided within the context of a particular application and its requirements. Various modifications to the preferred embodiment will, however, be apparent to one skilled in the art, and the general principles defined herein may be applied to other embodiments. Therefore, the present invention is not intended to be limited to the particular embodiments shown and described herein, but is to be accorded the widest scope consistent with the principles and novel features herein disclosed.
The physical access control system 100 further includes several local controllers (LC) 105, individually shown as LC1 and LC2, for controlling selected ones of the access controllers 103. Each local controller 105 is configured to make access decisions, such as including processor logic (not shown) and memory (not shown). The memory of the local controller 105, for example, stores a local cache of tokens or the like. In one embodiment, each local controller 105 operates to receive a token via a reader device of a corresponding access device 103, compares the received token with the tokens in its local token cache to make an access decision, and grants or denies access depending upon the decision result. If the received token matches a stored token, then access is granted and the local controller 105 controls the corresponding access device to grant access based on the access decision. If the token is not found, then access is denied.
Each token at any given local controller 105 may be authorized for selected times or according to predetermine rules. In one embodiment, for example, a scenarios database or the like incorporates access rules, scheduling information, operational modes, etc., for maintaining the access information for each local controller 105. A given token may have few, if any, limitations, meaning that it allows access to all areas at all times. Other tokens may have certain qualifications or limitations, such as allowing access only to selected areas, or allowing access only for selected times, or allowing access only for certain dates, or any combination of these limitations. Such qualifications are associated with scenarios, which describe general operational modes for each local controller 105, including rules applied to each token. The scenarios encompass various operational modes, such as emergency situations or scheduled events or time periods. In general, the scenarios determine which tokens are authorized for which areas for which times and for which situations or conditions. Each token may further include flags or the like for turning on and off authorization or modifying access rules or scenarios or access conditions associated with that token. For example, selected tokens may be enabled or disabled during certain times or dates, such as daytime/nighttime or weekday/weekend, etc. It is appreciated by those skilled in the art that any number of flags may be defined for each token.
In the illustrated embodiment, the physical access control system 100 includes one or more local controllers 105, each associated with or otherwise controlled by at least one access server (AC) 107. Although only two access servers 107 are shown, individually labeled AS1 and AS2, it is understood that the physical access control system 100 may include any number of access servers depending upon the particular configuration. The access controllers 103, the local controllers 105 and the access servers 109 are all coupled to a network 109. A management console (MC) 111 is also provided and coupled to the network 109. Each access controller 103 monitors and collects status and event information for a corresponding one of the doors 101. In one embodiment, the status and event information includes any type of relevant information suitable for the particular implementation of the physical access control system 100, such as access controller status (e.g., door open, door closed, door locked, door unlocked, etc.), local controller status (e.g., controller online/offline, access allowed events, access denied events, etc.), various types of alarms (e.g., door forced, door held, device tamper, etc.), etc.
The network 109 may incorporate any wired or wireless communication configuration or any combination thereof. Each of the access controllers 101, the local controllers 105, the access servers 107, the management console 111, etc., may be coupled to the network 109 using wired or wireless communications or the like. The network 109 is typically a relatively high bandwidth and/or high reliability network. The physical access control system 100 may be implemented as a closed system and/or otherwise a secure system. The network 109, for example, may be isolated from other networks to maintain a high level of security. In alternative embodiments, the network 109 includes less secure portions and may even be coupled to one or more public or larger networks, such as the public switched telephone network (PSTN) and/or the Internet and the like. As an example, the management console 111 may be externally coupled via the Internet for retrieving status and event information of selected access servers 107 within the physical access control system 100. In various embodiments, such as those including limited security or non-secure networks, secure communications between the controllers, servers, consoles, etc., may be facilitated using encrypted communication methods or channels. The network 109 is configured to enable communications according to any suitable type of communication protocol, such as, for example, the Hypertext Transfer Protocol (HTTP) or the like. A secure HTTP connection (e.g., HTTPS) or the like may be employed to provide a suitable level of authentication and encryption to prevent unauthorized access or control of the system.
The management console 111 monitors status and events and manages operations of selected devices, controllers, access servers, etc., within the physical access control system 100. As shown, the access controller AC1 collects status and event information of the door D1 and reports the collected information to the local controller LC1 via the network 109 as indicated by arrow 113. In a similar manner, the access controller AC2 collects status and event information of the door D2 and reports the collected information to the local controller LC1 via the network 109 as indicated by arrow 115. Furthermore, the access controllers AC3 and AC4 collect status and event information of the doors D3 and D4, respectively, and report this information to the local controller LC2 as indicated by arrows 117 and 119, respectively. In this manner, the local controller LC1 collects aggregated status and event information about doors D1 and D2 and the local controller LC2 collects aggregated status and event information about doors D3 and D4. The local controllers LC1 and LC2 further report aggregated status and event information to the access server AS1 via the network 109 as illustrated by arrows 121 and 123, respectively. The access server AS1 reports aggregated status and event information to the management console 111 via the network 109 as indicated by the arrow 125. The access server AS2 may collect similar status and event information from either one or both of the local controllers 105 or other local controllers (not shown) and report this information to the management console 111.
In conventional configurations, management consoles were essentially coupled to the network at “fixed” or predetermined known locations using point to point communications and the like. A proprietary, closed and relatively static event-driven protocol was used to enable communication between a fixed management console and selected access servers. Information communicated by an access server was interrupt-driven and communicated to particular management console(s) in an asynchronous manner, such as via a targeted communication or the like. In such a static and proprietary system, the conventional management console had to be connected and operational to receive and record the event communications, or otherwise receive a “dump” of queued event communications when brought online. The proprietary communication protocol of the conventional management console had to be specifically configured to receive and manage communications.
As described further below, each of the devices of the physical access control system 100 communicate via the network 109 employing a standardized and easily configurable message syntax that enables other devices to subscribe and unsubscribe to other devices at any time. As shown, for example, the management console 111 may directly receive the status and event information collected by the local controller LC1 via the network 109 as illustrated by arrow 127. The management console 111 may subscribe to receive the status and event information from any other local controller in the system in similar manner. Also, the management console 111 may also directly receive the status and event information detected by the access controller AC1 via the network 109 as illustrated by arrow 129. The management console 111 may subscribe to receive the status and event information from any other access controller in the system in similar manner. Furthermore, the access server AS1 may directly receive the status and event information of the access controller AC1 via the network 109 as illustrated by arrow 131, thereby bypassing the local controller LC1. The access server AS1 (or any other access server) may subscribe to receive the status and event information from any other access controller in the system in similar manner.
In one embodiment, the consumer logic 201 is included within any device of the physical access control system 100 for requesting information from other producer devices, such as within the local controllers 105, the access servers 107, and the management console 111. The consumer logic 201 may be included within any one of the access controllers 103 in the event it is desired to transfer status and event information from one access controller to another. In one embodiment, the producer logic 203 is included within any device of the physical access control system 100 for providing information in response to requests from other devices, such as within the access controllers 103, the local controllers 105, the access servers 107, and the management console 111. The management console 111 includes the producer logic 203 if it is desired to send information from to another management console (not shown) or to transmit information to other management devices (not shown). It is appreciated that any given device within the physical access control system 100 may include both the consumer logic 201 and the producer logic 203.
The consumer logic 201 includes a message processor 205 which further incorporates or otherwise interfaces a list of aggregated status and events, shown as a status and event document (S&E DOC) 207. The status and event information aggregated into the status and event document 207 may come from any one or more of a variety of sources depending upon which device incorporates the consumer logic 201 and from which devices it requests the information. The message processor 205 interfaces retrieve event feed logic 209 which generates a request message 211 and sends the request message 211 to the producer logic 203 via the network 109. The producer logic 203 responds with a status and event message 213 via the network 109 containing requested information. The status and event message 213 is provided to the message processor 205, which incorporates any new information contained within the message 213 into the status and event document 207.
In one embodiment, the consumer logic 201 includes polling logic 215 coupled to the message processor 205 and the retrieve event feed logic 209. The message processor 205 programs the polling logic 215 according to a predetermined time period or according to predetermined conditions or criterion, and the polling logic 215 times out and interrupts or otherwise communicates to the retrieve event feed logic 209. In response to a polling interrupt or communication from the polling logic 215, the retrieve event feed logic 209 generates and sends another message 211 to the producer logic 203. In one embodiment, the polling logic 215 includes a timer or the like which generates an interrupt upon expiration of each time period (e.g., every millisecond, every second, every minute, etc.). In another embodiment, the polling logic 215 incorporates more sophisticated logic for polling based on selected time periods and/or other events or dates or information or criterion. As an example, the polling logic 215 may be programmed to adjust the frequency of polling of certain producer devices during certain time of day or during certain days of the week, etc.
The producer logic 203 includes a message processor 217, which further incorporates or otherwise interfaces a list of aggregated status and events, shown as a status and event document 219. In one embodiment, the producer logic 203, or the device incorporating the producer logic 203, further includes consumer logic 221 configured in substantially the same manner as the consumer logic 201 for requesting status and event information from other devices in the physical access control system 100. For example, in one embodiment the local controller LC1 includes the consumer logic 221 (which may be configured in similar manner as the consumer logic 201) to request and collect status and event information from the access controllers AC1 and AC2, and further includes the producer logic 203 to provide the aggregated information to a requesting consumer device, such as the access server AS1 and/or the management console 111. It is noted that any device incorporating both the consumer logic 201 and the producer logic 203 may have a single message processor (e.g., message processors 205 and 217 are combined as a single processor) which manages a single status and event document (e.g., status and event documents 207 and 219 are combined as a single document). As shown, the consumer logic 201, or the device incorporating the consumer logic 201, may also include producer logic 229 coupled to the message processor 205. The producer logic 229 may be configured in substantially the same or similar manner as the producer logic 203, and may further employ the same message processor 205 of the consumer logic 201 rather than a separate message processor.
In one embodiment, the producer logic 203, or the device incorporating the producer logic 203, includes monitoring and detection logic 223 for monitoring status and detecting events associated with a corresponding one of the doors 101 or the like. Each access controller 103, for example, may include the monitoring and detection logic 223 for detecting the status and event information from at least one source (e.g., door 101 or the like) within the physical access control system 100. The status and event information from either one or both of the consumer logic 221 and the monitoring and detection logic 223 is provided to and collected by the message processor 217 and stored within the status and event document 219.
The producer logic 203 further includes return feed list logic 225 interfaced with the message processor 205 for responding to request messages 211 sent from the consumer logic 201 via the network 109. The return feed list logic 225 examines or otherwise parses the request message 211 and communicates with the message processor 217 to generate the corresponding status and event message 213, which is sent back to the consumer logic 201 in response to the request message 211. The message processor 217 gathers the status and event information within the status and event document 219 according to the request message 211 into the status and event information message 213 and then sends the message 213 back to the consumer logic 201. In certain embodiments, the request message 211 is configured as a simple request indication such that the producer logic 203 responds by incorporating substantially all of the information from the status and event document 219 into the status and event message 213. The message processor 205 is configured to filter out and discard redundant or obsolete status and event information and incorporate only new or updated information into the status and event document 207. In various embodiments, the message processor 217 is also configured according to predetermined rules or the like to filter out or otherwise remove obsolete information.
In other embodiments, the request message 211 incorporates one or more arguments or values or parameters or switches or the like to identify particular information requested or to otherwise limit the amount of information incorporated within the status and event message 213. In the illustrated embodiment, for example, each entry of the status and event documents 219 and 207 include a temporal value, such as a timestamp (TS) or a sequence number (SN) or the like indicative of when or in which order the status indication or event occurred. In this embodiment, the request message 211 may include an UPDATE SINCE value 227 including one or more temporal parameters, such as a timestamp and/or a sequence number or the like. The return feed list logic 225 detects whether the UPDATE SINCE value 227 is set, and if so, retrieves the temporal parameter(s) associated with the UPDATE SINCE value 227 and instructs the message processor 217 to include only the information after the SN or subsequent to the TS within the status and event message 213. In this manner, the UPDATE SINCE value 227 of the request message 211 may be used to limit the amount of data transmitted on the network 109, such as to new or updated information.
For example, the retrieve event feed logic 209 may send an initial request message 211 as a simple request or with the UPDATE SINCE value 227 not set or otherwise cleared to retrieve all of the status and event information contained within the status and event document 219. The message processor 205 receives and provides the last TS or SN of the last status and event message 213 to the retrieve event feed logic 209. Subsequently, when the retrieve event feed logic 209 sends another request message 211, such as, for example, in response to an interrupt from the polling logic 215, the retrieve event feed logic 209 sets the UPDATE SINCE value 227 and incorporates the last provided TS or SN. The return event feed logic 225 detects the UPDATE SINCE value 227 and provides the TS or SN to the message processor 217, which incorporates only updated status and event information into the status and event message 213 as of the TS or SN. The retrieve event feed logic 209 may continue to use the UPDATE SINCE value 227 in subsequent requests so that only updated information is provided in subsequent status and event messages. In this manner, the consumer logic 201 remains updated while minimizing information transmitted on the network 109.
The polling method employed between the consumer logic 201 and the producer logic 203 provides significant benefits over interrupt methods employed by conventional physical access control systems. Rather than having to wait for one or more producers to send new information, a consumer device simply polls one or more applicable producer devices for all available status and event information. For example, the local controller LC1 polls the access controllers AC1 and AC2 for any stored status and event information. The consumer device then polls each of the applicable producer devices on a periodic basis to retrieve only updated information since the last poll. It may be desired, however, that certain events, such as alarms or the like, be sent immediately rather than waiting for the next poll event. In one embodiment, the consumer logic 201 further includes trigger logic 231 coupled to the message processor 205. The message processor 205 instructs the trigger logic 231 to send a tickle request message 233 to the producer logic 203, which includes tickle logic 235 responsive to each tickle request message 233. The tickle logic 235 monitors the message processor 217 for any new events according to the tickle request message 233. At any time the tickle logic 235 detects new events as indicated by the tickle request message 233, it sends a tickle information message 237 to the trigger logic 231 with aggregate information regarding the new events. In one embodiment, the aggregate information within the tickle information message 237 is not the status or event information itself but instead includes differential information 238, such as the number of new events meeting the parameters of the corresponding tickle request message 233, the time(s) the new events were added, etc. When the trigger logic 231 receives the tickle information message 237, it instructs the retrieve event feed logic 215 to send an immediate request message 211 to the producer logic 203 to retrieve the new information. In one embodiment, the retrieve event feed logic 209 further resets the polling logic 215.
In one embodiment, the tickle request message 233 may be a relatively simple message which requests that the tickle logic 235 respond when any new status or event information is available by the message processor 217. It is appreciated, however, that much of the new information is either status or low priority event information such that the polling process may be sufficient. In another embodiment, the tickle request message 233 includes at least one event type value 239 which specifies any subset of the types of new events that may occur. For example, in one embodiment the event type value 239 specifies alarms or certain types of alarms or any other types of high priority events, so that the tickle logic 235 sends the tickle information message 237 only for those events indicated by the event type value 239. In response to the new event, the retrieve event feed logic 209 sends an ‘asynchronous’ request message 211 to request an immediate update including the new event(s). In this manner, the polling method including the UPDATE SINCE value 227 along with the tickle method including the event type value 239 ensures that the consumer logic 201 remains up-to-date and is further informed immediately of predetermined and selected events (e.g., high priority events), such as alarms and the like. In one embodiment, the tickle logic 235 is configurable to respond only in the event of new information, to respond after a predetermined period of time regardless of whether any new information is available, or to respond after a configurable time period regardless of whether any new information is available, or any combination of these methods.
In one embodiment, the status and event documents 207 and 219 and/or the messages transmitted between consumer devices and producer devices, such as the messages 211, 213, 233, 237, RM1-RM3, SEM1-SEM3, 503, etc., are configured according to a commonly accepted message syndication protocol, such as the Extensible Markup Language (XML) or the HyperText Markup Language (HTML) or the like. In one embodiment, the documents and/or messages are implemented according to the Really Simple Syndication (RSS) protocol or according to any other suitable type of syntax for a syndicated feed. In an alternative embodiment, the documents and/or messages are configured according to the Atom Syndication Format employing the XML language for information feeds, or the Atom Publishing Protocol (APP), which is a simple HTTP-based protocol for creating and updating web-based resources. As known to those skilled in the art, the RSS and Atom protocols are well-known for use to access web content, such as for blogs (web logs), podcasts, video blogs (vlogs), etc.
The use of RSS or Atom or any other open standard web feed data format for communicating status and event information in the physical access control system 100 provides many advantages and benefits as compared to conventional standards and protocols used in conventional physical access control systems. RSS is a polling type of protocol in which the consumer logic polls one or more producers within the system for status and event information. In this manner, the management console 111 or any other device may be coupled anywhere in the system and used to access or produce status or event information at any time. The consumer logic 201 is easily programmed to “subscribe” to any producer device including the producer logic 203 or 301 in the physical access control system 100. RSS feeds, when used for newscasts or blogs or the like, typically have a relatively low poll rate, such as once every few minutes or hours or once a day. In the physical access control system 100, the poll rate is increased to any suitable or desired rate, such as every few seconds, every one second or every sub-second interval to maintain updated information.
The content of RSS messages are generally relatively simple and designed using simple text generally suitable for human consumption. The consumer logic and the producer logic are easily implemented or otherwise written in the system based on well-known open standards. In this manner, rather than having to provide a sophisticated management console with complicated and proprietary communication software, a relatively simple modification of any type of controller, server or console enables simple yet powerful status and event reporting within the physical access control system 100. As described further below, the use of a commonly accepted message syndication protocol provides a significant benefit of facilitating integration, such as combining or linking two more physical access control systems together, adding new components to an existing system, modifying an existing system infrastructure, etc.
The illustrated embodiments also show extensions to RSS or the like without violating the basic syntax of RSS or the like. One extension is the tickle process using a separate tickle channel in which the tickle message 433 is sent by the trigger logic 231, which causes the tickle logic 235 to send the tickle information message 237 after a predetermined or configurable period of time and/or in response to detection of new status and event information, thereby provoking a new ‘asynchronous’ poll by the retrieve event feed logic 209. Another extension is the request new message process in which new information is detected (e.g., by new event detection logic 505 or the like) and communicated after a predetermined or configurable period of time and/or in response to detection of new status and event information. Another extension is the additional arguments or values or parameters or switches or the like to identify particular information requested or to otherwise limit the amount of information incorporated, such as the UPDATE SINCE value 227 incorporated into the request message 211. As previously described, the UPDATE SINCE value 227 may be used with corresponding parameters (e.g., time stamp, sequence number, etc.) to filter or otherwise limit the amount of information provided in the response message. The event type value 239 is used in a similar manner to limit the information monitored and the information returned, such as higher priority alarms and the like. Another extension is illustrated by the session tracker logic 305 which employs a session cache or the like in which the producer logic 301 tracks the information that has been given to each of one or more consumer logic 201 of consumer devices. Another extension is the rate of polling, which is increased to a relatively high rate.
In a conventional physical access control system, the addition of an NVR or other system components would require that the underlying physical access control system be modified to accommodate communications to or from the new component. As an example, the access server AS1 and other devices would otherwise have to be modified or otherwise reconfigured to “push” status and event to the newly installed NVR. Furthermore, the NVR, or any other device newly installed, would have to be compatible with the underlying system, which was typically proprietary to certain physical access control system vendors, providers, or manufacturers.
In contrast, the physical access control system 100 according to various embodiments does not need further modification for integrating the NVR 1301, since the syntax and protocol associated with message communication is according to a commonly accepted message syndication protocol which is “vendor-neutral”. As previously described, each of the components in the physical access control system 100 includes any combination of consumer or provider logic, such as the consumer logic 201 and the provider logic 203. As shown, for example, the access controller AC1 includes or otherwise interfaces at least producer (P) logic 1303 for gathering and producing status and event information associated with the door D1. The local controller LC1 includes or otherwise interfaces consumer and producer (CP) logic 1305 for retrieving status and event information from the access controller AC1 and for providing the status and event information to any other consumer device in the system, such as the access server AC1 and/or the management controller 111. The access server AS1 also includes or otherwise interfaces consumer and producer logic 1307 for retrieving status and event information from the local controller LC1 (and possibly other producer devices) and for providing aggregated status and event information to any other consumer device in the system, such as the management controller 111. The management controller 111 includes or otherwise interfaces consumer (C) logic 1309 for retrieving status and event information from any producer device in the physical access control system 100 as previously described.
As shown, the NVR 1301 includes or is otherwise interfaced with consumer logic 1311, which is similar to the consumer logic 201 previously described. The consumer logic 1311 enables the NVR 1301 to be subscribed to any relevant status and event information in the physical access control system 100, such as, for example, the status and event information from the access controller AC1 and associated with the door D1.
In one embodiment, the consumer logic 1311 of the NVR 1301 periodically polls the producer and consumer logic 1303 of the access controller AC1. In the event of an alarm associated with the door D1, the NVR 1301 receives the alarm event(s) and tags contemporaneous recorded information in the same manner as previously described. It is appreciated that the consumer logic 1311 of the NVR 1301 may further be subscribed to poll for status and event information from other consumer and producer devices aggregating status and event information associated with the door D1 in the event the access controller AC1 is unavailable or damaged or destroyed (such as in the event of a security breach associated with the door D1), such as, for example, the local controller LC1 and/or the access server AS1. It is further appreciated that the consumer logic 1311 of the NVR 1301 may employ the tickle method and/or request new event feed methods previously described if desired. It is appreciated that the physical access control system 100 requires no modification to add the NVR 1301, other than a possible extension of the network 109 to access the NVR 1301. It is further appreciated that any modification of the NVR 1301 to incorporate the consumer logic 1311 for detecting relevant status and alarm information is relatively simple and achievable without requiring proprietary equipment or special knowledge or expertise.
A physical access control system according to one embodiment includes a network, at least one access controller, a producer device and a consumer device. Each access controller generates status and event information associated with at least one controlled physical barrier. The producer device includes producer logic which collects and stores the status and event information via the network. The consumer device includes consumer logic which periodically polls the producer logic via the network to retrieve the status and event information from the producer device. The producer logic and the consumer logic communicate via the network according to a commonly accepted message syndication protocol.
In one embodiment, the commonly accepted message syndication protocol is the really simple syndication (RSS) protocol. In another embodiment, the commonly accepted message syndication protocol is the Atom Publishing Protocol. In one embodiment, the status and event information is communicated as an extensible markup language (XML) document.
In various embodiments, the consumer logic periodically sends a request message via the network to poll the producer logic, and the producer logic responds via the network with a status and event message incorporating the status and event information. The status and event information may include temporal information, where the consumer logic inserts a temporal parameter into the request message to identify and retrieve updated information.
The producer logic may include a message processor and trickle logic. The message processor aggregates the status and event information into a status and event document. The tickle logic detects new information added to the status and event document and sends via the network a tickle information message to the consumer logic in response. The consumer logic may respond to the tickle information message by sending a request message via the network to poll the producer logic for the new information. The consumer logic may further include trigger logic which sends a tickle message via the network to the producer logic to activate the tickle logic. The status and event information may include different event types, where the trigger logic may incorporate an event type value into the tickle message to identify at least one of the event types for the tickle logic to monitor.
The producer logic may include a message processor and return feed list logic. The message processor aggregates the status and event information. The return feed list logic receives a request message from the consumer logic and instructs the message processor to respond with a status and event message via the network incorporating the status and event information. The return feed list logic may include session tracker logic which tracks communication sessions and corresponding consumer devices sending request messages. The return feed list logic instructs the message processor to send complete status and event information via the network to a consumer device during a new session and instructs the message processor to send via the network updated status and event information to a consumer device during an existing session.
The consumer logic may include a consumer message processor which aggregates the status and event information and request new event feed list logic which sends via the network a request new message to the producer logic for requesting new information. The producer logic may include a producer message processor, return feed list logic, and new event detection logic. The producer message processor aggregates the status and event information. The return feed list logic instructs the message processor to send status and event messages via the network incorporating the status and event information to the consumer logic. The new event detection logic receives the request new message, monitors the producer message processor for the new information, and instructs the return feed list logic to cause a status and event message to be sent via the network from the producer message processor incorporating the new information.
Consumer logic is disclosed which is configured for coupling to a communication network of a physical access control system, where the system includes a controlled physical barrier. In one embodiment, the consumer logic includes retrieve logic and processor logic. The retrieve logic periodically sends a request message via the communication network to request status and event information associated with the controlled physical barrier. The processor logic receives a status and event message sent via the communication network incorporating the status and event information. The retrieve logic and the processor logic communicate via the communication network according to a commonly accepted message syndication protocol, such as the RSS protocol or the Atom Publishing Protocol or the like. The consumer logic may include polling logic configurable to establish a polling time period for sending the request message.
The status and event information may include temporal information, where the retrieve logic inserts a temporal parameter into the request message to request updated status and event information. The processor logic may receive a temporal value from the status and event message used to determine the temporal parameter.
The consumer logic may include trigger logic which sends a tickle request message via the communication network for requesting updated status and event information, and which informs the processor logic that the updated status and event information is available upon receipt of a tickle information message received via the communication network. The status and event information may include temporal information, where the retrieve logic inserts a temporal parameter into the request message to request the updated status and event information.
The consumer logic may include request logic which sends a request new message via the communication network to request updated status and event information. The consumer logic may include producer logic which sends the status and event information via the communication network in response to a request message received via the communication network.
Producer logic is disclosed which is configured for coupling to a communication network of a physical access control system which includes a controlled physical barrier. In one embodiment, the producer logic includes a document, return logic, and processor logic. The document stores status and event information associated with the controlled physical barrier. The return logic receives a request message via the communication network to request the status and event information. The processor logic sends a status and event message via the communication network incorporating the status and event information in response to the request message. The return logic and the processor logic communicate via the communication network according to a commonly accepted message syndication protocol, such as RSS or Atom Publishing Protocol or the like.
The status and event information may include temporal information, where the return logic detects a temporal parameter within the request message and instructs the processor logic to filter the status and event information based on the temporal parameter. The producer logic may include tickle logic which receives a tickle request message via the communication network for requesting updated status and event information, which monitors the processor logic, and which sends a tickle information message via the communication network when the updated status and event information is available. The tickle logic may insert differential information into the tickle information message providing information about the updated status and event information.
The producer logic may include new event detection logic which receives a request new message via the communication network, which monitors the processor logic for updated status and event information, and which instructs the processor logic to send the status and event message incorporating the updated status and event information. The producer logic may include monitor and detection logic which senses the status and event information of the controlled physical barrier. The producer logic may include consumer logic which periodically requests the status and event information via the communication network
Although the present invention has been described in considerable detail with reference to certain preferred versions thereof, other versions and variations are possible and contemplated. Those skilled in the art should appreciate that they can readily use the disclosed conception and specific embodiments as a basis for designing or modifying other structures for providing out the same purposes of the present invention without departing from the spirit and scope of the invention as defined by the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5337043 | Gokcebay | Aug 1994 | A |
5628004 | Gormley et al. | May 1997 | A |
5774059 | Henry et al. | Jun 1998 | A |
5878434 | Draper et al. | Mar 1999 | A |
5903225 | Schmitt et al. | May 1999 | A |
5924096 | Draper et al. | Jul 1999 | A |
5936544 | Gonzales et al. | Aug 1999 | A |
6064316 | Glick et al. | May 2000 | A |
6496595 | Puchek et al. | Dec 2002 | B1 |
6547130 | Shen | Apr 2003 | B1 |
6570498 | Frost et al. | May 2003 | B1 |
6617970 | Makiyama et al. | Sep 2003 | B2 |
6624739 | Stobbe | Sep 2003 | B1 |
6720874 | Fufido et al. | Apr 2004 | B2 |
6724296 | Hikita et al. | Apr 2004 | B1 |
6747564 | Mimura et al. | Jun 2004 | B1 |
6966491 | Gyger | Nov 2005 | B2 |
6990407 | Mbekeani et al. | Jan 2006 | B1 |
7080402 | Bates et al. | Jul 2006 | B2 |
7096354 | Wheeler et al. | Aug 2006 | B2 |
7283050 | Minowa | Oct 2007 | B2 |
7372839 | Relan et al. | May 2008 | B2 |
7375615 | Kitagawa et al. | May 2008 | B2 |
7407110 | Davis et al. | Aug 2008 | B2 |
7468658 | Bouressa | Dec 2008 | B2 |
7598842 | Landram et al. | Oct 2009 | B2 |
7599983 | Harper et al. | Oct 2009 | B2 |
7698566 | Stone | Apr 2010 | B1 |
7817047 | Brignone et al. | Oct 2010 | B1 |
7818783 | Davis | Oct 2010 | B2 |
20020016740 | Ogasawara | Feb 2002 | A1 |
20020059523 | Bacchiaz et al. | May 2002 | A1 |
20020091745 | Ramamurthy et al. | Jul 2002 | A1 |
20020094777 | Cannon et al. | Jul 2002 | A1 |
20020099945 | McLintock et al. | Jul 2002 | A1 |
20020133725 | Roy et al. | Sep 2002 | A1 |
20020137524 | Bade et al. | Sep 2002 | A1 |
20030004737 | Conquest et al. | Jan 2003 | A1 |
20030023882 | Udom | Jan 2003 | A1 |
20030046260 | Satyanarayanan et al. | Mar 2003 | A1 |
20030056096 | Albert et al. | Mar 2003 | A1 |
20030085914 | Takaoka et al. | May 2003 | A1 |
20030093690 | Kemper | May 2003 | A1 |
20030179073 | Ghazarian | Sep 2003 | A1 |
20030182194 | Choey et al. | Sep 2003 | A1 |
20030217122 | Roese et al. | Nov 2003 | A1 |
20030218533 | Flick | Nov 2003 | A1 |
20030233278 | Marshall | Dec 2003 | A1 |
20040017929 | Bramblet et al. | Jan 2004 | A1 |
20040036574 | Bostrom | Feb 2004 | A1 |
20040049675 | Micali et al. | Mar 2004 | A1 |
20040067773 | Rachabathuni et al. | Apr 2004 | A1 |
20040140899 | Bouressa | Jul 2004 | A1 |
20040153671 | Schuyler et al. | Aug 2004 | A1 |
20040203633 | Knauerhase et al. | Oct 2004 | A1 |
20040261478 | Conforti | Dec 2004 | A1 |
20050038791 | Ven | Feb 2005 | A1 |
20050061883 | Miller et al. | Mar 2005 | A1 |
20050171787 | Zagami | Aug 2005 | A1 |
20050241003 | Sweeney et al. | Oct 2005 | A1 |
20050255840 | Markham | Nov 2005 | A1 |
20050259606 | Shutter et al. | Nov 2005 | A1 |
20050274793 | Cantini et al. | Dec 2005 | A1 |
20050284931 | Adams et al. | Dec 2005 | A1 |
20060013234 | Thomas et al. | Jan 2006 | A1 |
20060022794 | Determan et al. | Feb 2006 | A1 |
20060048233 | Buttross et al. | Mar 2006 | A1 |
20060055510 | Little et al. | Mar 2006 | A1 |
20060059099 | Ronning et al. | Mar 2006 | A1 |
20060059557 | Markham et al. | Mar 2006 | A1 |
20060059963 | Conforti | Mar 2006 | A1 |
20060075492 | Golan et al. | Apr 2006 | A1 |
20060076420 | Prevost et al. | Apr 2006 | A1 |
20060106944 | Shahine et al. | May 2006 | A1 |
20060112423 | Villadiego et al. | May 2006 | A1 |
20060119469 | Hirai et al. | Jun 2006 | A1 |
20060136742 | Giobbi | Jun 2006 | A1 |
20060230019 | Hill et al. | Oct 2006 | A1 |
20060255129 | Griffiths | Nov 2006 | A1 |
20070046424 | Davis et al. | Mar 2007 | A1 |
20070046468 | Davis | Mar 2007 | A1 |
20070055731 | Thibeault | Mar 2007 | A1 |
20070088807 | Moore | Apr 2007 | A1 |
20070106754 | Moore | May 2007 | A1 |
20070186106 | Ting et al. | Aug 2007 | A1 |
20070250920 | Lindsay | Oct 2007 | A1 |
20080091944 | von Mueller et al. | Apr 2008 | A1 |
20080109098 | Moshier et al. | May 2008 | A1 |
20080129467 | Gennard | Jun 2008 | A1 |
20080189214 | Mueller et al. | Aug 2008 | A1 |
20080209506 | Ghai et al. | Aug 2008 | A1 |
20080263640 | Brown | Oct 2008 | A1 |
20080277486 | Seem et al. | Nov 2008 | A1 |
20090050697 | Sparks et al. | Feb 2009 | A1 |
20090064744 | Wang | Mar 2009 | A1 |
20100023865 | Fulker et al. | Jan 2010 | A1 |
20100188509 | Huh | Jul 2010 | A1 |
20110006879 | Lambrou et al. | Jan 2011 | A1 |
Number | Date | Country |
---|---|---|
WO2005083210 | Sep 2005 | WO |