[UI] Encrypt passwords in db
[validation.git] / ui / README.rst
1
2 Akraino Blueprint Validation UI
3 ========
4
5 Introduction
6 ------------
7
8 This project contains the source code of the Akraino Blueprint Validation UI. It is based on the ONAP portal SDK, version 2.4.0. It should be noted that the copyright of all the files of the aforementioned project that were left intact, has not been changed.
9
10 This UI consists of the front-end and back-end parts.
11
12 The front-end part is based on HTML, CSS, and AngularJS technologies. The back-end part is based on Spring MVC and Apache Tomcat technologies.
13
14 Based on these instructions, a user can provide the prerequisites, compile the source code and deploy the UI.
15
16 Scope
17 -----
18
19 The blueprint validation UI aims to be hosted by LF servers and will be exposed using public IP and domain names.
20
21 It provides a user-friendly way for displaying blueprints validation test results. Based on these results, the status of a blueprint can be determined (mature, incubation state, etc.).
22
23 In specific, the purpose of the UI is twofold:
24
25 1) Support full control loop of producing results. In this mode, the UI must be connected with a Jenkins instance capable of running blueprint validation tests.
26    It will enable the user to define a blueprint for validation using its name, version, layer, desired lab and desired timeslot. This data constitutes a submission. It should be noted that the blueprint family is derived from the blueprint name.
27    Also, the UI will have the ability to track the lifecycle of a submission. A submission state can be one of the following: submitted, waiting, running and completed. The implementation vehicle for this action is the REST API of Jenkins.
28    Moreover, the UI must be connected with a mariadb instance and the Nexus server where the results are stored.
29    Then, it will be able to trigger the appropriate job in Jenkins and receive the corresponding results from Nexus.
30    Note that it makes no difference whether the Jenkins instance is the community one or a private one.
31 2) Partial control of producing results. In this mode, the UI must be connected with a mariadb instance and the Nexus server where the results are stored.
32    Every blueprint owner is responsible of executing tests and storing results in Nexus using his/her own Jenkins instance. The UI only retrieves results from Nexus and displays them.
33
34 In both modes, user authentication, authorization and accounting (AAA) will be supported in order to control access to resources, enforce policies on these resources and audit their usage.
35
36 Prerequisites:
37 ~~~~~~~~~~~~~~
38
39 In order for the blueprint validation UI to be functional, the following items are taken for granted:
40
41 - An appropriate mariadb instance is up and running (look at the Database subsection).
42   This prerequisite concerns both of the UI modes.
43
44 - The available labs and their silos (i.e. which silo is used by a lab in order to store results in Nexus) for blueprint validation execution are stored in mariadb (look at the Database subsection). It is the lab owner's responsibility to update them using the UI.
45   This prerequisite concerns both the partial and the full control loop modes.
46
47 - The available timeslots for blueprint validation execution of every lab are stored in the mariadb (look at the Database subsection). It is the lab owner's responsibility to update them using the UI.
48   This prerequisite concerns only the full control loop mode.
49
50 - The data of available blueprints (i.e. blueprint name) is stored in the mariadb database (look at the Database subsection). This data is automatically updated by the UI using info from Nexus. If a blueprint owner's is not satisfied with this info, he/her must update it using the UI.
51   This prerequisite concerns only the full control loop mode.
52
53 - The data of an available blueprint instance for validation (i.e. version and layer) is stored in the mariadb database (look at the Database subsection). This data is automatically updated by the UI using info from Nexus. If a blueprint owner's is not satisfied with this info, he/her must update it using the UI.
54   This prerequisite concerns only the full control loop mode.
55
56 - A Jenkins instance exists capable of executing blueprint validation tests on the specified lab and storing the results to Nexus server (look at the Jenkins configuration subsection).
57   Also, this data is updated using info from results fetched from Nexus. This prerequisite concerns only the full control loop mode.
58
59 - A Nexus server exists where all the blueprint validation results are stored (look at the Nexus subsection).
60   This prerequisite concerns both of the UI modes.
61
62 - The whole installation and deployment of a blueprint and its corresponding blueprint family components (i.e. the appropriate edge cloud stack with its combination of infrastructure hardware components, OS, K8s, software, etc) are already performed in the appropriate lab.
63   Recall that multiple labs can be used for a specific blueprint validation. Also, it is the responsibility of the blueprint submitter to ensure that the edge validation and community CI labs can support comprehensive validation of the blueprint and cover all use case characteristics.
64   This prerequisite concerns both of the UI modes.
65
66 Developer's guide
67 -----------------
68
69 Download the project
70 ~~~~~~~~~~~~~~~~~~~~
71
72 .. code-block:: console
73
74     git clone "https://gerrit.akraino.org/r/validation"
75
76 Prerequisites
77 ~~~~~~~~~~~~~
78
79 - Tools
80
81 In order to setup the development environment, the following tools are needed:
82 - JDK 1.8
83 - Maven
84 - docker
85 - MySQL client
86
87 Execute the commands below in order to install these tools (note that the PROXY_IP and PROXY_PORT variables must be substituted with the ones that are used by the hosting operating system)
88
89 If the host is behind a proxy, define this proxy using the following commands:
90
91 .. code-block:: console
92     sudo touch /etc/apt/apt.conf.d/proxy.conf
93     sudo sh -c 'echo "Acquire::http::proxy \"http://<PROXY_IP>:<PROXY_PORT>/\";" >> /etc/apt/apt.conf.d/proxy.conf'
94     sudo sh -c 'echo "Acquire::https::proxy \"https://<PROXY_IP>:<PROXY_PORT>/\";" >> /etc/apt/apt.conf.d/proxy.conf'
95     sudo sh -c 'echo "Acquire::ftp::proxy \"ftp://<PROXY_IP>:<PROXY_PORT>/\";" >> /etc/apt/apt.conf.d/proxy.conf'
96     sudo apt-get update
97     export http_proxy=http://<PROXY_IP>:<PROXY_PORT>
98     export https_proxy=http://<PROXY_IP>:<PROXY_PORT>
99
100 Install jdk and maven using the following commands:
101
102 .. code-block:: console
103     sudo apt install default-jdk
104     sudo apt install maven
105
106 If the host is behind a proxy, configure this proxy for maven:
107
108 .. code-block:: console
109     nano ~/.m2/settings.xml
110     <Paste the following lines>
111
112     <settings xmlns="http://maven.apache.org/SETTINGS/1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
113      <proxies>
114       <proxy>
115        <active>true</active>
116        <protocol>http</protocol>
117        <host><PROXY_IP></host>
118        <port><PROXY_PORT></port>
119        <nonProxyHosts>127.0.0.1|localhost</nonProxyHosts>
120       </proxy>
121       <proxy>
122        <id>https</id>
123        <active>true</active>
124        <protocol>https</protocol>
125        <host><PROXY_IP></host>
126        <port><PROXY_PORT></port>
127        <nonProxyHosts>127.0.0.1|localhost</nonProxyHosts>
128       </proxy>
129      </proxies>
130     </settings>
131
132     <Save and exit from nano>
133
134 Install docker using the following commands:
135
136 .. code-block:: console
137     sudo apt install docker.io
138     sudo groupadd docker
139     sudo gpasswd -a $USER docker
140     newgrp docker
141
142 If the host is behind a proxy, configure docker to use this proxy:
143
144 .. code-block:: console
145     mkdir /etc/systemd/system/docker.service.d
146     sudo nano /etc/systemd/system/docker.service.d/http-proxy.conf
147     <Paste the following lines>
148
149     [Service]
150     Environment="HTTP_PROXY=http://<PROXY_IP>:<PROXY_PORT>/"
151
152     <Save and exit from nano>
153
154     sudo systemctl daemon-reload
155     sudo systemctl restart docker
156
157 Install mySQL client:
158
159 .. code-block:: console
160     sudo apt install mysql-client
161
162 - Database
163
164 A mariadb database instance is needed for both modes of the UI with the appropriate databases and tables in order for the back-end system to store and retrieve data.
165
166 The pom.xml file supports the creation of an appropriate docker image for development purposes. The initialization scripts reside under the db-scripts directory.
167
168 Also, a script has been developed, namely validation/docker/mariadb/deploy.sh which easily deploys the container. This script accepts the following items as input parameters:
169
170 CONTAINER_NAME, name of the container, default value is akraino-validation-mariadb
171 MARIADB_ROOT_PASSWORD, the desired mariadb root user password, this variable is required
172 MARIADB_AKRAINO_PASSWORD, the desired mariadb akraino user password, this variable is required
173 UI_ADMIN_PASSWORD, the desired Blueprint Validation UI password for the admin user, this variable is required
174 UI_AKRAINO_PASSWORD, the desired Blueprint Validation UI password for the akraino user, this variable is required
175 REGISTRY, registry of the mariadb image, default value is akraino
176 NAME, name of the mariadb image, default value is validation
177 TAG_PRE, first part of the image version, default value is mariadb
178 TAG_VER, last part of the image version, default value is latest
179 MARIADB_HOST_PORT, port on which mariadb is exposed on host, default value is 3307
180 ENCRYPTION_KEY, the key that should be used by the AES algorithm for encrypting passwords stored in database, this variable is required
181
182 Currently, two users are supported by the UI, namely admin (full privileges) and akraino (limited privileges). Their passwords must be defined in the database.
183
184 In order to build and deploy the image using only the required parameters, the below instructions should be followed:
185
186 The mariadb root password, mariadb akraino user password (currently the UI connects to the database using the akraino user), the UI admin password and the UI akraino password should be configured using the appropriate variables and the following commands should be executed:
187
188 .. code-block:: console
189
190     cd validation/ui
191     mvn docker:build -Ddocker.filter=akraino/validation:dev-mariadb-latest
192     cd ../docker/mariadb
193     ./deploy.sh TAG_PRE=dev-mariadb MARIADB_ROOT_PASSWORD=<mariadb root user password> MARIADB_AKRAINO_PASSWORD=<mariadb akraino user password> UI_ADMIN_PASSWORD=<UI admin user password> UI_AKRAINO_PASSWORD=<UI akraino user password> ENCRYPTION_KEY=<encryption key>
194     mysql -p<MARIADB_AKRAINO_PASSWORD> -uakraino -h <IP of the mariadb container> < ../../ui/db-scripts/examples/initialize_db_example.sql
195
196 In order to retrieve the IP of the mariadb container, the following command should be executed:
197
198 .. code-block:: console
199
200     docker inspect <name of the mariadb container>
201
202 Furthermore, the TAG_PRE variable should be defined because the default value is 'mariadb' (note that the 'dev-mariadb' is used for development purposes - look at pom.xml file).
203
204 If the database must be re-deployed (it is assumed that the corresponding mariadb container has been stopped and deleted) while the persistent storage already exists (currently, the 'akraino-validation-mariadb' docker volume is used), a different approach should be used after the image building process.
205
206 To this end, another script has been developed, namely validation/docker/mariadb/deploy_with_existing_storage.sh which easily deploys the container. This script accepts the following as input parameters:
207
208 CONTAINER_NAME, the name of the container, default value is akraino-validation-mariadb
209 REGISTRY, the registry of the mariadb image, default value is akraino
210 NAME, the name of the mariadb image, default value is validation
211 TAG_PRE, the first part of the image version, default value is mariadb
212 TAG_VER, the last part of the image version, default value is latest
213 MARIADB_HOST_PORT, the port on which mariadb is exposed on host, default value is 3307
214
215 In order to deploy the image using only the required parameters and the existing persistent storage, the below instructions should be followed:
216
217 The mariadb root user password should be configured using the appropriate variable and the following commands should be executed:
218
219 .. code-block:: console
220
221     cd validation/docker/mariadb
222     ./deploy_with_existing_persistent_storage.sh TAG_PRE=dev-mariadb
223
224 Finally, if the database must be re-deployed (it is assumed that the corresponding mariadb container has been stopped and deleted) and the old persistent storage must be deleted, the used docker volume should be first deleted (note that all database's data will be lost).
225
226 To this end, after the image build process, the following commands should be executed:
227
228 .. code-block:: console
229
230     docker volume rm akraino-validation-mariadb
231     cd validation/docker/mariadb
232     ./deploy.sh TAG_PRE=dev-mariadb MARIADB_ROOT_PASSWORD=<root user password> MARIADB_AKRAINO_PASSWORD=<mariadb akraino user password> UI_ADMIN_PASSWORD=<UI admin user password> UI_AKRAINO_PASSWORD=<UI akraino user password>
233     mysql -p<MARIADB_AKRAINO_PASSWORD> -uakraino -h <IP of the mariadb container> < ../../ui/db-scripts/examples/initialize_db_example.sql
234
235 In the context of the UI application, the following tables exist in the database:
236
237 - lab (here, every lab owner should store the name of the lab and the silo used for storing results in Nexus)
238 - timeslot (here, every lab owner should register the available timeslots that can be used for blueprint validation test execution)
239 - blueprint_layer (here, all the blueprint layers should be registered. These layers will be referenced by the blueprint instances)
240 - blueprint (here, every blueprint owner should register the name of the blueprint)
241 - blueprint_instance_for_validation (here, every blueprint owner should register the blueprint instances for validation, i.e. version and layer)
242 - blueprint_instance_blueprint_layer (here, the many-to-many relationship between blueprint instances and layers is formulated)
243 - blueprint_instance_timeslot (here, the many-to-many relationship between blueprint instances and timeslots is formulated)
244
245 As it has been already mentioned, a user can perform CRUD operations on these tables using the UI. Also, all these tables except from lab and timeslot are initialized and updated automatically
246 by the UI by fetching data from Nexus. It is the lab owners responsibility to update them if a modifications is needed (especially the data related to lab and timeslot tables).
247
248 An example of data initialization is stored in the following file:
249
250     db-scripts/examples/initialize_db_example.sql
251
252 That is the reason why the command 'mysql -p<MARIADB_AKRAINO_PASSWORD> -uakraino -h <IP of the mariadb container> < ../../ui/db-scripts/examples/initialize_db_example.sql' has been used previously.
253
254 Some of this data is illustrated below:
255
256 .. code-block:: console
257
258     Labs:
259     id:1, lab:'att', silo:'att-blu-val'
260
261     Timeslots:
262     id:1 , start date and time: 'now', duration: null, lab: 1
263
264     Blueprint layers:
265     id:1, layer: 'hardware';
266
267     Blueprints:
268     id: 2 , blueprint_name : 'rec'
269
270     Blueprint Instances:
271     id: 2, blueprint_id: 2 (i.e. rec), version: "master"
272
273     blueprint_instances_blueprint_layers
274     blueprint_id: 2 (i.e. rec), layer_id: 1 (i.e. hardware)
275
276     blueprint_instances_timeslots
277     blueprint_instance_id: 2 (i.e. rec), timeslot_id: 1 (i.e. now in att lab)
278
279 It should be noted that currently the start date and time and the duration of the timeslot are not taken into account by the UI (see limitation section). Therefore, a user should define 'now' and null respectively for their content.
280
281 Based on this data, the UI enables the user to select an appropriate blueprint instance for validation.
282
283 In the following lines it is explained how a user can update database using the mysql tool. However, it is advised that UI should be used for this purpose as it supports a more user-friendly way.
284
285 For example, if a user wants to define a new lab with the following data:
286
287     lab: community, silo : 'community'
288
289 the following file should be created:
290
291 name: dbscript
292 content:
293     SET FOREIGN_KEY_CHECKS=1;
294     use akraino;
295     insert into lab (id, lab, silo) values(2, 'community', 'community');
296
297 Then, the following command should be executed:
298
299 .. code-block:: console
300
301     mysql -p<MARIADB_AKRAINO_PASSWORD> -uakraino -h <IP of the mariadb container> < ./dbscript.sql
302
303 For example, if a user wants to define a new timeslot with the following data:
304
305     start date and time:'now', duration: 0, lab: AT&T
306
307 the following file should be created:
308
309 name: dbscript
310 content:
311     SET FOREIGN_KEY_CHECKS=1;
312     use akraino;
313     insert into timeslot values(2, 'now', null, 2);
314
315 2 is the id of the community lab.
316
317 Then, the following command should be executed:
318
319 .. code-block:: console
320
321     mysql -p<MARIADB_AKRAINO_PASSWORD> -uakraino -h <IP of the mariadb container> < ./dbscript.sql
322
323 Furthermore, if a user wants to define a new blueprint, namely "newBlueprint", and an instance of this blueprint with version "master" and layer "k8s" and assign a timeslot to it, the following file should be created:
324
325 name: dbscript
326 content:
327     SET FOREIGN_KEY_CHECKS=1;
328     use akraino;
329     insert into blueprint (id, blueprint_name) values(3, 'newBlueprint');
330     insert into blueprint_instance (id, blueprint_id, version) values(3, 3, 'master');
331     insert into blueprint_layer (id, layer) values(4, 'k8s');
332     insert into blueprint_instance_blueprint_layer (blueprint_instance_id, blueprint_layer_id) values(3, 4);
333     insert into blueprint_instance_timeslot (blueprint_instance_id, timeslot_id) values(3, 2);
334
335 Then, the following command should be executed:
336
337 .. code-block:: console
338
339     mysql -p<MARIADB_AKRAINO_PASSWORD> -uakraino -h <IP of the mariadb container> < ./dbscript.sql
340
341 The UI will automatically retrieve this new data and display it to the user.
342
343 - Jenkins Configuration
344
345 Recall that for full control loop, a Jenkins instance is needed capable of executing blueprint validation tests to the specified lab. The Blueprint validation UI will trigger job executions in that instance.
346
347 It should be noted that it is not the UI responsibility to deploy a Jenkins instance.
348
349 Furthermore, this instance must have the following option enabled: "Manage Jenkins -> Configure Global Security -> Prevent Cross Site Request Forgery exploits".
350
351 Also, currently, the corresponding Jenkins job should accept the following as input parameters: "SUBMISSION_ID", "BLUEPRINT", "VERSION", "LAYER", "OPTIONAL", "LAB" and "UI_IP".
352 The "SUBMISSION_ID" and "UI_IP" parameters (i.e. IP address of the UI host machine-this is needed by the Jenkins instance in order to send back Job completion notification) are created and provided by the back-end part of the UI.
353 The "BLUEPRINT", "VERSION", "LAYER" and "LAB" parameters are configured by the UI user. The parameter "OPTIONAL" defines whether the optional test cases should be included or not.
354
355 Moreover, as the Jenkins notification plugin (https://wiki.jenkins.io/display/JENKINS/Notification+Plugin) seems to ignore proxy settings, the corresponding Jenkins job must be configured to execute the following commands at the end (Post-build Actions)
356
357 TBD
358
359 - Nexus server
360
361 All the blueprint validation results are stored in Nexus server for both modes of the UI.
362
363 It should be noted that it is not the UI responsibility to deploy a Nexus server.
364
365 These results must be available in the following url:
366
367     https://nexus.akraino.org/content/sites/logs/<lab_silo>/bluval_results/<Blueprint name>/<Blueprint version>/<timestamp>/results/<layer>/<name_of_the_test_suite>
368
369 where <lab_silo> is the silo used by a lab for storing results in Nexus (for example 'att-blu-val'), <Blueprint name> is the name of the blueprint, <Blueprint version> the the blueprint version, <timestamp> is the timestamp used for producinf the results, <layer> is the blueprint layer and <name_of_the_test_suite> is the name of the corresponding test suite.
370
371 Below, an example URL is illustrated
372
373    https://nexus.akraino.org/content/sites/logs/att-blu-val/bluval_results/rec/master/20190611-132818/results/hardware/bios_version/
374
375 Moreover, the results should be stored in the 'output.xml' file and placed in the aforementioned URL.
376
377 Compiling
378 ~~~~~~~~~
379
380 .. code-block:: console
381
382     cd validation/ui
383     mvn clean package
384
385 Deploying
386 ~~~~~~~~~
387
388 The pom.xml file supports the building of an appropriate container image using the produced war file.
389
390 In order to build the image, the following commands should be executed:
391
392 .. code-block:: console
393
394     cd validation/ui
395     mvn docker:build -Ddocker.filter=akraino/validation:dev-ui-latest
396
397 Also, a script has been developed, namely validation/docker/ui/deploy.sh which easily deploys the container. This script accepts the following as input parameters:
398
399 CONTAINER_NAME, the name of the contaner, default value is akraino-validation-ui
400 DB_IP_PORT, the IP and port of the maridb instance, this variable is required
401 MARIADB_AKRAINO_PASSWORD, the mariadb akraino user password, this variable is required
402 REGISTRY, the registry of the mariadb image, default value is akraino
403 NAME, the name of the mariadb image, default value is validation
404 TAG_PRE, the first part of the image version, default value is ui
405 TAG_VER, the last part of the image version, default value is latest
406 JENKINS_URL, the URL of the Jenkins instance (http or https must be defined), the default value is 'https://jenkins.akraino.org/'
407 JENKINS_USERNAME, the Jenkins user name, the default value is 'demo' (in the context of UI full control loop mode, this parameter must be changed to include a real Jenkins user)
408 JENKINS_USER_PASSWORD, the Jenkins user password, the default value is 'demo' (in the context of UI full control loop mode, this parameter must be changed to include a real Jenkins user password)
409 JENKINS_JOB_NAME, the name of Jenkins job capable of executing the blueprint validation tests, the default value is 'validation' (in the context of UI full control loop mode, this parameter must be changed to include a real Jenkins job name)
410 NEXUS_PROXY, the needed proxy in order for the Nexus server to be reachable, default value is none
411 JENKINS_PROXY, the needed proxy in order for the Jenkins server to be reachable, default value is none
412 CERTDIR, the directory where the SSL certificates can be found, default value is the working directory where self signed certificates exist only for demo purposes
413 ENCRYPTION_KEY, the key that should be used by the AES algorithm for encrypting passwords stored in database, this variable is required
414
415 So, for a functional UI, the following prerequisites are needed:
416
417 - The mariadb container in up and running state
418 - A Jenkins instance capable of running the blueprint validation test (this is optional and is needed only for UI full control loop mode)
419 - A Nexus repo in which all the test results are stored.
420
421 Then, the following commands can be executed in order to deploy the UI container:
422
423 .. code-block:: console
424     cd ../docker/ui
425     ./deploy.sh TAG_PRE=dev-ui DB_IP_PORT=<IP and port of the mariadb> MARIADB_AKRAINO_PASSWORD=<mariadb akraino password> ENCRYPTION_KEY=<encryption key>
426
427 The content of the DB_IP_PORT can be for example '172.17.0.3:3306'. Also, the value of the encryption key should be the same as the value of the encryption key used in database deployment.
428
429 Furthermore, the TAG_PRE variable should be defined as the default value is 'ui' (note that the 'dev-ui' is used for development purposes - look at pom.xml file).
430
431 If no proxy exists, the proxy ip and port variables should not be defined.
432
433 The UI should be available in the following url:
434
435     https://<IP of UI container>:8443/bluvalui/
436
437 Note that the deployment uses the network host mode, so the ports 8080 and 8443 must be available on the host.
438
439 As far as the SSL certificates are concerned, self-signed built-in certificates exist in the 'validation/docker/ui' directory which are used by default. It should be noted that these
440 certificates should be used only for demo purposes. If a user wants to use different ones which are more appropriate for a production environment, the directory that contains these new
441 certificates must be defined using the 'CERTDIR' parameter of the 'validation/docker/ui/deploy.sh' script. It should be noted that the certificates must have specific names, that are 'bluval.crt'
442 and 'bluval.key' for the certificate and the key respectively.
443
444 User's guide
445 -----------------
446 TBD
447
448 Limitations
449 -----------
450 - The UI has been tested using Chrome and Firefox browsers.
451 - The back-end part of the UI does not take into account the start date and time and duration of the configured timeslot. It immediately triggers the corresponding Jenkins Job.