No Formal Workgroup G. Queiroz Internet-Draft September 5, 2018 Intended status: Experimental Expires: March 9, 2019 JSON Unified Digital Signatures System Standard 1 draft-judsys1-01 Abstract A simple digital signature standard designed to be used by regular people and to be of mandatory acceptance. Status of This Memo This Internet-Draft is submitted in full conformance with the provisions of BCP 78 and BCP 79. Internet-Drafts are working documents of the Internet Engineering Task Force (IETF). Note that other groups may also distribute working documents as Internet-Drafts. The list of current Internet- Drafts is at https://datatracker.ietf.org/drafts/current/. Internet-Drafts are draft documents valid for a maximum of six months and may be updated, replaced, or obsoleted by other documents at any time. It is inappropriate to use Internet-Drafts as reference material or to cite them other than as "work in progress." This Internet-Draft will expire on March 9, 2019. Copyright Notice Copyright (c) 2018 IETF Trust and the persons identified as the document authors. All rights reserved. This document is subject to BCP 78 and the IETF Trust's Legal Provisions Relating to IETF Documents (https://trustee.ietf.org/license-info) in effect on the date of publication of this document. Please review these documents carefully, as they describe your rights and restrictions with respect to this document. Queiroz Expires March 9, 2019 [Page 1] Internet-Draft JUDSYS1 September 2018 Table of Contents 1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . 4 1.1. Right of Implementation . . . . . . . . . . . . . . . . . 5 1.2. Terminology . . . . . . . . . . . . . . . . . . . . . . . 5 2. Encoding . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2.1. Files . . . . . . . . . . . . . . . . . . . . . . . . . . 6 2.1.1. File extensions . . . . . . . . . . . . . . . . . . . 6 2.2. Strings . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.3. Dates . . . . . . . . . . . . . . . . . . . . . . . . . . 7 2.4. Country codes . . . . . . . . . . . . . . . . . . . . . . 7 2.5. Certificate chains . . . . . . . . . . . . . . . . . . . 8 3. Certificates . . . . . . . . . . . . . . . . . . . . . . . . 8 3.1. Keys . . . . . . . . . . . . . . . . . . . . . . . . . . 8 3.2. Subject Attributes . . . . . . . . . . . . . . . . . . . 9 3.2.1. INT/type . . . . . . . . . . . . . . . . . . . . . . 9 3.2.2. INT/names . . . . . . . . . . . . . . . . . . . . . . 9 3.2.3. INT/parents . . . . . . . . . . . . . . . . . . . . . 10 3.2.4. INT/emails . . . . . . . . . . . . . . . . . . . . . 11 3.2.5. INT/phones . . . . . . . . . . . . . . . . . . . . . 11 3.2.6. INT/addresses . . . . . . . . . . . . . . . . . . . . 12 3.2.7. INT/pictures . . . . . . . . . . . . . . . . . . . . 12 3.2.8. INT/passports . . . . . . . . . . . . . . . . . . . . 12 4. Certification Chain . . . . . . . . . . . . . . . . . . . . . 14 4.1. Public Key Infrastructure . . . . . . . . . . . . . . . . 14 4.2. Nameless Certificates . . . . . . . . . . . . . . . . . . 14 4.3. Revocation . . . . . . . . . . . . . . . . . . . . . . . 14 5. Proof of attribute . . . . . . . . . . . . . . . . . . . . . 15 5.1. Standard attributes . . . . . . . . . . . . . . . . . . . 15 5.1.1. INT/job . . . . . . . . . . . . . . . . . . . . . . . 15 6. Signatures . . . . . . . . . . . . . . . . . . . . . . . . . 15 6.1. Standard attributes . . . . . . . . . . . . . . . . . . . 16 6.1.1. INT/reason . . . . . . . . . . . . . . . . . . . . . 16 6.1.2. INT/location . . . . . . . . . . . . . . . . . . . . 17 6.1.3. INT/date . . . . . . . . . . . . . . . . . . . . . . 17 6.1.4. INT/file . . . . . . . . . . . . . . . . . . . . . . 18 6.1.5. INT/counter . . . . . . . . . . . . . . . . . . . . . 18 6.2. Signature Request . . . . . . . . . . . . . . . . . . . . 18 7. Internet APIs . . . . . . . . . . . . . . . . . . . . . . . . 18 7.1. Online RESTful . . . . . . . . . . . . . . . . . . . . . 18 7.1.1. Sign certificate . . . . . . . . . . . . . . . . . . 18 7.1.2. Certificate revocation status . . . . . . . . . . . . 18 7.1.3. Timestamp servers . . . . . . . . . . . . . . . . . . 18 7.2. Browser interaction . . . . . . . . . . . . . . . . . . . 18 8. Smartcards . . . . . . . . . . . . . . . . . . . . . . . . . 18 9. Security and Usability Considerations . . . . . . . . . . . . 18 9.1. Mixing digital and paper signatures . . . . . . . . . . . 18 9.2. Dynamic Content . . . . . . . . . . . . . . . . . . . . . 18 Queiroz Expires March 9, 2019 [Page 2] Internet-Draft JUDSYS1 September 2018 9.3. Accidental changes . . . . . . . . . . . . . . . . . . . 20 9.4. Archive files . . . . . . . . . . . . . . . . . . . . . . 20 9.5. User misinterpretation and excessive trust on the machine 20 9.6. Certificate and password sharing . . . . . . . . . . . . 20 9.7. Cloud usage . . . . . . . . . . . . . . . . . . . . . . . 20 9.8. Side channel attacks . . . . . . . . . . . . . . . . . . 20 9.9. Document replacement . . . . . . . . . . . . . . . . . . 20 10. Language Specific Rules . . . . . . . . . . . . . . . . . . . 20 10.1. Portuguese . . . . . . . . . . . . . . . . . . . . . . . 20 10.1.1. Unicode Support . . . . . . . . . . . . . . . . . . 20 10.1.2. Standard Translations . . . . . . . . . . . . . . . 20 11. Country Specific Rules . . . . . . . . . . . . . . . . . . . 21 11.1. Brazil . . . . . . . . . . . . . . . . . . . . . . . . . 21 11.2. Subject Attributes . . . . . . . . . . . . . . . . . . . 22 11.2.1. BR/CPF . . . . . . . . . . . . . . . . . . . . . . . 22 11.2.2. BR/CNPJ . . . . . . . . . . . . . . . . . . . . . . 22 11.2.3. BR/RNE . . . . . . . . . . . . . . . . . . . . . . . 22 11.2.4. BR/RG . . . . . . . . . . . . . . . . . . . . . . . 22 11.2.5. BR/Titulo de Eleitor . . . . . . . . . . . . . . . . 23 11.2.6. BR/NIT . . . . . . . . . . . . . . . . . . . . . . . 23 12. JSON Schemas . . . . . . . . . . . . . . . . . . . . . . . . 23 12.1. Certificate File (.j1c) . . . . . . . . . . . . . . . . 23 12.2. Private Keys File (.j1k) . . . . . . . . . . . . . . . . 24 12.3. Proof of Attribute File (.j1a) . . . . . . . . . . . . . 25 12.4. Detached Digital Signature File (.j1s) . . . . . . . . . 25 12.5. Encrypted File (.j1e) . . . . . . . . . . . . . . . . . 25 12.6. Revocation Information File (.j1r) . . . . . . . . . . . 25 12.7. Hash (optionally salted) . . . . . . . . . . . . . . . . 25 12.8. AES-256-CBC . . . . . . . . . . . . . . . . . . . . . . 25 12.9. Argon2 . . . . . . . . . . . . . . . . . . . . . . . . . 26 12.10. ECDSA . . . . . . . . . . . . . . . . . . . . . . . . . 26 12.11. Encrypted Object . . . . . . . . . . . . . . . . . . . . 26 12.12. Signed Object . . . . . . . . . . . . . . . . . . . . . 28 12.13. Key . . . . . . . . . . . . . . . . . . . . . . . . . . 28 12.13.1. RSA . . . . . . . . . . . . . . . . . . . . . . . . 29 12.13.2. ECDSA Public Key . . . . . . . . . . . . . . . . . 30 12.14. Entity (subject of issuer) . . . . . . . . . . . . . . . 31 12.15. Certificate . . . . . . . . . . . . . . . . . . . . . . 32 12.16. Address . . . . . . . . . . . . . . . . . . . . . . . . 33 12.17. Passport . . . . . . . . . . . . . . . . . . . . . . . . 35 13. References . . . . . . . . . . . . . . . . . . . . . . . . . 36 13.1. Normative References . . . . . . . . . . . . . . . . . . 36 13.2. Informative References . . . . . . . . . . . . . . . . . 36 Author's Address . . . . . . . . . . . . . . . . . . . . . . . . 36 Queiroz Expires March 9, 2019 [Page 3] Internet-Draft JUDSYS1 September 2018 1. Introduction Currently, ITI, the government body responsible of ICP-Brasil, Brazil's PKI (Public Key Infrastructure), endorses three different standards: CAdES, XAdES and PAdES. Since they are all based on X.509 which is used in SSL, there should be an abundance of good software libraries and end user applications to support at least one of these standard. This is not the case. While there have been some efforts to write open source libraries and end user applications for ICP-Brasil, they are hard to find and most seem unfinished and abandoned. ITI provides a digital signature verification web tool, but it is only for CAdES and doesn't seem to work well. PAdES is a monster of its own kind. In an attempt to replicate the paper experience in the digital world, a PDF file can be signed, edited and resigned by another person in a way that they signed over different version of the same document. This is both hard to implement and hard to explain to end users. To make matters worse, PDF readers almost never come with the necessary CAs to verify ICP-Brasil digital signatures. Perhaps as result of this mess of different standards, the ITI admits that, no one is obliged to accept digital signatures in Brazil (see [ITI-FAQ-21]). This situation is unacceptable. We need a digital signature standard that: 1. Is easy for programmers to implement. Including reference libraries in multiple languages. 2. Is easy for ordinary people to use on a day to day basis. 3. Has strict rules to avoid interoperability problems. 4. Has mandatory acceptance by law. This document aims to provide a digital signature standard that address points one through three. Hopefully, this standard may fulfil the fourth point in the near future. Queiroz Expires March 9, 2019 [Page 4] Internet-Draft JUDSYS1 September 2018 1.1. Right of Implementation Any person, group or organization can freely implement this standard so long as the implementation is complete. 1.2. Terminology The keywords MUST, MUST NOT, REQUIRED, SHALL, SHALL NOT, SHOULD, SHOULD NOT, RECOMMENDED, MAY, and OPTIONAL, when they appear in this document, are to be interpreted as described in [RFC2119]. All apps MUST use the standard translations present in this document when they present in the Language specific rules section. *User*: A human being using a JUDSYS app. Unless otherwise specified, users MUST always be considered as non-tech-savvy people. *Signing app*: A computer program that digitally signs documents according to this standard. *Verifier app*: A computer program that verifies a digital signature according to this standard. (*App*) *JUDSYS app* or *implementation*: A computer program that is either a singing app or a verifier app or both. *Subject attributes*: Certain values that qualify the subject. Ex: email, full name, government issued identification numbers, et cetera. *Natural person*: A human begin. *Legal person*: A group of people who the Law considers to be its own person. *Software person*: A piece of software that acts in the name of a natural or legal person. *Digital signature*: (*PKI*) *Public Key Infrastructure*: (*KP*) *Key Pair*: *Certificate*: A short signed message that states a key pair is in the control of a specific subject. Queiroz Expires March 9, 2019 [Page 5] Internet-Draft JUDSYS1 September 2018 (*CA*) *Certificate Authority*: A certificate that is allowed to sign other certificates. This is, a CA is an entity (usually a company or government body) that ensures that the subject on a certificate is really the person it names. (*PA*) *Proof of attribute*: A short signed message in which the issuer certifies that a certain attribute is true. Examples: job titles and permissions delegated by the issuer to the subject. (*TA*) *Time-stamping Authority* This is very similar to the concept of attribute certificates. The names was changed to avoid using the "certificate" in two different contexts that may confuse users. *ICAO*: International Civil Aviation Organization. *JSON*: JavaScript Object Notation. 2. Encoding 2.1. Files All JUDSYS-1 files are JSON encoded with UTF-8. To avoid canonicalization problems, all signed messages are encoded in base64. Example: {"b": 1, "a":2} // becomes { "raw": "eyJiIjogMSwgImEiOjJ9Cg==", // This is to aid humans debugging, not for machines to use "what": "JUDSYS-1 base64" } 2.1.1. File extensions All JUDSYS-1 extensions begin with ".j1" (dot, jay, one). For JUDSYS-1 files, all apps MUST use only the file extensions show below: Queiroz Expires March 9, 2019 [Page 6] Internet-Draft JUDSYS1 September 2018 +-----------+------------------------------------+ | Extension | Usage | +-----------+------------------------------------+ | ".j1c" | Certificates (no private keys) | | ".j1a" | Attribute certificates | | ".j1k" | Certificates with the private keys | | ".j1s" | Detached digital signature | | ".j1e" | Encrypted file | | ".j1r" | Revocation information | +-----------+------------------------------------+ 2.2. Strings All apps MUST have proper Unicode support and fonts to display any characters that may be necessary for the country of intended use. This is, an app for France MUST have fonts with accented characters, but MAY have no CJK nor Cyrillic support. An app for Russia MUST have Cyrillic and Latin support, but MAY have no CJK or Mongolian support. It is RECOMMENDED to store string in NFC (Normal Form Composition). It is RECOMMENDED that all apps support as much Unicode characters and scripts as possible. It is also RECOMMENDED that all apps include the necessary fonts. Emoji usage is discouraged. 2.3. Dates All dates MUST be encoded as strings according to the [RFC3339]. If the time is not available, it MUST be assumed to be midnight. Times MUST NOT include fractions of a second. 2.4. Country codes All countries or similar MUST be represented by the upper case two letter codes defined on ISO 3166-1. If a country or similar does not have such code, it MUST be full English name with spaces and proper capitalization. Ex: "Principality of Sealand" not "principality of sealand" nor "PrincipalityOf_Sealand". International organizations MUST use their upper case English acronym if it has more than two letters. Ex: "ICAO" and "ICJ". Otherwise the full English name with spaces and capitalization MUST be used. Ex: "League of Nations". Queiroz Expires March 9, 2019 [Page 7] Internet-Draft JUDSYS1 September 2018 Special cases are: 1. "UN" for the United Nations (already on the ISO 3166-1). 2. "EU" for the European Union (already on the ISO 3166-1). 3. "INT" for international things such as passports, names and date of birth. 4. "MERCOSU" for the Southern Common Market, Mercosur in Spanish and Mercosul in Portuguese. 5. "UNASU" for the Union of South American Nations, UNSAUR in Spanish and UNASUL in Portuguese. 6. "NAFTA" for the North American Free Trade Agreement. 7. "HOAX" for URSAL - Uniao das Republicas Socialistas da America Latina. (just a joke, non-normative) 2.5. Certificate chains All JUDSYS-1 files MUST include all the necessary certificates, attribute certificates and revocation files for verifying the file in question. An exception is made to the root CAs which MUST NOT be included in any JUDSYS-1 file, as they MUST be a part of the apps themselves, preferably in the app's source code. 3. Certificates ✏️ 3.1. Keys All keys are encoded as a dictionaries, which MUST have the following keys: 1. "algorithm" 2. "id": A hash of the key that uniquely identifies it. 3. "usage": An enum that indicates what the key may be used for. Possible values: 1. "signing": The key is used only to sign digital documents, issue and revoke attribute certificates. Queiroz Expires March 9, 2019 [Page 8] Internet-Draft JUDSYS1 September 2018 2. "identification": They key is used only to identify the subject. Ex: login. 3. "encryption": The key is used only for any person to encrypt messages to the subject. 4. "certification": The key is used only to issue digital certificates. 5. "revocation": They key is used only to issue certificate revocations. Each key MUST NOT be used in any algorithms other than the one prescribed on the key "usage". Key material MUST NOT be reused. 3.2. Subject Attributes Attributes in the singular are a single value and attributes in the plural are arrays. The CA MUST verify the attributes it will use on certificates it issues. If any verification is not done or fails, the corresponding attributes MUST NOT be included in the issued certificate. Examples: 1. If the CA fails to verify that a phone number really belongs to the subject, it MUST never be included. 2. If the subject of the certificate to be issued forgets to bring their US/SSN, this attribute MUST NOT be included in the certificate. A CA MAY refuse to issue a certificate if essential properties could not verified. Examples: INT/name, US/SSN, BR/RG, BR/CPF. 3.2.1. INT/type An enum describing the type of the subject. Possible values are: "natural person", "legal person", and "other" (ex: software). 3.2.2. INT/names Each name is a one line Unicode string. All name entries each MUST be at most 5 KiB long. Queiroz Expires March 9, 2019 [Page 9] Internet-Draft JUDSYS1 September 2018 All apps MUST support such long names. They MAY, however, show only the beginning of the name by default and have a simple way to show the full name. Example: a tooltip or a button close to the name. There MUST be at least one name in the "INT/name" attribute. Any prefixes, suffixes, infixes, honorifics and similar things attached to the name MUST be verified. Example: a person may never use the prefix "Dr." if they have no valid doctorates degree. Generic prefixes like "Mr." or "Ms." and job titles MUST NOT be included in any of the names. For legal persons, it is RECOMMENDED to follow the convention: "() " Examples: 1. (USP) Universidade Sao Paulo 2. Monsters Inc. 3. Empresa Qualquer Servicos e Comercio LTDA For natural persons, it is RECOMMENDED to follow the convention: "() " Examples: 1. Dennis MacAlister Ritchie 2. (FHC) Fernando Henrique Cardoso 3. (Dom Pedro II) Pedro de Alcantara Joao Carlos Leopoldo Salvador Bibiano Francisco Xavier de Paula Leocadio Miguel Gabriel Rafael Gonzaga 3.2.3. INT/parents An array of entities. The order MUST NOT be assigned any meaning. The array MAY have any number of elements. The "INT/parents" attribute MAY lead to a recursive behaviour. This attribute SHOULD NOT exceed the grandparents generations. Example 1: [ {"id": "BR/CPF", "INT/names": ["Joao da Silva"], "BR/CPF": "123.456.789-00"}, {"id": "BR/CPF", "INT/names": ["Maria da Silva"], "BR/CPF": "987.654.321-00"}, {"id": "BR/CPF", "INT/names": ["Joaquim Freitas"], "BR/CPF": "987.654.321-00"} ] Queiroz Expires March 9, 2019 [Page 10] Internet-Draft JUDSYS1 September 2018 3.2.4. INT/emails An array of the subject's email addresses. The fist entry is considered the main one. The subject MAY have no email address. It is *RECOMENDED* to have at least one ASCII email address. Examples: // Okay: [] ["someone@example.com"] ["jose@construcoes-ltda.br", "jose@construcoes-ltda.br"] ["jose@construcoes-ltda.br", "jose@xn--construes-ltda-mjb8t.br"] ["jose@construcoes-ltda.br", "jose@construcoes-ltda.br", "jose@xn--construes-ltda-mjb8t.br"] ["jose@construcoes-ltda.br"] ["jose@construcoes-ltda.br", "jose@construcoes-ltda.br"] 3.2.5. INT/phones For SPAM/robo-calling prevention the subject MUST have the right to refuse the inclusion of the "INT/phone" attribute. The phone numbers MUST be encoded as a string array. Each element of that array represents one phone number and MUST include the country and area codes. The country code part MUST begin with a "+" (plus sign) and have a space to separate it from the rest of the number. This is mainly to aid humans, by separating the international part from the local one. The rest of the number SHOULD follow the traditions and conventions of the country in question and MAY include punctuation. Examples: // Okay: [] ["+55 (11) 0 0000-0000", "+55 0800 000"] // Wrong: ["+55(11) 0 0000-0000", "+550800000", "55 0800 000"] Note: This attribute is intended to be used by some legal persons and by pretty much no natural persons. Queiroz Expires March 9, 2019 [Page 11] Internet-Draft JUDSYS1 September 2018 3.2.6. INT/addresses For security reasons the subject MUST have the right to refuse the inclusion of "INT/address" attribute. 3.2.7. INT/pictures For privacy reasons the subject SHOULD have the right to refuse the inclusion of "INT/picture" attribute. The CA, however, CAN require this attribute but its is encouraged not to require it. The picture MUST always be static: no animated GIFs or similar. For natural persons the image MUST be picture of the subject. The specific are left to the CA, but it SHOULD follow the traditions and conventions of the CA's country. One suggestion for CAs is to follow the ICAO guidlines on photos for passports (see [ICAO-9303]). For legal persons the image MUST be a logo or other symbol that represents the subject. It MUST NOT be a picture of the owners or of the place where the subject is. Again, specific are left to the CA. Support for this property in apps is OPTIONAL but *RECOMENDED* to those that have a GUI. Those that decide to implement this property MUST be able do decode both JPEG and PNG. The picture MUST be data URL encoded using base64 and MUST NOT exceed 1 MiB. The size restriction applies to the image itself, not to the string that encodes it. The picture MUST NOT be rotated using metadata (see [JPEG-HOFF]) regardless of the file type (JPGE or PNG or other). Example: (Tux, the Linux mascot) [""] 3.2.8. INT/passports Each passport is encoded as a dictionary with the following keys: 1. "type": Indicates the type of document, for passports this is a "P". Queiroz Expires March 9, 2019 [Page 12] Internet-Draft JUDSYS1 September 2018 2. "number": A string, which MAY contain letters, the identifies this passport. 3. "country": The country that issued the passport. 4. "surname": The subject's last name. 5. "given_name": The subject's first name. 6. "nationality": The subject's nationality. 7. "date_of_birth": The subject's date of birth. 8. "place_of_birth": The subject's place of birth. 9. "personal_number": An id number identifying the subject. 10. "sex": The sex or gender of the subject. Note that "X" and other characters may be used instead of the traditional "F" and "M". 11. "date_of_issue": The date in which the passport was issued. 12. "date_of_expiry": The date in which the passport will expire. 13. "MRZ": the contents on the MRZ (machine readable zone). Only "type", "country" and "number" MUST be present. The "given_name" and "surname" are OPTIONAL because some people may have no first or last name. However, at least one of them MUST be included. Except of dates, it is RECOMMENDED that all fields match the way they are presented on the VIZ (Visual Inspection Zone), rather than the MRZ. Queiroz Expires March 9, 2019 [Page 13] Internet-Draft JUDSYS1 September 2018 { "type": "P", "country": "UTO", // This **MAY NOT** match ISO 3166-1, read ICAO Doc 9303 (pages 22 to 29) for details. "number": "L898902C3", "surname": "ERIKSSON", "given_name": "ANNA MARIA", "nationality": "UTOPIAN", "date_of_birth": "1974-08-12", "place_of_birth": "ZENITH", "personal_number": "Z E 184226 B", "sex": "F", /* Do NOT assume it is "F" or "M", other characters, such as "X" may de used. */ "date_of_issue": "2007-04-16", "date_of_expiry": "2012-04-15", "MRZ": "P" tag. 2. Properties such as "onclick" and "oninput" on any tags. 3. External URLs for the tags "" and "