Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/vitalics/dotenv-guards
guards functions for dotenv package
https://github.com/vitalics/dotenv-guards
dotenv dotenv-cli
Last synced: 1 day ago
JSON representation
guards functions for dotenv package
- Host: GitHub
- URL: https://github.com/vitalics/dotenv-guards
- Owner: vitalics
- License: mit
- Created: 2022-06-09T10:05:22.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-12-15T20:30:32.000Z (about 1 year ago)
- Last Synced: 2024-12-22T13:48:15.303Z (about 1 month ago)
- Topics: dotenv, dotenv-cli
- Language: TypeScript
- Homepage: https://www.npmjs.com/package/dotenv-guards
- Size: 101 KB
- Stars: 0
- Watchers: 3
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# dotenv guards
![dotenv-guards](images/logo.png)
![release status](https://github.com/vitalics/dotenv-guards/actions/workflows/release.yaml/badge.svg)
![tests status](https://github.com/vitalics/dotenv-guards/actions/workflows/pr.yaml/badge.svg)
guards functions for dotenv package
## installation
```bash
npm i dotenv dotenv-guards
```## usage
```js
import { numberGuard } from 'dotenv-guards';const jobsAsNumber = numberGuard(process.env.jobs, 2); // return 2 if jobs is not a number
```## Available guards
- `numberGuard` - parse a string to a number.
- `enumGuard` - parse a string to an enum.
- `booleanGuard` - parse a string to a boolean.
- `arrayGuard` - parse a string to an array.
- `string` - parse string and execute matchers.## Custom guards
In case if you want to define custom guards - you can use `define` and `revoke` functions.
Example:
``` ts
import { define, revoke } from 'dotenv-guards';// define new guard
const jsonGuard = define((val: string | undefined) => {
return JSON.parse(val);
});jsonGuard('{"qwe": true}'); // returns { qwe: true }
revoke(jsonGuard); // remove json guard
jsonGuard('{"qwe": true}'); // TypeError. jsonGuard is revoked
```## API
### number guard
```javascript
numberGuard(value, fallbackValue, options)
```### Parameters
- `value` - [`string`] - string-like variable.
- `options` - [`Object`]
- `throwOnFinite` - [`boolean`] - Throws an error if incoming value parsed to `Infinity`. Default is `false`.
- `throwOnNaN` - [`boolean`] - Throws an error if incoming value parsed to `NaN`. Default is `false`.
- `throwOnUndefined` - [`boolean`] - If `true` throwing an error if incoming value is undefined. Default is `false`.
- `throwOnSafeInteger` - [`boolean`] - Throws an error if incoming value is not safe integer. Default is `false`.#### Returns
`number`
Example:
```js
// process.env.jobs = '2'
numberGuard(process.env.jobs); // returns 2 as number// process.env.jobs = 'not a number string'
numberGuard(process.env.jobs); // returns 0 as number// process.env.jobs = 'not a number string'
numberGuard(process.env.jobs, 0, {throwOnSafeInteger: true}); //throws an error
```### boolean guard
```javascript
booleanGuard(value, options)
```#### Parameters
- value - [`string`] - string-like variable.
- `options` - [`Object`]
- `fallback` - fallback value if incoming value is not a boolean and cannot parse value to boolean.
- `trueSymbols` - [`string`] - Array of possible values which will be converted as `true`. Default is `['1', 'true']`
- `throwOnUndefined` Throw an error if incoming value is undefined, fallback value is not returned, since it returns an error. Default is `false`.
- `throwOnFail` - Throw an error if incoming value is not matching with `trueSymbols` option. Default is `false`.#### Returns
`boolean`
Example:
```javascript
// process.env.isDebug = 'true'
booleanGuard(process.env.isDebug); // returns true// process.env.acceptDownloading = 'yes'
booleanGuard(process.env.acceptDownloading, false, {trueSymbols: ['yes']}); // returns true since 'yes' is in the array
```### enum guard
```javascript
enum(value, arrayOfPossibleValues, fallbackValue)
```### Parameters
- `value` - [`string`] - string-like variable.
- `arrayOfPossibleValues` - [`Array`] - Array of possible values.
- `fallbackValue` - [`string`] - fallback value.#### Returns
`string`
Example:
``` javascript
// process.env.NODE_ENV = 'test'
enumGuard(process.env.NODE_ENV, ['development', 'production'], 'development'); // returns 'development'// or define more acceptable values
// process.env.NODE_ENV = 'test'
enumGuard(process.env.NODE_ENV, ['development', 'production', 'test'], 'development'); // returns 'test', since 'test' is in the array
```### array guard
```javascript
array(value, arrayOfPossibleValues, options)
```#### Parameters
- `value` - [`string`] - string-like variable.
- `arrayOfPossibleValues` - [`Array`] - If `true` throwing an error if at least one element is not matched.
- `options` - [`Object`]
- `strict` - [`boolean`] - If `true` throwing an error if at least one element is not matched. Default is `false`.
- `separator` - [`string`] - Parsing separator. Default is `,`#### Returns
`string`
Example:
```javascript
// process.env.array = 'val1,val2,val3'
arrayGuard(process.env.array, ['val1', 'val2']); // split string by `,` symbol and returns ['val1', 'val2']// custom separator
// process.env.array = 'val1;val2;val3'
arrayGuard(process.env.array, ['val1', 'val2', 'val3'], {separator: ';'}); // split string by `;` symbol and returns ['val1', 'val2', 'val3']
```### string guard
```javascript
string(value, options)
```#### Parameters
- `value` - [string]. Parsing string-like value.
- `options`
- `fallback`- [string] - fallback value if incoming value is not matched by regex or matcher function.
- `throwOnUndefined`- [boolean] - Throw an error if incoming value is undefined, fallback value is not returned, since it returns an error.
- `regexp`- [RegExp] - Regexp for incoming value. Returns first match.
- `throwOnNullable` - [boolean] - Throw an error if incoming value is null, undefined, empty string or empty array.
- `matcher` - [boolean] - Matcher function for incoming value. Returns boolean(is matched incoming string or not).
- `throwOnMismatch` - [boolean] - Throw an error if incoming value is not matched by regex or matcher function.#### Returns
`string`
Example:
```javascript
// process.env.token = 'hash123'
stringGuard(process.env.token); // returns hash123// matcher function
// process.env.token = 'hash123'
arrayGuard(process.env.token, {
matcher: (value) => value.startsWith('hash'),
}); // returns hash123// miss matching
// process.env.token = 'hash123'
arrayGuard(process.env.token, {
matcher: (value) => value.startsWith('random string'),
fallback: 'qwerty'
}); // returns qwerty, since mismatch
```### define(fn)
#### Parameters
- `function` - [Function] - First argument should accepts type `string | undefined`, otherwise it throws an `TypeError`
#### returns
Function
### revoke(fn)
#### Parameters
- `function` - [Function] - function reference from `define`. It will throw a `ReferenceError` in case of function is not created from `define`.
#### Returns
void