WO2003079628A1 - Certificate information storage system and method - Google Patents
Certificate information storage system and method Download PDFInfo
- Publication number
- WO2003079628A1 WO2003079628A1 PCT/CA2003/000406 CA0300406W WO03079628A1 WO 2003079628 A1 WO2003079628 A1 WO 2003079628A1 CA 0300406 W CA0300406 W CA 0300406W WO 03079628 A1 WO03079628 A1 WO 03079628A1
- Authority
- WO
- WIPO (PCT)
- Prior art keywords
- digital certificate
- data store
- store
- information
- data
- Prior art date
Links
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L12/00—Data switching networks
- H04L12/02—Details
- H04L12/22—Arrangements for preventing the taking of data from a data transmission channel without authorisation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L63/00—Network architectures or network communication protocols for network security
- H04L63/08—Network architectures or network communication protocols for network security for authentication of entities
- H04L63/0823—Network architectures or network communication protocols for network security for authentication of entities using certificates
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F21/00—Security arrangements for protecting computers, components thereof, programs or data against unauthorised activity
- G06F21/60—Protecting data
- G06F21/606—Protecting data by securing the transmission between two devices or processes
Definitions
- This application relates generally to the field of secure electronic messaging and in particular to storing cryptographic information contained in an electronic message in a memory of a computer device.
- Known secure messaging clients such as e-mail software applications operating on a computer device, maintain separate data stores or data storage areas for storing secure messaging information separate from other information.
- Such secure messaging mformation may include digital certificates, public keys, and the like.
- the other information may include contact information such as an address book, schedule information such as calendar reminders and appointments, and the like.
- a digital certificate may include information relevant to other types of stored information.
- a digital certificate normally includes the public key of an entity as well as identity information that is bound to the public key with one or more digital signatures.
- a digital certificate When a digital certificate is loaded onto a system for use by a messaging client, if the entity' s contact information is not already stored in an address store accessible to the messaging client, then a user must either manually add contact information for the entity identified in the digital certificate into an address book or similar contact list stored on the messaging client or manually enter an address for the entity each time a message is to be sent to that entity.
- a method of storing digital certificate information from a digital certificate received at a messaging client comprises the steps of extracting the digital certificate information from the digital certificate, determining whether the extracted digital certificate information is stored in a data store at the messaging client, and storing the extracted digital certificate information in the data store where the extracted digital certificate information is not stored in the data store.
- a system for storing digital certificate information at a messaging client in accordance with another aspect of the invention comprises a digital certificate loader module configured to receive digital certificates, and a digital certificate information injector module configured to extract digital certificate information from a digital certificate after the digital certificate is received by the digital certificate loader module, to determine whether the extracted digital certificate information is stored in an entry in a first data store, and to store the extracted digital certificate information in the first data store where the extracted digital certificate information is not stored in the entry in the first data store.
- a method of managing digital certificate data stored in a mobile communication device comprises the steps of receiving transmitted digital certificate data at the mobile communication device, comparing the transmitted digital certificate data to digital certificate data stored in a memory store in the mobile communication device, and updating the memory store to include transmitted digital certificate data not stored in the memory store.
- FIG. 1 is a block diagram of a messaging system.
- Fig. 2 is a block diagram illustrating a messaging system and a secure e-mail message exchange.
- Fig. 3 is a block diagram of a mobile device with a digital certificate information storage system.
- Fig. 4 is a flow diagram illustrating a method of storing digital certificate information.
- Fig. 5 is a flow diagram illustrating a method of generating and sending messages subject to digital certificate information stored in the digital certificate information storage system.
- Fig. 6 is a flow diagram illustrating a method of performing digital certificate related operations based on digital certificate related events.
- Fig.7 is a structural block diagram of the digital certificate information storage system.
- Fig. 8 is a block diagram of a wireless mobile communication device.
- Fig. 9 is a block diagram showing an example communication system.
- Fig. 10 is a block diagram of an alternative communication system.
- Fig. 11 is a block diagram of another alternative communication system.
- Secure messages include messages that have been signed with digital signature, encrypted, or otherwise processed to ensure one or more of data confidentiality, data integrity and user authentication.
- a secure message may be a message that has been signed, encrypted, encrypted and then signed, or signed and then encrypted, by a message sender. These operations may be carried out according to a known standard, such as the Secure Multipurpose Internet Mail Extensions (S/MDVIE) standard.
- S/MDVIE Secure Multipurpose Internet Mail Extensions
- Fig. 1 is a block diagram of a messaging system. There are many different messaging system topologies, and the system shown in Fig. 1 is but one of many that maybe used with the systems and methods disclosed herein.
- the system 10 includes a Wide Area Network (WAN) 12, to which a computer system 14, a wireless network gateway 16, and a corporate Local Area Network (LAN) 18 are connected.
- the wireless network gateway 16 is also connected to a wireless communication network 20 in which a wireless mobile communication device 22, hereinafter referred to primarily as a mobile device, is configured to operate.
- the computer system 14 represents a desktop or laptop PC that is configured for connection to the WAN 12.
- the WAN 12 can be a private network, or a larger publicly accessible network, such as the Internet.
- the corporate LAN 18 is an example of a network-based messaging client. As shown, a corporate LAN 18 is normally located behind a security firewall 24. Within the corporate LAN 30 is a message server 26, running on a computer within the firewall 24, that functions as the main interface for the corporation to exchange messages both within the LAN 18 and with other external messaging clients via the WAN 20. Two of the most common message servers 26 are the MicrosoftTM Exchange and Lotus DominoTM server products. These servers are often used in conjunction with Internet mail routers that route and deliver mail. A message server 26 may extend beyond just message sending and receiving, providing such functionality as dynamic database storage engines that have predefined database formats for data like calendars, to-do lists, task lists, e-mail and documentation.
- the message server 26 provides messaging capabilities to one or more network computer systems 28 in the LAN 18.
- a typical LAN includes multiple computer systems shown generally as computer systems 28, each of which implements a messaging client, most often as a software application such as Microsoft OutlookTM, for messaging functions.
- messages are received by the message server 26, distributed to the appropriate mailboxes for user accounts addressed in the received message, and can be accessed by a user through a computer in the one or more computer systems 28.
- messaging clients in the LAN 18 operate on the computer systems 28, there are also known messaging clients that operate in conjunction with handheld devices and other systems or devices with electronic messaging capabilities.
- a messaging client may also have additional non-messaging functions.
- the wireless network gateway 16 provides an interface to a wireless network 20, through which messages may be exchanged with a mobile device 22. Such functions as addressing of a mobile device 22, encoding or otherwise transforming messages for wireless transmission, and any other required interface functions are performed by the wireless network gateway 16. Where the wireless network gateway 16 is configured for operation in conjunction with more than one wireless network 20, the wireless network gateway 16 may also determine a most likely network for locating a given user and track users as they roam between countries or networks. Any computer system with access to the WAN 12 may exchange messages with a mobile device 22 through the wireless network gateway 16. Alternatively, private wireless network gateways such as wireless Virtual Private Network (VPN) routers could also be implemented to provide a private interface to a wireless network such as 20. For example, a wireless VPN implemented in the LAN 18 provides a private interface from the LAN 18 to one or more mobile devices through the wireless network 20.
- VPN Virtual Private Network
- Such a private interface to wireless devices via the wireless network gateway 16 and/or the wireless network 20 can effectively be extended to entities outside the LAN 18 by providing a message forwarding or redirection system which operates with the message server 26.
- incoming messages received by the message server 26 and addressed to a user that has a mobile device 22 are redirected through the wireless network interface, either a wireless VPN router, the gateway 16 or another interface, for example, to the wireless network 20 and to the user's mobile device 22.
- An exemplary redirector system operating on the message server 26 may be of the type disclosed in United States Patent No.
- wireless networks such as 20
- messages are normally delivered to and from mobile devices such as the mobile device 22 via RF transmissions between base stations in the wireless network 20 and mobile devices.
- Modern wireless networks typically serve thousands of subscribers, each subscriber having a mobile device.
- the wireless network 20 may be one of many different types of wireless network, such as a data-centric wireless network, a voice- centric wireless network or and a dual-mode networks that can support both voice and data communications over the same physical base stations.
- Dual-mode networks include, but are not limited to recently-developed Code Division Multiple Access (CDMA) networks, the Groupe Special Mobile or the Global System for Mobile Communications (GSM) and the General Packet Radio Service (GPRS), and future third-generation (3G) networks like Enhanced Data rates for Global Evolution (EDGE) and Universal Mobile Telecommunications Systems (UMTS).
- CDMA Code Division Multiple Access
- GSM Global System for Mobile Communications
- GPRS General Packet Radio Service
- 3G networks like Enhanced Data rates for Global Evolution (EDGE) and Universal Mobile Telecommunications Systems (UMTS).
- EDGE Enhanced Data rates for Global Evolution
- UMTS Universal Mobile Telecommunications Systems
- GPRS is a data overlay on the GSM wireless network, operating in virtually every country in Europe.
- other wireless networks may also be used.
- data-centric networks include, but are not limited to the MobitexTM Radio Network (“Mobitex”) and the DataTACTM Radio Network (“DataTAC”).
- Mobitex MobitexTM Radio Network
- DataTAC DataTACTM Radio Network
- Examples of older voice-centric data networks include Personal Communication Systems (PCS) networks like CDMA, GSM, and Time Division Multiple Access (TDMA).
- PCS Personal Communication Systems
- TDMA Time Division Multiple Access
- the mobile device 22 may be a data communication device, a voice communication device, or a multiple-mode device capable of voice, data and other types of communications.
- An exemplary mobile device 22 is described in further detail below and with reference to Fig. 8.
- an e-mail message is sent by an e-mail sender, possibly through a message server and/or a service provider system, and typically routed through the Internet to one or more message receivers.
- E-mail messages are normally sent unencrypted and use traditional Simple Mail Transfer Protocol (SMTP), RFC822 headers and MIME body parts to define the format of the e-mail message.
- SMTP Simple Mail Transfer Protocol
- RFC822 headers RFC822 headers and MIME body parts
- PGP Pretty Good Privacy
- Fig. 2 is a block diagram illustrating a messaging system and a secure e-mail message exchange.
- the messaging system in Fig. 2 illustrates components involved in an example e-mail message exchange between two messaging clients, operating at an e-mail sender 30 and a mobile device 22. Many other components may be present in the overall messaging system and involved in routing the message from the sender 30 to the receiver, mobile device 22, but have not been shown in Fig. 2 to avoid congestion in the drawing.
- Fig. 2 also shows an encrypted and signed message as one example of a secure message.
- the systems and methods disclosed herein are also applicable to messaging clients that can send and receive other types of secure messages as well.
- Messaging clients may be configured to send either secure or unsecure messages, for example, in response to default configuration settings or a per-message selection by a user at a sender system.
- the system in Fig. 2 includes an e-mail sender 30, configured for access to a
- the wireless gateway 34 provides an interface to the wireless network 36 in which the mobile device 22 is adapted to operate.
- the e-mail sender 30 may, for example, be a PC such as the system 14 in Fig. 1 , or a network-connected computer such as 28.
- the e-mail sender 30 might also be a mobile device on which e-mail messages may be composed and sent.
- the WAN 32, wireless gateway 34, wireless network 36 and mobile device 22 are substantially the same as similarly labelled components in Fig. 1.
- a message 40 is encrypted using a one-time session key chosen by the e-mail sender 30.
- the session key is used to encrypt the message body and is then itself encrypted using the public key of each addressed message receiver to which the message is to be sent. Encrypted in this way, message 40 includes an encrypted message body 44 and an encrypted session key 46.
- a message sender such as e-mail sender 30, must have access to the public key of each entity to which an encrypted message is to be sent.
- a secure e-mail message sender such as 30 normally signs a message by taking a digest of the message and signing the digest using the sender's private key.
- a digest may, for example, be generated by performing a check-sum, a Cyclic Redundancy Check (CRC), a digest algorithm such as Message Digest Algorithm 5 (MD5), a hash algorithm such as Secure Hashing Algorithm 1 (SHA-1), or some other preferably non-reversible operation on the message.
- CRC Cyclic Redundancy Check
- MD5 Message Digest Algorithm 5
- MD5 Message Digest Algorithm 5
- SHA-1 Secure Hashing Algorithm 1
- the signature private key is used, for example, to perform an encryption or other transformation operation on the digest to generate the digest signature.
- a digital signature including the digest and the digest signature, is then appended to the Outgoing message, as shown at 42.
- a digital certificate of the sender which includes the sender's public key and sender identity information that is bound to the public key with one or more digital signatures, and possibly any chained digital certificates and Certificate Revocation Lists (CRLs) associated with the sender's digital certificate and any chained digital certificates may also be attached to the secure message 40.
- CTLs Certificate Revocation Lists
- a secure message 40 includes at least addressing and possibly other header information that may possibly be signed but most of which is typically not encrypted.
- the secure e-mail message When the secure e-mail message is sent from the e-mail sender 30, it is routed through the WAN 32 to the wireless gateway 34.
- the e-mail sender 30 may send the message 40 directly to a wireless gateway 34 or the message 40 may instead be delivered to a computer system associated with the mobile device 22 and then redirected to the mobile device 22 through the wireless gateway 34.
- the message may be routed or redirected to the mobile device 22 through the wireless network 36 through a wireless VPN router.
- the receiver of such a signed message may verify the digital signature 42.
- the ' mobile device uses a digital signature check algorithm corresponding to the signature generation algorithm used by the message sender, which may be specified in a message header or in the digital signature 42, and the sender's public key. If a secure message includes the sender's digital certificate, then the sender's public key may be extracted from the digital certificate.
- the sender' s public key may instead be retrieved from a local store, for example, where the public key was extracted from an earlier message from the sender and stored in a key store in the receiver's local store or the sender's digital certificate is stored in the local store, or from a Public Key Server (PKS).
- PKS is a server that is normally associated with a Certificate Authority (CA) from which a digital certificate for an entity, including the entity's public key, is available.
- CA Certificate Authority
- a PKS might reside within a corporate LAN such as LAN 18 of Fig. 1, or anywhere on the WAN 32, Internet or other network or system through which message receivers may establish communications with the PKS.
- digital signature algorithms and digest algorithms may be publicly known, a sender signs an original message using its own private key. Therefore, an entity that alters an original message cannot generate a digital signature that can be verified with the sender's public key. If a sent message is altered by an attacker after it has been signed by a sender, then the digital signature verification based on the sender's public key fails. These mathematical operations do not prevent anyone from seeing the contents of the secure message, but do ensure that the message has not been tampered with because it was signed by the sender, and that the message was signed by the person as indicated in the "From" field of the message. When the digital signature 42 has been verified, or sometimes even if digital signature verification fails, the encrypted message body 44 is then decrypted before it can be displayed or further processed.
- a message receiver uses its private key to decrypt the encrypted session key 46 and then uses the decrypted session key to decrypt the encrypted message body 44 and thereby recover the original message.
- Decryption typically requires action on the part of a user, such as entry of a password or passphrase.
- an encrypted message will be stored at a receiving messaging client only in its encrypted form. Each time the message is to be displayed or otherwise processed, it is first decrypted.
- an entity may have more than one associated cryptographic key pair, such as a signature private/public key pair and an encryption private/public key pair.
- the mobile device 22 may use one private key to decrypt the encrypted message body 44, and a different private key to digitally sign an outgoing secure message.
- An encrypted message that is addressed to more than one receiver includes an encrypted version of the session key, for each receiver, that was encrypted using the public key of the receiver.
- Each receiver performs the same digital signature' verification operations, but decrypts a different one of the encrypted session keys using its own private key.
- a sending messaging client must have access to the public key of any receiver to which an encrypted message is to be sent.
- a receiving messaging client must be able to retrieve the sender's public key, which may be available to a messaging client through various mechanisms, in order to verify a digital signature in a signed message.
- Public keys are commonly provided in digital certificates.
- a digital certificate for any particular entity typically includes the entity's public key and identification information that is bound to the public key with a digital signature.
- Several types of digital certificates are currently in widespread use, including for example X.509 digital certificates that are typically used in S MIME.
- PGP uses digital certificates with a slightly different format.
- Other digital certificates such as a digital certificate according to a proprietary standard, may also be used.
- the digital signature in a digital certificate is generated by the issuer of the digital certificate, and can be checked by a message receiver substantially as described above.
- a digital certificate may include an expiry time or validity period from which a messaging client determines if the digital certificate has expired.
- Verification of the validity of a digital certificate may also involve tracing a certification path through a digital certificate chain, which includes a user' s digital certificate and other digital certificates to verify that the user ' s digital certificate is authentic.
- a digital certificate may also be checked against a CRL to ensure that the digital certificate has not been revoked.
- the public key in the digital certificate is assumed to be the public key of the entity for which the digital certificate was issued, also referred to as the subject of the digital certificate.
- Digital certificates may be available to a messaging client from several sources. When a digital certificate is attached to a received message, the digital certificate can be extracted from the message and stored in a memory store in the messaging client. Otherwise, digital certificates can be requested and downloaded from a PKS on a LAN, the Internet, or other network with which a requestor may establish communications. It is also contemplated that a messaging client may load digital certificates from other sources than a PKS. For example, many modern mobile devices are configured for connection to a PC . By connecting a mobile device to a PC to download digital certificates via a physical connection, such as a serial port or USB port, over-the-air transfer of digital certificates may be reduced.
- a physical connection such as a serial port or USB port
- digital certificate information is extracted from each digital certificate as it is loaded onto a mobile device 22 and stored in an address book or similar contact information store, or possibly another data store, on the mobile device 22.
- Fig. 3 is a block diagram of a mobile device 22 with a digital certificate information storage system.
- An exemplary mobile device 22 is described in greater detail with reference to Fig. 8.
- a mobile device 22 incorporating a digital certificate information storage system comprises a memory 52, a digital certificate loader 60, a contact information injector 62, a keyboard and user interface (UI) 64, a wireless transceiver 66, and a serial or universal serial bus (USB) port 68.
- the memory 52 preferably includes a plurality of different storage areas or data stores, shown in Fig. 3 as a digital certificate store 54, an address book 56 in which contact information is stored, an extracted digital certificate information store 57 in which other digital certificate information is stored, and an application data storage area 58. Other data may also be stored in the memory 52.
- the memory 52 is a writeable store such as a RAM or flash memory into which other device components may write data.
- the digital certificate store 54 is a storage area dedicated to storage of digital certificates on the device 22. Digital certificates may be stored in the digital certificate store 54 in the format in which they are received, or may alternatively be parsed or otherwise translated into a storage format before being written to the store 54.
- the address book 56 is a contact information store that stores contact information for entities with which a user of the mobile device 22 may exchange messages. The address book may also store physical address, mailing address and other contact information in addition to or instead of information that is used for messaging using the mobile device 22.
- the extracted digital certificate information store 57 is configured to store other information from digital certificates stored in the digital certificate store to enable simpler or faster processing of particular digital certificate information or use of digital certificate information by other systems or software applications installed on the mobile device 22. For example, an expiry time or validity period could be extracted from a digital certificate and used to create an appointment or reminder for a user of the mobile device 22 to thereby provide an indication to the user when a stored digital certificate has expired or is no longer valid.
- the application data store 58 stores data associated with software applications on the mobile device 22 and represents one illustrative example of other information that may be stored in the memory 52. The memory 52 may also be used by other device systems in addition to those shown in Fig. 3.
- the digital certificate loader 60 which will typically be implemented as a software module or application, manages loading of digital certificates onto the mobile device 22.
- a mobile device may obtain digital certificates from various sources.
- the digital certificate loader 60 is therefore connected to communication modules such as the wireless transceiver 66 and the serial or USB port 68, through which digital certificates may possibly be requested and received.
- the mobile device 22 may request the digital certificate from a PKS through the wireless transceiver 66 and also receive the digital certificate from a digital certificate source in response to the request through the wireless transceiver 66.
- the serial or USB port 68 may also be used in conjunction with a similarly equipped PC to download digital certificates onto the mobile device 22.
- the digital certificate information injector 62 preferably monitors the digital certificate store 54 to detect new digital certificates as they are stored to the digital certificate store 54.
- the digital certificate loader 60 may be configured to notify the digital certificate information injector 62 when a digital certificate is loaded onto the device 22.
- the digital certificate information injector 62 extracts information from the digital certificate.
- the digital certificate information injector 62 stores the extracted contact information to the address book 56, by either creating a new entry in the address book 56 using the extracted contact information or by storing the extracted contact information to an existing entry in the address book 56.
- the digital certificate information injector 62 preferably checks the address book 56 to determine whether or not the contact information or possibly some portion thereof already exists in an entry in the address book 56. For example, when a subject name is specified in a digital certificate using an e-mail address, the digital certificate information injector 62 may search the address book 56 for the e-mail address and create a new address book entry only if the e-mail address is not found in the address book 56.
- the digital certificate information injector 62 preferably checks the existing entry for the subject to determine if the further contact information also exists in the address book entry. If not, then the existing entry is preferably updated by storing the further contact information to the existing entry. Therefore, the digital certificate information injector 62 may update the address book 56 by either adding a new entry using the extracted information or storing extracted information to an existing entry.
- the digital certificate information injector 62 may similarly extract other information from digital certificates loaded onto the mobile device 22 for storage in a different store or storage area 57.
- digital certificates may include digital certificate expiry or validity information that could be used to create an appointment or reminder for a user of the mobile device 22 to alert the user when a digital certificate expires or is invalid or is about to expire or become invalid.
- the digital certificate information injector 62 preferably extracts a digital certificate subject name and expiry or validity information and checks the extracted digital certificate information store 57 to determine if an entry already exists for the subject. If not, then a new entry, i.e., a new . reminder or appointment, is created in the store 57 using the extracted digital certificate information.
- the digital certificate information injector 62 When an entry for the subject does exist in the store 57, then the expiry or validity information in the existing entry may be checked to determine if it is the same as the extracted information. If not, then the digital certificate information injector 62 preferably updates the existing entry with the extracted information. This is useful, for example, when a new digital certificate has been loaded to replace a digital certificate that has not yet expired. Therefore, as above, the digital certificate information injector 62 may update the store 57 by either adding a new entry using the extracted information or storing extracted information to an existing entry.. Other information in a digital certificate could similarly be extracted and stored in memory 52 on the mobile device 22.
- the types of digital certificate information that are extracted and stored could be configurable by a mobile device user, for example, by establishing settings associated with the digital certificate information injector 62.
- the digital certificate information inj ector 62 accesses the digital certificate store 54 to extract digital certificate information.
- the specific scheme of digital certificate information extraction from a stored digital certificate depends upon the format in which digital certificates are stored in the digital certificate store 54. If digital certificates are stored in the digital certificate store 54 in the format in which they are received, then the digital certificate information inj ector 62 retrieves a digital certificate from the digital certificate store and parses or otherwise translates the digital certificate into an appropriate format so that digital certificate information can be identified and extracted.
- the digital certificate information inj ector 62 may read only relevant information fields from the parsed data in the digital certificate store 54 as required to populate fields in entries in the other data stores 56, 57.
- the digital certificate loader 60 may be configured to pass digital certificate information from a digital certificate to the digital certificate information injector 62, which then stores the digital certificate information to the address book 56 or extracted digital certificate information store 57 as described above.
- Implementation of a digital certificate information storage system preferably does not preclude address book or other information entry via input means such as the keyboard/UI 64.
- input means such as the keyboard/UI 64.
- the keyboard/UI 64 or possibly another input device provides for manual contact information input and editing, as may occasionally be required.
- a mobile device 22 may include several different memory units, such that the stores 54, 56, 57, 58 may be implemented in separate memory units.
- the overall operation of a digital certificate information storage system in a multiple memory system is substantially as described above.
- the systems and methods disclosed herein are not restricted to implementation in a mobile device 22 having the memory arrangement shown in Fig.3.
- further data stores may be provided and configured for storage of information extracted from digital certificates.
- the extracted digital certificate information store 57 is intended as a general example of a store for digital certificate information other than contact information.
- fewer data stores may be enabled for digital certificate information extraction and storage, such that only one type of digital certificate information, contact information for example, is automatically stored.
- the digital certificate loader 60 and the digital certificate information injector 62 are illustrated as separate blocks in Fig. 3, the digital certificate loader 60 and the digital certificate information injector 62 may be implemented as a single software module, or as separate software modules.
- a digital certificate information storage system may also create or update application data in the application data store 58.
- Digital certificate information storage may also be applicable to other types of systems than a mobile device 22.
- On a desktop or laptop PC for example, even though data entry tends to be easier than on the mobile device 22, digital certificate information extraction and storage saves the time and effort associated with manual digital certificate information entry for each digital certificate stored on a system.
- Fig. 4 is a flow diagram illustrating a method of storing digital certificate information.
- the method begins at step 70, when a digital certificate is loaded onto a device, such as when storage of a digital certificate to a digital certificate store is detected.
- digital certificate information is extracted from the digital certificate.
- a determination is preferably made at step 74 as to whether or not the digital certificate information or a portion thereof, such as an e-mail address or subject name, already exists in an entry in the data store. If the digital certificate information already exists in the data store, then at step 75, the existing entry is preferably checked to determine whether or not further extracted digital certificate information, if any, exists in the entry.
- a digital certificate subject name could be used at step 74 to check for an entry in a data store, whereas an existing entry could be checked at step 75 to determine if other extracted information such as an expiry time or validity period has already been stored in the existing entry.
- the existing entry is updated by adding the further extracted information.
- a secure messaging flag may be set in the address book entry that includes or has been updated with the extracted contact information at step 79. Such a flag indicates that a corresponding digital certificate is stored for the contact.
- a user when addressing a message to the contact, may thereby easily determine whether or not a digital certificate for the contact has been received and loaded and thus whether or not secure messages may be sent to the contact without first obtaining the digital certificate for the contact from an outside digital certificate source.
- This flag or a further flag or indicator could also be used to cause secure messages to be sent to a contact according to a preferably configurable default secure messaging mode.
- a user may be prompted to select a messaging mode, including, for example, plaintext mode (no security), or one of multiple signed and/or encrypted secure modes.
- a messaging mode including, for example, plaintext mode (no security), or one of multiple signed and/or encrypted secure modes.
- plaintext mode no security
- a new entry is automatically created at step 78 and fields in the new entry are populated using the extracted information at • step 80.
- a secure messaging flag is then set for a new address book entry, as described above.
- the new entry may then be used similarly to any other entries in the data store, or possibly similar entries in another data store, and may, for example, be edited, deleted, forwarded to other users, displayed and the like.
- the new entry may also be used to address outgoing messages or to replace a sender address in a received message with a familiar name.
- Fig. 5 is a flow diagram illustrating a method of generating and sending messages subj ect to digital certificate information stored in the digital certificate information storage system.
- the method begins at step 90, in which a message is generated at the mobile device 22 and addressed to one or more recipients.
- the message may be addressed by a user manually selecting an e-mail address from the address book store 56, or by replying to a message previously received at the mobile device 22, for example.
- the mobile device 22 determines whether digital certificate information is stored in the digital certificate store 54 (or the extracted digital certificate information store 57) for the corresponding entity to which the message is addressed.
- the determination may be made by checking a secure messaging flag associated with the addressed recipient, or by searching the digital certificate store 54 (or the extracted digital certificate information store 57) for the electronic address of the recipient. If digital certificate information is not stored in the digital certificate store 54, then a list of No Certificate Information options is displayed, as shown in step 94. One of the No Certificate Information options is then selected by a user, as shown in step 96. Illustratively, the No Certificate Information options displayed and optionally selected include an option to request a digital certificate of the addressed recipient, as shown in step 98, to abort the message, as shown in step 100, or to send the message, as shown in step 102.
- step 98 If the option to request a digital certificate of the addressed recipient is selected, as shown in step 98, then the message is stored at the mobile device 22, and the mobile device 22 sends a request to a digital certificate provider for the digital certificate of the addressed recipient of the message.
- the user may select from one of several security operations, such as encrypting the message or a session key using the addressed recipient's public key, for example.
- step 100 If the option to abort the message is selected, as shown in step 100, then the messaging operation is aborted, and the generated message is not sent.
- step 102 If the option to send the message is selected, as shown in step 102, then the message is sent in the clear.
- the user may digitally sign the message using a private key, and may further attach the user's digital certificate to the outgoing message.
- step 92 if the mobile device 22 determines that digital certificate information is stored in the digital certificate store 54, then the mobile device 22 determines if the digital certificate is a valid digital certificate in step 104. If the digital certificate is not valid, then step 94 is executed, and subsequent steps 96, 98, 100, and 102 may also be executed, as determined by the user.
- the mobile device determines if the digital certificate is a valid digital certificate in step 104, then the mobile device determines if a default send flag has been set, as shown in step 106.
- the message is sent, as shown in step 102.
- Setting of the default send flag may be done manually by the user, or may be automatic. An automatic setting of the default send flag may be tied to the setting of the secure messaging flag. In one embodiment, the secure messaging flag also performs the function of the default send flag. In another embodiment, the default send flag and the secure messaging flags are separate flags that may be independently set, or as described above. Sending a message via the default send flag may also include execution of other operations, such as digitally signing the message with the user's private key, attaching the user's digital certificate to the message, or encrypting the message with the addressed recipient's public key.
- a list of Certificate Information options may be displayed, as shown in step 108.
- One of the Certificate Information options may be selected by a user, as shown in step 110.
- the Certificate Information options displayed and optionally selected include an option to perform a security operation on the message, as shown in step 112, or to send the message, as shown in step 102. If the option to perform a security operation on the message is selected, as shown in step 112, then one or more security operations may be performed on the message before the message is sent, such as digitally signing the message with the user's private key, attaching the user's digital certificate to the message, or encrypting the message with the addressed recipient's public key.
- step 102 If the option to send the message is selected, as shown in step 102, then the message is sent in the clear.
- the user may digitally sign the message using a private key, and may further attach the user's digital certificate to the outgoing message.
- the process depicted in Fig.5 may also be adapted for a plurality of recipients of a single message, such as when the user replies to all recipients of a message previously received at the mobile device 22, or addresses a new message to more than one recipient.
- Fig.6 is a flow diagram illustrating a method of performing digital certificate related operations based on digital certificate related events.
- the system detects the occurrence of a digital certificate event.
- a digital certificate event is an event or operation that involves a digital certificate, such as receiving digital certificate data to be stored in the digital certificate store, the occurrence of an associated calendar date, or the accessing of a digital certificate, either by the user or by an application program.
- digital certificate related data is stored in the digital certificate store and calendar data related to the digital certificate data, such as an expiry date of the digital certificate, is stored in a calendar application store.
- the calendar application checks for the expiration of digital certificate validity periods based on the expiry data stored in the calendar application store.
- a calendar event may occur when the mobile device is turned on and a resident calendar application program checks the calendar data for expiry data, or may alternatively be the occurrence of a calendar event for given expiry data.
- the system determines if invalid (by reason of expiry) digital certificates are found based on the calendar data. If invalid digital certificates are found, then the user is notified of the invalid digital certificates in step 128.
- the system determines whether the digital certificate accessed is valid, as shown in step 130.
- a digital certificate access may occur when a user of the mobile device addresses a message to an address associated with a digital certificate stored in the digital certificate store as previously described, or when the user accesses the digital certificate store and selects a particular digital certificate.
- the system determines if the digital certificate is valid based on the digital certificate data stored in the digital certificate store, validity or expiry information, or a CRL, for example. If the digital certificate is not valid, then at step 132, the user is notified of the invalid digital certificate.
- Fig. 7 is a structural block diagram of an automatic digital certificate information manager system.
- a digital certificate information manager 150 preferably a software application, is stored and executable on the mobile device 22.
- the digital certificate information manager 150 illustratively comprises the digital certificate loader 60 and the digital certificate information injector 62 and related components as described with reference to Fig. 3.
- the digital certificate information manager 150 is operable to monitor digital certificate input events 152, digital certificate access events 154, and calendar events 156, and to perform responding functions. For example, if the digital certificate information manager 150 detects a digital certificate input event 152, such as receiving a message 152a comprising a digital certificate or receiving digital certificate data 152b to be stored, then a corresponding digital certificate input event function is performed. Exemplary corresponding digital certificate input event functions include storing digital certificate data in the digital certificate store, parsing digital certificate data, setting a messaging flag related to the digital certificate, or updating mobile device application stores, such as a calendar application or address book application store.
- a digital certificate access event 154 such as addressing a message 154a to an address with an associated digital certificate stored in the digital certificate store, accessing the digital certificate store 154b and selecting a digital certificate, or access of a digital certificate by a mobile device software application 154c.
- a corresponding digital certificate access event function is performed.
- Exemplary corresponding digital certificate access event functions include a digital certificate validity check and requesting a new digital certificate, notifying a user in the event of an invalid digital certificate, or performing a security operation, such as signing the message, encrypting the message, and the like.
- the digital certificate information manager 150 detects a calendar event 156, such as the occurrence of a digital certificate expiry date, then the user is notified of the expiration of the digital certificate.
- Fig. 8 is a block diagram of a wireless mobile communication device, as an example of a device in which the systems and methods disclosed herein may be implemented.
- the mobile device 600 is preferably a two-way communication device having at least voice and data communication capabilities.
- the mobile device 600 preferably has the capability to communicate with other computer systems on the Internet.
- the mobile device may be referred to as a data messaging device, a two-way pager, a mobile telephone with data messaging capabilities, a wireless Internet appliance, or a data communication device (with or without telephony capabilities).
- a data messaging device a two-way pager
- a mobile telephone with data messaging capabilities a wireless Internet appliance
- a data communication device with or without telephony capabilities
- the mobile device 600 includes a transceiver 611, a microprocessor 638, a display 622, a Flash memory 624, a random access memory (RAM) 626, auxiliary input/output (I/O) devices 628, a serial port 630, a keyboard 632, a speaker 634, a microphone 636, a short-range wireless communications sub-system 640, and other device sub-systems 642.
- the transceiver 611 includes transmit and receive antennas 616, 618, a receiver (Rx) 612, a transmitter (Tx) 614, one or more local oscillators (LOs) 613, and a digital signal processor (DSP) 620.
- the mobile device 600 includes a plurality of software modules 624A-624N that can be executed by the microprocessor 638 (and/or the DSP 620), including a voice communication module 624A, a data communication module 624B , and a plurality of other operational modules 624N for carrying out a plurality of other functions.
- the mobile device 600 is preferably a two-way communication device having voice and data communication capabilities.
- the mobile device 600 may communicate over a voice network, such as any of the analog or digital cellular networks, and may also communicate over a data network.
- the voice and data networks are depicted in Fig. 8 by the communication tower 619.
- voice and data networks may be separate communication networks using separate infrastructure, such as base stations, network controllers, etc., or they may be integrated into a single wireless network. References to the network 619 should therefore be interpreted as encompassing both a single voice and data network and separate networks.
- the communication subsystem 611 is used to communicate with the network 619.
- the DSP 620 is used to send and receive communication signals to and from the transmitter 614 and receiver 612, and may also exchange control information with the transmitter 614 and receiver 612. If the voice and data communications occur at a single frequency, or closely-spaced set of frequencies, then a single LO 613 may be used in conjunction with the transmitter 614 and receiver 612.
- a plurality of LOs 613 can be used to generate a plurality of frequencies corresponding to the network 619.
- two antennas 616, 618 are depicted in Fig. 8, the mobile device 600 could be used with a single antenna structure.
- Information which includes both voice and data information, is communicated to and from the communication module 611 via a link between the DSP 620 and the microprocessor 638.
- the detailed design of the communication subsystem 611 is dependent upon the communication network 619 in which the mobile device 600 is intended to operate.
- a mobile device 600 intended to operate in a North American market may include a communication subsystem 611 designed to operate with the Mobitex or DataTAC mobile data communication networks and also designed to operated with any of a variety of voice communication networks, such as AMPS, TDM A, CDMA, PCS, etc., whereas a mobile device 600 intended for use in Europe may be configured to operate with the GPRS data commumcation network and the GSM voice communication network.
- Other types of data and voice networks both separate and integrated, may also be utilized with the mobile device 600.
- the access requirements for the mobile device 600 may also vary.
- mobile devices are registered on the network using a unique identification number associated with each device.
- network access is associated with a subscriber or user of the mobile device 600.
- a GPRS device typically requires a subscriber identity module (“SIM”), which is required in order to operate the mobile device 600 on a GPRS network.
- SIM subscriber identity module
- Local or non-network communication functions may be operable, without the SIM, but the mobile device 600 will be unable to carry out any functions involving communications over the network 619, other than any legally required operations, such as '911' emergency calling.
- the mobile device 600 may send and receive communication signals, preferably including both voice and data signals, over the network 619.
- Signals received by the antenna 616 from the communication network 619 are routed to the receiver 612, which provides for such operations as signal amplification, frequency down conversion, filtering, channel selection, and analog to digital conversion. Analog to digital conversion of the received signal allows more complex communication functions, such as digital demodulation and decoding to be performed using the DSP 620.
- signals to be transmitted to the network 619 are processed, including modulation and encoding, for example, by the DSP 620 and are then provided to the transmitter 614 for digital to analog conversion, frequency up conversion, filtering, amplification and transmission to the communication network 619 via the antenna 618.
- a single transceiver 611 is shown in Fig. 8 for both voice and data communications, it is possible that the mobile device 600 may include two distinct transceivers, a first transceiver for transmitting and receiving voice signals, and a second transceiver for transmitting and receiving data signals. Multiple transceiver may also be provided in a mobile device adapted to operate within more than one communication network or multiple frequency bands.
- the DSP 620 In addition to processing the communication signals, the DSP 620 also provides for receiver and transmitter control. For example, the gain levels applied to communication signals in the receiver 612 and transmitter 614 may be adaptively controlled through automatic gain control algorithms implemented in the DSP 620. Other transceiver control algorithms could also be implemented in the DSP 620 in order to provide more sophisticated control of the transceiver 611.-
- the microprocessor 638 preferably manages and controls the overall operation of the mobile device 600. Many types of microprocessors or microcontrollers could be used here, or, alternatively, a single DSP 620 could be used to carry out the functions of the microprocessor 638. Low-level communication functions, including at least data and voice communications, are performed through the DSP 620 in the transceiver 611. Other, high-level communication applications, such as a voice communication application 624A, and a data communication application 624B may be stored in the Hash memory 624 for execution by the microprocessor 638. For example, the voice communication module 624A may provide a high-level user interface operable to transmit and receive voice calls between the mobile device 600 and a plurality of other voice devices via the network 619.
- the data communication module 624B may provide a high-level user interface operable for sending and receiving data, such as e-mail messages, files, organizer information, short text messages, etc., between the mobile device 600 and a plurality of other data devices via the network 619.
- a secure messaging software application incorporating software modules corresponding to the digital certificate loader 60 and digital certificate information injector 62 in Fig. 3 for example, may operate in conjunction with the data communication module 624B in order to implement the techniques described above.
- the microprocessor 638 also interacts with other device subsystems, such as the display 622, the Flash memory 624, the RAM 626, the auxiliary input/output (I O) subsystems 628, the serial port 630, the keyboard 632, the speaker 634, the microphone 636, the short-range communications subsystem 640, and any of the other device subsystems generally designated as 642.
- the modules 624A-N are executed by the microprocessor 638 and may provide a high-level interface between a user and the mobile device 600.
- This interface typically includes a graphical component provided through the display 622, and an input/output component provided through the auxiliary I/O 628, the keyboard 632, the speaker 634, or the microphone 636.
- Such interfaces are designated generally as the keyboard/UI 64 in Fig. 3.
- Fig. 8 Some of the subsystems shown in Fig. 8 perform communication-related functions-, whereas other subsystems may provide "resident" or on-device functions. Notably, some subsystems, such as the keyboard 632 and the display 622 are used for both communication-related functions, such as entering a text message for transmission over a data communication network, and device-resident functions such as a calculator or task list or other PDA type functions.
- Operating system software used by the microprocessor 638 is preferably stored in a non-volatile store such as Hash memory 624.
- the Flash memory 624 may also include a file system for storing data.
- a storage area is also preferably provided in the Hash memory 624 to store digital certificates, address book entries, reminder or appointment information, and possibly other information.
- the operating system, specific device applications or modules, or parts thereof, may be temporarily loaded into a volatile store, such as RAM 626 for faster operation.
- received communication signals may also be temporarily stored to RAM 626, before permanently writing them to a file system located in the Hash memory 624.
- An exemplary application module 624N that may be loaded onto the dual- mode device 600 is a personal information manager (PIM) application providing PDA functionality, such as calendar events, appointments, and task items.
- PIM personal information manager
- Such a module could use expiry or validity period information extracted from a digital certificate and stored in an appropriate data store, in Hash memory 624 or RAM 626 for example, to provide a digital certificate expiry or like reminder to a user of the mobile device 600.
- This module 624N may also interact with the voice communication module 624A for managing phone calls, voice mails, etc., and may also interact with the data communication module 624B for managing e- mail communications and other data transmissions. Alternatively, all of the functionality of the voice communication module 624A and the data communication module 624B may be integrated into the P module.
- the Hash memory 624 preferably provides a file system to facilitate storage of
- the PIM application preferably includes the ability to send and receive data items, either by itself, or in conjunction with the voice and data communication modules 624A, 624B, via the wireless network 619.
- the PIM data items are preferably seamlessly integrated, synchronized and updated, via the wireless network 619, with a corresponding set of data items stored or associated with a host computer system, thereby creating a mirrored system for data items associated with a particular user.
- the mobile device 600 may also be manually synchronized with a host system by placing the mobile device 600 in an interface cradle, which couples the serial port 630 of the mobile device 600 to the serial port of the host system.
- the serial port 630 may also be used to enable a user to set preferences through an external device or software application, to
- Additional application modules 624N may be loaded onto the mobile device 600 through the network 619, through an auxiliary I/O subsystem 628 , through the serial port 630, through the short-range communications subsystem 640, or through any other suitable subsystem 642, and installed by a user in the Hash memory 624 or RAM 626.
- Such flexibility in application installation increases the functionality of the mobile device 600 and may provide enhanced on-device functions, communication-related functions, or both.
- secure communication applications may enable electronic commerce functions and other such financial transactions to be performed using the mobile device 600.
- a received signal such as a text message or a web page download
- the transceiver 611 When the mobile device 600 is operating in a data communication mode, a received signal, such as a text message or a web page download, is processed by the transceiver 611 and provided to the microprocessor 638, which preferably further processes the received signal for output to the display 622, or, alternatively, to an auxiliary I O device 628.
- a digital certificate received by the transceiver 611 in response to a request to a PKS or attached to a secure message for example, is processed as described above to add the digital certificate to a digital certificate store in the Hash memory 624 if it has not already been stored, and to extract and store digital certificate information in one or more data stores in the Hash memory 624 if necessary.
- a user of mobile device 600 may also compose data items, such as email messages, using the keyboard 632, which is preferably a complete alphanumeric keyboard laid out in the QWERTY style, although other styles of complete alphanumeric keyboards such as the known DVORAK style may also be used.
- User input to the mobile device 600 is further enhanced with a plurality of auxiliary I/O devices 628, which may include a thumbwheel input device, a touchpad, a variety of switches, a rocker input switch, etc.
- the composed data items input by the user may then be transmitted over the communication network 619 via the transceiver 611.
- the overall operation of the mobile device 600 is substantially similar to the data mode, except that received signals are preferably output to the speaker 634 and voice signals for transmission are generated by a microphone 636.
- the secure messaging techniques described above might not necessarily be applied to voice communications.
- Alternative voice or audio I/O subsystems such as a voice message recording subsystem, may also be implemented on the mobile device 600.
- voice or audio signal output is preferably accomplished primarily through the speaker 634, the display 622 may also be used to provide an indication of the identity of a calling party, the duration of a voice call, or other voice call related information.
- the microprocessor 638 in conjunction with the voice communication module 624A and the operating system software, may detect the caller identification information of an incoming voice call and display it on the display 622.
- the short-range communications subsystem 640 may include an infrared device and associated circuits and components, or a short-range wireless communication module such as a BluetoothTM module or an 802.11 module to provide for communication with similarly-enabled systems and devices.
- a short-range wireless communication module such as a BluetoothTM module or an 802.11 module to provide for communication with similarly-enabled systems and devices.
- Bluetooth and “802.11” refer to sets of specifications, available from the Institute of Electrical and Electronics Engineers, relating to wireless personal area networks and wireless LANs, respectively.
- a wireless mobile communication device is shown in Figs. 3 and 5 and described as one possible messaging client, the system and method disclosed herein may also be implemented in other messaging clients, including desktop and laptop computer systems, networked computer systems and other types of messaging clients.
- the digital certificate information storage system may also be configurable, such that new data store entries are created only under certain conditions, depending upon communications functionality of a messaging client or user preferences. For example, if a messaging client is an email client but a digital certificate does not contain an email address, then a contact information storage system may be configured such that no new address book entry would be created, since information required for messaging operations is not available from the digital certificate.
- FIG. 9 is a block diagram showing an example communication system.
- a computer system 802 a WAN 804, corporate LAN 806 behind a security firewall 808, wireless infrastructure 810, wireless networks 812 and 814, and mobile devices 816 and 818.
- the corporate LAN 806 includes a message server 820, a wireless connector system 828, a data store 817 including at least a plurality of mailboxes 819, a desktop computer system 822 having a communication link directly to a mobile device such as through physical connection 824 to an interface or connector 826, and a wireless VPN router 832. Operation of the system in Fig.9 is described below with reference to the messages 833, 834 and 836.
- the computer system 802 is, for example, a laptop, desktop or palmtop computer system configured for connection to the WAN 804. Such a computer system may connect to the WAN 804 via an ISP or ASP. Alternatively, the computer system 802 may be a network-connected computer system that, like the computer system 822 for example, accesses the WAN 804 through a LAN or other network. Many modern mobile devices are enabled for connection to a WAN through various infrastructure and gateway arrangements, so that the computer system 802 may also be a mobile device.
- the corporate LAN 806 is an illustrative example of a central, server-based messaging system that has been enabled for wireless communications.
- the corporate LAN 806 may be referred to as a "host system", in that it hosts both a data store 817 with mailboxes 819 for messages, as well as possibly further data stores (not shown) for other data items, that may be sent to or received from mobile devices 816 and 818, and the wireless connector system 828, the wireless VPN router 832, or possibly other components enabling communications between the corporate LAN 806 and one or more mobile devices 816 and 818.
- a host system is one or more computers at, with, or in association with which a wireless connector system is operating.
- the corporate LAN 806 is one preferred embodiment of a host system, in which the host system is a server computer running within a corporate network environment operating behind and protected by at least one security firewall 808.
- the corporate LAN 806 implements the wireless connector system 828 as an associated wireless communications enabling component, which will normally be a software program, a software application, or a software component built to work with at least one message server 820.
- the wireless connector system 828 is used to send user-selected information to, and to receive information from, one or more mobile devices 816and818, via one or more wireless networks 812 and 814.
- the wireless connector system 828 may be a separate component of a messaging system, as shown in Fig. 9, or may instead be partially or entirely incorporated into other communication system components.
- the message server 820 may incorporate a software program, application, or component implementing the wireless connector system 828, portions thereof, or some or all of its functionality.
- the message server 820 running on a computer behind the firewall 808, acts as the main interface for the corporation to exchange messages, including for example electronic mail, calendaring data, voice mail, electronic documents, and other PIM data with a WAN 804, such as the Internet.
- the particular intermediate operations and computers are dependent upon the specific type of message delivery mechanisms and networks via which messages are exchanged, and therefore have not been shown in Fig. 9.
- the functionality of the message server 820 may extend beyond message sending and receiving, providing such features as dynamic database storage for data like calendars, to-do lists, task lists, e-mail, and documentation, as described above.
- Message servers such as 820 normally maintain a plurality of mailboxes 819 in one or more data stores such as 817 for each user having an account on the server.
- the data store 817 includes mailboxes 819 for a number ("n") of user accounts.
- Messages received by the message server 820 that identify a user, a user account, a mailbox, or possibly another address associated with a user, account or mailbox 819, as a message recipient is typically stored in the corresponding mailbox 819. If a message is addressed to multiple recipients or a distribution list, then copies of the same message may be stored to more than one mailbox 819.
- the message server 820 may store a single copy of such a message in a data store accessible to all of the users having an account on the message server 820, and store a pointer or other identifier in each recipient's mailbox 819.
- each user then accesses his or her mailbox 819 and its contents using a messaging client such as Microsoft Outlook or Lotus Notes, which normally operates on a PC, such as the desktop computer system 822, connected in the LAN 806.
- a messaging client such as Microsoft Outlook or Lotus Notes, which normally operates on a PC, such as the desktop computer system 822, connected in the LAN 806.
- desktop computer system 822 is shown in Fig. 9, those skilled in the art will appreciate that a LAN typically contains many desktop, notebook, and laptop computer systems.
- Each messaging client normally accesses a mailbox 819 through the message server 820, although in some systems, a messaging client may enable direct access to the data store 817 and a mailbox 819 stored thereon by the desktop computer system 822. Messages may also be downloaded from the data store 817 to a local data store on the desktop computer system 822.
- the wireless connector system 828 operates in conjunction with the message server 820.
- the wireless connector system 828 may reside on the same computer system as the message server 820, or may instead be implemented on a different computer system.
- Software implementing the wireless connector system 828 may also be partially or entirely integrated with the message server 820.
- the wireless connector system 828 and the message server 820 are preferably designed to cooperate and interact to allow the pushing of information to the mobile devices 816, 818.
- the wireless connector system 828 is preferably configured to send information that is stored in one or more data stores associated with the corporate LAN 806 to one or more of the mobile devices 816, 818, through the corporate firewall 808 and via the WAN 804 and one of the wireless networks 812, 814.
- a user that has an account and associated mailbox 819 in the data store 817 may also have a mobile device, such as 816.
- a mobile device such as 816
- messages received by the message server 820 that identify a user, account, or mailbox 819 are stored to a corresponding mailbox 819 by the message server 820.
- messages received by the message server 820 and stored to the user's mailbox 819 are preferably detected by the wireless connector system 828 and sent to the user's mobile device 816.
- This type of functionality represents a "push" message sending technique.
- the wireless connector system 828 may instead employ a "pull" technique, in which items stored in a mailbox 819 are sent to a mobile device 816 or 818 responsive to a request or access operation made using the mobile device, or some combination of both techniques.
- a wireless connector 828 thereby enables a messaging system including a message server 820 to be extended so that each user's mobile device 816, 818 has access to stored messages of the message server 820.
- a wireless connector 828 uses a wireless friendly encoding, compression and encryption technique to deliver all information to a mobile device, thus effectively extending the company firewall 808 to include the mobile devices 816 and 818.
- a mobile device 816, 818 there are several paths for exchanging information with a mobile device 816, 818 from the corporate LAN 806.
- One possible information transfer path is through the physical connection 824 such as a serial port, using an interface or connector 826.
- This path is useful for example for bulk information updates often performed at initialization of a mobile device 816, 818 or periodically when a user of a mobile device 816, 818 is working at a computer system in the LAN 806, such as the computer system 822.
- PIM data is commonly exchanged over a such a connection as a serial port connected to a cradle in or upon which a mobile device 816, 818 may be placed.
- the physical connection 824 may also be used to transfer other information from a desktop computer system 822 to a mobile device 816, 818, including private security keys ("private keys") such as private encryption or digital signature keys associated with the desktop computer system 822, or other relatively bulky information such as digital certificates and CRLs.
- private keys private security keys
- Private key exchange using the physical connection 824 and the connector or interface 826 allows a user's desktop computer system 822 and mobile device 816 or 818 to share at least one identity for accessing all encrypted and/or signed mail.
- the user's desktop computer system 822 and mobile device 816 or 818 can also thereby share private keys so that either the host system 822 or the mobile device 816 or 818 can process secure messages addressed to the user ' s mailbox or account on the message server 820.
- a user's own digital certificate, a chain of digital certificates used to verify the user's digital certificate, and a CRL, as well as digital certificates, digital certificate chains and CRLs for other users, may be loaded onto a mobile device 816, 818 from the user' s desktop computer system 822.
- This loading of other user' s digital certificates and CRLs onto a mobile device 816, 818 allows a mobile device user to select other entities or users with whom they might be exchanging secure messages, and to pre-load the bulky information onto the mobile device through a physical connection instead of over the air, thus saving time and wireless bandwidth when a secure message is received from or to be sent to such other users, or when the status of a digital certificate is to be determined based on one or more CRLs. CRL-based status checks can also be avoided where the systems and methods described herein are employed. In known "synchronization" type wireless messaging systems, a physical path has also been used to transfer messages from mailboxes 819 associated with a message server 820 to mobile devices 816 and 818.
- Another method for data exchange with the mobile devices 816 and 818 is over-the-air, through the wireless connector system 828 and using the wireless networks 812 and 814. As shown in Fig. 8, this could involve a Wireless VPN router 832, if available in the network 806, or, alternatively, a traditional WAN connection to wireless infrastructure 810 that provides an interface to one or more wireless networks such as 814.
- the Wireless VPN router 832 provides for creation of a VPN connection directly through a specific wireless network 812 to a wireless device 816.
- Such a Wireless VPN router 832 may be used in conjunction with a static addressing scheme.
- IPV6 would provide enough IP addresses to dedicate an IP address to every mobile device 816 configured to operate within the network 812 and thus make it possible to push information to a mobile device 816 at any time.
- a primary advantage of using a wireless VPN router 832 is that it could be an off-the-shelf VPN component which would not require wireless infrastructure 810.
- a VPN connection may use a TCP/IP or UDP/IP connection to deliver messages directly to and from a mobile device 816.
- wireless infrastructure 810 is preferably used. The wireless infrastructure 810 may also determine a most likely wireless network for locating a given user, and track users as they roam between countries or networks. In wireless networks such as 812 and 814, messages are normally delivered to and from mobile devices via RF transmissions between base stations and the mobile devices.
- a plurality of connections to wireless networks 812 and 814 may be provided, including, for example, ISDN, Frame Relay or Tl connections using the TCP/IP protocol used throughout the Internet.
- the wireless networks 812 and 814 could represent distinct, unique and unrelated networks, or they could represent the same network in different countries, and may be any of different types of networks, including but not limited to, data-centric wireless networks, voice-centric wireless networks, and dual-mode networks that can support botti voice and data communications over the same or similar infrastructure, such as any of those described above.
- more than one over-the-air information exchange mechanism may be provided in the corporate LAN 806.
- the mobile devices 816 and 818 associated with users having mailboxes 819 associated with user accounts on the message server 820 are configured to operate on different wireless networks 812 and 814.
- the wireless network 812 supports IPv6 addressing
- the wireless VPN router 832 may be used by the wireless connector system 828 to exchange data with any mobile device 816 operating within the wireless network 812.
- the wireless network 814 may be a different type of wireless network, however, such as the Mobitex network, in which case information is instead exchanged with the mobile device 818 operating within the wireless network 814 via a connection to the WAN 804 and the wireless infrastructure 810.
- e-mail message 833 sent from the computer system 802 and addressed to at least one recipient having both an account and mailbox 819 or like data store associated with the message server 820 and a mobile device 816 or 818.
- the e-mail message 833 is intended for illustrative purposes only.
- the exchange of other types of information between the corporate LAN 806 is preferably also enabled by the wireless connector system 828.
- the e-mail message 833 sent from the computer system 802 via the WAN 804, may be fully in the clear, or signed with a digital signature and/or encrypted, depending upon the particular messaging scheme used. For example, if the computer system 802 is enabled for secure messaging using S/MIME, then the e-mail message 833 may be signed, encrypted, or both.
- E-mail messages such as 833 normally use traditional SMTP, RFC822 headers and MIME body parts to define the format of the e-mail message. These techniques are all well known to one in the art.
- the e-mail message 833 arrives at the message server 820, which determines into which mailboxes 819 the e-mail message 833 should be stored.
- a message such as the e-mail message 833 may include a user name, a user account, a mailbox identifier, or other type of identifier that is mapped to a particular account or associated mailbox 819 by the message server 820.
- recipients are typically identified using e-mail addresses corresponding to a user account and thus a mailbox 819.
- the wireless connector system 828 sends or mirrors, via the wireless network 812 or 814, certain user-selected data items or parts of data items from the corporate LAN 806 to the user's mobile device 816 or 818, preferably upon detecting that one or more triggering events has occurred.
- a triggering event includes, but is not limited to, one or more of the following: screen saver activation at a user' s networked computer system 822, disconnection of the user's mobile device 816 or 818 from the interface 826, or receipt of a command sent from a mobile device 816 or 818 to the host system to start sending one or more messages stored at the host system.
- the wireless connector system 828 may detect triggering events associated with the message server 820, such as receipt of a command, or with one or more networked computer systems 822, including the screen saver and disconnection events described above.
- triggering events associated with the message server 820 such as receipt of a command, or with one or more networked computer systems 822, including the screen saver and disconnection events described above.
- data items selected by the user are preferably sent to the user's mobile device.
- the e-mail message 833 assuming that a triggering event has been detected, the arrival of the message 833 at the message server 820 is detected by the wireless connector system 828.
- the wireless connector system 828 may register for advise syncs provided by the Microsoft Messaging Application Programming Interface (MAPI) to thereby receive notifications when a new message is stored to a mailbox 819.
- MMI Microsoft Messaging Application Programming Interface
- the wireless connector system 828 When a data item such as the e-mail message 833 is to be sent to a mobile device 816 or 818, the wireless connector system 828 preferably repackages the data item in a manner that is transparent to the mobile device 816 or 818, so that information sent to and received by the mobile device 816 or 818 appears similar to the information as stored on and accessible at the host system, LAN 806 in Fig.9.
- One preferred repackaging method includes wrapping received messages to be sent via a wireless network 812 or 814 in an electronic envelope that corresponds to the wireless network address of the mobile device 816 or 818 to which the message is to be sent.
- other repackaging methods could be used, such as special-purpose TCP/IP wrapping techniques.
- Such repackaging preferably also results in e-mail messages sent from a mobile device 816 or 818 appearing to come from a corresponding host system account or mailbox 819 even though they are composed and sent from a mobile device.
- a user of a mobile device 816 or 818 may thereby effectively share a single e-mail address between a host system account or mailbox 819 and the mobile device.
- Repackaging of the e-mail message 833 is indicated at 834 and 836. Repackaging techniques may be similar for any available transfer paths or may be dependent upon the particular transfer path, either the wireless infrastructure 810 or the wireless VPN router 832.
- the e-mail message 833 is preferably compressed and encrypted, either before or after being repackaged at 834, to thereby provide for secure transfer to the mobile device 818.
- Compression reduces the bandwidth required to send the message, whereas encryption ensures confidentiality of any messages or other information sent to the mobile devices 816 and 818.
- messages transferred via a VPN router 832 might only be compressed and not encrypted, since a VPN connection established by the VPN router 832 is inherently secure.
- Messages are thereby securely sent, via either encryption at the wireless connector system 828, which may be considered a non-standard VPN tunnel or a VPN-like connection, for example, or the VPN router 832, to mobile devices 816 and 818. Accessing messages using a mobile device 816 or 818 is thus no less secure than accessing mailboxes at the LAN 806 using the desktop computer system 822.
- arepackaged message 834 or 836 arrives at a mobile device 816 or 818, via the wireless infrastructure 810, or via the wireless VPN router 832, the mobile device 816 or 818 removes the outer electronic envelope from the repackaged message 834 or 836, and performs any required decompression and decryption operations.
- Messages sent from a mobile device 816 or 818 and addressed to one or more recipients are preferably similarly repackaged, and possibly compressed and encrypted, and sent to a host system such as the LAN 806. The host system may then remove the electronic envelope from the repackaged message, decrypt and decompress the message if desired, and route the message to the addressed recipients.
- Another goal of using an outer envelope is to maintain at least some of the addressing information in the original e-mail message 833.
- the outer envelope used to route information to mobile devices 816, 818 is addressed using a network address of one or more mobile devices, the outer envelope preferably encapsulates the entire original e-mail message 833, including at least one address field, possibly in compressed and/or encrypted form. This allows original "To", “From” and “CC" addresses of the e-mail message 833 to be displayed when the outer envelope is removed and the message is displayed on a mobile device 816 or 818.
- Fig. 10 is a block diagram of an alternative communication system, in which wireless communications are enabled by a component associated with an operator of a wireless network. As shown in Fig.
- the system includes a computer system 802, WAN 804, a corporate LAN 807 located behind a security firewall 808, network operator infrastructure 840, a wireless network 811, and mobile devices 813 and 815.
- the computer system 802, the WAN 804, the security firewall 808, the message server 820, the data store 817, the mailboxes 819, and the VPN router 835 are substantially the same as the similarly- labelled components in Fig. 9.
- the VPN router 835 since the VPN router 835 communicates with the network operator infrastructure 840, it need not necessarily be a wireless VPN router in the system of Fig. 10.
- the network operator infrastructure 840 enables wireless information exchange between the LAN 807 and the mobile devices 813 and 815, respectively associated with the computer systems 842 and 852 and configured to operate within the wireless network 811.
- LAN 807 a plurality of desktop computer systems 842 and 852 are shown, each having a physical connection 846 or 856 to an interface or connector 848 or 858.
- a wireless connector system 844 or 854 is operating on or in conjunction with each computer system 842 and 852.
- the wireless connector systems 844 and 854 are similar to the wireless connector system 828 described above, in that they enable data items, such as e-mail messages and other items that are stored in mailboxes 819, and possibly data items stored in a local or network data store, to be sent from the LAN 807 to one or more of the mobile devices 813 and 815.
- the network operator infrastructure 840 provides an interface between the mobile devices 813 and 815 and the LAN 807.
- operation of the system shown in Fig. 10 is described below in the context of an e-mail message as an illustrative example of a data item that may be sent to a mobile device 813 or 815.
- the message server 820 When an e-mail message 833, addressed to one or more recipients having an account on the message server 820, is received by the message server 820, the message, or possibly a pointer to a single copy of the message stored in a central mailbox or data store, is stored in the mailbox 819 of each such recipient. Once the e-mail message 833 or pointer has been stored to a mailbox 819, it may preferably be accessed using a mobile device 813 or 815. In the example shown in Fig. 10, the e-mail message 833 has been addressed to the mailboxes 819 associated with both desktop computer systems 842 and 852 and thus both mobile devices 813 and 815.
- communication network protocols commonly used in wired networks such as the LAN 807 and/or the WAN 804 are not suitable or compatible with wireless network communication protocols used within wireless networks such as 811.
- wireless network communication protocols used within wireless networks such as 811.
- communication bandwidth, protocol overhead, and network latency which are primary concerns in wireless network communications, are less significant in wired networks, which typically have much higher capacity and speed than wireless networks. Therefore, mobile devices 813 and 815 cannot normally access the data store 817 directly.
- the network operator infrastructure 840 provides a bridge between the wireless network 811 and the LAN 807.
- the network operator infrastructure 840 enables a mobile device 813 or 815 to establish a connection to the LAN 807 through the WAN 804, and may, for example, be operated by an operator of the wireless network 811 or a service provider that provides wireless communication service for mobile devices 813 and 815.
- a mobile device 813 or 815 establishes a communication session with the network operator infrastructure 840 using a wireless network compatible communication scheme, preferably a secure scheme such as Wireless Transport Layer Security (WTLS) when information should remain confidential, and a wireless web browser such as a Wireless Application Protocol (WAP) browser.
- WTLS Wireless Transport Layer Security
- WAP Wireless Application Protocol
- a user then requests, through manual selection or pre-selected defaults in the software residing in the mobile device, any or all information, or just new information, for example, stored in a mailbox 819 in the data store 817 at the LAN 807.
- the network operator infrastructure 840 establishes a connection or session with a wireless connector system 844, 854, using Secure Hypertext Transfer Protocol (HTTPS), for example, if no session has already been established.
- HTTPS Secure Hypertext Transfer Protocol
- a session between the network operator infrastructure 840 and a wireless connector system 844 or 854 may be made via a typical WAN connection or through the VPN router 835 if available.
- the network operator infrastructure 840 and the wireless connector systems 844 and 854 may be configured so that a communication connection remains open once established.
- a wireless connector system 844 or 854 retrieves requested information from a data store. For the e-mail message 833, the wireless connector system 844 or 854 retrieves the e-mail message 833 from the appropriate mailbox 819, typically through a messaging client operating in conjunction with the computer system 842 or 852, which may access a mailbox 819 either via the message server 820 or directly. Alternatively, a wireless connector system 844 or 854 may be configured to access mailboxes 819 itself, directly or through the message server 820. Also, other data stores, both network data stores similar to the data store 817 and local data stores associated with each computer system 842 and 852, maybe accessible to a wireless connector system 844 or 854, and thus to a mobile device 813 or 815.
- the e-mail message 833 is sent to the network operator infrastructure 840 as shown at 860 and 862, which then sends a copy of the e-mail message to each mobile device 813 and 815, as indicated at 864 and 866.
- Information is transferred between the wireless connector systems 844 and 854 and the network operator infrastructure 840 via either a connection to the WAN 804 or the VPN router 835.
- the network operator infrastructure 840 communicates with the wireless connector systems 844 and 854 and the mobile devices 813 and 815 via different protocols, translation operations may be performed by the network operator infrastructure 840. Repackaging techniques may also be used between the wireless connector systems 844 and 854 and the network operator infrastructure 840, and between each mobile device 813 and 815 and the network operator infrastructure 840.
- Messages or other information to be sent from a mobile device 813 or 815 may be processed in a similar manner, with such information first being transferred from a mobile device 813 or 815 to the network operator infrastructure 840.
- the network operator infrastructure 840 then sends the information to a wireless connector system 844 or 854 for storage in a mailbox 819 and delivery to any addressed recipients by the message server 820, for example, or may alternatively deliver the information to the addressed recipients.
- the above description of the system in Fig. 10 relates to pull-based operations.
- the wireless connector systems 844 and 854 and the network operator infrastructure may instead be configured to push data items to mobile devices 813 and 815.
- a combined push/pull system is also possible. For example, a notification of a new message or a list of data items currently stored in a data store at the LAN 807 could be pushed to a mobile device 813 or 815, which may then be used to request messages or data items from the LAN 807 via the network operator infrastructure 840.
- each wireless network may have an associated wireless network infrastructure component similar to 840.
- one or more of the wireless connector systems 844 and ' 854 is preferably configured to operate in conjunction with more than one of the computer systems 842 and 852, or to access a data store or mailbox 819 associated with more than one computer system.
- the wireless connector system 844 may be granted access to the mailboxes 819 associated with both the computer system 842 and the computer system 852. Requests for data items from either mobile device A 813 orB 815 are then processed by the wireless connector system 844.
- This configuration is useful to enable wireless communications between the LAN 807 and the mobile devices 813 and 815 without requiring a desktop computer system 842 and 852 to be running for each mobile device user.
- a wireless connector system may instead be implemented in conjunction with the message server 820 to enable wireless communications.
- Fig. 11 is a block diagram of another alternative communication system.
- the system includes a computer system 802, WAN 804, a corporate LAN 809 located behind a security firewall 808, an access gateway 880, a data store 882, wireless networks 884 and 886, and mobile devices 888 and 890.
- the computer system 802, the WAN 804, the security firewall 808, the message server 820, the data store 817, the mailboxes 819, the desktop computer system 822, the physical connection 824, the interface or connector 826 and the VPN router 835 are substantially the same as the corresponding components described above.
- the access gateway 880 and data store 882 provide mobile devices 888 and 890 with access to data items stored at the LAN 809.
- a wireless connector system 878 operates on or in conjunction with the message server 820, although a wireless connector system may instead operate on or in conjunction with one or more desktop computer systems 822 in the LAN 809.
- the wireless connector system 878 provides for transfer of data items stored at the LAN 809 to one or more of the mobile devices 888 and 890. These data items preferably include e-mail messages stored in mailboxes 819 in the data store 817, as well as possibly other items stored in the data store 817 or another network data store or a local data store of a computer system such as 822.
- an e-mail message 833 addressed to one or more recipients having an account on the message server 820 and received by the message server 820 are stored into the mailbox 819 of each such recipient.
- the external data store 882 preferably has a similar structure to, and remains synchronized with, the data store 817.
- PIM information or data stored at data store 882 preferably is independently modifiable to the PIM information or data stored at the host system.
- the independently modifiable information at the external data store 882 may maintain synchronization of a plurality of data stores associated with a user (i.e., data on a mobile device, data on a personal computer at home, data at the corporate LAN, etc.).
- This synchronization may be accomplished, for example, through updates sent to the data store 882 by the wireless connector system 878 at certain time intervals, each time an entry in the data store 817 is added or changed, at certain times of day, or when initiated at the LAN 809, by the message server 820 or a computer system 822, at the data store 882, or possibly by a mobile device 888 or 890 through the access gateway 880.
- an update sent to the data store 882 some time after the e-mail message 833 is received indicates that the message 833 has been stored in a certain mailbox 819 in the store 817, and a copy of the e-mail message is stored to a corresponding storage area in the data store 882.
- one or more copies of the e-mail message, indicated at 892 and 894 in Fig. 11, will be sent to and stored in corresponding storage areas or mailboxes in the data store 882.
- updates or copies of stored information in the data store 817 may be sent to the data store 882 via a connection to the WAN 804 or the VPN router 835.
- the wireless connector system 878 may post updates or stored information to a resource in the data store 882 via an HTTP post request.
- a secure protocol such as HTTPS or Secure Sockets Layer (SSL) may be used.
- a single copy of a data item stored in more than one location in a data store at the LAN 809 may instead be sent to the data store 882.
- This copy of the data item could then be stored either in more than one corresponding location in the data store 882, or a single copy may be stored in the data store 882, with a pointer or other identifier of the stored data item being stored in each corresponding location in the data store 882.
- the access gateway 880 is effectively an access platform, in that it provides mobile devices 888 and 890 with access to the data store 882.
- the data store 882 may be configured as a resource accessible on the WAN 804, and the access gateway 880 may be an ISP system or WAP gateway through which mobile devices 888 and 890 connect to the WAN 804.
- a WAP browser or other browser compatible with the wireless networks 884 and 886 may then be used to access the data store 882, which is synchronized with the data store 817, and download stored data items either automatically or responsive to a request from a mobile device 888 or 890.
- copies of the e-mail message 833 which was stored in the data store 817, are sent to the mobile devices 888 and 890.
- a data store on each mobile device 888 and 890 is thereby synchronized with a portion, such as a mailbox 819, of a data store 817 on a corporate LAN 809. Changes to a mobile device data store are similarly reflected in the data stores 882 and 817.
- the embodiments described herein are examples of structures, systems or methods having elements corresponding to the elements of the invention recited in the claims. This written description may enable those of ordinary skill in the art to make and use embodiments having alternative elements that likewise correspond to the elements of the invention recited in the claims. The intended scope of the invention thus includes other structures, systems or methods that do not differ from the literal language of the claims, and further includes other structures, systems or methods with insubstantial differences from the literal language of the claims.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Security & Cryptography (AREA)
- Computer Hardware Design (AREA)
- Theoretical Computer Science (AREA)
- General Engineering & Computer Science (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Bioethics (AREA)
- Health & Medical Sciences (AREA)
- General Health & Medical Sciences (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Computing Systems (AREA)
- Information Transfer Between Computers (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Storage Device Security (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
Description
Claims
Priority Applications (9)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
AU2003213910A AU2003213910A1 (en) | 2002-03-20 | 2003-03-20 | Certificate information storage system and method |
EP03709479A EP1488595B1 (en) | 2002-03-20 | 2003-03-20 | Certificate information storage system and method |
JP2003577495A JP2005521142A (en) | 2002-03-20 | 2003-03-20 | Certification information storage device and certification information storage method |
CA002479619A CA2479619C (en) | 2002-03-20 | 2003-03-20 | Certificate information storage system and method |
DE60315434T DE60315434T2 (en) | 2002-03-20 | 2003-03-20 | CERTIFICATE INFORMATION STORAGE SYSTEM AND METHOD |
KR1020047014846A KR100634861B1 (en) | 2002-03-20 | 2003-03-20 | Certificate information storage method |
US10/508,115 US20050149442A1 (en) | 2002-03-20 | 2003-03-20 | Certificate information storage system and method |
HK05102473A HK1071644A1 (en) | 2002-03-20 | 2005-03-22 | Certificate information storage system and method |
US13/043,859 US9807082B2 (en) | 2002-03-20 | 2011-03-09 | Certificate information storage system and method |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US36551602P | 2002-03-20 | 2002-03-20 | |
US60/365,516 | 2002-03-20 |
Related Child Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10508115 A-371-Of-International | 2003-03-20 | ||
US13/043,859 Continuation US9807082B2 (en) | 2002-03-20 | 2011-03-09 | Certificate information storage system and method |
Publications (1)
Publication Number | Publication Date |
---|---|
WO2003079628A1 true WO2003079628A1 (en) | 2003-09-25 |
Family
ID=28042028
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
PCT/CA2003/000406 WO2003079628A1 (en) | 2002-03-20 | 2003-03-20 | Certificate information storage system and method |
Country Status (11)
Country | Link |
---|---|
US (2) | US20050149442A1 (en) |
EP (1) | EP1488595B1 (en) |
JP (2) | JP2005521142A (en) |
KR (1) | KR100634861B1 (en) |
CN (1) | CN100563242C (en) |
AT (1) | ATE369689T1 (en) |
AU (1) | AU2003213910A1 (en) |
CA (1) | CA2479619C (en) |
DE (1) | DE60315434T2 (en) |
HK (1) | HK1071644A1 (en) |
WO (1) | WO2003079628A1 (en) |
Cited By (18)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP2005311814A (en) * | 2004-04-23 | 2005-11-04 | Fuji Xerox Co Ltd | Certificate compressing apparatus, certificate expanding apparatus, certificate compressing method, and program |
JP2005311818A (en) * | 2004-04-23 | 2005-11-04 | Fuji Xerox Co Ltd | Certificate compressing apparatus and method, program, and certificate expanding apparatus |
WO2005114946A1 (en) * | 2004-05-20 | 2005-12-01 | International Business Machines Corporation | An apparatus, computer-readable memory and method for authenticating and authorizing a service request sent from a service client to a service provider |
EP1633101A1 (en) * | 2004-09-02 | 2006-03-08 | Research In Motion Limited | System and method for searching and retrieving certificates |
US7549043B2 (en) | 2004-09-01 | 2009-06-16 | Research In Motion Limited | Providing certificate matching in a system and method for searching and retrieving certificates |
EP1942620A3 (en) * | 2006-12-27 | 2009-10-07 | Murata Machinery Ltd. | E-mail communication apparatus |
US7640428B2 (en) | 2004-09-02 | 2009-12-29 | Research In Motion Limited | System and method for searching and retrieving certificates |
US8019085B2 (en) | 2005-03-08 | 2011-09-13 | Research In Motion Limited | System and method for sending encrypted messages to a distribution list |
WO2012149219A3 (en) * | 2011-04-26 | 2012-12-27 | Apple Inc. | Electronic access client distribution apparatus and methods |
US8539226B2 (en) | 2001-06-12 | 2013-09-17 | Blackberry Limited | Certificate management and transfer system and method |
US8661267B2 (en) | 2001-08-06 | 2014-02-25 | Blackberry Limited | System and method for processing encoded messages |
US8898473B2 (en) | 2001-06-12 | 2014-11-25 | Blackberry Limited | System and method for compressing secure E-mail for exchange with a mobile data communication device |
US8943156B2 (en) | 2006-06-23 | 2015-01-27 | Blackberry Limited | System and method for handling electronic mail mismatches |
US9094429B2 (en) | 2004-08-10 | 2015-07-28 | Blackberry Limited | Server verification of secure electronic messages |
US9172540B2 (en) | 2001-06-12 | 2015-10-27 | Blackberry Limited | System and method for processing encoded messages for exchange with a mobile data communication device |
US9450759B2 (en) | 2011-04-05 | 2016-09-20 | Apple Inc. | Apparatus and methods for controlling distribution of electronic access clients |
US9628269B2 (en) | 2001-07-10 | 2017-04-18 | Blackberry Limited | System and method for secure message key caching in a mobile communication device |
US9877194B2 (en) | 2010-10-28 | 2018-01-23 | Apple Inc. | Methods and apparatus for delivering electronic identification components over a wireless network |
Families Citing this family (54)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
ATE405077T1 (en) * | 2003-11-26 | 2008-08-15 | Totemo Ag | METHOD AND DEVICE FOR ENCRYPTING ELECTRONIC MAIL |
EP1610518A1 (en) * | 2004-06-21 | 2005-12-28 | Ehsan Aboual Chamat | Authentication system and security device |
US20060036849A1 (en) * | 2004-08-09 | 2006-02-16 | Research In Motion Limited | System and method for certificate searching and retrieval |
US7631183B2 (en) | 2004-09-01 | 2009-12-08 | Research In Motion Limited | System and method for retrieving related certificates |
US7778228B2 (en) * | 2004-09-16 | 2010-08-17 | The Boeing Company | “Wireless ISLAND” mobile LAN-to-LAN tunneling solution |
US7715560B2 (en) * | 2004-11-17 | 2010-05-11 | Inventec Appliances Corp. | Systems and methods for hiding a data group |
US7730143B1 (en) * | 2004-12-01 | 2010-06-01 | Aol Inc. | Prohibiting mobile forwarding |
KR20060081337A (en) * | 2005-01-07 | 2006-07-12 | 엘지전자 주식회사 | Encryption and decryption method using a secret key |
ATE364291T1 (en) * | 2005-01-28 | 2007-06-15 | Research In Motion Ltd | AUTOMATIC INTEGRATION OF CONTENT FROM MULTIPLE STORES USING A MOBILE COMMUNICATIONS DEVICE |
US7739500B2 (en) * | 2005-03-07 | 2010-06-15 | Microsoft Corporation | Method and system for consistent recognition of ongoing digital relationships |
US7822200B2 (en) * | 2005-03-07 | 2010-10-26 | Microsoft Corporation | Method and system for asymmetric key security |
CN101248444A (en) * | 2005-07-25 | 2008-08-20 | 西尔弗布鲁克研究有限公司 | Product item having first coded data and unique identifier |
US20070043663A1 (en) * | 2005-08-16 | 2007-02-22 | Mark Simpson | E-payment advice system |
JP4783112B2 (en) * | 2005-10-11 | 2011-09-28 | 株式会社日立製作所 | Signature history storage device |
EP1803249B1 (en) * | 2005-10-14 | 2010-04-07 | Research In Motion Limited | System and method for protecting master encryption keys |
KR100755536B1 (en) * | 2005-12-15 | 2007-09-06 | 주식회사 팬택앤큐리텔 | Prevention system for the IP allocation of a cloned mobile phone |
US20070143596A1 (en) * | 2005-12-15 | 2007-06-21 | International Business Machines Corporation | Untrusted certificate store for secure e-mail |
US8090361B2 (en) | 2006-05-26 | 2012-01-03 | At&T Intellectual Property I, Lp | Methods and systems for monitoring computer systems using wireless devices |
JP2008048353A (en) * | 2006-08-21 | 2008-02-28 | Murata Mach Ltd | Electronic mail communication apparatus |
JP2008079091A (en) * | 2006-09-22 | 2008-04-03 | Fujitsu Ltd | Authentication system using electronic certificate |
US8572373B2 (en) * | 2006-11-30 | 2013-10-29 | Red Hat, Inc. | Method, apparatus and system for secure electronic mail |
KR20080109521A (en) * | 2007-06-13 | 2008-12-17 | 엘지전자 주식회사 | A receiver and a processing method for data broadcasting signal |
US20090028329A1 (en) * | 2007-07-23 | 2009-01-29 | Savi Technology, Inc. | Method and Apparatus for Providing Security in a Radio Frequency Identification System |
US20090216678A1 (en) * | 2008-02-25 | 2009-08-27 | Research In Motion Limited | System and method for facilitating secure communication of messages associated with a project |
US8108777B2 (en) | 2008-08-11 | 2012-01-31 | Microsoft Corporation | Sections of a presentation having user-definable properties |
US20100075283A1 (en) * | 2008-09-18 | 2010-03-25 | Raymond Rees | Device and method for training underground storage tank operators |
US8296563B2 (en) * | 2008-10-22 | 2012-10-23 | Research In Motion Limited | Method of handling a certification request |
US8255685B2 (en) | 2009-03-17 | 2012-08-28 | Research In Motion Limited | System and method for validating certificate issuance notification messages |
US8776192B2 (en) * | 2009-11-17 | 2014-07-08 | At&T Intellectual Property I, L.P. | Methods, systems, and computer program products for automatically verifying and populating digital certificates in an encryption keystore |
US9203831B2 (en) * | 2009-11-25 | 2015-12-01 | Red Hat, Inc. | SSL client authentication |
JP5429880B2 (en) * | 2010-08-10 | 2014-02-26 | Necビッグローブ株式会社 | Application distribution system, application distribution method, terminal, and program |
US9027141B2 (en) * | 2012-04-12 | 2015-05-05 | Netflix, Inc. | Method and system for improving security and reliability in a networked application environment |
US9571465B1 (en) * | 2014-09-18 | 2017-02-14 | Amazon Technologies, Inc. | Security verification by message interception and modification |
CN106464667B (en) | 2015-02-09 | 2020-01-10 | 华为技术有限公司 | Certificate management method, equipment and system |
CN105184138B (en) * | 2015-08-13 | 2019-01-22 | 深圳市广和通无线股份有限公司 | Wireless communication module and its certificate load and configuration method of calibration |
US10311042B1 (en) | 2015-08-31 | 2019-06-04 | Commvault Systems, Inc. | Organically managing primary and secondary storage of a data object based on expiry timeframe supplied by a user of the data object |
KR20180066148A (en) | 2015-10-21 | 2018-06-18 | 후아웨이 테크놀러지 컴퍼니 리미티드 | Method and device for managing certificates in a network functional virtualization architecture |
US9705859B2 (en) * | 2015-12-11 | 2017-07-11 | Amazon Technologies, Inc. | Key exchange through partially trusted third party |
US10412098B2 (en) * | 2015-12-11 | 2019-09-10 | Amazon Technologies, Inc. | Signed envelope encryption |
KR20180083690A (en) * | 2017-01-13 | 2018-07-23 | 에이치피프린팅코리아 주식회사 | image forming apparatus for performing screen saver and method of controlling image forming apparatus for performing screen saver |
US11489866B2 (en) | 2018-03-07 | 2022-11-01 | Private Identity Llc | Systems and methods for private authentication with helper networks |
US11138333B2 (en) | 2018-03-07 | 2021-10-05 | Private Identity Llc | Systems and methods for privacy-enabled biometric processing |
US11170084B2 (en) | 2018-06-28 | 2021-11-09 | Private Identity Llc | Biometric authentication |
US11394552B2 (en) | 2018-03-07 | 2022-07-19 | Private Identity Llc | Systems and methods for privacy-enabled biometric processing |
US11210375B2 (en) | 2018-03-07 | 2021-12-28 | Private Identity Llc | Systems and methods for biometric processing with liveness |
US10721070B2 (en) | 2018-03-07 | 2020-07-21 | Private Identity Llc | Systems and methods for privacy-enabled biometric processing |
US11392802B2 (en) | 2018-03-07 | 2022-07-19 | Private Identity Llc | Systems and methods for privacy-enabled biometric processing |
US11789699B2 (en) | 2018-03-07 | 2023-10-17 | Private Identity Llc | Systems and methods for private authentication with helper networks |
US11265168B2 (en) * | 2018-03-07 | 2022-03-01 | Private Identity Llc | Systems and methods for privacy-enabled biometric processing |
US11502841B2 (en) | 2018-03-07 | 2022-11-15 | Private Identity Llc | Systems and methods for privacy-enabled biometric processing |
US10938852B1 (en) | 2020-08-14 | 2021-03-02 | Private Identity Llc | Systems and methods for private authentication with helper networks |
KR102089852B1 (en) * | 2018-04-16 | 2020-04-23 | 주식회사 스마트엠투엠 | System and Method for Security Provisioning based on Blockchain |
CN115250186B (en) * | 2021-04-12 | 2024-04-16 | 顺丰科技有限公司 | Network connection authentication method, device, computer equipment and storage medium |
US20220103358A1 (en) * | 2021-12-08 | 2022-03-31 | Intel Corporation | Cloud key access mechanism |
Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1139608A2 (en) * | 2000-03-31 | 2001-10-04 | Lucent Technologies Inc. | Method and system for subscriber-configurable communications service |
US20010054149A1 (en) * | 2000-06-20 | 2001-12-20 | Yuichi Kawaguchi | Justification authenticating system, personal certificate issuing system, and personal certificate |
WO2002101580A1 (en) * | 2001-06-12 | 2002-12-19 | Research In Motion Limited | Certificate management and transfer system and method |
Family Cites Families (14)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5958005A (en) * | 1997-07-17 | 1999-09-28 | Bell Atlantic Network Services, Inc. | Electronic mail security |
JP3942267B2 (en) * | 1998-04-21 | 2007-07-11 | 東芝テック株式会社 | E-mail system |
US6990578B1 (en) * | 1999-10-29 | 2006-01-24 | International Business Machines Corp. | Method and apparatus for encrypting electronic messages composed using abbreviated address books |
JP2001352338A (en) | 2000-06-08 | 2001-12-21 | Nec Corp | Server, network system and mail transmission method |
WO2002001783A2 (en) * | 2000-06-27 | 2002-01-03 | Peoplestreet, Inc. | Systems and methods for managing contact information |
US20030041110A1 (en) * | 2000-07-28 | 2003-02-27 | Storymail, Inc. | System, Method and Structure for generating and using a compressed digital certificate |
US7130885B2 (en) * | 2000-09-05 | 2006-10-31 | Zaplet, Inc. | Methods and apparatus providing electronic messages that are linked and aggregated |
GB0027280D0 (en) * | 2000-11-08 | 2000-12-27 | Malcolm Peter | An information management system |
US7069310B1 (en) * | 2000-11-10 | 2006-06-27 | Trio Systems, Llc | System and method for creating and posting media lists for purposes of subsequent playback |
US7003551B2 (en) * | 2000-11-30 | 2006-02-21 | Bellsouth Intellectual Property Corp. | Method and apparatus for minimizing storage of common attachment files in an e-mail communications server |
US7412599B1 (en) * | 2000-12-07 | 2008-08-12 | Entrust Technologies Limited | Administrative remote notification system and method |
US7496604B2 (en) * | 2001-12-03 | 2009-02-24 | Aol Llc | Reducing duplication of files on a network |
US20030199282A1 (en) * | 2002-01-15 | 2003-10-23 | Cezary Marcjan | Mobile telephone active messaging system |
US7051049B2 (en) * | 2002-02-21 | 2006-05-23 | International Business Machines Corporation | Real-time chat and conference contact information manager |
-
2003
- 2003-03-20 EP EP03709479A patent/EP1488595B1/en not_active Expired - Lifetime
- 2003-03-20 WO PCT/CA2003/000406 patent/WO2003079628A1/en active IP Right Grant
- 2003-03-20 CN CNB03811142XA patent/CN100563242C/en not_active Expired - Lifetime
- 2003-03-20 DE DE60315434T patent/DE60315434T2/en not_active Expired - Lifetime
- 2003-03-20 AT AT03709479T patent/ATE369689T1/en not_active IP Right Cessation
- 2003-03-20 JP JP2003577495A patent/JP2005521142A/en not_active Ceased
- 2003-03-20 US US10/508,115 patent/US20050149442A1/en not_active Abandoned
- 2003-03-20 CA CA002479619A patent/CA2479619C/en not_active Expired - Lifetime
- 2003-03-20 AU AU2003213910A patent/AU2003213910A1/en not_active Abandoned
- 2003-03-20 KR KR1020047014846A patent/KR100634861B1/en active IP Right Grant
-
2005
- 2005-03-22 HK HK05102473A patent/HK1071644A1/en not_active IP Right Cessation
-
2009
- 2009-10-22 JP JP2009243910A patent/JP2010049702A/en not_active Withdrawn
-
2011
- 2011-03-09 US US13/043,859 patent/US9807082B2/en active Active
Patent Citations (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1139608A2 (en) * | 2000-03-31 | 2001-10-04 | Lucent Technologies Inc. | Method and system for subscriber-configurable communications service |
US20010054149A1 (en) * | 2000-06-20 | 2001-12-20 | Yuichi Kawaguchi | Justification authenticating system, personal certificate issuing system, and personal certificate |
WO2002101580A1 (en) * | 2001-06-12 | 2002-12-19 | Research In Motion Limited | Certificate management and transfer system and method |
Cited By (30)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8539226B2 (en) | 2001-06-12 | 2013-09-17 | Blackberry Limited | Certificate management and transfer system and method |
US9172540B2 (en) | 2001-06-12 | 2015-10-27 | Blackberry Limited | System and method for processing encoded messages for exchange with a mobile data communication device |
US8898473B2 (en) | 2001-06-12 | 2014-11-25 | Blackberry Limited | System and method for compressing secure E-mail for exchange with a mobile data communication device |
USRE45087E1 (en) | 2001-06-12 | 2014-08-19 | Blackberry Limited | Certificate management and transfer system and method |
US9628269B2 (en) | 2001-07-10 | 2017-04-18 | Blackberry Limited | System and method for secure message key caching in a mobile communication device |
US8661267B2 (en) | 2001-08-06 | 2014-02-25 | Blackberry Limited | System and method for processing encoded messages |
JP2005311818A (en) * | 2004-04-23 | 2005-11-04 | Fuji Xerox Co Ltd | Certificate compressing apparatus and method, program, and certificate expanding apparatus |
JP2005311814A (en) * | 2004-04-23 | 2005-11-04 | Fuji Xerox Co Ltd | Certificate compressing apparatus, certificate expanding apparatus, certificate compressing method, and program |
JP4552494B2 (en) * | 2004-04-23 | 2010-09-29 | 富士ゼロックス株式会社 | Certificate compression device, program, and certificate decompression device |
JP4682530B2 (en) * | 2004-04-23 | 2011-05-11 | 富士ゼロックス株式会社 | Certificate compression apparatus, certificate expansion apparatus, and program |
WO2005114946A1 (en) * | 2004-05-20 | 2005-12-01 | International Business Machines Corporation | An apparatus, computer-readable memory and method for authenticating and authorizing a service request sent from a service client to a service provider |
US9094429B2 (en) | 2004-08-10 | 2015-07-28 | Blackberry Limited | Server verification of secure electronic messages |
US9398023B2 (en) | 2004-08-10 | 2016-07-19 | Blackberry Limited | Server verification of secure electronic messages |
US7549043B2 (en) | 2004-09-01 | 2009-06-16 | Research In Motion Limited | Providing certificate matching in a system and method for searching and retrieving certificates |
EP1633101A1 (en) * | 2004-09-02 | 2006-03-08 | Research In Motion Limited | System and method for searching and retrieving certificates |
US7640428B2 (en) | 2004-09-02 | 2009-12-29 | Research In Motion Limited | System and method for searching and retrieving certificates |
AU2005204223B2 (en) * | 2004-09-02 | 2007-11-29 | Blackberry Limited | System and method for searching and retrieving certificates |
US8290166B2 (en) | 2005-03-08 | 2012-10-16 | Research In Motion Limited | System and method for sending encrypted messages to a distribution list |
US8019085B2 (en) | 2005-03-08 | 2011-09-13 | Research In Motion Limited | System and method for sending encrypted messages to a distribution list |
US8667266B2 (en) | 2005-03-08 | 2014-03-04 | Blackberry Limited | System and method for sending encrypted messages to a distribution list |
US8943156B2 (en) | 2006-06-23 | 2015-01-27 | Blackberry Limited | System and method for handling electronic mail mismatches |
EP1942620A3 (en) * | 2006-12-27 | 2009-10-07 | Murata Machinery Ltd. | E-mail communication apparatus |
US7930541B2 (en) | 2006-12-27 | 2011-04-19 | Murata Machinery, Ltd. | E-mail communication apparatus |
US9877194B2 (en) | 2010-10-28 | 2018-01-23 | Apple Inc. | Methods and apparatus for delivering electronic identification components over a wireless network |
US10206106B2 (en) | 2010-10-28 | 2019-02-12 | Apple Inc. | Methods and apparatus for delivering electronic identification components over a wireless network |
US9450759B2 (en) | 2011-04-05 | 2016-09-20 | Apple Inc. | Apparatus and methods for controlling distribution of electronic access clients |
US9788209B2 (en) | 2011-04-05 | 2017-10-10 | Apple Inc. | Apparatus and methods for controlling distribution of electronic access clients |
US8887257B2 (en) | 2011-04-26 | 2014-11-11 | David T. Haggerty | Electronic access client distribution apparatus and methods |
US9419970B2 (en) | 2011-04-26 | 2016-08-16 | Apple Inc. | Electronic access client distribution apparatus and methods |
WO2012149219A3 (en) * | 2011-04-26 | 2012-12-27 | Apple Inc. | Electronic access client distribution apparatus and methods |
Also Published As
Publication number | Publication date |
---|---|
DE60315434T2 (en) | 2008-04-24 |
AU2003213910A1 (en) | 2003-09-29 |
KR20050002877A (en) | 2005-01-10 |
JP2005521142A (en) | 2005-07-14 |
EP1488595A1 (en) | 2004-12-22 |
CA2479619C (en) | 2008-05-20 |
CA2479619A1 (en) | 2003-09-25 |
US20050149442A1 (en) | 2005-07-07 |
KR100634861B1 (en) | 2006-10-17 |
US9807082B2 (en) | 2017-10-31 |
DE60315434D1 (en) | 2007-09-20 |
CN1799240A (en) | 2006-07-05 |
EP1488595B1 (en) | 2007-08-08 |
HK1071644A1 (en) | 2005-07-22 |
JP2010049702A (en) | 2010-03-04 |
CN100563242C (en) | 2009-11-25 |
US20110271115A1 (en) | 2011-11-03 |
ATE369689T1 (en) | 2007-08-15 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
EP1488595B1 (en) | Certificate information storage system and method | |
US7865720B2 (en) | System and method for supporting multiple certificate status providers on a mobile communication device | |
EP1488597B1 (en) | System and method for checking digital certificate status | |
US8423763B2 (en) | System and method for supporting multiple certificate status providers on a mobile communication device | |
US7546453B2 (en) | Certificate management and transfer system and method | |
US9628269B2 (en) | System and method for secure message key caching in a mobile communication device | |
US8194857B2 (en) | Multiple-stage system and method for processing encoded messages | |
EP1417814B1 (en) | System and method for processing encoded messages |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AK | Designated states |
Kind code of ref document: A1 Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NO NZ OM PH PL PT RO RU SC SD SE SG SK SL TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW |
|
AL | Designated countries for regional patents |
Kind code of ref document: A1 Designated state(s): GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG |
|
121 | Ep: the epo has been informed by wipo that ep was designated in this application | ||
DFPE | Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed before 20040101) | ||
WWE | Wipo information: entry into national phase |
Ref document number: 2003577495 Country of ref document: JP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2479619 Country of ref document: CA Ref document number: 10508115 Country of ref document: US |
|
WWE | Wipo information: entry into national phase |
Ref document number: 1020047014846 Country of ref document: KR Ref document number: 2788/DELNP/2004 Country of ref document: IN |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2003709479 Country of ref document: EP |
|
WWE | Wipo information: entry into national phase |
Ref document number: 2003811142X Country of ref document: CN |
|
WWP | Wipo information: published in national office |
Ref document number: 2003709479 Country of ref document: EP |
|
WWP | Wipo information: published in national office |
Ref document number: 1020047014846 Country of ref document: KR |
|
WWG | Wipo information: grant in national office |
Ref document number: 2003709479 Country of ref document: EP |