The config file follows a format that is similar to the format required by the Service Manager/CAPIFcore Publisher.
At the end of the Kubernetes deployment, following script runs automatically.
servicemanager-preload.sh [config.yaml]
where [config.yaml] is a config file. If this arguement is not specified, the default is config.yaml. The input file is expected to be in the same directory as the servicemanager-preload.sh
script. You can call the command without arguements as below.
In our installation we provide 2 config files, config-nonrtric.yaml
and config-smo.yaml
. The file config-nonrtric.yaml
is used by both the NONRTRIC install and SMO installs. For the SMO install we concatate both files into a file called config-nonrtric-smo.yaml
and use that. This file is deleted after use in the installation script. We do it this way to avoid duplicating the information in config-nonrtric.yaml
.
kubectl get service
for both the nonrtric and onap namespaces.running_services_list
.running_services_list
, we build a payload from the entries for that YAML item.To distinguish between multiple interface descriptions, Service Manager prepends the port number and a hash code to the URL path.
We can specify either static or dynamic routes. Static routing defines a route when there is a single route for traffic to reach a destination. Dynamic routing allows us to specify path parameters. In this config file, we specify path parameters using regular expressions.
Kong uses the regex definition from the Rust programming language to specify the regular expression (regex) that describes the path parameters, Kong regex.
An example of a static path is as follows. This is the straightforward case.
/rapps
An example of a dynamic path is
~/rapps/(?<rappId>[a-zA-Z0-9]+([-_][a-zA-Z0-9]+)*)
Our dynamic path starts with a ~ character. In this example, we have a path parameter that is described by a regex capture group called rappId. The regex describes a word made of mixed-case alphanumeric characters optionally followed by one or more sets of a dash or underscore together with another word.
When the Service Manager client calls a dynamic API, it must strip the ~ and substitute the path parameter according to the rules specified in the regex. Therefore, we can call the above example by using
/rapps/my-rApp-id
as the URL where my-rApp-id is the rApp id of in the rApp Manager. The name my-rApp-id has to match the regex shown above.
It is required to name the capture group in this YAML config file. The capture group name is used by Service Manager when creating a Kong Request Transformerplugin. We can specify multiple capture groups in a URL if there are multiple path parameters in the API path.
We create a Kong Request Transformer plugin with the following .data[].config.replace, as in the following example curl and abridged response.
curl -X GET http://oran-nonrtric-kong-admin.nonrtric.svc.cluster.local:8001/plugins
{ "body": [], "uri": "/rapps/$(uri_captures[\"rappId\"])", "headers": [], "querystring": [] }
In our example, this allows Kong to match /rapps/my-rApp-id.
The Service Manager uses the following regex to search and replace the YAML file regexes.
/\(\?<([^>]+)>([^\/]+)/
Please note that the example path, /rapps/my-rApp-id, is not terminated by a '/'. Service Manager adds a '/' for internal matching. This made the regex easier to develop. Service Manager will match on /rapps/my-rApp-id/ for this case.