US20180253452A1 - System and method for enforcing the structure and content of databases synchronized over a distributed ledger - Google Patents

System and method for enforcing the structure and content of databases synchronized over a distributed ledger Download PDF

Info

Publication number
US20180253452A1
US20180253452A1 US15/972,479 US201815972479A US2018253452A1 US 20180253452 A1 US20180253452 A1 US 20180253452A1 US 201815972479 A US201815972479 A US 201815972479A US 2018253452 A1 US2018253452 A1 US 2018253452A1
Authority
US
United States
Prior art keywords
data
network connected
distributed ledger
network
connected devices
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Abandoned
Application number
US15/972,479
Inventor
Jonathan Sean Callan
Keir Finlow-Bates
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Individual
Original Assignee
Individual
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Individual filed Critical Individual
Priority to US15/972,479 priority Critical patent/US20180253452A1/en
Publication of US20180253452A1 publication Critical patent/US20180253452A1/en
Abandoned legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/21Design, administration or maintenance of databases
    • G06F16/211Schema design and management
    • G06F17/30292
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F16/00Information retrieval; Database structures therefor; File system structures therefor
    • G06F16/20Information retrieval; Database structures therefor; File system structures therefor of structured data, e.g. relational data
    • G06F16/27Replication, distribution or synchronisation of data between databases or within a distributed database system; Distributed database system architectures therefor
    • G06F17/30283
    • G06F17/30575
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L63/00Network architectures or network communication protocols for network security
    • H04L63/12Applying verification of the received information
    • H04L63/123Applying verification of the received information received data contents, e.g. message integrity
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/10Protocols in which an application is distributed across nodes in the network
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/14Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using a plurality of keys or algorithms
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/30Public key, i.e. encryption algorithm being computationally infeasible to invert or user's encryption keys not requiring secrecy
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3236Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions
    • H04L9/3239Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials using cryptographic hash functions involving non-keyed hash functions, e.g. modification detection codes [MDCs], MD5, SHA or RIPEMD
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3247Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving digital signatures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L67/00Network arrangements or protocols for supporting network services or applications
    • H04L67/01Protocols
    • H04L67/42
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/50Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols using hash chains, e.g. blockchains or hash trees

Definitions

  • This disclosure relates to computer systems and methods concerned with an addition of data to a plurality of databases synchronized through a distributed ledger or blockchain, henceforth referred to as the distributed ledger, and more specifically to an enforcement of a consensus amongst a plurality of participants as to how a schema for the plurality of databases will be maintained and/or extended via a medium of a network of the plurality of participants communicating through the distributed ledger.
  • Distributed ledgers provided in, for example, a peer-to-peer network, such as the distributed ledger used in the Bitcoin cryptocurrency system, rely on a consensus system agreed upon by participants on the peer-to-peer network in order to add blocks of data to the distributed ledger.
  • participants examine proposed data blocks in order to verify that they conform to a network agreed standard, rather than relying on a third-party trusted central authority to authorize the addition of data.
  • the file which constitutes a chain of data comprising the distributed ledger, may have a predetermined set of rules for ensuring blocks are added to the file representing the distributed ledger in a manner accepted by participants on the peer-to-peer network, nevertheless some of a data of interest encapsulated within a block may take many different unspecified or unpredictable formats.
  • consensus systems used in distributed ledgers specify a format that an encapsulating data must take, that is: how a block links to a previous block within the chain, what format digital signatures within the block should comply with, and how hashes of the data of interest should be ordered and structured.
  • the format of the data of interest encapsulated within the block are generally either unrestricted, or restricted at a launch of the distributed ledger and subsequently unalterable.
  • a solution for reaching a consensus among network connected devices on a peer-to-peer network maintaining and extending a distributed ledger, as to what data to add to the distributed ledger over time, and in particular what format a data representing a database schema and table structure of a plurality of databases, constructed and synchronized from contents of the distributed ledger, should take.
  • Distributed ledger data validators comprising, in a preferred embodiment of the present disclosure, a plurality of network connected devices participating in maintaining and extending the distributed ledger, may receive data and messages over the peer-to-peer network, which they may package into data blocks for potential inclusion in the distributed ledger.
  • the plurality of network connected devices each comprising one or more processors, and storage media comprising computer instructions, said plurality of network connected devices being connectible via a peer-to peer network to each other, are arranged such that when computer instructions are executed on the one or more processors of a one or more of the plurality of network connected devices, operations are caused for reaching a consensus for adding a block of data that includes a proposal for an extension to or alteration of the database schema to a distributed ledger.
  • An addition of the block of data to the distributed ledger may constitute an acceptance by the plurality of network connected devices of said proposal.
  • operations may commence by a first of the plurality of network connected devices generating a database schema change request message comprising a proposed extension to or alteration of the database schema that may indicate the intent of said first of the plurality of network connected devices to alter or extend the database schema of the corresponding plurality of databases.
  • the first of the plurality of network connected devices may transmit the database schema change request message, through the use of the peer-to-peer network, to the plurality of network connected devices connected to the peer-to-peer network.
  • a one or more of the plurality of network connected devices may then proceed by inserting the database schema change request message into a block of data conforming with a distributed ledger data format accepted by the plurality of network connected devices maintaining and extending the distributed ledger, and may transmit the block of data, through the use of the peer-to-peer network, to the plurality of network connected devices.
  • the plurality of network connected devices may then append or insert the block of data to the distributed ledger.
  • one or more of the plurality of network connected devices may then proceed by extracting the proposed extension to or alteration of the database schema from the database schema change request message contained in the block of data previously added to the distributed ledger and synchronized across the peer-to-peer network, and applying the proposed extension to or alteration of the database schema to each of the plurality of databases.
  • one or more of the plurality of network connected devices may have its own instance of a database. In other embodiments, multiple network connected devices may share one instance of the database.
  • the plurality of network connected devices may reject the block of data, whereby the block of data is not added to the distributed ledger.
  • the database schema change request message may be digitally signed by the first of the plurality of network connected devices using a private key of a public/private key pair.
  • the public key of the public/private key pair may be publicly associated with the first of the plurality of network connected devices.
  • the database schema change request message may be deemed valid only if it is included in a first block of data of the distributed ledger.
  • the first block of data is commonly known to those skilled in the art as a genesis block, and may be generated by an originator of the distributed ledger.
  • the database schema would remain fixed for a full lifespan of the distributed ledger.
  • the data block may only be added if a specified subset of the plurality of predetermined criteria are met.
  • the specified subset may include one, some, or all of the plurality of predetermined criteria.
  • Determining whether the plurality of predetermined criteria are met may be based on a one or more of: a previous data contained within the distributed ledger, a data contained within the block of data, a data available from a public computer server, a data available from a private computer server, a relationship between a plurality of data fields of the database and a public key of a public/private key pair, a consensus between the plurality of network connected devices, an authorization by a specific network connected device operating on the peer-to-peer network.
  • a criterion from the one of the plurality of predetermined criteria may based on the previous data contained within the distributed ledger.
  • a validity of the criterion may be determined by the plurality of network connected devices using a one or more computations or transformations of the previous data.
  • the computation compare the value of a hash of some or all of the previous data to determine if it matches, exceeds or falls below a target value.
  • the computation may comprise determining a presence of and verifying a validity of a digitally signed authorization within the previous data for a public key of a public/private key pair.
  • This public key may be associated with the first of the network connected devices.
  • the computation may determine an absence of a prior database schema change request message within a given subset of the previous data, and either rejecting or accepting the block of data based thereon.
  • a second of the plurality of network connected devices may commence by extracting a database schema from the distributed ledger.
  • the second of the plurality of network connected devices may construct a data addition or change request message comprising a proposed addition to or modification of data, complying with the database schema extracted from the distributed ledger.
  • the second of the plurality of network connected devices may then transmit the data addition or change request message to the peer-to-peer network.
  • a third of the plurality of network connected devices may extract the proposed addition to or modification of data from the data addition or change request message, and may insert it into a block of data;
  • the third of the plurality of network connected devices may then submit the block of data to the peer-to-peer network for validation and subsequent insertion into the distributed ledger.
  • the plurality of network connected devices may then insert the block of data into the distributed ledger.
  • the plurality of network connected devices may reject the block of data, which is therefore not added to the distributed ledger.
  • the second of the plurality of network connected devices may digitally sign the data addition or change request message using a private key of a public/private key pair.
  • the plurality of predetermined criteria utilized by the plurality of network connected devices may be include of one or more of: compliance with the database schema extracted from the distributed ledger, verification of an identity of a submitter of the data addition or change request, authorization by a specific node operating on the peer-peer network, a result of a computation based on a previous data contained within the distributed ledger, a result of a computation performed on a data contained within the block of data, a result of a computation performed on a data available from a public computer server, a result of a computation performed on a data available from a private computer server, a relationship between a plurality of data fields of the database and a public key of a public/private key pair, a consensus between the plurality of participating nodes operating on the peer-to-peer network.
  • the plurality of network connected devices and corresponding databases may be maintained in a synchronized state, with data added to the databases conforming to the database schema stored within the distributed ledger.
  • the database schema may be altered or extended as per a need of a one or more of a plurality of operators of the plurality of network connected devices, or as required by an extension of or alteration to a format of data to be stored in the plurality of databases.
  • FIG. 1 illustrates a peer-to-peer network with a plurality of network connected devices connected to the peer-to-peer network, and a plurality of associated databases, in accordance with an embodiment of the present disclosure.
  • FIG. 2 illustrates a network connected device and associated database that may be utilized in the generation and submission of a database schema change request message, in accordance with an embodiment of the present disclosure.
  • FIG. 3 is a block diagram illustrating a structure of a possible embodiment of a database schema change request message, in accordance with an embodiment of the present disclosure.
  • FIG. 4 is a signal flow diagram providing a general overview of a method and apparatus controlling the flow of the database schema change request message data from the first of the plurality of network connected devices to the plurality of network connected devices connected via the peer-to-peer network for eventual inclusion in the distributed ledger.
  • FIG. 5 is a diagram presenting a commencement or genesis of a distributed ledger by a network connected device with an associated database, and includes the addition of an initial database schema in a first block of the distributed ledger.
  • FIG. 6 is a diagram illustrating a new network connected device joining the distributed ledger, extracting database schema change requests, and constructing a complete database schema to apply to an associated database.
  • FIG. 7 is a diagram illustrating a new network connected device constructing a complete database scheme from a plurality of data sources.
  • FIG. 8 is a diagram illustrating a network connected device submitting a database change request message to the peer-to-peer network, and a second network connected device on the peer-to-peer network encapsulating the database change request message in a data block and appending it to the distributed ledger.
  • FIG. 9 is a signal flow diagram providing a general overview of a method and apparatus controlling the flow of a data message from the first of the plurality network connected device to the plurality of network connected devices connected via the peer-to-peer network for eventual inclusion in the distributed ledger.
  • a peer-to-peer network 108 is embodied within a packet switched network 101 , through the interconnection of the plurality of network connected devices on the peer-to-peer network 108 .
  • a network connected device 102 may connect to the peer-to-peer network through a direct connection to the packet switched network with a wired connection, or through a wireless connection by association with a wireless access point, a cellular base station, a Bluetooth connection, or other means of connection.
  • Other devices connected to the peer-to-peer network may include network connected devices acting as a communication node, for example network connected device 105 whose role is to maintain a list of other devices connected through the peer-to-peer network, and to forward on received network messages to those devices on the list, possibly independently, or possibly as a response to a request from another network connected device.
  • network connected device 105 whose role is to maintain a list of other devices connected through the peer-to-peer network, and to forward on received network messages to those devices on the list, possibly independently, or possibly as a response to a request from another network connected device.
  • no individual communication node is required to have a complete list of all devices, as the process of peer-to-peer networking only requires that a union of a set of all communication nodes contains a complete list of all devices on the peer-to-peer network, and for every pair of network connected devices there is a network route from one device to the other, possibly via a set of one or more nodes. Therefore, the only requirement to be
  • Further devices connected via the peer-to-peer network may include one or more network connected devices 104 , 106 , 107 , each acting as a database synchronization node or a validator node, whose role may be to act as a communication node, and may also be to receive database schema change request messages and other transaction or data messages from the peer-to-peer network, process them according to the methods and processes to be described further below, and transmitting the results of said processing back to the peer-to-peer network for potential inclusion in the distributed ledger.
  • the devices described above may be implemented through a system comprising a one or a plurality of: a general purpose microprocessor, a digital signal processors (DSP), an application specific instruction set processor (ASIP), a field programmable gate array (FPGA), a dedicated application specific integrated chip (ASIC), or other equivalent integrated or discrete logic circuitry and peripheral circuitry, connected to a tangible storage medium containing instructions which when executed effect methods and techniques described below.
  • DSP digital signal processors
  • ASIP application specific instruction set processor
  • FPGA field programmable gate array
  • ASIC dedicated application specific integrated chip
  • the techniques additionally, or alternatively, may be realized at least in part by a computer-readable communication medium or record carrier, that carries or communicates code in the form of instructions or data structures and that can be accessed, read, and/or executed by a computer.
  • said network connected device may be connected to a database 112 , said database 112 either embodied within the network connected device 102 and communicated to through a network bus within the network connected device 102 , or in an instantiation on a separate device or machine communicated to through an external packet-switched network connection, either on a local area network or wide area network, an external serial connection, through a wireless connection by association with a wireless access point, a cellular base station, a Bluetooth connection, or other means of connection.
  • the network connected device 104 may be connected to a separate database 114 through any of the aforementioned connection systems as described in [ 0055 ].
  • Both network connected device 106 and network connected device 107 may be connected to a same database 116 , each through any of the aforementioned connection systems as described in [0055], and may use any traditional synchronization methods as known to those skilled in the art of database synchronization for ensuring that records stored in the same database 116 may not be added or edited in a conflicting manner by either network connected device 106 or 107 .
  • the network connected device 102 may include a one or more central processing units (CPU) 202 capable of executing instructions stored in a memory 204 , and controlling other peripheral components through drivers 206 stored within the memory 204 .
  • CPU central processing units
  • Further storage 212 may be present, which may contain a cryptographically secure partition or component 214 , where cryptographic keys may be securely stored.
  • the network connected device 102 may connect to the packet switched network through a network module 208 , which may consist of a direct wired connection to the packet switched network through a cable 210 .
  • the network module 208 may contain wireless components comprising one or more wireless modules implemented in firmware or hardware, including a wireless local area network (WLAN) unit such as a Wi-Fi adapter utilizing an 802.11 protocol, a wireless wide area network (WWAN) unit such as Global System for Mobile communications (GSM), Long Term Evolution (LTE), or other cellular wireless data communication system, or a Bluetooth unit.
  • WLAN wireless local area network
  • WWAN wireless wide area network
  • GSM Global System for Mobile communications
  • LTE Long Term Evolution
  • Bluetooth unit a Bluetooth unit.
  • the wireless components may provide network connectivity to a packet switched network and hence to the peer-to-peer network for the network connected device.
  • Components comprising the network connected device 102 may communicate through a bus 216 , which may be implemented as a peripheral component interconnect express (PCIe) bus, a universal serial bus (USB), a universal asynchronous receiver/transmitter (UART) serial bus, a suitable advanced micro-controller bus architecture (AMBA) interface, a serial digital input output (SDIO) bus, or other equivalent interface.
  • PCIe peripheral component interconnect express
  • USB universal serial bus
  • UART universal asynchronous receiver/transmitter
  • AMBA advanced micro-controller bus architecture
  • SDIO serial digital input output
  • the network connected device 102 may, in some embodiments, include an interface 218 to permit communication with a database 112 .
  • the database 112 may be external to the network connected device 102 , and may be communicated with through a connecting cable 220 .
  • the connectivity may be implemented through an ethernet connection, a PCIe bus, a USB, a UART serial bus, a suitable AMBA interface, an SDIO bus, or other equivalent interface.
  • the database may be connected through a wireless connection, for example a WLAN unit such as a Wi-Fi adapter utilizing an 802.11 protocol, a WWAN unit such as GSM, LTE, or other cellular wireless data communication system, or a Bluetooth unit.
  • the database may be internal to the network connected device, and implemented entirely through software stored in storage 212 and/or memory 204 , executed by the CPU 202 , and communicating through the bus 216 .
  • the network connected device 102 may submit a database schema change request message 300 to the peer to peer network 108 , a possible structure of which is described in FIG. 3 .
  • the database schema change request message 300 may include a database schema change request message header.
  • the database schema change request message header 302 may include a marker indicating that the rest of the message contains database schema change data, and other header information such as a length of the message and a version number of the message.
  • the database schema change request message 300 may include a time stamp 304 , which in one embodiment may be used to indicate from what point in time the database schema change request message 300 is to be considered valid. Through these means it may be possible to register a database schema change request on the network with a future validity period, for example by specifying the time stamp as a future time. In another embodiment the time stamp may be a current time, thereby initiating authorizing the database schema change at the point the database schema change request message 300 is sent, or at a fixed predetermined time after the database schema change request message 300 is sent.
  • the database schema change request message 300 may include a database schema change data 306 , which may describe the addition, alteration or deletion of a database schema.
  • the database schema change data may be included in binary format, in JavaScript Object Notation (JSON), in Structured Query Language (SQL), in Extensible Markup Language (XML), or in another data format recognizable by a database as encoding a description of, extension to, alteration of or deletion of one or more of a plurality of structures, data tables, data descriptions and/or data format restrictions applicable to the database.
  • JSON JavaScript Object Notation
  • SQL Structured Query Language
  • XML Extensible Markup Language
  • a database schema change description may include the initialization of a database structure as well as the alteration or addition to an existing database structure.
  • a database contains a description of a structure of the database, known as a database schema, and which represents a logical view of the entire database. It may describe how data is organized and how the relationship between various elements of data is defined.
  • the database schema may formulate all the constraints that are to be applied to the data.
  • the database schema may define entities that constitute the components of the database and the relationship between them, and may contain a detailed description of the database, which may be depicted by a schema diagram.
  • the database schema may define a set of database tables, each containing a set of data fields, some of which may be restricted to only containing data in one of: a text format, a numerical formal, a numerical format restricted to integer values, a numerical format restricted to values less than or greater than a prescribed value, a discrete list of values that a given data value may be chosen from, a Boolean value, a specified length of a data field, a specified checksum that a data must satisfy, or some other data value or data structure.
  • the database schema change data 306 may include a description of how a given structure described by the database schema may be altered. For example, if the database schema restricts a length of a data field to a given number of characters, the database schema change data 306 may alter the restriction to increase or to decrease the length of the data field. Similarly, if the database schema restricts a data field to only contain numerical data, another element of the database schema change data 306 may alter this to allow text to be contained in data stored under the data field. In a further example, the database schema may restrict a data field to contain Elliptic Curve Digital Signature Algorithm (ECDSA) key data, and the database schema change data 306 may alter this to restrict the data field to contain ElGamal key data. In general the database schema change data 306 may contain data pertaining to instructions to alter any restriction on any data field as defined by the current database schema to any other restriction, or even the absence of a restriction, thus changing the underlying database schema.
  • EDSA Elliptic Curve Digital Signature Algorithm
  • the database schema may link a one data table to another data table.
  • a first data table may contain a list of options
  • a second data table may contain data including a field whose value is to be selected from the list of options provided in the first data table.
  • the database schema change data 306 may, in this example, contain an instruction to allow the field in the second data table to also contain a value selected from a differing table containing a differing list of options.
  • the database schema may be non-existent, and the database schema change data 306 may contain a set of instructions that define a complete initial database schema, thus initializing the database system.
  • the database schema change request message 300 may include another data payload 308 , which may include but is not limited to: at least one row of data to be inserted into a database, an information or meta-data relating to the submitter of the database schema change request message 300 , a cryptocurrency transaction, an encoding of an executable computer program or smart contract, another distributed ledger transaction.
  • the database schema change request message 300 may include a public key 310 of a public/private key pair generated by the network connected device 102 submitting the database schema change request message.
  • the public key infrastructure or algorithm may be one of ECDSA, digital signature algorithm (DSA), Rivest, Shamir, & Adleman (RSA), ElGamal, or some other secure asymmetric cryptographic key system.
  • the database schema change request message 300 may also include a hash 312 of a data contained in a preceding message content.
  • the data to be hashed may include one or more of the public key of the public/private key pair 310 , the other data payload 308 , the database schema change data 306 , the time stamp 304 and/or the database schema change request message header 302 .
  • the hash may be one of a secure hash algorithm (SHA), RACE integrity primitives evaluation message digest (RIPEMD), Whirlpool, Scrypt, HAS-160, BLAKE, or other cryptographic hash function applied to the preceding content of the message.
  • the database schema change request message 300 may also include a digital signature 314 , generated using a private key of the public/private key pair associated with the public key 310 and the hash 312 of the data contained in the preceding message content, in order to provide for a veracity or an authentication of database schema change request message 300 .
  • the digital signature algorithm used may be one of ECDSA, DSA, RSA, ElGamal, or some other secure asymmetric key digital signing algorithm.
  • an authorization for example a second digital signature
  • the authorization may be added at a later stage by one other of the plurality of network connected devices.
  • FIG. 4 A high level flow diagram illustrating one possible embodiment of the system and steps taken therein is presented in FIG. 4 . Note that although the embodiment and example provided by FIG. 4 is for a generation and inclusion of a single database schema change request message in the distributed ledger, the same flow diagram and associated methods and processes apply to the generation and inclusion of multiple database schema change request messages.
  • a set of multiple database schema change request messages may differ from a single database schema change request message in that different database schema change requests from different network connected devices may be packaged into one block of data by a network connected device functioning as a validator node 104 for submission to the peer-to-peer network and possible inclusion in the distributed ledger.
  • This allows for more efficient processing of multiple database schema change request messages submitted at approximately the same time by, for example, reducing a data overhead induced by a requirement for header data and digital signature data included in the block of data.
  • an other data not necessarily concerned with database schemas may also be generated and included in a data block and inserted or appended to the distributed ledger following the same methods taught in the following paragraphs describing the function and implementation of the system and method illustrated by FIG. 4 .
  • This other data may include further data for inclusion in fields or rows of the database, digital key announcement or revocation messages, cryptographic currency or native asset transaction messages, or other general data that may be of interest to participants on the peer-to-peer network.
  • the flow of a data comprising the generation of the database schema change request message, inclusion in a successfully generated block of data, and an insertion or appending of said block of data to the distributed ledger is also illustrated through FIG. 4 .
  • the successfully generated block of data may conform to a definition of acceptable data blocks, as defined through a consensus protocol accepted by the plurality of network connected devices participating on the peer-to-peer network, which may comprise a set of rules and structural requirements for such acceptable data blocks.
  • a generated block of data may be considered successful if it is conformant with the definition of acceptable data blocks and is accepted by, for example, a majority, a predetermined number or percentage, or a specific subset, of the plurality of network connected devices.
  • a block of data may comprise a binary block, a character-based string, or a data structure which may itself comprise a collection of keys, values, and other substructures of data.
  • the function of generating blocks of data may be the encapsulation of data to produce candidates for consideration by the plurality of network in order to be included in the distributed ledger. It is through this that the distributed ledger may grow in size over time, storing data of interest in the process.
  • the network connected device 102 may generate a database schema change request 402 .
  • the database schema change request may then be encapsulated in a network message 404 and sent on to the peer-to-peer network 406 .
  • the database schema change request may contain information on how a structure of and rules applying to the database associated with the distributed ledger and contents of said database may be changed in order to accommodate changing requirements for data storage in the database as time progresses.
  • the database schema change request may be generated by including a complete revision of the database schema in the database schema change request, or by including a list of changes, additions and deletions, known to those skilled in the art as “deltas”, to the database schema.
  • the communication node 105 may forward the message to other network connected devices on the peer-to-peer network as per step 408 .
  • Other network connected devices may also make requests to the communication node 105 for network messages that they have not yet received.
  • the database schema change request encapsulated in the network message is forwarded to all interested parties on the peer-to-peer network.
  • the database schema change request encapsulated in the network message may arrive at a network connected device acting as a validator node 104 .
  • the validator node 104 may then extract the database schema change request from the network message as per step 410 .
  • the validator node 104 may then inspect the database schema change request, as per step 412 , to determine if it satisfies a consensus protocol of the distributed ledger.
  • Said consensus protocol may include: compliance with authorization protocols, compliance with database schema design restrictions, compliance with database data restrictions, presence of a valid digital signature, or other distributed ledger and database schema restrictions.
  • the consensus protocol may comprise a set of rules, data structures and other computational requirements that a data submitted to the distributed ledger may be required to comply with in order for the data to be accepted in to the distributed ledger.
  • the rules may include requirements that data may not exceed a given length, that it is digitally signed by a submitter of the data, that it is time stamped, and so on.
  • the computational requirements may include requirements that the data contains short programs or scripts which, when executed on any one of the plurality of network connected devices return a predetermined result or value, for example a value of “true”, a number of a predetermined magnitude, a number exceeding or falling below a predetermined value, a public key, or some other result.
  • the consensus protocol may be stored in memory within the plurality of network connected devices, and may comprise instructions that are retrieved and executed by a processors within the plurality of network connected devices.
  • the consensus protocol may also comprise data that may be retrieved by each of the plurality of network connected devices from their respective memories or data storage units, and may be compared with data received over the network to determine if the rules, data structure requirements or computational requirements have been met.
  • the validator node 104 may proceed to step 414 , and may discard the database schema request.
  • the validator node 104 may proceed to step 416 .
  • the validator node 104 may proceed by constructing a block of data comprising the database schema change request and any other messages that the validator node 104 has previously received and that have not yet been included in the distributed ledger.
  • the block of data may be constructed in a manner that satisfies the consensus protocol of the distributed ledger, as is known to those skilled in the art.
  • the block of data may also contain other messages and elements, for example but not limited to, other database schema change requests, financial transaction data, key announcement and/or key revocation data, and other data to be stored in the distributed ledger.
  • the validator node 104 may then transmit the block of data containing the database schema change request to the peer-to-peer network as per step 418 .
  • the block of data may arrive at an another network connected device 106 , which may constitute a further validator node.
  • the other network connected device 106 may then repeat the same computation as previously performed by the previous validator node 104 in step 412 , and the computation may return either a successful result (Yes) or a failure (No).
  • the other network connected device 106 may determine the block of data generated by the validator node 104 to not be compliant with the consensus protocol of the distributed ledger, and may discard the block, as shown in step 422 .
  • the other network connected device 106 may determine the block of data generated by the validator node 104 to be compliant with the consensus protocol of the distributed ledger, and may add the block of data to its copy of the distributed ledger, as indicated by step 424 .
  • FIG. 5 a system and apparatus for generating an initial block of a distributed ledger, also known by those skilled in the art as a genesis block, is illustrated.
  • the network connected device 106 with the associated database 116 may initiate the creation and running of the distributed ledger by executing the steps below.
  • the network connected device 106 may produce a database schema 502 , which may include a description of tables, data field links, restrictions and other database schema components.
  • the network connected device 106 may apply the database schema 502 to the data in the associated database 116 , as indicated by a transfer arrow 504 .
  • the network connected device 106 may also generate a genesis block 508 , comprising a database schema change request 510 containing the database schema 502 .
  • the network connected device 106 may then transmit the genesis block onward to a peer-to-peer network as indicated by transfer arrow 506 for other network connected devices to receive and utilize as a starting block for the distributed ledger.
  • the network connected device 106 may then participate in generating and adding further distributed ledger blocks 512 , 514 and so on, to the distributed ledger.
  • a new network connected device 600 may join the distributed ledger and may commence downloading distributed ledger blocks of data over the peer-to-peer network, starting with a genesis block 610 , and in this example without loss of generality followed by other blocks 614 , 618 , 622 and 626 in sequence.
  • the other blocks of data may be received out of order and reassembled into the proper order once received.
  • the new network connected device 600 may inspect a block content to determine if it contains a database schema change request, and may extract and store any database schema change request discovered, thus generating a set of database schema change requests.
  • a block 610 contains a database schema change request 612
  • a block 614 contains a database schema change request 616
  • a block 618 contains a database schema change request 620
  • a block 626 contains a database schema change request 628 .
  • a block 622 contains no database schema change request.
  • the set of database schema requests may then be combined, as illustrated by an operation 630 .
  • a later database schema change request may, in some embodiments, take precedence over an earlier database schema change request.
  • the result of operation 630 may then result in a complete combined database schema 632 , which may represent a current state of a database schema embodied in the distributed ledger, and may be enforced by the new network connected device 600 on an associated database 602 .
  • information may be obtained from the distributed ledger by the new network connected device 600 to ensure a consistent database schema is applied to the associated database 602 .
  • a further network connected device 700 may browse the distributed ledger 710 and may commence obtaining data from one or more data sources in order to construct, through a combinatoric function 732 or some other constructive and/or additive and/or iterative function, the database schema 740 for the database 702 associated with the distributed ledger 710 .
  • the further network connected device 700 may download data 712 , representing all or part of the database schema, from a data source comprising the distributed ledger 710 .
  • the further network connected device 700 may download data 716 , representing all or part of the database schema, over the network through a file or data transfer protocol, from a data source comprising a public computer server 714 .
  • the further network connected device 700 may download data 720 , representing all or part of the database schema, over the network through a file or data transfer protocol, from a data source comprising a private computer server 718 .
  • the further network connected device 700 may obtain data 724 , representing all or part of the database schema, through an email 722 sent over a public or private network.
  • the data 724 may be contained in the email using, for example but not limited to: a Multipurpose Internet Mail Extension (MIME) type, a text representation within a body of the email, a binary attachment, a binary-to-text encoding.
  • MIME Multipurpose Internet Mail Extension
  • the further network connected device 700 may obtain data 728 , representing all or part of the database schema, contained within a removable data medium delivered through another distribution channel.
  • the distribution channel in FIG. 7 may be through postal mail 726 , however any suitable physical distribution for delivering the removable data medium may suffice, for example through a courier, a physical handover or other transfer.
  • the removable data medium in FIG. 7 is represented by a Compact Disc-Read Only Memory (CD-ROM) 730 placed within an envelope and delivered through postal mail, however any such removable data medium can comprise a power-backed RAM chip, a ROM chip, an EEPROM chip, a non-volatile RAM chip (NVRAM), other optical disc storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired data in a permanent or semi-permanent manner and that can be accessed by a computer.
  • CD-ROM Compact Disc-Read Only Memory
  • NVRAM non-volatile RAM chip
  • Disk and disc includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc, where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above may also be included within the scope of removable data media.
  • a database schema 804 is altered, reduced or extended to a new form 806 , transmitted to the peer-to-peer network 800 , accepted by a one of the plurality network connected devices 810 maintaining and extending the distributed ledger, and encapsulated into a data block 860 , which is subsequently appended to the distributed ledger as a new block 854 .
  • a network connected device 802 may reach a state in which it requires an extension to, a reduction of, or an alteration of a database schema 804 extracted from the distributed ledger that is applied to an associated database 808 .
  • a current database schema may restrict the length of a field used for storing customer names to a fixed number of characters, but it may be necessary to add a new customer with a name longer than that fixed number to the database, requiring a change to the current database schema to allow longer entries in the field.
  • the current database schema may provide details for a table used to store addresses, and the table may not contain a column for storing the country of the addresses. It may be necessary to add an address in a country different from all previous addresses, requiring a change to the current database schema to add an extra column for storing an address country.
  • the current state of the art either restricts a structure for data stored in the distributed ledger to a fixed format that cannot be subsequently changed, or allows any format of data to be stored in the distributed ledger.
  • An advantage of this disclosure is that it describes how a distributed ledger may be initiated with a restricted structure for data to be stored in the distributed ledger, but how that structure may subsequently be altered as the need arises.
  • the network connected device 802 may generate a database schema change request 806 that embodies the required extension to, reduction of or alteration of the database schema, as disclosed above.
  • a human operator of the system may decide that the database schema should be changed, and may trigger a generation of the database schema change request 806 through, for example, a user interface, by selecting a new representation of a state of the database schema.
  • a sensor enabled device may trigger the generation of the database schema change request 806 through, for example, a generation and submission of sensor data in a new format to the plurality of network connected devices, and a one of the plurality of network connected devices may in response generate the database schema change request 806 to accommodate the new format.
  • an automatically generated value may trigger the generation of the database schema change request 806 , for example a counter may roll over to a larger size, requiring a larger data field to accommodate a new larger counter value.
  • the submission of the counter in a larger format to the plurality of network connected devices may then cause a one of the plurality of network connected devices to generate the database schema change request 806 in response in order to accommodate the new larger value.
  • the network connected device 802 may then transmit the database schema change request 806 to the peer-to-peer network 800 .
  • the one of the plurality of network connected devices 810 which may store a database schema 812 that includes a copy of the database schema 804 , as both were previously extracted from the distributed ledger, and may be applying the database schema 812 to an associated database 814 , may receive the database schema change request 806 and examine it.
  • the one of the plurality of network connected devices 810 may then determine that the database schema change request complies with the consensus protocol accepted by the plurality of network connected devices participating in maintaining and extending the distributed ledger, and may therefore insert a copy of the database schema change request, said copy denoted by 862 , into a block candidate 860 for a next addition to the distributed ledger.
  • the plurality of network connected devices on the peer-to-peer network 800 accept the block candidate 860 , it may then be appended to a head block 850 of the distributed ledger, taking a position indicated by 854 .
  • the plurality of network connected devices may determine if a block candidate and encapsulated database schema change request may satisfy a set of distributed ledger and schema restrictions. This determination is described as a consensus protocol.
  • An embodiment of this disclosure may utilize one, some or all of the aspects of the consensus protocols described below, or other aspects of consensus protocols commonly known to those skilled in the art.
  • the consensus protocol may allow database schema change requests to be submitted by any participant on the distributed ledger, and the plurality of network connected devices may accept any such database schema change.
  • the consensus protocol many limit database schema change requests to at least an initial database schema specified in a first block of the distributed ledger.
  • the consensus protocol may include the acceptance of database schema change requests only if submitted by an authorized network connected device, and in some embodiments if digitally signed by said authorized network connected device.
  • the consensus protocol may include only accepting a database schema change request if no prior database schema change request has been submitted within: a predetermined number of blocks, a predetermined time, an other condition.
  • the consensus protocol may depend on a retrieved data from a public computer server or a private computer server, or a combination of both, and performing a calculation on or a comparison between the retrieved data and the database schema change request to determine if the database schema change request may be included in the distributed ledger.
  • the retrieved data may, for example, include a published schema specification.
  • FIG. 9 A high level flow diagram illustrating data submitted to the distributed ledger and validated against the database schema represented in the distributed ledger is presented in FIG. 9 .
  • FIG. 9 Note that although the embodiment and example provided by FIG. 9 is for a generation and inclusion of a single data message in the distributed ledger, the same flow diagram and associated methods and processes apply to the generation and inclusion of multiple data messages. From here on “a data message” can be equally read as “multiple data messages”.
  • the flow of a data comprising the generation of the data message, inclusion in a successfully generated block of data, and an insertion or appending of said block of data to the distributed ledger is also illustrated through FIG. 9 .
  • the network connected device 102 may generate a data message 902 .
  • the data message may then be encapsulated in a network message 904 and sent on to the peer-to-peer network 906 .
  • the communication node 105 may forward the message to other network connected devices on the peer-to-peer network as per step 908 .
  • Other network connected devices may also make requests to the communication node 105 for network messages that they have not yet received.
  • the database schema change request encapsulated in the network message is forwarded to all interested parties on the peer-to-peer network.
  • the data message encapsulated in the network message may arrive at a network connected device acting as a validator node 104 .
  • the validator node 104 may then extract the data message from the network message as per step 910 .
  • the validator node 104 may then inspect the data message, as per step 912 , to determine if it satisfies the consensus protocol of the distributed ledger.
  • Said consensus protocol may include: compliance with authorization protocols, compliance with database schema design restrictions, compliance with database data restrictions, presence of a valid digital signature, or other distributed ledger and database schema restrictions.
  • the validator node 104 may proceed to step 914 , and may discard the data message.
  • the validator node 104 may proceed to step 916 .
  • the validator node 104 may proceed by constructing a block of data comprising the database message and any other messages that the validator node 104 has previously received and that have not yet been included in the distributed ledger.
  • the block of data may be constructed in a manner that satisfies the consensus protocol of the distributed ledger, as is known to those skilled in the art.
  • the block of data may also contain other messages and elements, for example but not limited to, other data messages, financial transaction data, key announcement and/or key revocation data, and other data to be stored in the distributed ledger.
  • the validator node 104 may then transmit the block of data containing the data message to the peer-to-peer network as per step 918 .
  • the block of data may arrive at an another network connected device 106 , which may constitute a further validator node.
  • the another network connected device 106 may then repeat the same computation as previously performed by the validator node 104 in step 912 , and the computation may return either a successful result (Yes) or a failure (No).
  • the another network connected device 106 may determine the block of data generated by the validator node 104 to not be compliant with the consensus protocol of the distributed ledger, and may discard the block, as shown in step 922 .
  • the another network connected device 106 may determine the block of data generated by the validator node 104 to be compliant with the consensus protocol of the distributed ledger, and may add the block of data to its copy of the distributed ledger, as indicated by step 924 .
  • the data message generated in step 902 may be included in the distributed ledger, provided it complies with the database schema of the distributed ledger.
  • the technology described herein is operational with numerous other general purpose or special purpose computing system environments or configurations.
  • Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with the disclosure include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, processor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
  • instructions refer to computer-implemented steps for processing information in the system. Instructions can be implemented in software, firmware or hardware and include any type of programmed step undertaken by components of the system.
  • a processor may be any conventional general purpose single- or multi-chip processor such as a Pentium® processor, a Pentium® Pro processor, a 8051 processor, a MIPS® processor, a Power PC® processor, or an Alpha® processor.
  • the processor may be any conventional special purpose processor such as a digital signal processor or a graphics processor.
  • the processor typically has conventional address lines, conventional data lines, and one or more conventional control lines.
  • each of the modules comprises various sub-routines, procedures, definitional statements and macros.
  • Each of the modules are typically separately compiled and linked into a single executable program. Therefore, the description of each of the modules is used for convenience to describe the functionality of the preferred system.
  • the processes that are undergone by each of the modules may be arbitrarily redistributed to one of the other modules, combined together in a single module, or made available in, for example, a shareable dynamic-link library.
  • the system may be used in connection with various operating systems such as Linux®, UNIX® or Microsoft Windows®.
  • the system may be written in any conventional programming language such as C, C++, Pascal, or Java, and ran under a conventional operating system.
  • C, C++, Pascal, Java, and FORTRAN are industry standard programming languages for which many commercial compilers can be used to create executable code.
  • the system may also be written using interpreted languages such as Perl, Python or Ruby, or languages that may either be compiled or interpreted, such as BASIC or Lisp.
  • a general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, micro-controller, or state machine.
  • a processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
  • the functions and methods described may be implemented in hardware, software, or firmware executed on a processor, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium.
  • Computer-readable media include both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another.
  • a storage medium may be any available media that can be accessed by a computer.
  • such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disc storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer.
  • Disk and disc includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
  • an advantage of the systems and methods of this disclosure includes reaching a consensus among peers participating in a construction, maintenance and extension of a database structure and associated restrictions for a data format, namely a database schema, that is applicable to a distributed ledger, a distributed immutable shared file, a distributed ledger, or a shared peer-to-peer database, in a deterministic and objective manner.

Landscapes

  • Engineering & Computer Science (AREA)
  • Computer Security & Cryptography (AREA)
  • Computer Networks & Wireless Communication (AREA)
  • Signal Processing (AREA)
  • Theoretical Computer Science (AREA)
  • Databases & Information Systems (AREA)
  • General Engineering & Computer Science (AREA)
  • Computing Systems (AREA)
  • Data Mining & Analysis (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Computer Hardware Design (AREA)
  • Information Retrieval, Db Structures And Fs Structures Therefor (AREA)

Abstract

A method and system is presented for reaching consensus on adding data to and extending the structure or schema of databases synchronized across a distributed ledger or blockchain system, in which no central trusted authority is available, comprising sending an announcement message by a network connected device to a plurality of network connected devices over a network, said message proposing a database schema change or extension. If the announcement message and preceding data in the distributed ledger satisfy predetermined conditions, the plurality of network connected devices may include the data in the distributed ledger, and modify the schema of their databases in a corresponding manner. If data is submitted that requires a structural change to the database before the announcement message has been incorporated in the distributed ledger, the data is rejected by the network and is not included in the distributed ledger.

Description

    CROSS REFERENCE TO RELATED APPLICATIONS
  • The present application is a continuation of, and claims priority of, U.S. non-provisional application Ser. No. 15/449,989, entitled “System And Method For Enforcing The Structure And Content Of Databases Synchronized Over A Distributed Ledger”, filed Mar. 5, 2017. The aforementioned United States application is hereby incorporated by reference in its entirety.
  • TECHNICAL FIELD
  • This disclosure relates to computer systems and methods concerned with an addition of data to a plurality of databases synchronized through a distributed ledger or blockchain, henceforth referred to as the distributed ledger, and more specifically to an enforcement of a consensus amongst a plurality of participants as to how a schema for the plurality of databases will be maintained and/or extended via a medium of a network of the plurality of participants communicating through the distributed ledger.
  • BACKGROUND
  • Distributed ledgers provided in, for example, a peer-to-peer network, such as the distributed ledger used in the Bitcoin cryptocurrency system, rely on a consensus system agreed upon by participants on the peer-to-peer network in order to add blocks of data to the distributed ledger. In such systems, participants examine proposed data blocks in order to verify that they conform to a network agreed standard, rather than relying on a third-party trusted central authority to authorize the addition of data.
  • However, it may be impractical to use a file, in a flat-file format, which comprises data of the distributed ledger, in order to access the data contained therein efficiently. As a result, those skilled in the art know to implement a database system to extract the data from the distributed ledger and insert it into said database system, to facilitate searches for specific data entries.
  • Although the file, which constitutes a chain of data comprising the distributed ledger, may have a predetermined set of rules for ensuring blocks are added to the file representing the distributed ledger in a manner accepted by participants on the peer-to-peer network, nevertheless some of a data of interest encapsulated within a block may take many different unspecified or unpredictable formats.
  • It is currently the case that consensus systems used in distributed ledgers specify a format that an encapsulating data must take, that is: how a block links to a previous block within the chain, what format digital signatures within the block should comply with, and how hashes of the data of interest should be ordered and structured. However, the format of the data of interest encapsulated within the block are generally either unrestricted, or restricted at a launch of the distributed ledger and subsequently unalterable.
  • As a result there is a problem, in that a structure of tables within the database used to extract the distributed ledger data, and a permitted contents of such tables, are not well-defined.
  • It is therefore the intention of the present disclosure to address the problem of ensuring that a transaction or submission containing the data of interest submitted to the peer-to-peer network for inclusion in the distributed ledger has a format and structure that is agreed upon by participants on the peer-to-peer network, in order to ensure that the corresponding structure and contents of the plurality of databases are consistent, that is to say, that a consistent schema for the plurality of databases is defined and updated through the distributed ledger under a consensus of the peer-to-peer network.
  • SUMMARY
  • In accordance with the present disclosure, a solution is provided for reaching a consensus among network connected devices on a peer-to-peer network maintaining and extending a distributed ledger, as to what data to add to the distributed ledger over time, and in particular what format a data representing a database schema and table structure of a plurality of databases, constructed and synchronized from contents of the distributed ledger, should take.
  • Distributed ledger data validators, comprising, in a preferred embodiment of the present disclosure, a plurality of network connected devices participating in maintaining and extending the distributed ledger, may receive data and messages over the peer-to-peer network, which they may package into data blocks for potential inclusion in the distributed ledger.
  • In an embodiment, the plurality of network connected devices, each comprising one or more processors, and storage media comprising computer instructions, said plurality of network connected devices being connectible via a peer-to peer network to each other, are arranged such that when computer instructions are executed on the one or more processors of a one or more of the plurality of network connected devices, operations are caused for reaching a consensus for adding a block of data that includes a proposal for an extension to or alteration of the database schema to a distributed ledger. An addition of the block of data to the distributed ledger may constitute an acceptance by the plurality of network connected devices of said proposal.
  • In an embodiment, operations may commence by a first of the plurality of network connected devices generating a database schema change request message comprising a proposed extension to or alteration of the database schema that may indicate the intent of said first of the plurality of network connected devices to alter or extend the database schema of the corresponding plurality of databases.
  • Subsequently, the first of the plurality of network connected devices may transmit the database schema change request message, through the use of the peer-to-peer network, to the plurality of network connected devices connected to the peer-to-peer network.
  • A one or more of the plurality of network connected devices may then proceed by inserting the database schema change request message into a block of data conforming with a distributed ledger data format accepted by the plurality of network connected devices maintaining and extending the distributed ledger, and may transmit the block of data, through the use of the peer-to-peer network, to the plurality of network connected devices.
  • If one or more of a plurality of predetermined criteria are met, the plurality of network connected devices may then append or insert the block of data to the distributed ledger.
  • In an embodiment, one or more of the plurality of network connected devices may then proceed by extracting the proposed extension to or alteration of the database schema from the database schema change request message contained in the block of data previously added to the distributed ledger and synchronized across the peer-to-peer network, and applying the proposed extension to or alteration of the database schema to each of the plurality of databases. In this embodiment, one or more of the plurality of network connected devices may have its own instance of a database. In other embodiments, multiple network connected devices may share one instance of the database.
  • In an embodiment, if one, more or all of the predetermined criteria are not met, the plurality of network connected devices may reject the block of data, whereby the block of data is not added to the distributed ledger.
  • In an embodiment, the database schema change request message may be digitally signed by the first of the plurality of network connected devices using a private key of a public/private key pair. The public key of the public/private key pair may be publicly associated with the first of the plurality of network connected devices.
  • We move now to a brief examination of some of the predetermined criteria that may include a consensus system for the plurality of network connected devices to determine if the block of data will be accepted and added to the distributed ledger.
  • In an embodiment, the database schema change request message may be deemed valid only if it is included in a first block of data of the distributed ledger. The first block of data is commonly known to those skilled in the art as a genesis block, and may be generated by an originator of the distributed ledger. Under this embodiment, the database schema would remain fixed for a full lifespan of the distributed ledger.
  • In an embodiment, the data block may only be added if a specified subset of the plurality of predetermined criteria are met. The specified subset may include one, some, or all of the plurality of predetermined criteria.
  • Determining whether the plurality of predetermined criteria are met may be based on a one or more of: a previous data contained within the distributed ledger, a data contained within the block of data, a data available from a public computer server, a data available from a private computer server, a relationship between a plurality of data fields of the database and a public key of a public/private key pair, a consensus between the plurality of network connected devices, an authorization by a specific network connected device operating on the peer-to-peer network.
  • In a preferred embodiment, a criterion from the one of the plurality of predetermined criteria may based on the previous data contained within the distributed ledger. In this embodiment, a validity of the criterion may be determined by the plurality of network connected devices using a one or more computations or transformations of the previous data.
  • In one embodiment the computation compare the value of a hash of some or all of the previous data to determine if it matches, exceeds or falls below a target value.
  • In another embodiment the computation may comprise determining a presence of and verifying a validity of a digitally signed authorization within the previous data for a public key of a public/private key pair. This public key may be associated with the first of the network connected devices.
  • In an embodiment, the computation may determine an absence of a prior database schema change request message within a given subset of the previous data, and either rejecting or accepting the block of data based thereon.
  • In a generalization of the embodiments of the disclosure expounded above, the addition of a general data may be subjected to the same scrutiny and restrictions as per the the database schema change request message, which is itself data content submitted to the distributed ledger.
  • Under this embodiment of the disclosure, a second of the plurality of network connected devices may commence by extracting a database schema from the distributed ledger.
  • Subsequently, the second of the plurality of network connected devices may construct a data addition or change request message comprising a proposed addition to or modification of data, complying with the database schema extracted from the distributed ledger.
  • The second of the plurality of network connected devices may then transmit the data addition or change request message to the peer-to-peer network.
  • Subsequently a third of the plurality of network connected devices may extract the proposed addition to or modification of data from the data addition or change request message, and may insert it into a block of data; and
  • The third of the plurality of network connected devices may then submit the block of data to the peer-to-peer network for validation and subsequent insertion into the distributed ledger.
  • If a one, more, or all of a plurality of predetermined criteria agreed upon by a plurality of network connected devices operating on the peer-to-peer network are determined by the plurality of network connected devices maintaining and extending the distributed ledger on the peer-to-peer network to be met, the plurality of network connected devices may then insert the block of data into the distributed ledger.
  • Conversely, if one, more or all of the plurality of predetermined criteria are not met, the plurality of network connected devices may reject the block of data, which is therefore not added to the distributed ledger.
  • In an embodiment, the second of the plurality of network connected devices may digitally sign the data addition or change request message using a private key of a public/private key pair.
  • In an embodiment, the plurality of predetermined criteria utilized by the plurality of network connected devices may be include of one or more of: compliance with the database schema extracted from the distributed ledger, verification of an identity of a submitter of the data addition or change request, authorization by a specific node operating on the peer-peer network, a result of a computation based on a previous data contained within the distributed ledger, a result of a computation performed on a data contained within the block of data, a result of a computation performed on a data available from a public computer server, a result of a computation performed on a data available from a private computer server, a relationship between a plurality of data fields of the database and a public key of a public/private key pair, a consensus between the plurality of participating nodes operating on the peer-to-peer network.
  • Through these means, the plurality of network connected devices and corresponding databases may be maintained in a synchronized state, with data added to the databases conforming to the database schema stored within the distributed ledger. Furthermore, the database schema may be altered or extended as per a need of a one or more of a plurality of operators of the plurality of network connected devices, or as required by an extension of or alteration to a format of data to be stored in the plurality of databases.
  • Those skilled in the art will further appreciate the advantages and superior features found in this disclosure together with other important aspects thereof on reading the detailed description that follows in conjunction with the drawings.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating the principles of the present disclosure. In the figures, like reference numerals designate corresponding parts throughout the different views.
  • FIG. 1 illustrates a peer-to-peer network with a plurality of network connected devices connected to the peer-to-peer network, and a plurality of associated databases, in accordance with an embodiment of the present disclosure.
  • FIG. 2 illustrates a network connected device and associated database that may be utilized in the generation and submission of a database schema change request message, in accordance with an embodiment of the present disclosure.
  • FIG. 3 is a block diagram illustrating a structure of a possible embodiment of a database schema change request message, in accordance with an embodiment of the present disclosure.
  • FIG. 4 is a signal flow diagram providing a general overview of a method and apparatus controlling the flow of the database schema change request message data from the first of the plurality of network connected devices to the plurality of network connected devices connected via the peer-to-peer network for eventual inclusion in the distributed ledger.
  • FIG. 5 is a diagram presenting a commencement or genesis of a distributed ledger by a network connected device with an associated database, and includes the addition of an initial database schema in a first block of the distributed ledger.
  • FIG. 6 is a diagram illustrating a new network connected device joining the distributed ledger, extracting database schema change requests, and constructing a complete database schema to apply to an associated database.
  • FIG. 7 is a diagram illustrating a new network connected device constructing a complete database scheme from a plurality of data sources.
  • FIG. 8 is a diagram illustrating a network connected device submitting a database change request message to the peer-to-peer network, and a second network connected device on the peer-to-peer network encapsulating the database change request message in a data block and appending it to the distributed ledger.
  • FIG. 9 is a signal flow diagram providing a general overview of a method and apparatus controlling the flow of a data message from the first of the plurality network connected device to the plurality of network connected devices connected via the peer-to-peer network for eventual inclusion in the distributed ledger.
  • DETAILED DESCRIPTION
  • Aspects of this disclosure will be described in the context of an exemplary system of a plurality of network connected devices communicating through the medium of a peer-to-peer network system 100, thereby implementing a distributed ledger, as shown schematically in FIG. 1.
  • As depicted, a peer-to-peer network 108 is embodied within a packet switched network 101, through the interconnection of the plurality of network connected devices on the peer-to-peer network 108.
  • A network connected device 102 may connect to the peer-to-peer network through a direct connection to the packet switched network with a wired connection, or through a wireless connection by association with a wireless access point, a cellular base station, a Bluetooth connection, or other means of connection.
  • Other devices connected to the peer-to-peer network may include network connected devices acting as a communication node, for example network connected device 105 whose role is to maintain a list of other devices connected through the peer-to-peer network, and to forward on received network messages to those devices on the list, possibly independently, or possibly as a response to a request from another network connected device. As one skilled in the art will be aware, no individual communication node is required to have a complete list of all devices, as the process of peer-to-peer networking only requires that a union of a set of all communication nodes contains a complete list of all devices on the peer-to-peer network, and for every pair of network connected devices there is a network route from one device to the other, possibly via a set of one or more nodes. Therefore, the only requirement to be a participant on the peer-to-peer network is to establish a connection to one or more of the communication nodes on said network.
  • Further devices connected via the peer-to-peer network may include one or more network connected devices 104, 106, 107, each acting as a database synchronization node or a validator node, whose role may be to act as a communication node, and may also be to receive database schema change request messages and other transaction or data messages from the peer-to-peer network, process them according to the methods and processes to be described further below, and transmitting the results of said processing back to the peer-to-peer network for potential inclusion in the distributed ledger.
  • The devices described above may be implemented through a system comprising a one or a plurality of: a general purpose microprocessor, a digital signal processors (DSP), an application specific instruction set processor (ASIP), a field programmable gate array (FPGA), a dedicated application specific integrated chip (ASIC), or other equivalent integrated or discrete logic circuitry and peripheral circuitry, connected to a tangible storage medium containing instructions which when executed effect methods and techniques described below. The techniques additionally, or alternatively, may be realized at least in part by a computer-readable communication medium or record carrier, that carries or communicates code in the form of instructions or data structures and that can be accessed, read, and/or executed by a computer.
  • Returning to network connected device 102, said network connected device may be connected to a database 112, said database 112 either embodied within the network connected device 102 and communicated to through a network bus within the network connected device 102, or in an instantiation on a separate device or machine communicated to through an external packet-switched network connection, either on a local area network or wide area network, an external serial connection, through a wireless connection by association with a wireless access point, a cellular base station, a Bluetooth connection, or other means of connection.
  • Similarly, the network connected device 104 may be connected to a separate database 114 through any of the aforementioned connection systems as described in [0055].
  • Both network connected device 106 and network connected device 107 may be connected to a same database 116, each through any of the aforementioned connection systems as described in [0055], and may use any traditional synchronization methods as known to those skilled in the art of database synchronization for ensuring that records stored in the same database 116 may not be added or edited in a conflicting manner by either network connected device 106 or 107.
  • An embodiment of the network connected device 102 is presented in FIG. 2, and is now discussed in further detail. The network connected device 102 may include a one or more central processing units (CPU) 202 capable of executing instructions stored in a memory 204, and controlling other peripheral components through drivers 206 stored within the memory 204.
  • Further storage 212 may be present, which may contain a cryptographically secure partition or component 214, where cryptographic keys may be securely stored.
  • The network connected device 102 may connect to the packet switched network through a network module 208, which may consist of a direct wired connection to the packet switched network through a cable 210. In a different embodiment, the network module 208 may contain wireless components comprising one or more wireless modules implemented in firmware or hardware, including a wireless local area network (WLAN) unit such as a Wi-Fi adapter utilizing an 802.11 protocol, a wireless wide area network (WWAN) unit such as Global System for Mobile communications (GSM), Long Term Evolution (LTE), or other cellular wireless data communication system, or a Bluetooth unit. The wireless components may provide network connectivity to a packet switched network and hence to the peer-to-peer network for the network connected device.
  • Components comprising the network connected device 102 may communicate through a bus 216, which may be implemented as a peripheral component interconnect express (PCIe) bus, a universal serial bus (USB), a universal asynchronous receiver/transmitter (UART) serial bus, a suitable advanced micro-controller bus architecture (AMBA) interface, a serial digital input output (SDIO) bus, or other equivalent interface.
  • The network connected device 102 may, in some embodiments, include an interface 218 to permit communication with a database 112. In one possible embodiment, the database 112 may be external to the network connected device 102, and may be communicated with through a connecting cable 220. The connectivity may be implemented through an ethernet connection, a PCIe bus, a USB, a UART serial bus, a suitable AMBA interface, an SDIO bus, or other equivalent interface. In other embodiments, the database may be connected through a wireless connection, for example a WLAN unit such as a Wi-Fi adapter utilizing an 802.11 protocol, a WWAN unit such as GSM, LTE, or other cellular wireless data communication system, or a Bluetooth unit. In yet further embodiments of the system the database may be internal to the network connected device, and implemented entirely through software stored in storage 212 and/or memory 204, executed by the CPU 202, and communicating through the bus 216.
  • In an embodiment, the network connected device 102 may submit a database schema change request message 300 to the peer to peer network 108, a possible structure of which is described in FIG. 3.
  • The database schema change request message 300 may include a database schema change request message header. The database schema change request message header 302 may include a marker indicating that the rest of the message contains database schema change data, and other header information such as a length of the message and a version number of the message.
  • The database schema change request message 300 may include a time stamp 304, which in one embodiment may be used to indicate from what point in time the database schema change request message 300 is to be considered valid. Through these means it may be possible to register a database schema change request on the network with a future validity period, for example by specifying the time stamp as a future time. In another embodiment the time stamp may be a current time, thereby initiating authorizing the database schema change at the point the database schema change request message 300 is sent, or at a fixed predetermined time after the database schema change request message 300 is sent.
  • The database schema change request message 300 may include a database schema change data 306, which may describe the addition, alteration or deletion of a database schema. The database schema change data may be included in binary format, in JavaScript Object Notation (JSON), in Structured Query Language (SQL), in Extensible Markup Language (XML), or in another data format recognizable by a database as encoding a description of, extension to, alteration of or deletion of one or more of a plurality of structures, data tables, data descriptions and/or data format restrictions applicable to the database. Those skilled in the art will recognize that a database schema change description may include the initialization of a database structure as well as the alteration or addition to an existing database structure.
  • Those skilled in the art will be aware that a database contains a description of a structure of the database, known as a database schema, and which represents a logical view of the entire database. It may describe how data is organized and how the relationship between various elements of data is defined. The database schema may formulate all the constraints that are to be applied to the data.
  • The database schema may define entities that constitute the components of the database and the relationship between them, and may contain a detailed description of the database, which may be depicted by a schema diagram.
  • For example, the database schema may define a set of database tables, each containing a set of data fields, some of which may be restricted to only containing data in one of: a text format, a numerical formal, a numerical format restricted to integer values, a numerical format restricted to values less than or greater than a prescribed value, a discrete list of values that a given data value may be chosen from, a Boolean value, a specified length of a data field, a specified checksum that a data must satisfy, or some other data value or data structure.
  • The database schema change data 306 may include a description of how a given structure described by the database schema may be altered. For example, if the database schema restricts a length of a data field to a given number of characters, the database schema change data 306 may alter the restriction to increase or to decrease the length of the data field. Similarly, if the database schema restricts a data field to only contain numerical data, another element of the database schema change data 306 may alter this to allow text to be contained in data stored under the data field. In a further example, the database schema may restrict a data field to contain Elliptic Curve Digital Signature Algorithm (ECDSA) key data, and the database schema change data 306 may alter this to restrict the data field to contain ElGamal key data. In general the database schema change data 306 may contain data pertaining to instructions to alter any restriction on any data field as defined by the current database schema to any other restriction, or even the absence of a restriction, thus changing the underlying database schema.
  • In another example, the database schema may link a one data table to another data table. For example, a first data table may contain a list of options, and a second data table may contain data including a field whose value is to be selected from the list of options provided in the first data table. The database schema change data 306 may, in this example, contain an instruction to allow the field in the second data table to also contain a value selected from a differing table containing a differing list of options.
  • In another example, the database schema may be non-existent, and the database schema change data 306 may contain a set of instructions that define a complete initial database schema, thus initializing the database system.
  • The database schema change request message 300 may include another data payload 308, which may include but is not limited to: at least one row of data to be inserted into a database, an information or meta-data relating to the submitter of the database schema change request message 300, a cryptocurrency transaction, an encoding of an executable computer program or smart contract, another distributed ledger transaction.
  • The database schema change request message 300 may include a public key 310 of a public/private key pair generated by the network connected device 102 submitting the database schema change request message. The public key infrastructure or algorithm may be one of ECDSA, digital signature algorithm (DSA), Rivest, Shamir, & Adleman (RSA), ElGamal, or some other secure asymmetric cryptographic key system.
  • The database schema change request message 300 may also include a hash 312 of a data contained in a preceding message content. The data to be hashed may include one or more of the public key of the public/private key pair 310, the other data payload 308, the database schema change data 306, the time stamp 304 and/or the database schema change request message header 302. The hash may be one of a secure hash algorithm (SHA), RACE integrity primitives evaluation message digest (RIPEMD), Whirlpool, Scrypt, HAS-160, BLAKE, or other cryptographic hash function applied to the preceding content of the message.
  • The database schema change request message 300 may also include a digital signature 314, generated using a private key of the public/private key pair associated with the public key 310 and the hash 312 of the data contained in the preceding message content, in order to provide for a veracity or an authentication of database schema change request message 300. The digital signature algorithm used may be one of ECDSA, DSA, RSA, ElGamal, or some other secure asymmetric key digital signing algorithm.
  • In an embodiment, an authorization, for example a second digital signature, may be appended to or inserted into the database schema change request message 300, and may include a hash of some or all of the preceding message, and the digital signature 314, generated using a second private key of a second public/private key pair, for example a public key of an agency or a device providing permission to insert a database schema change request message into the distributed ledger. In this embodiment, the authorization may be added at a later stage by one other of the plurality of network connected devices.
  • A high level flow diagram illustrating one possible embodiment of the system and steps taken therein is presented in FIG. 4. Note that although the embodiment and example provided by FIG. 4 is for a generation and inclusion of a single database schema change request message in the distributed ledger, the same flow diagram and associated methods and processes apply to the generation and inclusion of multiple database schema change request messages.
  • A set of multiple database schema change request messages may differ from a single database schema change request message in that different database schema change requests from different network connected devices may be packaged into one block of data by a network connected device functioning as a validator node 104 for submission to the peer-to-peer network and possible inclusion in the distributed ledger. This allows for more efficient processing of multiple database schema change request messages submitted at approximately the same time by, for example, reducing a data overhead induced by a requirement for header data and digital signature data included in the block of data.
  • From here on “a database schema change request message” can therefore be equally read as “multiple database schema change request messages”.
  • Note further that an other data not necessarily concerned with database schemas may also be generated and included in a data block and inserted or appended to the distributed ledger following the same methods taught in the following paragraphs describing the function and implementation of the system and method illustrated by FIG. 4. This other data may include further data for inclusion in fields or rows of the database, digital key announcement or revocation messages, cryptographic currency or native asset transaction messages, or other general data that may be of interest to participants on the peer-to-peer network.
  • The interaction of the network connected device 102 with the plurality of network connected devices, and specifically a network connected device functioning as a communication node 105, and the network connected device functioning as the validator node 104, and finally another one of the plurality of network connected devices 106 functioning as a further validator node, is shown. The flow of a data comprising the generation of the database schema change request message, inclusion in a successfully generated block of data, and an insertion or appending of said block of data to the distributed ledger is also illustrated through FIG. 4.
  • The successfully generated block of data may conform to a definition of acceptable data blocks, as defined through a consensus protocol accepted by the plurality of network connected devices participating on the peer-to-peer network, which may comprise a set of rules and structural requirements for such acceptable data blocks. A generated block of data may be considered successful if it is conformant with the definition of acceptable data blocks and is accepted by, for example, a majority, a predetermined number or percentage, or a specific subset, of the plurality of network connected devices.
  • A block of data may comprise a binary block, a character-based string, or a data structure which may itself comprise a collection of keys, values, and other substructures of data.
  • The function of generating blocks of data may be the encapsulation of data to produce candidates for consideration by the plurality of network in order to be included in the distributed ledger. It is through this that the distributed ledger may grow in size over time, storing data of interest in the process.
  • Once the network connected device 102 has determined a need to add, modify or extend the database schema of the database associated with the distributed ledger, it may generate a database schema change request 402. The database schema change request may then be encapsulated in a network message 404 and sent on to the peer-to-peer network 406.
  • The database schema change request may contain information on how a structure of and rules applying to the database associated with the distributed ledger and contents of said database may be changed in order to accommodate changing requirements for data storage in the database as time progresses. An advantage of this aspect of the disclosure is that distributed ledgers possess features such as auditable and tamper-proof data storage that traditional databases do not, and by maintaining and altering the database schema on the distributed ledger, the advantages of these features apply to the database itself.
  • The database schema change request may be generated by including a complete revision of the database schema in the database schema change request, or by including a list of changes, additions and deletions, known to those skilled in the art as “deltas”, to the database schema.
  • Once the database schema change request encapsulated in the network message has been received by a network connected device acting as a communication node 105, the communication node 105 may forward the message to other network connected devices on the peer-to-peer network as per step 408. Other network connected devices may also make requests to the communication node 105 for network messages that they have not yet received. Through this, the database schema change request encapsulated in the network message is forwarded to all interested parties on the peer-to-peer network.
  • Through these network interactions, the database schema change request encapsulated in the network message may arrive at a network connected device acting as a validator node 104.
  • The validator node 104 may then extract the database schema change request from the network message as per step 410.
  • The validator node 104 may then inspect the database schema change request, as per step 412, to determine if it satisfies a consensus protocol of the distributed ledger. Said consensus protocol may include: compliance with authorization protocols, compliance with database schema design restrictions, compliance with database data restrictions, presence of a valid digital signature, or other distributed ledger and database schema restrictions.
  • The consensus protocol may comprise a set of rules, data structures and other computational requirements that a data submitted to the distributed ledger may be required to comply with in order for the data to be accepted in to the distributed ledger. The rules may include requirements that data may not exceed a given length, that it is digitally signed by a submitter of the data, that it is time stamped, and so on. The computational requirements may include requirements that the data contains short programs or scripts which, when executed on any one of the plurality of network connected devices return a predetermined result or value, for example a value of “true”, a number of a predetermined magnitude, a number exceeding or falling below a predetermined value, a public key, or some other result.
  • The consensus protocol may be stored in memory within the plurality of network connected devices, and may comprise instructions that are retrieved and executed by a processors within the plurality of network connected devices.
  • The consensus protocol may also comprise data that may be retrieved by each of the plurality of network connected devices from their respective memories or data storage units, and may be compared with data received over the network to determine if the rules, data structure requirements or computational requirements have been met.
  • If the validator node 104 determines that the database schema change request does not comply with the consensus protocol of the distributed ledger, the validator node 104 may proceed to step 414, and may discard the database schema request.
  • If the validator node 104 determines that the database schema change request does comply with the consensus protocol of the distributed ledger, and optionally if the database schema change request has not been included in a prior block of data, the validator node 104 may proceed to step 416.
  • In step 416 the validator node 104 may proceed by constructing a block of data comprising the database schema change request and any other messages that the validator node 104 has previously received and that have not yet been included in the distributed ledger. The block of data may be constructed in a manner that satisfies the consensus protocol of the distributed ledger, as is known to those skilled in the art. The block of data may also contain other messages and elements, for example but not limited to, other database schema change requests, financial transaction data, key announcement and/or key revocation data, and other data to be stored in the distributed ledger.
  • The validator node 104 may then transmit the block of data containing the database schema change request to the peer-to-peer network as per step 418.
  • Through transmission to the peer-to-peer network, the block of data may arrive at an another network connected device 106, which may constitute a further validator node. As marked by step 420, the other network connected device 106 may then repeat the same computation as previously performed by the previous validator node 104 in step 412, and the computation may return either a successful result (Yes) or a failure (No).
  • If the computation result of step 420 is a failure (No), the other network connected device 106 may determine the block of data generated by the validator node 104 to not be compliant with the consensus protocol of the distributed ledger, and may discard the block, as shown in step 422.
  • If the computation in step 420 produces a successful result, then the other network connected device 106 may determine the block of data generated by the validator node 104 to be compliant with the consensus protocol of the distributed ledger, and may add the block of data to its copy of the distributed ledger, as indicated by step 424.
  • In FIG. 5. a system and apparatus for generating an initial block of a distributed ledger, also known by those skilled in the art as a genesis block, is illustrated. In this embodiment, the network connected device 106 with the associated database 116 may initiate the creation and running of the distributed ledger by executing the steps below.
  • The network connected device 106 may produce a database schema 502, which may include a description of tables, data field links, restrictions and other database schema components.
  • The network connected device 106 may apply the database schema 502 to the data in the associated database 116, as indicated by a transfer arrow 504.
  • The network connected device 106 may also generate a genesis block 508, comprising a database schema change request 510 containing the database schema 502. The network connected device 106 may then transmit the genesis block onward to a peer-to-peer network as indicated by transfer arrow 506 for other network connected devices to receive and utilize as a starting block for the distributed ledger.
  • The network connected device 106, and other network connected devices may then participate in generating and adding further distributed ledger blocks 512, 514 and so on, to the distributed ledger.
  • In FIG. 6 a new network connected device 600 may join the distributed ledger and may commence downloading distributed ledger blocks of data over the peer-to-peer network, starting with a genesis block 610, and in this example without loss of generality followed by other blocks 614, 618, 622 and 626 in sequence. In other embodiments of the disclosure the other blocks of data may be received out of order and reassembled into the proper order once received.
  • For each block downloaded, the new network connected device 600 may inspect a block content to determine if it contains a database schema change request, and may extract and store any database schema change request discovered, thus generating a set of database schema change requests. In this example a block 610 contains a database schema change request 612, a block 614 contains a database schema change request 616, a block 618 contains a database schema change request 620, and a block 626 contains a database schema change request 628. A block 622 contains no database schema change request.
  • The set of database schema requests may then be combined, as illustrated by an operation 630. A later database schema change request may, in some embodiments, take precedence over an earlier database schema change request.
  • The result of operation 630 may then result in a complete combined database schema 632, which may represent a current state of a database schema embodied in the distributed ledger, and may be enforced by the new network connected device 600 on an associated database 602.
  • As has been demonstrated, through the methods and systems illustrated in FIG. 6 and the descriptive paragraphs above concerning it, information may be obtained from the distributed ledger by the new network connected device 600 to ensure a consistent database schema is applied to the associated database 602.
  • In FIG. 7, in an embodiment of the invention, a further network connected device 700 may browse the distributed ledger 710 and may commence obtaining data from one or more data sources in order to construct, through a combinatoric function 732 or some other constructive and/or additive and/or iterative function, the database schema 740 for the database 702 associated with the distributed ledger 710.
  • The further network connected device 700 may download data 712, representing all or part of the database schema, from a data source comprising the distributed ledger 710.
  • The further network connected device 700 may download data 716, representing all or part of the database schema, over the network through a file or data transfer protocol, from a data source comprising a public computer server 714.
  • The further network connected device 700 may download data 720, representing all or part of the database schema, over the network through a file or data transfer protocol, from a data source comprising a private computer server 718.
  • The further network connected device 700 may obtain data 724, representing all or part of the database schema, through an email 722 sent over a public or private network.
  • The data 724 may be contained in the email using, for example but not limited to: a Multipurpose Internet Mail Extension (MIME) type, a text representation within a body of the email, a binary attachment, a binary-to-text encoding.
  • The further network connected device 700 may obtain data 728, representing all or part of the database schema, contained within a removable data medium delivered through another distribution channel.
  • By way of example, and not limitation, the distribution channel in FIG. 7 may be through postal mail 726, however any suitable physical distribution for delivering the removable data medium may suffice, for example through a courier, a physical handover or other transfer.
  • By way of example, and not limitation, the removable data medium in FIG. 7 is represented by a Compact Disc-Read Only Memory (CD-ROM) 730 placed within an envelope and delivered through postal mail, however any such removable data medium can comprise a power-backed RAM chip, a ROM chip, an EEPROM chip, a non-volatile RAM chip (NVRAM), other optical disc storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired data in a permanent or semi-permanent manner and that can be accessed by a computer. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc, where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above may also be included within the scope of removable data media.
  • In FIG. 8 a database schema 804 is altered, reduced or extended to a new form 806, transmitted to the peer-to-peer network 800, accepted by a one of the plurality network connected devices 810 maintaining and extending the distributed ledger, and encapsulated into a data block 860, which is subsequently appended to the distributed ledger as a new block 854.
  • We now examine FIG. 8 in more detail. A network connected device 802 may reach a state in which it requires an extension to, a reduction of, or an alteration of a database schema 804 extracted from the distributed ledger that is applied to an associated database 808.
  • For example, a current database schema may restrict the length of a field used for storing customer names to a fixed number of characters, but it may be necessary to add a new customer with a name longer than that fixed number to the database, requiring a change to the current database schema to allow longer entries in the field.
  • In another example, the current database schema may provide details for a table used to store addresses, and the table may not contain a column for storing the country of the addresses. It may be necessary to add an address in a country different from all previous addresses, requiring a change to the current database schema to add an extra column for storing an address country.
  • The current state of the art either restricts a structure for data stored in the distributed ledger to a fixed format that cannot be subsequently changed, or allows any format of data to be stored in the distributed ledger. An advantage of this disclosure is that it describes how a distributed ledger may be initiated with a restricted structure for data to be stored in the distributed ledger, but how that structure may subsequently be altered as the need arises.
  • In FIG. 8 the network connected device 802 may generate a database schema change request 806 that embodies the required extension to, reduction of or alteration of the database schema, as disclosed above.
  • In one embodiment of the disclosure, a human operator of the system may decide that the database schema should be changed, and may trigger a generation of the database schema change request 806 through, for example, a user interface, by selecting a new representation of a state of the database schema.
  • In another embodiment of the disclosure, a sensor enabled device may trigger the generation of the database schema change request 806 through, for example, a generation and submission of sensor data in a new format to the plurality of network connected devices, and a one of the plurality of network connected devices may in response generate the database schema change request 806 to accommodate the new format.
  • In another embodiment of the disclosure, an automatically generated value may trigger the generation of the database schema change request 806, for example a counter may roll over to a larger size, requiring a larger data field to accommodate a new larger counter value. The submission of the counter in a larger format to the plurality of network connected devices may then cause a one of the plurality of network connected devices to generate the database schema change request 806 in response in order to accommodate the new larger value.
  • The network connected device 802 may then transmit the database schema change request 806 to the peer-to-peer network 800.
  • The one of the plurality of network connected devices 810, which may store a database schema 812 that includes a copy of the database schema 804, as both were previously extracted from the distributed ledger, and may be applying the database schema 812 to an associated database 814, may receive the database schema change request 806 and examine it.
  • The one of the plurality of network connected devices 810 may then determine that the database schema change request complies with the consensus protocol accepted by the plurality of network connected devices participating in maintaining and extending the distributed ledger, and may therefore insert a copy of the database schema change request, said copy denoted by 862, into a block candidate 860 for a next addition to the distributed ledger.
  • If the plurality of network connected devices on the peer-to-peer network 800 accept the block candidate 860, it may then be appended to a head block 850 of the distributed ledger, taking a position indicated by 854.
  • We proceed now to examine how the plurality of network connected devices may determine if a block candidate and encapsulated database schema change request may satisfy a set of distributed ledger and schema restrictions. This determination is described as a consensus protocol. An embodiment of this disclosure may utilize one, some or all of the aspects of the consensus protocols described below, or other aspects of consensus protocols commonly known to those skilled in the art.
  • In an embodiment, the consensus protocol may allow database schema change requests to be submitted by any participant on the distributed ledger, and the plurality of network connected devices may accept any such database schema change.
  • At the other end of the spectrum, the consensus protocol many limit database schema change requests to at least an initial database schema specified in a first block of the distributed ledger.
  • In another embodiment, the consensus protocol may include the acceptance of database schema change requests only if submitted by an authorized network connected device, and in some embodiments if digitally signed by said authorized network connected device.
  • In another embodiment, the consensus protocol may include only accepting a database schema change request if no prior database schema change request has been submitted within: a predetermined number of blocks, a predetermined time, an other condition.
  • In another embodiment, the consensus protocol may depend on a retrieved data from a public computer server or a private computer server, or a combination of both, and performing a calculation on or a comparison between the retrieved data and the database schema change request to determine if the database schema change request may be included in the distributed ledger. The retrieved data may, for example, include a published schema specification.
  • A high level flow diagram illustrating data submitted to the distributed ledger and validated against the database schema represented in the distributed ledger is presented in FIG. 9. Note that although the embodiment and example provided by FIG. 9 is for a generation and inclusion of a single data message in the distributed ledger, the same flow diagram and associated methods and processes apply to the generation and inclusion of multiple data messages. From here on “a data message” can be equally read as “multiple data messages”.
  • The interaction of the network connected device 102 with the plurality of network connected devices, and specifically a network connected device functioning as a communication node 105, and a network connected device functioning as a validator node 104, and finally another one of the plurality of network connected devices 106 functioning as a further validator node, is shown. The flow of a data comprising the generation of the data message, inclusion in a successfully generated block of data, and an insertion or appending of said block of data to the distributed ledger is also illustrated through FIG. 9.
  • Once the network connected device 102 has determined a need to add data to the distributed ledger, it may generate a data message 902. The data message may then be encapsulated in a network message 904 and sent on to the peer-to-peer network 906.
  • Once the data message encapsulated in the network message has been received by a network connected device acting as a communication node 105, the communication node 105 may forward the message to other network connected devices on the peer-to-peer network as per step 908. Other network connected devices may also make requests to the communication node 105 for network messages that they have not yet received. Through these means, the database schema change request encapsulated in the network message is forwarded to all interested parties on the peer-to-peer network.
  • Through these network interactions, the data message encapsulated in the network message may arrive at a network connected device acting as a validator node 104.
  • The validator node 104 may then extract the data message from the network message as per step 910.
  • The validator node 104 may then inspect the data message, as per step 912, to determine if it satisfies the consensus protocol of the distributed ledger. Said consensus protocol may include: compliance with authorization protocols, compliance with database schema design restrictions, compliance with database data restrictions, presence of a valid digital signature, or other distributed ledger and database schema restrictions.
  • If the validator node 104 determines that the data message does not comply with the consensus protocol of the distributed ledger the validator node 104 may proceed to step 914, and may discard the data message.
  • If the validator node 104 determines that the data message does comply with the consensus protocol of the distributed ledger, and optionally if the data message has not been included in a prior block of data, the validator node 104 may proceed to step 916.
  • In step 916 the validator node 104 may proceed by constructing a block of data comprising the database message and any other messages that the validator node 104 has previously received and that have not yet been included in the distributed ledger. The block of data may be constructed in a manner that satisfies the consensus protocol of the distributed ledger, as is known to those skilled in the art. The block of data may also contain other messages and elements, for example but not limited to, other data messages, financial transaction data, key announcement and/or key revocation data, and other data to be stored in the distributed ledger.
  • The validator node 104 may then transmit the block of data containing the data message to the peer-to-peer network as per step 918.
  • Through transmission to the peer-to-peer network, the block of data may arrive at an another network connected device 106, which may constitute a further validator node. As marked by step 920, the another network connected device 106 may then repeat the same computation as previously performed by the validator node 104 in step 912, and the computation may return either a successful result (Yes) or a failure (No).
  • If the computation result of step 920 is a failure (No), the another network connected device 106 may determine the block of data generated by the validator node 104 to not be compliant with the consensus protocol of the distributed ledger, and may discard the block, as shown in step 922.
  • If the computation in step 920 produces a successful result, then the another network connected device 106 may determine the block of data generated by the validator node 104 to be compliant with the consensus protocol of the distributed ledger, and may add the block of data to its copy of the distributed ledger, as indicated by step 924.
  • Through these means the data message generated in step 902 may be included in the distributed ledger, provided it complies with the database schema of the distributed ledger.
  • The technology described herein is operational with numerous other general purpose or special purpose computing system environments or configurations. Examples of well-known computing systems, environments, and/or configurations that may be suitable for use with the disclosure include, but are not limited to, personal computers, server computers, hand-held or laptop devices, multiprocessor systems, processor-based systems, programmable consumer electronics, network PCs, minicomputers, mainframe computers, distributed computing environments that include any of the above systems or devices, and the like.
  • As used herein, instructions refer to computer-implemented steps for processing information in the system. Instructions can be implemented in software, firmware or hardware and include any type of programmed step undertaken by components of the system.
  • A processor may be any conventional general purpose single- or multi-chip processor such as a Pentium® processor, a Pentium® Pro processor, a 8051 processor, a MIPS® processor, a Power PC® processor, or an Alpha® processor. In addition, the processor may be any conventional special purpose processor such as a digital signal processor or a graphics processor. The processor typically has conventional address lines, conventional data lines, and one or more conventional control lines.
  • The system is comprised of various modules as discussed in detail. As can be appreciated by one of ordinary skill in the art, each of the modules comprises various sub-routines, procedures, definitional statements and macros. Each of the modules are typically separately compiled and linked into a single executable program. Therefore, the description of each of the modules is used for convenience to describe the functionality of the preferred system. Thus, the processes that are undergone by each of the modules may be arbitrarily redistributed to one of the other modules, combined together in a single module, or made available in, for example, a shareable dynamic-link library.
  • The system may be used in connection with various operating systems such as Linux®, UNIX® or Microsoft Windows®.
  • The system may be written in any conventional programming language such as C, C++, Pascal, or Java, and ran under a conventional operating system. C, C++, Pascal, Java, and FORTRAN are industry standard programming languages for which many commercial compilers can be used to create executable code. The system may also be written using interpreted languages such as Perl, Python or Ruby, or languages that may either be compiled or interpreted, such as BASIC or Lisp.
  • Those of skill will further appreciate that the various illustrative logical blocks, modules, circuits, and algorithm steps described in connection with the embodiments disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. To clearly illustrate this interchangeability of hardware and software, various illustrative components, blocks, modules, circuits, and steps have been described above generally in terms of their functionality. Whether such functionality is implemented as hardware or software depends upon the particular application and design constraints imposed on the overall system. Skilled artisans may implement the described functionality in varying ways for each particular application, but such implementation decisions should not be interpreted as causing a departure from the scope of the present disclosure.
  • The various illustrative logical blocks, modules, and circuits described in connection with the embodiments disclosed herein may be implemented or performed with a general purpose processor, a DSP, an ASIC, an FPGA or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, micro-controller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration.
  • In one or more example embodiments, the functions and methods described may be implemented in hardware, software, or firmware executed on a processor, or any combination thereof. If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. Computer-readable media include both computer storage media and communication media including any medium that facilitates transfer of a computer program from one place to another. A storage medium may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disc storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
  • The foregoing description details certain embodiments of the systems, devices, and methods disclosed herein. It will be appreciated, however, that no matter how detailed the foregoing appears in text, the systems, devices, and methods can be practiced in many ways. As is also stated above, it should be noted that the use of particular terminology when describing certain features or aspects of the disclosure should not be taken to imply that the terminology is being re-defined herein to be restricted to including any specific characteristics of the features or aspects of the technology with which that terminology is associated.
  • It will be appreciated by those skilled in the art that various modifications and changes may be made without departing from the scope of the described technology. Such modifications and changes are intended to fall within the scope of the embodiments. It will also be appreciated by those of skill in the art that parts included in one embodiment are interchangeable with other embodiments; one or more parts from a depicted embodiment can be included with other depicted embodiments in any combination. For example, any of the various components described herein and/or depicted in the Figures may be combined, interchanged or excluded from other embodiments.
  • With respect to the use of substantially any plural and/or singular terms herein, those having skill in the art can translate from the plural to the singular and/or from the singular to the plural as is appropriate to the context and/or application. The various singular/plural permutations may be expressly set forth herein for sake of clarity.
  • It will be understood by those within the art that, in general, terms used herein are generally intended as “open” terms (e.g., the term “including” should be interpreted as “including but not limited to,” the term “having” should be interpreted as “having at least,” the term “includes” should be interpreted as “includes but is not limited to,” etc.). It will be further understood by those within the art that if a specific number of an introduced claim recitation is intended, such an intent will be explicitly recited in the claim, and in the absence of such recitation no such intent is present. For example, as an aid to understanding, the following appended claims may contain usage of the introductory phrases “at least one” and “one or more” to introduce claim recitations. However, the use of such phrases should not be construed to imply that the introduction of a claim recitation by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim recitation to embodiments containing only one such recitation, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an” (e.g., “a” and/or “an” should typically be interpreted to mean “at least one” or “one or more”); the same holds true for the use of definite articles used to introduce claim recitations. In addition, even if a specific number of an introduced claim recitation is explicitly recited, those skilled in the art will recognize that such recitation should typically be interpreted to mean at least the recited number (e.g., the bare recitation of “two recitations,” without other modifiers, typically means at least two recitations, or two or more recitations). Furthermore, in those instances where a convention analogous to “at least one of A, B, and C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, and C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). In those instances where a convention analogous to “at least one of A, B, or C, etc.” is used, in general such a construction is intended in the sense one having skill in the art would understand the convention (e.g., “a system having at least one of A, B, or C” would include but not be limited to systems that have A alone, B alone, C alone, A and B together, A and C together, B and C together, and/or A, B, and C together, etc.). It will be further understood by those within the art that virtually any disjunctive word and/or phrase presenting two or more alternative terms, whether in the description, claims, or drawings, should be understood to contemplate the possibilities of including one of the terms, either of the terms, or both terms. For example, the phrase “A or B” will be understood to include the possibilities of “A” or “B” or “A and B.”
  • While various aspects and embodiments have been disclosed herein, other aspects and embodiments will be apparent to those skilled in the art. The various aspects and embodiments disclosed herein are for purposes of illustration and are not intended to be limiting.
  • As will be appreciated from the above discussion, an advantage of the systems and methods of this disclosure includes reaching a consensus among peers participating in a construction, maintenance and extension of a database structure and associated restrictions for a data format, namely a database schema, that is applicable to a distributed ledger, a distributed immutable shared file, a distributed ledger, or a shared peer-to-peer database, in a deterministic and objective manner.

Claims (17)

What is claimed is:
1. A method for modifying a schema for a database maintained using a distributed ledger on a network, in response to a submission of a data in a new format, comprising:
determining the new format of the data;
generating a schema change request comprising a proposed modification of the schema, the proposed modification accommodating the new format of the data;
adding the schema change request to the distributed ledger;
extracting the schema change request from the distributed ledger; and
applying the proposed modification from the schema change request to the database.
2. The method of claim 1, wherein the data is submitted by a sensor enabled device.
3. The method of claim 2, wherein the schema change request is signed using a private key of a public/private key pair associated with the sensor enabled device.
4. The method of claim 1, wherein some or all of the schema for the database is distributed through distribution channels comprising one or more of:
the distributed ledger,
a private computer server,
a public computer server,
a file distributed through email,
a file distributed on a removable data medium delivered through another distribution channel.
5. The method of claim 1, wherein the schema change request is not added to the distributed ledger if a one or more predetermined criteria are not met.
6. The method of claim 5, wherein the one or more predetermined criteria are not met if the schema change request is not included in a first data block of the distributed ledger.
7. The method of claim 5, wherein determining if some or all of the one or more predetermined criteria are met is based on a one or more of:
a result of a computation performed on a previous data contained within the distributed ledger,
a result of a computation performed on a data available from a public computer server,
a result of a computation performed on a data available from a private computer server,
a relationship between a data structure of the database and a public key of a public/private key pair,
a consensus between a plurality of participating nodes operating on the network,
an authorization by a specific node operating on the network.
8. The method of claim 7, wherein if a criterion of the one or more predetermined criteria is based on the previous data, a validity of the criterion is determined using a one or more of:
a hash of some or all of the previous data,
a presence of a digitally signed authorization within the previous data for the public key of the public/private key pair,
an absence of a digitally signed revocation within the previous data for the public key of the public/private key pair,
an absence of a prior schema change request within a given subset of the previous data.
9. A plurality of network connected devices, each comprising: one or more processors, and storage media comprising computer instructions, said plurality of network connected devices being connectible via a network to each other, arranged such that when computer instructions are executed on the one or more processors of a one or more of the plurality of network connected devices, operations are caused for reaching a consensus among the plurality of network connected devices for modifying a schema for a database maintained by the plurality of network connected devices using a distributed ledger on a network, in response to a submission by a first device of a data in a new format, comprising:
determining the new format of the data, by a second device;
generating, by the second device, a schema change request comprising a proposed modification of the schema, the proposed modification accommodating the new format of the data;
transmitting the schema change request, by the second device, through the network, to the plurality of network connected devices;
inserting the schema change request into a data block by a third device;
transmitting the data block, by the third device, to the network;
adding the data block to the distributed ledger, by the plurality of network connected devices;
extracting the proposed modification of the schema from the schema change request contained in the data block, by a one or more of the plurality of network connected devices; and
applying the proposed modification of the schema to the database, by the one or more of the plurality of network connected devices.
10. The plurality of network connected devices of claim 9, wherein the first device comprises a sensor enabled device.
11. The plurality of network connected devices of claim 10, wherein the schema change request is signed using a private key of a public/private key pair associated with the first device.
12. The plurality of network connected devices of claim 9, wherein some or all of the schema for the database is distributed to the plurality of network connected devices through distribution channels comprising one or more of:
the distributed ledger,
a private computer server,
a public computer server,
a file distributed through email,
a file distributed on a removable data medium delivered through another distribution channel.
13. The plurality of network connected devices of claim 9, wherein the data block is not added to the distributed ledger by the one or more of the plurality of network connected devices if a one or more predetermined criteria are not met.
14. The plurality of network connected devices of claim 13, wherein the one or more predetermined criteria are determined not to be met, by the plurality of network connected devices, if the schema change request is not included in a first data block of the distributed ledger.
15. The plurality of network connected devices of claim 13, wherein determining by the plurality of network connected devices if the one or more predetermined criteria are met is based on a one or more of:
a result of a computation performed on a previous data contained within the distributed ledger,
a result of a computation performed on a data contained within the data block,
a result of a computation performed on a data available from a public computer server,
a result of a computation performed on a data available from a private computer server,
a relationship between a data field of the database and a public key of a public/private key pair,
a consensus between the plurality of network connected devices,
an authorization by a specific network connected device operating on the network.
16. The plurality of network connected devices of claim 15, wherein if a criterion from the one or more predetermined criteria is based on the previous data contained within the distributed ledger, a validity of the criterion is determined by the plurality of network connected devices using one or more of:
a hash of some or all of the previous data,
a presence of a digitally signed authorization within the previous data for a public key of the public/private key pair,
an absence of a digitally signed revocation within the previous data for the public key of the public/private key pair,
an absence of a prior schema change request within a given subset of the previous data.
17. The plurality of network connected devices of claim 9, wherein the second device comprises the first device.
US15/972,479 2017-03-05 2018-05-07 System and method for enforcing the structure and content of databases synchronized over a distributed ledger Abandoned US20180253452A1 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US15/972,479 US20180253452A1 (en) 2017-03-05 2018-05-07 System and method for enforcing the structure and content of databases synchronized over a distributed ledger

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US15/449,989 US10621150B2 (en) 2017-03-05 2017-03-05 System and method for enforcing the structure and content of databases synchronized over a distributed ledger
US15/972,479 US20180253452A1 (en) 2017-03-05 2018-05-07 System and method for enforcing the structure and content of databases synchronized over a distributed ledger

Related Parent Applications (1)

Application Number Title Priority Date Filing Date
US15/449,989 Continuation US10621150B2 (en) 2017-03-05 2017-03-05 System and method for enforcing the structure and content of databases synchronized over a distributed ledger

Publications (1)

Publication Number Publication Date
US20180253452A1 true US20180253452A1 (en) 2018-09-06

Family

ID=63355677

Family Applications (3)

Application Number Title Priority Date Filing Date
US15/449,989 Active 2037-06-08 US10621150B2 (en) 2017-03-05 2017-03-05 System and method for enforcing the structure and content of databases synchronized over a distributed ledger
US15/972,479 Abandoned US20180253452A1 (en) 2017-03-05 2018-05-07 System and method for enforcing the structure and content of databases synchronized over a distributed ledger
US16/159,645 Abandoned US20190050431A1 (en) 2017-03-05 2018-10-13 System and method for enforcing the structure and content of databases synchronized over a distributed ledger

Family Applications Before (1)

Application Number Title Priority Date Filing Date
US15/449,989 Active 2037-06-08 US10621150B2 (en) 2017-03-05 2017-03-05 System and method for enforcing the structure and content of databases synchronized over a distributed ledger

Family Applications After (1)

Application Number Title Priority Date Filing Date
US16/159,645 Abandoned US20190050431A1 (en) 2017-03-05 2018-10-13 System and method for enforcing the structure and content of databases synchronized over a distributed ledger

Country Status (1)

Country Link
US (3) US10621150B2 (en)

Cited By (20)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN109857807A (en) * 2019-01-10 2019-06-07 中钞信用卡产业发展有限公司杭州区块链技术研究院 Transaction data synchronization method, apparatus, equipment and medium based on block chain
CN110222518A (en) * 2019-05-30 2019-09-10 北京工业大学 Credible powers and functions access control method based on block chain
US10430390B1 (en) * 2018-09-06 2019-10-01 OmniMesh Technologies, Inc. Method and system for managing mutual distributed ledgers in a system of interconnected devices
US10469571B2 (en) * 2014-09-29 2019-11-05 Amazon Technologies, Inc. Block allocation based on server utilization
WO2020095110A1 (en) * 2018-11-09 2020-05-14 Velo Holdings Limited Blockchain with non-turing complete system guards
WO2020113314A1 (en) * 2018-12-04 2020-06-11 Zeu Crypto Networks Inc. System and method for augmenting database applications with blockchain technology
GB2588812A (en) * 2019-11-08 2021-05-12 Jitsuin Ltd Data block modification
US20210167970A1 (en) * 2019-03-15 2021-06-03 Tencent Technology (Shenzhen) Company Limited Data synchronization method and apparatus, computer device, and readable storage medium
WO2021102572A1 (en) * 2019-11-26 2021-06-03 Zeu Crypto Networks Inc. Method and system for converting database applications into blockchain applications
US20210256012A1 (en) * 2018-12-20 2021-08-19 Advanced New Technologies Co., Ltd. Methods and apparatuses for reading and updating data structures, and electronic devices
US20210273791A1 (en) * 2018-05-25 2021-09-02 Intertrust Technologies Corporation Cryptographic systems and methods using distributed ledgers
US20210365439A1 (en) * 2020-05-22 2021-11-25 Couchbase, Inc. Distributed transaction execution in distributed databases
US20210382899A1 (en) * 2018-11-01 2021-12-09 Sap Se Dual-stack architecture that integrates relational database with blockchain
US11361324B2 (en) * 2020-11-03 2022-06-14 International Business Machines Corporation Blockchain-issued verifiable credentials for portable trusted asset claims
US20220353230A1 (en) * 2017-03-31 2022-11-03 Intel Corporation Systems and methods for fair information exchange using publish-subscribe with blockchain
US11552800B2 (en) * 2018-05-22 2023-01-10 Siemens Aktiengesellschaft Apparatus, system and method for operating a software-defined network
US20230088443A1 (en) * 2021-09-23 2023-03-23 Bank Of America Corporation System for intelligent database modelling
US20230088869A1 (en) * 2021-09-23 2023-03-23 Bank Of America Corporation System for authorizing a database model using distributed ledger technology
US11681687B2 (en) 2020-08-31 2023-06-20 Couchbase, Inc. Executing transactions on distributed databases
US11709831B2 (en) 2019-08-09 2023-07-25 Couchbase, Inc. Cost-based query optimization for array fields in database systems

Families Citing this family (56)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
CN107196989B (en) * 2017-03-21 2019-08-09 阿里巴巴集团控股有限公司 A kind of processing method and processing device of service request
US10945166B2 (en) * 2017-04-07 2021-03-09 Vapor IO Inc. Distributed processing for determining network paths
CN107395665B (en) * 2017-05-22 2020-04-24 创新先进技术有限公司 Block chain service acceptance and service consensus method and device
MA49571A (en) * 2017-07-10 2021-03-24 Zamna Tech Limited METHOD AND SYSTEM FOR DATA SECURITY IN INDEPENDENT IT SYSTEMS AND DIGITAL NETWORKS
US10868673B2 (en) * 2017-09-25 2020-12-15 Sap Se Network access control based on distributed ledger
US10367811B2 (en) 2017-10-06 2019-07-30 Stealthpath, Inc. Methods for internet communication security
US10374803B2 (en) 2017-10-06 2019-08-06 Stealthpath, Inc. Methods for internet communication security
US10361859B2 (en) * 2017-10-06 2019-07-23 Stealthpath, Inc. Methods for internet communication security
US10977016B2 (en) 2017-10-31 2021-04-13 EMC IP Holding Company LLC Management of data using templates
US10567168B2 (en) 2017-11-16 2020-02-18 International Business Machines Corporation Blockchain transaction privacy enhancement through broadcast encryption
WO2019111056A1 (en) 2017-12-06 2019-06-13 Vchain Technology Limited Method and system for data security, validation, verification and provenance within independent computer systems and digital networks
US11086901B2 (en) * 2018-01-31 2021-08-10 EMC IP Holding Company LLC Method and system for efficient data replication in big data environment
US10756904B1 (en) * 2018-02-22 2020-08-25 EMC IP Holding Company LLC Efficient and secure distributed ledger maintenance
US10693662B2 (en) * 2018-02-22 2020-06-23 Idlogiq Inc. Methods for secure serialization of supply chain product units
US10817829B2 (en) * 2018-02-23 2020-10-27 Bank Of America Corporation Blockchain-based supply chain smart recall
US11055658B2 (en) 2018-02-23 2021-07-06 Bank Of America Corporation Blockchain-based supply chain certification systems and methods
US10609069B2 (en) 2018-02-23 2020-03-31 Bank Of America Corporation Reflexive benign service attack on IoT device(s)
US11122037B2 (en) 2018-02-27 2021-09-14 Bank Of America Corporation Internet of things (“IoT”) protection retro-system
CA3132468A1 (en) * 2018-03-02 2019-09-06 Ranieri Solutions, Llc Methods and apparatus for servicing an obligation utilizing a blockchain
US11138658B2 (en) 2018-03-02 2021-10-05 Ranieri Ip, Llc Methods and apparatus for mortgage loan securitization based upon blockchain verified ledger entries
US10700867B2 (en) 2018-03-09 2020-06-30 Bank Of America Corporation Internet of things (“IoT”) multi-layered embedded handshake
US10721132B2 (en) 2018-03-12 2020-07-21 Bank Of America Corporation IoT circuitry modules
US10574651B2 (en) 2018-03-13 2020-02-25 Bank Of America Corporation Internet of things (“IoT”) chain link
US10749687B2 (en) * 2018-03-15 2020-08-18 Microsoft Technology Licensing, Llc Binding version stamp for smart contracts
US10645108B2 (en) 2018-03-19 2020-05-05 Bank Of America Corporation Smart Internet of Things (“IoT”) web of trust
US10637873B2 (en) * 2018-03-20 2020-04-28 Bank Of America Corporation Smart internet of things (“IOT”) relay monitors
US10819746B2 (en) 2018-03-21 2020-10-27 Bank Of America Corporation Nodes on an internet of things (“IoT”) with dual-network access ports
US10567390B2 (en) 2018-03-26 2020-02-18 Bank Of America Corporation Peer to peer internet of things (“IoT”) validation system
US10831914B2 (en) 2018-03-26 2020-11-10 Bank Of America Corporation Secure extensible wireless communication with IoT devices
US11057462B2 (en) 2018-03-27 2021-07-06 Bank Of America Corporation Asset management block chain
US10848588B2 (en) 2018-03-27 2020-11-24 Bank Of America Corporation Reverse proxy server for an internet of things (“IoT”) network
US10602930B2 (en) 2018-03-29 2020-03-31 Bank Of America Corporation Multi-biometric-factor, internet of things (IOT), secured network
US10721065B2 (en) * 2018-03-29 2020-07-21 Accenture Global Solutions Limited Active state blockchain synchronization
US10673626B2 (en) * 2018-03-30 2020-06-02 Spyrus, Inc. Threshold secret share authentication proof and secure blockchain voting with hardware security modules
US10841303B2 (en) 2018-04-12 2020-11-17 Bank Of America Corporation Apparatus and methods for micro-segmentation of an enterprise internet-of-things network
WO2019217323A1 (en) 2018-05-06 2019-11-14 Strong Force TX Portfolio 2018, LLC Methods and systems for improving machines and systems that automate execution of distributed ledger and other transactions in spot and forward markets for energy, compute, storage and other resources
US11544782B2 (en) 2018-05-06 2023-01-03 Strong Force TX Portfolio 2018, LLC System and method of a smart contract and distributed ledger platform with blockchain custody service
US11669914B2 (en) 2018-05-06 2023-06-06 Strong Force TX Portfolio 2018, LLC Adaptive intelligence and shared infrastructure lending transaction enablement platform responsive to crowd sourced information
US11550299B2 (en) 2020-02-03 2023-01-10 Strong Force TX Portfolio 2018, LLC Automated robotic process selection and configuration
CN109086325A (en) * 2018-06-29 2018-12-25 阿里巴巴集团控股有限公司 Data processing method and device based on block chain
US10853353B2 (en) * 2018-08-03 2020-12-01 American Express Travel Related Services Company, Inc. Blockchain-enabled datasets shared across different database systems
US11336430B2 (en) 2018-09-07 2022-05-17 Sap Se Blockchain-incorporating distributed authentication system
US11314749B2 (en) 2018-10-03 2022-04-26 International Business Machines Corporation Blockchain implementing reliability database
US11226971B2 (en) * 2018-10-03 2022-01-18 International Business Machines Corporation Blockchain implementing reliability database
US11243917B2 (en) 2018-10-03 2022-02-08 International Business Machines Corporation Blockchain implementing reliability database
US10922309B2 (en) * 2018-11-19 2021-02-16 Dragonchain, Inc. Distributed ledger interaction system and methods
US11023490B2 (en) * 2018-11-20 2021-06-01 Chicago Mercantile Exchange Inc. Selectively replicated trustless persistent store
US10949417B2 (en) 2018-11-26 2021-03-16 Bank Of America Corporation Blockchain augmented internet of things (“IoT”) device-based system for dynamic supply chain tracking
CN110083659A (en) * 2019-03-21 2019-08-02 深圳壹账通智能科技有限公司 Multi-source data read method and relevant device based on distributed system
US11120040B2 (en) * 2019-03-26 2021-09-14 International Business Machines Corporation Multi-ledger blockchain management
US11095512B2 (en) 2019-04-17 2021-08-17 Bank Of America Corporation Internet of things (“IoT”) versatile nodes
EP3959842A1 (en) 2019-04-24 2022-03-02 International Business Machines Corporation Extracting data from a blockchain network
US11144537B2 (en) 2019-09-16 2021-10-12 Bank Of America Corporation System for data consensus validation in an electronic distributed server network using a screening node
US11558423B2 (en) 2019-09-27 2023-01-17 Stealthpath, Inc. Methods for zero trust security with high quality of service
US11982993B2 (en) 2020-02-03 2024-05-14 Strong Force TX Portfolio 2018, LLC AI solution selection for an automated robotic process
US11880365B2 (en) 2022-03-23 2024-01-23 Bank Of America Corporation Multimodal and distributed database system structured for dynamic latency reduction

Family Cites Families (8)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7505993B2 (en) 2005-12-14 2009-03-17 International Business Machines Corporation Database schema for content managed data
US20100146003A1 (en) 2008-12-10 2010-06-10 Unisys Corporation Method and system for building a B-tree
US9553982B2 (en) 2013-07-06 2017-01-24 Newvoicemedia, Ltd. System and methods for tamper proof interaction recording and timestamping
US20160283920A1 (en) 2015-03-28 2016-09-29 Justin Fisher Authentication and verification of digital data utilizing blockchain technology
CN108352016B (en) 2015-07-08 2022-11-11 巴克莱执行服务有限公司 Data validation and storage
US10915874B2 (en) * 2015-11-10 2021-02-09 Loyyal Corporation System and process for tokenization of digital media
US10417217B2 (en) * 2016-08-05 2019-09-17 Chicago Mercantile Exchange Inc. Systems and methods for blockchain rule synchronization
US10614239B2 (en) * 2016-09-30 2020-04-07 Amazon Technologies, Inc. Immutable cryptographically secured ledger-backed databases

Cited By (32)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10469571B2 (en) * 2014-09-29 2019-11-05 Amazon Technologies, Inc. Block allocation based on server utilization
US20220353230A1 (en) * 2017-03-31 2022-11-03 Intel Corporation Systems and methods for fair information exchange using publish-subscribe with blockchain
US11552800B2 (en) * 2018-05-22 2023-01-10 Siemens Aktiengesellschaft Apparatus, system and method for operating a software-defined network
US11924332B2 (en) 2018-05-25 2024-03-05 Intertrust Technologies Corporation Cryptographic systems and methods using distributed ledgers
US11606201B2 (en) * 2018-05-25 2023-03-14 Intertrust Technologies Corporation Cryptographic systems and methods using distributed ledgers
US20210273791A1 (en) * 2018-05-25 2021-09-02 Intertrust Technologies Corporation Cryptographic systems and methods using distributed ledgers
US10430390B1 (en) * 2018-09-06 2019-10-01 OmniMesh Technologies, Inc. Method and system for managing mutual distributed ledgers in a system of interconnected devices
US11200211B2 (en) 2018-09-06 2021-12-14 OmniMesh Technologies, Inc. Method and system for managing mutual distributed ledgers in a system of interconnected devices
US20210382899A1 (en) * 2018-11-01 2021-12-09 Sap Se Dual-stack architecture that integrates relational database with blockchain
WO2020095110A1 (en) * 2018-11-09 2020-05-14 Velo Holdings Limited Blockchain with non-turing complete system guards
WO2020113314A1 (en) * 2018-12-04 2020-06-11 Zeu Crypto Networks Inc. System and method for augmenting database applications with blockchain technology
EP3891621A4 (en) * 2018-12-04 2022-08-24 ZeU Technologies, Inc. System and method for augmenting database applications with blockchain technology
US11775507B2 (en) * 2018-12-20 2023-10-03 Advanced New Technologies Co., Ltd. Methods and apparatuses for reading and updating data structures, and electronic devices
US20210256012A1 (en) * 2018-12-20 2021-08-19 Advanced New Technologies Co., Ltd. Methods and apparatuses for reading and updating data structures, and electronic devices
CN109857807A (en) * 2019-01-10 2019-06-07 中钞信用卡产业发展有限公司杭州区块链技术研究院 Transaction data synchronization method, apparatus, equipment and medium based on block chain
US20210167970A1 (en) * 2019-03-15 2021-06-03 Tencent Technology (Shenzhen) Company Limited Data synchronization method and apparatus, computer device, and readable storage medium
US11985251B2 (en) * 2019-03-15 2024-05-14 Tencent Technology (Shenzhen) Company Limited Data synchronization method and apparatus, computer device, and readable storage medium
CN110222518A (en) * 2019-05-30 2019-09-10 北京工业大学 Credible powers and functions access control method based on block chain
US11709831B2 (en) 2019-08-09 2023-07-25 Couchbase, Inc. Cost-based query optimization for array fields in database systems
WO2021089495A1 (en) * 2019-11-08 2021-05-14 Jitsuin Ltd Data block modification
US20220021518A1 (en) * 2019-11-08 2022-01-20 Jitsuin Ltd. Data block modification
GB2588812A (en) * 2019-11-08 2021-05-12 Jitsuin Ltd Data block modification
WO2021102572A1 (en) * 2019-11-26 2021-06-03 Zeu Crypto Networks Inc. Method and system for converting database applications into blockchain applications
US20210365439A1 (en) * 2020-05-22 2021-11-25 Couchbase, Inc. Distributed transaction execution in distributed databases
US12032560B2 (en) 2020-05-22 2024-07-09 Couchbase, Inc. Distributed transaction execution management in distributed databases
US11681687B2 (en) 2020-08-31 2023-06-20 Couchbase, Inc. Executing transactions on distributed databases
US12007985B2 (en) 2020-08-31 2024-06-11 Couchbase, Inc. Executing transactions on distributed databases
US11361324B2 (en) * 2020-11-03 2022-06-14 International Business Machines Corporation Blockchain-issued verifiable credentials for portable trusted asset claims
US11822524B2 (en) * 2021-09-23 2023-11-21 Bank Of America Corporation System for authorizing a database model using distributed ledger technology
US11907179B2 (en) * 2021-09-23 2024-02-20 Bank Of America Corporation System for intelligent database modelling
US20230088869A1 (en) * 2021-09-23 2023-03-23 Bank Of America Corporation System for authorizing a database model using distributed ledger technology
US20230088443A1 (en) * 2021-09-23 2023-03-23 Bank Of America Corporation System for intelligent database modelling

Also Published As

Publication number Publication date
US20180253451A1 (en) 2018-09-06
US20190050431A1 (en) 2019-02-14
US10621150B2 (en) 2020-04-14

Similar Documents

Publication Publication Date Title
US10621150B2 (en) System and method for enforcing the structure and content of databases synchronized over a distributed ledger
US20190325038A1 (en) Consensus based editable blockchain
US10601598B2 (en) System and method for storing the location on a blockchain of a hash of a digital item within said digital item
JP7285840B2 (en) Systems and methods for authenticating off-chain data based on proof verification
US20190179801A1 (en) File management/search system and file management/search method based on block chain
JP6943356B2 (en) Blockchain-based document management method using UTXO-based protocol and document management server using this {METHOD FOR MANAGING DOCUMENT ON BASIS OF BLOCKCHAIN BY USING UTXO-BASED PROTOCOL, AND DOCUMENT MANAGEN
US10491396B2 (en) Method and server for providing notary service for file and verifying file recorded by notary service
US10235538B2 (en) Method and server for providing notary service for file and verifying file recorded by notary service
US10754848B2 (en) Method for registration of data in a blockchain database and a method for verifying data
US12045227B2 (en) Proof-of-work for blockchain applications
KR20210003234A (en) Maintaining blocks of a blockchain in a segmented blockchain network
US20190334700A1 (en) Method and system for managing decentralized data access permissions through a blockchain
US10938565B2 (en) Method and apparatus for inter-blockchain transmission of authenticable message
US10951394B2 (en) System and method for publication of private data using a blockchain network
US20190363896A1 (en) Blockchain based decentralized and distributed certificate authority
WO2020258847A1 (en) Method and apparatus for cross-chain transmission of authenticable message based on processing module
WO2023071373A1 (en) Blockchain consensus method, apparatus, and device, and storage medium
EP3920464A1 (en) Method for storing transaction that represents asset transfer to distributed network and program for the same
US11711221B1 (en) Systems and methods for trusted chain code system
WO2021109718A1 (en) Verification method and apparatus based on block chain system
JP2022551874A (en) Method and Apparatus for Secure Symbiosis Mining
CN111309809A (en) Block header storage method and equipment thereof
KR20150131318A (en) A method and system for transferring data
CN113132459B (en) Distributed storage method, system, storage medium, information data processing terminal
US10938578B2 (en) System and method for maintaining an integrity of a blockchain using digital certificates

Legal Events

Date Code Title Description
STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: DOCKETED NEW CASE - READY FOR EXAMINATION

STPP Information on status: patent application and granting procedure in general

Free format text: NON FINAL ACTION MAILED

STPP Information on status: patent application and granting procedure in general

Free format text: RESPONSE TO NON-FINAL OFFICE ACTION ENTERED AND FORWARDED TO EXAMINER

STPP Information on status: patent application and granting procedure in general

Free format text: FINAL REJECTION MAILED

STCB Information on status: application discontinuation

Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION