aboutsummaryrefslogtreecommitdiff
path: root/docs/nng_tls_config_key.adoc
blob: 69e33fea857b46c21633b5f2d851a11e8855f250 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
nng_tls_config_key(3)
=====================
:doctype: manpage
:manmanual: nng
:mansource: nng
:manvolnum: 3
:icons: font
:source-highlighter: pygments
:copyright: Copyright 2018 Staysail Systems, Inc. <info@staysail.tech> \
            Copyright 2018 Capitar IT Group BV <info@capitar.com> \
            This software is supplied under the terms of the MIT License, a \
            copy of which should be located in the distribution where this \
            file was obtained (LICENSE.txt).  A copy of the license may also \
            be found online at https://opensource.org/licenses/MIT.

NAME
----
nng_tls_config_key - configure certificate authority certificate chain

SYNOPSIS
--------

[source, c]
-----------
#include <nng/nng.h>

int nng_tls_config_key(nni_tls_config *cfg, const uint8_t *key, size_t size)
-----------

DESCRIPTION
-----------

The `nng_tls_config_key()` function configures a private  'key' to be used
along with a certificate established with
<<nng_tls_config_cert#,nng_tls_config_cert(3)>>, for the given configuration
'cfg'.

This function should be called immediately after `nng_tls_config_cert()`,
with the appropriate private key.

The 'key' may be in either https://tools.ietf.org/html/rfc7468[PEM] or DER
format.  When the 'chain' is
in PEM format, the key will be ASCII encoded. A certificate may be present
as well.  The value of 'size' corresponds to the PEM encoding, not including
any terminating NUL byte.

When using DER encoding, the 'size' will be the total number of bytes, after
encoding.

The key material may be encrypted with a password, which can be supplied
using the <<nng_tls_config_pass#,nng_tls_config_pass(3)>> function.

RETURN VALUES
-------------

This function returns 0 on success, and non-zero otherwise.

ERRORS
------

`NNG_ENOMEM`:: Insufficient memory is available.
`NNG_EBUSY`:: The configuration 'cfg' is already in use, and cannot be modified.
`NNG_EINVAL`:: An invalid 'key' or 'size' was supplied.

SEE ALSO
--------

<<nng_strerror#,nng_strerror(3)>>,
<<nng_tls_config_alloc#,nng_tls_config_alloc(3)>>,
<<nng_tls_config_cert#,nng_tls_config_cert(3)>>,
<<nng_tls_config_pass#,nng_tls_config_pass(3)>>,
<<nng#,nng(7)>>


COPYRIGHT
---------

Copyright 2018 mailto:info@staysail.tech[Staysail Systems, Inc.] +
Copyright 2018 mailto:info@capitar.com[Capitar IT Group BV]

This document is supplied under the terms of the
https://opensource.org/licenses/MIT[MIT License].