Compare commits
24 Commits
Author | SHA1 | Date | |
---|---|---|---|
7267a0cc38 | |||
79ab43876d | |||
50742ddfa5 | |||
83a851a6aa | |||
b6d5f61f3c | |||
101772d8dc | |||
ba4a910962 | |||
739c95c1e1 | |||
39442208c8 | |||
b686202ae5 | |||
4093d091f4 | |||
7a8086b58c | |||
a45e41889d | |||
c33ee3f52c | |||
1732a2ab3e | |||
43ebd17ae6 | |||
18f09a5109 | |||
bec73de6d5 | |||
deba684093 | |||
1625f507d8 | |||
32f8315493 | |||
ffbf56625e | |||
d928a62b5e | |||
b5c5b18f35 |
66
.gitea/workflows/default_nottags.yaml
Normal file
66
.gitea/workflows/default_nottags.yaml
Normal file
@ -0,0 +1,66 @@
|
|||||||
|
name: Default (not tags)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags-ignore:
|
||||||
|
- '**'
|
||||||
|
|
||||||
|
env:
|
||||||
|
IMAGE: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
NPMCI_COMPUTED_REPOURL: https://${{gitea.repository_owner}}:${{secrets.GITEA_TOKEN}}@gitea.lossless.digital/${{gitea.repository}}.git
|
||||||
|
NPMCI_TOKEN_NPM: ${{secrets.NPMCI_TOKEN_NPM}}
|
||||||
|
NPMCI_TOKEN_NPM2: ${{secrets.NPMCI_TOKEN_NPM2}}
|
||||||
|
NPMCI_GIT_GITHUBTOKEN: ${{secrets.NPMCI_GIT_GITHUBTOKEN}}
|
||||||
|
NPMCI_URL_CLOUDLY: ${{secrets.NPMCI_URL_CLOUDLY}}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
security:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
continue-on-error: true
|
||||||
|
container:
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Install pnpm and npmci
|
||||||
|
run: |
|
||||||
|
pnpm install -g pnpm
|
||||||
|
pnpm install -g @shipzone/npmci
|
||||||
|
|
||||||
|
- name: Run npm prepare
|
||||||
|
run: npmci npm prepare
|
||||||
|
|
||||||
|
- name: Audit production dependencies
|
||||||
|
run: |
|
||||||
|
npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
npmci command pnpm audit --audit-level=high --prod
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Audit development dependencies
|
||||||
|
run: |
|
||||||
|
npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
npmci command pnpm audit --audit-level=high --dev
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
test:
|
||||||
|
if: ${{ always() }}
|
||||||
|
needs: security
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Test stable
|
||||||
|
run: |
|
||||||
|
npmci node install stable
|
||||||
|
npmci npm install
|
||||||
|
npmci npm test
|
||||||
|
|
||||||
|
- name: Test build
|
||||||
|
run: |
|
||||||
|
npmci node install stable
|
||||||
|
npmci npm install
|
||||||
|
npmci npm build
|
124
.gitea/workflows/default_tags.yaml
Normal file
124
.gitea/workflows/default_tags.yaml
Normal file
@ -0,0 +1,124 @@
|
|||||||
|
name: Default (tags)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
tags:
|
||||||
|
- '*'
|
||||||
|
|
||||||
|
env:
|
||||||
|
IMAGE: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
NPMCI_COMPUTED_REPOURL: https://${{gitea.repository_owner}}:${{secrets.GITEA_TOKEN}}@gitea.lossless.digital/${{gitea.repository}}.git
|
||||||
|
NPMCI_TOKEN_NPM: ${{secrets.NPMCI_TOKEN_NPM}}
|
||||||
|
NPMCI_TOKEN_NPM2: ${{secrets.NPMCI_TOKEN_NPM2}}
|
||||||
|
NPMCI_GIT_GITHUBTOKEN: ${{secrets.NPMCI_GIT_GITHUBTOKEN}}
|
||||||
|
NPMCI_URL_CLOUDLY: ${{secrets.NPMCI_URL_CLOUDLY}}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
security:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
continue-on-error: true
|
||||||
|
container:
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Prepare
|
||||||
|
run: |
|
||||||
|
pnpm install -g pnpm
|
||||||
|
pnpm install -g @shipzone/npmci
|
||||||
|
npmci npm prepare
|
||||||
|
|
||||||
|
- name: Audit production dependencies
|
||||||
|
run: |
|
||||||
|
npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
npmci command pnpm audit --audit-level=high --prod
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
- name: Audit development dependencies
|
||||||
|
run: |
|
||||||
|
npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
npmci command pnpm audit --audit-level=high --dev
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
test:
|
||||||
|
if: ${{ always() }}
|
||||||
|
needs: security
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Prepare
|
||||||
|
run: |
|
||||||
|
pnpm install -g pnpm
|
||||||
|
pnpm install -g @shipzone/npmci
|
||||||
|
npmci npm prepare
|
||||||
|
|
||||||
|
- name: Test stable
|
||||||
|
run: |
|
||||||
|
npmci node install stable
|
||||||
|
npmci npm install
|
||||||
|
npmci npm test
|
||||||
|
|
||||||
|
- name: Test build
|
||||||
|
run: |
|
||||||
|
npmci node install stable
|
||||||
|
npmci npm install
|
||||||
|
npmci npm build
|
||||||
|
|
||||||
|
release:
|
||||||
|
needs: test
|
||||||
|
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/')
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Prepare
|
||||||
|
run: |
|
||||||
|
pnpm install -g pnpm
|
||||||
|
pnpm install -g @shipzone/npmci
|
||||||
|
npmci npm prepare
|
||||||
|
|
||||||
|
- name: Release
|
||||||
|
run: |
|
||||||
|
npmci node install stable
|
||||||
|
npmci npm publish
|
||||||
|
|
||||||
|
metadata:
|
||||||
|
needs: test
|
||||||
|
if: github.event_name == 'push' && startsWith(github.ref, 'refs/tags/')
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
container:
|
||||||
|
image: ${{ env.IMAGE }}
|
||||||
|
continue-on-error: true
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v3
|
||||||
|
|
||||||
|
- name: Prepare
|
||||||
|
run: |
|
||||||
|
pnpm install -g pnpm
|
||||||
|
pnpm install -g @shipzone/npmci
|
||||||
|
npmci npm prepare
|
||||||
|
|
||||||
|
- name: Code quality
|
||||||
|
run: |
|
||||||
|
npmci command npm install -g typescript
|
||||||
|
npmci npm install
|
||||||
|
|
||||||
|
- name: Trigger
|
||||||
|
run: npmci trigger
|
||||||
|
|
||||||
|
- name: Build docs and upload artifacts
|
||||||
|
run: |
|
||||||
|
npmci node install stable
|
||||||
|
npmci npm install
|
||||||
|
pnpm install -g @git.zone/tsdoc
|
||||||
|
npmci command tsdoc
|
||||||
|
continue-on-error: true
|
128
.gitlab-ci.yml
128
.gitlab-ci.yml
@ -1,128 +0,0 @@
|
|||||||
# gitzone ci_default
|
|
||||||
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
|
||||||
|
|
||||||
cache:
|
|
||||||
paths:
|
|
||||||
- .npmci_cache/
|
|
||||||
key: '$CI_BUILD_STAGE'
|
|
||||||
|
|
||||||
stages:
|
|
||||||
- security
|
|
||||||
- test
|
|
||||||
- release
|
|
||||||
- metadata
|
|
||||||
|
|
||||||
before_script:
|
|
||||||
- pnpm install -g pnpm
|
|
||||||
- pnpm install -g @shipzone/npmci
|
|
||||||
- npmci npm prepare
|
|
||||||
|
|
||||||
# ====================
|
|
||||||
# security stage
|
|
||||||
# ====================
|
|
||||||
# ====================
|
|
||||||
# security stage
|
|
||||||
# ====================
|
|
||||||
auditProductionDependencies:
|
|
||||||
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
|
||||||
stage: security
|
|
||||||
script:
|
|
||||||
- npmci command npm config set registry https://registry.npmjs.org
|
|
||||||
- npmci command pnpm audit --audit-level=high --prod
|
|
||||||
tags:
|
|
||||||
- lossless
|
|
||||||
- docker
|
|
||||||
allow_failure: true
|
|
||||||
|
|
||||||
auditDevDependencies:
|
|
||||||
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
|
||||||
stage: security
|
|
||||||
script:
|
|
||||||
- npmci command npm config set registry https://registry.npmjs.org
|
|
||||||
- npmci command pnpm audit --audit-level=high --dev
|
|
||||||
tags:
|
|
||||||
- lossless
|
|
||||||
- docker
|
|
||||||
allow_failure: true
|
|
||||||
|
|
||||||
# ====================
|
|
||||||
# test stage
|
|
||||||
# ====================
|
|
||||||
|
|
||||||
testStable:
|
|
||||||
stage: test
|
|
||||||
script:
|
|
||||||
- npmci node install stable
|
|
||||||
- npmci npm install
|
|
||||||
- npmci npm test
|
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
|
|
||||||
testBuild:
|
|
||||||
stage: test
|
|
||||||
script:
|
|
||||||
- npmci node install stable
|
|
||||||
- npmci npm install
|
|
||||||
- npmci npm build
|
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
|
||||||
tags:
|
|
||||||
- docker
|
|
||||||
|
|
||||||
release:
|
|
||||||
stage: release
|
|
||||||
script:
|
|
||||||
- npmci node install stable
|
|
||||||
- npmci npm publish
|
|
||||||
only:
|
|
||||||
- tags
|
|
||||||
tags:
|
|
||||||
- lossless
|
|
||||||
- docker
|
|
||||||
- notpriv
|
|
||||||
|
|
||||||
# ====================
|
|
||||||
# metadata stage
|
|
||||||
# ====================
|
|
||||||
codequality:
|
|
||||||
stage: metadata
|
|
||||||
allow_failure: true
|
|
||||||
only:
|
|
||||||
- tags
|
|
||||||
script:
|
|
||||||
- npmci command npm install -g typescript
|
|
||||||
- npmci npm prepare
|
|
||||||
- npmci npm install
|
|
||||||
tags:
|
|
||||||
- lossless
|
|
||||||
- docker
|
|
||||||
- priv
|
|
||||||
|
|
||||||
trigger:
|
|
||||||
stage: metadata
|
|
||||||
script:
|
|
||||||
- npmci trigger
|
|
||||||
only:
|
|
||||||
- tags
|
|
||||||
tags:
|
|
||||||
- lossless
|
|
||||||
- docker
|
|
||||||
- notpriv
|
|
||||||
|
|
||||||
pages:
|
|
||||||
stage: metadata
|
|
||||||
script:
|
|
||||||
- npmci node install stable
|
|
||||||
- npmci npm install
|
|
||||||
- npmci command npm run buildDocs
|
|
||||||
tags:
|
|
||||||
- lossless
|
|
||||||
- docker
|
|
||||||
- notpriv
|
|
||||||
only:
|
|
||||||
- tags
|
|
||||||
artifacts:
|
|
||||||
expire_in: 1 week
|
|
||||||
paths:
|
|
||||||
- public
|
|
||||||
allow_failure: true
|
|
@ -3,10 +3,10 @@
|
|||||||
"projectType": "npm",
|
"projectType": "npm",
|
||||||
"module": {
|
"module": {
|
||||||
"githost": "gitlab.com",
|
"githost": "gitlab.com",
|
||||||
"gitscope": "pushrocks",
|
"gitscope": "push.rocks",
|
||||||
"gitrepo": "smartwhois",
|
"gitrepo": "smartwhois",
|
||||||
"description": "a package for dealing with whois requests",
|
"description": "a package for dealing with whois requests",
|
||||||
"npmPackagename": "@pushrocks/smartwhois",
|
"npmPackagename": "@push.rocks/smartwhois",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"projectDomain": "push.rocks"
|
"projectDomain": "push.rocks"
|
||||||
}
|
}
|
||||||
|
21
package.json
21
package.json
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@pushrocks/smartwhois",
|
"name": "@push.rocks/smartwhois",
|
||||||
"version": "1.0.4",
|
"version": "1.0.16",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "a package for dealing with whois requests",
|
"description": "a package for dealing with whois requests",
|
||||||
"main": "dist_ts/index.js",
|
"main": "dist_ts/index.js",
|
||||||
@ -11,18 +11,21 @@
|
|||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(tstest test/ --web)",
|
"test": "(tstest test/ --web)",
|
||||||
"build": "(tsbuild --web --allowimplicitany)",
|
"build": "(tsbuild --web --allowimplicitany)",
|
||||||
"buildDocs": "(tsdoc)"
|
"buildDocs": "tsdoc"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@gitzone/tsbuild": "^2.1.65",
|
"@git.zone/tsbuild": "^2.1.65",
|
||||||
"@gitzone/tsbundle": "^2.0.7",
|
"@git.zone/tsbundle": "^2.0.7",
|
||||||
"@gitzone/tsdoc": "^1.1.12",
|
"@git.zone/tsrun": "^1.2.39",
|
||||||
"@gitzone/tsrun": "^1.2.39",
|
"@git.zone/tstest": "^1.0.74",
|
||||||
"@gitzone/tstest": "^1.0.74",
|
"@push.rocks/tapbundle": "^5.0.4",
|
||||||
"@pushrocks/tapbundle": "^5.0.4",
|
|
||||||
"@types/node": "^18.15.11"
|
"@types/node": "^18.15.11"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
|
"@push.rocks/smartrequest": "^2.0.15",
|
||||||
|
"@push.rocks/smarturl": "^3.0.6",
|
||||||
|
"@tsclass/tsclass": "^4.0.38",
|
||||||
|
"tldts": "^6.0.3",
|
||||||
"whoiser": "^1.16.0"
|
"whoiser": "^1.16.0"
|
||||||
},
|
},
|
||||||
"browserslist": [
|
"browserslist": [
|
||||||
|
2854
pnpm-lock.yaml
generated
2854
pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
24
readme.md
24
readme.md
@ -1,26 +1,26 @@
|
|||||||
# @pushrocks/smartwhois
|
# @push.rocks/smartwhois
|
||||||
a package for dealing with whois requests
|
a package for dealing with whois requests
|
||||||
|
|
||||||
## Availabililty and Links
|
## Availabililty and Links
|
||||||
* [npmjs.org (npm package)](https://www.npmjs.com/package/@pushrocks/smartwhois)
|
* [npmjs.org (npm package)](https://www.npmjs.com/package/@push.rocks/smartwhois)
|
||||||
* [gitlab.com (source)](https://gitlab.com/pushrocks/smartwhois)
|
* [gitlab.com (source)](https://gitlab.com/push.rocks/smartwhois)
|
||||||
* [github.com (source mirror)](https://github.com/pushrocks/smartwhois)
|
* [github.com (source mirror)](https://github.com/push.rocks/smartwhois)
|
||||||
* [docs (typedoc)](https://pushrocks.gitlab.io/smartwhois/)
|
* [docs (typedoc)](https://push.rocks.gitlab.io/smartwhois/)
|
||||||
|
|
||||||
## Status for master
|
## Status for master
|
||||||
|
|
||||||
Status Category | Status Badge
|
Status Category | Status Badge
|
||||||
-- | --
|
-- | --
|
||||||
GitLab Pipelines | [](https://lossless.cloud)
|
GitLab Pipelines | [](https://lossless.cloud)
|
||||||
GitLab Pipline Test Coverage | [](https://lossless.cloud)
|
GitLab Pipline Test Coverage | [](https://lossless.cloud)
|
||||||
npm | [](https://lossless.cloud)
|
npm | [](https://lossless.cloud)
|
||||||
Snyk | [](https://lossless.cloud)
|
Snyk | [](https://lossless.cloud)
|
||||||
TypeScript Support | [](https://lossless.cloud)
|
TypeScript Support | [](https://lossless.cloud)
|
||||||
node Support | [](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
node Support | [](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
Code Style | [](https://lossless.cloud)
|
Code Style | [](https://lossless.cloud)
|
||||||
PackagePhobia (total standalone install weight) | [](https://lossless.cloud)
|
PackagePhobia (total standalone install weight) | [](https://lossless.cloud)
|
||||||
PackagePhobia (package size on registry) | [](https://lossless.cloud)
|
PackagePhobia (package size on registry) | [](https://lossless.cloud)
|
||||||
BundlePhobia (total size when bundled) | [](https://lossless.cloud)
|
BundlePhobia (total size when bundled) | [](https://lossless.cloud)
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
|
25
test/test.ts
25
test/test.ts
@ -1,4 +1,4 @@
|
|||||||
import { expect, expectAsync, tap } from '@pushrocks/tapbundle';
|
import { expect, expectAsync, tap } from '@push.rocks/tapbundle';
|
||||||
import * as smartwhois from '../ts/index.js';
|
import * as smartwhois from '../ts/index.js';
|
||||||
|
|
||||||
let testSmartWhois: smartwhois.SmartWhois;
|
let testSmartWhois: smartwhois.SmartWhois;
|
||||||
@ -6,12 +6,33 @@ let testSmartWhois: smartwhois.SmartWhois;
|
|||||||
tap.test('should create a valid instance of SmartWhois', async () => {
|
tap.test('should create a valid instance of SmartWhois', async () => {
|
||||||
testSmartWhois = new smartwhois.SmartWhois();
|
testSmartWhois = new smartwhois.SmartWhois();
|
||||||
expect(testSmartWhois).toBeInstanceOf(smartwhois.SmartWhois);
|
expect(testSmartWhois).toBeInstanceOf(smartwhois.SmartWhois);
|
||||||
})
|
});
|
||||||
|
|
||||||
|
tap.test('should get a parsed url result for whois', async () => {
|
||||||
|
const domainDelegation = await testSmartWhois.getDomainDelegation('https://coffee.link/understanding-gen-z/');
|
||||||
|
console.log(domainDelegation);
|
||||||
|
const parsedUrlResult2 = await testSmartWhois.getDomainDelegation('task.vc');
|
||||||
|
console.log(parsedUrlResult2);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should get additional data', async () => {
|
||||||
|
const parsedUrlResult = await testSmartWhois.getAdditionalWhoisDataForDomain('https://coffee.link/understanding-gen-z/');
|
||||||
|
console.log(parsedUrlResult);
|
||||||
|
});
|
||||||
|
|
||||||
tap.test('should get whois info for domain', async () => {
|
tap.test('should get whois info for domain', async () => {
|
||||||
const whoisInfo = await testSmartWhois.getWhoisForDomain('task.vc');
|
const whoisInfo = await testSmartWhois.getWhoisForDomain('task.vc');
|
||||||
console.log(whoisInfo);
|
console.log(whoisInfo);
|
||||||
});
|
});
|
||||||
|
tap.test('should get whois info for domain', async () => {
|
||||||
|
const whoisInfo = await testSmartWhois.getWhoisForDomain('https://lossless.com');
|
||||||
|
console.log(whoisInfo);
|
||||||
|
});
|
||||||
|
|
||||||
|
tap.test('should get whois info for domain', async () => {
|
||||||
|
const whoisInfo = await testSmartWhois.getWhoisForDomain('https://coffee.link/understanding-gen-z/');
|
||||||
|
console.log(whoisInfo);
|
||||||
|
});
|
||||||
|
|
||||||
tap.test('should check for a valid tld', async () => {
|
tap.test('should check for a valid tld', async () => {
|
||||||
const comIsValid = await testSmartWhois.isValidTld('.com');
|
const comIsValid = await testSmartWhois.isValidTld('.com');
|
||||||
|
@ -2,7 +2,7 @@
|
|||||||
* autocreated commitinfo by @pushrocks/commitinfo
|
* autocreated commitinfo by @pushrocks/commitinfo
|
||||||
*/
|
*/
|
||||||
export const commitinfo = {
|
export const commitinfo = {
|
||||||
name: '@pushrocks/smartwhois',
|
name: '@push.rocks/smartwhois',
|
||||||
version: '1.0.4',
|
version: '1.0.16',
|
||||||
description: 'a package for dealing with whois requests'
|
description: 'a package for dealing with whois requests'
|
||||||
}
|
}
|
||||||
|
92
ts/index.ts
92
ts/index.ts
@ -1,7 +1,90 @@
|
|||||||
import * as plugins from './smartwhois.plugins.js';
|
import * as plugins from './smartwhois.plugins.js';
|
||||||
|
|
||||||
|
export interface IWhoisInfo {
|
||||||
|
domain: string;
|
||||||
|
isRegistered: boolean;
|
||||||
|
domainStatus: Array<
|
||||||
|
| 'clientTransferProhibited'
|
||||||
|
| 'clientUpdateProhibited'
|
||||||
|
| 'clientDeleteProhibited'
|
||||||
|
| 'clientHold'
|
||||||
|
| 'serverTransferProhibited'
|
||||||
|
| 'serverUpdateProhibited'
|
||||||
|
| 'serverDeleteProhibited'
|
||||||
|
| 'serverHold'
|
||||||
|
| 'inactive'
|
||||||
|
| 'pendingDelete'
|
||||||
|
| 'pendingRenew'
|
||||||
|
| 'pendingTransfer'
|
||||||
|
| 'pendingUpdate'
|
||||||
|
| 'ok'>;
|
||||||
|
domainWithoutSuffix: string;
|
||||||
|
hostname: string;
|
||||||
|
isIcann: boolean;
|
||||||
|
isIp: boolean;
|
||||||
|
isPrivate: boolean;
|
||||||
|
publicSuffix: string;
|
||||||
|
subdomain: string;
|
||||||
|
dnsSec: 'signedDelegation' | 'unsigned';
|
||||||
|
originalWhoisInfo: {
|
||||||
|
[key: string]: any;
|
||||||
|
};
|
||||||
|
whoisServers: string[];
|
||||||
|
registrar: string;
|
||||||
|
registrarUrl: string;
|
||||||
|
createdDate: string;
|
||||||
|
updatedDate: string;
|
||||||
|
expiryDate: string;
|
||||||
|
}
|
||||||
|
|
||||||
export class SmartWhois {
|
export class SmartWhois {
|
||||||
public async getWhoisForDomain(domainArg: string) {
|
/**
|
||||||
|
* can be used to prepare an input for the whois command
|
||||||
|
*/
|
||||||
|
public async getDomainDelegation(urlArg: string): Promise<plugins.tsclass.network.IDomainDelegation> {
|
||||||
|
if (!urlArg.includes('//')) {
|
||||||
|
urlArg = `https://${urlArg}`;
|
||||||
|
}
|
||||||
|
const smarturlInstance = plugins.smarturl.Smarturl.createFromUrl(urlArg);
|
||||||
|
const tldtsData = plugins.tldts.parse(urlArg);
|
||||||
|
return {
|
||||||
|
fullUrl: smarturlInstance.toString(),
|
||||||
|
fullDomain: smarturlInstance.hostname,
|
||||||
|
domain: tldtsData.domain,
|
||||||
|
publicSuffix: tldtsData.publicSuffix,
|
||||||
|
subdomain: tldtsData.subdomain,
|
||||||
|
domainWithoutSuffix: tldtsData.domainWithoutSuffix,
|
||||||
|
isIcann: tldtsData.isIcann,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public async getAdditionalWhoisDataForDomain(domainArg: string) {
|
||||||
|
if (domainArg.includes('//')) {
|
||||||
|
const parsedUrlResult = await this.getDomainDelegation(domainArg);
|
||||||
|
domainArg = parsedUrlResult.fullDomain;
|
||||||
|
}
|
||||||
|
|
||||||
|
// lets test http response
|
||||||
|
const httpResult = await plugins.smartrequest.safeGet(`http://${domainArg}/`);
|
||||||
|
|
||||||
|
// lets test https response
|
||||||
|
const httpsResult = await plugins.smartrequest.safeGet(`https://${domainArg}/`);
|
||||||
|
|
||||||
|
return {
|
||||||
|
httpStatus: httpResult.statusCode,
|
||||||
|
httpsStatus: httpsResult.statusCode,
|
||||||
|
httpHeaders: httpResult.headers,
|
||||||
|
httpsHeaders: httpsResult.headers,
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public async getWhoisForDomain(domainArg: string): Promise<IWhoisInfo> {
|
||||||
|
if (domainArg.includes('//')) {
|
||||||
|
const parsedUrlResult = await this.getDomainDelegation(domainArg);
|
||||||
|
domainArg = parsedUrlResult.fullDomain;
|
||||||
|
}
|
||||||
const whoisInfo = await plugins.whoiser.domain(domainArg);
|
const whoisInfo = await plugins.whoiser.domain(domainArg);
|
||||||
const whoisServers = Object.keys(whoisInfo);
|
const whoisServers = Object.keys(whoisInfo);
|
||||||
const selectedWhoisInfo: any = whoisInfo[whoisServers[0]];
|
const selectedWhoisInfo: any = whoisInfo[whoisServers[0]];
|
||||||
@ -10,7 +93,14 @@ export class SmartWhois {
|
|||||||
const createdDate = selectedWhoisInfo['Created Date'];
|
const createdDate = selectedWhoisInfo['Created Date'];
|
||||||
const updatedDate = selectedWhoisInfo['Updated Date'];
|
const updatedDate = selectedWhoisInfo['Updated Date'];
|
||||||
const expiryDate = selectedWhoisInfo['Expiry Date'];
|
const expiryDate = selectedWhoisInfo['Expiry Date'];
|
||||||
|
|
||||||
|
const tldtsData = plugins.tldts.parse(domainArg);
|
||||||
|
|
||||||
return {
|
return {
|
||||||
|
...tldtsData,
|
||||||
|
isRegistered: true,
|
||||||
|
domainStatus: selectedWhoisInfo['Domain Status'].map((statusArg: string) => statusArg.split(' ')[0]),
|
||||||
|
dnsSec: selectedWhoisInfo['DNSSEC'],
|
||||||
originalWhoisInfo: whoisInfo,
|
originalWhoisInfo: whoisInfo,
|
||||||
whoisServers,
|
whoisServers,
|
||||||
registrar,
|
registrar,
|
||||||
|
@ -1,6 +1,24 @@
|
|||||||
// third party
|
// @tsclass scope
|
||||||
import * as whoiser from 'whoiser';
|
import * as tsclass from '@tsclass/tsclass';
|
||||||
|
|
||||||
export {
|
export {
|
||||||
whoiser
|
tsclass,
|
||||||
|
}
|
||||||
|
|
||||||
|
// pushrocks scope
|
||||||
|
import * as smarturl from '@push.rocks/smarturl';
|
||||||
|
import * as smartrequest from '@push.rocks/smartrequest';
|
||||||
|
|
||||||
|
export {
|
||||||
|
smarturl,
|
||||||
|
smartrequest,
|
||||||
|
}
|
||||||
|
|
||||||
|
// third party
|
||||||
|
import * as whoiser from 'whoiser';
|
||||||
|
import tldts from 'tldts';
|
||||||
|
|
||||||
|
export {
|
||||||
|
whoiser,
|
||||||
|
tldts,
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user