Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/onlxltd/notarytool
A TypeScript implementation of Apple's notarization process.
https://github.com/onlxltd/notarytool
apple cd ci crossplatform javascript macos notarytool signing typescript
Last synced: 3 months ago
JSON representation
A TypeScript implementation of Apple's notarization process.
- Host: GitHub
- URL: https://github.com/onlxltd/notarytool
- Owner: onlxltd
- License: mit
- Created: 2023-06-26T23:29:40.000Z (over 1 year ago)
- Default Branch: master
- Last Pushed: 2024-07-31T07:24:02.000Z (6 months ago)
- Last Synced: 2024-10-01T21:18:20.663Z (4 months ago)
- Topics: apple, cd, ci, crossplatform, javascript, macos, notarytool, signing, typescript
- Language: TypeScript
- Homepage: https://npmjs.com/package/notarytool
- Size: 158 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 4
-
Metadata Files:
- Readme: readme.md
- License: LICENSE
Awesome Lists containing this project
README
# NotaryTool
[![build](https://github.com/onlxltd/notarytool/actions/workflows/build-release.yml/badge.svg?style=flat-square)](https://github.com/onlxltd/notarytool/actions/workflows/build-release.yml) ![npm bundle size](https://img.shields.io/bundlephobia/min/notarytool?style=flat-square) [![DeepScan grade](https://deepscan.io/api/teams/13435/projects/24967/branches/773213/badge/grade.svg?style=flat-square)](https://deepscan.io/dashboard#view=project&tid=13435&pid=24967&bid=773213)
NotaryTool is a TypeScript implementation of Apple's notarization process.
The tool can be used on any platform and on macOS will attempt to staple on completion.NotaryTool is supported by [ON LX Limited](https://onlx.ltd/?src=notarytool). Check out our projects such as [Ctrl Suite](https://onlx.ltd/ctrl-suite?src=notarytool) and [bonjour-service](https://npmjs.com/package/bonjour-service).
## Installation
Add to your project dependencies using Yarn or NPM.#### Install with Yarn
```
yarn add notarytool
```
#### Install with NPM
```
npm install notarytool
```## Usage
```js
import NotaryTool from 'notarytool'/**
* Setup the tool using API credentials
*/
const tool = new NotaryTool({
appleApiKey : process.env.APPLE_API_KEY,
appleApiKeyId : process.env.APPLE_API_KEY_ID,
appleApiIssuerId : process.env.APPLE_API_ISSUER_ID
})/**
* Monitor the current status of the tool
*/
tool.on('progress', val => console.log('progress:', val))
tool.on('status', (status, message) => console.log('status:', status, message))/**
* Call notarize with the file path
*/
try {
await tool.notarize(process.env.FILE_PATH)
console.log('Success')
} catch(error) {
console.log('Failed', error)
}
```## API
### Initializing
```js
const tool = new NotaryTool(options: NotaryToolConfig)
```Creates an new tool instance that can handle notarizing multiple times
Options are:
- @string `appleApiKey` The file path to the AuthKey_{id}.p8 file from the App Store
- @string `appleApiKeyId` The {id} of the AuthKey file
- @string `appleApiIssuerId` The issuer ID provided by the App Store
- @boolean? `ignoreStaple` If enabled on macOS, staple stage will be skipped### Methods
#### `await tool.notarize(filePath: string)`
Begins the file notarization process. Function returns a void on success and throws errors
### Events
#### `tool.on('progress', (val: number) => console.log(val))`
Provides progress of process from 0.0 to 1.0. Value will hang around 0.75 whilst response from App Store is provided.
#### `tool.on('status', (status: NotaryToolStatus, message: string | undefined) => console.log(status, message))`
Provides a status value and optional readable message where applicable.
### Enums
#### NotaryToolStatus
```js
enum NotaryToolStatus {
BeginUpload = 'begin_upload',
Uploaded = 'uploaded',
Invalid = 'invalid',
InProgress = 'in_progress',
Complete = 'complete'
}
```