Skip to content

Commit

Permalink
Merge pull request #1430 from actions/add-mask-docs
Browse files Browse the repository at this point in the history
Update docs for setSecret
  • Loading branch information
rentziass authored May 25, 2023
2 parents 37e09c5 + ae9272d commit a6bf872
Show file tree
Hide file tree
Showing 2 changed files with 17 additions and 2 deletions.
13 changes: 12 additions & 1 deletion docs/commands.md
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,18 @@ function setSecret(secret: string): void {}

Now, future logs containing BAR will be masked. E.g. running `echo "Hello FOO BAR World"` will now print `Hello FOO **** World`.

**WARNING** The add-mask and setSecret commands only support single line secrets. To register a multiline secrets you must register each line individually otherwise it will not be masked.
**WARNING** The add-mask and setSecret commands only support single-line
secrets or multi-line secrets that have been escaped. `@actions/core`
`setSecret` will escape the string you provide by default. When an escaped
multi-line string is provided the whole string and each of its lines
individually will be masked. For example you can mask `first\nsecond\r\nthird`
using:

```sh
echo "::add-mask::first%0Asecond%0D%0Athird"
```

This will mask `first%0Asecond%0D%0Athird`, `first`, `second` and `third`.

**WARNING** Do **not** mask short values if you can avoid it, it could render your output unreadable (and future steps' output as well).
For example, if you mask the letter `l`, running `echo "Hello FOO BAR World"` will now print `He*********o FOO BAR Wor****d`
Expand Down
6 changes: 5 additions & 1 deletion packages/core/__tests__/core.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -161,7 +161,11 @@ describe('@actions/core', () => {

it('setSecret produces the correct command', () => {
core.setSecret('secret val')
assertWriteCalls([`::add-mask::secret val${os.EOL}`])
core.setSecret('multi\nline\r\nsecret')
assertWriteCalls([
`::add-mask::secret val${os.EOL}`,
`::add-mask::multi%0Aline%0D%0Asecret${os.EOL}`
])
})

it('prependPath produces the correct commands and sets the env', () => {
Expand Down

0 comments on commit a6bf872

Please sign in to comment.