1 .\" $NetBSD: libnetpgp.3,v 1.10 2009/12/14 23:29:56 agc Exp $
3 .\" Copyright (c) 2009 The NetBSD Foundation, Inc.
4 .\" All rights reserved.
6 .\" This manual page is derived from software contributed to The
7 .\" NetBSD Foundation by Alistair Crooks (agc@NetBSD.org)
9 .\" Redistribution and use in source and binary forms, with or without
10 .\" modification, are permitted provided that the following conditions
12 .\" 1. Redistributions of source code must retain the above copyright
13 .\" notice, this list of conditions and the following disclaimer.
14 .\" 2. Redistributions in binary form must reproduce the above copyright
15 .\" notice, this list of conditions and the following disclaimer in the
16 .\" documentation and/or other materials provided with the distribution.
18 .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
19 .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
20 .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
21 .\" PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
22 .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
23 .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
24 .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
25 .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
26 .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
27 .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
28 .\" POSSIBILITY OF SUCH DAMAGE.
35 .Nd digital signing and verification, encryption and decryption
41 The following functions relate to initialisations and finalisations:
44 .Fa "netpgp_t *netpgp" "char *userid" "char *pubringfile" "char *secringfile"
48 .Fa "netpgp_t *netpgp"
51 The following functions are for debugging, reflection and information:
54 .Fa "const char *filename"
58 .Fa "const char *filename"
62 .Fa "const char *type"
65 .Fo netpgp_list_packets
66 .Fa "netpgp_t *netpgp" "char *filename" "int armour" "char *pubringname"
69 The following functions are for variable management:
72 .Fa "netpgp_t *netpgp" "const char *name" "const char *value"
76 .Fa "netpgp_t *netpgp" "const char *name"
80 .Fa "netpgp_t *netpgp" "const char *name" "const int delta"
83 The following function sets the home directory:
85 .Fo netpgp_set_homedir
86 .Fa "netpgp_t *netpgp" "char *homedir" "char *subdir" "const int quiet"
89 The following functions are used for key management:
92 .Fa "netpgp_t *netpgp"
95 .Fo netpgp_match_list_keys
96 .Fa "netpgp_t *netpgp" "char *pattern"
100 .Fa "netpgp_t *netpgp" "char *userid"
104 .Fa "netpgp_t *netpgp" "const char *id"
107 .Fo netpgp_export_key
108 .Fa "netpgp_t *netpgp" "char *userid"
111 .Fo netpgp_import_key
112 .Fa "netpgp_t *netpgp" "char *file"
115 .Fo netpgp_generate_key
116 .Fa "netpgp_t *netpgp" "char *userid" "int numbits"
119 The following functions are used for file management:
121 .Fo netpgp_encrypt_file
122 .Fa "netpgp_t *netpgp" "char *userid" "char *filename" "char *out"
126 .Fo netpgp_decrypt_file
127 .Fa "netpgp_t *netpgp" "char *filename" "char *out" "int armored"
131 .Fa "netpgp_t *netpgp" "char *userid" "char *filename" "char *out"
132 .Fa "int armored" "int cleartext" "int detached"
135 .Fo netpgp_verify_file
136 .Fa "netpgp_t *netpgp" "char *f" "int armored"
139 The following functions are used for memory signing and encryption:
141 .Fo netpgp_encrypt_memory
142 .Fa "netpgp_t *netpgp" "char *userid" "void *in" "const size_t insize"
143 .Fa "char *out" "size_t outsize" "int armored"
146 .Fo netpgp_decrypt_memory
147 .Fa "netpgp_t *netpgp" "const void *input" "const size_t insize"
148 .Fa "char *out" "size_t outsize" "const int armored"
151 .Fo netpgp_sign_memory
152 .Fa "netpgp_t *netpgp" "const char *userid" "char *mem"
153 .Fa "size_t size" "char *out" "size_t outsize"
154 .Fa "const unsigned armored" "const unsigned cleartext"
157 .Fo netpgp_verify_memory
158 .Fa "netpgp_t *netpgp" "const void *in" "const size_t insize"
159 .Fa "void *out" "size_t outsize" "const int armored"
163 is a library interface to enable digital signatures to be created and
164 verified, and also for files and memory to be encrypted and decrypted.
165 Functions are also provided for management of user keys.
167 The library uses functions from the openssl library for multi-precision
168 integer arithmetic, and for RSA and DSA key signing and verification,
169 encryption and decryption.
171 Normal operation sees the
173 process be initialised using the
175 function, which will set up the public and private keyrings, and set the
178 argument passed to the function.
179 If no public key ring file is provided, initial values will be taken from those
181 .Pa .gnupg/pubring.gpg
182 file in the user's home directory.
183 Similarily, if no secret key ring file is provided,
184 initial values will be taken from those
186 .Pa .gnupg/secring.gpg
187 file in the user's home directory.
190 returns 1 on sucess, 0 on failure.
192 To list all the keys in a keyring, the
196 .Fn netpgp_match_list_keys
197 function is used to match (via regular expression)
198 a subset of the keys in the keyring.
199 If the expression to match is NULL,
200 the search will degenerate into a
201 listing of all keys in the keyring.
203 The home directory is specified as an internal variable,
204 and its existence is checked using the
205 .Fn netpgp_set_homedir
207 This function can operate in a verbose or quiet
208 manner, depending on the value of the argument provided.
209 If the subdirectory argument is provided, this subdirectory
210 is appended to the home directory in order to search for
214 .Fn netpgp_export_key
216 Output is sent to the standard output.
218 To import a key onto the public keyring, the
219 .Fn netpgp_import_key
221 The name of the file containing the key to be imported is provided
222 as the filename argument.
224 To generate a key, the
225 .Fn netpgp_generate_key
227 It takes an argument of the number of bits to use in the key.
228 At the time that this manual page was created (April 2009),
229 the recommendations are that the bare minimum key size
230 of at least 2048 bits is used, and it would be much better
231 to use at least 4096 or 8192 bits.
232 This situation should be monitored to ensure that it does
235 Encryption, decryption, signing and verification of
236 files are the lifeblood of the
239 To encrypt a file, the
240 .Fn netpgp_encrypt_file
242 .Fn netpgp_decrypt_file
243 is used to decrypt the results of the encryption.
246 is used, and the resulting signed file can be verified
248 .Fn netpgp_verify_file
251 .Fn netpgp_sign_memory
252 is a function which can sign an area
254 .Fn netpgp_verify_memory
255 verifies the digital signature produced.
257 Internally, an encrypted or signed file
260 which hold information pertaining to the signature,
261 encryption method, and the data which is being protected.
262 This information can be displayed in a verbose manner using
264 .Fn netpgp_list_packets
271 functions are used to manage the hash algorithm that
272 is used with RSA signatures.
273 These functions are general purpose functions, and
274 are used to set and retrieve values for internal variables.
276 can be used to set and to retrieve the
279 the home directory from which to find the keyrings,
280 the verbosity settings, and many more.
283 function is used to add a numeric increment to the
285 This incremental value can be negative.
286 It is primarily used to increase the verbosity settings.
290 files are encrypted using the public key of the userid.
291 The secret key is used to decrypt the results of that encryption.
292 Files are signed using the secret key of the userid.
293 The public key is used to verify that the file was signed,
294 who signed the file, and the date and time at which it was signed.
296 Some utility functions are also provided for debugging, and for
297 finding out version and maintainer information from calling programs.
302 functions (for getting verbose debugging information on a per-source
307 returns the information depending upon the
316 library first appeared in
321 .An Alistair Crooks Aq agc@NetBSD.org
322 wrote this high-level interface.
324 This manual page was written by
325 .An Alistair Crooks .