summaryrefslogtreecommitdiffstats
path: root/docker/examples/blueprint-laika-policy.yaml
blob: d0a9c6852b3e0ad74e542b4e57de754661ed59ae (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
tosca_definitions_version: cloudify_dsl_1_3

description: >
  This Blueprint installs a chain of two laika instances on a Docker cluster

imports:
  - http://www.getcloudify.org/spec/cloudify/3.4/types.yaml
  - {{ ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2 }}/type_files/docker/2.3.0/node-type.yaml
  - {{ ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2 }}/type_files/relationship/1.0.0/node-type.yaml
  - {{ ONAPTEMPLATE_RAWREPOURL_org_onap_dcaegen2 }}/type_files/dcaepolicy/1.0.0/node-type.yaml

inputs:
  laika_image:
    type: string

  host_capacity_policy_id:
    type: string
    default: DCAE_alex.Config_host_capacity_policy_id_value

  host_location_policy_id:
    type: string
    default: DCAE_alex.Config_host_location_policy_id_value

  db_server_policy_id:
    type: string
    default: DCAE_alex.Config_db_server_policy_id_value

node_templates:

  host_capacity_policy:
    type: dcae.nodes.policy
    properties:
        policy_id: { get_input: host_capacity_policy_id }
        # Use this property to toggle whether policy is required meaning errors are considered
        # critical otherwise errors are silenced.
        policy_required: true

  host_location_policy:
    type: dcae.nodes.policy
    properties:
        policy_id: { get_input: host_location_policy_id }
        policy_required: true

  db_server_policy:
    type: dcae.nodes.policy
    properties:
        policy_id: { get_input: db_server_policy_id }

  laika-zero:
    type: dcae.nodes.DockerContainerForComponents
    properties:
        service_component_type:
            'laika'
        location_id:
            'rework-central'
        service_id:
            'foo-service'
        application_config:
            some-param: "Lorem ipsum dolor sit amet"
            downstream-laika: "{{ laika }}"
        image: { get_input : laika_image }
        docker_config:
            healthcheck:
                type: "http"
                endpoint: "/health"
            policy:
                trigger_type: "docker"
                script_path: "/bin/echo"
    relationships:
      # Link to downstream laika
      - type: dcae.relationships.component_connected_to
        target: laika-one
      - type: dcae.relationships.component_contained_in
        target: docker_host
      - type: cloudify.relationships.depends_on
        target: host_capacity_policy
      - type: cloudify.relationships.depends_on
        target: host_location_policy
    interfaces:
      cloudify.interfaces.lifecycle:
        start:
          inputs:
            ports:
              - "8080:5432"
            envs:
              SOME-ENV: "BAM"
            max_wait:
              120
        stop:
          inputs:
            cleanup_image:
              False

  laika-one:
    type: dcae.nodes.DockerContainerForComponents
    properties:
        service_component_type:
            'laika'
        application_config:
            some-param: "Lorem ipsum dolor sit amet"
        image: { get_input : laika_image }
        # Trying without health check
    relationships:
      - type: dcae.relationships.component_contained_in
        target: docker_host
      - type: cloudify.relationships.depends_on
        target: db_server_policy
    interfaces:
      cloudify.interfaces.lifecycle:
        stop:
          inputs:
            cleanup_image:
              False

  docker_host:
    type: dcae.nodes.SelectedDockerHost
    properties:
        location_id:
            'rework-central'
        docker_host_override:
            'component_dockerhost'