Compare commits
42 Commits
Author | SHA1 | Date | |
---|---|---|---|
211529ffff | |||
d4f5d19231 | |||
80d6a5103a | |||
c22bbe2daf | |||
82af55fae9 | |||
90f8ee4e9d | |||
4fe85134c4 | |||
c307b7c7b0 | |||
e4f608f7eb | |||
0689e33ae6 | |||
7109b666f5 | |||
11bb21e0e0 | |||
4fdc985461 | |||
bd4de83e83 | |||
545e792751 | |||
4fa25477ad | |||
95de67fe17 | |||
2ec33a118a | |||
bb1293c764 | |||
344f144c2c | |||
07cdcb074d | |||
09d9fd45cf | |||
9883067d8b | |||
854dac5732 | |||
73c37d8bf8 | |||
f0664d4c7d | |||
3dff5dbbc6 | |||
15e3497c55 | |||
4184e8f20f | |||
5ebee20a7a | |||
a6aa1b06da | |||
07610c007c | |||
f056e062b3 | |||
00855e3d63 | |||
d5fea19831 | |||
4c3715f655 | |||
513bb686ef | |||
b1f8c79b8d | |||
b0dbb9b8a0 | |||
83108ce02d | |||
2911dd4972 | |||
16150541b0 |
22
.gitignore
vendored
22
.gitignore
vendored
@ -1,4 +1,22 @@
|
|||||||
node_modules/
|
.nogit/
|
||||||
|
|
||||||
|
# artifacts
|
||||||
coverage/
|
coverage/
|
||||||
pages/
|
|
||||||
public/
|
public/
|
||||||
|
pages/
|
||||||
|
|
||||||
|
# installs
|
||||||
|
node_modules/
|
||||||
|
|
||||||
|
# caches
|
||||||
|
.yarn/
|
||||||
|
.cache/
|
||||||
|
.rpt2_cache
|
||||||
|
|
||||||
|
# builds
|
||||||
|
dist/
|
||||||
|
dist_web/
|
||||||
|
dist_serve/
|
||||||
|
dist_ts_web/
|
||||||
|
|
||||||
|
# custom
|
115
.gitlab-ci.yml
115
.gitlab-ci.yml
@ -1,48 +1,119 @@
|
|||||||
image: hosttoday/ht-docker-node:npmts
|
# gitzone ci_default
|
||||||
|
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
|
||||||
|
cache:
|
||||||
|
paths:
|
||||||
|
- .npmci_cache/
|
||||||
|
key: "$CI_BUILD_STAGE"
|
||||||
|
|
||||||
stages:
|
stages:
|
||||||
|
- security
|
||||||
- test
|
- test
|
||||||
- release
|
- release
|
||||||
- page
|
- metadata
|
||||||
|
|
||||||
testLEGACY:
|
# ====================
|
||||||
|
# security stage
|
||||||
|
# ====================
|
||||||
|
mirror:
|
||||||
|
stage: security
|
||||||
|
script:
|
||||||
|
- npmci git mirror
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
|
snyk:
|
||||||
|
stage: security
|
||||||
|
script:
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci command npm install -g snyk
|
||||||
|
- npmci command npm install --ignore-scripts
|
||||||
|
- npmci command snyk test
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
|
# ====================
|
||||||
|
# test stage
|
||||||
|
# ====================
|
||||||
|
|
||||||
|
testStable:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci test legacy
|
- npmci npm prepare
|
||||||
|
- npmci node install stable
|
||||||
|
- npmci npm install
|
||||||
|
- npmci npm test
|
||||||
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
|
- priv
|
||||||
|
|
||||||
testLTS:
|
testBuild:
|
||||||
stage: test
|
stage: test
|
||||||
script:
|
script:
|
||||||
- npmci test lts
|
- npmci npm prepare
|
||||||
|
- npmci node install stable
|
||||||
|
- npmci npm install
|
||||||
|
- npmci command npm run build
|
||||||
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
|
- notpriv
|
||||||
testSTABLE:
|
|
||||||
stage: test
|
|
||||||
script:
|
|
||||||
- npmci test stable
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
|
|
||||||
release:
|
release:
|
||||||
stage: release
|
stage: release
|
||||||
script:
|
script:
|
||||||
- npmci publish
|
- npmci node install stable
|
||||||
|
- npmci npm publish
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- docker
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
|
# ====================
|
||||||
|
# metadata stage
|
||||||
|
# ====================
|
||||||
|
codequality:
|
||||||
|
stage: metadata
|
||||||
|
allow_failure: true
|
||||||
|
script:
|
||||||
|
- npmci command npm install -g tslint typescript
|
||||||
|
- npmci npm install
|
||||||
|
- npmci command "tslint -c tslint.json ./ts/**/*.ts"
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
- priv
|
||||||
|
|
||||||
|
trigger:
|
||||||
|
stage: metadata
|
||||||
|
script:
|
||||||
|
- npmci trigger
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
- notpriv
|
||||||
|
|
||||||
pages:
|
pages:
|
||||||
image: hosttoday/ht-docker-node:npmpage
|
image: hosttoday/ht-docker-dbase:npmci
|
||||||
stage: page
|
services:
|
||||||
|
- docker:stable-dind
|
||||||
|
stage: metadata
|
||||||
script:
|
script:
|
||||||
- npmci command npmpage --host gitlab
|
- npmci command npm install -g @gitzone/tsdoc
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci npm install
|
||||||
|
- npmci command tsdoc
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
- notpriv
|
||||||
only:
|
only:
|
||||||
- tags
|
- tags
|
||||||
artifacts:
|
artifacts:
|
||||||
expire_in: 1 week
|
expire_in: 1 week
|
||||||
paths:
|
paths:
|
||||||
- public
|
- public
|
||||||
|
allow_failure: true
|
||||||
|
4
.snyk
Normal file
4
.snyk
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
# Snyk (https://snyk.io) policy file, patches or ignores known vulnerabilities.
|
||||||
|
version: v1.12.0
|
||||||
|
ignore: {}
|
||||||
|
patch: {}
|
70
README.md
70
README.md
@ -1,47 +1,61 @@
|
|||||||
# npmextra
|
# @pushrocks/npmextra
|
||||||
do more with npm.
|
do more with npm
|
||||||
|
|
||||||
npmextra is a hub for a series of js tools that help writing, documenting and maintaining npm modules.
|
## Availabililty and Links
|
||||||
|
* [npmjs.org (npm package)](https://www.npmjs.com/package/@pushrocks/npmextra)
|
||||||
## Availabililty
|
* [gitlab.com (source)](https://gitlab.com/pushrocks/npmextra)
|
||||||
[](https://www.npmjs.com/package/npmextra)
|
* [github.com (source mirror)](https://github.com/pushrocks/npmextra)
|
||||||
[](https://gitlab.com/pushrocks/npmextra)
|
* [docs (typedoc)](https://pushrocks.gitlab.io/npmextra/)
|
||||||
[](https://github.com/pushrocks/npmextra)
|
|
||||||
[](https://pushrocks.gitlab.io/npmextra/)
|
|
||||||
|
|
||||||
## Status for master
|
## Status for master
|
||||||
[](https://gitlab.com/pushrocks/npmextra/commits/master)
|
[](https://gitlab.com/pushrocks/npmextra/commits/master)
|
||||||
[](https://gitlab.com/pushrocks/npmextra/commits/master)
|
[](https://gitlab.com/pushrocks/npmextra/commits/master)
|
||||||
[](https://david-dm.org/pushrocks/npmextra)
|
[](https://www.npmjs.com/package/@pushrocks/npmextra)
|
||||||
[](https://www.bithound.io/github/pushrocks/npmextra/master/dependencies/npm)
|
[](https://snyk.io/test/npm/@pushrocks/npmextra)
|
||||||
[](https://www.bithound.io/github/pushrocks/npmextra)
|
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
[](https://nodejs.org/dist/latest-v6.x/docs/api/)
|
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
[](https://nodejs.org/dist/latest-v6.x/docs/api/)
|
[](https://prettier.io/)
|
||||||
[](http://standardjs.com/)
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
|
Use TypeScript for best in class instellisense.
|
||||||
|
|
||||||
|
## Using npmextra for managing toolconfigs
|
||||||
|
|
||||||
The main purpose of npmextra is to configure different tools using one npmextra.json. This way complex setups avoid additional complexity caused by too many configuration files.
|
The main purpose of npmextra is to configure different tools using one npmextra.json. This way complex setups avoid additional complexity caused by too many configuration files.
|
||||||
|
|
||||||
npmextra.json
|
npmextra.json
|
||||||
|
|
||||||
```json
|
```json
|
||||||
{
|
{
|
||||||
"sometool": {
|
"sometool": {
|
||||||
"defaultKey1": "awesomeValueFromConfig"
|
"defaultKey1": "awesomeValueFromConfig"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
```typescript
|
```typescript
|
||||||
import * as npmextra from 'npmextra'
|
import { Npmextra } from 'npmextra';
|
||||||
|
|
||||||
npmextra.dataFor({
|
let myNpmExtra = new Npmextra('my/path/to/cwd'); // cwd argument is optional
|
||||||
toolName:'sometool',
|
mergedData = myNpmExtra.dataFor('sometool', {
|
||||||
defaultSettings: { // gets merged with whatever is in the configfile
|
// gets merged with whatever is in the configfile
|
||||||
defaultKey1: 'defaultValue1', // so this will get overwritten with "awesomeValueFromConfig"
|
defaultKey1: 'defaultValue1', // so this will get overwritten with "awesomeValueFromConfig"
|
||||||
defaultKey2: 'defaultValue2' // this one will pass through unaltered
|
defaultKey2: 'defaultValue2' // this one will pass through unaltered
|
||||||
},
|
});
|
||||||
cwd?: string // lets you specifiy a custom current working directory to look for the npmextra.json
|
|
||||||
})
|
|
||||||
```
|
```
|
||||||
|
|
||||||
[](https://push.rocks)
|
### Tools that already use the config feature of npmextra
|
||||||
|
|
||||||
|
- [npmts](https://www.npmjs.com/package/npmts)
|
||||||
|
- [npmci](https://www.npmjs.com/package/npmci)
|
||||||
|
- [npmdocker](https://www.npmjs.com/package/npmdocker)
|
||||||
|
|
||||||
|
## Using the KeyValueStore
|
||||||
|
|
||||||
|
For further information read the linked docs at the top of this readme.
|
||||||
|
|
||||||
|
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
|
||||||
|
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
|
||||||
|
|
||||||
|
[](https://maintainedby.lossless.com)
|
||||||
|
16
dist/index.d.ts
vendored
16
dist/index.d.ts
vendored
@ -1,16 +0,0 @@
|
|||||||
export interface IDataFor {
|
|
||||||
toolName: string;
|
|
||||||
defaultSettings?: any;
|
|
||||||
cwd?: string;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* gets you the configuration data for
|
|
||||||
* @executes SYNC
|
|
||||||
*/
|
|
||||||
export declare let dataFor: <IOptions>(optionsArg: IDataFor) => IOptions;
|
|
||||||
/**
|
|
||||||
* tells you if a configfile is present
|
|
||||||
*/
|
|
||||||
export declare let configFilePresent: (optionsArg: {
|
|
||||||
cwd?: string;
|
|
||||||
}) => boolean;
|
|
65
dist/index.js
vendored
65
dist/index.js
vendored
@ -1,65 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./npmextra.plugins");
|
|
||||||
const paths = require("./npmextra.paths");
|
|
||||||
/**
|
|
||||||
* gets you the configuration data for
|
|
||||||
* @executes SYNC
|
|
||||||
*/
|
|
||||||
exports.dataFor = (optionsArg) => {
|
|
||||||
// handle default settings
|
|
||||||
if (typeof optionsArg.toolName !== undefined
|
|
||||||
&& typeof optionsArg.defaultSettings !== undefined) {
|
|
||||||
let newDefaultOptions = {};
|
|
||||||
newDefaultOptions[optionsArg.toolName] = optionsArg.defaultSettings;
|
|
||||||
optionsArg.defaultSettings = newDefaultOptions;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
// set lookup path
|
|
||||||
let lookupPath;
|
|
||||||
if (optionsArg.cwd) {
|
|
||||||
lookupPath = plugins.path.join(optionsArg.cwd, 'npmextra.json');
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
lookupPath = paths.configFile;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
// get allData
|
|
||||||
let allData;
|
|
||||||
if (plugins.smartfile.fs.fileExistsSync(lookupPath)) {
|
|
||||||
allData = plugins.smartfile.fs.toObjectSync(lookupPath);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
plugins.beautylog.warn(`${lookupPath} is missing!`);
|
|
||||||
allData = {};
|
|
||||||
}
|
|
||||||
;
|
|
||||||
// assign all data
|
|
||||||
allData = plugins.lodash.merge({}, optionsArg.defaultSettings, allData);
|
|
||||||
if (optionsArg.toolName) {
|
|
||||||
if (allData[optionsArg.toolName]) {
|
|
||||||
return allData[optionsArg.toolName];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
plugins.beautylog.error(`There is no data for ${optionsArg.toolName}`);
|
|
||||||
return undefined;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
return allData;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* tells you if a configfile is present
|
|
||||||
*/
|
|
||||||
exports.configFilePresent = (optionsArg) => {
|
|
||||||
let lookupPath;
|
|
||||||
if (optionsArg.cwd) {
|
|
||||||
lookupPath = plugins.path.join(optionsArg.cwd, 'npmextra.json');
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
lookupPath = paths.configFile;
|
|
||||||
}
|
|
||||||
;
|
|
||||||
return plugins.smartfile.fs.fileExistsSync(lookupPath);
|
|
||||||
};
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsOENBQTZDO0FBQzdDLDBDQUF5QztBQVF6Qzs7O0dBR0c7QUFDUSxRQUFBLE9BQU8sR0FBRyxDQUFXLFVBQW9CO0lBRWhELDBCQUEwQjtJQUMxQixFQUFFLENBQUMsQ0FDQyxPQUFPLFVBQVUsQ0FBQyxRQUFRLEtBQUssU0FBUztXQUNyQyxPQUFPLFVBQVUsQ0FBQyxlQUFlLEtBQUssU0FDN0MsQ0FBQyxDQUFDLENBQUM7UUFDQyxJQUFJLGlCQUFpQixHQUFHLEVBQUUsQ0FBQTtRQUMxQixpQkFBaUIsQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLEdBQUcsVUFBVSxDQUFDLGVBQWUsQ0FBQTtRQUNuRSxVQUFVLENBQUMsZUFBZSxHQUFHLGlCQUFpQixDQUFBO0lBQ2xELENBQUM7SUFBQSxDQUFDO0lBRUYsa0JBQWtCO0lBQ2xCLElBQUksVUFBa0IsQ0FBQTtJQUN0QixFQUFFLENBQUMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNqQixVQUFVLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBQyxlQUFlLENBQUMsQ0FBQTtJQUNsRSxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixVQUFVLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQTtJQUNqQyxDQUFDO0lBQUEsQ0FBQztJQUVGLGNBQWM7SUFDZCxJQUFJLE9BQU8sQ0FBQTtJQUNYLEVBQUUsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDbEQsT0FBTyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsRUFBRSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQTtJQUMzRCxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxHQUFHLFVBQVUsY0FBYyxDQUFDLENBQUE7UUFDbkQsT0FBTyxHQUFHLEVBQUUsQ0FBQTtJQUNoQixDQUFDO0lBQUEsQ0FBQztJQUVGLGtCQUFrQjtJQUNsQixPQUFPLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxFQUFDLFVBQVUsQ0FBQyxlQUFlLEVBQUMsT0FBTyxDQUFDLENBQUE7SUFDckUsRUFBRSxDQUFDLENBQUMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUM7UUFDdEIsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDL0IsTUFBTSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUE7UUFDdkMsQ0FBQztRQUFDLElBQUksQ0FBQyxDQUFDO1lBQ0osT0FBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsd0JBQXdCLFVBQVUsQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFBO1lBQ3RFLE1BQU0sQ0FBQyxTQUFTLENBQUE7UUFDcEIsQ0FBQztJQUNMLENBQUM7SUFBQyxJQUFJLENBQUMsQ0FBQztRQUNKLE1BQU0sQ0FBQyxPQUFPLENBQUE7SUFDbEIsQ0FBQztBQUNMLENBQUMsQ0FBQTtBQUVEOztHQUVHO0FBQ1EsUUFBQSxpQkFBaUIsR0FBRyxDQUFDLFVBQTBCO0lBQ3RELElBQUksVUFBa0IsQ0FBQTtJQUN0QixFQUFFLENBQUMsQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztRQUNqQixVQUFVLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBQyxlQUFlLENBQUMsQ0FBQTtJQUNsRSxDQUFDO0lBQUMsSUFBSSxDQUFDLENBQUM7UUFDSixVQUFVLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQTtJQUNqQyxDQUFDO0lBQUEsQ0FBQztJQUNGLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUUsQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLENBQUE7QUFDMUQsQ0FBQyxDQUFBIn0=
|
|
6
dist/npmextra.classes.keyValueStore.d.ts
vendored
6
dist/npmextra.classes.keyValueStore.d.ts
vendored
@ -1,6 +0,0 @@
|
|||||||
export declare type keyValueStoreTypes = 'path' | 'gitProject';
|
|
||||||
export declare class KeyValueStore {
|
|
||||||
constructor(optionsArg: {
|
|
||||||
type: keyValueStoreTypes;
|
|
||||||
});
|
|
||||||
}
|
|
22
dist/npmextra.classes.keyValueStore.js
vendored
22
dist/npmextra.classes.keyValueStore.js
vendored
@ -1,22 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
/**
|
|
||||||
* reads a keyValueFile from disk
|
|
||||||
*/
|
|
||||||
let kvRead = () => {
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* writes a key value file to disk
|
|
||||||
*/
|
|
||||||
let kvWrite = () => {
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* wipes a key value store from disk
|
|
||||||
*/
|
|
||||||
let kevWipe = () => {
|
|
||||||
};
|
|
||||||
class KeyValueStore {
|
|
||||||
constructor(optionsArg) {
|
|
||||||
}
|
|
||||||
}
|
|
||||||
exports.KeyValueStore = KeyValueStore;
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZXh0cmEuY2xhc3Nlcy5rZXlWYWx1ZVN0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvbnBtZXh0cmEuY2xhc3Nlcy5rZXlWYWx1ZVN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFJQTs7R0FFRztBQUNILElBQUksTUFBTSxHQUFHO0FBRWIsQ0FBQyxDQUFBO0FBRUQ7O0dBRUc7QUFDSCxJQUFJLE9BQU8sR0FBRztBQUVkLENBQUMsQ0FBQTtBQUVEOztHQUVHO0FBQ0gsSUFBSSxPQUFPLEdBQUc7QUFFZCxDQUFDLENBQUE7QUFFRDtJQUNJLFlBQVksVUFFWDtJQUVELENBQUM7Q0FDSjtBQU5ELHNDQU1DIn0=
|
|
3
dist/npmextra.paths.d.ts
vendored
3
dist/npmextra.paths.d.ts
vendored
@ -1,3 +0,0 @@
|
|||||||
export declare let cwd: string;
|
|
||||||
export declare let packageDir: string;
|
|
||||||
export declare let configFile: string;
|
|
8
dist/npmextra.paths.js
vendored
8
dist/npmextra.paths.js
vendored
@ -1,8 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
const plugins = require("./npmextra.plugins");
|
|
||||||
// directories
|
|
||||||
exports.cwd = process.cwd();
|
|
||||||
exports.packageDir = plugins.path.join(__dirname, '../');
|
|
||||||
// files
|
|
||||||
exports.configFile = plugins.path.join(exports.cwd, 'npmextra.json');
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZXh0cmEucGF0aHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi90cy9ucG1leHRyYS5wYXRocy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsOENBQTZDO0FBRTdDLGNBQWM7QUFDSCxRQUFBLEdBQUcsR0FBRyxPQUFPLENBQUMsR0FBRyxFQUFFLENBQUE7QUFDbkIsUUFBQSxVQUFVLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFDLEtBQUssQ0FBQyxDQUFBO0FBRTFELFFBQVE7QUFDRyxRQUFBLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxXQUFHLEVBQUMsZUFBZSxDQUFDLENBQUEifQ==
|
|
6
dist/npmextra.plugins.d.ts
vendored
6
dist/npmextra.plugins.d.ts
vendored
@ -1,6 +0,0 @@
|
|||||||
import 'typings-global';
|
|
||||||
export import beautylog = require('beautylog');
|
|
||||||
export import lodash = require('lodash');
|
|
||||||
export import path = require('path');
|
|
||||||
export import smartfile = require('smartfile');
|
|
||||||
export import q = require('q');
|
|
8
dist/npmextra.plugins.js
vendored
8
dist/npmextra.plugins.js
vendored
@ -1,8 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-global");
|
|
||||||
exports.beautylog = require("beautylog");
|
|
||||||
exports.lodash = require("lodash");
|
|
||||||
exports.path = require("path");
|
|
||||||
exports.smartfile = require("smartfile");
|
|
||||||
exports.q = require("q");
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnBtZXh0cmEucGx1Z2lucy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3RzL25wbWV4dHJhLnBsdWdpbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLDBCQUF1QjtBQUN2Qix5Q0FBOEM7QUFDOUMsbUNBQXdDO0FBQ3hDLCtCQUFvQztBQUNwQyx5Q0FBOEM7QUFDOUMseUJBQThCIn0=
|
|
21
npmextra.json
Normal file
21
npmextra.json
Normal file
@ -0,0 +1,21 @@
|
|||||||
|
{
|
||||||
|
"npmci": {
|
||||||
|
"globalNpmTools": [],
|
||||||
|
"npmAccessLevel": "public"
|
||||||
|
},
|
||||||
|
"npmts": {
|
||||||
|
"testConfig": {
|
||||||
|
"parallel": false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"gitzone": {
|
||||||
|
"module": {
|
||||||
|
"githost": "gitlab.com",
|
||||||
|
"gitscope": "pushrocks",
|
||||||
|
"gitrepo": "npmextra",
|
||||||
|
"shortDescription": "do more with npm",
|
||||||
|
"npmPackagename": "@pushrocks/npmextra",
|
||||||
|
"license": "MIT"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
1692
package-lock.json
generated
Normal file
1692
package-lock.json
generated
Normal file
File diff suppressed because it is too large
Load Diff
42
package.json
42
package.json
@ -1,11 +1,13 @@
|
|||||||
{
|
{
|
||||||
"name": "npmextra",
|
"name": "@pushrocks/npmextra",
|
||||||
"version": "1.0.12",
|
"version": "3.0.7",
|
||||||
|
"private": false,
|
||||||
"description": "do more with npm",
|
"description": "do more with npm",
|
||||||
"main": "dist/index.js",
|
"main": "dist/index.js",
|
||||||
"typings": "dist/index.d.ts",
|
"typings": "dist/index.d.ts",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(npmts)"
|
"test": "(tstest test/)",
|
||||||
|
"build": "(tsbuild)"
|
||||||
},
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
@ -18,16 +20,30 @@
|
|||||||
},
|
},
|
||||||
"homepage": "https://gitlab.com/pushrocks/npmextra#README",
|
"homepage": "https://gitlab.com/pushrocks/npmextra#README",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@types/q": "^0.x.x",
|
"@pushrocks/smartfile": "^7.0.4",
|
||||||
"beautylog": "^5.0.20",
|
"@pushrocks/smartlog": "^2.0.19",
|
||||||
"lodash": "^4.15.0",
|
"@pushrocks/smartpath": "^4.0.1",
|
||||||
"q": "^1.4.1",
|
"@pushrocks/smartpromise": "^3.0.5",
|
||||||
"smartfile": "^4.0.13",
|
"@pushrocks/taskbuffer": "^2.0.10"
|
||||||
"typings-global": "^1.0.6"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/should": "^8.1.27",
|
"@gitzone/tsbuild": "^2.1.17",
|
||||||
"should": "^11.1.0",
|
"@gitzone/tsrun": "^1.2.8",
|
||||||
"typings-test": "^1.0.1"
|
"@gitzone/tstest": "^1.0.24",
|
||||||
}
|
"@pushrocks/tapbundle": "^3.0.13",
|
||||||
|
"@types/node": "^12.7.5",
|
||||||
|
"tslint": "^5.20.0",
|
||||||
|
"tslint-config-prettier": "^1.18.0"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"ts/*",
|
||||||
|
"ts_web/*",
|
||||||
|
"dist/*",
|
||||||
|
"dist_web/*",
|
||||||
|
"dist_ts_web/*",
|
||||||
|
"assets/*",
|
||||||
|
"cli.js",
|
||||||
|
"npmextra.json",
|
||||||
|
"readme.md"
|
||||||
|
]
|
||||||
}
|
}
|
||||||
|
2
test/test.d.ts
vendored
2
test/test.d.ts
vendored
@ -1,2 +0,0 @@
|
|||||||
import "typings-test";
|
|
||||||
import "should";
|
|
25
test/test.js
25
test/test.js
@ -1,25 +0,0 @@
|
|||||||
"use strict";
|
|
||||||
require("typings-test");
|
|
||||||
const path = require("path");
|
|
||||||
require("should");
|
|
||||||
const npmExtra = require("../dist/index");
|
|
||||||
describe("npmextra", function () {
|
|
||||||
it("should read a config file", function () {
|
|
||||||
let testData = npmExtra.dataFor({
|
|
||||||
toolName: "testTool",
|
|
||||||
defaultSettings: { someKey2: "someValue2" },
|
|
||||||
cwd: path.join(process.cwd(), "test/")
|
|
||||||
});
|
|
||||||
testData.should.have.ownProperty("someKey2");
|
|
||||||
});
|
|
||||||
it("should read a config file", function () {
|
|
||||||
let testData = npmExtra.dataFor({
|
|
||||||
toolName: "testTool",
|
|
||||||
defaultSettings: { someKey2: "someValue2" },
|
|
||||||
cwd: path.join(process.cwd(), "test/")
|
|
||||||
});
|
|
||||||
testData.should.have.ownProperty("someKey2");
|
|
||||||
testData.testValue.should.equal(2);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbInRlc3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLHdCQUFzQjtBQUN0Qiw2QkFBOEI7QUFDOUIsa0JBQWdCO0FBRWhCLDBDQUEyQztBQUUzQyxRQUFRLENBQUMsVUFBVSxFQUFDO0lBQ2hCLEVBQUUsQ0FBQywyQkFBMkIsRUFBQztRQUMzQixJQUFJLFFBQVEsR0FBRyxRQUFRLENBQUMsT0FBTyxDQUFDO1lBQzVCLFFBQVEsRUFBQyxVQUFVO1lBQ25CLGVBQWUsRUFBQyxFQUFDLFFBQVEsRUFBQyxZQUFZLEVBQUM7WUFDdkMsR0FBRyxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRSxFQUFDLE9BQU8sQ0FBQztTQUN4QyxDQUFDLENBQUM7UUFDSCxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDakQsQ0FBQyxDQUFDLENBQUM7SUFDSCxFQUFFLENBQUMsMkJBQTJCLEVBQUM7UUFDM0IsSUFBSSxRQUFRLEdBQUcsUUFBUSxDQUFDLE9BQU8sQ0FBQztZQUM1QixRQUFRLEVBQUMsVUFBVTtZQUNuQixlQUFlLEVBQUMsRUFBQyxRQUFRLEVBQUMsWUFBWSxFQUFDO1lBQ3ZDLEdBQUcsRUFBRSxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsRUFBQyxPQUFPLENBQUM7U0FDeEMsQ0FBQyxDQUFDO1FBQ0gsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQzdDLFFBQVEsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUN2QyxDQUFDLENBQUMsQ0FBQztBQUNQLENBQUMsQ0FBQyxDQUFDIn0=
|
|
25
test/test.kvstore.ts
Normal file
25
test/test.kvstore.ts
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
import { expect, tap } from '@pushrocks/tapbundle';
|
||||||
|
|
||||||
|
import * as npmextra from '../ts/index';
|
||||||
|
|
||||||
|
let myKeyValueStore: npmextra.KeyValueStore;
|
||||||
|
|
||||||
|
tap.test('should create a keyValueStore', async () => {
|
||||||
|
myKeyValueStore = new npmextra.KeyValueStore('custom', 'test');
|
||||||
|
expect(myKeyValueStore).to.be.instanceof(npmextra.KeyValueStore);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('expect result to be empty', async () => {
|
||||||
|
let result = myKeyValueStore.readAll();
|
||||||
|
// tslint:disable-next-line:no-unused-expression
|
||||||
|
expect(result).to.be.empty;
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('expect to add an object to the kv Store', async () => {
|
||||||
|
await myKeyValueStore.writeAll({
|
||||||
|
myKey: 'myValue'
|
||||||
|
});
|
||||||
|
await expect(myKeyValueStore.readKey('myKey')).to.eventually.equal('myValue');
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.start();
|
54
test/test.ts
54
test/test.ts
@ -1,25 +1,33 @@
|
|||||||
import "typings-test";
|
import { expect, tap } from '@pushrocks/tapbundle';
|
||||||
import path = require("path");
|
import path = require('path');
|
||||||
import "should";
|
|
||||||
|
|
||||||
import npmExtra = require("../dist/index");
|
// module to test
|
||||||
|
import npmExtra = require('../ts/index');
|
||||||
|
|
||||||
describe("npmextra",function(){
|
let testNpmextra: npmExtra.Npmextra;
|
||||||
it("should read a config file",function(){
|
|
||||||
let testData = npmExtra.dataFor({
|
tap.test('should create a new Npmtextra instance', async () => {
|
||||||
toolName:"testTool",
|
testNpmextra = new npmExtra.Npmextra('./test/');
|
||||||
defaultSettings:{someKey2:"someValue2"},
|
expect(testNpmextra).be.instanceof(npmExtra.Npmextra);
|
||||||
cwd: path.join(process.cwd(),"test/")
|
});
|
||||||
});
|
|
||||||
testData.should.have.ownProperty("someKey2");
|
tap.test('should state wether a npmextra.json exists', async () => {
|
||||||
});
|
// tslint:disable-next-line:no-unused-expression
|
||||||
it("should read a config file",function(){
|
expect(testNpmextra.npmextraJsonExists).be.true;
|
||||||
let testData = npmExtra.dataFor({
|
});
|
||||||
toolName:"testTool",
|
|
||||||
defaultSettings:{someKey2:"someValue2"},
|
tap.test('should pass through default value, if not overriden by config from file', async () => {
|
||||||
cwd: path.join(process.cwd(),"test/")
|
let testData = testNpmextra.dataFor('testTool', { someKey2: 'someValue2' });
|
||||||
});
|
console.log(testData);
|
||||||
testData.should.have.ownProperty("someKey2");
|
expect(testData).have.ownProperty('someKey2');
|
||||||
testData.testValue.should.equal(2);
|
});
|
||||||
});
|
|
||||||
});
|
tap.test('should read a config file', async () => {
|
||||||
|
let testData = testNpmextra.dataFor<any>('testTool', {
|
||||||
|
someKey2: 'someValue2'
|
||||||
|
});
|
||||||
|
expect(testData).have.ownProperty('someKey2');
|
||||||
|
expect(testData.testValue).equal(2);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.start();
|
||||||
|
70
ts/index.ts
70
ts/index.ts
@ -1,68 +1,4 @@
|
|||||||
import * as plugins from './npmextra.plugins'
|
import * as plugins from './npmextra.plugins';
|
||||||
import * as paths from './npmextra.paths'
|
|
||||||
|
|
||||||
export interface IDataFor {
|
export * from './npmextra.classes.npmextra';
|
||||||
toolName: string
|
export * from './npmextra.classes.keyvaluestore';
|
||||||
defaultSettings?
|
|
||||||
cwd?: string
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* gets you the configuration data for
|
|
||||||
* @executes SYNC
|
|
||||||
*/
|
|
||||||
export let dataFor = <IOptions>(optionsArg: IDataFor): IOptions => {
|
|
||||||
|
|
||||||
// handle default settings
|
|
||||||
if (
|
|
||||||
typeof optionsArg.toolName !== undefined
|
|
||||||
&& typeof optionsArg.defaultSettings !== undefined
|
|
||||||
) {
|
|
||||||
let newDefaultOptions = {}
|
|
||||||
newDefaultOptions[optionsArg.toolName] = optionsArg.defaultSettings
|
|
||||||
optionsArg.defaultSettings = newDefaultOptions
|
|
||||||
};
|
|
||||||
|
|
||||||
// set lookup path
|
|
||||||
let lookupPath: string
|
|
||||||
if (optionsArg.cwd) {
|
|
||||||
lookupPath = plugins.path.join(optionsArg.cwd,'npmextra.json')
|
|
||||||
} else {
|
|
||||||
lookupPath = paths.configFile
|
|
||||||
};
|
|
||||||
|
|
||||||
// get allData
|
|
||||||
let allData
|
|
||||||
if (plugins.smartfile.fs.fileExistsSync(lookupPath)) {
|
|
||||||
allData = plugins.smartfile.fs.toObjectSync(lookupPath)
|
|
||||||
} else {
|
|
||||||
plugins.beautylog.warn(`${lookupPath} is missing!`)
|
|
||||||
allData = {}
|
|
||||||
};
|
|
||||||
|
|
||||||
// assign all data
|
|
||||||
allData = plugins.lodash.merge({},optionsArg.defaultSettings,allData)
|
|
||||||
if (optionsArg.toolName) {
|
|
||||||
if (allData[optionsArg.toolName]) {
|
|
||||||
return allData[optionsArg.toolName]
|
|
||||||
} else {
|
|
||||||
plugins.beautylog.error(`There is no data for ${optionsArg.toolName}`)
|
|
||||||
return undefined
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
return allData
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* tells you if a configfile is present
|
|
||||||
*/
|
|
||||||
export let configFilePresent = (optionsArg: {cwd?: string}): boolean => {
|
|
||||||
let lookupPath: string
|
|
||||||
if (optionsArg.cwd) {
|
|
||||||
lookupPath = plugins.path.join(optionsArg.cwd,'npmextra.json')
|
|
||||||
} else {
|
|
||||||
lookupPath = paths.configFile
|
|
||||||
};
|
|
||||||
return plugins.smartfile.fs.fileExistsSync(lookupPath)
|
|
||||||
}
|
|
||||||
|
@ -1,32 +0,0 @@
|
|||||||
import * as plugins from './npmextra.plugins'
|
|
||||||
|
|
||||||
export type keyValueStoreTypes = 'path' | 'gitProject'
|
|
||||||
|
|
||||||
/**
|
|
||||||
* reads a keyValueFile from disk
|
|
||||||
*/
|
|
||||||
let kvRead = () => {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* writes a key value file to disk
|
|
||||||
*/
|
|
||||||
let kvWrite = () => {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* wipes a key value store from disk
|
|
||||||
*/
|
|
||||||
let kevWipe = () => {
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
export class KeyValueStore {
|
|
||||||
constructor(optionsArg: {
|
|
||||||
type: keyValueStoreTypes
|
|
||||||
}) {
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
112
ts/npmextra.classes.keyvaluestore.ts
Normal file
112
ts/npmextra.classes.keyvaluestore.ts
Normal file
@ -0,0 +1,112 @@
|
|||||||
|
import * as plugins from './npmextra.plugins';
|
||||||
|
import * as paths from './npmextra.paths';
|
||||||
|
|
||||||
|
import { Task } from '@pushrocks/taskbuffer';
|
||||||
|
|
||||||
|
export type TKeyValueStore = 'path' | 'gitProject' | 'custom';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* kvStore is a simple key vlaue store to store data about projects between runs
|
||||||
|
*/
|
||||||
|
export class KeyValueStore {
|
||||||
|
private dataObject: any = {};
|
||||||
|
private deletedObject: any = {};
|
||||||
|
public syncTask = new Task({
|
||||||
|
name: 'syncTask',
|
||||||
|
buffered: true,
|
||||||
|
bufferMax: 2,
|
||||||
|
execDelay: 500,
|
||||||
|
taskFunction: async () => {
|
||||||
|
this.dataObject = {
|
||||||
|
...plugins.smartfile.fs.toObjectSync(this.filePath),
|
||||||
|
...this.dataObject
|
||||||
|
};
|
||||||
|
for (const key of Object.keys(this.deletedObject)) {
|
||||||
|
delete this.dataObject[key];
|
||||||
|
}
|
||||||
|
this.deletedObject = {};
|
||||||
|
await plugins.smartfile.memory.toFs(JSON.stringify(this.dataObject), this.filePath);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
/**
|
||||||
|
* computes the identity
|
||||||
|
*/
|
||||||
|
private initFilePath = () => {
|
||||||
|
// determine the right base directory
|
||||||
|
let baseDir: string;
|
||||||
|
if (this.type === 'custom') {
|
||||||
|
baseDir = paths.kvCustomDir;
|
||||||
|
} else if (this.type === 'gitProject') {
|
||||||
|
baseDir = paths.kvGitDir;
|
||||||
|
} else if (this.type === 'path') {
|
||||||
|
baseDir = paths.kvPathDir;
|
||||||
|
}
|
||||||
|
this.filePath = plugins.path.join(baseDir, this.identity + '.json');
|
||||||
|
plugins.smartfile.fs.ensureDirSync(paths.kvCustomDir);
|
||||||
|
plugins.smartfile.fs.ensureDirSync(paths.kvGitDir);
|
||||||
|
plugins.smartfile.fs.ensureDirSync(paths.kvPathDir);
|
||||||
|
plugins.smartfile.fs.ensureFileSync(this.filePath, '{}');
|
||||||
|
};
|
||||||
|
|
||||||
|
public type: TKeyValueStore; // the type of the kvStore
|
||||||
|
public identity: string; // the identity of the kvStore
|
||||||
|
public filePath: string; // the filePath of the kvStore
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the constructor of keyvalue store
|
||||||
|
* @param typeArg
|
||||||
|
* @param customStringArg
|
||||||
|
*/
|
||||||
|
constructor(typeArg: TKeyValueStore, customStringArg: string) {
|
||||||
|
// set kvStoreType
|
||||||
|
this.type = typeArg;
|
||||||
|
this.identity = customStringArg;
|
||||||
|
this.initFilePath();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* reads all keyValue pairs at once and returns them
|
||||||
|
*/
|
||||||
|
public async readAll() {
|
||||||
|
await this.syncTask.trigger();
|
||||||
|
return this.dataObject;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* reads a keyValueFile from disk
|
||||||
|
*/
|
||||||
|
public async readKey(keyArg: string) {
|
||||||
|
await this.syncTask.trigger();
|
||||||
|
return this.dataObject[keyArg];
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* writes a specific key to the keyValueStore
|
||||||
|
*/
|
||||||
|
public async writeKey(keyArg: string, valueArg: any) {
|
||||||
|
await this.writeAll({
|
||||||
|
[keyArg]: valueArg
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
public async deleteKey(keyArg: string) {
|
||||||
|
this.deletedObject[keyArg] = this.dataObject[keyArg];
|
||||||
|
await this.syncTask.trigger();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* writes all keyValue pairs in the object argument
|
||||||
|
*/
|
||||||
|
public async writeAll(keyValueObject) {
|
||||||
|
this.dataObject = { ...this.dataObject, ...keyValueObject };
|
||||||
|
await this.syncTask.trigger();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* wipes a key value store from disk
|
||||||
|
*/
|
||||||
|
public async wipe() {
|
||||||
|
this.dataObject = {};
|
||||||
|
await plugins.smartfile.fs.remove(this.filePath);
|
||||||
|
}
|
||||||
|
}
|
72
ts/npmextra.classes.npmextra.ts
Normal file
72
ts/npmextra.classes.npmextra.ts
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
import * as plugins from './npmextra.plugins';
|
||||||
|
import * as paths from './npmextra.paths';
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Npmextra class allows easy configuration of tools
|
||||||
|
*/
|
||||||
|
export class Npmextra {
|
||||||
|
cwd: string;
|
||||||
|
lookupPath: string;
|
||||||
|
npmextraJsonExists: boolean;
|
||||||
|
npmextraJsonData: any;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* creates instance of Npmextra
|
||||||
|
*/
|
||||||
|
constructor(cwdArg?: string) {
|
||||||
|
if (cwdArg) {
|
||||||
|
this.cwd = cwdArg;
|
||||||
|
} else {
|
||||||
|
this.cwd = paths.cwd;
|
||||||
|
}
|
||||||
|
this.checkLookupPath();
|
||||||
|
this.checkNpmextraJsonExists();
|
||||||
|
this.checkNpmextraJsonData();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* merges the supplied options with the ones from npmextra.json
|
||||||
|
*/
|
||||||
|
dataFor<IToolConfig>(toolnameArg: string, defaultOptionsArg: any): IToolConfig {
|
||||||
|
let npmextraToolOptions;
|
||||||
|
if (this.npmextraJsonData[toolnameArg]) {
|
||||||
|
npmextraToolOptions = this.npmextraJsonData[toolnameArg];
|
||||||
|
} else {
|
||||||
|
npmextraToolOptions = {};
|
||||||
|
}
|
||||||
|
let mergedOptions = {
|
||||||
|
...defaultOptionsArg,
|
||||||
|
...npmextraToolOptions
|
||||||
|
};
|
||||||
|
return mergedOptions;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* checks if the JSON exists
|
||||||
|
*/
|
||||||
|
private checkNpmextraJsonExists() {
|
||||||
|
this.npmextraJsonExists = plugins.smartfile.fs.fileExistsSync(this.lookupPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gets lookupPath
|
||||||
|
*/
|
||||||
|
private checkLookupPath() {
|
||||||
|
if (this.cwd) {
|
||||||
|
this.lookupPath = plugins.path.join(this.cwd, 'npmextra.json');
|
||||||
|
} else {
|
||||||
|
this.lookupPath = paths.configFile;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* get npmextraJsonData
|
||||||
|
*/
|
||||||
|
private checkNpmextraJsonData() {
|
||||||
|
if (this.npmextraJsonExists) {
|
||||||
|
this.npmextraJsonData = plugins.smartfile.fs.toObjectSync(this.lookupPath);
|
||||||
|
} else {
|
||||||
|
this.npmextraJsonData = {};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
@ -1,8 +1,34 @@
|
|||||||
import * as plugins from './npmextra.plugins'
|
import * as plugins from './npmextra.plugins';
|
||||||
|
|
||||||
// directories
|
// directories
|
||||||
export let cwd = process.cwd()
|
export let cwd = process.cwd();
|
||||||
export let packageDir = plugins.path.join(__dirname,'../')
|
export let packageDir = plugins.path.join(__dirname, '../');
|
||||||
|
|
||||||
|
// ----------------------
|
||||||
|
// keyValueStore specific
|
||||||
|
// ----------------------
|
||||||
|
|
||||||
|
export let home = plugins.smartpath.get.home();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* keyValue base path
|
||||||
|
*/
|
||||||
|
export let kvBase = plugins.path.join(home, '.npmextra/kv');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the base directory for custom string based key value store
|
||||||
|
*/
|
||||||
|
export let kvCustomDir = plugins.path.join(kvBase, 'custom');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* the subdir for git based keyValue
|
||||||
|
*/
|
||||||
|
export let kvGitDir = plugins.path.join(kvBase, 'git');
|
||||||
|
|
||||||
|
/**
|
||||||
|
* keyValue for path based keyValue store
|
||||||
|
*/
|
||||||
|
export let kvPathDir = plugins.path.join(kvBase, 'path');
|
||||||
|
|
||||||
// files
|
// files
|
||||||
export let configFile = plugins.path.join(cwd,'npmextra.json')
|
export let configFile = plugins.path.join(cwd, 'npmextra.json');
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
import 'typings-global'
|
import * as beautylog from '@pushrocks/smartlog';
|
||||||
export import beautylog = require('beautylog')
|
import * as path from 'path';
|
||||||
export import lodash = require('lodash')
|
import * as smartfile from '@pushrocks/smartfile';
|
||||||
export import path = require('path')
|
import * as smartpath from '@pushrocks/smartpath';
|
||||||
export import smartfile = require('smartfile')
|
import * as smartpromise from '@pushrocks/smartpromise';
|
||||||
export import q = require('q')
|
import * as taskbuffer from '@pushrocks/taskbuffer';
|
||||||
|
|
||||||
|
export { beautylog, path, smartfile, smartpath, smartpromise, taskbuffer };
|
||||||
|
18
tslint.json
18
tslint.json
@ -1,3 +1,17 @@
|
|||||||
{
|
{
|
||||||
"extends": "tslint-config-standard"
|
"extends": ["tslint:latest", "tslint-config-prettier"],
|
||||||
}
|
"rules": {
|
||||||
|
"semicolon": [true, "always"],
|
||||||
|
"no-console": false,
|
||||||
|
"ordered-imports": false,
|
||||||
|
"object-literal-sort-keys": false,
|
||||||
|
"member-ordering": {
|
||||||
|
"options":{
|
||||||
|
"order": [
|
||||||
|
"static-method"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defaultSeverity": "warning"
|
||||||
|
}
|
||||||
|
Reference in New Issue
Block a user