cleargate 0.8.1 → 0.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -35,15 +35,15 @@ cached_gate_result:
35
35
  pass: null
36
36
  failing_criteria: []
37
37
  last_gate_check: null
38
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
39
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
40
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
41
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
42
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
43
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
44
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
45
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
46
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
38
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
39
+ pushed_by: null # set by push: which user pushed
40
+ pushed_at: null # set by push: ISO-8601 timestamp
41
+ last_pulled_by: null # set by pull: which user pulled
42
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
43
+ last_remote_update: null # set by pull: server's last-modified timestamp
44
+ source: "local-authored" # flips to "remote-authored" on intake
45
+ last_synced_status: null # required for conflict-detector; status at last sync
46
+ last_synced_body_sha: null # sha256 of body at last sync
47
47
  ---
48
48
 
49
49
  # BUG-{ID}: {Bug Name}
@@ -33,15 +33,15 @@ cached_gate_result:
33
33
  pass: null
34
34
  failing_criteria: []
35
35
  last_gate_check: null
36
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
37
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
38
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
39
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
40
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
41
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
42
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
43
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
44
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
36
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
37
+ pushed_by: null # set by push: which user pushed
38
+ pushed_at: null # set by push: ISO-8601 timestamp
39
+ last_pulled_by: null # set by pull: which user pulled
40
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
41
+ last_remote_update: null # set by pull: server's last-modified timestamp
42
+ source: "local-authored" # flips to "remote-authored" on intake
43
+ last_synced_status: null # required for conflict-detector; status at last sync
44
+ last_synced_body_sha: null # sha256 of body at last sync
45
45
  ---
46
46
 
47
47
  # CR-{ID}: {Change Request Name}
@@ -38,15 +38,15 @@ cached_gate_result:
38
38
  pass: null
39
39
  failing_criteria: []
40
40
  last_gate_check: null
41
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
42
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
43
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
44
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
45
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
46
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
47
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
48
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
49
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
41
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
42
+ pushed_by: null # set by push: which user pushed
43
+ pushed_at: null # set by push: ISO-8601 timestamp
44
+ last_pulled_by: null # set by pull: which user pulled
45
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
46
+ last_remote_update: null # set by pull: server's last-modified timestamp
47
+ source: "local-authored" # flips to "remote-authored" on intake
48
+ last_synced_status: null # required for conflict-detector; status at last sync
49
+ last_synced_body_sha: null # sha256 of body at last sync
50
50
  ---
51
51
 
52
52
  # EPIC-{ID}: {Epic Name}
@@ -20,7 +20,7 @@ cached_gate_result:
20
20
  pass: null
21
21
  failing_criteria: []
22
22
  last_gate_check: null
23
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
23
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
24
24
  pushed_by: null
25
25
  pushed_at: null
26
26
  last_pulled_by: null
@@ -28,15 +28,15 @@ cached_gate_result:
28
28
  pass: null
29
29
  failing_criteria: []
30
30
  last_gate_check: null
31
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
32
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
33
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
34
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
35
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
36
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
37
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
38
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
39
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
31
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
32
+ pushed_by: null # set by push: which user pushed
33
+ pushed_at: null # set by push: ISO-8601 timestamp
34
+ last_pulled_by: null # set by pull: which user pulled
35
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
36
+ last_remote_update: null # set by pull: server's last-modified timestamp
37
+ source: "local-authored" # flips to "remote-authored" on intake
38
+ last_synced_status: null # required for conflict-detector; status at last sync
39
+ last_synced_body_sha: null # sha256 of body at last sync
40
40
  PROPOSAL-{ID}: {Initiative Name}
41
41
  1. Initiative & Context
42
42
  1.1 Objective
@@ -62,15 +62,15 @@ cached_gate_result:
62
62
  pass: null
63
63
  failing_criteria: []
64
64
  last_gate_check: null
65
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
66
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
67
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
68
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
69
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
70
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
71
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
72
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
73
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
65
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
66
+ pushed_by: null # set by push: which user pushed
67
+ pushed_at: null # set by push: ISO-8601 timestamp
68
+ last_pulled_by: null # set by pull: which user pulled
69
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
70
+ last_remote_update: null # set by pull: server's last-modified timestamp
71
+ source: "local-authored" # flips to "remote-authored" on intake
72
+ last_synced_status: null # required for conflict-detector; status at last sync
73
+ last_synced_body_sha: null # sha256 of body at last sync
74
74
  ---
75
75
 
76
76
  # STORY-{EpicID}-{StoryID}: {Story Name}
@@ -1,6 +1,6 @@
1
1
  {
2
- "cleargate_version": "0.8.1",
3
- "generated_at": "2026-04-27T09:03:42.064Z",
2
+ "cleargate_version": "0.8.2",
3
+ "generated_at": "2026-04-27T09:39:12.477Z",
4
4
  "files": [
5
5
  {
6
6
  "path": ".claude/agents/architect.md",
@@ -144,28 +144,28 @@
144
144
  },
145
145
  {
146
146
  "path": ".cleargate/templates/Bug.md",
147
- "sha256": "3ba6e72bd2bc01cf8d0ea06390f8ea511bef3a421a33c48de033051f844dfa0e",
147
+ "sha256": "54660457a8b7f5c9f1a286993e2d83d46fef880a3d65086421d8db815a9c01ec",
148
148
  "tier": "template",
149
149
  "overwrite_policy": "merge-3way",
150
150
  "preserve_on_uninstall": false
151
151
  },
152
152
  {
153
153
  "path": ".cleargate/templates/CR.md",
154
- "sha256": "58ea4badb03991d119f8aa8870992a8239c8df6ad198e0d9ca04a805756e4bac",
154
+ "sha256": "e4cff0314217d649177a3dd1603c510d2f5246c1cf297baaa91d5941c1eedc91",
155
155
  "tier": "template",
156
156
  "overwrite_policy": "merge-3way",
157
157
  "preserve_on_uninstall": false
158
158
  },
159
159
  {
160
160
  "path": ".cleargate/templates/epic.md",
161
- "sha256": "6c85e4c9602af657e6778af9009a67936c27e47331479d0c246cdf1242177c82",
161
+ "sha256": "fa0e5bf85b50bee11d38646b2606652999ac2ff7c649810408c35ff25d7a025c",
162
162
  "tier": "template",
163
163
  "overwrite_policy": "merge-3way",
164
164
  "preserve_on_uninstall": false
165
165
  },
166
166
  {
167
167
  "path": ".cleargate/templates/hotfix.md",
168
- "sha256": "2a7c745b0d46f4a092c507d6b427c15d64540e332f9544bc572451a313f4e5cc",
168
+ "sha256": "93c6690a23bcfca98697048b7f1c2c5c76ee16c2d295a53ced8471e8c4eb78d3",
169
169
  "tier": "template",
170
170
  "overwrite_policy": "merge-3way",
171
171
  "preserve_on_uninstall": false
@@ -179,7 +179,7 @@
179
179
  },
180
180
  {
181
181
  "path": ".cleargate/templates/proposal.md",
182
- "sha256": "e8055dac81ecf94d01fe610e8cdaf4fa73a2f8d9953e4db90b91a20a8c81460d",
182
+ "sha256": "227907f5de028453168c487e9c4ec4d4acd578298d13d658f7a7b63ef76dc23d",
183
183
  "tier": "template",
184
184
  "overwrite_policy": "merge-3way",
185
185
  "preserve_on_uninstall": false
@@ -207,7 +207,7 @@
207
207
  },
208
208
  {
209
209
  "path": ".cleargate/templates/story.md",
210
- "sha256": "f46364178f09d2514405723e53d5e388ab41bce5e2b318dc1aed8743500f042f",
210
+ "sha256": "0817454195b1c3ddb7a2559a0295273082fb621cdfd7a77594414876da28c620",
211
211
  "tier": "template",
212
212
  "overwrite_policy": "merge-3way",
213
213
  "preserve_on_uninstall": false
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "cleargate",
3
- "version": "0.8.1",
3
+ "version": "0.8.2",
4
4
  "private": false,
5
5
  "type": "module",
6
6
  "description": "Planning framework for Claude Code agents — sprint/epic/story protocol, four-agent loop (architect/developer/qa/reporter), Karpathy-style awareness wiki.",
@@ -35,15 +35,15 @@ cached_gate_result:
35
35
  pass: null
36
36
  failing_criteria: []
37
37
  last_gate_check: null
38
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
39
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
40
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
41
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
42
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
43
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
44
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
45
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
46
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
38
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
39
+ pushed_by: null # set by push: which user pushed
40
+ pushed_at: null # set by push: ISO-8601 timestamp
41
+ last_pulled_by: null # set by pull: which user pulled
42
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
43
+ last_remote_update: null # set by pull: server's last-modified timestamp
44
+ source: "local-authored" # flips to "remote-authored" on intake
45
+ last_synced_status: null # required for conflict-detector; status at last sync
46
+ last_synced_body_sha: null # sha256 of body at last sync
47
47
  ---
48
48
 
49
49
  # BUG-{ID}: {Bug Name}
@@ -33,15 +33,15 @@ cached_gate_result:
33
33
  pass: null
34
34
  failing_criteria: []
35
35
  last_gate_check: null
36
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
37
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
38
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
39
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
40
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
41
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
42
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
43
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
44
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
36
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
37
+ pushed_by: null # set by push: which user pushed
38
+ pushed_at: null # set by push: ISO-8601 timestamp
39
+ last_pulled_by: null # set by pull: which user pulled
40
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
41
+ last_remote_update: null # set by pull: server's last-modified timestamp
42
+ source: "local-authored" # flips to "remote-authored" on intake
43
+ last_synced_status: null # required for conflict-detector; status at last sync
44
+ last_synced_body_sha: null # sha256 of body at last sync
45
45
  ---
46
46
 
47
47
  # CR-{ID}: {Change Request Name}
@@ -38,15 +38,15 @@ cached_gate_result:
38
38
  pass: null
39
39
  failing_criteria: []
40
40
  last_gate_check: null
41
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
42
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
43
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
44
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
45
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
46
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
47
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
48
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
49
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
41
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
42
+ pushed_by: null # set by push: which user pushed
43
+ pushed_at: null # set by push: ISO-8601 timestamp
44
+ last_pulled_by: null # set by pull: which user pulled
45
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
46
+ last_remote_update: null # set by pull: server's last-modified timestamp
47
+ source: "local-authored" # flips to "remote-authored" on intake
48
+ last_synced_status: null # required for conflict-detector; status at last sync
49
+ last_synced_body_sha: null # sha256 of body at last sync
50
50
  ---
51
51
 
52
52
  # EPIC-{ID}: {Epic Name}
@@ -20,7 +20,7 @@ cached_gate_result:
20
20
  pass: null
21
21
  failing_criteria: []
22
22
  last_gate_check: null
23
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
23
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
24
24
  pushed_by: null
25
25
  pushed_at: null
26
26
  last_pulled_by: null
@@ -28,15 +28,15 @@ cached_gate_result:
28
28
  pass: null
29
29
  failing_criteria: []
30
30
  last_gate_check: null
31
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
32
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
33
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
34
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
35
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
36
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
37
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
38
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
39
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
31
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
32
+ pushed_by: null # set by push: which user pushed
33
+ pushed_at: null # set by push: ISO-8601 timestamp
34
+ last_pulled_by: null # set by pull: which user pulled
35
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
36
+ last_remote_update: null # set by pull: server's last-modified timestamp
37
+ source: "local-authored" # flips to "remote-authored" on intake
38
+ last_synced_status: null # required for conflict-detector; status at last sync
39
+ last_synced_body_sha: null # sha256 of body at last sync
40
40
  PROPOSAL-{ID}: {Initiative Name}
41
41
  1. Initiative & Context
42
42
  1.1 Objective
@@ -62,15 +62,15 @@ cached_gate_result:
62
62
  pass: null
63
63
  failing_criteria: []
64
64
  last_gate_check: null
65
- # Sync attribution (EPIC-010). Optional; stamped by `cleargate push` / `cleargate pull`.
66
- pushed_by: null # STORY-010-07 writer / STORY-010-04 reader
67
- pushed_at: null # STORY-010-07 writer / STORY-010-04 reader
68
- last_pulled_by: null # STORY-010-04 writer / STORY-010-03 reader
69
- last_pulled_at: null # STORY-010-04 writer / STORY-010-03 reader
70
- last_remote_update: null # STORY-010-02 writer (from MCP) / STORY-010-03 reader
71
- source: "local-authored" # STORY-010-05 flips to "remote-authored" on intake
72
- last_synced_status: null # STORY-010-04 writer; required for conflict-detector rule 6
73
- last_synced_body_sha: null # STORY-010-04 writer; sha256 of body at last sync
65
+ # Sync attribution. Optional; stamped by `cleargate push` / `cleargate pull`.
66
+ pushed_by: null # set by push: which user pushed
67
+ pushed_at: null # set by push: ISO-8601 timestamp
68
+ last_pulled_by: null # set by pull: which user pulled
69
+ last_pulled_at: null # set by pull: ISO-8601 timestamp
70
+ last_remote_update: null # set by pull: server's last-modified timestamp
71
+ source: "local-authored" # flips to "remote-authored" on intake
72
+ last_synced_status: null # required for conflict-detector; status at last sync
73
+ last_synced_body_sha: null # sha256 of body at last sync
74
74
  ---
75
75
 
76
76
  # STORY-{EpicID}-{StoryID}: {Story Name}
@@ -1,6 +1,6 @@
1
1
  {
2
- "cleargate_version": "0.8.1",
3
- "generated_at": "2026-04-27T09:03:42.064Z",
2
+ "cleargate_version": "0.8.2",
3
+ "generated_at": "2026-04-27T09:39:12.477Z",
4
4
  "files": [
5
5
  {
6
6
  "path": ".claude/agents/architect.md",
@@ -144,28 +144,28 @@
144
144
  },
145
145
  {
146
146
  "path": ".cleargate/templates/Bug.md",
147
- "sha256": "3ba6e72bd2bc01cf8d0ea06390f8ea511bef3a421a33c48de033051f844dfa0e",
147
+ "sha256": "54660457a8b7f5c9f1a286993e2d83d46fef880a3d65086421d8db815a9c01ec",
148
148
  "tier": "template",
149
149
  "overwrite_policy": "merge-3way",
150
150
  "preserve_on_uninstall": false
151
151
  },
152
152
  {
153
153
  "path": ".cleargate/templates/CR.md",
154
- "sha256": "58ea4badb03991d119f8aa8870992a8239c8df6ad198e0d9ca04a805756e4bac",
154
+ "sha256": "e4cff0314217d649177a3dd1603c510d2f5246c1cf297baaa91d5941c1eedc91",
155
155
  "tier": "template",
156
156
  "overwrite_policy": "merge-3way",
157
157
  "preserve_on_uninstall": false
158
158
  },
159
159
  {
160
160
  "path": ".cleargate/templates/epic.md",
161
- "sha256": "6c85e4c9602af657e6778af9009a67936c27e47331479d0c246cdf1242177c82",
161
+ "sha256": "fa0e5bf85b50bee11d38646b2606652999ac2ff7c649810408c35ff25d7a025c",
162
162
  "tier": "template",
163
163
  "overwrite_policy": "merge-3way",
164
164
  "preserve_on_uninstall": false
165
165
  },
166
166
  {
167
167
  "path": ".cleargate/templates/hotfix.md",
168
- "sha256": "2a7c745b0d46f4a092c507d6b427c15d64540e332f9544bc572451a313f4e5cc",
168
+ "sha256": "93c6690a23bcfca98697048b7f1c2c5c76ee16c2d295a53ced8471e8c4eb78d3",
169
169
  "tier": "template",
170
170
  "overwrite_policy": "merge-3way",
171
171
  "preserve_on_uninstall": false
@@ -179,7 +179,7 @@
179
179
  },
180
180
  {
181
181
  "path": ".cleargate/templates/proposal.md",
182
- "sha256": "e8055dac81ecf94d01fe610e8cdaf4fa73a2f8d9953e4db90b91a20a8c81460d",
182
+ "sha256": "227907f5de028453168c487e9c4ec4d4acd578298d13d658f7a7b63ef76dc23d",
183
183
  "tier": "template",
184
184
  "overwrite_policy": "merge-3way",
185
185
  "preserve_on_uninstall": false
@@ -207,7 +207,7 @@
207
207
  },
208
208
  {
209
209
  "path": ".cleargate/templates/story.md",
210
- "sha256": "f46364178f09d2514405723e53d5e388ab41bce5e2b318dc1aed8743500f042f",
210
+ "sha256": "0817454195b1c3ddb7a2559a0295273082fb621cdfd7a77594414876da28c620",
211
211
  "tier": "template",
212
212
  "overwrite_policy": "merge-3way",
213
213
  "preserve_on_uninstall": false