Compare commits

...

36 Commits

Author SHA1 Message Date
36bcb9265a 4.0.4 2022-09-13 19:13:04 +02:00
53bf2f3569 fix(core): update 2022-09-13 19:13:04 +02:00
523ab7ee77 4.0.3 2022-09-13 18:47:19 +02:00
d60cc5430f fix(core): update 2022-09-13 18:47:19 +02:00
c0035bb4f3 4.0.2 2022-03-24 19:57:09 +01:00
976f81420f fix(core): update 2022-03-24 19:57:09 +01:00
1be144d099 4.0.1 2022-03-18 23:15:02 +01:00
9d4b7a5292 4.0.0 2022-03-18 23:05:32 +01:00
563d6f0ac3 3.0.26 2022-03-18 22:52:38 +01:00
4da0aeb871 fix(core): update 2022-03-18 22:52:38 +01:00
931defe98a 3.0.25 2022-03-18 22:50:25 +01:00
1e6077ce34 fix(core): update 2022-03-18 22:50:24 +01:00
8b1769d65e 3.0.24 2021-01-22 18:27:51 +00:00
48878c0b38 fix(core): update 2021-01-22 18:27:50 +00:00
76cfc8bec0 3.0.23 2021-01-22 14:46:04 +00:00
7f3118c525 fix(core): update 2021-01-22 14:46:02 +00:00
9d189d1b59 3.0.22 2020-12-31 04:42:47 +00:00
0266afca8e fix(core): update 2020-12-31 04:42:46 +00:00
bef836fc83 3.0.21 2020-12-31 04:25:31 +00:00
2bd1741893 fix(core): update 2020-12-31 04:25:31 +00:00
bd20512b10 3.0.20 2020-12-31 04:11:34 +00:00
25d0ba8036 fix(core): update 2020-12-31 04:11:33 +00:00
c517652122 3.0.19 2020-12-31 03:56:41 +00:00
bf3e640307 fix(core): update 2020-12-31 03:56:40 +00:00
08cb2392fa 3.0.18 2020-01-23 17:14:58 +00:00
4e1fa4efab fix(core): update 2020-01-23 17:14:57 +00:00
26d00bb9d3 3.0.17 2019-11-24 11:44:33 +00:00
fd27ed1a56 fix(core): update 2019-11-24 11:44:32 +00:00
1f31fe9dc5 3.0.16 2019-11-24 11:44:21 +00:00
bd7888f7ce fix(core): update 2019-11-24 11:44:21 +00:00
201812e182 3.0.15 2019-11-24 11:43:32 +00:00
8dfa3f8965 fix(core): update 2019-11-24 11:43:32 +00:00
43d50b746b 3.0.14 2019-10-10 18:24:04 +02:00
a1ee8f37d6 fix(core): update 2019-10-10 18:24:03 +02:00
8d9c75e113 3.0.13 2019-10-10 18:14:08 +02:00
8ff2a9d64a fix(core): update 2019-10-10 18:14:07 +02:00
30 changed files with 12907 additions and 1164 deletions

20
.gitignore vendored
View File

@ -1,4 +1,20 @@
.yarn/ .nogit/
pages/
# artifacts
coverage/
public/ public/
pages/
# installs
node_modules/ node_modules/
# caches
.yarn/
.cache/
.rpt2_cache
# builds
dist/
dist_*/
# custom

View File

@ -1,10 +1,10 @@
# gitzone standard # gitzone ci_default
image: hosttoday/ht-docker-node:npmci image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
cache: cache:
paths: paths:
- .npmci_cache/ - .npmci_cache/
key: "$CI_BUILD_STAGE" key: '$CI_BUILD_STAGE'
stages: stages:
- security - security
@ -12,6 +12,9 @@ stages:
- release - release
- metadata - metadata
before_script:
- npm install -g @shipzone/npmci
# ==================== # ====================
# security stage # security stage
# ==================== # ====================
@ -19,38 +22,42 @@ mirror:
stage: security stage: security
script: script:
- npmci git mirror - npmci git mirror
only:
- tags
tags: tags:
- lossless
- docker - docker
- notpriv - notpriv
snyk: auditProductionDependencies:
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
stage: security stage: security
script: script:
- npmci npm prepare - npmci npm prepare
- npmci command npm install -g snyk - npmci command npm install --production --ignore-scripts
- npmci command npm install --ignore-scripts - npmci command npm config set registry https://registry.npmjs.org
- npmci command snyk test - npmci command npm audit --audit-level=high --only=prod --production
tags: tags:
- docker - docker
- notpriv allow_failure: true
auditDevDependencies:
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
stage: security
script:
- npmci npm prepare
- npmci command npm install --ignore-scripts
- npmci command npm config set registry https://registry.npmjs.org
- npmci command npm audit --audit-level=high --only=dev
tags:
- docker
allow_failure: true
# ==================== # ====================
# test stage # test stage
# ==================== # ====================
testLTS: testStable:
stage: test
script:
- npmci npm prepare
- npmci node install lts
- npmci npm install
- npmci npm test
coverage: /\d+.?\d+?\%\s*coverage/
tags:
- docker
- notpriv
testSTABLE:
stage: test stage: test
script: script:
- npmci npm prepare - npmci npm prepare
@ -60,7 +67,17 @@ testSTABLE:
coverage: /\d+.?\d+?\%\s*coverage/ coverage: /\d+.?\d+?\%\s*coverage/
tags: tags:
- docker - docker
- notpriv
testBuild:
stage: test
script:
- npmci npm prepare
- npmci node install stable
- npmci npm install
- npmci command npm run build
coverage: /\d+.?\d+?\%\s*coverage/
tags:
- docker
release: release:
stage: release stage: release
@ -70,6 +87,7 @@ release:
only: only:
- tags - tags
tags: tags:
- lossless
- docker - docker
- notpriv - notpriv
@ -78,20 +96,15 @@ release:
# ==================== # ====================
codequality: codequality:
stage: metadata stage: metadata
image: docker:stable
allow_failure: true allow_failure: true
services: only:
- docker:stable-dind - tags
script: script:
- export SP_VERSION=$(echo "$CI_SERVER_VERSION" | sed 's/^\([0-9]*\)\.\([0-9]*\).*/\1-\2-stable/') - npmci command npm install -g typescript
- docker run - npmci npm prepare
--env SOURCE_CODE="$PWD" - npmci npm install
--volume "$PWD":/code
--volume /var/run/docker.sock:/var/run/docker.sock
"registry.gitlab.com/gitlab-org/security-products/codequality:$SP_VERSION" /code
artifacts:
paths: [codeclimate.json]
tags: tags:
- lossless
- docker - docker
- priv - priv
@ -102,18 +115,20 @@ trigger:
only: only:
- tags - tags
tags: tags:
- lossless
- docker - docker
- notpriv - notpriv
pages: pages:
image: hosttoday/ht-docker-node:npmci
stage: metadata stage: metadata
script: script:
- npmci command npm install -g typedoc typescript - npmci node install lts
- npmci command npm install -g @gitzone/tsdoc
- npmci npm prepare - npmci npm prepare
- npmci npm install - npmci npm install
- npmci command typedoc --module "commonjs" --target "ES2016" --out public/ ts/ - npmci command tsdoc
tags: tags:
- lossless
- docker - docker
- notpriv - notpriv
only: only:

11
.vscode/launch.json vendored Normal file
View File

@ -0,0 +1,11 @@
{
"version": "0.2.0",
"configurations": [
{
"command": "npm test",
"name": "Run npm test",
"request": "launch",
"type": "node-terminal"
}
]
}

26
.vscode/settings.json vendored Normal file
View File

@ -0,0 +1,26 @@
{
"json.schemas": [
{
"fileMatch": ["/npmextra.json"],
"schema": {
"type": "object",
"properties": {
"npmci": {
"type": "object",
"description": "settings for npmci"
},
"gitzone": {
"type": "object",
"description": "settings for gitzone",
"properties": {
"projectType": {
"type": "string",
"enum": ["website", "element", "service", "npm", "wcc"]
}
}
}
}
}
}
]
}

View File

View File

@ -9,11 +9,12 @@
"dockerSock": false "dockerSock": false
}, },
"gitzone": { "gitzone": {
"projectType": "npm",
"module": { "module": {
"githost": "gitlab.com", "githost": "gitlab.com",
"gitscope": "pushrocks", "gitscope": "pushrocks",
"gitrepo": "smartstring", "gitrepo": "smartstring",
"shortDescription": "handle strings in smart ways. TypeScript ready.", "description": "handle strings in smart ways. TypeScript ready.",
"npmPackagename": "@pushrocks/smartstring", "npmPackagename": "@pushrocks/smartstring",
"license": "MIT" "license": "MIT"
} }

13375
package-lock.json generated

File diff suppressed because it is too large Load Diff

View File

@ -1,13 +1,14 @@
{ {
"name": "@pushrocks/smartstring", "name": "@pushrocks/smartstring",
"version": "3.0.12", "version": "4.0.4",
"private": false, "private": false,
"description": "handle strings in smart ways. TypeScript ready.", "description": "handle strings in smart ways. TypeScript ready.",
"main": "dist/index.js", "main": "dist_ts/index.js",
"typings": "dist/index.d.ts", "typings": "dist_ts/index.d.ts",
"type": "module",
"scripts": { "scripts": {
"test": "(tstest test/)", "test": "(tstest test/)",
"build": "(tsbuild)" "build": "(tsbuild --web --allowimplicitany)"
}, },
"repository": { "repository": {
"type": "git", "type": "git",
@ -24,19 +25,39 @@
}, },
"homepage": "https://gitlab.com/pushrocks/smartstring#readme", "homepage": "https://gitlab.com/pushrocks/smartstring#readme",
"devDependencies": { "devDependencies": {
"@gitzone/tsbuild": "^2.1.17", "@gitzone/tsbuild": "^2.1.65",
"@gitzone/tsrun": "^1.2.8", "@gitzone/tsrun": "^1.2.37",
"@gitzone/tstest": "^1.0.28", "@gitzone/tstest": "^1.0.73",
"@pushrocks/tapbundle": "^3.0.13", "@pushrocks/tapbundle": "^5.0.4",
"@types/node": "^12.7.12", "@types/node": "^18.7.17",
"tslint": "^5.20.0", "tslint": "^6.1.3",
"tslint-config-prettier": "^1.18.0" "tslint-config-prettier": "^1.18.0"
}, },
"dependencies": { "dependencies": {
"crypto-random-string": "^3.0.1", "@pushrocks/isounique": "^1.0.5",
"js-base64": "^2.5.1", "@pushrocks/smartenv": "^5.0.3",
"normalize-newline": "^3.0.0", "@types/randomatic": "^3.1.3",
"buffer": "^6.0.3",
"crypto-random-string": "^4.0.0",
"js-base64": "^3.7.2",
"normalize-newline": "^4.1.0",
"randomatic": "^3.1.1", "randomatic": "^3.1.1",
"strip-indent": "^3.0.0" "strip-indent": "^4.0.0",
} "url": "^0.11.0"
},
"files": [
"ts/**/*",
"ts_web/**/*",
"dist/**/*",
"dist_*/**/*",
"dist_ts/**/*",
"dist_ts_web/**/*",
"assets/**/*",
"cli.js",
"npmextra.json",
"readme.md"
],
"browserslist": [
"last 1 chrome versions"
]
} }

View File

@ -8,13 +8,20 @@ handle strings in smart ways. TypeScript ready.
* [docs (typedoc)](https://pushrocks.gitlab.io/smartstring/) * [docs (typedoc)](https://pushrocks.gitlab.io/smartstring/)
## Status for master ## Status for master
[![build status](https://gitlab.com/pushrocks/smartstring/badges/master/build.svg)](https://gitlab.com/pushrocks/smartstring/commits/master)
[![coverage report](https://gitlab.com/pushrocks/smartstring/badges/master/coverage.svg)](https://gitlab.com/pushrocks/smartstring/commits/master) Status Category | Status Badge
[![npm downloads per month](https://img.shields.io/npm/dm/@pushrocks/smartstring.svg)](https://www.npmjs.com/package/@pushrocks/smartstring) -- | --
[![Known Vulnerabilities](https://snyk.io/test/npm/@pushrocks/smartstring/badge.svg)](https://snyk.io/test/npm/@pushrocks/smartstring) GitLab Pipelines | [![pipeline status](https://gitlab.com/pushrocks/smartstring/badges/master/pipeline.svg)](https://lossless.cloud)
[![TypeScript](https://img.shields.io/badge/TypeScript->=%203.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/) GitLab Pipline Test Coverage | [![coverage report](https://gitlab.com/pushrocks/smartstring/badges/master/coverage.svg)](https://lossless.cloud)
[![node](https://img.shields.io/badge/node->=%2010.x.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/) npm | [![npm downloads per month](https://badgen.net/npm/dy/@pushrocks/smartstring)](https://lossless.cloud)
[![JavaScript Style Guide](https://img.shields.io/badge/code%20style-prettier-ff69b4.svg)](https://prettier.io/) Snyk | [![Known Vulnerabilities](https://badgen.net/snyk/pushrocks/smartstring)](https://lossless.cloud)
TypeScript Support | [![TypeScript](https://badgen.net/badge/TypeScript/>=%203.x/blue?icon=typescript)](https://lossless.cloud)
node Support | [![node](https://img.shields.io/badge/node->=%2010.x.x-blue.svg)](https://nodejs.org/dist/latest-v10.x/docs/api/)
Code Style | [![Code Style](https://badgen.net/badge/style/prettier/purple)](https://lossless.cloud)
PackagePhobia (total standalone install weight) | [![PackagePhobia](https://badgen.net/packagephobia/install/@pushrocks/smartstring)](https://lossless.cloud)
PackagePhobia (package size on registry) | [![PackagePhobia](https://badgen.net/packagephobia/publish/@pushrocks/smartstring)](https://lossless.cloud)
BundlePhobia (total size when bundled) | [![BundlePhobia](https://badgen.net/bundlephobia/minzip/@pushrocks/smartstring)](https://lossless.cloud)
Platform support | [![Supports Windows 10](https://badgen.net/badge/supports%20Windows%2010/yes/green?icon=windows)](https://lossless.cloud) [![Supports Mac OS X](https://badgen.net/badge/supports%20Mac%20OS%20X/yes/green?icon=apple)](https://lossless.cloud)
## Usage ## Usage
@ -58,9 +65,13 @@ smartstring.indent.indent('somestringanotherstring', '>>>> '); // indents a stri
smartstring.indent.normalize(' somestring anotherstring', '>>>> '); // looks for the least amount of indention and removes superflouous space smartstring.indent.normalize(' somestring anotherstring', '>>>> '); // looks for the least amount of indention and removes superflouous space
``` ```
## Contribution
We are always happy for code contributions. If you are not the code contributing type that is ok. Still, maintaining Open Source repositories takes considerable time and thought. If you like the quality of what we do and our modules are useful to you we would appreciate a little monthly contribution: You can [contribute one time](https://lossless.link/contribute-onetime) or [contribute monthly](https://lossless.link/contribute). :)
For further information read the linked docs at the top of this readme. For further information read the linked docs at the top of this readme.
> MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh) > MIT licensed | **©** [Lossless GmbH](https://lossless.gmbh)
| By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy.html) | By using this npm module you agree to our [privacy policy](https://lossless.gmbH/privacy)
[![repo-footer](https://pushrocks.gitlab.io/assets/repo-footer.svg)](https://maintainedby.lossless.com) [![repo-footer](https://lossless.gitlab.io/publicrelations/repofooter.svg)](https://maintainedby.lossless.com)

View File

@ -1,16 +1,16 @@
import * as smartstring from '../ts/index'; import * as smartstring from '../ts/index.js';
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
// Base64 // Base64
let testBase64: smartstring.Base64; let testBase64: smartstring.Base64;
tap.test('expect create a valid instance of Base64', async () => { tap.test('expect create a valid instance of Base64', async () => {
testBase64 = new smartstring.Base64('somestring', 'string'); testBase64 = new smartstring.Base64('somestring', 'string');
expect(testBase64).be.instanceOf(smartstring.Base64); expect(testBase64).toBeInstanceOf(smartstring.Base64);
}); });
tap.test('expect read output a file as base64 and base64uri', async () => { tap.test('expect read output a file as base64 and base64uri', async () => {
expect(testBase64.base64String).not.equal(testBase64.base64UriString); expect(testBase64.base64String).not.toEqual(testBase64.base64UriString);
let testBase64_2 = new smartstring.Base64(testBase64.base64UriString, 'base64uri'); let testBase64_2 = new smartstring.Base64(testBase64.base64UriString, 'base64uri');
expect(testBase64_2.simpleString).equal(testBase64.simpleString); expect(testBase64_2.simpleString).toEqual(testBase64.simpleString);
}); });
tap.start(); tap.start();

View File

@ -1,12 +1,12 @@
import * as smartstring from '../ts/index'; import * as smartstring from '../ts/index.js';
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
// Docker // Docker
tap.test('expect create a Env Object', async () => { tap.test('expect create a Env Object', async () => {
let envStringArray = ['VIRTUAL_HOST=sub.domain.tld', 'DEFAULT_HOST=some.domain.com']; let envStringArray = ['VIRTUAL_HOST=sub.domain.tld', 'DEFAULT_HOST=some.domain.com'];
let envObject: any = smartstring.docker.makeEnvObject(envStringArray); let envObject: any = smartstring.docker.makeEnvObject(envStringArray);
expect(envObject.VIRTUAL_HOST).to.equal('sub.domain.tld'); expect(envObject.VIRTUAL_HOST).toEqual('sub.domain.tld');
expect(envObject.DEFAULT_HOST).to.equal('some.domain.com'); expect(envObject.DEFAULT_HOST).toEqual('some.domain.com');
}); });
tap.start(); tap.start();

View File

@ -1,4 +1,4 @@
import * as smartstring from '../ts/index'; import * as smartstring from '../ts/index.js';
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
// Domain // Domain
@ -6,26 +6,31 @@ let testDomain: smartstring.Domain;
let testDomain2: smartstring.Domain; let testDomain2: smartstring.Domain;
tap.test('expect create a new Domain object', async () => { tap.test('expect create a new Domain object', async () => {
testDomain = new smartstring.Domain('https://level3D.level2D.level1D'); testDomain = new smartstring.Domain('https://level3D.level2D.level1D');
expect(testDomain).be.instanceof(smartstring.Domain); expect(testDomain).toBeInstanceOf(smartstring.Domain);
console.log(testDomain); console.log(testDomain);
}); });
tap.test('expect have a .topLevel', async () => { tap.test('expect have a .topLevel', async () => {
expect(testDomain.topLevel).equal('level1D'); expect(testDomain.topLevel).toEqual('level1D');
}); });
tap.test('expect have a .level2', async () => { tap.test('expect have a .level2', async () => {
expect(testDomain.level2).equal('level2D'); expect(testDomain.level2).toEqual('level2D');
}); });
tap.test('expect have a .level3', async () => { tap.test('expect have a .level3', async () => {
expect(testDomain.level3).equal('level3D'); expect(testDomain.level3).toEqual('level3D');
}); });
tap.test('expect have the correct dns zone name', async () => { tap.test('expect have the correct dns zone name', async () => {
expect(testDomain.zoneName).equal('level2D.level1D'); expect(testDomain.zoneName).toEqual('level2D.level1D');
}); });
tap.test('expect have the correct protocol', async () => { tap.test('expect have the correct protocol', async () => {
expect(testDomain.protocol).equal('https'); expect(testDomain.protocol).toEqual('https');
}); });
tap.test('testDomain2 expect be a basic domain', async () => { tap.test('testDomain2 expect be a basic domain', async () => {
testDomain2 = new smartstring.Domain('bleu.de'); testDomain2 = new smartstring.Domain('testing.bleu.de');
console.log(testDomain2);
});
tap.test('should parse complex domains', async () => {
testDomain2 = new smartstring.Domain('https://sub1.sub2.lossless.com/some/path:5431');
console.log(testDomain2); console.log(testDomain2);
}); });

View File

@ -1,26 +1,26 @@
import * as smartstring from '../ts/index'; import * as smartstring from '../ts/index.js';
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
// git // git
let testGit: smartstring.GitRepo; let testGit: smartstring.GitRepo;
tap.test('expect create a new Git class GitRepo', async () => { tap.test('expect create a new Git class GitRepo', async () => {
testGit = new smartstring.GitRepo('git+https://github.com/pushrocks/smartstring.git'); testGit = new smartstring.GitRepo('git+https://github.com/pushrocks/smartstring.git');
expect(testGit).be.instanceof(smartstring.GitRepo); expect(testGit).toBeInstanceOf(smartstring.GitRepo);
}); });
tap.test('expect return a .host', async () => { tap.test('expect return a .host', async () => {
expect(testGit.host).equal('github.com'); expect(testGit.host).toEqual('github.com');
}); });
tap.test('expect return a .user', async () => { tap.test('expect return a .user', async () => {
expect(testGit.user).equal('pushrocks'); expect(testGit.user).toEqual('pushrocks');
}); });
tap.test('expect return a .repo', async () => { tap.test('expect return a .repo', async () => {
expect(testGit.repo).equal('smartstring'); expect(testGit.repo).toEqual('smartstring');
}); });
tap.test('expect return a .httpsUrl', async () => { tap.test('expect return a .httpsUrl', async () => {
expect(testGit.httpsUrl).equal('https://github.com/pushrocks/smartstring.git'); expect(testGit.httpsUrl).toEqual('https://github.com/pushrocks/smartstring.git');
}); });
tap.test('expect return a .sshUrl', async () => { tap.test('expect return a .sshUrl', async () => {
expect(testGit.sshUrl).equal('git@github.com:pushrocks/smartstring.git'); expect(testGit.sshUrl).toEqual('git@github.com:pushrocks/smartstring.git');
}); });
tap.start(); tap.start();

View File

@ -1,4 +1,4 @@
import * as smartstring from '../ts/index'; import * as smartstring from '../ts/index.js';
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
// indent // indent

View File

@ -1,6 +1,6 @@
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
import * as smartstring from '../ts/index'; import * as smartstring from '../ts/index.js';
tap.test('should normalize a string', async () => { tap.test('should normalize a string', async () => {
const testString = ` const testString = `
@ -8,7 +8,7 @@ tap.test('should normalize a string', async () => {
is indented with two spaces is indented with two spaces
`; `;
const normalizedString = smartstring.normalize.standard(testString); const normalizedString = smartstring.normalize.standard(testString);
expect(normalizedString).to.equal( expect(normalizedString).toEqual(
` `
myawesome string; myawesome string;
is indented with two spaces is indented with two spaces

View File

@ -1,14 +1,14 @@
import { tap, expect } from '@pushrocks/tapbundle'; import { tap, expect } from '@pushrocks/tapbundle';
import * as smartstring from '../ts'; import * as smartstring from '../ts/index.js';
tap.test('should state valuid utf8', async () => { tap.test('should state valuid utf8', async () => {
expect(smartstring.type.isUtf8('hithere')).to.be.true; expect(smartstring.type.isUtf8('hithere')).toBeTrue();
}); });
tap.test('should state wether base64 string is valid', async () => { tap.test('should state wether base64 string is valid', async () => {
const base64String = smartstring.base64.encode('hi there'); const base64String = smartstring.base64.encode('hi there');
expect(smartstring.type.isBase64(base64String)).to.be.true; expect(smartstring.type.isBase64(base64String)).toBeTrue();
expect(smartstring.type.isBase64('hi there')).to.be.false; expect(smartstring.type.isBase64('hi there')).toBeFalse();
}); });
tap.start(); tap.start();

8
ts/00_commitinfo_data.ts Normal file
View File

@ -0,0 +1,8 @@
/**
* autocreated commitinfo by @pushrocks/commitinfo
*/
export const commitinfo = {
name: '@pushrocks/smartstring',
version: '4.0.4',
description: 'handle strings in smart ways. TypeScript ready.'
}

View File

@ -1,13 +1,11 @@
import * as create from './smartstring.create'; import * as create from './smartstring.create.js';
import * as docker from './smartstring.docker'; import * as docker from './smartstring.docker.js';
import * as indent from './smartstring.indent'; import * as indent from './smartstring.indent.js';
import * as normalize from './smartstring.normalize'; import * as normalize from './smartstring.normalize.js';
import * as type from './smartstring.type'; import * as type from './smartstring.type.js';
export { create, docker, normalize, indent, type }; export { create, docker, normalize, indent, type };
export { Base64, base64 } from './smartstring.base64'; export { Base64, base64 } from './smartstring.base64.js';
export { Domain } from './smartstring.domain'; export { Domain } from './smartstring.domain.js';
export { GitRepo } from './smartstring.git'; export { GitRepo } from './smartstring.git.js';
export { Cryptr } from './smartstring.encryption';

View File

@ -1,16 +1,16 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
/** /**
* the type for base 64 * the type for base 64
*/ */
export type TBase64Input = 'string' | 'base64' | 'base64uri'; export type TStringInputType = 'string' | 'base64' | 'base64uri';
/** /**
* handle base64 strings * handle base64 strings
*/ */
export class Base64 { export class Base64 {
private refString: string; private refString: string;
constructor(inputStringArg, typeArg: TBase64Input) { constructor(inputStringArg, typeArg: TStringInputType) {
switch (typeArg) { switch (typeArg) {
case 'string': // easiest case case 'string': // easiest case
this.refString = inputStringArg; this.refString = inputStringArg;
@ -65,5 +65,5 @@ export let base64 = {
*/ */
decode: (stringArg: string) => { decode: (stringArg: string) => {
return plugins.jsBase64.decode(stringArg); return plugins.jsBase64.decode(stringArg);
} },
}; };

View File

@ -1,4 +1,4 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
/** /**
* creates a random string * creates a random string
@ -24,6 +24,6 @@ export const createRandomString = (
* creates a crytic string in the speicifed length * creates a crytic string in the speicifed length
* @param lengthArg the length of the crypto string * @param lengthArg the length of the crypto string
*/ */
export const createCryptoRandomString = (lengthArg: number): string => { export const createCryptoRandomString = (): string => {
return plugins.cryptoRandomString(lengthArg); return plugins.isounique.uni();
}; };

View File

@ -1,4 +1,4 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
/** /**
* converts an erray of env strings from docker remote api to an usable object. * converts an erray of env strings from docker remote api to an usable object.

View File

@ -1,4 +1,4 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
export class Domain { export class Domain {
public fullName: string; public fullName: string;
@ -16,7 +16,18 @@ export class Domain {
public port; public port;
public nodeParsedUrl: plugins.url.UrlWithStringQuery; public nodeParsedUrl: plugins.url.UrlWithStringQuery;
constructor(domainStringArg: string) { constructor(domainStringArg: string) {
const regexMatches = this._domainRegex(domainStringArg); // lets do the node standard stuff first
this.protocol = this._protocolRegex(domainStringArg);
if (!this.protocol) {
domainStringArg = `https://${domainStringArg}`;
}
this.nodeParsedUrl = plugins.url.parse(domainStringArg);
this.port = this.nodeParsedUrl.port;
// lets do the rest after
const regexMatches = this._domainRegex(
domainStringArg.replace(this.nodeParsedUrl.pathname, '')
);
this.fullName = ''; this.fullName = '';
for (let i = 1; i <= 5; i++) { for (let i = 1; i <= 5; i++) {
if (regexMatches[i - 1]) { if (regexMatches[i - 1]) {
@ -31,23 +42,20 @@ export class Domain {
this['level' + i.toString()] = undefined; this['level' + i.toString()] = undefined;
} }
} }
this.protocol = this._protocolRegex(domainStringArg);
this.zoneName = this.level2 + '.' + this.level1; this.zoneName = this.level2 + '.' + this.level1;
// aliases // aliases
this.topLevel = this.level1; this.topLevel = this.level1;
this.domainName = this.level2; this.domainName = this.level2;
this.subDomain = this.level3; this.subDomain = this.level3;
this.nodeParsedUrl = plugins.url.parse(domainStringArg);
this.port = this.nodeParsedUrl.port;
} }
// helper functions // helper functions
/** */ /** */
private _domainRegex(stringArg: string) { private _domainRegex(stringArg: string) {
const regexString = /([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}$/; const regexString =
/([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}([a-zA-Z0-9\-\_]*)\.{0,1}$/;
const regexMatches = regexString.exec(stringArg); const regexMatches = regexString.exec(stringArg);
regexMatches.reverse(); //make sure we build the domain from toplevel to subdomain (reversed order) regexMatches.reverse(); //make sure we build the domain from toplevel to subdomain (reversed order)
regexMatches.pop(); // pop the last element, which is, since we reversed the Array, the full String of matched elements regexMatches.pop(); // pop the last element, which is, since we reversed the Array, the full String of matched elements

View File

@ -1,43 +0,0 @@
import * as plugins from './smartstring.plugins';
const algorithm = 'aes-256-ctr';
export class Cryptr {
private key: Buffer;
constructor(secret) {
if (!secret || typeof secret !== 'string') {
throw new Error('Cryptr: secret must be a non-0-length string');
}
this.key = plugins.crypto
.createHash('sha256')
.update(String(secret))
.digest();
}
encrypt(value: string) {
if (value == null) {
throw new Error('value must not be null or undefined');
}
const iv = plugins.crypto.randomBytes(16);
const cipher = plugins.crypto.createCipheriv(algorithm, this.key, iv);
const encrypted = cipher.update(String(value), 'utf8', 'hex') + cipher.final('hex');
return iv.toString('hex') + encrypted;
}
decrypt(value: string) {
if (value == null) {
throw new Error('value must not be null or undefined');
}
const stringValue = String(value);
const iv = Buffer.from(stringValue.slice(0, 32), 'hex');
const encrypted = stringValue.slice(32);
const decipher = plugins.crypto.createDecipheriv(algorithm, this.key, iv);
return decipher.update(encrypted, 'hex', 'utf8') + decipher.final('utf8');
}
}

View File

@ -1,4 +1,4 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
/* ---------------------------------------------- * /* ---------------------------------------------- *
* ------------------ classes ------------------- * * ------------------ classes ------------------- *
@ -25,7 +25,8 @@ export class GitRepo {
* ------------------ helpers ------------------- * * ------------------ helpers ------------------- *
* ---------------------------------------------- */ * ---------------------------------------------- */
const gitRegex = function (stringArg: string) { const gitRegex = function (stringArg: string) {
const regexString = /([a-zA-Z0-9\-\.]*)(?:\/|\:)([a-zA-Z0-9\-\.]*)(?:\/)([a-zA-Z0-9\-\.]*)(?:\.git)/; const regexString =
/([a-zA-Z0-9\-\.]*)(?:\/|\:)([a-zA-Z0-9\-\.]*)(?:\/)([a-zA-Z0-9\-\.]*)(?:\.git)/;
let regexMatches = regexString.exec(stringArg); let regexMatches = regexString.exec(stringArg);
return regexMatches; return regexMatches;
}; };

View File

@ -1,4 +1,4 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
/** /**
* splits a string into an array * splits a string into an array

View File

@ -1,4 +1,4 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
/** /**
* replaces all occurences of something in a string * replaces all occurences of something in a string

View File

@ -1,13 +1,22 @@
// node native // node native
import * as crypto from 'crypto'; import * as smartenv from '@pushrocks/smartenv';
import * as url from 'url'; const smartenvInstance = new smartenv.Smartenv();
import * as isounique from '@pushrocks/isounique';
export { crypto, url }; export { isounique };
import { Buffer } from 'buffer';
if (smartenvInstance.isBrowser) {
globalThis.Buffer = Buffer;
}
import * as url from 'url';
export { url };
// third party // third party
export let jsBase64 = require('js-base64').Base64; import { Base64 as jsBase64 } from 'js-base64';
export let stripIndent = require('strip-indent'); import stripIndent from 'strip-indent';
export let normalizeNewline = require('normalize-newline'); import normalizeNewline from 'normalize-newline';
export let randomatic = require('randomatic'); import randomatic from 'randomatic';
export let cryptoRandomString = require('crypto-random-string');
export { jsBase64, stripIndent, normalizeNewline, randomatic };

View File

@ -1,71 +1,78 @@
import * as plugins from './smartstring.plugins'; import * as plugins from './smartstring.plugins.js';
import * as base64 from './smartstring.base64'; import * as base64 from './smartstring.base64.js';
export const isUtf8 = (stringArg: string) => { export const isUtf8 = (stringArg: string) => {
const bytes = Buffer.from(stringArg); const bytes = Buffer.from(stringArg);
let i = 0; let i = 0;
while(i < bytes.length) while (i < bytes.length) {
{ if (
if( (// ASCII // ASCII
bytes[i] === 0x09 || bytes[i] === 0x09 ||
bytes[i] === 0x0A || bytes[i] === 0x0a ||
bytes[i] === 0x0D || bytes[i] === 0x0d ||
(0x20 <= bytes[i] && bytes[i] <= 0x7E) (0x20 <= bytes[i] && bytes[i] <= 0x7e)
)
) { ) {
i += 1; i += 1;
continue; continue;
} }
if( (// non-overlong 2-byte if (
(0xC2 <= bytes[i] && bytes[i] <= 0xDF) && // non-overlong 2-byte
(0x80 <= bytes[i+1] && bytes[i+1] <= 0xBF) 0xc2 <= bytes[i] &&
) bytes[i] <= 0xdf &&
0x80 <= bytes[i + 1] &&
bytes[i + 1] <= 0xbf
) { ) {
i += 2; i += 2;
continue; continue;
} }
if( (// excluding overlongs if (
bytes[i] === 0xE0 && // excluding overlongs
(0xA0 <= bytes[i + 1] && bytes[i + 1] <= 0xBF) && (bytes[i] === 0xe0 &&
(0x80 <= bytes[i + 2] && bytes[i + 2] <= 0xBF) 0xa0 <= bytes[i + 1] &&
) || bytes[i + 1] <= 0xbf &&
(// straight 3-byte 0x80 <= bytes[i + 2] &&
((0xE1 <= bytes[i] && bytes[i] <= 0xEC) || bytes[i + 2] <= 0xbf) || // straight 3-byte
bytes[i] === 0xEE || (((0xe1 <= bytes[i] && bytes[i] <= 0xec) || bytes[i] === 0xee || bytes[i] === 0xef) &&
bytes[i] === 0xEF) && 0x80 <= bytes[i + 1] &&
(0x80 <= bytes[i + 1] && bytes[i+1] <= 0xBF) && bytes[i + 1] <= 0xbf &&
(0x80 <= bytes[i+2] && bytes[i+2] <= 0xBF) 0x80 <= bytes[i + 2] &&
) || bytes[i + 2] <= 0xbf) || // excluding surrogates
(// excluding surrogates (bytes[i] === 0xed &&
bytes[i] === 0xED && 0x80 <= bytes[i + 1] &&
(0x80 <= bytes[i+1] && bytes[i+1] <= 0x9F) && bytes[i + 1] <= 0x9f &&
(0x80 <= bytes[i+2] && bytes[i+2] <= 0xBF) 0x80 <= bytes[i + 2] &&
) bytes[i + 2] <= 0xbf)
) { ) {
i += 3; i += 3;
continue; continue;
} }
if( (// planes 1-3 if (
bytes[i] === 0xF0 && // planes 1-3
(0x90 <= bytes[i + 1] && bytes[i + 1] <= 0xBF) && (bytes[i] === 0xf0 &&
(0x80 <= bytes[i + 2] && bytes[i + 2] <= 0xBF) && 0x90 <= bytes[i + 1] &&
(0x80 <= bytes[i + 3] && bytes[i + 3] <= 0xBF) bytes[i + 1] <= 0xbf &&
) || 0x80 <= bytes[i + 2] &&
(// planes 4-15 bytes[i + 2] <= 0xbf &&
(0xF1 <= bytes[i] && bytes[i] <= 0xF3) && 0x80 <= bytes[i + 3] &&
(0x80 <= bytes[i + 1] && bytes[i + 1] <= 0xBF) && bytes[i + 3] <= 0xbf) || // planes 4-15
(0x80 <= bytes[i + 2] && bytes[i + 2] <= 0xBF) && (0xf1 <= bytes[i] &&
(0x80 <= bytes[i + 3] && bytes[i + 3] <= 0xBF) bytes[i] <= 0xf3 &&
) || 0x80 <= bytes[i + 1] &&
(// plane 16 bytes[i + 1] <= 0xbf &&
bytes[i] === 0xF4 && 0x80 <= bytes[i + 2] &&
(0x80 <= bytes[i + 1] && bytes[i + 1] <= 0x8F) && bytes[i + 2] <= 0xbf &&
(0x80 <= bytes[i + 2] && bytes[i + 2] <= 0xBF) && 0x80 <= bytes[i + 3] &&
(0x80 <= bytes[i + 3] && bytes[i + 3] <= 0xBF) bytes[i + 3] <= 0xbf) || // plane 16
) (bytes[i] === 0xf4 &&
0x80 <= bytes[i + 1] &&
bytes[i + 1] <= 0x8f &&
0x80 <= bytes[i + 2] &&
bytes[i + 2] <= 0xbf &&
0x80 <= bytes[i + 3] &&
bytes[i + 3] <= 0xbf)
) { ) {
i += 4; i += 4;
continue; continue;
@ -78,5 +85,15 @@ export const isUtf8 = (stringArg: string) => {
}; };
export const isBase64 = (stringArg: string) => { export const isBase64 = (stringArg: string) => {
return stringArg.endsWith('='); const notBase64 = /[^A-Z0-9+\/=]/i;
const len = stringArg.length;
if (!len || len % 4 !== 0 || notBase64.test(stringArg)) {
return false;
}
const firstPaddingChar = stringArg.indexOf('=');
return (
firstPaddingChar === -1 ||
firstPaddingChar === len - 1 ||
(firstPaddingChar === len - 2 && stringArg[len - 1] === '=')
);
}; };

7
tsconfig.json Normal file
View File

@ -0,0 +1,7 @@
{
"compilerOptions": {
"target": "ES2022",
"module": "ES2022",
"moduleResolution": "nodenext"
}
}

View File

@ -1,17 +0,0 @@
{
"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"
}