METHOD, PARTICIPANT UNIT, TRANSACTION REGISTER AND PAYMENT SYSTEM FOR MANAGING TRANSACTION DATA SETS

Information

  • Patent Application
  • 20230259899
  • Publication Number
    20230259899
  • Date Filed
    June 30, 2021
    3 years ago
  • Date Published
    August 17, 2023
    a year ago
Abstract
A method involves a first participating unit having an electronic coin data set registered in a coin register of a payment system. The method includes: generating a transaction data set relating to the transmission of the electronic coin data set to a second participating unit; encrypting the generated transaction data set using a cryptographic key, wherein the cryptographic key is composed of at least two cryptographic sub-keys of different respective remote entities; and initiating a communication connection to a transaction register of the payment system in order to transmit the encrypted transaction data set to the transaction register.
Description
TECHNICAL FIELD OF THE INVENTION

The invention relates to a method in a first participant unit, a method in a transaction register, a participant unit, a transaction register and a payment system for managing transaction data sets when transmitting electronic coin data sets.


TECHNICAL BACKGROUND OF THE INVENTION

Privacy is an important value for society, especially when it comes to very sensitive data such as payment information. Security of payment transactions and associated payment transaction data means both protecting the confidentiality of the data exchanged; and protecting the integrity of the data exchanged; and protecting the availability of the data exchanged.


For electronic coin data sets, it must be possible to provide proof of basic control functions, in particular (1) the detection of multiple spending methods, also known as double spending, and (2) the detection of uncovered payments. In case (1) someone tries to spend the same coin data set several times and case (2) someone tries to spend a coin data set although he has no credit (anymore).


To illustrate case (1), FIG. 1a and FIG. 1b show a payment system in which it is possible to exchange a monetary amount in the form of electronic coin data sets C directly between terminals M in the payment system. When transmitting directly between terminals M, no central instance of the payment system, for example a coin register 2, is required. In FIG. 1a, a terminal M1 splits a coin partial data set Ca to obtain a coin partial data set Cb. The terminal M1 passes the coin data set Cb to terminals M2 and M3 simultaneously in an unauthorised manner.


In the payment system of FIG. 1a, terminal M2 shares the coin data set Cb and obtains the coin data set Cc, which is then shared directly with terminal M4. Terminal M4 passes the coin data set Cc directly to terminal M6. Terminal M6 passes the coin data set Cc directly to terminal M8. The unsuspecting participant with terminal M3 passes the coin partial data set Cb directly to terminal M5. Terminal M3 passes the coin data set Cb directly to terminal M5. Terminal M5 passes the coin data set Cb directly to terminal M7. Thus, both coin data sets Cb and Cc change hands frequently without a coin register 2 of the payment system being aware of this.


If—as shown in FIG. 1b—the terminal M7 registers the coin data set Cb in a coin register 2 of the payment system (=switching or switch), the coin data set Cb becomes invalid (shown by crossing out the coin data set) and a coin data set Cd becomes valid. If the terminal M8 now also wants to register the coin data set Cc as the coin data set Ce with the coin register 2, the coin register 2 detects that the coin data set Cb is already invalid. The attack by M1 is only now detected. As a result, the coin register 2 accepts neither the coin data set Cc nor the coin data set Ce.


In addition, due to the large number of transactions of an electronic coin data set and also due to the advancing life span, the risk of manipulation(s) being carried out on the electronic coin data set increases.


In the future, it should be possible to dispense with cash (banknotes and analogue coins) altogether, or at least with analogue coins.


In certain circumstances, it may be desirable to restrict privacy according to due process, for example if criminal activity is suspected. So far, the payment system protects the privacy of the participants.


It is therefore the object of the present invention to provide a method and a system in which a payment transaction between participants in a payment system is secure yet simple. In particular, a direct and anonymous payment between participant units, such as devices, tokens, smartphones, security elements but also machines, cash terminals or vending machines is to be created. It should be possible for the participant (=user) to combine and/or split several coin data sets as desired in order to enable flexible exchanging (transmitting). The exchanged coin data sets shall be confidential to other system participants, but allow each system participant to perform basic checks on the coin data set, namely (1) detecting multiple spending attempts; (2) detecting attempts to pay with non-existent monetary amounts; and (3) detecting return criteria for already spent coin data sets, for example that a coin data set should expire.


In particular, it should be possible to de-anonymise transactions on official request, for example to enable law enforcement.


SUMMARY OF THE INVENTION

The task is solved in particular by a method in a first participant unit, preferably a first security element, comprising an electronic coin data set registered in a coin register of a payment system. The method comprises the following method steps: Generating a transaction data set with respect to transmitting the electronic coin data set to a second participant unit, preferably a second security element or with respect to a modification of the electronic coin data set to be registered at the coin register; encrypting the generated transaction data set with a cryptographic key, the cryptographic key being composed of at least two cryptographic subkeys, preferably at least three cryptographic subkeys, each of different remote instances; and initiating a communication link establishment to a transaction register to send the encrypted transaction data set to the transaction register.


In certain circumstances it may be desirable to restrict privacy according to due method, for example where criminal activity is suspected. By the method according to the invention, access to confidential information is granted to a defined (determined) group of persons, in particular law enforcement authorities in law enforcement, in order to prevent or prosecute crimes. In order to gain access, i.e. to be able to decrypt encrypted transaction data sets, several (at least two) partial keys of different remote instances are necessary. This further preserves the confidentiality and also the data integrity of the payment system.


In the following description, the communication process with transaction data sets (=sending) is conceptually separated from the communication process with coin data sets (transmitting).


An electronic coin data set is in particular an electronic data set that represents a monetary (=monetary) amount and is also colloquially referred to as a “digital coin” or “electronic coin”, in English “digital/electronic Coin”. This monetary amount can change from a first terminal to another terminal in the method. In the following, a monetary amount is understood to be a digital amount that can, for example, be credited to an account of a financial institution or exchanged for another means of payment. An electronic coin data set thus represents cash in electronic form.


An electronic coin data set for transmitting monetary amounts differs substantially from the electronic data set, for example the transaction data set, for exchanging or transferring data, since, for example, a classical data transaction takes place on the basis of a question-answer principle or on an intercommunication between the data transfer partners, for example the participant unit and the transaction register. An electronic coin data set, on the other hand, is unique and stands in the context of a security concept, which can comprise masking, signatures or encryption, for example. In principle, an electronic coin data set contains all data required for a receiving instance with regard to verification, authentication and forwarding to other instances. Intercommunication between the terminals during exchange is therefore basically not necessary for this type of data set.


In contrast to the copying of electronic data sets, i.e. the duplication of digital data, a valid electronic coin data set may only exist once in the payment system. This system requirement must be observed in particular when transmitting electronic coin data sets.


In order to make a transmission protocol secure, the electronic coin data sets are managed by respective participant units, for example by security elements integrated therein, and are also transmitted by them. In a preferred embodiment, the security element is inserted into the participant unit ready for use. In this case, the participant unit can contain an application through which a user (=participant) controls a payment process and accesses electronic coin data sets of the security element in this payment process.


The participant unit can be, for example, a mobile terminal such as a smartphone, a tablet computer, a computer, a server or a machine. A transmitting of the electronic coin data set from the (first) security element of a first participant unit takes place, for example, to the (second) security element of another participant unit. A participant unit-to participant unit transmission path can be set up, via which, for example, a secure channel is set up between the two security elements, via which the transmitting of the electronic coin data set then takes place. An application (installed) inserted on the participant unit ready for use can initiating and controlling the transmitting of the coin data set by using input and/or output means of the respective participant unit. For example, electronic coin data set amounts can be displayed and the transmission process can be monitored.


According to the invention, it is envisaged that a transaction data set is generated by the first participant unit, i.e. the participant unit sending the (at least one) coin data set. The transaction data set comprises the information required to uniquely identify the transmission of the coin data set between two participant units of the payment system in the totality of the transmissions (payment transactions). The transaction data set comprises in particular the participant units participating in the transmission and information about the coin data set to be transmitted. With a (decrypted) transaction data set, the transmitting of the electronic coin data set can be clearly reconstructed. In a preferred embodiment, the transaction data set has at least one identifier or address of the first participant unit (=sender), i.e. a date with which this security element can be uniquely identified in the payment system. In addition, the transaction data set has at least one identifier or address of a second participant unit (=receiver), i.e. a date with which this security element can be uniquely identified in the payment system. In addition, the transaction data set has a monetary amount of the electronic coin data set.


In a further preferred embodiment, the transaction data set comprises a transaction number. This transaction number is, for example, a random number generated before the generating step. Preferably, a random number generator of the participant unit or the security element is used for this purpose. Alternatively or additionally, the transaction number is an identification number of the transaction that is unique for transmission from the first participant unit. Additionally, the transaction number may be an identification of the transaction in the payment system.


In a further preferred embodiment, the transaction data set further comprises a masked electronic coin data set corresponding to the electronic coin data set to be transmitted, preferably in place of the monetary amount of the electronic coin data set or in place of the electronic coin data set. Masking will be explained later. The non-introduction of the electronic coin data set enables the retention of two system requirements, namely that the electronic coin data set is only present once in the system and (and is precisely not a copy in the transaction data set), and secondly that possession of the electronic coin data set entitles the holder to payment, i.e. a transaction data set that has not yet been encrypted (if necessary transmitted to the second participant unit) or a decrypted transaction data set would contain coin data sets potentially usable for payment transactions, thus increasing the risk of fraud.


In a further preferred embodiment, the transaction data set has a transaction time. For this purpose, a timestamp is generated and appended to the transaction data set. The time stamp is preferably unique throughout the payment system.


The transaction data set may contain further data, such as transaction location (GPS). Preferably, however, it consists of the aforementioned data.


In a preferred embodiment, the first participant unit appends a transaction time to the encrypted transaction data set (in plain text), for example as a metadate. Thus, this transaction time can be in the transaction register as an input parameter for calculating a deletion time of the encrypted transaction data set. For example, in the context of data retention, the encrypted transaction data set could be automatically deleted from the transaction register after a set storage time, for example X months or Y years, has elapsed. This is advantageous in the case that the transaction data set is temporally transmitted to the transaction register much later after the transmission of the coin data set, in order not to prolong the storage (possibly in an illegal way).


An identifier or identifiers of the transaction data set could also be appended in plain text as a further metadata.


In a further preferred embodiment, the transaction data set has an acknowledgement of receipt from the second participant unit. The receipt serves as proof or acknowledgement of proper receipt of the electronic coin data set in the second participant unit, and possession of the receipt in the first participant unit proves proper transmission of the electronic coin data set.


This transaction data set first of all contradicts the requirement of anonymity for the payment system. For this reason, the transaction data set is encrypted in a subsequent step. Encrypting the transaction data set is preferably carried out immediately after it has been generated; more preferably, generating and encrypting are carried out as one atomic operation. Encrypting is done with a cryptographic key. This means that the transaction data set cannot be viewed by an uninvolved third party and its content is hidden from this uninvolved third party. This ensures that an attack on the participant identity module to spy out unencrypted transaction data is unsuccessful.


This cryptographic key is composed of at least two partial keys. Each partial key originates from a (single) remote instance. The remote instances are independent of each other. A remote instance has knowledge and possession of only one (own) partial key. In particular, a remote instance has no knowledge of and is not in possession of a partial key of another remote instance. Composing the cryptographic key also includes deriving a public key part of a PKI key infrastructure to be used for encrypting, which may have been generated using a composed private key part.


By remote instance is meant here that this instance is not a local instance of a participant unit. The remote instance is preferably not the coin register of the payment system, not the transaction register of the payment system and not the monitoring register of the payment system, so that in order to maintain anonymity and neutrality in the payment system, an independence the register instances of the payment system cannot decrypt the encrypted transaction data set or cannot contribute a partial key for decrypting.


This allows the transaction data set to be stored in encrypted form in a trusted location, the transaction register. As a result of a court ruling, this encrypted transaction data set can be decrypted by authorised parties as the remote instances. These authorised parties could be, for example, a law enforcement agency, a notary public, the ministry of justice, a central bank, an issuing instance of the payment process, a judicial instance or others.


In a preferred embodiment, the cryptographic partial keys are each from a law enforcement authority instance; a notary instance; a ministry of justice instance; a central issuing authority of the payment system; or a commercial bank instance of the payment system.


In a preferred embodiment, the cryptographic key for encrypting the transaction data set is a public key part of an asymmetric public key infrastructure (PKI), wherein the corresponding private key part for decrypting the encrypted transaction data set is composed by an addition operation or a bitwise XOR operation from all cryptographic part keys of the different remote instances.


In a preferred embodiment, the cryptographic key for encrypting the transaction data set is a public key part of an asymmetric key infrastructure (PKI), wherein the corresponding private key part for decrypting the encrypted transaction data set is composed of a predefined number of cryptographic partial keys of different remote instances, the predefined number being less than the total number of different remote instances having a partial key.


All remote instances have only one partial key of the decryption key each, i.e. all remote instances or a subset of the remote instances are always required to jointly decrypt the encrypted transaction data set. This improves security against misuse, as multiple instances are needed to perform a data access, which is a significant extra effort in an attack scenario.


The partial keys are combined into a common (private) decryption key. This combining is done, for example, in the transaction register. Alternatively, the combining is done in the first participant unit. This combining is done, for example, by addition or by bitwise XORing, which no remote instance can obtain on its own in mere knowledge of the partial key(s). This shared (private) decryption key is then used to decrypt the encrypted transaction data set.


The corresponding public key part of this shared private decryption key is used in the first participant unit for encrypting the generated transaction data set. This public key part can be sent from the transaction register to the participant unit and received there. Preferably, however, the public key is stored in the participant unit, in particular pre-stored, further preferably stored in an alteration-protected manner.


In an alternative embodiment, the cryptographic key for encrypting is a symmetric key, wherein the corresponding private key part for decrypting the transaction data set is composed of at least two cryptographic key parts by an addition operation or a bitwise XOR operation.


This key concept guarantees that no remote instance could bypass all others to decrypt data on its own. In one embodiment, threshold cryptography is used to allow that not all remote instances necessarily have to contribute their partial key, but that a subset of the instances is sufficient to compose the decryption key. The rule is that at least the number of the subset must contribute their respective partial key. If the subset is smaller than a predefined minimum number of remote instances, decryption is not possible.


In a less preferred alternative embodiment, all remote instances (all authorised parties) have a complete set of partial decryption keys for decrypting the encrypted transaction data set. Each remote instance then has a security element, for example a smart card, a TSM, an eUICC, in whose data memory all partial keys are stored. Each of these remote instances is then technically capable of decrypting the encrypted transaction data set on its own, for example as soon as accessing it has been authenticated by a trusted authority, for example a judicial authority after a ruling has been issued. This accessing is only granted by the trusted authority (the transaction register) if this authority/these authorities can produce a legally binding document that depicts a court decision in this regard. This arrangement has the advantage that, in urgent cases, an analysis of possibly relevant transaction data sets could be carried out more quickly with fewer remote instances involved.


In an alternative design, all remote instances generate their own PKI key pair consisting of a private key part and a public key part. The public key parts of the respective key pairs are provided and/or received by the first participant unit. The first participant unit encrypts the generated transaction data set with a first public key part of a first remote instance to obtain a first incompletely encrypted transaction data set. This first encrypted transaction data set is encrypted by the first participant unit with a public key part of a second remote instance to obtain a second encrypted transaction data set. Preferably, this second encrypted transaction data set is encrypted by the first participant unit with a public key part of a third remote instance to obtain a third encrypted transaction data set. The number and/or order of application of the public key parts of the respective remote instance is, for example, fixed throughout the payment system to facilitate subsequent decryption in the transaction register with the corresponding private key parts of the remote instances. Alternatively, at least the order, and in one embodiment also the number, of the application of the public keys of the respective instance is varied and the decryption in the transaction register is carried out via “trial & error”, i.e. a heuristic method in which a decryption order and key selection is searched/tried until the desired decryption takes place, in order to better secure the method.


The encryption methods described here are transparent to ensure user acceptance.


The subsequent step of the method is to initiate a communication link to a transaction register of the payment system to send the encrypted transaction data set to the transaction register. This is an attempt to send the transaction data set to the transaction register. A common communication protocol, such as TCP/IP or a mobile communication, may be used. In the case of a security element, for example, a proactive command is sent to the participant unit.


Initiating represents an attempt to set up or initiate a connection, the termination of which is also a scenario of the method according to the invention. Initiating may also involve the participant unit not attempting to establish a connection, knowing that no connection to the transaction register is possible, for example upon detection of an offline status of the first participant unit, such as “no reception” or “flight mode” or “no credit”. Next, knowing that the connection to the transaction register is impossible, for example by previously querying or checking existing communication options, is considered the same as initiating.


Initiating also includes reading a memory content of a first security element by the first participant unit and sending the read content by the first participant unit.


Initiating also includes reading a memory content of a first security element by the transaction register and receiving the read content in the transaction register.


The transaction register of the payment system is used to archive the encrypted transaction data set. This encrypted transaction data set can be decrypted there, in particular after a request by the authorities, using composed (combined) partial keys of the remote instances and subsequently viewed by the requesting instance (judicial authority, etc.). An inspection for control purposes of every transmitting of an electronic coin data set in the payment system and/or every modification to be registered or every registered modification of an electronic coin data set in the payment system is thus possible, but only technically realisable under very strict conditions.


The official request, for example a court order, contains a participant unit identifier and queries all transactions of this identifier within a determining time period or at a determining time. The metadata of the transaction data set then facilitates the response to this request at the transaction register.


The transaction register can be, for example, a non-public database of the payment system. The encrypted transaction data sets are stored in this database—for possible later verification. The transaction register is designed, for example, as a centrally managed database in the form of a data memory or service server of the payment system.


In a preferred embodiment, the first security element is inserted in the first participant unit ready for use. This ensures that the transaction data sets are generated and encrypted without manipulation and, if necessary, also sent. In one embodiment, the transaction data set is created in the security element and then encrypted by the participant unit.


A security element is a technical resource-constrained device. For example, a security element is a special computer program product, in particular in the form of a secured runtime environment within an operating system of a terminal, in English a Trusted Execution Environments, TEE, or an eSIM software, stored on a data memory, for example a participant unit, such as a (mobile) terminal, a machine or an ATM. Alternatively or additionally, the security element is designed, for example, as special hardware, in particular in the form of a secure hardware platform module, Trusted Platform Module, TPM, or as a smart card or an embedded security module, eUICC, eSIM. The security element provides a trusted environment and thus has a higher level of trust than a terminal in which the security element may be integrated ready for use.


The transmitting of an electronic coin data set is preferably done between two security elements to provide a trusted environment. In this case, the logical transmission of the electronic coin data set is direct, whereas a physical transmission may involve one or more intermediate instances, for example one or more participant units to make the security element(s) operational and/or a remote data storage service where a wallet application containing electronic coin data sets is physically stored.


Security elements can transmit electronic coin data sets between each other and then re-use them directly—without register checking—especially if the payment system assumes that electronic coin data sets of security elements are per se considered valid.


One or more electronic coin data sets may be securely stored in a participant unit or security element, for example, a plurality of electronic coin data sets may be securely stored in a data memory exclusively associated with a participant unit or security element. The data memory then represents, for example, an electronic purse application. This data memory can be, for example, internal, external or virtual to the security element.


The first security element could also have obtained electronic coin data sets from less trustworthy entities, such as participant units, i.e. terminals or machines, for example via an import/export function of the security element. Such obtained electronic coin data sets that were not obtained directly from another security element are considered less trustworthy. It could be a requirement of the payment system to check such electronic coin data sets for validity by means of the coin register or by an action (modification) by the receiving security element to transfer the electronic coin data set to the receiving security element before it is allowed to be passed on.


A transmitting of the electronic coin data set between the first and the second security element may be integrated in a transmission protocol between two participant units and/or integrated in a secure channel between two applications of the respective participant unit. In addition, the transmitting may involve an Internet data connection to an external data memory, such as an online memory.


The electronic coin data set (to be transmitted or modified) is registered in a coin register of the payment system. Thus, for example, for registering the electronic coin data set, a communication link establishment to the coin register is provided. This communication link does not necessarily have to be present during the transmission process (payment process). Preferably, the coin register is provided for managing and checking masked electronic coin data sets. The coin register can additionally manage and check other (non-payment) transactions between participant units.


The coin register is a database in which masked electronic coin data sets are registered with corresponding processing of the masked electronic coin data set. Masking will be explained later. In a preferred embodiment, a validity status of the (masked) electronic coin data set can be derived therefrom. Preferably, the validity of the (masked) electronic coin data set is noted in and by the coin register. Modifications, such as switching, splitting or combining, to the individual electronic coin data sets are recorded in the coin register. Preferably, modifications requested or made or to be made also cause the generating of a transaction data set as described above, which is stored in encrypted form in the transaction register. In this way, the transaction register also serves to archive modifications to a coin data set. This information in the payment system, which may be redundant to the information in the coin register or the monitoring register, increases the stability and security of the payment system.


In one embodiment of the payment system, the registration of the processing or processing steps for a respective modification may also concern the registration of check results and intermediate check results concerning the validity of an electronic coin data set, in particular the determining of check values and counter values of corresponding coin data sets. If a processing is final, this is displayed, for example, by corresponding flags or a derived overall mark in the coin register. Final processing then determines whether an electronic coin data set is valid or invalid.


In a preferred embodiment of the payment system, the registration of check results and intermediate check results concerning a respective modification or transmission process between participant units or their security elements and concerning the validity (in particular for display) of an electronic coin data set, in particular the determining of check values and counter values of corresponding electronic coin data sets, is not performed in the coin register of the payment system but in a monitoring register of the payment system.


In a preferred embodiment of the payment system, the monitoring register is arranged to store anonymised and/or pseudonymised transaction data sets to enable monitoring of transactions during operation of the payment system. The monitoring register is a separate instance of the same payment system from the coin register. By splitting the coin register and the monitoring register within a payment system, the coin register can be less complex and map a simple validity check, while the monitoring register checks the correctness of transmission processes, a possibly required deanonymisation of a participant unit and/or the check of count values or check values of electronic coin data sets. In addition, the coin register does not contain any (or less) confidential or security-critical data due to splitting. Communication—especially from participant units—with the coin register can thus take place without (or only with weak-group keys/shared keys/ . . . ) authentication.


Both the coin register and the monitoring register can, for example, be decentralised public databases. This database makes it possible in a simple way to check electronic coin data sets with regard to their validity and to prevent “double spending”, i.e. multiple spending, without the transmitting itself being registered or logged. The database, for example a distributed ledger technology, DLT, describes a technique for networked computers to come to an agreement on the order of determining transactions and that these transactions update data. It is equivalent to a decentralised management system or database.


Alternatively, the coin register is a centrally managed database, for example in the form of a publicly accessible data memory or a hybrid of a centralised and decentralised database. For example, the coin register and the monitoring register are designed as a service server of the payment system. In a preferred embodiment, the first participant unit sends the encrypted transaction data set to the transaction register. In this case, after initiating, a communication between the participant unit and the transaction register could be successfully established and the encrypted transaction data set could be successfully sent. Subsequently, the first participant unit can locally delete the transaction data set to save storage space.


In a preferred embodiment, the encrypted transaction data set is sent to the transaction register in a cryptographically secure manner. For example, mutual authentication is used between the participant unit and the transaction register. A key exchange is either negotiated in advance as a session key or issued in advance. This additional transport security prevents an attacker from learning that a transaction data set is now being transmitted. This increases the security when transmitting the transaction data set.


In a preferred embodiment, the encrypted transaction data set is stored in the first participant unit if the communication link establishment (after initiating) to the transaction register or the sending of the encrypted transaction data set fails. The storage may be a temporary storage as long as the encrypted transaction data set has not been successfully sent to the transaction register. The stored encrypted transaction data set is thus used for a necessary repetition (RETRY) of the sending in case of connection failures or authentication problems and does not then need to be created and encrypted again.


In a preferred embodiment, the encrypted transaction data set is sent from the first security element to the transaction register as soon as the communication link establishment with the transaction register is successful. A successful connection establishment means, for example, that a communication of data via an established communication channel is enabled, i.e. the communication channel between the transaction register and the participant unit has been established. This keeps the transaction register up to date with regard to completed/scheduled transmitting, and recent transactions are promptly archived in the transaction register. Furthermore, the transmission is prioritised in case no connection to the transaction register was available at the time of the transmission of the coin data set and the participant unit or its security element is instructed to promptly send the encrypted transaction data set to the transaction register if a communication link is (detected) available. In a preferred embodiment, the electronic coin data set is transmitted from the first participant unit to the second participant unit. The transmitting occurs, for example, immediately before the generating step, such that the transaction data set relates to a coin data set to be transmitted. The transmitting occurs, for example, immediately after the generating step but before the encrypting step, so that the transmitting could be part of the atomic operation described above and only the entire generate-transmit-encrypt chain can be executed. This avoids differences between the generated transaction data set and the actual transmitted coin data set. For example, transmitting takes place immediately after the encrypting step and before the initiating step, so that the transaction data set concerns a coin data set to be transmitted. For example, transmitting occurs immediately after the initiating step so that the transaction data set concerns a coin data set that has already been transmitted.


For transmitting the electronic coin data set to the second participant unit, a data connection to other instances of the payment system is not mandatory. In order to make a transmission protocol secure, the electronic coin data sets are, for example, managed by security elements within the respective participant units and also transmitted through them. In an (offline) transmission environment, it is important that transmission errors or conflicts can be resolved without intermediary central instances of a payment system, such as the coin register or monitoring register. A transmission protocol can ensure that a transmission process (payment process), although executed asynchronously, is trusted by checking the presence of a receive message and using security elements. A two-step transmitting (sending, then deleting) is preferred to ensure that monetary amounts are not destroyed nor duplicated while active.


In a preferred embodiment, the generated transaction data set is stored, preferably non-volatile, in the first participant unit. The storage may be a temporary storage as long as the electronic coin data set has not been successfully transmitted to the second participant unit. In this case, the storage is local. The transaction data set can be used to repeat the transmission process between the participant units in case of a faulty transmission. No changes have to be made to the coin data set or the transaction data set itself. The stored transaction data set thus serves for a necessary repetition (RETRY) of the transmission in case of connection errors or authentication problems during the transmission.


In addition or alternatively, the stored transaction data set is used for reversal (ROLLBACK) in case of failed transmission of the coin data set. Thus, the method provides both a settlement procedure and a retry procedure to be able to reverse or retry the transaction in case of a transmission error event where the transmitting of the coin data set was not completed.


This completes or completely undoes the transmitting in the event of a retransmission.


In a preferred embodiment, in a transmission error event, the stored transaction data set is used to resend the electronic coin data set. It is assumed that the transmitting of the electronic coin data set has failed, but the transmitting process is still to be completed. The transmitting of the electronic coin data set is promptly repeated. The electronic coin data set to be retransmitted is the same as the electronic coin data set that had a transmission error event during transmission. Therefore, no changes to the coin data set are required for the resend. In one embodiment, another transaction data set is generated for logging purposes.


A transmission error event is assumed, for example, if a confirmation of receipt has not been received in the first security element within a predefined period of time. For this purpose, for example, a timer is started, preferably the timer is started during the sending step of the electronic coin data set.


The transmission error event can alternatively or additionally be displayed by an error message of the first or the second security element. This explicitly displays the error case. The transmission error event can also be assumed by a detected connectivity failure (connectivity failure). This implicitly displays the error case.


The transmission error event can also occur due to authentification failure (connectivity failure).


The transmission error event can also occur due to the shutdown of a terminal (device shutdown) in which one of the security elements is inserted ready for use, or due to exceeding the transmission distance (exceeded distance) due to a movement of a subscriber.


The transmission error event can also occur due to an internal error (internal error) in the first or second security element, in an application of the terminal, or in the respective terminal, for example due to a storage error or lack of memory. In a preferred embodiment, the first security element polls the second security element at predefined periodic intervals and actively requests an acknowledgement of receipt, alternatively also when a time value of a timer is exceeded.


In a preferred embodiment, after the transmitting step, successful transmitting is displayed in the first participant unit. A user display can be updated or the monetary amount can be deleted from a list of available monetary amounts. This display indicates to a participant (user) in the payment system that the transmission process was successful. In addition or alternatively, an available monetary amount is updated, in particular reduced according to the transmitted monetary amount.


In a preferred embodiment, the electronic coin data set is evaluated as an input parameter of an application of the first participant unit in the display step. The transaction data of this electronic coin data set thus actively controls the transmission process irrespective of an application that is inserted executably in the first participant unit. Changes to the electronic coin data set are visualised for a user by the application on the first participant unit, the user thus obtaining prompt feedback on the validity/status of the electronic coin data set to be transmitted/that is transmitted.


In a preferred embodiment, the transmitting step is not executed until a checking step determines that a check value for a number of transmissions to the second participant unit or to one or more other participant units is below or equal to a predefined threshold value in the event of a failed communication link establishment to the transaction register or a failed transmission of the encrypted transaction data set to the transaction register. This limits the number of transmissions of coin data sets from the first participant unit to a maximum value if no transmission of the respective transaction data set to the transaction register has occurred or could occur in the meantime. This forces the first participant unit to always check whether a threshold value, for example 100, more preferably 50, more preferably 10 transmissions, ideally 5 transmissions, has been reached.


In a preferred embodiment, if a predefined threshold value of a check value for a number of transmissions to the second participant unit or to one or more further participant units is exceeded in the event of a failed communication link establishment to the transaction register or a failed transmitting of the encrypted transaction data set to the transaction register, a transmitting of the encrypted transaction data set and/or of a stored transaction data set to the transaction register must take place before the electronic coin data set is transmitted. This limits the number of transmissions of coin data sets from the first participant unit to a maximum value if no transmitting of the respective transaction data sets to the transaction register has or could take place in the meantime. This forces the first participant unit to send the encrypted transaction data sets. Transmitting coin data sets is prevented until the transaction data sets have been successfully sent. The threshold value is for example 100, more preferably 50, more preferably 10 transmissions, ideally 5 transmissions.


In a preferred embodiment, if the transmission of the electronic coin data set is successful and the communication link establishment to the transaction register fails or the encrypted transaction data set is sent to the transaction register, a check value is incremented in the first participant unit. In this way, the check value to be checked is always up-to-date with respect to transmitted coin data sets whose corresponding transaction data set has not yet been transmitted from the participant unit to the transaction register.


In a preferred embodiment, the method comprises the further steps of: Masking the electronic coin data set by applying a homomorphic one-way function to the electronic coin data set to obtain a masked electronic coin data set and registering the masked electronic coin data set in a coin register of the payment system, the registering preferably being for switching, splitting or connecting masked electronic coin data sets. This allows modifications to the coin data set to be tracked and documented in the coin register without removing anonymity in the payment system. Masking will be explained later.


The task is also solved by a previously described participant unit. The participant unit has a computing unit which is arranged to execute the method described here. The participant unit also has means for accessing a data memory, at least one electronic coin data set being stored in the data memory. The participant unit further comprises an interface arranged for establishing a communication link establishment to a transaction register for sending an encrypted transaction data set to the transaction register.


The task is further solved by a method in a transaction register for saving encrypted transaction data sets of a payment system, comprising the method steps of: receiving an encrypted transaction data set from a first participant unit, the received encrypted transaction data set having been generated and encrypted by the method described above; and storing the encrypted transaction data set in a memory range of the transaction register.


The task is further solved by a method for saving encrypted transaction data sets of a payment system comprising the method steps: Generating, from a first participant unit, a transaction data set with respect to transmitting the electronic coin data set to a second participant unit, preferably a second security element, or with respect to a modification of the electronic coin data set to be registered at the coin register; encrypting, by the first participant unit, the generated transaction data set with a cryptographic key, the cryptographic key being composed of at least two cryptographic keys, preferably at least three cryptographic keys, of respectively different remote instances, sending the encrypted transaction data set to a transaction register; receiving an encrypted transaction data set, the received encrypted transaction data set having been generated and encrypted in particular by the method described above; and storing the encrypted transaction data set in a memory range of the transaction register.


In a preferred embodiment, storing in the transaction register is limited in time to a predefined period of time. This time period starts, for example, at the time of receiving the encrypted transaction data set in the transaction register or is started by a transaction time attached as a metadata to the encrypted transaction data set. This time period is, for example, a legal requirement, i.e. a minimum or maximum time period for saving the transaction data set, for example in the context of a data retention, for example X months or Y years.


In a preferred embodiment, the method comprises the further step of decrypting the encrypted transaction data set with a cryptographic key, wherein the key for decrypting the encrypted transaction data set is composed of at least two cryptographic partial keys of respective different remote instances in the transaction register.


In a preferred embodiment, the composing is performed by an addition operation or a bitwise XOR operation.


In a preferred embodiment, the cryptographic key for decrypting the encrypted transaction data set is composed of a predefined number of cryptographic partial keys of different remote instances, the predefined number being less than the total number of different instances.


In a preferred embodiment, decryption is performed only upon external request. This request may be the result of an investigative process to verify whether a transaction has actually occurred.


In a preferred embodiment, the transaction register has a hardware security module, HSM for short, whereby the hardware security module is a secure key store in which different generations of the partial keys of the respective remote instances are saved. In this way, partial keys of individual remote instances can be renewed or exchanged without having to re-encrypt the encrypted transaction data sets stored up to that point or even having to remain undecryptable in the transaction register. The key generations are preferably kept up to date by an HSM of the transaction registry.


In a preferred embodiment, the transaction register has a hardware security module to which the various instances authenticate themselves before decrypting the stored encrypted transaction data set. The HSM can thus fulfil various functions; it is primarily a secure key store and a secure processing unit. For example, the HSM module may contain different key generations of the partial keys, with the remote instances authenticating themselves to the HSM to enable decryption with all generations.


In a preferred embodiment, after receiving the encrypted transaction data set from the first participant unit, the encrypted transaction data set is re-encrypted. This means that the encrypted transaction data set is always re-encrypted (i.e. decrypted and newly encrypted) when it is received, thus avoiding transaction data sets being stored in the transaction register in different encrypted form. This simplifies the administration of the encrypted transaction data sets in the transaction register.


Alternatively, after receiving an updated partial key from one of the instances, the encrypted transaction data set is re-encrypted. This prevents transaction data sets from being stored in the transaction register in different encrypted form when the key of an instance is changed.


In a preferred embodiment, after receiving the encrypted transaction data set from the first participant unit, the encrypted transaction data set is decrypted and an identifier of a (first and/or second) participant unit is replaced by a pseudonym in the transaction data set to obtain a decrypted pseudonymised transaction data set. In one embodiment of the method, storing the received encrypted transaction data set is unaffected.


In a preferred embodiment, an identifier of a participant unit (for example, participant ID of a terminal) in the payment system is uniquely assigned to a natural person. This personal allocation is carried out, for example, by an issuing instance of the payment system or a banking instance of the payment system and may also be managed there. This personal allocation can also be managed by a service instance, for example an instance that provides a wallet application for the terminal or that provides online access to a cloud wallet. This assignment of person to identifier is only carried out by the respective instance after the person has been successfully identified, for example by presenting an official identification document such as an identity card or passport.


In a preferred embodiment, after receiving the encrypted transaction data set from the first participant unit, the encrypted transaction data set is decrypted and a monetary amount of an electronic coin data set is replaced by one or more amount categories in the transaction data set to obtain a decrypted amount-categorised transaction data set. For example, an amount category is an amount range (from-to) in which the monetary amount of the coin data set lies. For example, an amount category is a rounded amount value of the monetary amount, either up or down. In one embodiment of the method, storing the received encrypted transaction data set is unaffected.


In a preferred embodiment, the decrypted pseudonymised or decrypted amount-categorised transaction data set is sent to a monitoring register of the payment system and stored there. In this way, anonymised or pseudonymised transaction data sets can be stored in the monitoring register, thereby enabling monitoring of transactions during operation.


When pseudonymised transaction data sets are created, an anonymity level is changed for the respective transaction data set. The pseudonymised transaction data set always has a higher level of anonymity than the (non-pseudonymised) transaction data set. With this higher anonymity level, the pseudonymised transaction data set—in a default of the payment system—can also be stored unencrypted in the register instances (coin register, monitoring register, transaction register) and used for further validity checks in the payment system. This could improve the detection of cases of fraud or manipulation in the payment system by the payment system itself; a request by the authorities (court order) may then not be necessary.


An anonymity level of a data record reflects a degree of anonymity of the (coin or transaction) data record, i.e. a possibility of assigning a constant identity, such as participant identifier, ID number, natural person, etc., to a data record. Preferably, a distinction is made between several levels, for example 3 levels, in the method: completely anonymous (level 1), pseudonymous (level 2) or non-anonymous (level 3). The aim of the payment system is to transmit monetary amounts anonymously (level 1), i.e. it should not be possible for a participant in the payment system—similar to analogue cash—to infer the constant identity of the participant on the basis of a received coin data set. For law enforcement, however, it is important to be able to assign a constant identity to a coin data set without any doubt. Therefore, the generated transaction data sets are not anonymous (level 3), i.e. they are clearly assigned to a constant identity, for example a participant identifier, which can lead to a natural person via a person assignment.


A mixed form is a pseudonym (level 2). This is the temporary or permanent assignment of a derived identity to a data record. The derivation is generated, for example, in a trusted instance such as a monitoring register.


A participant identifier in the encrypted transaction data set preferably has a level 3 anonymity, so that decrypting the transaction data set displays the constant participant identifier.


A monetary amount in the encrypted transaction data set preferably has a level 3 anonymity such that decrypting the transaction data set displays the exact amount.


In a preferred embodiment, the anonymity level of a participant identifier in the transaction data set is different from an anonymity level of an amount category, so that mixed forms (different levels) can be present in a pseudonymised transaction data set.


The task is also solved by a transaction register for a payment system. The transaction register has a computing unit which is arranged for executing the method of the method described above in a transaction register. The transaction register also has means for accessing a data memory, at least one encrypted transaction data set being stored in the data memory. The transaction register further comprises an interface arranged to communicate with a participant unit to receive an encrypted transaction data set from the participant unit.


Preferably, the system comprises means for executing the generating step and the encrypting step of the method described above. The encrypted transaction data set may be sent to a transaction register.


In a preferred embodiment, the transaction register further comprises: a hardware security module arranged for securely saving partial keys of different generations; and decrypting encrypted transaction data sets.


In a preferred embodiment, the transaction register HSM is arranged for decrypting encrypted transaction data sets; replacing a participant unit identifier with a pseudonym in the transaction data set to obtain a decrypted pseudonymised transaction data set.


In a preferred embodiment, the HSM of the transaction register is arranged for decrypting encrypted transaction data sets and replacing a monetary amount of an electronic coin data set with an amount category in the transaction data set to obtain a decrypted amount-categorised transaction data set.


In a preferred embodiment, the interface is arranged to send the decrypted pseudonymised or the decrypted amount categorised transaction data set to a monitoring register of the payment system.


The task is further accomplished by a payment system comprising at least one previously described participant unit, the participant unit being arranged for executing the previously described method in a first participant unit; and a previously described transaction register, the transaction register being arranged for executing the previously described method in a transaction register.


In a preferred embodiment, the payment system further comprises an issuing instance arranged to create an electronic coin data set for the payment system; and/or a coin register arranged to register a masked electronic coin data set, the registering preferably being for switching, splitting or connecting masked electronic coin data sets; and/or a monitoring register arranged for receiving a pseudonymised masked electronic coin data set from the participant unit or for receiving a decrypted pseudonymised or decrypted amount categorised transaction data set from the transaction register.


Preferably, the payment system is also arranged to manage electronic coin data sets from further issuing instances and/or monetary amounts as book money.


In an advantageous embodiment, the electronic coin data set comprises a monetary amount, i.e. a datum representing a monetary value of the electronic coin data set, and an obfuscation amount, for example a random number. In addition, the electronic coin data set may have further metadata, for example which currency the monetary amount represents. An electronic coin data set is uniquely represented by these at least two data (monetary amount, obfuscation amount). Anyone who has access to this data of an electronic coin data set can use this electronic coin data set for payment. Knowing these two data (monetary amount, obfuscation amount) is therefore equivalent to owning the digital money. This electronic coin data set can be transmitted directly between two participant units. In one embodiment of the invention, only the transmission of the monetary amount and the obfuscation amount is necessary to exchange digital money. In one embodiment, a status (active, inactive) of the electronic coin data set is also added to the coin data set so that it then consists of three data (monetary amount, obfuscation amount, status). Alternatively, the status of a coin data set is not added to the coin data set and is only kept in the security element itself and/or the coin register.


In a preferred embodiment, a corresponding masked electronic coin data set is associated with each electronic coin data set in the respective method. Knowledge of a masked electronic coin data set does not authorise the issuance of the digital money represented by the electronic coin data set. This represents a key difference between masked electronic coin data sets and (non-masked) electronic coin data sets. A masked electronic coin data set is unique and also uniquely associated with an electronic coin data set, so there is a 1-to-1 relationship between a masked electronic coin data set and a (non-masked) electronic coin data set. The masking of the electronic coin data set is preferably performed by a computing unit of the participant unit. The participant unit has at least one electronic coin data set. Alternatively, masking may be performed by a computing unit of a participant unit receiving the electronic coin data set.


This masked electronic coin data set is obtained by applying a homomorphic one-way function, in particular a homomorphic cryptographic function. This function is a one-way function, i.e. a mathematical function that is “easy” to compute in terms of complexity theory, but “difficult” to practically impossible to reverse. In this context, one-way function also refers to a function for which no inversion is known that can be practically executed in a reasonable amount of time and with a reasonable amount of effort. Thus, the calculation of a masked electronic coin data set from an electronic coin data set is comparable to the generation of a public key in an encryption procedure via a residue class group. Preferably, a one-way function is used that operates on a group in which the discrete logarithm problem is difficult to solve, such as a cryptographic method analogous to an elliptic curve cipher, or ECC, from a private key of a corresponding cryptographic method. The reverse function, i.e. generating an electronic coin data set from a masked electronic coin data set, is thereby—equivalent to generating the private key from a public key in an encryption procedure over a residue class group—very time-consuming. In the present document, when sums and differences or other mathematical operations are mentioned, they are to be understood in the mathematical sense of the respective operations on the corresponding mathematical group, for example the group of points on an elliptic curve.


The one-way function is homomorphic, i.e. a cryptographic method that has homomorphism properties. Thus, mathematical operations can be performed on the masked electronic coin data set that can also be performed in parallel on the (non-masked) electronic coin data set and thus be traced. Using the homomorphic one-way function, calculations with masked electronic coin data sets can be traced in the coin register and/or the monitoring register without the corresponding (non-masked) electronic coin data sets being known there. Therefore, certain calculations with electronic coin data sets, for example for processing the (non-masked) electronic coin data set (for example splitting or connecting), can also be determined in parallel with the corresponding masked electronic coin data sets in the coin register, for example for validation checks (=validities). In addition, parallel proof of the legitimacy of the respective electronic coin data set can be provided in the monitoring register. The homomorphism properties apply at least to addition and subtraction operations, so that a switching (=switching), splitting (=splitting) or combining (=connecting) of electronic coin data sets is also recorded in the monitoring register by means of the correspondingly masked electronic coin data sets in the coin register or the check whether the electronic coin data set is to be returned (deleted) or recoined and is verified by the requesting participant units or by the security elements of the participant units and/or by the coin processing system. The coin register and/or the monitoring register shall be able to retrace the electronic coin record without knowledge of the monetary amount and the performing participant unit.


The homomorphism property thus allows an entry of valid and invalid electronic coin data sets based on their masked electronic coin data sets to be kept in a coin register and a monitoring register without knowledge of the electronic coin data sets, even if these electronic coin data sets are processed (split, connected, switched) or directly transmitted, i.e. an action is performed on these electronic coin data sets. This always ensures that no additional monetary amount has been created or that an identity of the participant units or their security elements is recorded in the coin register or monitoring register. Masking allows a high level of security without revealing the monetary amount or the participant unit.


When transmitting an electronic coin data set directly from the first participant unit to a second participant unit, two participant units have simultaneous knowledge of the electronic coin data set to be transmitted. It is important to prevent the sending first participant unit from also using the electronic coin data set at another (third) participant unit for payment (so-called double spending). Before transmitting, a status of the electronic coin data set can be set to inactive status to invalidate the electronic coin data set, then transmitting (as the first step of transmitting) to the second participant unit takes place, and if there is an acknowledgement of receipt from the second participant unit, deletion of the electronic coin data set in the first participant unit takes place (as the second step of transmitting). A deletion confirmation from the first participant unit may be sent to the coin register or the second participant unit to display a successful deletion (performed in the first participant unit) of the electronic coin data set.


In addition, the transmitted electronic coin data set can be switched (=switch) from the first participant unit to a second participant unit. Preferably, the switching can be done automatically upon receiving the cancellation confirmation of an electronic coin data set in the second participant unit. In addition, it may also occur upon request, for example, a command from the first participant unit and/or the second participant unit. Additionally, an electronic coin data set can also be split (“Split”) into at least two electronic coin data sets. Additionally, two electronic coin data sets can be connected to one electronic coin data set (“Merge”).


Switching, splitting and connecting are different modifications to an electronic coin data set, i.e. actions with the electronic coin data set. These modifications require registering the masked coin data set in the coin register of the payment system. The actual execution of the individual modifications will be explained later.


Switching also occurs when an electronic coin data set has been modified, for example split or connected to other electronic coin data sets, especially in order to be able to settle a monetary amount to be paid appropriately.


This pseudonymisation is explained in more detail below: The transmitting of electronic coin data sets in the payment system is anonymous as long as the anonymity is not to be explicitly removed by additional measures. It could be a requirement in the payment system to remove anonymity depending on a value for monetary amounts. In other words, a typical requirement in the payment system could be to send monetary amounts anonymously below a determining threshold. If this limit is exceeded, the transmitting in the system is de-anonymised.


In a preferred embodiment, the method comprises the further steps of: masking the electronic coin data set by applying a homomorphic one-way function to the electronic coin data set to obtain a masked electronic coin data set; associating the masked electronic coin data set with a pseudonym to obtain a pseudonymised masked electronic coin data set; and sending the pseudonymised masked electronic coin data set to a monitoring register of the payment system. In this way, modifications to the electronic coin data set are tracked in the coin register and documented in the monitoring register under a pseudonym, without removing any anonymity in the payment system. The monitoring register can thus identify the outgoing transactions at the participant unit even if the affiliation of the pseudonym and participant unit is known.


In the above-mentioned method according to the invention, the pseudonymised masked electronic coin data set is preferably inserted into the transaction data set in the generating step by the first participant unit, further preferably instead of the masked electronic coin data set, and is thus sent to the transaction register in encrypted form. Later decryption also reveals the pseudonym under which the transaction took place.


This method is an alternative to providing the transaction register with pseudonymised transaction data as described above and could be used in parallel or in addition to this method in the monitoring register. The selection of the respective pseudonymisation method can be set flexibly in the payment system and adapted to the actual requirements of the payment system, for example to the computing power of the transaction register or the monitoring register or a transmission capacity in the payment system.


Since a digital payment transaction (the transmission of electronic coin data sets) of a large monetary amount could also be split into several digital payment transactions of smaller monetary amounts, each of which may be below the threshold, the threshold must be participant unit-specific and/or time period-dependent. Moreover, due to the non-transparent multiple (direct) transmission of a coin data set between a multitude of different participant units, this requirement for de-anonymisation, also called re-identification, is not directed at individual transmissions (transactions) between two participant units, but usually concerns the sum of all transactions within a determining time unit (duration) that are received and/or transmitted by a participant unit. A mechanism is therefore provided to determine what the sum of all monetary amounts sent or received by a participant unit is within a given unit of time. For this purpose, a method is described that enables the de-anonymity of a sending participant unit when exceeding a limit value per time unit.


To enable such a mechanism for de-anonymisation, in a preferred embodiment of the method, pseudonymisation is performed. For this purpose, a linking step is performed before the masking step in order to associate a pseudonym of the first participant unit with the electronic coin data set. The pseudonym is preferably participant unit-specific. A pseudonym is any type of disguised identity that allows direct inference to be made, not in mere knowledge of the electronic coin data set, to the participant unit and the transactions performed therewith.


The participant unit must make a modification (splitting, switching, connecting) for each coin data set received in order to associate the pseudonym with the coin data set. The registration in the coin register associated with each modification (for validating the modification) is sufficient to uniquely associate all coin data set transactions made with the participant unit to that participant unit based on the associated pseudonym. A monitoring register, knowing the association of the pseudonym and the participant unit, can identify the transactions received by the participant unit.


Thus, modifications to the electronic coin data set are associated with a pseudonym stored on the participant unit. This pseudonym can be either permanent or valid only for a determined time period.


The difference between an anonymous masked electronic coin data set and a pseudonymised masked electronic coin data set is thus the identifiability of the participant unit by the monitoring register when it uses the pseudonym. An anonymous masked electronic coin data set does not contain any information about its origin, so it cannot be connected to a participant unit. In contrast, a pseudonymised masked electronic coin data set has an association with a pseudonym of the participant unit, so that the participant unit that sent the pseudonymised masked electronic coin data set to the monitoring register can be identified by the associated pseudonym.


The mechanism described is sufficient to determine whether the sum of the monetary amounts of all transactions of a participant unit are below a threshold value, preferably within a certain time unit. If it is detected that the threshold is exceeded by a desired modification, the monitoring register could promptly prevent such modification by blocking or rejecting the registration of the corresponding electronic coin data set in the coin register. Alternatively or additionally, the participant unit could be informed that the modification (and thus the transaction) would only be carried out if the participant unit de-anonymises itself, e.g. discloses personal access data, before the modification is registered and the electronic coin data set is set to valid, thereby accepting the transaction.


In a preferred embodiment of masking, sending the pseudonymised masked electronic coin data set instead of an anonymous masked electronic coin data set reduces the number of range confirmations or range proofs that the monitoring register requests from the first participant unit.


The monitoring register, the coin register and/or the first participant unit may process the masked electronic coin data sets in an anonymous or in a pseudonymous mode. In an anonymous mode, the monitoring register requests necessary and further (catch-up) range proofs or range confirmations. In pseudonymous mode, the monitoring register does not request at least one of the further range proofs or range confirmations, but checks for the pseudonym whether a (catch-up) criterion is fulfilled. An electronic coin data set can already be treated as valid if the necessary checks have been made. Only when the (catch-up) criterion is fulfilled are range proofs or a cumulative range proof (or confirmation) requested from the participant unit. For example, a time period or a number of masked electronic coin data sets can be used as (catch-up) criteria for the pseudonym.


In a further preferred embodiment of pseudonymisation, the first participant unit receives a request for a sum range confirmation or a sum range proof from the monitoring register, and sends the requested sum range confirmation or the requested sum range proof to the monitoring register.


In an alternative embodiment, the first participant unit generates an unsolicited aggregate range confirmation or an unsolicited aggregate range proof, and sends the unsolicited aggregate range confirmation or the requested aggregate range proof to the monitoring register.


A sum range confirmation or a sum range proof is an indication by the participant unit of a sum of monetary amounts of a plurality of electronic coin data sets, preferably electronic coin data sets transmitted directly between participant units. This sum information is compared with a range information in the monitoring register. If the range is exceeded, the electronic coin data sets are de-anonymised in order to secure or control the transmitting of large monetary amounts.


Preferably, the first participant unit forms a sum of monetary amounts of several electronic coin data sets and confirms with the sum range confirmation that the formed sum is within a range. The sum range confirmation is understood in the monitoring register as a display of the participant unit and the participant unit is considered trustworthy.


In an alternative embodiment of pseudonymisation, the first participant unit creates a sum range proof for several electronic coin data sets that can be verified by the monitoring register. The sum range is thus then checked by the monitoring register and confirmation is made there that the sum is in range (or not). The sum range proof is preferably also part of the transaction data set for the transaction register.


In a preferred embodiment of pseudonymisation, the multiple electronic coin data sets comprise only selected electronic coin data sets. Thus, the sum range confirmation or sum range proof is not performed for all electronic coin data sets of the participant units, but only for a targeted selection. In one embodiment, the selection only concerns electronic coin data sets of sent pseudonymised masked electronic coin data sets. In an alternative embodiment of masking, only electronic coin data sets from sent anonymous masked electronic coin data sets or sent pseudonymised masked electronic coin data sets are affected. In an alternative embodiment of masking, only electronic coin data sets from sent anonymised masked electronic coin data sets, sent pseudonymised masked electronic coin data sets and/or masked electronic coin data sets not sent to the monitoring register are affected. In a preferred embodiment of the pseudonymisation process, the multiple electronic coin data sets are selected according to a pre-selected time period as a selection criterion. The time period may be selected to be a day, a week, or a much lesser time period.


This selection is preferably masked and then sent to the transaction register in encrypted form as part of the transaction data set.


In an alternative or additional embodiment of pseudonymisation, a list in the first participant unit or monitoring register is to be used as the selection criterion, based on which list the electronic coin data sets are selected.


This list is preferably masked and then sent to the transaction register in encrypted form as part of the transaction data set.


In a preferred embodiment of pseudonymisation, the monitoring register requests range confirmations or range proofs from participant units as part of a summary check. Preferably, the monitoring register applies a first sum check mode for anonymous masked electronic coin data sets.


Preferably, the monitoring register applies a second sum check mode for pseudonymised masked electronic coin data sets.


In a preferred embodiment of pseudonymising, the monitoring register checks a range proof for each modified electronic coin data set received.


In a preferred embodiment of pseudonymisation, the monitoring register requests range confirmations or range proofs from participant units on a regular or quasi-random basis. This is done, for example, in the first sum check mode.


In an alternative or additional embodiment of pseudonymisation, the monitoring register requests a range confirmation or range proof from the participant unit only after a number of coin data sets have been received for a pseudonym. This is done, for example, in the second sum check mode. This number is preferably dependent on the subscriber unit type and/or the coin amount range. In this way, the range proofs or range confirmations can be flexibly adapted to a specific user situation and thus increase the security of the payment system.


In principle, identifying the outgoing transactions or the incoming transactions is sufficient, so that in one embodiment masking the electronic coin data set and associating the masked electronic coin data set in the second participant unit with a pseudonym of the second participant unit in the second participant unit and sending the pseudonymised masked electronic coin data set to the monitoring register is not performed.


These identified outgoing transactions are preferably sent to the transaction register in encrypted form as part of the transaction data set.


The associating step of pseudonymising is preferably performed by signing the respective masked electronic coin data set in the second participant unit with a private signature key of the second participant unit for obtaining a signed masked electronic coin data set as a pseudonymised masked electronic coin data set or as a pseudonymised masked transmitted electronic coin data set.


The signing is done with a private signature key of the participant unit. This signature key is preferably participant unit-specific, i.e. knowing the verification key, it can be traced who last modified (switched, split, connected) the coin data set. The signed masked electronic coin data set is registered in the monitoring register.


In the above-mentioned method according to the invention, the signed masked electronic coin data set is preferably inserted into the transaction data set in the generating step by the first participant unit, further preferably instead of the masked electronic coin data set, and thus sent to the transaction register in encrypted form. A subsequent decryption then also reveals the signature under which the transaction took place.


To generate a signature, an asymmetric cryptosystem is thus preferred, in which the participant unit calculates a value for a data record using a secret signature key, referred to here as a private signature key or “private key”. This value allows anyone to verify the authorship and integrity of the record using a public verification key, the “public key”.


Preferably, with the step of registering, there will be a verification of the signature in the monitoring register, with the monitoring register having the public verification key of the signature for this purpose. The signature can now be verified by the monitoring register by having a public verification key of the signature known there.


The public verification key for checking the signature is preferably only known to the monitoring register, whereby the method remains anonymous for the participant units among themselves.


Preferably, the coin register registers any modification, i.e. switching, splitting and/or connecting together with the signature of the participant unit. In this way, monitoring and determining the sum of monetary amounts for all transactions of a participant unit can be done by the coin register and/or the monitoring register. For example, the signature is part of the transaction data set and is sent to the transaction register either in encrypted form or also in plain text and stored (archived) there.


Preferably, the signature is valid within a determining time unit, the determining time unit preferably being a day. Thus, for this determining time unit, the transaction volume (=sum of monetary amounts in transactions) per participant unit can be checked.


Each participant unit thus has an asymmetric key pair to sign each modification with the private signature key. The public key is known to the monitoring register (and also to the coin register). Thus, the monitoring register can associate each transaction with the participant unit as the sender or recipient of the coin data set.


The mechanism described is sufficient to detect (measure) whether the sum of all monetary amounts per participant unit (=transactions) is within a limit per time unit, for example a daily limit.


The following explains the detection of return criteria for already issued coin data sets, for example that a coin data set is to expire:


The electronic coin data sets are issued by a central issuing instance, whereby each electronic coin data set additionally has a check value. The check value is incremented when the electronic coin data set is transmitted directly between two participant units, or the check value is invariant to an action (modification) performed by participant units on the electronic coin data set. The method comprises the step of: determining by the participant unit, based on the check value of an electronic coin data set, whether the electronic coin data set is displayed by the participant unit to the payment system or determining by the participant unit, based on the check value of the electronic coin data set, whether the electronic coin data set is returned to the central issuing instance. Thus, in a preferred embodiment, the check value for unsent transaction data sets mentioned above or another check value is also used to determine whether the electronic coin data set is displayed by the first participant unit to the payment system, in particular a coin register, and/or whether the electronic coin data set is returned to the central issuing instance.


Each check value of the electronic coin data set is used in the method to enable or enhance a control function in the payment system. Each check value is preferably a data element of the electronic coin data set that can be read by the participant unit or a data element in the participant unit and its value can be determined by the participant unit. The return criteria check value is linked to an electronic coin data set.


In a first embodiment, the check value for the return criteria is incremented (=increased stepwise) when the electronic coin data set is transmitted directly between two participant units. The incrementing is either incremented by a sending participant unit immediately before the coin data set is sent to a receiving terminal. Or the incrementing is done in a receiving participant unit immediately after receiving the coin data set. Thus, the number of direct transmissions between participant units is recorded for each coin data set.


In a second (alternative to the first) embodiment, the check value is invariant to an action performed by participant units with the electronic coin data set (action invariant). Action invariant means that the check value is obtained unchanged during an action with the coin data set. The action invariant check value is not individual to the electronic coin data set, but group specific and therefore applies to a plurality of different coin data sets to maintain anonymity and prevent coin data set tracking.


As an action with a coin data set any modification made to the coin data set by a terminal, i.e. in particular switching, splitting, combining, will be described later. In addition, any transmitting of the coin data set, for example to a (different) participant unit or also to an instance in the payment system, is meant as an action. In addition, an action means redeeming the coin data set to credit a monetary amount of the coin data set or changing the currency system. These actions are performed by participant units and do not change the check value.


The check value of the electronic coin data set is used by the participant unit to determine whether this electronic coin data set is displayed (=reported) to the payment system. For example, if the number of transmissions between participant units exceeds a predefined threshold value, the electronic coin data set is displayed to the payment system. In an exemplary embodiment of the method, displaying corresponds to sending a switching command to a coin register of the payment system to cause switching of the coin data set to the participant unit sending the coin data set. In an alternative exemplary embodiment of the method, the display causes the coin data set to be marked in a monitoring register of the payment system. The check value and/or the coin data set may, but need not, be transmitted to the payment system for the purpose of display. The return of the electronic coin data set by the participant unit requires either the redemption of a monetary amount associated with the electronic coin data set or the issuance of a new electronic coin data set with an identical monetary amount.


The return of the electronic coin data set by the participant unit may trigger a reset or deletion of all existing entries for the electronic coin data set in the monitoring register in the payment system. This deletes digital traces of the electronic coin data set and ensures the anonymity of the method.


Alternatively, the check value of the electronic coin data set is used by the participant unit to determine whether the electronic coin data set is returned to the central issuing instance. Thus, the check value can be used to define a criterion for the return of an electronic coin data set. In this way, electronic coin data sets can be expired, for example, based on their lifetime or the number of actions performed with the coin data set, in order to increase the security at the payment system.


In a preferred embodiment, the electronic coin data set is returned to the central issuing instance as a result of being displayed by the payment system (the monitoring register). The display to the payment system thus determines in the payment system whether the coin data set is to be returned. In this embodiment, determining whether a return must be made is performed in the payment system instead of the participant unit. The result of the determining is communicated to the participant unit and the participant unit is requested by the payment system to return the electronic coin data set.


In a preferred embodiment, the payment system (the monitoring register) requests modification of the electronic coin data set as a result of the display. Modifying, for example splitting, combining or switching, requires registering the electronic coin data set in the payment system. In many embodiments of the digital currency system, a return to the issuing instance is not necessary and sometimes not useful. This is especially true if the coin data set was modified quickly after it was issued. In this embodiment, the coin data set is not returned, but it is considered returned.


In a preferred embodiment, a counter value in the payment system (the monitoring register) relating to that electronic coin data set is determined as a result of being displayed by the payment system using the check value of the electronic coin data set. The check value of the coin data set is preferably transmitted from the participant unit to the payment system (the monitoring register). The counter value is not part of the coin data set. Preferably, the counter value is managed in the payment system. Preferably, the counter value is incremented with each action (modification, transmission, redemption) concerning the electronic coin data set. Preferably, the counter value is increased with different weighting for different actions. This makes it possible to control the return in an improved way according to different actions. Thus, in the coin data set, the check value is provided as a data element that is incremented, in particular, with each direct transmission between participant units. The counter value in the payment system incorporates the check value, for example by adding the previous counter value to the check value.


In a preferred embodiment, each electronic coin data set has a first check value and a second check value. The first check value is then incremented accordingly when the electronic coin data set is transmitted directly between two participant units, the first check value of the electronic coin data set being used to determine whether the electronic coin data set is displayed by the participant unit at the payment system. At least the second check value of the electronic coin data set is used to determine whether the electronic coin data set is returned to the central issuing instance. Thus, a display check value is provided separately from a return check value in the coin data set.


Preferably, the second check value is invariant to an action performed by participant units on the electronic coin data set, wherein preferably the second check value is at least one value from the following list: return date of the electronic coin data set; issue date of the electronic coin data set; registration date of the electronic coin data set; and identification value of the electronic coin data set. The action invariant check value is not individual to the electronic coin data set but is group specific and therefore applies to a plurality of different coin data sets to maintain anonymity and prevent coin data set tracking. The second action-invariant check value is not individual to the electronic coin data set, but applies to a plurality of different coin data sets (group ID) to preserve anonymity and prevent coin data set tracking.


In an advantageous embodiment, the second check value is variable and comprises the first check value to determine whether the electronic coin data set is returned. A sum could be formed and this sum compared to a predefined threshold value. For example, the number of direct transmissions could be a return criterion, so that no infrastructure for evaluating the coin data set with regard to the return of the coin data set would have to be maintained in the payment system, thus enabling a simpler and more secure administration while creating the control functions.


In an advantageous embodiment, exceeding a threshold value of the check value of the electronic coin data set is detected by a first terminal and an action with this electronic coin data set, in particular the direct transmitting of this electronic coin data set from the first terminal to a second terminal, is only carried out if it has been determined in the first terminal that no other electronic coin data set is present in the first terminal. This ensures that a payment transaction between two terminals can still be carried out and completed with the coin data set despite the high number of direct transmissions of this coin data set between terminals due to the lack of alternative coin data sets in the terminal.


In an advantageous embodiment, exceeding a blocking threshold value of the check value of the electronic coin data set is detected by a first participant unit and an action with this electronic coin data set, in particular the direct forwarding (transmitting) of this electronic coin data set from the first participant unit to a second participant unit, is blocked, irrespective of whether another electronic coin data set is present in the first participant unit or not. Thus, a threshold value is defined which, when reached, completely prevents (blocks) direct transmitting between participant units. For example, this coin data set could be stored in a secure storage area, where only a return process but no action process of the participant unit has access.


The threat of blocking may be detected in advance by the participant unit and communicated to a user of the participant unit to prevent the coin data set from being blocked by immediately returning the coin data set. Additionally or alternatively, the participant unit may return the electronic coin data set upon detection of exceeding the blocking threshold value.


Preferably, the threshold value of the check value is less than the blocking threshold value of the check value. The blocking threshold value can be a multiple of the threshold value in order not to block the coin data set too early. For example, the threshold value is ten, or for example five, or for example 3. The blocking threshold value is correspondingly 30, or for example 15, or for example 10.


In a preferred embodiment, the issuing instance queries check values of coin data sets at predefined periodic intervals or in a targeted manner and automatically reclaims an electronic coin data set when a check value of the electronic coin data set is exceeded.


In a preferred embodiment of the return method, the payment system's monitoring register determines a counter value in the monitoring register relating to the electronic coin data set using the electronic coin data set's check value. If a threshold value of the counter value is exceeded, the electronic coin data set is returned (directly or indirectly) to the central issuing instance. Preferably, only masked coin data sets are managed in the monitoring register. The issuing instance or the payment system requests the corresponding coin data set from the participant unit or provides a corresponding information from the payment system to the participant unit for (direct) return. The counter value is preferably increased with each action on the electronic coin data set, whereby preferably for different actions the counter value is increased with different weighting. Reference is made to the above advantages in such a method.


In a preferred embodiment of the return method, when an action is performed on the electronic coin data set by the monitoring register, the check value of the electronic coin data set is reset by the payment system. This simplifies the method as the participant unit does not need to be adjusted to the sum of all allowed actions, but only to the sum of successively allowed direct transmissions.


In a preferred embodiment, when combining (=connecting) electronic coin data sets into a combined electronic coin data set, the payment system determines the highest check value of the electronic coin data sets and takes this highest check value as the check value of the combined electronic coin data set.


In a preferred embodiment, when combining electronic coin data sets into a combined electronic coin data set, a new check value is determined by the monitoring register from the sum of all check values of the electronic coin data sets divided by the product of the number of coin data sets with a constant correction value, wherein said new check value is taken as the check value of the combined electronic coin data set, wherein the correction value is greater than or equal to 1, and wherein preferably the correction value depends on a maximum deviation of the individual check values of the electronic coin data sets or on a maximum check value of one of the electronic coin data sets, wherein further preferably the correction value is less than or equal to 2. The correction value is constant for payment.


In a preferred embodiment, the return of the electronic coin data set from the monitoring register to the issuing instance occurs when the terminal initiates the redeeming of a monetary amount of the electronic coin data set to an account of the payment system and/or when the participant unit requests an exchange of the monetary amount of the electronic coin data set to another currency system of the payment system.


An electronic coin data set can be split in a participant unit and this splitting is subsequently registered in the coin register. This has the advantage that an owner of the at least one electronic coin data set is not forced to always transmit the entire monetary amount at once, but to now form and transmit corresponding partial monetary amounts. The monetary value can be split symmetrically or asymmetrically without restrictions as long as all electronic coin data subsets have a positive monetary amount that is smaller than the monetary amount of the electronic coin data set from which to split and the sum of the electronic coin data sets is equal to the electronic coin data set to be split. Alternatively or additionally, fixed denominations can be used. Splitting into partial amounts is arbitrary. The splitting triggers, for example, executing the method described above for generating and encrypting a transaction data set, and the masked split electronic coin token data set may be part of a transaction data set for the transaction register.


The method preferably comprises the further steps of: Switching the transmitted electronic coin data set; and/or Connecting the transmitted electronic coin data set to a second electronic coin data set to form a (new) connected electronic coin data set.


Upon switching, the electronic coin data set obtained from the first participant unit results in a new electronic coin data set, preferably with the same monetary amount, called the electronic coin data set to be switched. The new electronic coin data set is generated by the second participant unit, preferably by using the monetary amount of the obtained electronic coin data set as the monetary amount of the electronic coin data set to be switched. In doing so, a new obfuscation amount, for example a random number, is generated. The new obfuscation amount is added to the obfuscation amount of the obtained electronic coin data set, for example, so that the sum of both obfuscation amounts (new and obtained) serves as the obfuscation amount of the electronic coin data set to be switched. After switching, the obtained electronic coin record and the electronic coin record to be switched are preferably masked in the participant unit by applying the homomorphic one-way function to the obtained electronic coin record and the electronic coin record to be switched, respectively, to obtain a masked obtained electronic coin record and a masked electronic coin record to be switched, respectively. The switching triggers, for example, executing the method described above for generating and encrypting a transaction data set, and the masked electronic coin to-be-switched data set may be part of a transaction data set for the transaction register.


The switching is thus secured by adding a new obfuscation amount to the obfuscation amount of the obtained electronic coin data set, thereby obtaining an obfuscation amount known only to the second participant unit. Newly created obfuscation amounts must have a high entropy, as they are used as a blinding factor for the corresponding masked electronic coin record. Preferably, a random number generator on the security element is used for this purpose. This safeguard can be tracked in the coin register.


Preferably, as part of the switching, additional information needed to register the switching of the masked electronic coin data set in the coin register is calculated in the participant unit. Preferably, the additional information includes a range record of the masked electronic coin data set to be switched and a range record of the masked obtained electronic coin data set. The range proof is a proof that the monetary amount of the electronic coin data set is non-negative, the electronic coin data set is validly created and/or the monetary amount and obfuscation amount of the electronic coin data set are known to the creator of the range proof. In particular, the range proof is used to provide such proof(s) without revealing the monetary amount and/or the obfuscation amount of the masked electronic coin data set. These range proofs are also called “zero-knowledge range proofs”. Preferably, ring signatures are used as range proofs. This is followed by registering the switching of the masked electronic coin data set in the remote coin register. Registering triggers, for example, executing the method described above for generating and encrypting a transaction data set, and the masked electronic coin record to be switched may be part of a transaction data set for the transaction register.


The step of executing the registration is preferably executed when the second participant unit is connecting to the coin register. While the electronic coin data sets are used for direct payment between two participant units, the masked coin data sets can be registered with a pseudonym in the coin register. The registering triggers, for example, executing the method described above for generating and encrypting a transaction data set, and the pseudonymised masked electronic coin record to be switched may be part of a transaction data set for the transaction register.


In a further preferred embodiment of the method, for connecting electronic coin data sets, a further electronic coin data set (connected electronic coin data set) is determined from a first and a second electronic coin data set. In doing so, the obfuscation amount for the electronic coin data set to be connected is calculated by forming the sum of the respective obfuscation amounts of the first and the second electronic coin data set. Further, preferably, the monetary amount for the linked electronic coin data set is calculated by forming the sum of the respective monetary amounts of the first and second electronic coin data sets.


After connecting, the first electronic coin data set, the second electronic coin data set, and the electronic coin data set to be connected in the (first and/or second) participant unit is masked by applying the homomorphic one-way function to each of the first electronic coin data set, the second electronic coin data set, and the electronic coin data set to be connected, respectively, to obtain a masked first electronic coin data set, a masked second electronic coin data set, and a masked electronic coin data set to be connected, respectively. Further, additional information required for registering the connecting of the masked electronic coin data sets in the remote coin register is calculated in the participant unit. Preferably, the additional information includes a range proof on the masked first electronic coin partial data set and a range proof on the masked second electronic coin partial data set. The range proof is a proof that the monetary amount of the electronic coin data set is non-negative, the electronic coin data set is validly created and/or the monetary amount and obfuscation amount of the electronic coin data set are known to the creator of the range proof. In particular, the range proof is used to provide such proof(s) without revealing the monetary value and/or obfuscation amount of the masked electronic coin data set. These range proofs are also called “zero-knowledge range proofs”. Preferably, ring signatures are used as range proofs. This is followed by registering the connecting of the two masked electronic coin records in the remote coin register. Registering triggers, for example, executing the method described above for generating and encrypting a transaction data set, and the masked linked electronic coin partial data set may be part of a transaction data set for the transaction register.


The connecting step can be used to combine two electronic coin data sets or two electronic coin partial data sets. In this process, the monetary amounts as well as the obfuscation amounts are added together. Thus, as with splitting, a validity of the two original coin data sets can be performed when connecting.


In a preferred embodiment, the registering step comprises receiving the masked electronic coin data set to be switched in the coin register, checking the masked electronic coin data set to be switched for validity; and registering the masked electronic coin data set to be switched in the coin register if the checking step is successful, whereby the electronic coin data set to be switched is deemed to be checked.


This results, for example, in at least a three-tier payment system. In a first layer (direct transaction layer), electronic coin data sets are transmitted directly between individual participant units or their security elements. In a second layer (verification layer), masked electronic coin data sets are registered and verified in a coin register and a monitoring register. Preferably, no payment transactions are recorded in the second layer, but only masked electronic coin data sets, their status, check values if applicable, signatures and modifications for the purpose of verifying the validity of (non-masked) electronic coin data sets. This ensures the anonymity of the participants in the payment system. The second layer provides information on valid and invalid electronic coin data sets, for example, to avoid multiple issuance of the same electronic coin data set, or to verify the authenticity of the electronic coin data set as validly issued electronic money, or to record the sum of monetary amounts per security element in order to compare this sum with a threshold value and to prevent or allow modification accordingly. The second layer can use a counter value of an electronic coin data set to determine whether the electronic coin data set has expired and is to be returned, or modified accordingly so that it is considered returned. In a third layer (archiving layer), encrypted transaction data sets are stored in a transaction register and are decrypted to be verified upon regulatory request as shown above.


In addition, the payment system also comprises, for example, an issuing instance that generates (creates) and reclaims (deletes) electronic coin data sets. When issuing an electronic coin data set from the issuing instance to a participant unit, a masked electronic coin data set can be issued in parallel by the issuing instance to the coin register and/or the monitoring register of the payment system for registration of the electronic coin data set.


A participant unit can have a security element or be a security element itself in which the electronic coin data set is securely stored. An application can be inserted on the participant unit ready for use, which controls or at least initiates parts of the transmitting method.


The transmitting of electronic coin data sets can be done with the help of terminals as participant units that are logically and/or physically connected to the security elements.


The communication between two participant units, possibly with the respective security elements, can be wireless or wired, or e.g. also by optical means, preferably via QR code or barcode, and can be designed as a secure channel, for example between applications of the participant units. The optical path may comprise, for example, the steps of generating an optical code, in particular a 2D code, preferably a QR code, and reading the optical code.


The transmitting of the electronic coin data set is secured, for example, by cryptographic keys, such as a session key negotiated for an electronic coin data set exchange or a symmetric or asymmetric key pair.


By communicating between participant units, for example via their security elements, the exchanged electronic coin data sets are protected against theft or manipulation. The security element level thus complements the security of established blockchain technology.


In a preferred embodiment, the coin data sets are transmitted as APDU commands. For this purpose, the coin data set is preferably stored in an (embedded) UICC as a security element and is managed there. An APDU is a combined command/data block of a connection protocol between the UICC and a terminal. The structure of the APDU is defined by the ISO-7816-4 standard. APDUs represent an information element of the application layer (layer 7 of the OSI layer model).


Furthermore, it is advantageous that the electronic coin data sets can be transmitted in any format. This implies that they can be communicated, i.e. transmitted, on any channels. They do not have to be stored in a determined format or in a determined programme.


A participant unit is considered to be in particular a mobile telecommunication terminal, for example a smartphone. Alternatively or additionally, the participant unit can also be a device such as a wearable, smart card, machine, tool, vending machine or even a container or vehicle. A participant unit is thus either stationary or mobile. The participant unit is preferably designed to use the Internet and/or other public or private networks. For this purpose, the participant unit uses a suitable connection technology, for example Bluetooth, LoRa, NFC and/or WiFi, and has at least one corresponding interface. The participant unit can also be designed to connect to the internet and/or other networks by accessing a mobile network.


For example, two participant units provide a local wireless communication link via whose protocol the transmission between the two security elements located therein is then inserted.


In one embodiment, the first and/or second security element may process the received electronic coin data sets according to their monetary value when multiple electronic coin data sets are present or received. Thus, it can be provided that electronic coin data sets with a higher monetary value are processed before electronic coin data sets with a lower monetary value.


In one embodiment, after receiving an electronic coin data set, the participant unit can be designed to connect it to an electronic coin data set already present in the participant unit depending on attached information, such as a currency or denomination, and execute a connecting step accordingly. Furthermore, the participant unit can also be designed to automatically execute a switching after receiving the electronic coin data set.


In one embodiment, further information, in particular metadata, is transmitted from the first participant unit or first security element to the second participant unit or second security element during transmitting, for example a currency. In one embodiment, this information may be comprised by the electronic coin data set.


The methods are not limited to a currency. For example, the payment system may be arranged to manage different currencies from different issuing instances. For example, the payment system is arranged to convert (=change) an electronic coin data set of a first currency into an electronic coin data set of another currency. This change is also a modification of the electronic coin data set. With the change, the original coin data set becomes invalid and is considered returned. Flexible payment with different currencies is thus possible and user-friendliness is increased.


The methods also allow the electronic coin data set to be converted into book money, e.g. the monetary amount to be paid into an account of the participant in the payment system. This conversion is also a modification. Upon redemption, the electronic coin data set becomes invalid and is considered returned.


Preferably, the at least one initial electronic coin data set is created exclusively by the issuing instance, although preferably the split electronic coin data sets, in particular electronic coin token data sets, may also be generated by a participant unit. Preferably, the generation and selection of a monetary amount also includes the selection of a high entropy obfuscation amount. The issuing instance is a computing system, which is preferably remote from the first and/or second participant unit. After creating the new electronic coin data set, the new electronic coin data set is masked in the issuing instance by applying the homomorphic one-way function to the new electronic coin data set to obtain a masked new electronic coin data set accordingly. Furthermore, additional information needed to register the creation of the masked new electronic coin data set in the remote coin register is computed in the issuing instance. Preferably, this additional information is a proof that the (masked) new electronic coin data set originates from the issuing instance, for example by signing the masked new electronic coin data set. In one embodiment, the issuing instance may sign a masked electronic coin data set with its signature when generating the electronic coin data set. The signature of the issuing instance is stored in the coin register. The signature of the issuing instance is different from the generated signature of a participant unit or security element.


Preferably, the issuing instance can deactivate an electronic coin data set in its possession (i.e. of which it knows the monetary amount and the obfuscation amount) by masking the masked electronic coin data set to be deactivated with the homomorphic one-way function and preparing a deactivate command for the coin register. Part of the deactivate command is preferably, in addition to the masked electronic coin data set to be deactivated, proof that the deactivating step was initiated by the issuing instance, for example in the form of the signed masked electronic coin data set to be deactivated. As additional information, the deactivate command could include range checks for the masked electronic coin data set to be deactivated. The deactivation may be the result of a return. This is followed by registering the masking of the masked electronic coin data set in the remote coin register. The deactivate command triggers the deactivate step.


The create and deactivate steps are preferably performed in secure locations, in particular not in the participant units. In a preferred embodiment, the steps of creating and deactivating are only performed or triggered by the issuing instance. Preferably, these steps take place in a secure location, for example in a hardware and software architecture designed to process sensitive data material in insecure networks. Deactivating the corresponding masked electronic coin data set has the effect that the corresponding masked electronic coin data set is no longer available for further processing, in particular transactions. However, in one embodiment, it may be provided that the deactivated masked electronic coin data set remains in archival storage at the issuing instance. The fact that the deactivated masked electronic coin data set is no longer valid or returned may be indicated, for example, by means of a flag or other coding, or the deactivated masked electronic coin data set may be destroyed and/or deleted. The deactivated electronic coin data set is also physically remote from the participant unit or security element.


The method according to the invention enables various processing operations (modifications) to be performed on the electronic coin data sets and the corresponding masked electronic coin data sets. Each of the processing operations (in particular creating, deactivating, splitting, connecting and switching) is registered in the coin register and appended to the list of previous processing operations for the respective masked electronic coin data set in an unchangeable form. Each of the processing operations triggers, for example, the method for generating and encrypting a transaction data set. The registration process is independent of the payment process between the participant units in terms of both time and location (space). The processing operations “create” and “deactivate” (=return), which concern the existence of the monetary amount itself, i.e. mean the creation and destruction up to the destruction of money, require an additional authorisation, for example in the form of a signature, by the issuing instance in order to be registered (i.e. logged) in the coin register. The remaining processing operations (splitting, connecting, switching), of which splitting and connecting can also be delegated from one participant unit to another participant unit, do not require authorisation by the issuing instance or by the instruction initiator (=payer, e.g. participant unit or security element).


A processing in the direct transaction layer only concerns the ownership and/or the allocation of the coin data sets to participant units of the respective electronic coin data sets. A registration of the respective processing in the coin register or the monitoring register is realised, for example, by corresponding list entries in a database, which comprises a number of flags to be performed by the coin register. A possible structure for a list entry comprises, for example, column(s) for a predecessor coin data set, column(s) for a successor coin data set, a signature column for the issuing instance, a signature column for the sending and/or receiving security element, a signature column for coin distribution operations and at least one marking column. A change (modification) is final if and the required flags have been validated by the coin register or the monitoring register, i.e. changed from status “0” to status “1”, for example, after the corresponding check. If a check fails or takes too long, it is changed from status “−” to status “0” instead, for example. Other status values are conceivable and/or the status values mentioned here are interchangeable. The statuses regarding the modifications are independent of the status during the transmission process (inactive/active). Preferably, the validity of the respective (masked) electronic coin data sets is summarised from the status values of the flags, each in a column for each masked electronic coin data set involved in the registering processing.


In another embodiment, at least two, preferably three, or even all of the aforementioned flags may also be replaced by a single flag that is set when all checks have been successfully completed. Furthermore, the two columns for predecessor data sets and successor data sets can be combined into one column each, in which all coin data sets are listed together. This would make it possible to manage more than two electronic coin data sets per field entry and thus, for example, to split them into more than two coin data sets.


The checks by the monitoring register to verify whether a processing is final are already described above and are in particular:

    • Are the masked electronic coin data sets of the predecessor column(s) valid?
    • Does a monitoring result in the correct check value?
    • Are the range proofs for the masked electronic coin data sets successful?
    • Is the signature of the masked electronic coin data set a valid signature of the issuing instance?
    • Does the sending/receiving participant unit (pseudonym) exceed a limit for a maximum allowable monetary amount, especially per time unit?
    • Is the coin data set Inactive due to transmitting between participant units?


Preferably, a masked electronic coin data set is also invalid if any of the following checks apply, i.e. if:

    • (1) the masked electronic coin data set is not registered in the coin register;
    • (2) the last processing of the masked electronic coin data set indicates that there are predecessor coin data sets for it, but this last processing is not final; or
    • (3) the last processing of the masked electronic coin data set indicates that there are successor coin data sets for it and that last processing is final;
    • (4) the masked electronic coin data set is not the successor to a valid masked electronic data set, unless it is signed by the issuing instance;
    • (5) the monetary amount of the masked electronic coin data set causes a limit for a maximum allowable monetary amount, in particular per time unit, to be exceeded and the requested de-anonymisation is rejected by the relevant participant unit;
    • (6) An active status for a security element is entered in the coin register, but another participant unit requests an action (switching, combining, splitting) under possession notification.


Preferably, the payment system is adapted to perform the above method and/or at least one of the embodiments.


Another aspect relates to a currency system comprising an issuing instance, a coin register layer, a first security element and a second security element, wherein the issuing instance is adapted to create an electronic coin data set. The masked electronic coin data set is adapted to be verifiably created by the issuing instance. The verification layer is adapted for executing a registration step as performed in the above method. Preferably, the security elements, i.e. at least the first and second security elements are adapted for executing one of the above methods (i) transmitting and (ii) generating+encrypting+initiating.


In a preferred execution of the currency system, only the issuing instance is authorised to initially create and finally withdraw an electronic coin data set. Processing, for example the step of connecting, splitting and/or switching, can and preferably is performed by a participant unit. Preferably, the processing step of deactivating can only be executed by the issuing instance.


Preferably, the coin register, the monitoring register and the issuing instance are arranged in a common server instance or are present as a computer program product on a server and/or a computer.


Preferably, the transaction register is located in, or is a computer program product on, a server instance different from the common server instance.


An electronic coin data set can exist in a variety of different forms and can thus be exchanged via different communication channels, hereinafter also referred to as interfaces. A very flexible exchange of electronic coin data sets is thus created.


The electronic coin data set can be represented in the form of a file, for example. A file consists of data that belong together in terms of content and are stored on a data carrier, data memory or storage medium. Each file is initially a one-dimensional string of bits that are normally interpreted as a group of byte blocks. An application programme (application) or an operating system of the security element and/or the terminal interpret this bit or byte sequence as, for example, a text, an image or a sound recording. The file format used for this can be different, for example it can be a plain text file representing the electronic coin data set. In particular, the monetary amount and the blind signature are represented as a file.


For example, the electronic coin data set is a sequence of American Standard Code for Information Interchange, or ASCII, characters. In particular, the monetary amount and the blind signature are mapped as this sequence.


The electronic coin data set can also be converted from one form of representation to another form of representation in a participant unit. For example, the electronic coin data set can be received as a QR code in a participant unit and output as a file or string by the participant unit.


These different forms of representation of one and the same electronic coin data set enable a very flexible exchange between participant units or security elements or terminals of different technical equipment using different transmission media (air, paper, wired) and taking into account the technical design of a participant unit. The choice of the presentation form of the electronic coin data sets is preferably made automatically, for example on the basis of recognised or negotiated transmission media and device components. In addition, a user of a participant unit can also choose the form of presentation for exchanging (=transmitting) an electronic coin data set.


In a simple case, the data memory is an internal data memory of the participant unit. This is where the electronic coin data sets are stored. Easy accessing of electronic coin data sets is thus ensured.


The data memory is in particular an external data memory, also called online memory. Thus, the security element or the participant unit has only one means of access to the externally and thus securely stored electronic coin data sets. In particular, if the security element or participant unit is lost or malfunctions, the electronic coin data sets are not lost. Since the ownership of the (non-masked) electronic coin data sets is equal to the ownership of the monetary amount, money can be saved and managed more securely by using external data memories.


If the coin register is a remote instance, the participant unit preferably has an interface for communication using a common internet communication protocol, for example TCP, IP, UDP or HTTP. The transmitting may involve communication over the cellular network.


In a preferred embodiment, the interface for outputting (=sending) the at least one electronic coin data set is a protocol interface for wirelessly sending the electronic coin data set to the other security element via a participant unit using a wireless communication protocol. In particular, a near-field communication, for example by means of Bluetooth protocol or NFC protocol or IR protocol, is provided; alternatively or additionally, WLAN connections or mobile radio connections are conceivable. The electronic coin data set is then adapted according to the protocol properties or integrated into the protocol and transmitted.


In a preferred embodiment, the interface for outputting the at least one electronic coin data set is a data interface for providing the electronic coin data set to the other participant unit by means of an application. In contrast to the protocol interface, the electronic coin data set is transmitted by means of an application. This application then transmits the electronic coin data set in a corresponding file format. A file format specific to electronic coin data sets can be used. In its simplest form, the coin data set is transmitted as an ASCII string or as a text message, for example SMS, MMS, instant messenger message (such as Threema or WhatsApp). In an alternative form, the coin data set is transmitted as an APDU string. A wallet application may also be provided. In this case, the exchanging participant units preferably ensure that an exchange is possible by means of the application, i.e. that both participant units have the application and are ready to exchange.


In a preferred embodiment, the participant unit further comprises an interface for receiving electronic coin data sets.


In a preferred embodiment, the interface for receiving the at least one electronic coin data set is an electronic capture module of the security element or terminal, arranged to capture an electronic coin data set presented in visual form. The capture module is then, for example, a camera or a barcode or QR code scanner.


In a preferred embodiment, the interface for receiving the at least one electronic coin data set is a protocol interface for wirelessly receiving the electronic coin data set from another security element or terminal by means of a communication protocol for wireless communication. In particular, near-field communication, for example by means of Bluetooth protocol or NFC protocol or IR protocol, is provided. Alternatively or additionally, WLAN connections or mobile radio connections are conceivable.


In a preferred embodiment, the interface for receiving the at least one electronic coin data set is a data interface for receiving the electronic coin data set from the other participant unit by means of an application. This application then receives the coin data set in a corresponding file format. A file format specific to coin data sets can be used. In its simplest form, the coin data set is transmitted as an ASCII string or as a text message, for example SMS, MMS, Threema or WhatsApp. In an alternative form, the coin data set is transmitted as an APDU string. Additionally, the transmitting can be done by means of a wallet application.


In a preferred embodiment, the participant unit comprises at least one security element reader arranged to read a security element; a random number generator; and/or a communication interface to a vault module and/or banking institution with accessing a bank account to be authorised.


In a preferred embodiment, the data memory is a shared data memory that can be accessed by at least one other participant unit, each of which comprises an application, said application being arranged to communicate with the coin register for corresponding registration of electronic coin records.


Thus, what is proposed here is a solution that issues digital money in the form of electronic coin data sets, which is modelled on the use of conventional (analogue) banknotes and/or coins. The digital money is represented here by electronic coin data sets. As with (analogue) banknotes, these electronic coin data sets can be used for all forms of payments, including peer-to-peer payments and/or POS payments. Knowing all the components (especially monetary amount and obfuscation amount) of a valid electronic coin data set is tantamount to possession (ownership of) the digital money. It is therefore advisable to keep these valid electronic coin data sets confidential, e.g. to save them in a security element/vault module (of a terminal) and process them there. Elm to decide on the authenticity of an electronic coin data set and to prevent duplicate issues, masked electronic coin data sets are kept in the coin register as a unique corresponding public representation of the electronic coin data set. Knowing or having a masked electronic coin data set does not constitute possession of money. Rather, it is akin to verifying the authenticity of the analogue means of payment.


The coin register also contains, for example, flags on performed and planned processing of the masked electronic coin data set. The processing flags are used to derive a status of the respective masked electronic coin data set, indicating whether the corresponding (non-masked) electronic coin data set is valid, i.e. ready for payment. Therefore, a recipient of an electronic coin data set will first generate a masked electronic coin data set and have the coin register authenticate the validity of the masked electronic coin data set. A major advantage of this solution according to the invention is that the digital money is distributed to terminals, merchants, banks and other users of the system, but no digital money or further metadata is stored with the coin register or the monitoring register—i.e. common instances.


The proposed solution can be integrated into existing payment systems and infrastructures. In particular, there can be a combination of analogue payment transactions with notes and coins and digital payment transactions according to the present solution. Thus, a payment transaction can be made with banknotes and/or coins, but the change or change back is available as an electronic coin data set. For example, ATMs with a corresponding configuration, in particular with a suitable communication interface, and/or mobile terminals can be provided for the transaction. Furthermore, an exchange of electronic coin data set into banknotes or coins is conceivable.


The steps of creating, switching, splitting, connecting and deactivating (returning) are each triggered by a corresponding creating, switching, splitting, connecting or deactivating command (return command).





BRIEF SUMMARY OF FIGURES

In the following, the invention or further embodiments and advantages of the invention will be explained in more detail with reference to figures, the figures merely describing embodiments of the invention. Identical components in the figures are given the same reference signs. The figures are not to be regarded as true to scale, and individual elements of the figures may be shown in exaggeratedly large or exaggeratedly simplified form.


They show:



FIG. 1a,b an embodiment example of a payment system according to the state of the art;



FIG. 2 an embodiment example of a payment system according to the invention;



FIG. 3 an embodiment example of a method flow chart of a method according to the invention in a participant unit;



FIG. 4 an embodiment example of a method flow chart of a method according to the invention in a transaction register;



FIG. 5 an embodiment example of an encryption and decryption of a transaction data set;



FIG. 6 a further embodiment of the payment system embodiment example of FIG. 2;



FIG. 7 an alternative further development of the embodiment example of a payment system of FIG. 2;



FIG. 8 an embodiment example of a coin register and monitoring register;



FIG. 9 an embodiment example of a system according to the invention for splitting and switching and directly transmitting electronic coin data sets;



FIG. 10 an embodiment example of a payment system according to the invention for connecting electronic coin data sets;



FIG. 11 an embodiment example of a method flow chart of a method according to the invention and corresponding processing steps of a coin data set;



FIG. 12 an embodiment example of a method flow chart of a method according to the invention and corresponding processing steps of a coin data set;



FIG. 13 an embodiment example of a security element according to the invention;



FIG. 14 a payment system according to the invention;



FIG. 15 an embodiment example of a sequence of payment operations according to the invention, monitoring the monetary amounts per participant unit; and



FIG. 16 an embodiment example of a range confirmation procedure according to the invention.





FIGURE DESCRIPTION


FIG. 1a and FIG. 1b show an embodiment example of a payment system according to the prior art. These FIG. 1a and FIG. 1b are already described in the introduction to the description. Repeating, it is pointed out, that a terminal M8 wants to register the coin data set Cc as the coin data set Ce to the coin register 2 and the coin register 2 determines that the coin data set Cb is already invalid. As a result, the coin register 2 does neither accept either the supposedly valid coin data set Cc nor the coin data set Ce to be switched.


The problem can occur if, for example, an attacker with terminal M1 directly forwards a coin data set Cb (without permission) to two terminals M2 and M3. As soon as one of the two participants with terminal M2 registers the coin data set in coin register 2 (so-called coin change), the coin data set Cb becomes invalid. An unsuspecting subscriber with terminal M3 instead passes the coin data set Cb directly to terminal M5 without registering it. Only terminal M7 breaks the direct transmission chain and displays coin data set Cb at coin register 2. In parallel, the subscriber with terminal M2 splits coin data set Cb into coin data set Cc and Cx and passes Cc directly to terminal M4. Terminal M4 passes the coin data set Cc directly to terminal M6. Terminal M6 passes the coin data set Cc directly to terminal M8. Only when coin data set Cc is registered with coin register 2 can the invalidity of coin data set Cb and consequently the double spending be detected. Thus, an attack (double-spending of an electronic coin data set) of M1 is detected late in the prior art and a large number of direct transmissions have been executed in an unauthorised manner. In addition, due to the large number of transactions of an electronic coin data set and also due to the advancing life span, the risk increases that manipulation(s) have been carried out on the electronic coin data set.


Therefore, in a payment system, if a certain lifetime or number of actions on/with the coin data set is exceeded, the coin data set should expire, i.e. on the one hand, the number of direct transmitting of coin data sets should be limited and on the other hand, in case of a detected attack, it should be possible to trace who carried out the attack (here terminal M1). For the purpose of securing evidence, a method/system is described below in which transaction data of participant units (terminals or security elements) are archived in a remote transaction register and can be checked in the event of an official decision.


For this purpose, the payment system according to the invention comprises at least two, preferably a plurality of participant units TEs, which are also referred to or shown below as security elements SEx or terminals Mx, and a transaction register. The payment system may further comprise, for example, at least one issuing instance 1, one or more commercial banks, one (or more) central issuing register 2, which performs the registration of the coin data sets and checks and records the modifications to the coin data set. Further examples of payment systems according to the invention are shown in FIGS. 6, 7, 14 and 16.



FIG. 2 shows an embodiment example of a payment system BZ according to the invention. The payment system BZ comprises at least two security elements SE1 and SE2. The SE1 and SE2 can be inserted ready for use in respective terminals M1 and M2 and connected logically or physically to the respective terminal M1 and M2. A transaction register 4 of the payment system BZ is also shown.


In the payment system of FIG. 2, an issuing instance 1, for example a central bank, is also provided, which generates the electronic coin data set C in addition to the person allocation 7. A masked electronic coin data set Z is generated for the electronic coin data set C and registered in a coin register 2 of the payment system 104. The electronic coin data set C is output by the issuing instance 1 to the first terminal M1 in step 102. The masked electronic coin data set Z is output in step 104, for example, by the issuing instance 1 directly or via the first terminal M1 to the coin register 2. The masked electronic coin data set Z is alternatively generated by the first terminal M1 (or second terminal M2) and sent to the coin register 2 in step 104.


During a scheduled or already executed transmission 105 of an electronic coin data set C, as will be described in further detail below, a transaction data set TDS is generated in the first terminal M1. The transaction data set TDS has a subscriber ID of the sending terminal M1, a subscriber ID of the receiving terminal M2, optionally a transaction number, optionally a monetary amount of the coin data set, optionally a masked coin data set Z corresponding to the electronic coin data set C (masking will be explained later), and optionally a transaction time. Each participant ID of a terminal is assigned to a natural person for payment. This person assignment 7 is carried out and also managed here by an issuing instance, for example. This assignment 7 is only carried out after the person has been successfully identified by presenting an identity card or passport. This assignment 7 can be changed at the request of the person, for example when changing the participant unit or adding another participant unit.


After generating the transaction data set TDS, the first terminal M1 encrypts it with a cryptographic key. This cryptographic key is, for example, a public key part of a corresponding composed private key part. This private key part is composed of three partial keys 8a, 8b, 8c, whereby the partial keys 8a, 8b, 8c have been added or XOR-associated, for example. This linking of the partial keys 8a, 8b, 8c takes place either in the first terminal M1 or in the transaction register 4. This linking of the partial keys 8a, 8b, 8c is, for example, secret throughout the system. Knowledge or possession of only one partial key 8a, 8b, 8c does not enable decryption of the transaction data set TDS. FIG. 5 shows an embodiment example for encrypting and decrypting a transaction data set TDS.


In FIG. 2, the encrypted transaction data set TDS is sent from the first terminal M1 to the transaction register 4 and stored there. The time of transmitting is preferably closely associated with the transmitting 105 of the electronic coin data set, so that the transaction register 4 is always up to date with the transactions carried out in the payment system BZ.


In cases of suspected fraud, an official order, for example a court order, could be issued to decrypt the encrypted transaction data set TDS in order to detect and analyse the transaction recorded with it (the transmitting 105). By means of the official decision, for example, all stored transactions would then be queried at the transaction register 4 for a terminal M (by means of the identifier) over a determining time or period of time. In addition, further attributes of the transaction data, such as the monetary amounts of the coin data sets, the respective transaction partners, etc., could be queried.


As a result of the adjudication, the transaction data can be decrypted by having a plurality of remote instances, as authorised parties, generate (or provide) a decryption key by combining their partial keys. The remote instances are, for example, law enforcement agencies, notaries, the ministry of justice, a central bank or others.


All remote instances (authorised parties) have only partial keys 8a, 8b, 8c of the decryption key. All members or a minimum number n of m remote instances are required to decrypt the transaction data set TDS together. Technically, the individual partial keys 8a, 8b, 8c of the different remote instances are composed into a common private key part by addition or by bitwise XORing. This private key part (which corresponds to the corresponding public key part of the encryption) is then used to decrypt the transaction data set TDS. This concept guarantees that no remote instance can decrypt the transaction data set TDS on its own and could thus bypass other instances. If the concept should not rely on the availability of all m remote instances, threshold cryptography could be applied to use a subset n of these partial keys 8a, 8b, 8c. This subset n then defines the minimum number of partial keys 8a, 8b, 8c to be combined.


The payment system shown in FIG. 2 has a three-layer structure. In a first layer, the issuing instance 1, for example a central bank, is responsible for money creation and destruction, as will be explained later. Commercial banks (not shown) can store coin data sets C, for example in vault modules that are designed as highly secure modules, for example as HSMs. Distributes money to users and sends or receives money to/from the central bank.


In a second layer, the coin register 2 and the transaction register 4 are provided. This layer is used to check coin data sets C, in particular the validity and authenticity of coin data sets C in circulation, and checks whether coin data sets C have been issued twice. In order to set up a law enforcement system, the transaction register 4 is provided. It is also conceivable to decouple this transaction register 4 from the payment system BZ in order to follow the principle of “separation of concerns”. For the sake of simplicity, the transaction register 4 is assigned below to the second layer of the payment system BZ. As a trusted instance, the transaction register 4 is responsible for protecting people's privacy in regular situations and for disclosing encrypted transaction data sets TDS when required by court decisions. This makes it possible to check that no irregular transactions or money operations are taking place, in particular that no (new) money is being illegally created or destroyed. The transaction register 4 is an extension for use cases in law enforcement with the aim of detecting suspicious transaction data. The transaction register 4 stores encrypted records of transactions that are (required to be) reported by the participants involved and passes them on to the authorities according to due method. The transaction register 4 stores the transaction data sets TDS in encrypted form. This ensures that due process must be followed and that no one can access this sensitive transaction data at will. In addition, a re-encryption unit can be used in the transaction register to perform re-encryption of the TDS so that a law enforcement agency only obtains access to the officially authorised data. Metadata, such as transaction time and subscriber ID, is used to provide the requested data. The re-encryption unit can access and decrypt all data.


The third layer is a direct transaction layer 3, in which all participants, i.e. consumers, merchants, etc., participate equally via their participant units TE to exchange electronic coin data sets C. The transaction data is stored in a memory. Each participant unit TE may have a wallet application to manage coin data sets C. The coin data sets C can be stored locally in the participant unit TE or they can be stored in an online storage (=cloud storage) and the participant unit TE can manage them remotely. In the case of an offline scenario, where a transmission 105 is made without control instances or register instances 2, 4, 6 of the payment system BZ, participant units TE can interact instantly (directly) with other participant units TE. The actual data transmission for a coin data set may comprise further intermediary instances. This offline design of the payment system BZ requires that the coin data sets C are saved in certified areas, for example a wallet application, ideally within security elements SE, for example smart cards or an eSim environment, in order to obtain trustworthiness in the payment system BZ.


To generate an electronic coin data set C, the following method is proposed.


The transmitting 105 is done, for example, wirelessly via WLAN, NFC or Bluetooth, thus preferably locally. The transmission 105 may be further secured by cryptographic encryption methods, for example by negotiating a session key or applying a PKI infrastructure. The transmitting 105 may also be performed involving an online data memory from which the electronic coin data set C is transmitted to the TE2 (M2, SE2).


In the transmission step 105, for example, a secure channel is established between the SE1 and the SE2, during which both SEs authenticate each other. The transmission path between SE1 and SE2 is not necessarily direct, but can be an internet or near-field communication path with instances (terminals, routers, switches, applications) connected in between. By using SEs as a secure environment instead of terminals ME as TEs, a higher level of trust is generated, i.e. trustworthiness in the payment system BZ is increased. At the same time as the eMD C is sent, or immediately before or after, a timer is optionally started. Before this, the eMD C can be invalidated and then no longer be used by SE1 for actions (as described below). The eMD C is thus blocked in the payment system BZ due to a transmission process 105 that has already been initiated (and not yet completed). This prevents double spending. Invalidation enables easy handling during the transmission process 105.


When the eMD C is properly received in the SE2, an acknowledgement of receipt is generated by the SE2 and sent back to the SE1. The receipt confirmation from the SE2 can be sent as a deletion request, because only after deletion of the eMD C in the SE1 can (may) the eMD C be validated and used in the SE2. Optionally, the deletion of the eMD C can be displayed by SE1. For example, an amount display of the SE1 (or a terminal ME1 in which the SE1 is logically located) is updated. For example, the monetary amount of the eMD C is subtracted from an amount of the SE1 available for payment transactions. A deletion confirmation can be sent from the SE1 to the SE2. This serves as an acknowledgement that the eMD C is no longer available in SE1 and can therefore be validated in SE2. Upon obtaining the deletion confirmation in the SE2, the SE2 can convert a status of the eMD C in the SE2 into an active status, the eMD C is thus validated and can be used for further payment transactions or actions (splitting, combining, switching) in the SE2 from this point on. Optionally, the eMD C of the SE2 is switched to the SE2 in coin register 2 (see below), whereby the eMD C is registered to the SE2 (step 104).


A transmission error of transmitting 105 may be detected in the SE1, for example by exceeding a predefined time period, indexed by a timer, or by receiving an error message from the SE2 or the terminal M1 or the other terminal M2 (not shown). For example, with each new transmission attempt for transmitting the eMD C (RETRY), a counter value can be incremented and, if a maximum permissible number of retries is exceeded, for example 10 or 5 or 3 times, it is automatically decided in step 308, independently of the error case, that no new sending attempt (RETRY) is carried out, but that the transmission 105 is to be terminated as unsuccessful and a ROLLBACK is to be carried out.


In an alternative embodiment of the transmitting method 105, the status of the eMD is reported by the SE1 to the coin register 2. A connecting is then established with the coin register 2 for a status request to the eMD C. If the coin register 2 continues to report an inactive status back to the eMD C (registered to the SE1), no transaction error (tampering attempt) is assumed. However, if coin register 2 returns an active status to the eMD C or a registration to another SE, a transaction error (tampering attempt) is assumed and the payment system is alerted. The transaction data set TDS of the SE1 is used for proof.


The electronic coin data set C may be requested in advance from an issuing instance 1 and optionally received by a terminal M (or an SE) or the issuing instance 1 or another payment system. Steps 104 and 105 may correspond to steps 104 and 105 of FIG. 11. An action (splitting, connecting, switching, transmitting, redeeming, switching) on the eMD C may correspond to any of the actions of FIGS. 9 to 12.


For example, a true random number is generated as the obfuscation amount ri. The obfuscation amount ri is associated with a monetary amount υi. Accordingly, an ith electronic coin data set according to the invention could be:






C
i={υi;ri}  (1)


A valid electronic coin data set can be used for payment. The owner of the two values υi and ri, is therefore in possession of the digital money. The digital money is defined by a pair consisting of a valid electronic coin data set Ci and a corresponding masked electronic coin data set Zi. A masked electronic coin data set Zi is obtained by applying a homomorphic one-way function f (Ci) according to equation (2):






Z
i=ƒ(Ci)  (2)


This function f(Ci) is public, i.e. any system participant can call and use this function. This function f(Ci) is defined according to equation (3):






Z
ii·H+ri·G  (3)


where H and G are generator points of a group G in which the discrete logarithm problem is hard, with generators G and H for which the discrete logarithm of the other basis is unknown. For example, G and H are generator points of an elliptic curve cipher, ECC,—that is, private keys of ECC. These generator points G and H must be chosen in such a way that the context of G and H is not publicly known, so that if:






G=n·H  (4)


the association n must be practically undetectable to prevent the monetary amount υi from being manipulated and yet a valid Zi could be calculated. Equation (3) is a “Pederson commitment for ECC”, which ensures that the monetary amount υi can be conceited, i.e. “committed”, to a coin register 2 without revealing it to the coin register 2. Only the masked coin data set Zi is therefore sent (revealed) to the public and remote coin register 2, which is shown in FIG. 2 as step 104 (registering).


Even though in the present example an encryption based on elliptic curves is described, another cryptographic method based on a discrete logarithmic method would also be conceivable.


Due to the entropy of the obfuscation amount ri, equation (3) makes it possible to obtain a cryptographically strong Zi even with a small range of values for monetary amounts vi. Thus, a simple brute force attack by merely estimating monetary amounts υi is practically impossible.


Equation (3) is a one-way function, which means that computing Zi from Ci is easy because an efficient algorithm exists, whereas computing Ci starting from Zi is very hard because no algorithm that can be solved in polynomial time exists.


Moreover, equation (3) is homomorphic for addition and subtraction, which means:






Z
i
+Z
j=(υi·H+ri·G)+(υj·H+rj·G)=(υijH+(ri−rjG  (5)


Thus, addition operations and subtraction operations can be executed both in the direct transaction layer 3 and in parallel in the coin register 2 without the coin register 2 having knowledge of the electronic coin data sets Ci. The homomorphic property of equation (3) allows monitoring of valid and invalid electronic coin data sets Ci based solely on the masked coin data sets Zi and ensuring that no new monetary amount υj has been created.


This homomorphic property allows the coin data set Ci to be split according to equation (1) into:






C
i
=C
j
+C
k={υj;rj}+{υk;rk}  (6)


where it holds that:





υijk  (7)






r
i
=r
j
+r
k  (8)


For the corresponding masked coin data sets holds:






Z
i
=Z
j
+Z
k  (9)


Equation (9) can be used, for example, to easily check a “symmetric or asymmetric splitting” processing or a “symmetric or asymmetric splitting” processing step of a coin data set according to FIG. 9 or 12 without the coin register 2 having knowledge of Ci, Cj, Ck. In particular, the condition of equation (9) is checked to validate split coin data sets Cj and Ck and to invalidate coin data set Ci. Such splitting of an electronic coin data set Ci is shown in FIG. 9 or 12.


Electronic coin data sets C can also be joined (connected) in the same way, see FIG. 10 or 11 and the explanations.


In addition, it is important to check whether (not allowed) negative monetary amounts are registered. An owner of an electronic coin data set Ci must be able to prove to the coin register 2 and/or a monitoring register 6 that all monetary amounts υi in a processing operation are within a range of values of [0, . . . , n] without informing the coin register 2 of the monetary amounts vi. These range proofs are also called “range proofs”. Preferably, ring signatures are used as range proofs. For the present embodiment example, both the monetary amount υ and the obfuscation amount r of an electronic coin data set C are resolved in bit representation. It holds:





υi=Σaj·2j for 0≤j≤n and aj∈{0;1}  (9a)





as well as






r
i
=Σb
j·2j for 0≤j≤n and bj∈{0;1}  (9b)


For each bit, preferably a ring signature with






C
ij
=a
j
·H+b
j
·G  (9c)





and






C
ij
−a
j
·H  (9d)


is carried out, whereby in one embodiment it can be provided that a ring signature is only carried out for certain bits.



FIG. 3 shows an embodiment example of a method flow diagram of a method 300 according to the invention in a participant unit TE, hereinafter also referred to as terminals M or security elements SE. The dashed blocks of the method 300 are optional. Each of these steps may involve subscriber interaction or at least subscriber information, for example via a GUI of the TE.


In step 301, a transaction data set TDS is generated. The transaction data set TDS comprises the participant identifiers from the first participant unit TE1 (sending TE) and from the second participant unit TE2. In addition, information about the electronic coin data set C to be transmitted (or the transmitted) is included, for example the monetary amount υ. Instead of the information about the electronic coin data set C to be transmitted (or the transmitted), the masked electronic coin data set Z can be inserted into the TDS. In addition, a transaction time may be included in the TDS to indicate the time of transmission 105 of the electronic coin data set C between the two participant units TE. The time of generating 301 may be closely timed to the time of transmitting 105. The payment system BZ may require that the electronic coin data set C is transmitted first (step 105) before the encrypted transaction data set TDS is sent.


After the generating step 301, the generated transaction data set TDS is encrypted. For this purpose, the first participant unit TE1 has a public key part K composed of partial keys of different remote instances. The key composition is shown, for example, in FIG. 5. Alternatively, the participant unit TE1 receives a corresponding cryptographic key K in step 302, for example upon request of the key at the transaction register 4. The key K may be a key of a PKI structure or a symmetric key.


In step 303, the encrypting of the transaction data set TDS with the cryptographic key K in the first participant unit TE1 takes place, for example by an encryption module or a computing unit of the first participant unit TE1.


Not shown in FIG. 3 is an optional linking step of (plain text) metadata to the encrypted transaction data set TDS, for example an identifier of the first participant unit TE1, an identifier of the second participant unit TE2 and/or a transaction time. This metadata allows the encrypted TDS stored locally and/or in the transaction register 4 to be indexed or catalogued.


In step 304, a communication link to the transaction register 4 is then initiated. This attempts to establish a communication channel between the first participant unit TE1 and the transaction register 4. Initiating also comprises the respective participant unit TE detecting/knowing that an offline transaction is currently scheduled/performing and that a connecting to the remote transaction register 4 cannot or should not be established.


In the subsequent check step 305, the participant unit TE1 is queried whether a connection could be established in step 304.


In the yes case of check step 305 the encrypted transaction data set TDS is sent to the transaction register 4 in step 306. If necessary, other transaction data sets TDS from previous transmissions of electronic coin data sets C are also transmitted, should this communication link have been created for the first time since these transmissions. In this context, a check value is then also reset (not shown in FIG. 3) representing a number of transmissions of electronic coin data sets C that have occurred without sending a transaction data set TDS. In a check step 305a, if necessary, it is queried whether a transmission error occurred during sending 305 of the encrypted transaction data set TDS. In the no case of the check step 305a, the encrypted and/or the unencrypted transaction data set TDS is then optionally stored locally in the first participant unit TE2 for archiving purposes or for storing a history or for queries based on official requests. Subsequently, the electronic coin data set C is transmitted to the second participant unit TE2 in step 105 if it is a requirement in the payment system BZ that the encrypted transaction data set TDS is to be sent first before the electronic coin data set C may be transmitted in step 105. In one embodiment of the method 300, registering 104 of the masked electronic coin data set Z in the coin register 2 is mandatory after transmitting 105. In one embodiment of the method 300, a pseudonymised masked coin data set is registered in the coin register 2 or the monitoring register 6 in step 104 as described in FIGS. 7, 15 and 16.


In the no case of check step 305 (offline transaction, flight mode, no sending of transaction data TDS desired (by subscriber)) and also in the yes case of check step 305a (transmission error, disconnection), a connection error is detected in step 307. Following this, a check value p in the first participant unit TE1 is compared with a threshold value X in check step 308. The check value in step 308 represents a number of (offline) transmissions 105 of electronic coin data sets C that have occurred without sending a transaction data set TDS. These (offline) transmissions 105 from the first participant unit TE1 may have been transmitted to any other participant unit TEx. In the yes case of the check step 308, i.e. if this check value p is greater than the threshold value X, for example 100 or 50 or 10 transmissions, the transaction data set TDS is stored (encrypted and/or unencrypted) and it is mandatory to repeat step 304. In the no case of check step 308, transmitting 105 takes place if there is a requirement in the payment system BZ that the encrypted transaction data set TDS must be sent first before the electronic coin data set C may be transmitted in step 105. In step 310, the check value p is then incremented, i.e. increased in steps, preferably by 1.


Steps 308 to 310 ensure that the off-line behaviour of the participant units TE remains monitored and is not possible to exceed a predefined determined (payment system predetermined) threshold value X of transmission numbers. Transaction data sets TDS of an offline transaction that cannot be transmitted immediately, i.e. a transmitting 105 without registering 104 or reporting to one of the register instances 2, 4, 6 of the payment system BZ, are temporarily stored in step 309 and transmitted at a later time. The number of offline transactions that a participant unit TE may perform is limited by the payment system and controlled by means of the check value p in step 308. If the threshold value X is reached, the transaction data sets TDS must first be sent before another offline transaction 105 is possible (see step 309 for step 304). This check value p may be recorded and maintained independently of other checks in the participant unit TE. This check value p can be combined with other check or count values pi1, pi2, of the coin data set C for checking in the coin register 2 or the monitoring register 6, see payment system BZ of FIG. 6.


Individual method steps can be interchanged. For example, a general first requirement in the payment system BZ can be that coin data sets C are first transmitted between TEs before a transaction data set TDS is created for them. In this case, a TDS would always relate to a coin data set C that has already been transmitted, and step 105 would be performed before the associated steps 301, 303.


Alternatively, a general first default in the payment system BZ can be that coin data sets C are only transmitted between TEs (step 105) after a transaction data set TDS has been created for it (step 301). In this case, a TDS would always concern a coin data set C that has yet to be transmitted, and step 105 would be performed after the corresponding step 301.


A second general requirement in the payment system BZ could concern the local storage of TDS in the TE. Thus, it may be required that TDS are also to be stored locally (i.e. history or archiving). The storage step 309 is then not only to be provided for transmitting repetitions (in case of error of a first transmitting attempt). It may be a default detail that the TDS shall also be stored encrypted in the TE. This local storage of the TDS, which is redundant to the storage of the TDS in the transaction register 4, can be read out in the context of an official request (a court order), i.e. the participant can be forced to provide this local storage or the transfer of the local storage can take place in a (background) process of the participant unit TE without participant interaction.


A third general requirement in the payment system BZ can be to store pseudonymised TDS* in a monitoring register 6 of the payment system BZ. These pseudonymised TDS* are taken into account in the validity of the coin data sets in order to be able to detect fraud scenarios within the payment system.


A fourth general requirement in the payment system FC can be not to send encrypted TDS to the transaction register 4 if an offline transaction is planned/carried out. This default can be closely coupled with the check value p, so that a participant unit TE issues a warning to the participant already before selecting a transmitting mode (online or offline) that a check value p has exceeded a threshold value for the maximum number of offline transmissions 105 and no further offline transmission is possible without first sending (old) TDS to the transaction register 4 (with resetting of the check value counter).



FIG. 4 shows an embodiment example of a method flowchart of a method 400 according to the invention in a transaction register 8. The dashed blocks of the method 400 are optional.


Here, in step 401, an encrypted transaction data set TDS is received from a participant unit TE in the transaction register 4. This transaction data set TDS has been generated according to the method shown in FIG. 3.


In the optional check step 402, it is checked whether different generations of partial keys are present in the payment system BZ, for example the transaction register 4, preferably an HSM module within the transaction register 4 as a key store. In the yes case of step 402, the transaction data set TDS is decrypted with the private key part k of the cryptographic key as decryption key in step 403 and re-encrypted with a cryptographic key, for example an HSM key of the transaction register 4. In this way, storing differently encrypted transaction data sets TDS encrypted with different key versions of the remote instances can be prevented in the transaction register 4. The administrative overhead in transaction register 4 is thus reduced.


After re-encrypting step 403 or in the no case of check step 402, the transaction data set TDS is stored in a memory range and archived there. If applicable, the transaction data set TDS has metadata in plain text that is entered or kept track of in a database of the transaction register 4. For example, if a transaction time exists as a metadata of the TDS, a deletion time can be generated as part of a retention. The TDS would then be automatically deleted from the transaction register 4 after a set period of time (the deletion time) has elapsed.


In the transaction register 4 (e.g. a database as a trusted entity), the TDS are stored in encrypted form, requiring several partial keys to decrypt them. This ensures that due process must be followed and that no one can access sensitive transaction data TDS at will.


Optionally, for example in the absence of a key store in the transaction register 4, partial keys of the cryptographic key k are received in step 405 and combined in step 406 in the transaction register 4, for example to form the private key part of the private key part when using a PKI key structure. The combination is secret, for example, so as not to allow owners of the partial keys 8a, 8b, 8c to combine the decryption key. The combined key may also be composed of only a subset of partial keys, which is possible by applying threshold value cryptography.


In the context of an official request—generated from outside the payment system BZ—in particular on the basis of a court order, a decryption request is made to the transaction register 4 in step 407. In this step, the metadata of the transaction data sets can be matched with parameters of the decryption request, for example to query all transaction data sets with a determining participant ID for a determining point in time or time period. Subsequently, in step 408, each remote instance is requested to authenticate to the transaction register 4. Alternatively, only a required subset of remote instances necessary to decrypt the desired transaction data set(s) TDS is requested. In step 409, decryption is then performed using the combined key from the shared partial keys of the remote instances.


Optionally, in step 410, for example, even without step 407, a participant unit identifier in the decrypted transaction data set TDS is replaced by a pseudonym of the participant unit TE. Preferably, the pseudonym corresponds to the pseudonym of FIGS. 7, 15 and 16. This changes an anonymity level for the TDS so that the TDS can be used in unencrypted form for coin data set verification.


Optionally, in step 411, for example, even without step 407, a monetary amount in the decrypted transaction data set TDS is replaced with one or more amount categories in addition to or as an alternative to step 410. In one embodiment, for example, the monetary amount of the coin data set C is rounded up or down, for example:

    • monetary amount of 1.97 becomes the amount category “2 euros”
    • monetary amount of 878.99 becomes the amount category “1000 euro”
    • monetary amount of 4.07 becomes amount category “4 euros”
    • monetary amount of 2118.22 becomes the amount category “2000 Euro”


In a further embodiment, the monetary amount is sorted into one or more amount categories that represent amount ranges, for example:

    • a monetary amount of 1.97 becomes the amount category “less than 10 euro”
    • monetary amount of 878.99 becomes the amount category “between 100 and 1000 euros”)
    • monetary amount of 4.07 becomes the amount category “greater than 1 euro”


Steps 410 and/or 411 can be performed by an HSM in transaction register 4. The pseudonymised transaction data TDS* and/or the amount categorised transaction data is (re)sent to the monitoring register 6 or the participant unit TE in step 412. changed for the respective transaction data set. The encrypted transaction data set TDS is stored in the transaction register (step 404 after step 412, if applicable).


The pseudonymised transaction data set TDS* always has a higher level of anonymity than the (non-pseudonymised) transaction data set TDS. With this higher anonymity level, the pseudonymised transaction data set TDS* —in a default of the payment system BZ—can also be stored unencrypted in the coin register 2, monitoring register 6 and/or the transaction register 4 and used for further validity checks in the payment system BZ. This could improve the detection of fraud or manipulation in the payment system BZ by the payment system BZ itself, and an official request (court order) may not be necessary.



FIG. 5 shows an embodiment example of encryption and decryption of a transaction data set TDS. The remote instances 8a, 8b, 8c each have partial keys whose bitwise addition results in a private key part k of a cryptographic key (key pair). The private key part k is stored, for example, in a key store of the transaction register 4, for example a hardware security module of the transaction register 4.


The public key part K is derived from the private key part k and provided to the participant unit TE. The re-encryption step 303 in FIG. 3 of the generated transaction data set TDS or the re-encryption step 403 in FIG. 4 of the decrypted transaction data set TDS will then be performed with the public key part K. This asymmetric crypto system must be able to ensure that the public key part K is indeed the key part derived from the combined private key part k and that this is not a forgery by an impostor. Digital certificates confirming the authenticity of the public key part K serve this purpose. The digital certificate can itself be protected by a digital signature. The transaction data set TDS encrypted with the public key part K is stored in the transaction register 4.


Before using the private key part k to decrypt the stored encrypted transaction data set TDS, the subset or all remote instances must authenticate themselves to the transaction register 4. If authentication is successful, the transaction data set TDS is decrypted using the private key part k.


The generated transaction data set consisting of, for example, a transaction number, a recipient address (here from TE2), a sender address (here from TE1) and a monetary amount of the eMD C. The generated transaction data set may also be used in TE1 to log the transmitting 105 in order to rollback (ROLLBACK) or retry (RETRY) the transmitting 105 in the event of a transmission error.



FIG. 6 shows a further embodiment of the embodiment example of a system of FIG. 2. Reference is made to the executions of FIG. 2 to avoid repetition.


According to FIG. 6, at least one additional check value pi1 can be stored as a further data element in the electronic coin data set C. This check value pi1 is incremented during each direct transmission 105 of this electronic coin data set C between participant units TE1, TE2, i.e. terminals M1, M2 or security elements SE1, SE2 as participant units TE1, TE2.


In the payment system BZ, a counter value pi2 can also be kept or determined to include the check value pi, for example as the sum of the previous (registered) counter value pi2 and the check value pi1, to determine whether to return the coin data set C. Each action with coin data set C increases this counter value pi2. Different action types weight the counter value pi2 differently, so that, for example, a direct transfer of the coin data set C has a higher weight than a modification (splitting, combining, switching). In this way, the lifetime and the actions performed in it of a coin data set C are evaluated and criteria for its return are defined according to the actions performed. The check value pi1 and also the counter value pi2 represent the life cycle of the coin data set C, which is then used to decide whether to return it.


As already described in FIG. 3, a check value p can be provided in the payment system BZ in a participant unit TE (i.e. the terminals M1, M2 or security elements SE1, SE2 shown in FIG. 6), which represents the number of coin data sets C already transmitted without (directly) accompanied sending an encrypted transaction data set TDS to the transaction register 4. This check value p is compared with a threshold value X when a connection error is detected in step 307. This determines whether a further (offline) transmission 105 may be performed (payment system default) or not.



FIG. 6 shows the transaction register 4, which has already been described with FIGS. 2 to 5. In addition, the transaction register 4 can be in communication link with the monitoring register 6 in order to register pseudonymised transaction data sets TDS* in the monitoring register 6. For this purpose, according to step 410, for example, a participant unit identifier in the decrypted transaction data set TDS is replaced by a pseudonym P of the participant unit TE. Furthermore, according to step 411, for example, in addition or as an alternative to step 410, a monetary amount in the decrypted transaction data set TDS is replaced by an amount category. Steps 410 and/or 411 may be performed by an HSM in the transaction register 4. The pseudonymised transaction data TDS* and/or the amount categorised transaction data TDS* are sent to the monitoring register 6 according to step 412, while the encrypted transaction data sets TDS are stored in the transaction register 4.


In FIG. 6, a masked electronic coin data set Zi is calculated from the electronic coin data set Ci using equation (3), for example in SE1, and this masked coin data set Zi is registered in a monitoring register 6 together with at least the second check value pi2.


In SE2, the transmitted electronic coin data set Ci is obtained as Ci*. Upon obtaining the electronic coin data set Ci*, the SE2 is in possession of the digital money represented by the electronic coin data set Ci*. With direct transmission 105, it is available to the SE2 for further action.


Due to the higher trustworthiness when using SEs, SE1, SE2 can trust each other and in principle no further steps are necessary for transmitting 105. However, SE2 does not know whether the electronic coin data set Ci* is actually valid. To further safeguard transmitting 105, further steps may be provided in the method, as explained below.


To check the validity of the obtained electronic coin data set Ci*, the masked transmitted electronic coin data set Zi* can be calculated in SE2 using the—public—one-way function from equation (3). The masked transmitted electronic coin data set Zi* is then transmitted to the coin register 2 in step 104 and searched for there. If it matches a registered and valid masked electronic coin data set, the validity of the obtained coin data set Ci* is displayed to the SE2 and it is valid that the obtained electronic coin data set Ci* is equal to the registered electronic coin data set Ci. In one embodiment, the validity check can be used to determine that the obtained electronic coin data set Ci* is still valid, i.e. that it has not already been used by another processing step or in another transaction/action and/or has not been subject to further modification.


Preferably, a switching (=Switch) of the obtained electronic coin data set takes place afterwards.


The sole knowledge of a masked electronic coin data set Zi does not entitle to spend the digital money of the corresponding electronic coin data set Ci.


The sole knowledge of the electronic coin data set Ci entitles for payment, i.e. to perform a transaction successfully, especially if the coin data set Ci is valid, for example if the electronic coin data set Ci has an active status. The status is preferably set to an active status only upon obtaining the deletion confirmation of the SE1. There is a one-to-one relationship between the electronic coin data sets Ci and the corresponding masked electronic coin data sets Zi. The masked electronic coin data sets Zi are registered in the coin register 2, for example a public database. This registration 104 first makes it possible to check the validity of the electronic coin data set Ci, for example whether new monetary amounts have been created (in an illegal manner).


The masked electronic coin data sets Zi are stored in the coin register 2. All processing on the electronic coin data set Zi is registered there, whereas the actual transmitting of the digital money takes place in a (secret, i.e. not known to the public) direct transaction layer 3 of the payment system BZ. Moreover, in this payment system BZ, monitoring operations on the coin data set C and the participant unit TE can be recorded in a monitoring register 6.


To prevent multiple issuance or to ensure more flexible transmitting 105, the electronic coin data sets C can be modified. Table 1 below lists exemplary operations, with the specified command also executing a corresponding processing step:









TABLE 1







Number of operations that can be performed per processing


of a C in the TE or the issuing instance











command
create
create random
create
create range


or step
signature
number
masking
proof














generating
1
1
1
0 or 1


returning
1
0
1
0 or 1


splitting
1
1
3
0 or 1


connecting
1
0
3
1


switching
1
1
2
1









Other operations not listed in Table 1 may be required, such as changing the currency or redeeming the monetary amount in an account. Instead of the implementation listed, other implementations are also conceivable that imply other operations. Table 1 shows that for each coin data set, each of the processing operations (modifications) “create”, “return”, “split”, “connecting” and “switching” may provide for different operations “create signature”; “create random number”; “create masking”; “range check”, each of the processing operation being registered in the coin register 2 and appended there in invariant form to a list of previous processing operations for masked electronic coin data sets Zi. The operations of the processing operations “create” and “return” an electronic coin data set C are executed only at secure locations and/or only by selected instances, for example the issuing instance 1, while the operations of all other processing operations can be executed on the participant units TE, i.e. the terminals M or their security elements SE.


The number of operations for the individual processings is marked with “0”, “1” or “2” in Table 1. The number “0” indicates that a participant unit TE or the issuing instance 1 does not need to perform this operation for this processing of the electronic coin data set C. The number “1” indicates that the participant unit TE or the issuing instance 1 must be able to perform this operation once for this processing of the electronic coin data set C. The number “2” indicates that the participant unit TE or the issuing instance 1 must be able to perform this operation twice for this processing of the electronic coin data set.


In principle, in one embodiment, it can also be provided that an range check is also performed by the issuing instance 1 during generating and/or deleting.


Table 2 below lists the operations required for the coin register 2 and/or the monitoring register 6 for the individual processing operations:









TABLE 2







Number of operations that can be performed per processing of a C in the coin register

















retrace homomorphic




check
check validity

properties of



check
signature
of masked

masked electronic


command
signature
from security
electronic
retrace
coin data sets, i.e.


or step
from issuer
element
coin data set
range proof
adding or subtracting















generating
1
0
0
0 or 1
0


returning
1
0
1
0 or 1
0


splitting
0
1
1
2 or more
1


connecting
0
1
2 or more
1
1


switching
0
1
1
1
0









Other operations not listed in table 2 may be required. Instead of the listed implementation, other implementations are conceivable that imply other operations. All operations of table 2 can be performed in the coin register 2, which is a trusted instance, for example a server instance, for example a distributed trusted server, which ensures sufficient integrity of the electronic coin data sets C.


Table 3 shows the preferred components to be installed for the system participants in the payment system of FIG. 1:









TABLE 3







Preferred units in the system components













coin





register/monitoring



issuing
participant
register/transaction


command or step
instance
unit
register





random number generator
yes




(high security)


random generator

yes
—/—/yes


(deterministic)


PKI for signing
yes
yes
—/—/yes


PKI for signature check

(yes)
yes


read access
yes
yes
yes


write access
yes
yes
yes


returning the electronic
yes
yes



coin data set


transport encryption
yes
yes
—/—/yes


secure storage
(yes)
yes
—/—/yes


masking unit
yes
yes



range proof

yes



check range proof


yes/yes/—









Table 3 shows an overview of the preferred components to be used in each system participant, i.e. the issuing instance 1, a participant unit TE and the register instances, namely the coin register 2, the monitoring register 6, the transaction register 4.


The participant units TE can be designed by means of an e-wallet for electronic coin data sets Ci (with the check value p, pi1, pi2), i.e. as an electronic purse with a memory section in which a plurality of coin data sets Ci can be stored, and thus be implemented, for example, in the form of an application on a smartphone or IT system of a trader, a commercial bank or another market participant. Thus, the components in the participant unit TE, as shown in table 3, are implemented as software. It is assumed that the coin register 2, the transaction register 4 and/or the monitoring register 6 are based on a server or on a DLT and are operated by a number of trusted market participants.



FIG. 7 shows an alternative embodiment to FIG. 6 of the execution example of a system of FIG. 2. Reference is made to the executions of FIG. 2 and FIG. 6 to avoid repetition. The embodiments of FIG. 7 can also be combined with the embodiments of FIG. 6.



FIG. 7 shows an example of a payment system BZ with terminals M1 and M2 (as examples of participant units TE), an issuing instance 1, a coin register 2, a monitoring register 6 and a transaction register 4. The terminals M1 and M2 can also be devices or security elements SE1, SE2.


The coin register 2 contains a register 210 in which valid masked electronic coin data set Zi is stored. The electronic coin data set Ci represents a monetary amount vi. The electronic coin data set Ci is output to a first terminal M1. Electronic coin data sets Ci, preferably for which a masked electronic coin data set Zi is registered, can be used for payment. The masked electronic coin data set Zi can also be referred to as an amount-masked electronic coin data set, since the monetary amount υi for the coin register 2 is unknown (and also remains unknown in the further course). A receiver, here for example a second terminal M2, of the electronic coin data set Ci can check its validity with the help of the coin register 2. The coin register 2 can confirm the validity of the electronic coin data set Cu with the help of the masked electronic coin data set Zi. For the coin register 2, the masked electronic coin data set Zi is an anonymous electronic coin data set, especially since it does not know an owner of the associated electronic coin data set Ci. The anonymity level of a masked coin data set Zi in the register 201 of the coin register 2 is therefore level 1 (completely anonymous).



FIG. 7 shows that the second terminal M2 sends masked electronic coin data sets Zi* to the coin register 2 anonymously in an anonymous mode M2a, i.e., in particular, it sends only the masked electronic coin data set Zi*. The coin register 2 processes the anonymously sent masked electronic coin data set Zi* in an anonymous mode 2a, in which, for example, the second terminal M2 is only confirmed that the sent masked electronic coin data set Zi* is valid.


The coin register 2 stores in the register 210 anonymous (amount) masked coin data sets Zi of electronic coin data sets Ci of the issuing instance 1 or of modified electronic coin data sets of the terminals M.



FIG. 7 further shows that the second terminal M2 can also send masked electronic coin data sets Si* in a pseudonymised mode M2p to the monitoring register 6. For example, the second terminal M2 associates the masked electronic coin data set Zi* with a pseudonym PM2 and sends the pseudonymised masked electronic coin data set Si* to the monitoring register 6. The second terminal M2 could generate a pseudonymised masked electronic coin data set Si* by attaching the pseudonym PM2 to the masked electronic coin data set Zi*. In the embodiment shown, the second terminal M2 creates a signature over the masked electronic coin data set Zi* and adds the signature to the coin data set Zi*. The pseudonym PM2 can be, for example, the public key of the signature key pair. Alternatively, the pseudonym PM2 is a derivation from a participant identifier, such as terminal number, IMEI, IMSI or a similarly derived identifier.


The pseudonym P can be a derivative of the above-mentioned participant unit identifier. The pseudonym P may additionally be listed in the personal identifier 7 of the issuing instance 1 (or alternatively of a service provider, e.g. a wallet application provider or an online storage provider) next to the participant unit identifier. To protect the natural person, the pseudonym P can only be assigned to a natural person in a trusted instance, if applicable.


The monitoring register 6 processes the pseudonymously sent masked electronic coin data set Si* in a pseudonymous mode 2p, in which it is also confirmed to the second terminal M2 that the sent masked electronic coin data set Zi* is valid. However, the assignment of the masked electronic coin data set Zi to the pseudonym PM 2 is additionally stored in a data structure 220 of the monitoring register 6. As will become clear in the further embodiments, the data structure 220 can be used as a register for masked electronic coin data sets Zi still to be checked, i.e. it can also fulfil the function of a coin register 2. In pseudonymous mode 2p, the monitoring register 6 postpones or skips, in particular, a checking step performed in anonymous mode 2a (more frequently or always). In the checking step, it is checked—preferably further in ignorance of the monetary amount υi—whether the monetary amount υi of the masked electronic coin data set Zi is within a range.


The aspects described below are based at least in part on details of this embodiment of FIG. 2, 6 or 7. The more complex pseudonymous mode 2p or M2p is primarily described there, since the simpler anonymous mode 2a or M2a runs without a pseudonym (or signature). FIGS. 15 and 16, on the other hand, describe embodiments that can only optionally be combined with the details of the other embodiments.



FIG. 8 shows a data structure for a coin register 2 and/or a monitoring register 6 of the preceding figures. In FIG. 8, data of the coin register 2 and/or the monitoring register 6 are shown together as a table in a common data structure for illustration purposes. The registers 2, 6 register the masked electronic coin data sets Zi and their processing, if any. The coin register 2 and the monitoring register 6 can be housed in a common server instance and are only logically separated from each other in order to be able to reduce the computing effort for the individual checks by strict assignments. Alternatively, the registers 2, 6 are also physically separated from each other. Both registers 2, 6 are preferably located locally remote from the participant units TE and are housed in a server architecture, for example.


Each processing operation for a processing (creating, deactivating, splitting, connecting and switching) is registered in the coin register 2 and appended there, for example in unchangeable form, to a list of previous processing operations for masked electronic coin data sets Zi. The individual operations and their check results, i.e. the intermediate results of a processing operation, are recorded in the coin register 2. Although a continuous list is assumed in the following, this data structure can also be cleaned or compressed, if necessary according to predetermined rules, or provided separately in a cleaned or compressed form.


The processing operations “creating” and “deactivating”, which concern the existence of the monetary amount υi, per se, i.e. imply the creation and the destruction of money, require an additional authorisation by the issuing instance 1 to be registered (i.e. logged) in the coin register 2 and/or the monitoring register 6. The remaining processing operations (splitting, connecting, switching) do not require authorisation by the issuing instance 1 or by the command initiator (=payer, e.g. the first terminal M1). However, the other processing operations must be checked with regard to various check criteria.


A registration of the respective processing is realised, for example, by corresponding list entries in the database according to FIG. 8. Each list entry has further flags 25 to 28 which document the intermediate results of the respective processing which must be carried out by the coin register 2 and/or the monitoring register 6. Preferably, the flags 25 to 28 are used as an aid and are discarded by the coin register 2 and/or the monitoring register 6 after completion of the instructions.


For anonymous coin data sets, all checks must always be executed, so that all flags 25-28 could also be discarded. For pseudonymised coin data sets, on the other hand, a check can be omitted or executed later.


In FIG. 8, for example, the checks corresponding to flags 27b and 27c are not necessary for pseudonymised coin data sets because they are carried out later in a different form. The checking steps of flags 25, 26, 27a and 28, on the other hand, are necessary. In the following, we will refer in part to necessary or validity-relevant verification steps and to verifiable or validity-independent verification steps, since they are performed directly or indirectly. A coin data set can be treated as valid if the necessary checks have been carried out. The data in columns 24, 28 and 29 highlighted in bold in FIG. 8 are only relevant for coin data sets obtained pseudonymised and therefore primarily concern entries in the monitoring register 6.


An optional flag 29 can, for example, display the completion of processing. The flags 29 are in the state when a processing command is received, for example, and are set to the state “1” after all checks have been successfully completed (for flags 25-28) and are set to the state “0” if at least one check has failed. A (completion) flag 29 with the value “2” could display, for example, that only the necessary examinations were completed and that examinations that could be made up for were omitted. If checks for one or more entries are later made up by the terminal with the pseudonym, the flag can be set to the value “1”. Instead of using the completion flag 29 in this way, the flags 27b and 27c of the checks to be made up could of course also be used and/or a separate pseudonym flag could be used.


For example, a possible structure for a list entry of a coin data set comprises two columns 22a, 22b for a predecessor coin data set (O1, O2), two columns 23a, 23b for a successor coin data set (S1, S2), a signature column 24 for signatures of issuing entity (issuing entities) 1 and signatures of terminals M, and six marker columns 25, 26, 27a, 27b and 27c and 28. Each of the entries in columns 25 to 28 has three alternative states “-”, “1” or “0”.


Column 25 (O flag) displays whether a validation check was successful with regard to a predecessor electronic coin data set in column 22a/b. The “1” state indicates that a validity check revealed that the electronic coin data set of column 22a/b is valid and the “0” state indicates that a validity check revealed that the electronic coin data set of column 22a/b is invalid and the state “-” indicates that a validity check has not yet been completed. For multiple predecessor coin data sets, it is preferred to use a common O flag (both valid) rather than two separate O flags. Column 26 (C flag) displays whether an initial check calculation was successful for the masked electronic coin data sets. The first check calculation checks in particular whether the command is amount-neutral, i.e. primarily that the sum of the monetary amounts involved is zero. The state “1” means that a calculation was successful and the state “0” indicates that calculation was not successful and the state “-” displays that a calculation has not yet been completed.


For example, the calculation to be performed in column 26 is:





(ZO1+ZO2)−(ZS1+ZS2)−−0  (10)


Column 27a (R1 flag) displays whether a first check of a range proof or the range proof was successful. The same applies to the other columns 27b (R2 flag) and 27c (R3 flag). The state “1” means that a validity check showed that the range proofs or the range evidence could or could not be retraced and the state “0” indicates that a validity check showed that the range proofs or the range evidence could not or could not be retraced and the state “-” indicates that a validity check is not yet completed, was not successful. The first range proof of column 27a is always necessary for the coin data set(s) to be considered valid. A typical example of a necessary check is the check that the monetary amount is not negative (or none of the monetary amounts are negative). The second and third range proofs do not affect the validity of the coin data set and can be made up for pseudonymised masked coin data sets, for example in a later transaction of the pseudonym. The range proof of column 27b is used to check whether the monetary amount of the masked coin data set (or each coin data set) is below a maximum amount. The maximum amount can be pre-determined system-wide or for specific terminal types. For example, the range proof of column 27c compares a sum of monetary amounts (sent or) received by the participant unit TE in a specified time period, such as 24 hours, against a sum limit, or checks, for example, a transaction count per time period for the participant unit TE, such as a maximum of 5 per minute or 100 per day. The limit values can be predefined by the payment system BZ system-wide or defined for specific participant unit types (i.e. participant unit-specific). For example, a coffee machine of type X can only dispense four portions of hot drinks per minute due to the device and accordingly only four coin transactions per minute are permitted.


The column 28 (S flag) displays whether a signature of the electronic coin data set matches the signature of column 24, where state “1” indicates that a validity check revealed that the signature could be identified as that of the issuing instance and state “0” indicates that a validity check revealed that the signature could not be identified as that of the issuing instance and the state “-” indicates that a validity check has not yet been completed.


A change in the status of one of the flags (also referred to as a “flag”) requires authorisation by the coin register 2 and/or the monitoring register 6 and must then be stored unalterably in the data structure of FIG. 8. Processing is final in anonymous mode (or for an anonymous masked coin data set) if and only if the required flags 25 to 28 have been validated by the coin register 6, i.e. changed from the “0” state to the “1” state or the “1” state after the appropriate check. Processing is completed in pseudonymous mode (or for a pseudonymised masked coin data set) when the checks to flags 25 to 27a and 28 have been performed by monitoring register 6.


In the following, a data structure without completion flag 29 is assumed and the validity of anonymous coin data sets is considered first. In order to determine whether a masked electronic coin data set Z is valid, the coin register 2 searches for the last change affecting the masked electronic coin data set Z. The coin register 2 then checks whether the masked electronic coin data set Z is valid. It holds that the masked electronic coin data set Z is valid if the masked electronic coin data set Z is listed for its last processing in one of the successor columns 23a, 23b, if and only if that last processing has the corresponding final flag 25 to 28. It also applies that the masked electronic coin data set Z is valid, provided that the masked electronic coin data set Z is listed for its last processing in one of the predecessor columns 22a, 22b, if and only if this last processing has failed, i.e. at least one of the corresponding required states of the flags 25 to 28 is set to “0”.


If the masked electronic coin data set Z is not found in the coin register 2, it is invalid. It is also true that the anonymous masked electronic coin data set Z is not valid for all other cases. For example, if the last processing of the masked electronic coin data set Z is listed in one of the successor columns 23a, 23b, but this last processing never became final, or if the last processing of the masked electronic coin data set Z is in one of the predecessor columns 22a, 22b and this last processing is final.


The checks made by coin register 2 and/or monitoring register 6 to determine whether a processing is final are represented by columns 25 to 28: The state in column 25 displays whether the masked electronic coin data set(s) are valid according to predecessor columns 22a, 22b. The state in column 26 indicates whether the calculation of the masked electronic coin data set according to equation (10) is correct. The state in column 27a indicates whether the range checks for the masked electronic coin data set Z could be successfully verified. The state in column 28 indicates whether the signature in column 24 of the masked electronic coin data set Z is a valid signature of issuing instance 1.


The state “0” in a column 25 to 28 thereby displays that the verification was not successful. The status “1” in a column 25 to 28 indicates that the verification was successful. The state “-” in a column 25 to 28 displays that no check was carried out. The states can also have a different value, as long as a clear distinction can be made between success/failure of a check and it is evident whether a determining check was carried out.


As an example, five different processes are defined, which are explained in detail here. Reference is made to the corresponding list entry in FIG. 8.


For example, one processing is “generating” an electronic coin data set Ci. Generating in the direct transaction layer 3 by the issuing instance 1 involves selecting a monetary amount υi and creating an obfuscation amount ri, as described earlier with equation (1). As shown in FIG. 8, the “generating” processing does not require any entries/flags in columns 22a, 22b, 23b and 25 to 27. In the successor column 23a, the masked electronic coin data set Zi is registered. This registration is preferably done before transmitting 105 to a participant unit TE, in particular or already during generation by the issuing instance 1, in both cases executing equation (3) for this purpose. The masked electronic coin data set Zi is signed by the issuing instance 1 when it is generated, this signature is entered in column 24 to ensure that the electronic coin data set Ci has actually been generated by an issuing instance 1, although other methods may also be used for this purpose. If the signature of a obtained Ci matches the signature in column 24, the flag in column 28 is set (from “0” to “1”). The flags in columns 25 to 27 do not require a status change and can be ignored. The range proof is not needed because the coin register 2 and/or the monitoring register 6 can trust that the issuing instance 1 does not issue negative monetary amounts. However, in an alternative executing, it can be sent by the issuing instance 1 in the create command and checked by the coin register 2 and/or the monitoring register 6.


For example, one processing is “deactivating”. The deactivating, i.e. destroying money, causes the masked electronic coin data set Zi to become invalid after successful executing of the deactivate command by the issuing instance 1. One can therefore no longer process the (masked) electronic coin data set to be deactivated in the coin register 2 and/or in the monitoring register 6. To avoid confusion, the corresponding (non-masked) electronic coin data sets Ci should also be deactivated in the direct transaction layer 3. When “deactivating”, the predecessor column 22a is written to with the electronic coin data set Zi, but no successor column 23a, 23b is occupied. The masked electronic coin data set Zi shall be checked during deactivation to ensure that the signature matches the signature according to column 24 to ensure that the electronic coin data set Ci has indeed been created by an issuing instance 1, again other means may be used for this check. If the signed Zi sent in the deactivate command can be confirmed as signed by issuing instance 1, flag 28 is set (from “0” to “1”). The flags according to columns 26 to 27 do not require a status change and can be ignored. The flags according to columns 25 and 28 are set after appropriate verification.


A processing (modification) is, for example, “splitting”. The splitting, i.e. dividing an electronic coin data set Zi into a number n, for example 2, of electronic coin data sets Zj and Zk is first carried out in the direct transaction layer 3, as still shown in FIGS. 9, 11 and 12, whereby the monetary amounts υj and the obfuscation amount rj are generated. υk and rk are obtained by equations (7) and (8). In the coin register 2 and/or the monitoring register 6, the flags 24 to 27 are set, the predecessor column 22a is described by the electronic coin data set Zi, successor column 23a is described by Zj and successor column 23b is described by Zk. The status changes required according to columns 24 to 27 are made after the corresponding check by coin register 2 and/or monitoring register 6 and document the respective check result. The flag according to column 28 is ignored, especially in anonymous mode. A first range proof R1 according to column 27a must be provided, for example, to show that no monetary amount is negative. A second range proof R2 in column 27b is not necessary because the successor monetary partial amounts are always smaller than the initial monetary amount of the predecessor. A cumulative range entry R3 in column 27c is also usually not necessary (no new monetary amounts). Column 24 is used for the entry of a participant unit TE generated signature splitting the coin data set.


For example, one processing is “connecting”. Connecting, i.e. merging, two electronic coin data sets Zi and Zj into one electronic coin data set Zm is first performed in the direct transaction layer 3, as still shown in FIGS. 10 and 11, where the monetary amount υm and the obfuscation amount rm are calculated. In the coin register 2 and/or the monitoring register 6, the flags 25 to 28 are set, the predecessor column 22a is described with the electronic coin data set Zi, predecessor column 22b is described with Zj and successor column 23b is described with Zm. The flags in columns 25 to 28 require status changes and the coin register 2 and/or monitoring register 6 performs the corresponding checks. A first range proof R1 according to column 27a must be provided to show that no new money has been generated. A second range proof R2 in column 27b is useful, as the new monetary amount of the successor could be larger than a maximum value. A sum range proof R3 in column 27c is also usually useful, as the terminal could be using newly received predecessors. The flag according to column 28 can be ignored. Column 24 is used to generate an entry of a participant unit TE connecting the coin data set.


Another processing is, for example, “switching”. The switching is necessary when an electronic coin data set has been transmitted to another participant unit TE and re-issuing by the transmitting participant unit TE is to be prevented. During switching, the electronic coin data set Ck obtained from the first participant unit TE1 is exchanged for a new electronic coin data set Cl with the same monetary amount. The new electronic coin data set Cl is generated by the second participant unit TE2. This switching is necessary to invalidate (invalidate) the electronic coin data set Ck obtained from the first participant unit TE2, thus avoiding re-issuing the same electronic coin data set Ck. This is because, as long as the electronic coin data set Ck is not switched, since the first participant unit TE1 is aware of the electronic coin data set Ck, the first participant unit TE1 can pass this electronic coin data set Ck to a third participant unit TE. The switching is done, for example, by adding a new obfuscation amount radd to the obfuscation amount rk of the obtained electronic coin data set Ck, thereby obtaining an obfuscation amount rl that only the second participant unit TE2 knows. This can also be done in the coin register 2 or the monitoring register 6. To prove that only a new obfuscation amount radd has been added to the obfuscation amount rk of the masked obtained electronic coin data set Zk, but the monetary amount has remained the same, and thus equation (11):





υkl  (11)


holds, the second participant unit TE2 must be able to prove that Zl-Zk can be represented as a scalar multiple of G, i.e. as radd*G. This means that only one obfuscation amount radd has been generated and the monetary amount of Zl is equal to the monetary amount of Zk, i.e. Zl=Zk+radd*G. This is done by generating a signature with the public key Zl−Zk=radd*G.


The modifications “splitting” and “connecting” to an electronic coin data set can also be delegated from one participant unit TE1 to another participant unit TE, for example if a communication link to the coin register 2 and/or to the monitoring register 6 is not available.



FIG. 9 shows an embodiment example of a payment system BZ according to the invention for the actions of “splitting”, “connecting” and “switching” electronic coin data sets C. In FIG. 9, the first participant unit TE1 has obtained the coin data set Ci and now wishes to perform a payment transaction not with the entire monetary amount vi, but only with a partial amount υk. To do this, the coin data set Ci is split. To do this, the monetary amount is first divided:





υijk  (12)


Each of the obtained amounts υj, υk, must be greater than 0, because negative monetary amounts are not permitted.


In a preferred embodiment, the monetary amount υi is split symmetrically into a number n of equally large partial monetary amounts υj.





υji/n  (12a)


The number n is an integer greater than or equal to two. For example, a monetary amount of 10 units can be split into 2 partial amounts of 5 units (n=2) or into 5 partial amounts of 2 units each (n=5) or 10 partial amounts of one unit each (n=10).


In addition, new obfuscation amounts are derived:






r
i
=r
j
−r
k  (13)


When symmetrically splitting, an individual unique obfuscation amount rj is formed in participant unit TE1 for each coin partial amount, where the sum of the number n of obfuscation amounts rj of the coin data sets is equal to the obfuscation amount ri of the split coin data set:






r
ik=1nrj_k  (13a)


In particular, the last obfuscation partial amount rj_n is equal to the difference between the obfuscation amount ri and the sum of the remaining obfuscation partial amounts:






r
j_n
=r
i−Σk=1n−1rj k  (13b)


In this way, the obfuscation amounts rj_1 to rj_n−1 can be chosen arbitrarily and the rule of equation (13a) is satisfied by calculating the “last” individual obfuscation amount rj_n accordingly.


For asymmetric splitting, masked coin data sets Zj and Zk are obtained from coin data sets Cj and Ck according to equation (3) and registered in coin register 2 and/or monitoring register 6. For splitting, the predecessor column 22a is described by the coin data set Zi, the successor column 23a by Zj and the successor column 23b by Zk. Additional information for the range proof (zero-knowledge-proof) is to be generated. The flags in columns 25 to 27 require status change and the coin register 2 and/or the monitoring register 6 performs the corresponding checks. The flag according to column 28 and the status according to column 29 are ignored.


In the case of symmetrical splitting, a signature is calculated in the respective participant unit TE. For this purpose, the following signature key sig is used for the kth coin part record Cj_k:





sig−ri−n·rj_k  (13c)


Where n is the number of symmetrically split coin part records. In the case of symmetrical splitting, the signature of the kth coinage record Cj_k can be verified according to (13c) with the following verification key Sig:





Sig=Zi−n·Zj_k  (13d)


Where Zj_k is the masked kth coin part record and n is the number of symmetrically split coin part records. This simplification results from the relationship with equation (3):






Z
i
−n·Z
j_k=(υi−n·υj_kH+(ri−n·rj_kG  (13e)


where, due to the symmetry properties of splitting, the following applies:





i−n·υj_kH=0  (13f)


so that equation 13e is simplified to:






Z
i
−n·Z
j k−(ri−n·rj kG  (13g)


The simplification due to equation 13f makes it possible to completely dispense with zero-knowledge proofs, whereby the application of symmetrical splitting saves enormous computing power and data volume.


Then, a coinage data set, here Ck is transmitted from the first participant unit TE1 to the second participant unit TE2. To prevent double spending, a switching operation is useful to exchange the electronic coin data set Ck obtained from the first participant unit TE1 for a new electronic coin data set Cl with the same monetary amount. The new electronic coin data set Cl is generated by the second participant unit TE2. The monetary amount of the coin data set Cl is taken over and not changed, see equation (11).


Then, according to equation (14), a new obfuscation amount radd is added to the obfuscation amount rk of the obtained electronic coin data set Ck,






r
l
=r
k
+r
add  (14)


thereby obtaining an obfuscation amount rl known only to the second participant unit TE2. In order to prove that only a new obfuscation amount radd has been added to the obfuscation amount rk of the obtained electronic coin data set Zk, but that the monetary amount has remained the same (υki), the second participant unit TE2 must be able to prove that Zl-Zk can be represented as a multiple of G. This is done by means of public signature radd according to equation (15):






R
add
=r
add
·G=Z
l
−Z
k=(νl−νk)*H+(rk+radd−rk)*G  (15)


where G is the generator point of the ECC. Then the coin data set Cl to be switched is masked using equation (3) to obtain the masked coin data set Zl. In the coin register 2 and/or the monitoring register 6, the private signature radd can then be used to sign, for example, the masked to-be-switched electronic coin data set Zl, which is taken as proof that the second participant unit TE2 has only added an obfuscation amount radd to the masked electronic coin data set and no additional monetary value, i.e. υ1k.


The proof is as follows:






Z
kk·H+rk·G






Z
ll·H+rl·G=υk·H+(rk+raddG






Z
l
−Z
k=(rk+radd−rkG





=radd·G  (16)



FIG. 10 shows an example of a payment system according to the invention for connecting (also called combining) electronic coin data sets. Here, the two coin data sets Ci and Cj are obtained in the second participant unit TE2. Following the splitting according to FIG. 9, a new coin data set Zm is obtained by adding both the monetary amounts and the obfuscation amount of the two coin data sets Ci and Cj. Then the obtained coin data set Cm to be connected is masked and the masked coin data set Zm is registered in the coin register 2. Then, when “connecting”, the signature of the second participant unit TE2 is entered as it has obtained the coin data set Ci and Cj.


When combined by the payment system BZ, the highest of the two individual check values of the respective electronic coin records Ci and Cj is determined. This highest check value is taken as the check value Ci and Cj of the combined electronic coin data set.


Alternatively, when combining (=connecting) by a payment system BZ, a new check value is determined from the sum of all check values of the electronic coin data records Ci and Cj divided by the product of the number (here two) of coin data records Ci and Cj with a constant correction value. The correction value is constant for the payment system. Preferably, the correction value is greater than or equal to 1. Preferably, the correction value is dependent on a maximum deviation of the individual check values of the electronic coin data sets Ci and Cj or on a maximum check value of one of the electronic coin data sets Ci and Cj. Further preferably, the correction value is less than or equal to 2. This new check value is adopted as the check value of the combined electronic coin data set Cm.



FIGS. 11 and 12 each show an embodiment example of a method flow diagram of a method 100. FIGS. 11 and 12 are explained together below. In optional steps 101 and 102, a coin data set is requested and provided on the part of the issuing instance 1 to the first participant unit TE1 after the electronic coin data set is created. A signed masked electronic coin data set is sent to the coin register 2 and/or the monitoring register 6 in step 103. In step 103, masking of the obtained electronic coin data set Ci is performed according to equation (3) and signing is performed in step 103p according to equation (3a). Then, in step 104, the masked electronic coin data set Zi is registered in the coin register 2 or the monitoring register 6. Optionally, the participant unit TE1 can switch the obtained electronic coin data set, in which case a signature Si would be registered in the coin register 2 or the monitoring register 6. In step 105, transmitting of the coin data set Ci in the direct transaction layer 3 to the second participant unit TE2 takes place. In optional steps 106 and 107, a validity check with prior masking is performed, in which, in the good case, the coin register 2 and/or the monitoring register 6 confirm the validity of the coin data set Zi or Ci.


In the optional step 108, the switching of a obtained coin data set Ck (of course, the obtained coin data set Ci could also be switched) to a new coin data set Ci is then carried out, whereby the coin data set Ck becomes invalid and double spending is prevented. To do this, the monetary amount υk—of the transmitted coin data set Ck is used as the “new” monetary amount vi. In addition, as already explained with equations (14) to (17), the obfuscation amount rl is created. The additional obfuscation amount radd is used to prove that no new money (in the form of a higher monetary amount) was generated by the second participant unit TE2. Then the masked coin data set is signed and the signed masked coin data set Zl to be switched is sent to the coin register 2 and/or the monitoring register 6 and the switching from Ck to Cl is instructed. In addition, a signature Sk is created by the first participant unit TE1 or the second participant unit TE2 and stored in the coin register 2 and/or the monitoring register 6. In addition or alternatively, a signature Sl could also be created and deposited in the coin register 2 and/or monitoring register 6 if sending participant units TE were registered instead of receiving participant units TE.


In step 108′, the corresponding check is made in coin register 2 and/or monitoring register 6, entering Zk in column 22a according to the table in FIG. 8 and the coin data set Zl to be rewritten in column 23b. A check is then made in coin register 2 and/or monitoring register 6 to see whether Zk is (still) valid, i.e. whether the last processing of Zk is entered in one of the columns 23a/b (as proof that Zk has not been further split or deactivated or connected) and whether a check for the last processing has failed. In addition, Zl is entered in column 23b and the flags in columns 25, 26, 27 are initially set to “0”. Now a check is made whether Zl is valid, whereby the check according to equations (16) and (17) can be used. In the good case, the flag in column 25 is set to “1”, otherwise to “0”. Now a check is made, the calculation according to equation (10) shows that Zk and Zl are valid and the flag in column 26 is set accordingly. Furthermore, it is checked whether the ranges are conclusive, then the flag is set in column 27. Then the signature Sl is verified with the corresponding public verification key present in the coin register 2 and/or the monitoring register 6 and logged accordingly. If all checks have been successful and this has been recorded accordingly in the coin register 2 and/or the monitoring register 6, the coin data set is considered switched. I.e. the coin data set Ck is no longer valid and from now on the coin data set Cl is valid. Double-issuing is no longer possible if a third participant unit TE inquires about the validity of the (double-spend) coin data set at the coin register 2 and/or the monitoring register 6. When verifying the signature, it is possible to check in pseudonymous mode whether the second participant unit TE2 has exceeded a monetary amount limit. The check is performed with respect to a time unit, for example a daily limit could be monitored with it. If the limit is exceeded, the coin register 2 and/or the monitoring register 6 first refuses to switch the coin data set Cl and requests the second participant unit TE2 to deanonymise. System-dependent deanonymised switching may be permitted.


In optional step 109, connecting two coin data sets Ck and Ci to a new coin data set Cm is performed, invalidating the coin data sets Ck, Ci preventing double spending. For this purpose, the monetary amount υm is formed from the two monetary amounts υk and υi. For this purpose, the obfuscation amount rm is formed from the two obfuscation amounts rk and ri. In addition, the masked coin data set Zm to be connected is obtained by means of equation (3) and this is sent (together with other information) to the monitoring register 6 and/or the coin register 2 and connecting is requested as processing. In addition, a signature Sk and a signature Si are generated and communicated to the monitoring register 6 and/or the coin register 2.


In step 109′, the corresponding check is made in the coin register 2 and/or the monitoring register 6. In the process, Zm is entered in column 23b according to the table in FIG. 2, which also corresponds to a transcription. A check is then made in the coin register 2 and/or the monitoring register 6 as to whether Zk and Zi are (still) valid, i.e. whether the last processing of Zk or Zi is entered in one of the columns 23a/b (as proof that Zk and Zi have not been further split or deactivated or connected) and whether a check for the last processing has failed. In addition, the flags in columns 25, 26, 27 are initially set to “0”. Now a check is made whether Zm is valid, whereby the check according to equations (16) and (17) can be used. In the good case, the flag in column 25 is set to “1”, otherwise to “0”. Now a check is made, the calculation according to equation (10) shows that Zi plus Zk equals Zm and accordingly the flag in column 26 is set. Furthermore, it is checked whether the ranges are conclusive, then the flag is set in column 27. When checking the signature, it can be checked whether the second participant unit TE2 has exceeded a limit value for monetary amounts. The check is made with respect to a time unit, for example, a daily limit could be monitored with it. If the limit is exceeded, the coin register 2 and/or the monitoring register 6 first refuses to connect the coin data set Cm and requests the second participant unit TE2 to deanonymise. De-anonymised connecting may then be permitted.


In optional step 110, an asymmetric splitting of a coin data set Ci into two coin data sets Ck and Cj is performed, whereby the coin data set Ci is invalidated and the two asymmetrically split coin data sets Ck and Cj are to be made valid. In an asymmetric splitting, the monetary amount Di is split into monetary partial amounts υk and υj of different sizes. For this purpose, the obfuscation amount ri is split into the two obfuscation amounts rk and rj. In addition, the masked coin data sets Zk and Zj are obtained by means of equation (3) and sent to the coin register 2 and/or the monitoring register 6 with further information, for example the range checks (zero-knowledge-proofs), and the splitting is requested as processing. In addition, a signature Si is created and sent to coin register 2 and/or monitoring register 6.


In step 110′, the corresponding check is made in coin register 2 and/or monitoring register 6, with Zj and Zk being entered in columns 23a/b according to the table in FIG. 2. A check is then made in the monitoring register 6 and/or the coin register 2 as to whether Zi is (still) valid, i.e. whether the last processing of Zi is entered in one of the columns 23a/b (as proof that Zi has not been further split or deactivated or connected) and whether a check for the last processing has failed. In addition, the flags in columns 25, 26, 27 are initially set to “0”. Now a check is made whether Zj and Zk are valid, whereby the check according to equations (16) and (17) can be used. In the good case, the flag in column 25 is set to “1”. Now a check is made, the calculation according to equation (10) shows that Zi is equal to Zk plus Zj and accordingly the flag in column 26 is set. Furthermore, it is checked whether the ranges are conclusive, then the flag is set in column 27. When checking the signature, it can be checked whether the second participant unit TE2 has exceeded a limit value for monetary amounts. The check is made with respect to a time unit, for example, a daily limit could be monitored with it. If the limit is exceeded, the coin register 2 and/or the monitoring register 6 first refuses to split the coin data set Ci and requests the second participant unit TE2 to deanonymise. De-anonymised splitting may then be permitted.



FIG. 13 shows an embodiment example of a first participant unit TE1 according to the invention. The first participant unit TE1 may be a device M1 in which a security element SE1 is inserted. For simplicity, the term device M1 will be used hereinafter. In the device M1, electronic coin data sets Ci can be stored in a data memory 10, 10′. In this case, the electronic coin data sets Ci may be located on the data memory 10 of the device M1 or may be available in an external data memory 10′. When using an external data memory 10′, the electronic coin data sets Ci could be stored in an online memory, for example a data memory 10′ of a digital wallet provider. In addition, private data memory, for example a network-attached-storage, NAS in a private network could also be used.


In one case, the electronic coin data set Ci is shown as a printout on paper. In this case, the electronic coin data set may be represented by a QR code, an image of a QR code, or may be a file or a string of characters (ASCII).


The device M1 has at least one interface 12 available as a communication channel for outputting the coin data set Ci. This interface 12 is for example an optical interface, for example for displaying the coin data set Ci on a display unit (display), or a printer for printing out the electronic coin data set Ci as a paper printout. This interface 12 can also be a digital communication interface, for example for near field communication, such as NFC, Bluetooth, or an internet-enabled interface, such as TCP, IP, UDP, HTTP or accessing a smart card as a security element. For example, this interface 12 is a data interface such that the coin data set Ci is transmitted between devices via an application, such as an instant messenger service, or as a file or string.


In addition, the interface 12 or another interface (not shown) of the device M1 is arranged to interact with the coin register 4. The device M1 is preferably online capable for this purpose.


In addition, the device M1 may also have an interface for receiving electronic coin data sets. This interface is arranged to receive visually presented coin data sets, for example by means of a capture module such as a camera or scanner, or digitally presented coin data sets, received via NFC, Bluetooth, TCP, IP, UDP, HTTP or coin data sets presented by means of an application.


The device M1 also comprises a computing unit 13 capable of performing the coin data set masking method and coin data set processing operations described above.


The device M1 is online capable and can preferably detect when it is connecting to a WLAN by means of a location detection module 15. Optionally, a specific WLAN network can be marked as preferred (=location zone) so that the device M1 executes special functions only if it is logged into this WLAN network. Alternatively, the location detection module 15 detects when the device M1 is in predefined GPS coordinates including a defined radius and performs the special functions according to the location zone thus defined. This location zone can be inserted into the unit M1 either manually or via other units/modules. The special functions that the device M1 performs when the location zone is detected are, in particular, transmitting electronic coin data sets from/to the external data memory 10 from/to a safe module 14 and, if necessary, transmitting masked coin data sets Z to the coin register 4 and/or the monitoring register 6, for example as part of the above-mentioned processing operations on a coin data set. The device M1 is thus arranged to execute the method according to FIG. 3. The device M1 is arranged to create and encrypt a transaction data set TDS. The device M1 is arranged to initiate a communication to a transaction register. The device M1 is arranged to send the encrypted transaction data set TDS to the transaction register. The device M1 is arranged to attach metadata (in plain text) to the transaction data set TDS. The M1 device is arranged to locally (temporarily) store the transaction data set TDS.


In the simplest case, all coin data sets Ci are automatically connected to a coin data set in the device M1 after obtaining (see connecting-processing or connecting-step). That is, as soon as a new electronic coin data set is received, a connecting or switching command is sent to the coin register 4. The device M1 can also prepare electronic coin data sets in algorithmically defined denominations and hold them in the data memory 10, 10′ so that a payment process is possible even without a data connection to the coin register 4 and/or monitoring register 6.



FIG. 14 shows a payment system for better understanding. The overall system according to the invention comprises an issuing instance (central bank) la. In addition, further issuing instances 1b, 1c can be provided, which for example issue electronic coin data sets in another currency. Furthermore, at least one payment system BZ is shown in which at least one coin register 2, one monitoring register 6 and one transaction register 4 of the payment system BZ are provided in order to carry out a registration of the coin data sets Ci or Zi and to check and record the modifications to the coin data set Ci. The issuing instance 1a may also be provided as part of the payment system BZ. In addition, banking instance(s) may be located between the issuing instance 1a-c and the payment system BZ. For example, registers 2, 4, 6 are housed together in a server instance where they are logically separated from each other. Alternatively, the registers 2, 4, 6 are also spatially/physically separated from each other. The transaction register 4 can also be arranged as a unit external to the payment system BZ. In addition, a judicial/court authority 9 is shown which, in the event of suspected fraud, requests a judicial request for encrypting encrypted transaction data sets TDS from the payment system BZ (or directly from the transaction register). Remote instances 8a-c with corresponding partial keys are also shown to provide their partial keys to the transaction register 4 in case of a request to obtain a cryptographic key as a decryption key.


In addition, in FIG. 14, a plurality of subscribers, shown as terminals Mx (with respective SEx), is provided. The terminals M1 to M6 can directly exchange coin data sets Ci in the direct transaction layer 3. For example, terminal M5 transmits a coin data set to terminal M4. For example, terminal M4 transmits the coin data set to terminal M3. For example, terminal M6 transmits a coin data set to terminal M1. In each sending terminal Mx or each receiving terminal Mx, the check value pi1 of the coin data set to be sent or received and, if applicable, the counter value pi2 are used to check whether the coin data set is displayed at the payment system and/or whether the coin data set is to be returned at the issuing instance 1a. For example, the payment system BZ uses the check value pi1 or a counter value pi2 derived from the check value pi1 to check for each coin data set C whether the coin data set C is to be returned or not. In addition, a check value is provided in each terminal Mx to monitor a number of transaction data sets TDS that have not yet been transmitted despite coin data sets that have been transmitted.


In FIG. 15, a flow chart of a method is shown, by which, for example, compliance with a limit value for monetary amounts per unit of time is made possible.


In the upper part of the figure, the payment system BZ consisting of three terminals M1, M2, M3 is shown. In the lower part of the figure three data structures 910, 920, 930 of the respective registers 2, 4, 6 are shown. The valid masked coin data sets Zi are stored in the data structure 910 of the coin register 2. The data structure 920 of the monitoring register 6 comprises the assignment of pseudonymously sent masked coin data sets to the pseudonym and of can be considered as monitoring register 6 still to be checked pseudonymously sent coin data sets. Based on the data in data structure 920, monitoring register 6 can decide whether a range proof is requested for a pseudonym. Encrypted transaction data sets TDS are stored in the transaction register data structure 930.


The following transactions were performed:


1. The first terminal M1 has split a coin 901. the coin register 2 therefore knows that the coin Ci is a result of this splitting and stores the masked coin data set Zi in the data structure 910. the first terminal M1 could send the split to the monitoring register 6 anonymously or pseudonymously. In the illustration, it is assumed that terminals M1 and M3 send their masked coin data sets to monitoring register 6 anonymously.


2. The first terminal M1 sends the coin Cl directly to the second terminal M2 in a direct transmission step 902. Neither the coin register 2 nor the monitoring register 6 obtain any information about this. The first terminal M1 generates a transaction data set TDS902 relating to the transmission step 902, encrypts this transaction data set TDS902 and sends it to the transaction register 4. The encrypted transaction data set TDS902 contains an identifier of the first terminal M1, an identifier of the second terminal M2 and the monetary amount υ1 of the coin C1.


3. The second terminal M2 converts (switches) 903 the coin C1 to the coin C2. The new masked coin data set Z2 is stored in the data structure 910 of the coin register 2 and the old masked coin data set Z1 is deleted (or marked as invalid). The second terminal M2 sends its masked (or at least the represented) coin data sets pseudonymised to the monitoring register 6. Thus, the monitoring register 6 also obtains the information that the second terminal M2 with the pseudonym PM2 has received the coin C1 (and now possesses coin C2) and accordingly stores in the data structure 920 of the monitoring register 6 the masked coin data set Z2 (and/or the masked coin data set Z1) for PM2. In addition, the monitoring register 6 will skip at least one verification step, such as a range proof for the coin data set Z2 or a sum range proof for the terminal M2.


4. The second terminal M2 sends the coin C2 to the third terminal M3 in another direct transmission step 905. Neither the coin register 2 nor the monitoring register 6 obtains any information about this. The second terminal M2 generates a transaction data set TDS905 relating to the transmission step 905, encrypting this transaction data set TDS905 and sending it to the transaction register 4. The encrypted transaction data set TDS905 includes an identifier of the second terminal M2, an identifier of the third terminal M3, and the monetary amount υ2 of the coin C2.


5. In step 904, the third terminal M3 connects the received coin C2 to the connected coin C3 and sends this information with anonymous masked coin data sets to the coin register 2. The coin register 2 executes all verification steps, i.e. in particular all range proofs for the involved masked coin data sets Z2 . . . and Z3 or also a sum range proof for the third terminal M3. The coin register 2 only then deletes the masked coin data set Z2 (as well as the other coin data sets of the operation) from the data structure 910 and stores the new masked coin data set Z3 as a valid masked coin data set.


6. The third terminal M3 sends the coin C3 directly to the second terminal M2 in step 906. Neither the coin register 2 nor the monitoring register 6 obtains any information about this. The third terminal M3 generates a transaction data set TDS906 relating to the transmitting step 906, encrypting this transaction data set TDS906 and sending it to the transaction register 4. The encrypted transaction data set TDS906 includes an identifier of the third terminal M3, an identifier of the second terminal M2 and the monetary amount υ3 of the coin C3.


7. In a further step 903, the second terminal M2 converts (switches) the coin C3 to the coin C4 and sends a masked coin data set Z4 together with its pseudonym to the monitoring register 6. The monitoring register 6 obtains the information and performs the necessary checks. Using the data structure 920, the monitoring register 6 determines whether one or more checks should now be made up for the pseudonym of the terminal M2. If the criterion for a catching up, such as time lapse or number of transactions for a pseudonym, is not yet fulfilled, only the further masked coin data set Z4 for the pseudonym is noted in the data structure 920 of the monitoring register 6. The coin register 2 stores the masked coin data set Z4 in the data structure 910 and deletes the masked coin data set Z3 there. If, on the other hand, a criterion for catching up on the verification step is fulfilled, it first executes the catching up of the verification step (or its equivalent).


In the concrete example, the monitoring register 6 has the information that the second terminal M2 had the coin C2 (see step 3). Since the sum of the monetary amounts of coin C2 and coin C4 could exceed a coin threshold, monitoring register 6 requests a sum range proof (or sum range confirmation) from the second terminal M2. The sum range proof shows that the sum of the monetary amounts of coins C2 and C4 does not yet exceed the—for example daily—limit of transactions for the second terminal M2. The monitoring register 6 can also monitor a limit for a time-independent number of transactions (range proof after 3/5/10/ . . . transactions). As an alternative or in addition to a cumulative check of several coin data sets, the monitoring register 6 can make up a range check for the individual coin data sets associated with the pseudonym PM2 in the data structure 920 of the monitoring register 6 (Is the monetary amount of each coin data set Z2 and Z4 less than X?). If checks have been successfully made up, the corresponding records in the data structure 920 of the monitoring register 6 can also be deleted.


The transaction register 4 has the transaction data sets TDS902, TDS905 and TDS906 in encrypted form in its data structure 930.


In an embodiment not shown in FIG. 15, the transaction data sets are decrypted and pseudonymised. During pseudonymisation, the identifiers of the terminals M1 to M3 are replaced by the pseudonyms P and the respective amount is converted into amount categories. The pseudonymised unencrypted transaction data sets are sent to the monitoring register 6. As the sum of the monetary amounts of coin C2 and coin C4 could exceed a coin threshold, the monitoring register 6 requests a sum range proof (or sum range confirmation) from the second terminal M2. Alternatively, the amount categories in the pseudonymised transaction data sets TDS* are meaningful such that the monitoring register 6 can perform the sum range proof itself using the pseudonymised transaction data sets TDS*. As an alternative or in addition to a sum check, the monitoring register 6 can now also make up for a range check for the individual coin data sets using the pseudonymised transaction data sets TDS*.



FIG. 16 shows another example of an operation in a payment system BZ with masked coin data sets. A first terminal M1 sends anonymous masked coin data sets to the coin register 2 in steps 151. A second terminal M2, on the other hand, sends pseudonymised masked coin data sets to the monitoring register 6 in steps 161.


The coin register 2 responds to each of the anonymous sending steps 151 of the first terminal M1 (in its anonymous mode) with a (catch-up) check for the masked coin data set or the first terminal M1. The additional necessary checks, if any, are not shown in FIG. 11. In step 152, the coin register 2 requests a range proof for each masked coin data set that the monetary amount of the masked coin data set from step 151 is below a maximum value (or a corresponding range confirmation). Alternatively or additionally, at step 152, the coin register 2 requests a sum range proof (or confirmation) from the first terminal M1. The requested proof (or proofs) shall be generated by the first terminal M1 in step 153 and sent in step 154 in order for the (at least one) masked coin data set of step 151 to be treated as valid in the coin register 2.


The monitoring register 6 responds to the first transmitting step 161 of the second terminal M2 (in its pseudonymous mode) by skipping a (catch-up) check for the masked coin data set or the second terminal M2. The pseudonymously sent masked coin data set is registered as valid. For example, necessary checks not shown here take place, but do not require further communication with the second terminal M2. As previously described in other examples, the monitoring register 6 stores a mapping between the pseudonym and the masked coin data set(s) sent pseudonymously. In the example shown, the monitoring register 6 also responds in an analogous manner to a second (or further) transmission steps 161 of the second terminal M2. In each case, it checks for the pseudonym whether a catch-up criterion is fulfilled.


Only in the third step 161 shown does the monitoring register 6 determine that a check is to be made up for the pseudonym. It sends a request 162 to the second terminal M2 to create, for example, range proofs for multiple coin data sets or a sum range proof. In step 163, the second terminal M2 creates a plurality of range proofs, a sum range proof or a sum range confirmation and sends them to the monitoring register 6 in step 164. In step 163, for example, a plurality of coin data sets of the second terminal M2 are selected and summed over their monetary amounts. These coin data sets concern either only pseudonymised coin data sets or anonymous and pseudonymised coin data sets (in this case, the masked coin data sets that have already been sent are used and the sum is formed from the monetary amounts of the corresponding unmasked coin data sets). The selection can be made on the basis of criteria that are either known to the system or transmitted from the monitoring register 6 in step 162. The criteria are, for example, a period of time, in particular a predefined period of time in which a sum of all monetary amounts should/must not exceed a certain range, for example a monetary amount x euros per time unit y. The criterion can alternatively or additionally be a list in the first terminal M1 or the monitoring register 6. This makes a certain randomisation of the range possible, with which the system is further secured. The sum formed is then matched against the range (and using the criterion if applicable). In step 164, the requested sum range confirmation (or requested sum range proof) is transmitted from the second terminal M2 to the monitoring register 6.


Since a payment transaction (transmitting coin data sets) of a large monetary amount can also be split into several payment transactions of smaller monetary amounts, each of which could be below a range, the method defines the range (=limit), if necessary, on a terminal-specific and time period-dependent basis. The range usually concerns a sum of all transactions within a determining time unit that are received and/or sent by a terminal. A mechanism is therefore provided for determining what the sum of all monetary amounts sent or received by a terminal is within a determined unit of time.


Within the scope of the invention, all elements described and/or drawn and/or claimed may be combined with each other as desired.

Claims
  • 1.-44. (canceled)
  • 45. A method in a first participant unit comprising an electronic coin data set registered in a coin register of a payment system, with the method steps: generating a transaction data set with respect to transmitting the electronic coin data set to a second participant unit, including a second security element, or with respect to a modification of the electronic coin data set to be registered at the coin register;encrypting the generated transaction data set with a cryptographic key, the cryptographic key being composed of at least two cryptographic subkeys, of different remote instances respectively; andinitiating a communication link to a transaction register to send the encrypted transaction data set to the transaction register.
  • 46. The method according to claim 45, wherein the first security element is inserted ready for use in the first participant unit and the generating and encrypting is performed by the first security element.
  • 47. The method according to claim 45, wherein the first participant unit sends the encrypted transaction data set to the transaction register.
  • 48. The method according to claim 45, wherein the encrypted transaction data set is sent to the transaction register in a cryptographically transport-secured manner.
  • 49. The method according to claim 45, wherein the transaction data set comprises at least: an identifier or address of the first participant unit, andan identifier or address of a second participant unit, anda monetary amount of the electronic coin data set.
  • 50. The method according to claim 49, wherein the transaction data set further comprises: a transaction number and/ora masked electronic coin data set corresponding to the electronic coin data set to be transmitted or an electronic coin data set to be modified or to a modified electronic coin data set, instead of the monetary amount of the electronic coin data set, and/ora transaction time.
  • 51. The method according to claim 45, wherein the first participant unit appends a transaction time to the encrypted transaction data set.
  • 52. The method according to claim 45, wherein the encrypted transaction data set is stored in the first participant unit if the communication link establishment to the transaction register or the sending of the encrypted transaction data set fails.
  • 53. The method according to claim 45, wherein the encrypted transaction data set is sent from the first participant unit to the transaction register once the communication link establishment with the transaction register is successful.
  • 54. The method according to claim 45, wherein the first participant unit transmits the electronic coin data set to a second participant unit.
  • 55. The method according to claim 54, wherein the transmitting step occurs immediately before or after the generating step or the encrypting step or the initiating step.
  • 56. The method according to claim 54, wherein the transmitting step is executed only after a checking step yields, that a check value for a number of transmissions to the second participant unit or to further participant units in case of failed communication link establishment to the transaction register or failed sending of the encrypted transaction data set to the transaction register is below or equal to a predefined threshold value.
  • 57. The method according to claim 54, wherein upon exceeding a predefined threshold value of a check value for a number of transmissions to the second participant unit or to further participant units in case of failed communication link establishment to the transaction register or failed sending the encrypted transaction data set to the transaction register, sending the encrypted transaction data set and/or a stored transaction data set to the transaction register must take place before transmitting the electronic coin data set.
  • 58. The method according to claim 54, wherein upon successful transmission of the electronic coin data set and failed communication link establishment to the transaction register or failed sending of the encrypted transaction data set to the transaction register, a check value is incremented in the first participant unit.
  • 59. The method according to claim 58, wherein the check value is also used to determine whether the electronic coin data set is displayed by the first participant unit at the payment system, in particular a coin register or a monitoring register, and/or whether the electronic coin data set is returned to the central issuing instance.
  • 60. The method according to claim 54, wherein in a transmission error event, the electronic coin data set is resent based on the transaction data set.
  • 61. The method according to claim 45, comprising the further steps of: masking the electronic coin data set by applying a homomorphic one-way function to the electronic coin data set to obtain a masked electronic coin data set;registering the masked electronic coin data set in a coin register and/or a monitoring register of the payment system, said registering being preferential for switching, splitting or connecting masked electronic coin data sets.
  • 62. The method according to claim 45, comprising the further steps of: masking the electronic coin data set by applying a homomorphic one-way function to the electronic coin data set for obtaining a masked electronic coin data set;associating the masked electronic coin data set with a pseudonym to obtain a pseudonymised masked electronic coin data set; and sending the pseudonymised masked electronic coin data set to a monitoring register of the payment system.
  • 63. The method according to claim 45, wherein the cryptographic partial keys are each from: a law enforcement authority instance;a notary authority instance;a ministry of justice authority instance;a central issuing authority of the payment system; ora commercial banking authority of the payment system.
Priority Claims (1)
Number Date Country Kind
10 2020 004 121.3 Jul 2020 DE national
PCT Information
Filing Document Filing Date Country Kind
PCT/EP2021/068064 6/30/2021 WO