summaryrefslogtreecommitdiffstats
path: root/samples/tosca.yaml
blob: 4472f7ef8022abb515742193317437940b358d1f (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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
tosca_definitions_version:tosca_simple_yaml_1_0_0
description:
	This module defines a VNF Deployment Unit.
import:
	

metadata:
	 ID:clearwater
	 Vendor:HP
dsl_definitions:
	compute_props_host_ellis:&compute_props_host_ellis
	 	 num_cpu:4
		 mem_size:4096
	compute_props_host_bono:&compute_props_host_bono
	 	 num_cpu:3
		 mem_size:2048
node_types:
	tosca.nodes.compute.ellis:
		derived_from:tosca.nodes.compute

	tosca.nodes.compute.bono:
		derived_from:tosca.nodes.compute

topology_template:
		# a description of the topology template
		description:>
			Vdus used in a vnfd
	inputs:
		storage_size:
			type:scalar-unit.size
			default:2048
			description:The required storage resource
		storage_location:
			type:string
			description:>
				Block storage mount point (filesystem path).
	node_templates:
		ellis:
			type:tosca.nodes.Compute
			capabilities:
				os:
					properties:
						architecture:
						type:
						distribution:
						version:
				host:
					properties:*compute_props_host_ellis
				scalable:
					properties:
						min_instances:1
						default_instances:1
			requirements:
				- local_storage:
					node:ellis_BlockStorage
						relationship:
							type:AttachesTo
							properties:
								location:{ get_input:storage_location }
			interfaces:
				Standard:
					start:
						implementation:start.sh
					delete:
						implementaion:stop.sh
					stop:
						implementaion:shutdown.sh
		ellis_BlockStorage:
			type:tosca.nodes.BlockStorage
			properties:
				size:{ get_input:storage_size }
		bono:
			type:tosca.nodes.Compute
			capabilities:
				os:
					properties:
						architecture:
						type:
						distribution:
						version:
				host:
					properties:*compute_props_host_bono
				scalable:
					properties:
						min_instances:3
						default_instances:3
			requirements:
				- local_storage:
					node:bono_BlockStorage
						relationship:
							type:AttachesTo
							properties:
								location:{ get_input:storage_location }
			interfaces:
				Standard:
					start:
						implementation:start.sh
					delete:
						implementaion:stop.sh
					stop:
						implementaion:shutdown.sh
		bono_BlockStorage:
			type:tosca.nodes.BlockStorage
			properties:
				size:{ get_input:storage_size }
	clearwater_network1:
			type:tosca.nodes.network.Network
			properties:
			ip_version:4
	ellis_port1:
			type:tosca.nodes.network.Port
			requirements:
				- binding:
					node:ellis
				- link:
					 node:clearwater_network1
	clearwater_network2:
			type:tosca.nodes.network.Network
			properties:
			ip_version:4
	ellis_port2:
			type:tosca.nodes.network.Port
			requirements:
				- binding:
					node:ellis
				- link:
					 node:clearwater_network2
	clearwater_network1:
			type:tosca.nodes.network.Network
			properties:
			ip_version:4
	bono_port1:
			type:tosca.nodes.network.Port
			requirements:
				- binding:
					node:bono
				- link:
					 node:clearwater_network1
	clearwater_network2:
			type:tosca.nodes.network.Network
			properties:
			ip_version:4
	bono_port2:
			type:tosca.nodes.network.Port
			requirements:
				- binding:
					node:bono
				- link:
					 node:clearwater_network2
span> If you remember from above, each network has a "metadata" section, this matches the name of the variable $network_metadata. In that section there is a "vips" section, that contains a list of "vips", and one of the vips is "public", and one of the fields is "ipaddr". * [1] https://docs.mirantis.com/openstack/fuel/fuel-8.0/file-ref.html#fuel-file-reference-pages * [2] https://wiki.openstack.org/wiki/Fuel/Plugins ## The "Settings" section This looks like user interface stuff and default settings. For instance: settings: ``` editable: ... additional_components: ceilometer: description: If selected, Ceilometer component will be installed label: Install Ceilometer type: checkbox value: false weight: 40 ``` This is clearly the label "Install Ceilometer" in the Fuel web dashboard. This looks like an email label entry with the corresponding regex to validate it: ``` settings: editable: access: email: description: Email address for Administrator label: Email regex: error: Invalid email source: ^\S+@\S+$ type: text value: admin@localhost weight: 40 ... ``` ## Other I think most of it, specially the "settings" part, has been machine created. It would be nice to recreate one of this files from a manual Fuel deployment.