Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/shinnn/load-gh-token
Get a GitHub access token from either an environment variable or a file
https://github.com/shinnn/load-gh-token
access-token configuration environment-variables github-api javascript nodejs secret-management security token
Last synced: about 2 months ago
JSON representation
Get a GitHub access token from either an environment variable or a file
- Host: GitHub
- URL: https://github.com/shinnn/load-gh-token
- Owner: shinnn
- License: isc
- Created: 2015-04-25T01:06:10.000Z (almost 10 years ago)
- Default Branch: master
- Last Pushed: 2019-06-06T22:43:02.000Z (over 5 years ago)
- Last Synced: 2024-11-15T22:42:33.438Z (2 months ago)
- Topics: access-token, configuration, environment-variables, github-api, javascript, nodejs, secret-management, security, token
- Language: JavaScript
- Homepage:
- Size: 40 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# load-gh-token
[![npm version](https://img.shields.io/npm/v/load-gh-token.svg)](https://www.npmjs.com/package/load-gh-token)
[![Build Status](https://travis-ci.com/shinnn/load-gh-token.svg?branch=master)](https://travis-ci.com/shinnn/load-gh-token)
[![codecov](https://codecov.io/gh/shinnn/load-gh-token/branch/master/graph/badge.svg)](https://codecov.io/gh/shinnn/load-gh-token)Get a [GitHub access token](https://help.github.com/en/articles/creating-a-personal-access-token-for-the-command-line) from either an environment variable or a file
```javascript
const loadGhToken = require('load-gh-token');// When `process.env.GITHUB_TOKEN === '36fae5325faa9b32edfd776f6b85bf71ac0a49bf'`
(async () => {
const token = await loadGhToken(); //=> '36fae5325faa9b32edfd776f6b85bf71ac0a49bf'
})();
```## Installation
[Use](https://docs.npmjs.com/cli/install) [npm](https://docs.npmjs.com/about-npm/).
```
npm install load-gh-token
```## API
```javascript
const loadGhToken = require('load-gh-token');
```### loadGhToken([*options*])
*options*: `Object`
Return: `Promise`If there is an environment variable `GITHUB_TOKEN`, it reads its value.
If the variable `GITHUB_TOKEN` is not defined, then it reads a file `github-token.txt` at the current working directory.
```javascript
// When `process.env.GITHUB_TOKEN` is undefined but a file ./github-token.txt exists(async () => {
const token = await loadGhToken();
// '... contents of github-token.txt without whitespaces ...'
})();
```If both the `GITHUB_TOKEN` environment variable and the file `./github-token.txt` don't exist, the `Promise` will be rejected.
```javascript
(async () => {
try {
await loadGhToken();
} catch (err) {
err.message;
// Tried to get a personal access token for GitHub API from the `GITHUB_TOKEN` environment variable or a file at '/Users/example/github-token.txt', but neither exists.err.code;
//=> 'ERR_NO_GITHUB_TOKEN'
}
})();
```## License
[ISC License](./LICENSE) © 2018 - 2019 Watanabe Shinnosuke