sign
Deprecated This command will be removed in the 1.0.0 version of
isomorphic-gitas it is no longer necessary.Previously, to sign commits you needed two steps,
commitand thensign. Now commits can be signed when they are created with thecommitcommand, provided you use apgpplugin.
Create a signed commit
| param | type [= default] | description |
|---|---|---|
| core | string = 'default' | The plugin core identifier to use for plugin injection |
| fs [deprecated] | FileSystem | The filesystem containing the git repo. Overrides the fs provided by the plugin system. |
| dir | string | The working tree directory path |
| gitdir | string = join(dir, '.git') | The git directory path |
| openpgp | string | An instance of the OpenPGP library |
| privateKeys | string | A PGP private key in ASCII armor format |
| return | Promise<void> | Resolves successfully when filesystem operations are completed |
It creates a signed version of whatever commit HEAD currently points to, and then updates the current branch, leaving the original commit dangling.
The privateKeys argument is a single string in ASCII armor format. However, it is plural "keys" because
you can technically have multiple private keys in a single ASCII armor string. The openpgp.sign() function accepts
multiple keys, so while I haven't tested it, it should support signing a single commit with multiple keys.
Example Code:
let sha = await git.sign({
dir: '$input((/))',
openpgp,
privateKeys: `$textarea((
-----BEGIN PGP PRIVATE KEY BLOCK-----
...
))`
})
console.log(sha)