blob: 44dfe05306adb316a03ea3ca1c05077757fd9574 [file] [log] [blame]
DarraghEgan3f423112019-05-15 12:44:12 +00001.. This work is licensed under a Creative Commons Attribution 4.0 International License.
2.. http://creativecommons.org/licenses/by/4.0
3
4============================================================
5Installing Keys and Certificates in ODL for NETCONF over TLS
6============================================================
7
8The purpose of this document is to help you with the setup needed for the installation of xNF keys and certificates inside of OpenDaylight(ODL) in SDNC.
9
10To use NETCONF over TLS, ODL needs to be configured with Keys and Certificates to use for TLS connections.
11
12Preparing Required Key and Certificate Files
13============================================
14
15The first step to adding the keys and certificates for ODL is to have configured a zip file made up of your keys and certificates that ODL needs.
16
17There are three files required in the zip file and those are:
18 1. client.crt
19 2. client.key
20 3. trustedCertificates.crt which contains a list of trusted certificates - normally one or more CA or sub-CA certificates, or xNF self-signed certificate(s) for testing only
21
22Client.crt represents the client certificate and the client.key is the private key that is to be used.
23Only a single client/client cert is supported as of the Dublin release and multiple clients are not supported.
24
25These files will all be needed when configuring ODLs private key, own certificate and trusted certificates.
26
27An example of the three required files that are needed in the zip folder can be seen in the screenshots below:
28
29
30 .. image:: images/client_certificate.png
31 :align: center
32
33
34 .. image:: images/client_key.png
35 :align: center
36
37
38 .. image:: images/trusted_certificate.png
39 :align: center
40
41
42
43Once you have these three files created you need to create a zip file from these files.
44You will then have to add the name of this zip file to a file called certs.properties file.
45You should use the naming convention keys<IncrementedNumber>.zip that is used in the screenshot below and that between each zip file there is a new line with \*****” between each zip file.
46Since the Dublin release only supports a single client this means that there should be only one zip file present.
47
48Below is an image of how the certs.properties files should be written:
49
50 .. image:: images/certs_properties.png
51
52
53
54How to Install Certs and Keys when deploying SDNC/ODL with OOM in K8s environment
55=================================================================================
56
57At setup time, you will need to place the zip file along with the certs.properties file in the following file path:
58 */docker-data/sdnc/certs/*
59
60Placing the files in this location will ensure that your files are mounted into the SDNC container at run time in the /tmp folder.
61
62If you are running in a Kubernetes container and would like to edit the default mount path you need to go to the following path:
63 *oom/kubernetes/sdnc/values.yaml*
64
65
66If you have your zip file and the certs.properties file set up correctly at setup-time, these RPC’s will automatically be called from the installCerts.py file and your keys and certificates will be added to the ODL keystore for you.
67
68The last step that is needed once you have your zip file and certs.properties file in the correct folder you need to run the following command to deploy ONAP:
69
70.. code-block:: bash
71
72 helm deploy dev local/onap -f /root/oom/kubernetes/onap/resources/environments/public-cloud.yaml -f /root/integration-override.yaml --namespace onap --verbose
73
74Or if you do not want to deploy the full ONAP but just SDNC container run:
75
76.. code-block:: bash
77
78 helm upgrade -i dev-sdnc <path to sdnc chart> --namespace onap -f <path to global override> -f <path to sdnc sub chart>
79
80Example of this full command is:
81
82.. code-block:: bash
83
84 helm upgrade -i dev-sdnc /root/.helm/plugins/deploy/cache/onap-subcharts/sdnc --namespace onap -f /root/.helm/plugins/deploy/cache/onap/global-overrides.yaml -f /root/.helm/plugins/deploy/cache/onap-subcharts/sdnc/subchart-overrides.yaml
85
86
87How to Install Certs and Keys when deploying SDNC/ODL with docker-compose
88=========================================================================
89
90If you want to do a local installation of SDNC/ODL with docker-compose you need to first download the OAM repo from the gerrit repo with the following URL.
91
92 *git clone https://gerrit.onap.org/r/sdnc/oam*
93
94Once you have this downloaded you need to go the following location.
95
96 */oam/installation/src/main/yaml*
97
98Once you are there you need to edit the docker-compose.yaml file to include your directory where you have the zip file and certs.properties located.
99
100You need to add in the following lines into the yaml file just below *container_name: sdnc_controller_container* in the file::
101
102 volumes:
103 - <Your_Workspace>:/opt/opendaylight/current/certs
104
105Once you have the mount path for your files added into the yaml file you can run the following command::
106
107 docker-compose up -d
108
109
110Clustering:
111=============
112
113For running a Kubernetes cluster using a pre-built SDNC image the keys and certificates only need to be placed on a single mount point and not put on each image individually as the keys and certificates will be replicated across all instances in the cluster.
114
115To get your Kubernetes running in a cluster, you need to SSH into your Rancher machine that your pods are running on and go to the directory:
116
117 */root/oom/kubernetes/sdnc/*
118
119In this directory you will find the values.yaml file which is the one you will need to edit. You need to find the variable *replicaCount* which is the default number of instances and change that value to 3 for clustering and also look for config: enableClustering and ensure that it is set to true.
120
121Once this is edited you will need to stop the SDNC container with the command:
122
123.. code-block:: bash
124
125 helm delete --purge dev-sdnc
126
127 make all
128
129 helm upgrade -i dev-sdnc /root/oom/kubernetes/sdnc --namespace onap -f /root/.helm/plugins/deploy/cache/onap/global-overrides.yaml -f /root/.helm/plugins/deploy/cache/onap-subcharts/sdnc/subchart-overrides.yaml
130
131
132EXAMPLE: Mounting pnf-simulator
133===============================
134
135If you want to mount a pnf-simulator onto the SDNC container the you must have the pnf-simulator container up and running and the SDNC container running with the keys and certificates in the ODL keystore.
136
137To mount your pnf-simulator you must send the following RPC:
138 *PUT /restconf/config/network-topology:network-topology/topology/topology-netconf/node/pnf-simulator*
139
140
141You must also send this as the body of the request::
142
143 <node xmlns="urn:TBD:params:xml:ns:yang:network-topology">
144 <node-id>pnf-simulator</node-id>
145 <key-based xmlns="urn:opendaylight:netconf-node-topology">
146 <key-id xmlns="urn:opendaylight:netconf-node-topology">ODL_private_key_0</key-id>
147 <username xmlns="urn:opendaylight:netconf-node-topology">netconf</username>
148 </key-based>
149 <host xmlns="urn:opendaylight:netconf-node-topology">IP-ADDRESS</ip-address></host>
150 <port xmlns="urn:opendaylight:netconf-node-topology">6513</port>
151 <tcp-only xmlns="urn:opendaylight:netconf-node-topology">false</tcp-only>
152 <protocol xmlns="urn:opendaylight:netconf-node-topology">
153 <name xmlns="urn:opendaylight:netconf-node-topology">TLS</name>
154 </protocol>
155 <max-connection-attempts xmlns="urn:opendaylight:netconf-node-topology">2</max-connection-attempts>
156 </node>
157
158
egernugf417c2a2020-06-18 14:55:41 +0100159where IP-ADDRESS is the ip-address you are trying to mount the pnf-simulator on.
160
161
162
163
164New secure communication functionality
165=================================================================================
166
167In order to ensure secure communication on southband interface a new functionality have been introduced. The Certificate Management Protocol ver. 2 (CMPv2) is handled by the AAF microservice CertService.
168
169SDNC is capable of obtaining certificates signed by an external Certificate Authority to secure external ONAP communication.
170
171Confirmation of this functionality can be performed in OOM using the Contrib projects EJBCA service.
172
173Firstly, CertService will need to be deployed. This will require the global flag *global.cmpv2Enabled* to be set to true in *kubernetes/onap/resources/overrides/aaf-cert-service-environment.yaml*
174
egernug4537e7e2020-11-18 13:07:26 +0000175There is also an additional module that will need to be deployed named platform. This is required for secret creation.
176
egernugf417c2a2020-06-18 14:55:41 +0100177To deploy the EJBCA server the global flag *global.addTestingComponents* in *kubernetes/onap/values.yaml* will need to be set to true. This flag will load the test configuration from *kubernetes/aaf/charts/aaf-cert-service/resources/test/cmpServers.json*
178
179
180
181cmpServers.json:
182
183.. code-block:: json
184
185 {
186 "cmpv2Servers": [
187 {
188 "caName": "Client",
189 "url": "http://aafcert-ejbca:8080/ejbca/publicweb/cmp/cmp",
190 "issuerDN": "CN=ManagementCA",
191 "caMode": "CLIENT",
192 "authentication": {
193 "iak": "mypassword",
194 "rv": "mypassword"
195 }
196 },
197 {
198 "caName": "RA",
199 "url": "http://aafcert-ejbca:8080/ejbca/publicweb/cmp/cmpRA",
200 "issuerDN": "CN=ManagementCA",
201 "caMode": "RA",
202 "authentication": {
203 "iak": "mypassword",
204 "rv": "mypassword"
205 }
206 }
207 ]
208 }
209
210
211
212SDNC invokes the CertService in a new initContainer called certs-init.
213
214There are a number of variables used that can be configured and these are available in *kubernetes/onap/values.yaml* under aaf/certServiceClient
215
216
217
218CertService configuration:
219
220.. code-block:: yaml
221
222 aaf:
223 certServiceClient:
224 image: onap/org.onap.aaf.certservice.aaf-certservice-client:1.0.0
225 secret:
226 name: aaf-cert-service-client-tls-secret
227 mountPath: /etc/onap/aaf/certservice/certs/
228 envVariables:
229 # Certificate related
230 cmpv2Organization: "Linux-Foundation"
231 cmpv2OrganizationalUnit: "ONAP"
232 cmpv2Location: "San-Francisco"
233 cmpv2State: "California"
234 cmpv2Country: "US"
235 # Client configuration related
236 caName: "RA"
237 requestURL: "https://aaf-cert-service:8443/v1/certificate/"
238 requestTimeout: "20000"
239 keystorePath: "/etc/onap/aaf/certservice/certs/certServiceClient-keystore.jks"
240 keystorePassword: "secret"
241 truststorePath: "/etc/onap/aaf/certservice/certs/truststore.jks"
242 truststorePassword: "secret"
243
244
245
246
247For more information:
248
249+------------------------------------------------------------------------------------------+
250|https://onap-doc.readthedocs.io/en/latest/submodules/aaf/certservice.git/docs/index.html |
251+------------------------------------------------------------------------------------------+
252|https://doc.primekey.com/ejbca |
253+------------------------------------------------------------------------------------------+
254
DarraghEgan3f423112019-05-15 12:44:12 +0000255
256
257
258APPENDIX:
259===========
260
261ODL Commands
262~~~~~~~~~~~~~
263There are three RPC’s needed to configure the keys and certificates for TLS and these are:
264
265 1. “add-keystore-entry”
266 2. “add-private-keys”
267 3. “add-trusted-certificate”
268
269These three commands will be implemented by scripts in the SDNC container so these will all be implemented automatically.
270
271add-keystore-entry
272-----------------------------
273This is used to add the client private key from the xNF and a key-id to ODL’s TLS keystore. This is triggered with a POST command on ODL’s keystore operations.
274
275The “private-key” data is taken form the client.key file.
276
277add-private-keys
278---------------------------
279This is used to associate the private key with the client certificate and CA from the xNF and add it to the ODL keystore.
280
281
282add-trusted-certificate
283-------------------------------------
284This is used to add the list of CA’s and server certificates from the xnf as trusted certificates. The trustedCertificates.crt file is needed for this action as it contains the list of CA’s.
285
286
287Checking Correct Certs Installation
288~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
289If you would like to run a check to make sure that your keys and certificates were installed correctly in ODL you can run the following command in Postman REST client:
290 *GET http://localhost:8282/restconf/config/netconf-keystore:keystore*
291
292The authorization that is needed to gain access to ODL’s restconf interface is the default SDNC username and password.
293
294You should get a response back which looks like the screenshot below:
295
296 .. image:: images/get_keystore.png
297
298
299
300
301
302
303ODL APIs:
304--------------
305
306The ODL features that are installed by the SDNC script are:
307
308 **odl-restconf-all**
309
310 **odl-mdsal-all**
311
312 **odl-netconf-topology**
313
314When we are using a clustered topology some of these features are replaced by other features.
315 **odl-netconf-clustered-topology** replaces **odl-netconf-topology** as these two features cannot be installed together as it will break ODL.
316
317 **odl-mdsal-clustering** also gets installed.