http: Print human readable GNUTLS status.
[gnupg.git] / common / openpgpdefs.h
1 /* openpgpdefs.h - Constants from the OpenPGP standard (rfc2440)
2  * Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005,
3  *               2006 Free Software Foundation, Inc.
4  * Copyright (C) 2014 Werner Koch
5  *
6  * This file is free software; you can redistribute it and/or modify
7  * it under the terms of either
8  *
9  *   - the GNU Lesser General Public License as published by the Free
10  *     Software Foundation; either version 3 of the License, or (at
11  *     your option) any later version.
12  *
13  * or
14  *
15  *   - the GNU General Public License as published by the Free
16  *     Software Foundation; either version 2 of the License, or (at
17  *     your option) any later version.
18  *
19  * or both in parallel, as here.
20  *
21  * This file is distributed in the hope that it will be useful,
22  * but WITHOUT ANY WARRANTY; without even the implied warranty of
23  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24  * GNU General Public License for more details.
25  *
26  * You should have received a copy of the GNU General Public License
27  * along with this program; if not, see <http://www.gnu.org/licenses/>.
28  */
29
30 #ifndef GNUPG_COMMON_OPENPGPDEFS_H
31 #define GNUPG_COMMON_OPENPGPDEFS_H
32
33 typedef enum
34   {
35     PKT_NONE          = 0,
36     PKT_PUBKEY_ENC    = 1,  /* Public key encrypted packet. */
37     PKT_SIGNATURE     = 2,  /* Secret key encrypted packet. */
38     PKT_SYMKEY_ENC    = 3,  /* Session key packet. */
39     PKT_ONEPASS_SIG   = 4,  /* One pass sig packet. */
40     PKT_SECRET_KEY    = 5,  /* Secret key. */
41     PKT_PUBLIC_KEY    = 6,  /* Public key. */
42     PKT_SECRET_SUBKEY = 7,  /* Secret subkey. */
43     PKT_COMPRESSED    = 8,  /* Compressed data packet. */
44     PKT_ENCRYPTED     = 9,  /* Conventional encrypted data. */
45     PKT_MARKER        = 10, /* Marker packet. */
46     PKT_PLAINTEXT     = 11, /* Literal data packet. */
47     PKT_RING_TRUST    = 12, /* Keyring trust packet. */
48     PKT_USER_ID       = 13, /* User id packet. */
49     PKT_PUBLIC_SUBKEY = 14, /* Public subkey. */
50     PKT_OLD_COMMENT   = 16, /* Comment packet from an OpenPGP draft. */
51     PKT_ATTRIBUTE     = 17, /* PGP's attribute packet. */
52     PKT_ENCRYPTED_MDC = 18, /* Integrity protected encrypted data. */
53     PKT_MDC           = 19, /* Manipulation detection code packet. */
54     PKT_COMMENT       = 61, /* new comment packet (GnuPG specific). */
55     PKT_GPG_CONTROL   = 63  /* internal control packet (GnuPG specific). */
56   }
57 pkttype_t;
58
59
60 typedef enum
61   {
62     SIGSUBPKT_TEST_CRITICAL = -3,
63     SIGSUBPKT_LIST_UNHASHED = -2,
64     SIGSUBPKT_LIST_HASHED   = -1,
65     SIGSUBPKT_NONE          =  0,
66     SIGSUBPKT_SIG_CREATED   =  2, /* Signature creation time. */
67     SIGSUBPKT_SIG_EXPIRE    =  3, /* Signature expiration time. */
68     SIGSUBPKT_EXPORTABLE    =  4, /* Exportable. */
69     SIGSUBPKT_TRUST         =  5, /* Trust signature. */
70     SIGSUBPKT_REGEXP        =  6, /* Regular expression. */
71     SIGSUBPKT_REVOCABLE     =  7, /* Revocable. */
72     SIGSUBPKT_KEY_EXPIRE    =  9, /* Key expiration time. */
73     SIGSUBPKT_ARR           = 10, /* Additional recipient request. */
74     SIGSUBPKT_PREF_SYM      = 11, /* Preferred symmetric algorithms. */
75     SIGSUBPKT_REV_KEY       = 12, /* Revocation key. */
76     SIGSUBPKT_ISSUER        = 16, /* Issuer key ID. */
77     SIGSUBPKT_NOTATION      = 20, /* Notation data. */
78     SIGSUBPKT_PREF_HASH     = 21, /* Preferred hash algorithms. */
79     SIGSUBPKT_PREF_COMPR    = 22, /* Preferred compression algorithms. */
80     SIGSUBPKT_KS_FLAGS      = 23, /* Key server preferences. */
81     SIGSUBPKT_PREF_KS       = 24, /* Preferred key server. */
82     SIGSUBPKT_PRIMARY_UID   = 25, /* Primary user id. */
83     SIGSUBPKT_POLICY        = 26, /* Policy URL. */
84     SIGSUBPKT_KEY_FLAGS     = 27, /* Key flags. */
85     SIGSUBPKT_SIGNERS_UID   = 28, /* Signer's user id. */
86     SIGSUBPKT_REVOC_REASON  = 29, /* Reason for revocation. */
87     SIGSUBPKT_FEATURES      = 30, /* Feature flags. */
88
89     SIGSUBPKT_SIGNATURE     = 32, /* Embedded signature. */
90
91     SIGSUBPKT_FLAG_CRITICAL = 128
92   }
93 sigsubpkttype_t;
94
95
96 typedef enum
97   {
98     CIPHER_ALGO_NONE        =  0,
99     CIPHER_ALGO_IDEA        =  1,
100     CIPHER_ALGO_3DES        =  2,
101     CIPHER_ALGO_CAST5       =  3,
102     CIPHER_ALGO_BLOWFISH    =  4, /* 128 bit */
103     /* 5 & 6 are reserved */
104     CIPHER_ALGO_AES         =  7,
105     CIPHER_ALGO_AES192      =  8,
106     CIPHER_ALGO_AES256      =  9,
107     CIPHER_ALGO_TWOFISH     = 10, /* 256 bit */
108     CIPHER_ALGO_CAMELLIA128 = 11,
109     CIPHER_ALGO_CAMELLIA192 = 12,
110     CIPHER_ALGO_CAMELLIA256 = 13
111   }
112 cipher_algo_t;
113
114
115 typedef enum
116   {
117     PUBKEY_ALGO_RSA         =  1,
118     PUBKEY_ALGO_RSA_E       =  2, /* RSA encrypt only (legacy). */
119     PUBKEY_ALGO_RSA_S       =  3, /* RSA sign only (legacy).    */
120     PUBKEY_ALGO_ELGAMAL_E   = 16, /* Elgamal encrypt only.      */
121     PUBKEY_ALGO_DSA         = 17,
122     PUBKEY_ALGO_ECDH        = 18, /* RFC-6637  */
123     PUBKEY_ALGO_ECDSA       = 19, /* RFC-6637  */
124     PUBKEY_ALGO_ELGAMAL     = 20, /* Elgamal encrypt+sign (legacy).  */
125
126     PUBKEY_ALGO_EDDSA      = 105  /* EdDSA (cf. Ed25519) (experimental). */
127   }
128 pubkey_algo_t;
129
130
131 typedef enum
132   {
133     DIGEST_ALGO_MD5         =  1,
134     DIGEST_ALGO_SHA1        =  2,
135     DIGEST_ALGO_RMD160      =  3,
136     /* 4, 5, 6, and 7 are reserved. */
137     DIGEST_ALGO_SHA256      =  8,
138     DIGEST_ALGO_SHA384      =  9,
139     DIGEST_ALGO_SHA512      = 10,
140     DIGEST_ALGO_SHA224      = 11
141   }
142 digest_algo_t;
143
144
145 typedef enum
146   {
147     COMPRESS_ALGO_NONE      =  0,
148     COMPRESS_ALGO_ZIP       =  1,
149     COMPRESS_ALGO_ZLIB      =  2,
150     COMPRESS_ALGO_BZIP2     =  3
151   }
152 compress_algo_t;
153
154
155 #endif /*GNUPG_COMMON_OPENPGPDEFS_H*/