None.
This disclosure relates generally to apparatus, systems, and methods for improving security on a public or private network, such as detecting and/or preventing the unauthorized creation, insertion, deletion, update, or writing of files. This disclosure relates more particularly to apparatus, systems, and methods that rely on non-flashable circuitry, in contrast to software, for screening data packets or frames coming from a public or private network, and thus offer added protection against hackers or other unauthorized users.
Security on networks is usually provided by software. However, software can be altered by hackers or other unauthorized users. As such, software, regardless of its level of sophistication, may have an inherent weakness compared to non-flashable circuitry.
An example of a secure data storage device on a private or public network is described in U.S. Pat. No. 6,631,453 issued on Oct. 7, 2003. This patent reference discloses a data storage/transmission hardware device (or multiple devices physically linked together) with two (or more) connectors. One of the connectors allows for the reading and writing of information (referred to as the “active channel”) while the other connector(s) (referred to as “passive channels”) allow solely for the reading of information. The actual limitation of “write” access of the passive connectors is brought about by a combination of hardware and firmware.
Security threats are often presented by cyber-attacks where a hacker or other unauthorized user creates, inserts, deletes, updates, renames, or writes computer files remotely by sending data packets or frames via a private or public network. The data packets or frames sent by the hacker or other unauthorized user are usually detected by firewall software and discarded. However, firewalls are an incomplete stopgap solution as they are still vulnerable due to their nature as software and unreliable to protect against cyber-attacks as they require constant updating from trained personnel. Even with that updating, they still may not be able to keep up with the flow of new malware. As such, firewall software may not be sufficient.
In view of the foregoing, there is still a need in the art for apparatus, systems, and methods for improving security on a public or private network, such as detecting and/or preventing the unauthorized creation, insertion, deletion, renaming, writing or update of files. Preferably, these apparatus, systems, and methods rely on non-flashable circuitry, in contrast to software, for improving security.
The disclosure describes an apparatus for providing protection to a device connected to a public or private network. The apparatus comprises an enclosure having at least first, second, and third connections. The apparatus also comprises non-flashable circuitry located in the enclosure, wherein the non-flashable circuitry is connectable to the public or private network via the first and second connections, and the non-flashable circuitry is connectable to the device via the third connection. As used herein, non-flashable circuitry is such that firmware implemented on non-flashable circuitry cannot be altered or updated from a remote location. The non-flashable circuitry is configured to receive first data packets or frames from the public or private network via the first connection, determine whether the first data packets or frames contain an instruction of a known file-sharing protocol other than a reading instruction, discard the first data packets or frames when the first data packets or frames contain the instruction other than the reading instruction, and transmit the first data packets or frames to the device via the third connection when the first data packets or frames are not discarded. The non-flashable circuitry is further configured to receive second data packets or frames via the second connection, determine whether the second data packets or frames are digitally signed and originate from a source identified by a token stored in the non-flashable circuitry, discard the second data packets or frames when the second data packets or frames are not digitally signed or do not originate from the source, and transmit the second data packets or frames to the device via the third connection when the data packets or frames originate from the source.
The disclosure further describes an apparatus for protecting a database from cyber attacks. The apparatus comprises an enclosure having at least a connection, a storage medium that is located in the enclosure, the storage medium hosting the database, and non-flashable circuitry located in the enclosure. The non-flashable circuitry is connectable to a public or private network via the connection and wherein the non-flashable circuitry is configured to receive data packets or frames from the public or private network via the connection, determine whether the data packets or frames contain a reading instruction of a known file-sharing protocol and the data packets or frames are addressed to the storage medium, execute the reading instruction when the data packets or frames contain the reading instruction and the data packets or frames are addressed to the storage medium, determine whether the data packets or frames are digitally signed by a source identified by a token stored in the non-flashable circuitry and the data packets or frames are addressed to the storage medium, execute the instructions contained in the data packets or frames when the data packets or frames are digitally signed and the data packets or frames are addressed to the storage medium, determine whether the data packets or frames contain an instruction of the known file-sharing protocol other than the reading instruction, the data packets or frames are not digitally signed by the source, and the data packets or frames are addressed to the storage medium, and discard the data packets or frames when the data packets or frames contain the instruction other than the reading instruction, the data packets or frames are not digitally signed by the source, and the data packets or frames are addressed to the storage medium.
The disclosure further describes a method of providing protection to a device or a database connected to a public or private network against cyber attacks. The method comprises the step of providing an apparatus such as described in this section. The apparatus is used to perform the steps of receiving data packets or frames from the public or private network, either transmitting the data packets or frames when the data packets or frames contain a reading instruction or executing reading instructions contained in the data packets or frames, either transmitting the data packets or frames when the data packets or frames are digitally signed by the source or executing instructions contained in the data packets or frames when the data packets or frames are digitally signed by the source, and discarding the data packets or frames when the data packets or frames are not digitally signed by the source and contain an instruction other than a reading instruction.
For a more detailed description of the embodiments of the disclosure, reference will now be made to the accompanying drawings, wherein:
This disclosure describes hardware units that rely on non-flashable circuitry (e.g., Application-Specific Integrated Circuits (ASICs), Field-Programmable Gate Arrays (FPGAs), or permanent Read-Only Memory (ROM) chips, or other burnable circuitry) for improving security on a public or private network. These hardware units can be added to a network without substantial modifications to the other devices already connected to the network. Thus, in contrast with current ways of providing protection, which are solely software based, the hardware units are hardware that may be added to the public or private network. These hardware units detect and block or drop data packets or frames that contain an instruction of a known file-sharing protocol other than a reading instruction which are not digitally signed by a recognized source. Examples of known file-sharing protocols include, but are not limited to, the Server Message Block (SMB) protocol, the Network File System (NFS) protocol, the Apple Filing Protocol (AFP), or other protocols that may be developed in the future and are known at the time the apparatus are manufactured and/or in use. Examples of instructions other than a reading instruction include, but are not limited to, instructions to create a file, insert data in a file, delete a file, rename a file, update or write on a file. Thus, a cyber attack or unauthorized access may be detected instantaneously by what it attempts to do, typically the creation, insertion, deletion, update, renaming, or writing of files.
For example, computer systems and networks 614 may include a Remote Telemetry Unit (“RTU”) of a Supervisory Control and Data Acquisition (“SCADA”) system, a data server, or a file server. In the example shown, the computer systems and networks 614 are connected to the Internet (an example of a public network) to share data. In particular, a Programmable Logic Controller (“PLC”) located in the demilitarized zone DMZ may be able to retrieve data from the computer systems and networks 614. In these examples, malicious agents may utilize the Internet and/or the Local Area Network (“LAN”) to compromise code or data hosted on the computer systems and networks 614. In order to ensure the protection of this code or data, the hardware unit 600 is connected between the Internet and/or the LAN and the computer systems and networks 614. In particular, the hardware unit 600 has two interfaces 604 and 605, each having its own IP address, that are both connected to the Internet and/or the LAN, and a third interface 606, that is connected to the computer systems and networks 614.
In other examples, a customer database portion 727 may include documents or data files, encryption keys, or Bitcoin keys. The customer database portion 727 is brought online on a public or private network to share data. In these examples, malicious agents may utilize the Internet and/or the LAN to compromise code or data stored on the customer database portion 727. In order to ensure the protection of this code or data, the customer database portion 727 is stored on a disk of the hardware unit 600, which is, in turn, connected to the Internet and/or the LAN. Again, the hardware unit 600 has two interfaces 604 and 605, each having its own IP address, that are both connected to the Internet and/or the LAN.
The IP address of the interface 604 is preferably public. The IP address of the interface 605 is preferably kept private, for example, with the utilization of a Virtual Private Network (“VPN”) server. The hardware unit 600 contains firmware 603 that detects an attempt to create, insert data in, delete, update, rename, or write a file via an external port interface 604 configured as read-only (r/o). The hardware unit 600 also contains firmware 626 which enables the requirement of a certificate connection code for read-write via an external port interface 605 configured as read-write (r/w). The firmware 603 and 626 are implemented with non-flashable circuitry, whereby the firmware 603 and 626 cannot be updated from a remote location.
The hardware unit 600 includes an enclosure 601. The hardware unit 600 contains a motherboard 602 which controls the operation of the hardware unit 600. The motherboard 602 contains the embedded firmware 603 which uses logic for the hardware unit 600 and controls the behavior of the hardware unit 600 for reading via an external port configured as read-only. The firmware 603 is designated as non-flashable memory where the firmware 603 cannot be updated from a remote location. The motherboard 602 also contains the embedded firmware 626 which enables the requirement of a certificate connection code for reading or writing via an external port configured as read-write. The hardware unit 600 contains a storage disk 615 that is used to capture database events 616 and house internal utilities 617.
The motherboard 602 contains four interfaces or ports: Port1604, Port2605, Port3606 and Port4607. The hardware unit 600 contains four external wired or wireless connections: LAN1608, LAN2609, LOCAL 610, and WAN 611. Port1604 is connected to LAN1608. Port2605 is connected to LAN2609. Port3 is connected to LOCAL which is externally connected to the protected systems and networks 614 which are being protected from cyber attacks by the hardware unit 600. Port4607 is connected to WAN 611. LAN1608 uses IP Address 1612. LAN2609 uses IP Address 2613. The hardware unit 600 contains forward facing to internet code 625 which allows connections on LAN1608 and LAN2609 directly to the internet/cloud if needed. Upon installation of the hardware unit 600, Port1604, and Port2605 can be configured (e.g., their processor chips can be burned) as read-only or read-write.
For the diagram of
As illustrated in
In the firmware 603, the embedded logic 518 first checks the data packet 519 to determine if the data packet 519 is trying to write, or more generally, whether the data packet 519 contains an instruction of a known file-sharing protocol other than a reading instruction, which may be an instruction to create, insert data, delete, rename, update or write. If not, then the embedded logic 518 allows the passage of the data packet 519, for example, to the computer systems and networks 614, or allows the execution of a reading instruction on the customer database portion 727, and replies a successful return code. If the data packet 519 is trying to write or, more generally, contains an instruction other than a reading instruction, then the embedded logic 518 makes an additional check to see if the entry port is configured as read-write. If yes, then the embedded logic 518 allows passage of the data packet 519, for example, to the computer systems and networks 614, or allows the execution of a writing instruction or generally the execution of an instruction other than a reading instruction on the customer database portion 727, and then replies a successful return code 520. If the entry port is configured as read-only, then the embedded logic records a database event 521 in the storage disk 615 in the database events 616 area, replies an error return code 522, and drops the data packet 519.
The database events 616 portion of the storage disk 615 contains the following information for each event, regardless of being recorded by the embedded logic 618 or 518: a unit identifier of the hardware unit 600, a sequentially generated event identifier, a client identifier of the customer, the current date, the current time, an error return code 622, an event type, a result which describes the action taken by the hardware unit 600, the directory of the file which sent the data packet 619, the source address of the URL which sent the data packet 619, the filename for the source which sent the data packet 619, the destination address of the data packet 619, the reporting URL where the database event 616 is to be reported, and other pertinent information for reporting which do not have specifically designated fields.
The hardware unit 600 has a reporting utility 623 which resides in the internal utilities 617 portion of the storage disk 615. The reporting utility 623 reads the system clock 624 periodically and then reads the database events 616 and electronically transmits the database events 616 that have not been previously reported to an external location. The hardware unit 600 electronically transmits reported database events through, for example, Port4607 using WAN 611.
Back in reference to the example of
In addition to the foregoing, the disclosure also contemplates at least the following embodiments. It should be noted that any element of any embodiments 1-23 may further include details related to this element that are disclosed in a paragraph or Figure describing the preferred embodiments without including details of other elements that are disclosed in the same or other paragraph or Figure.
Embodiment 1 is an apparatus for providing protection to a device connected to a public or private network. The apparatus comprises an enclosure and non-flashable circuitry located in the enclosure.
The enclosure has at least first, second, and third connections, which are either wired or wireless. The non-flashable circuitry is connectable to the public or private network via the first connection (e.g., a read-only connection) and the second connection (e.g., a read-write connection). The non-flashable circuitry is also connectable to the device via the third connection.
In order to implement a “read-only connection,” the non-flashable circuitry is configured on the one hand to:
In order to implement a “read-write connection,” the non-flashable circuitry is configured on the other hand to:
Determining whether the first data packets or frames contain the instruction other than the reading instruction may involve testing whether the data packets or frames contain any of an instruction to either create a file, insert data in a file, delete a file, update a file, rename a file, or write on a file. In some cases, all these tests are performed. However, more or fewer than all these tests could be performed.
Determining whether the second data packets or frames are digitally signed and originate from a source identified by a token stored in the non-flashable circuitry may involve any known or future-developed algorithm capable of providing a digital signature matching the token.
Embodiment 2 is an apparatus as described in embodiment 1, further comprising a storage medium that is located in the enclosure. The storage medium may be any storage medium, such as a disk, flash memory, or solid-state drive. The non-flashable circuitry is further configured to record a first database event on the storage medium when the first data packets or frames contain the instruction other than the reading instruction, wherein the first database event includes at least the source address of the universal resource locator (“URL”) which sent the first data packet or frame containing the instruction other than the reading instruction.
Embodiment 3 is an apparatus as described in embodiment 1, wherein the storage medium specifically includes a disk.
Embodiment 4 is an apparatus as described in embodiments 2 or 3, wherein the non-flashable circuitry is further configured to periodically (e.g., based on an internal or external clock signal) inspect the storage medium for one or more newly recorded database events. The non-flashable circuitry is further configured to transmit the one or more newly recorded database events. In order to do so, the non-flashable circuitry may, for example, use the first or second connection to send data packets or frames to create or update a file on the public or private network, or use the third connection to send data packets or frames to create or update a file on the machine. Alternatively, the non-flashable circuitry may use another connection to create or update a file on a node connected to the other connection.
Embodiment 5 is an apparatus as described in any of embodiments 1 to 4 wherein the non-flashable circuitry is further configured so that one or both of the first connection and the second connection interface(s) directly with the Internet, such as with the use of forward facing to internet code.
Embodiment 6 is an apparatus as described in any of embodiments 1 to 5 wherein the third connection is connected to a database, documents or data files, encryption keys, or bitcoin keys.
Embodiment 7 is an apparatus as described in any of embodiments 1 to 6, wherein the non-flashable circuitry is further configured to decrypt the second data packets or frames via the second connection using a public key. Determining whether the second data packets or frames are digitally signed and originate from a source identified by a token stored in the non-flashable circuitry preferably involves decrypting the second data packets or frames via the second connection using the public key.
Embodiment 8 is an apparatus as described in any of embodiments 1 to 7 wherein at least one of the first, second, and third connections are wired connections.
Embodiment 9 is an apparatus as described in any of embodiments 1 to 8, wherein the non-flashable circuitry is further configured to receive third data packets or frames from the device via the third connection, and transmit the third data packets or frames to the public or private network via the first or second connection, or via a fourth connection provided on the enclosure and connected to the non-flashable circuitry.
Embodiment 10 is an apparatus as described in any of embodiments 1 to 9, wherein the first and second database events each specifically includes one or more of the following:
Embodiment 11 is a system comprising an apparatus as described in any of embodiments 1 to 10 and a Virtual Private Network (“VPN”) server, wherein the second connection is connected to the VPN server via the public or private network.
Embodiment 12 is a system comprising an apparatus as described in any of embodiments 1 to 10 and a Programmable Logic Controller (“PLC”) or a Remote Telemetry Unit (“RTU”) of a Supervisory Control and Data Acquisition (“SCADA”) system or a data server, or a file server. The third connection is connected to the Programmable Logic Controller, the Remote Telemetry Unit, the data server, or the file server.
Embodiment 13 is an apparatus for protecting a database from cyber attacks. The apparatus comprises an enclosure, a storage medium that is located in the enclosure, the storage medium including any storage medium, such as a disk, flash memory, or solid-state drive, the storage medium hosting the database, and non-flashable circuitry located in the enclosure.
The enclosure has at least a connection, and preferably at least first and second connections, which are either wired or wireless. The non-flashable circuitry is connectable to a public or private network via the connection, and preferably via the first connection (e.g., a read-only connection) and the second connection (e.g., a read-write connection).
The non-flashable circuitry is configured to:
Determining whether the data packets or frames contain the instruction other than the reading instruction may involve testing whether the data packets or frames contain any of an instruction to either create a file, insert data in a file, delete a file, update a file, rename a file, or write on a file. In some cases, all these tests are performed. However, more or fewer than all these tests could be performed.
Determining whether the data packets or frames are digitally signed and originate from a source identified by a token stored in the non-flashable circuitry may involve any known or future-developed algorithm capable of providing a digital signature matching the token.
Determining whether the data packets or frames are addressed to the storage medium may involve testing whether the data packets or frames are destined to a specific IP (static) address assigned to the storage medium.
Embodiment 14 is an apparatus as described in embodiment 13, wherein the non-flashable circuitry is further configured to record a database event on the storage medium when the data packets or frames contain the instruction other than the reading instruction, the data packets or frames are not digitally signed by the source, and the data packets or frames are addressed to the storage medium, wherein the database event includes at least the source address of the URL which sent the data packet or frames containing the instruction other than the reading instruction, not being digitally signed, and being addressed to the storage medium.
Embodiment 15 is an apparatus as described in embodiments 13 or 14, wherein the non-flashable circuitry is further configured to decrypt the data packets or frames (preferably the ones received via the second connection) when the data packets or frames contain the reading instruction and the data packets or frames are addressed to the storage medium. The decryption may involve a public key, which may also be used as the token identifying the source.
Embodiment 16 is an apparatus as described in any of embodiments 13 to 15, wherein another connection is provided on the enclosure and is connected to the non-flashable circuitry. The non-flashable circuitry is further configured to transmit the data packets or frames via the other connection when the data packet or frames are not addressed to the storage medium.
Embodiment 17 is an apparatus as described in any of embodiments 13 to 16, wherein the connection (and optionally at least one of the first and second connections) is(are) specifically wired.
Embodiment 18 is an apparatus as described in any of embodiments 13 to 17 wherein the non-flashable circuitry is further configured so that one or both of the first connection and the second connection interface(s) directly with the Internet, such as with the use of forward facing to internet code.
Embodiment 19 is an apparatus as described in any of embodiments 14 to 18, wherein the non-flashable circuitry is further configured to periodically (e.g., based on an internal or external clock signal) inspect the storage medium for one or more newly recorded database events. The non-flashable circuitry is further configured to transmit the one or more newly recorded database events. In order to do so, the non-flashable circuitry may, for example, use the connection (or optionally the first or second connection) to send data packets or frames to create or update a file on the public or private network, or alternatively, use another connection to create or update a file on a node connected to the other connection.
Embodiment 20 is an apparatus as described in any of embodiments 14 to 19, wherein the database events each specifically includes one or more of the following:
Embodiment 21 is an apparatus as described in any of embodiments 13 to 20, wherein the database hosted on the storage medium is at least partially encrypted using a public key, which may be used as the token identifying the source. As such, even if the storage medium is physically accessed by an unauthorized user, data in the database hosted on the storage medium may remain indecipherable by the unauthorized user.
Embodiment 22 is a method of providing protection to a device or a database connected to a public or private network. The method comprises the step of providing an apparatus as described in any of embodiments 1 to 21. The method comprises using the apparatus to perform the following steps:
Embodiment 23 is a method as described in embodiment 22, further comprising recording a database event if the data packets or frames contain the instruction other than the reading instruction and are not digitally signed by the source.
Specific embodiments of the invention are shown by way of examples in the drawings and description. It should be understood, however, that the drawings and detailed description thereto are not intended to limit the claims to the particular form disclosed, but on the contrary, the intention is to cover all modifications, equivalents, and alternatives falling within the scope of the claims.
Number | Name | Date | Kind |
---|---|---|---|
6438130 | Kagan | Aug 2002 | B1 |
6453353 | Win | Sep 2002 | B1 |
6631453 | Friday | Oct 2003 | B1 |
6763015 | Phillips | Jul 2004 | B1 |
7426599 | Yancey | Sep 2008 | B2 |
7808995 | Kuo | Oct 2010 | B2 |
9848005 | Ardeli | Dec 2017 | B2 |
20050169270 | Mutou | Aug 2005 | A1 |
20060041889 | Radulescu | Feb 2006 | A1 |
20060253903 | Krumel | Nov 2006 | A1 |
20080132288 | Misawa | Jun 2008 | A1 |
20080137854 | Friday | Jun 2008 | A1 |
20080279166 | Carty | Nov 2008 | A1 |
20100061263 | Breeding | Mar 2010 | A1 |
20100169964 | Liu | Jul 2010 | A1 |
20100174608 | Harkness | Jul 2010 | A1 |
20120182891 | Lee | Jul 2012 | A1 |
20120240185 | Kapoor | Sep 2012 | A1 |
20130275228 | Milazzo | Oct 2013 | A1 |
20140269697 | Salys | Sep 2014 | A1 |
20140328249 | Vermani | Nov 2014 | A1 |
20190313160 | Stokking | Oct 2019 | A1 |
20200004962 | Araujo et al. | Jan 2020 | A1 |
20210067534 | Mi | Mar 2021 | A1 |
20210152860 | Patro | May 2021 | A1 |
20210226899 | Kanurakaran | Jul 2021 | A1 |
20210377029 | Sloane | Dec 2021 | A1 |
20220272039 | Cardona | Aug 2022 | A1 |
20230117644 | Kamisetty | Apr 2023 | A1 |
20230205715 | Harris | Jun 2023 | A1 |
20240022638 | Wang | Jan 2024 | A1 |
Number | Date | Country |
---|---|---|
103838670 | Jun 2014 | CN |
2441909 | Mar 2008 | GB |
2001075595 | Oct 2001 | WO |
2003067810 | Aug 2003 | WO |
2004102326 | Nov 2004 | WO |
2016117302 | Jul 2016 | WO |
2016015981 | Oct 2016 | WO |