WO1998054634A1 - Method and apparatus for providing secure time stamps for documents and computer files - Google Patents

Method and apparatus for providing secure time stamps for documents and computer files Download PDF

Info

Publication number
WO1998054634A1
WO1998054634A1 PCT/US1998/010765 US9810765W WO9854634A1 WO 1998054634 A1 WO1998054634 A1 WO 1998054634A1 US 9810765 W US9810765 W US 9810765W WO 9854634 A1 WO9854634 A1 WO 9854634A1
Authority
WO
WIPO (PCT)
Prior art keywords
time stamp
time
check
notary
data
Prior art date
Application number
PCT/US1998/010765
Other languages
French (fr)
Inventor
Sol Aisenberg
George Freedman
A. Ze'ev Hed
Richard Pavelle
Original Assignee
Sol Aisenberg
George Freedman
Hed A Ze Ev
Richard Pavelle
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Sol Aisenberg, George Freedman, Hed A Ze Ev, Richard Pavelle filed Critical Sol Aisenberg
Priority to CA002290365A priority Critical patent/CA2290365A1/en
Priority to DE69802080T priority patent/DE69802080D1/en
Priority to EP98924915A priority patent/EP0985171B1/en
Publication of WO1998054634A1 publication Critical patent/WO1998054634A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F21/00Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
    • G06F21/60Protecting data
    • G06F21/64Protecting data integrity, e.g. using checksums, certificates or signatures
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L9/00Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols
    • H04L9/32Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials
    • H04L9/3297Cryptographic mechanisms or cryptographic arrangements for secret or secure communications; Network security protocols including means for verifying the identity or authority of a user of the system or for message authentication, e.g. authorization, entity authentication, data integrity or data verification, non-repudiation, key authentication or verification of credentials involving time stamps, e.g. generation of time stamps
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2209/00Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
    • H04L2209/60Digital content management, e.g. content distribution
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04LTRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
    • H04L2209/00Additional information or applications relating to cryptographic mechanisms or cryptographic arrangements for secret or secure communication H04L9/00
    • H04L2209/80Wireless

Definitions

  • the present invention relates to apparatus and methods for providing secure time stamps to documents and transactions.
  • Prior time stamp apparatus have used internal clock modules contained within a data processing system or the time stamp apparatus itself to generate the value of the day and time within a time stamp. For security purposes, this solution is unacceptable since such internal clocks are readily modifiable by the user to reset the date and time upon computer initialization or power loss.
  • One such apparatus is disclosed in United States Patent No. 5,136,643, issued to Fisher, entitled PUBLIC/KEY DATE TIME NOTARY FACILITY.
  • the system disclosed in Fisher contains one or more digital clocks, the values of which are averaged and used as part of a notary time stamp value.
  • the clock module in the Fisher apparatus has been designed to prevent physical tampering, the problem of continuous power to the clock is not solved, since even backup batteries lose power eventually.
  • an apparatus for generating notary time stamps comprises means for obtaining a time signal generated external to the apparatus, the time signal comprising date and time information.
  • the apparatus further comprises logic means for creating a unique, sequential time stamp identifier through an irreversible process.
  • the apparatus further comprises means for forming the time stamp and for generating a check-sum value which may be based on the content of one or all of the parameters of the time stamp itself.
  • the external signal comprises a time signal in Universal Time Code (UTC) format or a signal based on a Global Positioning Satellite (GPS) signal.
  • the logic means for creating the sequential time stamp identifier comprises a programmable memory device having a plurality of cells, each of which may be written or "burned" only once, to irreversibly change the digital signature output from the memory device.
  • a method for generating time stamps to be associated with documents and data files comprises the steps of receiving a request for a time stamp, retrieving an external time signal including date and time information, irreversibly modifying the output signature of a write-once memory to generate a unique, sequential time stamp identifier, generating the notary time stamp from the date and time data and the time stamp identifier, and generating a check-sum value derived at least partially from the date and time data or time stamp identifier.
  • a notary time stamp for association with documents and data files comprises a source identifier uniquely identifying the source of the time stamp, a time stamp sequence identifier generated through an irreversible process by the source of the notary time stamp, time and date data obtained externally of the source of the notary time stamp, and a check-sum value derived from at least one of the source identifier, time stamp sequence identifier and day and time data.
  • an apparatus for verifying the authenticity of a time stamp is presented, the time stamp parameters including a source identifier, a time stamp sequence identifier, date and time data and a check-sum value.
  • the apparatus for verifying the authenticity comprises means for reading the notary time stamp parameters and means responsive to the check-sum value for verifying the integrity of the parameters from which the check-sum value is derived.
  • Fig. 1 is a schematic block diagram of a computer system suitable for use with the presentation
  • Fig. 2 is a schematic block diagram of the notary time stamp apparatus of the presentation
  • Figs. 3 are schematic representations of the notary time stamp data structure in accordance with the present invention.
  • Fig. 4A is a schematic block diagram of an alternative embodiment of the notary time stamp apparatus of Fig. 2;
  • Fig. 4B is a schematic block diagram illustrating one or more inventive notary time stamp generator networked to a time signal source
  • Fig. 5 is a flow-chart illustrating the inventive method for generating the notary time stamp of Fig. 3;
  • Fig. 6 is a flow-chart illustrating the inventive method for validating the notary time stamp generated by the process illustrated in Fig. 5.
  • an apparatus for generating notary time stamps comprises a collection of logic components mounted to a circuit board.
  • the circuit board which is insertable into an existing data processing systems particularly a personal computer, is described in detail with reference to Fig. 2, or may be configured as a standalone apparatus, as described with reference to Fig. 4.
  • a brief overview of a computer system suitable for use with the invention is provided below.
  • Fig. 1 illustrates the system architecture for a computer system 100, such as an IBM PS/2® computer with which the invention can be implemented.
  • the exemplary computer system of Fig. 1 is for descriptive purposes only. Though the description below may refer to terms commonly used in describing particular computer systems, such as an IBM PS/2 computer, the description and concepts equally apply to other systems, including systems having architectures dissimilar to Fig. 1.
  • the computer system 100 includes a central processing unit (CPU) 105, which may include a conventional microprocessor, random access memory (RAM) 110 for temporary storage of information, and read only memory (ROM) 115 for permanent storage of information.
  • CPU central processing unit
  • RAM random access memory
  • ROM read only memory
  • a memory controller 120 is provided for controlling system RAM 110.
  • a bus controller 125 is provided for controlling bus 130, and an interrupt controller 135 is used for receiving and processing various interrupt signals from the other system components.
  • Mass storage may be provided by diskette 142, CD-ROM 147 or hard disk 152. Data and software may be exchanged with computer system 100 via removable media such as diskette 142 and CD-ROM 147.
  • Diskette 142 is insertable into diskette drive 141, which is, in turn, connected to bus 130 by controller 140.
  • CD-ROM 147 is insertable into CD-ROM drive 146, which is in turn, connected to bus 130 by controller 145.
  • hard disk 152 is part of a fixed disk drive 151, which is connected to bus 130 by controller 150.
  • keyboard 156 and mouse 157 are connected to bus 130 by keyboard and mouse controller 155.
  • Other peripheral devices may be connected to bus 130 by controller 197, which may be an RS-232 serial port controller, as illustrated, or alternatively, a parallel port controller.
  • controller 197 which may be an RS-232 serial port controller, as illustrated, or alternatively, a parallel port controller.
  • DMA controller 160 is provided for performing direct memory access to system RAM 110.
  • a visual display is generated by a video controller 165, which controls video display 170.
  • Computer system 100 also includes a communications adapter 190 which allows the system to be interconnected to a local area network (LAN) or a wide area network (WAN), or the Internet schematically illustrated by bus 191 and network 195.
  • communication adapter 190 may be a PCMCIA bus adapter which allows any number of peripherals adhering to the PCMCIA standard to be interfaced with computer system 100 in a manner within the scope of those skilled in the art.
  • Computer system 100 is generally controlled and coordinated by operating system software, such as the OS/2® operating system, available from the International Business Machines Corporation, Boca Raton, Florida or Windows NT, available from Microsoft Corp., Redmond, WA.
  • the operating system controls allocation of system resources and performs tasks such as process scheduling, memory management, and networking and I/O services, among other things.
  • Generator 200 comprises processor 206, RAM memory 208, buffer memory 210, ROM memory 212, internal bus 214, bus controller 216, circuit board 224, and programmable read-only memory (PROM) 222.
  • processor 206 RAM memory 208
  • buffer memory 210 ROM memory 212
  • internal bus 214 bus controller 216
  • circuit board 224 circuit board 224
  • programmable read-only memory (PROM) 222 a plurality of satellites 220A-C, receiver 202, antenna 204, and external bus 130 are illustrated, although not part of generator 200.
  • the functional elements of generator 200 may be implemented with discrete components and integrated circuit components including but not limited to small scale logic, large scale logic, or very large scale logic components.
  • the components are mounted to circuit board 224 and are interconnected to one another via internal bus 214 and possibly other connections.
  • internal bus 214 may be a multi-bit bus, e.g. an 8-bit, 16-bit, 32-bit, or 64- bit bus, and is coupled to external bus 130 via bus controller 216.
  • Bus controller 216 provides signal buffering and controls the flow of data and controls signals between internal bus 214 and external bus 130, in a manner reasonably understood by those skilled in the art.
  • controller 216 may be implemented as a serial port controller, such as an RS-232 or compatible controller, or alternatively, may be a parallel port controller or a PCMCIA controller/adapter.
  • External bus 130 may be implemented as a 16-bit or 32-bit bus used to interface with computer system 100 of Fig. 1 or other computer systems and peripheral devices.
  • a portion of external bus 130 may be integrally formed on circuit board 224 so as to establish an electrical connection with controller 216 upon insertion into the back plane connectors of a conventional personal computer.
  • generator 200 receives power through the back plane connection and, accordingly, does not need a separate power supply.
  • Processor 206 in the illustrative embodiment, may be implemented with any number of commercially available microprocessors, such as the X86 family of microprocessors available from Intel Corporation, Santa Clara, California or the Motorola 68000 family of processors available from Motorola, Inc. Schaumburg, IL. Those skilled in the art will appreciate that instead of a microprocessor, the processing functions described hereafter may be similarly implemented with a combination of firmware and dedicated integrated circuits capable of performing similar functions. As will be described hereinafter in greater detail, the processor 206 performs the necessary process steps for generation of the notary time stamp of the present invention. Processor 206 is controlled by instructions or sequences of instructions which may be stored in ROM 212, RAM 208, local memory contained internally within the processor 206 or even system RAM110 of Fig. 1.
  • ROM 212 may be implemented with any number of commercially available read only memory circuit elements and functions to store data and/or sequences of instructions useful by processor 206.
  • RAM 208 may be implemented with any number of commercially available random access memory circuit elements and serves to temporarily store data or other information usable by processor 206.
  • Buffer memory 210 in the illustrative embodiment, may be implemented as a separate portion of random access memory or, alternatively, may comprise a delineated portion of RAM 208. Buffer memory 210 may be used to store the value of the notary time stamp and the component values thereof during the generation process, as described in greater detail with reference to Figs. 3-4.
  • PROM memory 222 is utilized, in the illustrative embodiment, as a means for irreversibly generating a sequence of unique digital signatures used to identify the notary time stamps of the present invention.
  • PROM 222 may be implemented with any number of commercially available "write-once" memory devices, the cells of which are unmodifiable once “burned”.
  • a high-energy write signal is selectively supplied to PROM 222 causing an irreversible "burning" of one or more selected cells within the PROM, thereby changing the overall digital output or signature of the PROM device after each burning.
  • PROM 222 cannot be used to generate the same digital signature twice.
  • the extra electrical power needed for the write signal supplied to PROM 222 may be supplied by any number of sources, including an external power supply, internal batteries, or through a serial or parallel port associated with computer system 100.
  • Program logic 226 associated with PROM 222 and contained on generator 200 ensures that the appropriate cell within PROM 222 is burned, thereby allowing the output digital signature of the PROM to be incrementally and permanently altered.
  • Such logic is within the scope of those skilled in the art and may comprise a simple incrementation or decrementation function, depending on the size, structure and addressing scheme associated with the PROM.
  • generator 200 is designed to obtain a timing signal from a source external to generator 200 itself.
  • Such time signals may be obtained from a receiving device, such as receiver 202, coupled directly to generator 200 through a dedicated bus, or, alternatively, operatively coupled to generator 200 through external bus 130 as well as possibly through communication networks 191 and 195, as explained hereinafter.
  • Receiver 202 may comprise any number of commercially available receivers capable of obtaining a nationally or internationally accepted timing signal, such as the NAVSTAR Global Positioning System (GPS), a LORAN-C signal, a World-Wide Verification Signal, or other signal that is compatible with international timing systems, such as the universal coordinated time (UTC) system.
  • GPS Global Positioning System
  • LORAN-C LORAN-C signal
  • UTC universal coordinated time
  • receiver 202 may be implemented with any number of commercially available GPS receivers. To better facilitate an understanding of the invention, some background about the nature of the GPS signal is provided.
  • the NAVSTAR Global Positioning System GPS is a precise satellite navigation system installed by the U.S. Department of Defense, comprising 24 satellites orbiting the earth in 12-hour orbits.
  • the GPS system provides position information in three dimensions (latitude, longitude, and altitude) and provides full 24-hour service for time broadcasts. In operation, each satellite continually broadcasts its own position and its own precise time.
  • the GPS system offers time stability to within 300 ns.
  • a receiver such as receiver 202, may determine the exact time, latitude, longitude and altitude of the receiver.
  • the Trimble Mobile GPS Locator 110 comprises a GPS antenna and receiver which generates precise GPS position and time data and is connectable to either generator 200 or a personal computer via a serial interface, such as an RS- 232 interface, or compatible controller.
  • the output of such devices may be in a number of formats including UTC time sequence (ASCII) format.
  • a Mobile GPS Source Developer's Kit SDK is commercially available from Trimble Navigation, Ltd. to allow for the design of custom GPS applications for various Trimble products. Such source developer's kit may be utilized to customize the data stream output by a Trimble receiver in accordance with the present invention.
  • Mobile GPS PCMCIA card Another receiver suitable for use with the present invention is the Mobile GPS PCMCIA card also commercially available from Trimble Navigation Ltd.
  • the Mobile GPS PCMCIA card may interface with a PCMCIA bus adaptor of either generator 200 or computer system 100 in a conventional manner and generates similar, periodic digital sentences similar to the previously described receiver.
  • notary time stamp generator 200 the functions of processor 206, RAM 208, buffer 210, ROM 212, and bus 214 may be performed by similar components already within computer system 100, e.g. CPU 105, RAM 110, ROM 115 and bus 130.
  • the methods performed by such components, as well as the programming instructions necessary to achieve such methods, are described hereinafter with reference to Figs. 5-6.
  • receiver 202 is connectible to bus 130 via a serial or parallel port controller, as previously described.
  • a separate board containing PROM 222 and program logic 226 may be likewise connectible to bus 130 via a serial or parallel controller, in a manner similar to receiver 202.
  • many existing computer systems may be upgraded to perform the functions of the inventive stamp generator through installation of the appropriate programming instructions and connection of a receiver 202 and PROM 222 and its associated programming logic 226.
  • Time stamp 300 comprises a date/time field 302, an optional position field 304, a generator identification field 306, a time stamp serial number field 308, and one or more check sum fields 310.
  • Time/date field 302 contains date and time information as received from a source external to generator 200. The length and content of the data contained in field 302 may vary depending on the source of the date and time information. For example, if the source of the time and date information is any of the previously mentioned Trimble Navigation products, the field will have a (UTC) format.
  • Generator 200 can be designed to retrieve external timing signals from more than one source.
  • a timing signal may be achieved over a network from a source on the Internet or through a dedicated receiver directly connected to the generator 200 or a computer system 100 to generator 200 is coupled.
  • field 302 may include an identifier code within the time date field which identifies the source and/or format of the time and date information.
  • Optional position field 304 of time stamp 300 may comprise a digital word also generated by receiver 202 representing the latitude and longitude of the receiver at the time a notary time stamp 300 was requested. A number of techniques may be used to generate the binary value of the serial number field 308. Depending on the implementation of receiver 202, the positional information necessary to include position field 304 may or may not be present. For example, some of the previously mentioned receivers commercially available from Trimble navigation provide positional information in their output data stream, or, alternatively, such information is available for extraction from the data stream and reformatting at the designer's discretion using the SDK available from that manufacturer. The value of position field 304 is particularly relevant with the implementation of the invention as described with reference to Fig. 4 in which the receiver 402 may be housed in the same apparatus with the notary stamp generator 400, as described hereinafter.
  • Identification field 306 comprises a unique identifier associated with generator 200 and may be implemented with either a 16 or 32 bit digital word.
  • the value representing the identification field 306 may be hardwired using discrete components, such as resistors potted in epoxy, at the time which generator 200 is manufactured.
  • the identifier may be programmed into an unalterable portion of ROM memory associated with the time stamp generator 200. The identification field is unique to each specific generator manufactured.
  • Time stamp 300 further comprises a serial number field 308, which, in the illustrative embodiment, may be implemented with a unique 16, 32 or 64 bit binary value.
  • the serial number field 308 is a unique identifier generated by generator 200 through an irreversible process.
  • PROM 222 is supplied with a high energy write signal causing an irreversible burning of a predetermined cell or cells within the PROM. Subsequently, reading a pattern of cells from PROM 222 outputs a unique binary signature which may be used as the value for serial number field 308.
  • the digital signatures output from PROM 222 form a sequence of digital signatures which may not be reset or recreated using the same PROM.
  • the number of sequential serial number values obtainable from a PROM depends on the size of the PROM and any initial or default values present or burned into the PROM upon insertion into generator 200. Once the PROM has been completely utilized, it may be replaced with a new PROM having a different initial value. In this manner, a particular generator 200 having a unique identifier associated therewith will never generate the same time stamp serial number twice.
  • time stamp 300 further comprises one or more check-sums 310 which may be implemented with any number of known check-sum algorithms.
  • check-sum 310 may include a title count of characters within any one of fields 302-308 or any combination thereof.
  • the check-sum algorithm used to derive the value of field 310 may include a total character count plus a check-sum for sequence involving prime numbers such as 1, 2, 3, 5, 7, 11 and 13.
  • time stamp 300 is written into a portion of memory associated with the data file or document. This portion of memory associated with the document is preferably unaccessible and unmodifiable except by time generator 200.
  • the database may include a specific field specifically designed for storing of the time stamp 300.
  • check sum 310 may be computed from the content of the data file, in place of, or in combination with, the content of any one of the fields of time stamp 300.
  • the time stamp may contain two check-sum values, one derived from the contents of the data file and the other derived from the contents of the time stamp itself.
  • the time stamp may include a separate check-sum derived from both the contents of the data file and one or more of the time stamp fields. In this manner, any attempt to change the content of the document as well as the time stamp will be flagged when the check-sum is verified through an authentication process, as explained hereinafter.
  • the memory associated with the data file for storing the time stamp may be of sufficient size to store multiple time stamps entries, thereby providing a chronology of the exact dates and times at which the document was modified.
  • Generator 400 is similar in design and architecture to generator 200 as previously described with reference to Fig. 2.
  • generator 400 includes a power supply 410, housing 405 and several ports 412, for example, serial or parallel ports or a PCMCIA adapter, a receiver 402, similar to receiver 202 previously described, and a peripheral 404 and keyboard 406, all internally coupled to internal bus 214.
  • receiver 402 and peripheral 404 may be coupled directly to generator 200 through the various ports and adaptors.
  • Peripheral 404 provides a means through which a time stamp value may be fixed to a tangible document.
  • peripheral 404 may comprise any number of commercially available bar code generators which can translate the time stamp 300 into a bar code representation and affix the bar code to a tangible document, for example by insertion of the document into a slot within housing 405 or peripheral 404.
  • peripheral 404 may include a scanning device for reading time stamp values.
  • peripheral 404 may include a scanning apparatus implemented with any number of commercially available bar code readers.
  • a dedicated keyboard 406 attached to housing 405 may be included.
  • a port for connection with a standard PC alphanumeric keyboard and controller, such as keyboard 156 and controller 155 illustrated in Fig. 1, may be included.
  • the design and construction of a bar code generator apparatus and/or bar code scanning apparatus which may be suitable for use as peripheral 404 are within the scope of those reasonably skilled in the art, as are the design of housing 405, power supply 410, and keyboard 406, as well as their interconnection with generator 200. A detailed implementation of such devices will not be included herein for the sake of brevity.
  • Generator 400 may be used with both tangible documents as well as electronic files supplied to generator 400 via connection to a computer or network, as illustrated in Fig. 4B.
  • any number of time stamp generators 200, as coupled to computer systems 100 or standalone generators 400 may be connected over a local area network, wide area network, or, over the Internet.
  • an external receiver 402A e.g. a GPS receiver
  • computer systems 100A-C each of which include a time stamp generator 200A-C, respectively, in accordance with the present invention.
  • a standalone time stamp generator 400A and 400B are further coupled to receive 402A in a similar manner.
  • Time stamp generator 400B itself includes its own receiver 402B.
  • time stamp generators may be intercoupled over a network, provided at least one external receiver is accessible through the network to provide the necessary information for the time and date portion of the time stamp.
  • the limitations of actual network configurations are dictated by the bandwidth of the network, the protocol, and the number of ports available on each respective apparatus.
  • a single receiver may provide the necessary time and date information to multiple time stamp generators, thereby eliminating the need for each time stamp generator to be coupled directly to a single external time source.
  • Fig. 5 is a flow chart illustrating the basic process steps used by processor 206 to generate a notary time stamp in accordance with the present invention.
  • the coding of the process steps of the illustrated flow chart information instructions suitable for control of processor 206 will be understandable by one having ordinary skill in the art of programming.
  • the process steps described within Fig. 5 applicable equally to either generator 200 or 400.
  • processor 206 Following power-on and initialization, processor 206 remains idle until a request is received for generation of a time stamp, as illustrated by decisional block 500.
  • Processor 206 retrieves an externally generated time signal from receiver 202, either directly through a serial or parallel port, or through a network necessary connection, as described previously. Once the time and date data is retrieved, any necessary reformatting of the data occurs and the data is stored in buffer 210 as the value of field 302 of Fig. 3.
  • processor 206 requests a write/read operation to be performed on PROM 222. The operation triggers selection of the next address from the PROM and further triggers a high energy write signal to be applied to the selected PROM address.
  • processor 206 retrieves the generator identifier, typically from ROM, and appends the value to buffer 210 as the value of field 306, as illustrated in Fig. 3.
  • a check-sum algorithm is applied to some or all of the contents of buffer 210 and the check-sum value written into the buffer 210 as the value of field 310, as illustrated by process 508.
  • processor 206 in conjunction with the operating system of computer system 100 and any applicable network's protocols causes the file contents to be retrieved and temporarily written to RAM 208, as illustrated by decisional block 510 and procedural block 512.
  • processor 206 causes a check-sum algorithm to be applied to the contents of the file in RAM 208, as illustrated by the procedural block 514.
  • the resulting check-sum value is appended to the contents of buffer 210 either in place of the existing check-sum field 310 or in addition thereto, as illustrated by procedural block 514.
  • processor 206 causes the contents of buffer 210, representing the notary time stamp, to be written to an area of memory associated with the data file and accessible only by the time stamp generator 200.
  • only field 302, 306, 308 and 304 are viewable or added to the header information of a file.
  • the check-sum value(s) are not visible to anyone viewing the time stamp or the file.
  • buffer 210 may be written to a peripheral device, such as bar code generator 404 for application to a tangible document, as illustrated by procedural block 518. If power has not been removed from generator 200 the process remains in idle while awaiting the next request for a time stamp, as illustrated.
  • the process illustrated in Fig. 5 may also be utilized to generate a time stamp 300 including optional positional information 304.
  • positional information would be added to buffer 210 in procedural step 502. Where such positional information is directly available from the external receiver, the information is retrieved along with the date and time information.
  • Use of positional information in time stamp 300 is valid only where the position of the receiver is within reasonable proximity, e.g. the error differential of the receiver, to the actual time stamp generator itself. Otherwise, particularly in the instance of network connections or retrieval of time and date information over the Internet, the location of the specific receiver may be irrelevant to the location of the time stamp generator generating the time stamp in question.
  • Fig. 6 is a flow chart illustrating the basic process steps used by processor 206 to validate a notary time stamp in accordance with the present invention.
  • the coding of the process steps of the flow chart into instructions suitable for control of processor 206 will be understood by one having ordinary skill in the art of programming.
  • the process steps described in Fig. 6 are applicable equally to either a generator 200 or a generator 400.
  • processor 206 Following power-on and initialization, processor 206 remains idle until a request for validation of a time stamp is received, as illustrated by decisional block 600.
  • processor 206 determines whether or not the request was accompanied by an address in memory of an electronically stored time stamp, as well as possibly the address of the data file associated with the time stamp, as illustrated by decisional block 602.
  • processor 206 retrieves the time stamp value, including the check sum values, from the designated memory location, as illustrated in by processed block 604.
  • processor 206 causes the same check sum algorithm to be applied to the contents of the retrieved time stamp value, as illustrated by procedure block 606.
  • the recomputed check sum value is then compared to the value within the retrieved time stamp, as illustrated by procedural block 608, to determine if a match occurs, as illustrated by decisional block 610. If no match occurs, indicating that the contents of the time stamp have been altered from their original value, processor 206 causes a message to be displayed and/or printed to the user indicating that the integrity of the retrieved time stamp is no longer valid, as illustrated by procedural block 612. If the recomputed and retrieved check sum values match, processor 206 will display and/or print a message indicating that the retrieved time stamp is valid, as illustrated by procedural block 614.
  • processor 206 will retrieve the referenced data file in block 604, as well, and also recompute the check sum value for the data file, if applicable, in block 606. Next, the contents of the recomputed data file check sum will be compared with the data file check sum from the retrieved time stamp, in a manner similar to that previously described with reference to procedural blocks 606 and 608. If a match occurs, processor 206 will cause a message to be displayed and/or printed indicating that the data file associated with the time stamp is valid, similar that displayed with reference to block 614.
  • processor 206 will cause a message to be displayed and/or printed, indicating that the contents of the datafile have been altered, similar to that displayed with reference to block 612.
  • processor 206 will attempt to read the value of a time stamp from peripheral 404, indicating that the time stamp is affixed to a tangible document, as illustrated in procedural block 616. The procedure then proceeds to block 606, as previously described.
  • time stamp check sum field 310 and any accompanying datafile check sum fields may be generated using one or more different check sum algorithms.
  • processor 206 may be able to generate check sums using any one of a plurality of available check sum generation algorithms programmed into processor 206.
  • the check sum fields may include not only the value of the check sum, but a code identifying which algorithm was utilized to generate the check sum and the field within the time stamp on which the check sum was derived. In this manner, different check sum algorithms may be utilized to further reinforce the security of the time stamp generation process.
  • time stamp itself, or, selective fields of the time stamp, may be encrypted using any number of encryption technologies such as those commercially available from RSA Data Security Inc., Redwood City, California.
  • Other types of encryption algorithms including secret key encryption and public/private key encryption may be utilized with the notary time stamp of the present invention.
  • an identifier indicating either the key or the type of encryption utilized may be appended to the time stamp to facilitate decryption and validation processes.

Abstract

Secure time stamps (300) generated by the inventive apparatus (200) and method include an externally generated time signal (302), such as a GPS signal, a time stamp serial number (303), generated through an irreversible process which may not be duplicated by the apparatus, and one or more check sum values (310) used to verify the content of the time stamp parameters or any data file associated with the time stamp. Also disclosed are apparatus and methods for verifying the authenticity of previously generated time stamps in either electronic or tangible form. The time stamp generator apparatus (200) may be implemented as an add-on board to an existing computer system or as a stand alone device (400) which may also include a GPS receiver (402) and a scanner for verifying previously generated time stamps.

Description

METHOD AND APPARATUS FOR PROVIDING SECURE TIME STAMPS FOR DOCUMENTS AND COMPUTER FILES
FIELD OF THE INVENTION
The present invention relates to apparatus and methods for providing secure time stamps to documents and transactions.
BACKGROUND OF THE INVENTION
A need has always existed for a method of establishing the age and authenticity of documents, particularly for legal and business purposes. For documents written on paper, methods currently exist for establishing the age of a document by analysis of the chemical composition of the paper and the ink. Further, handwriting analysis can be used to establish the authenticity of the document signatures. These methods, however, are not practical for widespread use and require a significant level of expertise to establish either the age or the authenticity of the document signatures.
Impartial third party notaries have been typically relied upon to establish both the age and authenticity of paper documents. With such an approach, there is no assurance against collusion or conspiracies to defraud involving third party notary. Still, further, where a large volume of transactions or documents related thereto, such as with financial transactions, is involved, the task of third party notarization becomes too cumbersome and the ability to immediately notarize the document is not possible.
With the rapid growth of electronic document and the movement toward a paperless society, there is an increasing need for establishing not only the integrity of an electronic document but the exact date and time, and, possibly, even the place at which a document was created or last modified.
Prior time stamp apparatus have used internal clock modules contained within a data processing system or the time stamp apparatus itself to generate the value of the day and time within a time stamp. For security purposes, this solution is unacceptable since such internal clocks are readily modifiable by the user to reset the date and time upon computer initialization or power loss. One such apparatus is disclosed in United States Patent No. 5,136,643, issued to Fisher, entitled PUBLIC/KEY DATE TIME NOTARY FACILITY. The system disclosed in Fisher contains one or more digital clocks, the values of which are averaged and used as part of a notary time stamp value. Although the clock module in the Fisher apparatus has been designed to prevent physical tampering, the problem of continuous power to the clock is not solved, since even backup batteries lose power eventually. Further, since the internally generated clock signal is not a universally recognized, the authenticity of the time stamp is not universally recognized. United States Patent 5,189,700, issued to Blandford, entitled DEVICES TO SUPPLY AUTHENTICATED TIME AND TIME STAMP AND AUTHENTICATE DIGITAL DOCUMENTS, likewise discloses a device in which a resident real time clock provides the source of time for the time stamps. The apparatus disclosed in Blandford suffers from the same inherent problems as the Fisher patent, namely, the internally generated clock is not a universally recognized value for the time at any given instance. Hence, the credibility of the time stamps issued therefrom is similarly not universally recognized.
Accordingly, in light of the above deficiencies in previously attempted solutions, a need exists for a method and apparatus by which a highly accurate and universally accepted notary stamp may be applied to both paper and electronic documents and associated transactions, such a stamp being useful to both compute the age of a document, and, in the case of electronic documents, verify the authenticity and integrity of the document. A further need exists for a method of providing a "virtual seal" on computer files and records so that the exact date, time and place of the sealing may be later ascertained. Further, a need exists to determine whether modifications or subsequent edits to such sealed documents has occurred and, possibly, even a history of such modifications to the documents.
SUMMARY OF THE INVENTION
The above described deficiencies in prior devices and previously described needs are fulfilled by the present invention which contemplates a method and apparatus for generating a time stamp from a widely accepted, externally generated time signal. The time stamp further comprises a time stamp serial number generated through an irreversible process which may not be duplicated by the same generating apparatus. In addition, time stamp includes one or more check-sum values based on the contents of the time stamp and/or the document with which the time stamp is associated. In one aspect of the invention, an apparatus for generating notary time stamps comprises means for obtaining a time signal generated external to the apparatus, the time signal comprising date and time information. The apparatus further comprises logic means for creating a unique, sequential time stamp identifier through an irreversible process. The apparatus further comprises means for forming the time stamp and for generating a check-sum value which may be based on the content of one or all of the parameters of the time stamp itself. In an illustrative embodiment, the external signal comprises a time signal in Universal Time Code (UTC) format or a signal based on a Global Positioning Satellite (GPS) signal. The logic means for creating the sequential time stamp identifier comprises a programmable memory device having a plurality of cells, each of which may be written or "burned" only once, to irreversibly change the digital signature output from the memory device.
According to a second aspect of the invention, a method for generating time stamps to be associated with documents and data files comprises the steps of receiving a request for a time stamp, retrieving an external time signal including date and time information, irreversibly modifying the output signature of a write-once memory to generate a unique, sequential time stamp identifier, generating the notary time stamp from the date and time data and the time stamp identifier, and generating a check-sum value derived at least partially from the date and time data or time stamp identifier.
According to a third aspect of the invention, a notary time stamp for association with documents and data files comprises a source identifier uniquely identifying the source of the time stamp, a time stamp sequence identifier generated through an irreversible process by the source of the notary time stamp, time and date data obtained externally of the source of the notary time stamp, and a check-sum value derived from at least one of the source identifier, time stamp sequence identifier and day and time data. According to yet a fourth aspect of the invention, an apparatus for verifying the authenticity of a time stamp is presented, the time stamp parameters including a source identifier, a time stamp sequence identifier, date and time data and a check-sum value. The apparatus for verifying the authenticity comprises means for reading the notary time stamp parameters and means responsive to the check-sum value for verifying the integrity of the parameters from which the check-sum value is derived. BRIEF DESCRIPTION OF THE DRAWINGS
The above and other features, objects, and advantages of the invention will be better understood by referring to the following description in conjunction with the accompanying drawing in which:
Fig. 1 is a schematic block diagram of a computer system suitable for use with the presentation;
Fig. 2 is a schematic block diagram of the notary time stamp apparatus of the presentation;
Figs. 3 are schematic representations of the notary time stamp data structure in accordance with the present invention;
Fig. 4A is a schematic block diagram of an alternative embodiment of the notary time stamp apparatus of Fig. 2;
Fig. 4B is a schematic block diagram illustrating one or more inventive notary time stamp generator networked to a time signal source;
Fig. 5 is a flow-chart illustrating the inventive method for generating the notary time stamp of Fig. 3; and
Fig. 6 is a flow-chart illustrating the inventive method for validating the notary time stamp generated by the process illustrated in Fig. 5.
DETAILED DESCRIPTION
In accordance with a first illustrative embodiment of the invention, an apparatus for generating notary time stamps comprises a collection of logic components mounted to a circuit board. The circuit board which is insertable into an existing data processing systems particularly a personal computer, is described in detail with reference to Fig. 2, or may be configured as a standalone apparatus, as described with reference to Fig. 4. Prior to describing the embodiment of Fig. 2 in detail, a brief overview of a computer system suitable for use with the invention is provided below.
Fig. 1 illustrates the system architecture for a computer system 100, such as an IBM PS/2® computer with which the invention can be implemented. The exemplary computer system of Fig. 1 is for descriptive purposes only. Though the description below may refer to terms commonly used in describing particular computer systems, such as an IBM PS/2 computer, the description and concepts equally apply to other systems, including systems having architectures dissimilar to Fig. 1.
The computer system 100 includes a central processing unit (CPU) 105, which may include a conventional microprocessor, random access memory (RAM) 110 for temporary storage of information, and read only memory (ROM) 115 for permanent storage of information. A memory controller 120 is provided for controlling system RAM 110. A bus controller 125 is provided for controlling bus 130, and an interrupt controller 135 is used for receiving and processing various interrupt signals from the other system components.
Mass storage may be provided by diskette 142, CD-ROM 147 or hard disk 152. Data and software may be exchanged with computer system 100 via removable media such as diskette 142 and CD-ROM 147. Diskette 142 is insertable into diskette drive 141, which is, in turn, connected to bus 130 by controller 140. Similarly, CD-ROM 147 is insertable into CD-ROM drive 146, which is in turn, connected to bus 130 by controller 145. Finally, hard disk 152 is part of a fixed disk drive 151, which is connected to bus 130 by controller 150.
User input to computer system 100 may be provided by a number of devices. For example, keyboard 156 and mouse 157 are connected to bus 130 by keyboard and mouse controller 155. Other peripheral devices may be connected to bus 130 by controller 197, which may be an RS-232 serial port controller, as illustrated, or alternatively, a parallel port controller. It will be obvious to those reasonably skilled in the art that other input devices such as a pen and/or tablet and a microphone for voice input may be connected to computer system 100 through bus 130 and an appropriate controller/software. DMA controller 160 is provided for performing direct memory access to system RAM 110. A visual display is generated by a video controller 165, which controls video display 170. Computer system 100 also includes a communications adapter 190 which allows the system to be interconnected to a local area network (LAN) or a wide area network (WAN), or the Internet schematically illustrated by bus 191 and network 195. Alternatively, communication adapter 190 may be a PCMCIA bus adapter which allows any number of peripherals adhering to the PCMCIA standard to be interfaced with computer system 100 in a manner within the scope of those skilled in the art. Computer system 100 is generally controlled and coordinated by operating system software, such as the OS/2® operating system, available from the International Business Machines Corporation, Boca Raton, Florida or Windows NT, available from Microsoft Corp., Redmond, WA. The operating system controls allocation of system resources and performs tasks such as process scheduling, memory management, and networking and I/O services, among other things.
Referring to Fig. 2, a notary time stamp generator 200 in accordance with a first embodiment of the present invention is illustrated. Generator 200 comprises processor 206, RAM memory 208, buffer memory 210, ROM memory 212, internal bus 214, bus controller 216, circuit board 224, and programmable read-only memory (PROM) 222. In addition, a plurality of satellites 220A-C, receiver 202, antenna 204, and external bus 130 are illustrated, although not part of generator 200.
In the contemplated embodiment, the functional elements of generator 200 may be implemented with discrete components and integrated circuit components including but not limited to small scale logic, large scale logic, or very large scale logic components. The components are mounted to circuit board 224 and are interconnected to one another via internal bus 214 and possibly other connections. In the illustrative embodiment, internal bus 214 may be a multi-bit bus, e.g. an 8-bit, 16-bit, 32-bit, or 64- bit bus, and is coupled to external bus 130 via bus controller 216. Bus controller 216 provides signal buffering and controls the flow of data and controls signals between internal bus 214 and external bus 130, in a manner reasonably understood by those skilled in the art. For example, controller 216 may be implemented as a serial port controller, such as an RS-232 or compatible controller, or alternatively, may be a parallel port controller or a PCMCIA controller/adapter. External bus 130 may be implemented as a 16-bit or 32-bit bus used to interface with computer system 100 of Fig. 1 or other computer systems and peripheral devices. Alternatively, a portion of external bus 130 may be integrally formed on circuit board 224 so as to establish an electrical connection with controller 216 upon insertion into the back plane connectors of a conventional personal computer. In such an embodiment, generator 200 receives power through the back plane connection and, accordingly, does not need a separate power supply.
Processor 206, in the illustrative embodiment, may be implemented with any number of commercially available microprocessors, such as the X86 family of microprocessors available from Intel Corporation, Santa Clara, California or the Motorola 68000 family of processors available from Motorola, Inc. Schaumburg, IL. Those skilled in the art will appreciate that instead of a microprocessor, the processing functions described hereafter may be similarly implemented with a combination of firmware and dedicated integrated circuits capable of performing similar functions. As will be described hereinafter in greater detail, the processor 206 performs the necessary process steps for generation of the notary time stamp of the present invention. Processor 206 is controlled by instructions or sequences of instructions which may be stored in ROM 212, RAM 208, local memory contained internally within the processor 206 or even system RAM110 of Fig. 1.
ROM 212 may be implemented with any number of commercially available read only memory circuit elements and functions to store data and/or sequences of instructions useful by processor 206. Similarly, RAM 208 may be implemented with any number of commercially available random access memory circuit elements and serves to temporarily store data or other information usable by processor 206. Buffer memory 210, in the illustrative embodiment, may be implemented as a separate portion of random access memory or, alternatively, may comprise a delineated portion of RAM 208. Buffer memory 210 may be used to store the value of the notary time stamp and the component values thereof during the generation process, as described in greater detail with reference to Figs. 3-4.
PROM memory 222 is utilized, in the illustrative embodiment, as a means for irreversibly generating a sequence of unique digital signatures used to identify the notary time stamps of the present invention. PROM 222 may be implemented with any number of commercially available "write-once" memory devices, the cells of which are unmodifiable once "burned". In the illustrative embodiment, a high-energy write signal is selectively supplied to PROM 222 causing an irreversible "burning" of one or more selected cells within the PROM, thereby changing the overall digital output or signature of the PROM device after each burning. PROM 222 cannot be used to generate the same digital signature twice. In this manner, the use of unique time stamp serial number and a unique generator identifier provide a tamper-proof technique of generating time stamps. The extra electrical power needed for the write signal supplied to PROM 222 may be supplied by any number of sources, including an external power supply, internal batteries, or through a serial or parallel port associated with computer system 100. Program logic 226 associated with PROM 222 and contained on generator 200 ensures that the appropriate cell within PROM 222 is burned, thereby allowing the output digital signature of the PROM to be incrementally and permanently altered. Such logic is within the scope of those skilled in the art and may comprise a simple incrementation or decrementation function, depending on the size, structure and addressing scheme associated with the PROM.
In the illustrative embodiment, generator 200 is designed to obtain a timing signal from a source external to generator 200 itself. Such time signals may be obtained from a receiving device, such as receiver 202, coupled directly to generator 200 through a dedicated bus, or, alternatively, operatively coupled to generator 200 through external bus 130 as well as possibly through communication networks 191 and 195, as explained hereinafter.
Receiver 202, in the illustrative embodiment, may comprise any number of commercially available receivers capable of obtaining a nationally or internationally accepted timing signal, such as the NAVSTAR Global Positioning System (GPS), a LORAN-C signal, a World-Wide Verification Signal, or other signal that is compatible with international timing systems, such as the universal coordinated time (UTC) system.
In the illustrative embodiment, receiver 202 may be implemented with any number of commercially available GPS receivers. To better facilitate an understanding of the invention, some background about the nature of the GPS signal is provided. The NAVSTAR Global Positioning System (GPS) is a precise satellite navigation system installed by the U.S. Department of Defense, comprising 24 satellites orbiting the earth in 12-hour orbits. The GPS system provides position information in three dimensions (latitude, longitude, and altitude) and provides full 24-hour service for time broadcasts. In operation, each satellite continually broadcasts its own position and its own precise time. The GPS system offers time stability to within 300 ns. By using the signals from multiple of the GPS satellites, a receiver, such as receiver 202, may determine the exact time, latitude, longitude and altitude of the receiver.
One such receiver suitable for use with the present invention is the Trimble Mobile GPS Locator 110, commercially available from Trimble Navigation Ltd., Sunnyvale, California. The Trimble Mobile GPS Locator 110 comprises a GPS antenna and receiver which generates precise GPS position and time data and is connectable to either generator 200 or a personal computer via a serial interface, such as an RS- 232 interface, or compatible controller. The output of such devices may be in a number of formats including UTC time sequence (ASCII) format. In addition, a Mobile GPS Source Developer's Kit (SDK) is commercially available from Trimble Navigation, Ltd. to allow for the design of custom GPS applications for various Trimble products. Such source developer's kit may be utilized to customize the data stream output by a Trimble receiver in accordance with the present invention.
Another receiver suitable for use with the present invention is the Mobile GPS PCMCIA card also commercially available from Trimble Navigation Ltd. The Mobile GPS PCMCIA card may interface with a PCMCIA bus adaptor of either generator 200 or computer system 100 in a conventional manner and generates similar, periodic digital sentences similar to the previously described receiver.
As a variation to the illustrative embodiment of notary time stamp generator 200, the functions of processor 206, RAM 208, buffer 210, ROM 212, and bus 214 may be performed by similar components already within computer system 100, e.g. CPU 105, RAM 110, ROM 115 and bus 130. The methods performed by such components, as well as the programming instructions necessary to achieve such methods, are described hereinafter with reference to Figs. 5-6. In such an embodiment, receiver 202 is connectible to bus 130 via a serial or parallel port controller, as previously described. In addition, a separate board containing PROM 222 and program logic 226 may be likewise connectible to bus 130 via a serial or parallel controller, in a manner similar to receiver 202. With this embodiment, many existing computer systems may be upgraded to perform the functions of the inventive stamp generator through installation of the appropriate programming instructions and connection of a receiver 202 and PROM 222 and its associated programming logic 226.
Referring to Fig. 3, a data structure suitable for use as a notary time stamp in accordance with the present invention is illustrated as a time stamp 300. Time stamp 300 comprises a date/time field 302, an optional position field 304, a generator identification field 306, a time stamp serial number field 308, and one or more check sum fields 310. Time/date field 302 contains date and time information as received from a source external to generator 200. The length and content of the data contained in field 302 may vary depending on the source of the date and time information. For example, if the source of the time and date information is any of the previously mentioned Trimble Navigation products, the field will have a (UTC) format. Generator 200 can be designed to retrieve external timing signals from more than one source. For example, a timing signal may be achieved over a network from a source on the Internet or through a dedicated receiver directly connected to the generator 200 or a computer system 100 to generator 200 is coupled. In the illustrative embodiment, field 302 may include an identifier code within the time date field which identifies the source and/or format of the time and date information.
Optional position field 304 of time stamp 300 may comprise a digital word also generated by receiver 202 representing the latitude and longitude of the receiver at the time a notary time stamp 300 was requested. A number of techniques may be used to generate the binary value of the serial number field 308. Depending on the implementation of receiver 202, the positional information necessary to include position field 304 may or may not be present. For example, some of the previously mentioned receivers commercially available from Trimble navigation provide positional information in their output data stream, or, alternatively, such information is available for extraction from the data stream and reformatting at the designer's discretion using the SDK available from that manufacturer. The value of position field 304 is particularly relevant with the implementation of the invention as described with reference to Fig. 4 in which the receiver 402 may be housed in the same apparatus with the notary stamp generator 400, as described hereinafter.
Identification field 306 comprises a unique identifier associated with generator 200 and may be implemented with either a 16 or 32 bit digital word. In the illustrative embodiment, the value representing the identification field 306 may be hardwired using discrete components, such as resistors potted in epoxy, at the time which generator 200 is manufactured. Alternatively, the identifier may be programmed into an unalterable portion of ROM memory associated with the time stamp generator 200. The identification field is unique to each specific generator manufactured.
Time stamp 300 further comprises a serial number field 308, which, in the illustrative embodiment, may be implemented with a unique 16, 32 or 64 bit binary value. In the illustrative embodiment, the serial number field 308 is a unique identifier generated by generator 200 through an irreversible process. Specifically, PROM 222 is supplied with a high energy write signal causing an irreversible burning of a predetermined cell or cells within the PROM. Subsequently, reading a pattern of cells from PROM 222 outputs a unique binary signature which may be used as the value for serial number field 308. By selectively burning cells within the PROM in a predetermined sequential fashion, e.g. incrementing or decrementing the address of the last cell burned, the digital signatures output from PROM 222 form a sequence of digital signatures which may not be reset or recreated using the same PROM. The number of sequential serial number values obtainable from a PROM depends on the size of the PROM and any initial or default values present or burned into the PROM upon insertion into generator 200. Once the PROM has been completely utilized, it may be replaced with a new PROM having a different initial value. In this manner, a particular generator 200 having a unique identifier associated therewith will never generate the same time stamp serial number twice.
In addition, time stamp 300 further comprises one or more check-sums 310 which may be implemented with any number of known check-sum algorithms. For example, check-sum 310 may include a title count of characters within any one of fields 302-308 or any combination thereof. Alternatively, the check-sum algorithm used to derive the value of field 310 may include a total character count plus a check-sum for sequence involving prime numbers such as 1, 2, 3, 5, 7, 11 and 13.
The notary time stamp of the present invention is contemplated for use with both tangible hard copy documents as well as electronic documents or data files. In the latter instance, time stamp 300 is written into a portion of memory associated with the data file or document. This portion of memory associated with the document is preferably unaccessible and unmodifiable except by time generator 200. For data files forming a portion of a database, the database may include a specific field specifically designed for storing of the time stamp 300. For time stamps associated with a data file, check sum 310 may be computed from the content of the data file, in place of, or in combination with, the content of any one of the fields of time stamp 300. For example, the time stamp may contain two check-sum values, one derived from the contents of the data file and the other derived from the contents of the time stamp itself. Alternatively, the time stamp may include a separate check-sum derived from both the contents of the data file and one or more of the time stamp fields. In this manner, any attempt to change the content of the document as well as the time stamp will be flagged when the check-sum is verified through an authentication process, as explained hereinafter.
In instances where a history of changes to a document is desired, the memory associated with the data file for storing the time stamp may be of sufficient size to store multiple time stamps entries, thereby providing a chronology of the exact dates and times at which the document was modified.
Referring now to Fig. 4A, a schematic block diagram of a stand-alone time stamp generator 400 is illustrated. Generator 400 is similar in design and architecture to generator 200 as previously described with reference to Fig. 2. In addition, generator 400 includes a power supply 410, housing 405 and several ports 412, for example, serial or parallel ports or a PCMCIA adapter, a receiver 402, similar to receiver 202 previously described, and a peripheral 404 and keyboard 406, all internally coupled to internal bus 214. Alternatively, but not shown, receiver 402 and peripheral 404 may be coupled directly to generator 200 through the various ports and adaptors.
Peripheral 404 provides a means through which a time stamp value may be fixed to a tangible document. For instance, peripheral 404 may comprise any number of commercially available bar code generators which can translate the time stamp 300 into a bar code representation and affix the bar code to a tangible document, for example by insertion of the document into a slot within housing 405 or peripheral 404. In addition, peripheral 404 may include a scanning device for reading time stamp values. In an implementation where the time stamp is affixed to a tangible document as a bar code, peripheral 404 may include a scanning apparatus implemented with any number of commercially available bar code readers. One such scanning apparatus which may be implemented with a reduced number of moving parts and reduced power consumption is disclosed in United States Patent 5,350,909, issued to Powell, et al. and entitled OPTICAL SCANNER FOR BAR CODE SCANNING. To control operation of generator 400, a dedicated keyboard 406 attached to housing 405 may be included. Alternatively, a port for connection with a standard PC alphanumeric keyboard and controller, such as keyboard 156 and controller 155 illustrated in Fig. 1, may be included. The design and construction of a bar code generator apparatus and/or bar code scanning apparatus which may be suitable for use as peripheral 404 are within the scope of those reasonably skilled in the art, as are the design of housing 405, power supply 410, and keyboard 406, as well as their interconnection with generator 200. A detailed implementation of such devices will not be included herein for the sake of brevity.
Generator 400 may be used with both tangible documents as well as electronic files supplied to generator 400 via connection to a computer or network, as illustrated in Fig. 4B. Specifically, any number of time stamp generators 200, as coupled to computer systems 100 or standalone generators 400 may be connected over a local area network, wide area network, or, over the Internet. As illustrated in Fig. 4B, an external receiver 402A, e.g. a GPS receiver, is coupled over a computer network to computer systems 100A-C, each of which include a time stamp generator 200A-C, respectively, in accordance with the present invention. A standalone time stamp generator 400A and 400B are further coupled to receive 402A in a similar manner. Time stamp generator 400B itself includes its own receiver 402B. Any number of time stamp generators may be intercoupled over a network, provided at least one external receiver is accessible through the network to provide the necessary information for the time and date portion of the time stamp. The limitations of actual network configurations are dictated by the bandwidth of the network, the protocol, and the number of ports available on each respective apparatus. In this matter, a single receiver may provide the necessary time and date information to multiple time stamp generators, thereby eliminating the need for each time stamp generator to be coupled directly to a single external time source.
Fig. 5 is a flow chart illustrating the basic process steps used by processor 206 to generate a notary time stamp in accordance with the present invention. The coding of the process steps of the illustrated flow chart information instructions suitable for control of processor 206 will be understandable by one having ordinary skill in the art of programming. The process steps described within Fig. 5 applicable equally to either generator 200 or 400.
Following power-on and initialization, processor 206 remains idle until a request is received for generation of a time stamp, as illustrated by decisional block 500. Processor 206 retrieves an externally generated time signal from receiver 202, either directly through a serial or parallel port, or through a network necessary connection, as described previously. Once the time and date data is retrieved, any necessary reformatting of the data occurs and the data is stored in buffer 210 as the value of field 302 of Fig. 3. Next, processor 206 requests a write/read operation to be performed on PROM 222. The operation triggers selection of the next address from the PROM and further triggers a high energy write signal to be applied to the selected PROM address. The cell(s) addressed are then irreversibly burned and the output signature of the PROM supplied to processor 206 for appending to the contents of buffer 210 as the value of field 308. This process is illustrated by procedural block 504. Next, processor 206 retrieves the generator identifier, typically from ROM, and appends the value to buffer 210 as the value of field 306, as illustrated in Fig. 3. Next, a check-sum algorithm is applied to some or all of the contents of buffer 210 and the check-sum value written into the buffer 210 as the value of field 310, as illustrated by process 508.
If the request for a time stamp included the name of a file, processor 206, in conjunction with the operating system of computer system 100 and any applicable network's protocols causes the file contents to be retrieved and temporarily written to RAM 208, as illustrated by decisional block 510 and procedural block 512. Next, processor 206 causes a check-sum algorithm to be applied to the contents of the file in RAM 208, as illustrated by the procedural block 514. The resulting check-sum value is appended to the contents of buffer 210 either in place of the existing check-sum field 310 or in addition thereto, as illustrated by procedural block 514. Next, processor 206 causes the contents of buffer 210, representing the notary time stamp, to be written to an area of memory associated with the data file and accessible only by the time stamp generator 200. In the illustration embodiment, only field 302, 306, 308 and 304, if applicable, are viewable or added to the header information of a file. The check-sum value(s) are not visible to anyone viewing the time stamp or the file.
Alternatively, if the request for a time stamp was not accompanied with the name of a data file, the contents of buffer 210 may be written to a peripheral device, such as bar code generator 404 for application to a tangible document, as illustrated by procedural block 518. If power has not been removed from generator 200 the process remains in idle while awaiting the next request for a time stamp, as illustrated.
The process illustrated in Fig. 5 may also be utilized to generate a time stamp 300 including optional positional information 304. Such positional information would be added to buffer 210 in procedural step 502. Where such positional information is directly available from the external receiver, the information is retrieved along with the date and time information. Use of positional information in time stamp 300, is valid only where the position of the receiver is within reasonable proximity, e.g. the error differential of the receiver, to the actual time stamp generator itself. Otherwise, particularly in the instance of network connections or retrieval of time and date information over the Internet, the location of the specific receiver may be irrelevant to the location of the time stamp generator generating the time stamp in question.
Fig. 6 is a flow chart illustrating the basic process steps used by processor 206 to validate a notary time stamp in accordance with the present invention. The coding of the process steps of the flow chart into instructions suitable for control of processor 206 will be understood by one having ordinary skill in the art of programming. The process steps described in Fig. 6 are applicable equally to either a generator 200 or a generator 400.
Following power-on and initialization, processor 206 remains idle until a request for validation of a time stamp is received, as illustrated by decisional block 600. In procedural block 602, processor 206 determines whether or not the request was accompanied by an address in memory of an electronically stored time stamp, as well as possibly the address of the data file associated with the time stamp, as illustrated by decisional block 602. Next, processor 206 retrieves the time stamp value, including the check sum values, from the designated memory location, as illustrated in by processed block 604. Next, processor 206 causes the same check sum algorithm to be applied to the contents of the retrieved time stamp value, as illustrated by procedure block 606. The recomputed check sum value is then compared to the value within the retrieved time stamp, as illustrated by procedural block 608, to determine if a match occurs, as illustrated by decisional block 610. If no match occurs, indicating that the contents of the time stamp have been altered from their original value, processor 206 causes a message to be displayed and/or printed to the user indicating that the integrity of the retrieved time stamp is no longer valid, as illustrated by procedural block 612. If the recomputed and retrieved check sum values match, processor 206 will display and/or print a message indicating that the retrieved time stamp is valid, as illustrated by procedural block 614. If a data file address was specified along with the address of the electronically stored time stamp, processor 206 will retrieve the referenced data file in block 604, as well, and also recompute the check sum value for the data file, if applicable, in block 606. Next, the contents of the recomputed data file check sum will be compared with the data file check sum from the retrieved time stamp, in a manner similar to that previously described with reference to procedural blocks 606 and 608. If a match occurs, processor 206 will cause a message to be displayed and/or printed indicating that the data file associated with the time stamp is valid, similar that displayed with reference to block 614. Alternatively, if the recomputed check sum for the datafile does not match the check sum from the retrieved time stamp, processor 206 will cause a message to be displayed and/or printed, indicating that the contents of the datafile have been altered, similar to that displayed with reference to block 612.
If, in decisional block 602, no references to memory addresses were supplied along with the verification request, processor 206 will attempt to read the value of a time stamp from peripheral 404, indicating that the time stamp is affixed to a tangible document, as illustrated in procedural block 616. The procedure then proceeds to block 606, as previously described.
It will be obvious to those reasonably skilled in the art that the contents of the time stamp check sum field 310 and any accompanying datafile check sum fields may be generated using one or more different check sum algorithms. For instance, processor 206 may be able to generate check sums using any one of a plurality of available check sum generation algorithms programmed into processor 206. In such instance, the check sum fields may include not only the value of the check sum, but a code identifying which algorithm was utilized to generate the check sum and the field within the time stamp on which the check sum was derived. In this manner, different check sum algorithms may be utilized to further reinforce the security of the time stamp generation process.
In addition, the entire time stamp itself, or, selective fields of the time stamp, may be encrypted using any number of encryption technologies such as those commercially available from RSA Data Security Inc., Redwood City, California. Other types of encryption algorithms including secret key encryption and public/private key encryption may be utilized with the notary time stamp of the present invention. In such instances, an identifier indicating either the key or the type of encryption utilized may be appended to the time stamp to facilitate decryption and validation processes.
Although various exemplary embodiments of the invention have been disclosed, it will be apparent to those skill in the art that various changes and modifications can be made which will achieve some of the advantages of the invention without departing from the spirit and scope of the invention. These and other obvious modifications are intended to be covered by the appended claims.

Claims

1. An apparatus for generating notary time stamps comprising: means (200, 206) for retrieving a time signal, the time signal generated externally to the apparatus and comprising date and time data; logic means (226, 222) for irreversibly creating a sequential time stamp identifier for association with the date and time data; and means, responsive to the sequential identifier and the date and time data, for generating a notary time stamp (206, 212, 208), the notary time stamp comprising a first portion which may be utilized to verify the contents of a second portion of the notary time stamp.
2. The apparatus of claim 1 wherein the logic means for irreversibly creating a sequential identifier comprises: a memory device (222) comprising a plurality of cells, each cell of which can be programmed only once.
3. The apparatus of claim 1 wherein the first portion comprises a check sum (310) having a value derived from a portion of the time stamp.
4. The apparatus of claim 5 wherein the document comprises a data file and the apparatus further comprises means for writing the notary time stamp to a portion of memory associated with the data file.
5. The apparatus of claim 4 wherein the first portion comprises a check sum (310) having a value derived from one of the time stamp and the data file.
6. The apparatus of claim 1 wherein the apparatus has associated therewith an apparatus identifier and wherein the means for generating the notary time stamp (206, 212, 208) further comprises means, responsive to the apparatus identifier, for generating a notary time stamp further comprising an apparatus identifier.
7. In a notarial time stamp generation apparatus, a method for generating time stamps to be associated with documents and data files, the method comprising the steps of:
(a) receiving a request for generation of a notary time stamp (300);
(b) retrieving a time signal (302), the time signal generated externally of the apparatus and comprising date and time data;
(c) irreversibly modifying the output signature of a write once memory device (222) to generate a unique time stamp identifier (308);
(d) generating a notary time stamp (300) from the date and time data and the time stamp identifier (308); and
(e) generating as part of the notary time stamp a check-sum (310) having a value derived from at least a portion of the notary time stamp.
8. The method of claim 7 wherein the apparatus has associated therewith a unique source identifier (306) and wherein step (d) further comprises the step of: d.1 generating a notarial time stamp (300) from the date and time data (302), the time stamp identifier (308), and the apparatus identifier (306).
9. A notary time stamp for association with documents or data files comprising: a source identifier (306) uniquely identifying the source of the notary time stamp; a time stamp sequence identifier (308) generated through an irreversible process by the source of the notary time stamp; time and date data (302) obtained external of the source of the notary time stamp; and a check-sum value (310) derived from at least one of the source identifier, time stamp sequence identifier and date and time data.
10. An apparatus (200) for verifying the authenticity of a notary time (300) stamp associated with a document or data file, the notary time stamp comprising a source identifier (306), a time stamp sequence identifier (308), date and time data (302) and a check-sum value (310) derived from at least a portion of the time stamp, the apparatus comprising: means for reading the notary time stamp; and means (206), responsive to the check-sum value, for verifying the portion of the time stamp from which the check sum value was derived.
11. The apparatus of claim 10 wherein the notary time stamp is associated with a data file and wherein the check sum value is at least partially derived from the content of the data file and wherein the means for verifying the check-sum value further comprises: means for verifying the content of the data file from which the check-sum value was at least partially derived.
12. In an apparatus verifying the authenticity of a time stamp having a checksum value portion, a method comprising the steps of:
(a) reading the time stamp (300);
(b) identifying the data from which a check-sum value (310) was derived;
(c) computing a new check-sum value from the identified data;
(d) comparing the new check-sum value with a previously calculated check-sum value (310) portion of the time stamp (300); and
(e) generating a message in response to the comparison of step (d).
13. The method of claim 12 wherein the data identified by the check-sum value portion comprises a data file associated with the time stamp and wherein step (c) comprises the step of: c.1 computing a new check-sum value from the data file.
14. The method of claim 12 wherein the data identified by the check-sum value portion comprises a second portion of the time stamp and wherein step (c) comprises the step of: c.1 computing a new check-sum value (310) from at least the second portion of the time stamp.
PCT/US1998/010765 1997-05-29 1998-05-27 Method and apparatus for providing secure time stamps for documents and computer files WO1998054634A1 (en)

Priority Applications (3)

Application Number Priority Date Filing Date Title
CA002290365A CA2290365A1 (en) 1997-05-29 1998-05-27 Method and apparatus for providing secure time stamps for documents and computer files
DE69802080T DE69802080D1 (en) 1997-05-29 1998-05-27 METHOD AND DEVICE FOR REALIZING SAVED TIMES FOR DOCUMENTS AND COMPUTER FILES
EP98924915A EP0985171B1 (en) 1997-05-29 1998-05-27 Method and apparatus for providing secure time stamps for documents and computer files

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US08/865,292 1997-05-29
US08/865,292 US6209090B1 (en) 1997-05-29 1997-05-29 Method and apparatus for providing secure time stamps for documents and computer files

Publications (1)

Publication Number Publication Date
WO1998054634A1 true WO1998054634A1 (en) 1998-12-03

Family

ID=25345152

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US1998/010765 WO1998054634A1 (en) 1997-05-29 1998-05-27 Method and apparatus for providing secure time stamps for documents and computer files

Country Status (5)

Country Link
US (1) US6209090B1 (en)
EP (1) EP0985171B1 (en)
CA (1) CA2290365A1 (en)
DE (1) DE69802080D1 (en)
WO (1) WO1998054634A1 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1022640A2 (en) * 1999-01-20 2000-07-26 Hewlett-Packard Company Provision of trusted services
SG108926A1 (en) * 2002-06-18 2005-02-28 Seiko Instr Inc Electronic balloting module and electronic balloting method
GB2431020A (en) * 2005-10-05 2007-04-11 Gary Watkins Accurate and verifiable time stamping for electronic documents
ITTO20130675A1 (en) * 2013-08-06 2015-02-07 Panini Spa DIGITAL SCANNER OF CHECKS, SYSTEM AND METHOD FOR THE TRACEABILITY OF CHECKS
EP2083531A3 (en) * 2008-01-23 2017-06-14 De Luca, Stefano Location- and time-stamping device, particularly for digital documents
US10833849B2 (en) 2018-03-21 2020-11-10 Clover Network, Inc. Unified secure device provisioning
US11721181B2 (en) 2019-07-26 2023-08-08 Clover Network, Llc. Advanced hardware system for self service checkout kiosk

Families Citing this family (50)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1006462A3 (en) 1998-12-01 2005-03-30 Lucent Technologies Inc. A method and apparatus for persistent storage of web resources
IL128720A (en) * 1999-02-25 2009-06-15 Cidway Technologies Ltd Method for certification of over the phone transactions
JP4779183B2 (en) * 1999-03-26 2011-09-28 ソニー株式会社 Playback apparatus and playback method
US6839879B1 (en) * 1999-05-07 2005-01-04 Xilinx, Inc. Method and system for time-stamping and managing electronic documents
US6948069B1 (en) 1999-07-02 2005-09-20 Time Certain, Llc Method and system for determining and maintaining trust in digital image files with certifiable time
US8868914B2 (en) * 1999-07-02 2014-10-21 Steven W. Teppler System and methods for distributing trusted time
US6898709B1 (en) 1999-07-02 2005-05-24 Time Certain Llc Personal computer system and methods for proving dates in digital data files
US6895507B1 (en) * 1999-07-02 2005-05-17 Time Certain, Llc Method and system for determining and maintaining trust in digital data files with certifiable time
US7409557B2 (en) 1999-07-02 2008-08-05 Time Certain, Llc System and method for distributing trusted time
EP1122728A1 (en) * 1999-08-20 2001-08-08 Sony Corporation Information recording/reproducing device
US6792536B1 (en) 1999-10-20 2004-09-14 Timecertain Llc Smart card system and methods for proving dates in digital files
US20050160272A1 (en) * 1999-10-28 2005-07-21 Timecertain, Llc System and method for providing trusted time in content of digital data files
US6993656B1 (en) * 1999-12-10 2006-01-31 International Business Machines Corporation Time stamping method using aged time stamp receipts
US7813875B2 (en) * 2002-10-10 2010-10-12 Sirf Technology, Inc. Layered host based satellite positioning solutions
US7546395B2 (en) * 2002-10-10 2009-06-09 Sirf Technology, Inc. Navagation processing between a tracker hardware device and a computer host based on a satellite positioning solution system
US20010052873A1 (en) * 2000-06-14 2001-12-20 Rezai Ahmad (Dulce) Global positioning system stamp machine
FR2811848A1 (en) * 2000-07-13 2002-01-18 Thomson Multimedia Sa SYSTEM, METHOD AND DEVICE FOR TIMING AND VERIFYING HORODATE VALIDITY IN A DIGITAL BROADCASTING ENVIRONMENT
US6826546B1 (en) * 2000-08-17 2004-11-30 Ideaflood, Inc. Method and system for licensing a copy of a copyright protected work
KR20010008268A (en) * 2000-11-20 2001-02-05 이계철 A new time stamping service for setting client's system clock
US6633862B2 (en) * 2000-12-29 2003-10-14 Intel Corporation System and method for database cache synchronization across multiple interpreted code engines
KR100350506B1 (en) * 2000-12-29 2002-08-29 삼성전자 주식회사 Time information management method and system for embed system
GB2375846B (en) * 2001-05-10 2004-11-24 Christopher Howard Cook Computer processing of electronic documents
FI115811B (en) * 2001-06-27 2005-07-15 Nokia Corp Procedure for checking time data, system and terminal
US7268901B2 (en) * 2001-07-26 2007-09-11 Hewlett-Packard Development Company, L.P. Intelligent printing by a kiosk
AUPR745301A0 (en) * 2001-09-03 2001-09-27 Mobilesoft Pty Limited Method and system for compiling and verifying computer code
US7197143B2 (en) * 2002-01-18 2007-03-27 The Johns Hopkins University Digital video authenticator
US20030204736A1 (en) * 2002-04-25 2003-10-30 International Business Machines Corporation Apparatus for authenticated recording and method therefor
JP2003323357A (en) * 2002-05-08 2003-11-14 Hitachi Ltd Time stamp generation system
US7509683B2 (en) * 2002-08-26 2009-03-24 Hewlett-Packard Development Company, L.P. System and method for authenticating digital content
US7197644B2 (en) * 2002-12-16 2007-03-27 Xerox Corporation Systems and methods for providing hardcopy secure documents and for validation of such documents
US20040192343A1 (en) * 2003-01-28 2004-09-30 Kentaro Toyama System and method for location annotation employing time synchronization
DE10326665A1 (en) * 2003-06-11 2005-01-20 Endress + Hauser Process Solutions Ag Method for monitoring a field device
US20060184452A1 (en) * 2003-10-14 2006-08-17 Maccord Mason Pllc, Electronic document management system
WO2005086460A1 (en) * 2004-02-06 2005-09-15 Sirf Technology, Inc. Navigation processing in host based satellite positioning solution methods and systems
US7752667B2 (en) * 2004-12-28 2010-07-06 Lenovo (Singapore) Pte Ltd. Rapid virus scan using file signature created during file write
US7805765B2 (en) * 2004-12-28 2010-09-28 Lenovo (Singapore) Pte Ltd. Execution validation using header containing validation data
US7890762B2 (en) * 2004-12-30 2011-02-15 Sap Ag Differentiated proxy digital signatures
US9277295B2 (en) 2006-06-16 2016-03-01 Cisco Technology, Inc. Securing media content using interchangeable encryption key
WO2008002653A2 (en) * 2006-06-28 2008-01-03 University Of Utah Research Foundation System and method for precise absolute time event generation and capture
US9137480B2 (en) * 2006-06-30 2015-09-15 Cisco Technology, Inc. Secure escrow and recovery of media device content keys
US7873878B2 (en) * 2007-09-24 2011-01-18 International Business Machines Corporation Data integrity validation in storage systems
JP5045472B2 (en) * 2008-02-07 2012-10-10 富士通株式会社 Mail management apparatus, mail management method, and mail management program
US8145910B1 (en) * 2008-02-29 2012-03-27 Adobe Systems Incorporated System and method to enforce collaboration rules for timestamps of a collaboration event
JP5154292B2 (en) * 2008-04-24 2013-02-27 株式会社日立製作所 Information management system, form definition management server, and information management method
US20110038594A1 (en) * 2008-04-25 2011-02-17 Symons Gary M Handheld recorder incorporating true raw audio or video certification
US8374930B2 (en) * 2009-02-02 2013-02-12 Trustifi Corporation Certified email system and method
US8341023B2 (en) * 2009-06-17 2012-12-25 Trustifi Corporation Certified email system and method
US10692048B2 (en) * 2013-05-08 2020-06-23 Practice Insight Pty Ltd Apparatus and method for generating a chronological timesheet
JP6266801B2 (en) * 2014-09-16 2018-01-31 新日鉄住金ソリューションズ株式会社 Management system, portable terminal device, management method, information processing method, and program
WO2017130300A1 (en) * 2016-01-26 2017-08-03 信吉 森元 System and method for verifying real-time time stamp created by digital time stamp device

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1992003000A1 (en) * 1990-08-02 1992-02-20 Bell Communications Research, Inc. Method for secure time-stamping of digital documents
US5189700A (en) * 1989-07-05 1993-02-23 Blandford Robert R Devices to (1) supply authenticated time and (2) time stamp and authenticate digital documents
US5297178A (en) * 1992-03-18 1994-03-22 Arachnid, Inc. High security counter
EP0635790A1 (en) * 1993-07-22 1995-01-25 International Business Machines Corporation Client/server based secure timekeeping system
US5402490A (en) * 1992-09-01 1995-03-28 Motorola, Inc. Process for improving public key authentication
WO1995015522A1 (en) * 1993-12-02 1995-06-08 Scheele, Drew Digital data verification system

Family Cites Families (23)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4649266A (en) * 1984-03-12 1987-03-10 Pitney Bowes Inc. Method and apparatus for verifying postage
US5189707A (en) 1985-10-11 1993-02-23 Hitachi, Ltd. Method of loading surface mounted device and an apparatus therefor
US5001752A (en) 1989-10-13 1991-03-19 Fischer Addison M Public/key date-time notary facility
GB8923351D0 (en) 1989-10-17 1989-12-06 Stc Plc Multifrequency optical network
US5212788A (en) 1990-05-22 1993-05-18 Digital Equipment Corporation System and method for consistent timestamping in distributed computer databases
JPH0432940A (en) 1990-05-23 1992-02-04 Toshiba Corp Decentralized data base system
US5893117A (en) 1990-08-17 1999-04-06 Texas Instruments Incorporated Time-stamped database transaction and version management system
US5334974A (en) 1992-02-06 1994-08-02 Simms James R Personal security system
US5241675A (en) 1992-04-09 1993-08-31 Bell Communications Research, Inc. Method for enforcing the serialization of global multidatabase transactions through committing only on consistent subtransaction serialization by the local database managers
US5410739A (en) 1992-09-29 1995-04-25 The Titan Corporation Variable data message communication over voice communication channel
US5243652A (en) 1992-09-30 1993-09-07 Gte Laboratories Incorporated Location-sensitive remote database access control
US5440313A (en) 1993-05-27 1995-08-08 Stellar Gps Corporation GPS synchronized frequency/time source
US5367306A (en) 1993-06-04 1994-11-22 Hollon Blake D GPS integrated ELT system
US5544353A (en) 1993-06-14 1996-08-06 International Business Machines Corporation Distributed processing object shared resource control apparatus and method
US5499294A (en) * 1993-11-24 1996-03-12 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Digital camera with apparatus for authentication of images produced from an image file
DE4344471A1 (en) * 1993-12-21 1995-08-17 Francotyp Postalia Gmbh Method and device for generating and checking a security impression
US5467342A (en) 1994-01-12 1995-11-14 Scientific-Atlanta, Inc. Methods and apparatus for time stamp correction in an asynchronous transfer mode network
US5422816A (en) 1994-02-22 1995-06-06 Trimble Navigation Limited Portable personal navigation tracking system
US5530851A (en) 1994-04-28 1996-06-25 The United States Of America As Represented By The Secretary Of The Navy Early commit timestamp computer database protocol
GB2298951B (en) 1995-03-17 1999-10-27 Olivetti Res Ltd Addition of time information
WO1998034403A1 (en) * 1995-09-29 1998-08-06 Intel Corporation Apparatus and method for securing captured data transmitted between two sources
US5742685A (en) * 1995-10-11 1998-04-21 Pitney Bowes Inc. Method for verifying an identification card and recording verification of same
DE19610401A1 (en) * 1996-03-16 1997-09-18 Deutsche Telekom Ag Method and arrangement for proving the time at which a cryptographic process was carried out

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5189700A (en) * 1989-07-05 1993-02-23 Blandford Robert R Devices to (1) supply authenticated time and (2) time stamp and authenticate digital documents
WO1992003000A1 (en) * 1990-08-02 1992-02-20 Bell Communications Research, Inc. Method for secure time-stamping of digital documents
US5297178A (en) * 1992-03-18 1994-03-22 Arachnid, Inc. High security counter
US5402490A (en) * 1992-09-01 1995-03-28 Motorola, Inc. Process for improving public key authentication
EP0635790A1 (en) * 1993-07-22 1995-01-25 International Business Machines Corporation Client/server based secure timekeeping system
WO1995015522A1 (en) * 1993-12-02 1995-06-08 Scheele, Drew Digital data verification system

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
EP1022640A2 (en) * 1999-01-20 2000-07-26 Hewlett-Packard Company Provision of trusted services
EP1022640A3 (en) * 1999-01-20 2006-08-02 Hewlett-Packard Company, A Delaware Corporation Provision of trusted services
SG108926A1 (en) * 2002-06-18 2005-02-28 Seiko Instr Inc Electronic balloting module and electronic balloting method
GB2431020A (en) * 2005-10-05 2007-04-11 Gary Watkins Accurate and verifiable time stamping for electronic documents
GB2431020B (en) * 2005-10-05 2010-08-25 Gary Watkins Apparatus and system for verification of documents and data
EP2083531A3 (en) * 2008-01-23 2017-06-14 De Luca, Stefano Location- and time-stamping device, particularly for digital documents
ITTO20130675A1 (en) * 2013-08-06 2015-02-07 Panini Spa DIGITAL SCANNER OF CHECKS, SYSTEM AND METHOD FOR THE TRACEABILITY OF CHECKS
US10833849B2 (en) 2018-03-21 2020-11-10 Clover Network, Inc. Unified secure device provisioning
US11711205B2 (en) 2018-03-21 2023-07-25 Clover Network, Llc. Unified secure device provisioning
US11721181B2 (en) 2019-07-26 2023-08-08 Clover Network, Llc. Advanced hardware system for self service checkout kiosk

Also Published As

Publication number Publication date
EP0985171A1 (en) 2000-03-15
EP0985171B1 (en) 2001-10-17
US6209090B1 (en) 2001-03-27
DE69802080D1 (en) 2001-11-22
CA2290365A1 (en) 1998-12-03

Similar Documents

Publication Publication Date Title
EP0985171B1 (en) Method and apparatus for providing secure time stamps for documents and computer files
US5001752A (en) Public/key date-time notary facility
US5136643A (en) Public/key date-time notary facility
USRE38375E1 (en) Method and system for the secured distribution of multimedia titles
US5022080A (en) Electronic notary
US5189700A (en) Devices to (1) supply authenticated time and (2) time stamp and authenticate digital documents
CN100447776C (en) Embedded safety ship of real-time clock and method for correcting real-time clock thereof
US5097504A (en) Method and device for qualitative saving of digitized data
US5781630A (en) Method and device for accurately dating an electronic document
US7506812B2 (en) Transparently securing data for transmission on financial networks
US20040139327A1 (en) System and method for document-driven processing of digitally-signed electronic documents
US20030023858A1 (en) Method for secure e-passports and e-visas
EP1227613B1 (en) Method and apparatus for attaching electronic signature to document having structure
WO1998037655A1 (en) Method and system for processing electronic documents
JP2003228284A (en) Data retention device, data retention method, data verification device, data access permission device, program, recording medium
EP1022640A2 (en) Provision of trusted services
JP2997483B2 (en) Verification data generator
WO2022179120A1 (en) Gateway interception method and apparatus, electronic device and storage medium
JP3475145B2 (en) Time information providing system, time information providing method, and computer-readable recording medium storing a program for causing a computer to execute the time information providing method
RU2207617C1 (en) Method and electronic cryptographic module for information protection and authenticity control
JP2002244554A (en) Method for generating and confirming time stamp, and device and system therefor
JPH10289523A (en) Device for storing data and method therefor
JP4226447B2 (en) How to verify digital signature
JP2002358240A (en) Temporal certification method for electronic file and temporal certification device for electronic file
CN113723958A (en) Payment file testing method, device, equipment and medium based on AI encryption

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): CA JP

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LU MC NL PT SE

DFPE Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101)
121 Ep: the epo has been informed by wipo that ep was designated in this application
ENP Entry into the national phase

Ref document number: 2290365

Country of ref document: CA

Ref country code: CA

Ref document number: 2290365

Kind code of ref document: A

Format of ref document f/p: F

WWE Wipo information: entry into national phase

Ref document number: 1998924915

Country of ref document: EP

NENP Non-entry into the national phase

Ref country code: JP

Ref document number: 1999500859

Format of ref document f/p: F

WWP Wipo information: published in national office

Ref document number: 1998924915

Country of ref document: EP

WWW Wipo information: withdrawn in national office

Ref document number: 1998924915

Country of ref document: EP