Commit ed9cbef
fix(drawer): implicit webhook input + 'any' type for trigger drawers (#171)
* fix(drawer): implicit webhook input + 'any' type for trigger drawers
Before: a drawer with a webhook trigger couldn't pass `buttons drawer
NAME --summary` validation because refs like
`${inputs.webhook.body.resource.defaultDatasetId}` hit "unknown
drawer input 'webhook'" — the input is populated by the listener
dispatcher, not declared in drawer.json.
Now: when a drawer has kind=webhook in Triggers, the validator
auto-declares an implicit InputDef{Name:"webhook", Type:"any"}. The
"any" type compatibly matches string/int/bool at the arg-type check
(fall-through to press-time best-effort resolution) so downstream
steps reading webhook fields pass validation regardless of arg type.
This was caught during the real-world Apify webhook setup — the
on-apify-done drawer needed `${inputs.webhook.body.resource.defaultDatasetId}`
to flow into an `apify-fetch-dataset` button that declares a string
arg, and the validator blocked the press every time.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
* fix(init): comprehensive .gitignore + auto-add on batteries set
Two linked fixes so secret-bearing files in .buttons/ can't
accidentally ship in a commit:
1) `buttons init` now writes a .gitignore that covers everything in
.buttons/ that can hold secrets or per-machine state:
- batteries.json (API keys, 0600 on disk but 'git add -A' ignores
perms)
- webhook.json (tunnel hostname + id; machine-specific)
- buttons/*/pressed/ + drawers/*/pressed/ (run history with
press-time args)
- idempotency/ (cached results keyed on args)
- queues/ (file-lock state)
2) Older projects that already ran `buttons init` before this fix
shipped get upgraded in place. The init path now reads an existing
.gitignore and appends any missing secret patterns under an
"Added by buttons upgrade" header, idempotent and append-only so
user customisations are preserved.
3) `buttons batteries set --local` (or local-default in a project)
now runs the same ensure-pattern check on .buttons/.gitignore
before returning success, so a battery set in a project that
somehow missed the init .gitignore still gets covered. Emits a
"added batteries.json to .buttons/.gitignore" notice in stderr
and the JSON payload so the user knows we touched their repo.
Global scope (~/.buttons/) skips the check since it's outside any
repo.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
* fix(gosec): annotate .gitignore writes as not-path-traversable
gosec G703 flagged os.WriteFile calls on paths ending in
.buttons/.gitignore because the path traces back to config.DataDir()
which reads BUTTONS_HOME. The filename is a literal and the parent
directory is constrained to BUTTONS_HOME / discovered .buttons/ /
~/.buttons — no user-tainted path-traversal vector.
#nosec with a rationale comment at each site.
Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
---------
Co-authored-by: Claude Opus 4.7 (1M context) <noreply@anthropic.com>1 parent 38f718c commit ed9cbef
3 files changed
Lines changed: 185 additions & 6 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
68 | 69 | | |
69 | 70 | | |
70 | 71 | | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
71 | 89 | | |
72 | | - | |
| 90 | + | |
73 | 91 | | |
74 | 92 | | |
75 | | - | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
76 | 98 | | |
77 | 99 | | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
78 | 103 | | |
79 | 104 | | |
80 | 105 | | |
81 | 106 | | |
82 | 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 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
83 | 154 | | |
84 | 155 | | |
85 | 156 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
4 | 4 | | |
5 | 5 | | |
6 | 6 | | |
| 7 | + | |
7 | 8 | | |
8 | 9 | | |
9 | 10 | | |
| |||
120 | 121 | | |
121 | 122 | | |
122 | 123 | | |
123 | | - | |
124 | | - | |
125 | | - | |
126 | | - | |
| 124 | + | |
127 | 125 | | |
128 | 126 | | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
129 | 134 | | |
130 | 135 | | |
131 | 136 | | |
132 | 137 | | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
| 190 | + | |
| 191 | + | |
| 192 | + | |
| 193 | + | |
| 194 | + | |
| 195 | + | |
| 196 | + | |
| 197 | + | |
| 198 | + | |
| 199 | + | |
| 200 | + | |
| 201 | + | |
| 202 | + | |
| 203 | + | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
133 | 221 | | |
134 | 222 | | |
135 | 223 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
62 | 62 | | |
63 | 63 | | |
64 | 64 | | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
65 | 77 | | |
66 | 78 | | |
67 | 79 | | |
| |||
453 | 465 | | |
454 | 466 | | |
455 | 467 | | |
| 468 | + | |
| 469 | + | |
| 470 | + | |
| 471 | + | |
| 472 | + | |
| 473 | + | |
| 474 | + | |
| 475 | + | |
456 | 476 | | |
457 | 477 | | |
458 | 478 | | |
| |||
0 commit comments