我正在尝试删除一些防火墙规则(默认规则),前提是它们使用下面的 GCP 部署管理器配置存在,但我遇到了一些错误,任何帮助将不胜感激:
default_vpc_list.jinja:
resources:
- name: def_firw
action: gcp-types/compute-v1:compute.firewalls.list
properties:
filter: (name = "default*")
{% if "($(ref.def_firw.items[0]))"|length > 0 %}
- name: firewall-delete-internal
action: gcp-types/compute-v1:compute.firewalls.delete
metadata:
dependsOn:
- def_firw
properties:
firewall: $(ref.def_firw.items[0].name)
{% endif %}
outputs:
- name: fw_rules
value: $(ref.def_firw.items[0].name)
这是yaml文件:
imports:
- path: jinja/default_vpc_list.jinja
name: default_vpc_list.jinja
resources:
- name: default_vpc_list
type: default_vpc_list.jinja
使用此代码会出现错误:
The reference 'items[0].name' is not found, reason: The resource 'def_firw' exists, but the reference value does not, details: Missing property in path $['ref']['def_firw']['items']
更新:采用了一种解决方法并将 runtimePolicy: CREATE 设置为仅在创建资源时触发:
- name: delete-default-private-route
action: gcp-types/compute-v1:compute.routes.delete
metadata:
dependsOn:
- defaultRoutelist
runtimePolicy:
- CREATE
properties:
route: $(ref.defaultRoutelist.items[0].name)