summaryrefslogtreecommitdiffstats
path: root/scripts/inventory.sh
blob: f7f217eedb659a3cd466d70a3d85d73df2eb84d8 (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
#!/bin/bash
# ================================================================================
# Copyright (c) 2020 AT&T Intellectual Property. All rights reserved.
# ================================================================================
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
# ============LICENSE_END=========================================================
#
# Functions for uploading blueprints to DCAE inventory

# Inventory API endpoint
INVENTORY=https://inventory:8080/dcae-service-types
#INVENTORY=https://localhost:8080/dcae-service-types

# Default fixed values in service type definition
OWNER=dcaeorch
COMPONENT=dcae
APPLICATION=DCAE

function flatten {
  # Convert a blueprint file into a flattened, escaped string
  # that can stored into a DCAE inventory "service type"
  # $1: path to blueprint file to be flattened

  FLAT=$(sed -e 's/\\/\\\\/g' -e 's/"/\\"/g' -e 's/$/\\n/g' < $1 | tr -d '\n')
  echo "${FLAT}"
}

function create_service_type {
  # Create a DCAE service type object (JSON),
  # suitable for uploading to DCAE inventory.
  # Use the name of the blueprint file (minus
  # the .yaml suffix) as the type name.
  # Use date-time (to the minute) in numeric
  # form as the type version.
  # $1: path to blueprint file for the service type
  echo "
   {
    \"vnfTypes\": [],
    \"owner\": \"${OWNER}\",
    \"typeVersion\": $(date +%y%m%d%I%M),
    \"typeName\": \"$(basename $1 .yaml)\",
    \"component\": \"${COMPONENT}\",
    \"application\": \"${APPLICATION}\",
    \"blueprintTemplate\": \"$(flatten $1)\"
   }"
}

function upload_service_type {
  # Transform a blueprint into a DCAE service type
  # and upload to DCAE inventory
  # $1: path to the blueprint
  # $2: path to CA cert file (optional)
  if [ "$2" ]
  then
     TLSCURL="--cacert $2"
  fi
  create_service_type $1 | \
  curl  $TLSCURL -X POST -H "Content-Type: application/json" -d @- ${INVENTORY}
}