24 Commits

Author SHA1 Message Date
50742ddfa5 1.0.15 2023-10-06 11:10:13 +02:00
83a851a6aa fix(core): update 2023-10-06 11:10:13 +02:00
b6d5f61f3c 1.0.14 2023-04-19 21:51:15 +02:00
101772d8dc fix(core): update 2023-04-19 21:51:14 +02:00
ba4a910962 1.0.13 2023-04-19 21:36:44 +02:00
739c95c1e1 fix(core): update 2023-04-19 21:36:44 +02:00
39442208c8 1.0.12 2023-04-19 18:57:12 +02:00
b686202ae5 fix(core): update 2023-04-19 18:57:12 +02:00
4093d091f4 1.0.11 2023-04-19 18:49:06 +02:00
7a8086b58c fix(core): update 2023-04-19 18:49:06 +02:00
a45e41889d 1.0.10 2023-04-19 18:41:54 +02:00
c33ee3f52c fix(core): update 2023-04-19 18:41:54 +02:00
1732a2ab3e 1.0.9 2023-04-19 14:52:38 +02:00
43ebd17ae6 fix(core): update 2023-04-19 14:52:37 +02:00
18f09a5109 1.0.8 2023-04-18 20:40:39 +02:00
bec73de6d5 fix(core): update 2023-04-18 20:40:39 +02:00
deba684093 1.0.7 2023-04-10 14:43:46 +02:00
1625f507d8 fix(core): update 2023-04-10 14:43:46 +02:00
32f8315493 1.0.6 2023-04-10 14:42:24 +02:00
ffbf56625e fix(core): update 2023-04-10 14:42:24 +02:00
d928a62b5e 1.0.5 2023-04-10 14:34:29 +02:00
b5c5b18f35 fix(core): update 2023-04-10 14:34:28 +02:00
3e3b61cc73 1.0.4 2023-04-03 17:50:55 +02:00
ecb009dedb fix(core): update 2023-04-03 17:50:55 +02:00
8 changed files with 2179 additions and 874 deletions

View File

@ -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"
} }

View File

@ -1,6 +1,6 @@
{ {
"name": "@pushrocks/smartwhois", "name": "@push.rocks/smartwhois",
"version": "1.0.3", "version": "1.0.15",
"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",
@ -10,19 +10,21 @@
"license": "MIT", "license": "MIT",
"scripts": { "scripts": {
"test": "(tstest test/ --web)", "test": "(tstest test/ --web)",
"build": "(tsbuild --web --allowimplicitany)", "build": "(tsbuild --web --allowimplicitany)"
"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

File diff suppressed because it is too large Load Diff

View File

@ -1,8 +1,8 @@
# @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/pushrocks/smartwhois)
* [github.com (source mirror)](https://github.com/pushrocks/smartwhois) * [github.com (source mirror)](https://github.com/pushrocks/smartwhois)
* [docs (typedoc)](https://pushrocks.gitlab.io/smartwhois/) * [docs (typedoc)](https://pushrocks.gitlab.io/smartwhois/)
@ -13,14 +13,14 @@ Status Category | Status Badge
-- | -- -- | --
GitLab Pipelines | [![pipeline status](https://gitlab.com/pushrocks/smartwhois/badges/master/pipeline.svg)](https://lossless.cloud) GitLab Pipelines | [![pipeline status](https://gitlab.com/pushrocks/smartwhois/badges/master/pipeline.svg)](https://lossless.cloud)
GitLab Pipline Test Coverage | [![coverage report](https://gitlab.com/pushrocks/smartwhois/badges/master/coverage.svg)](https://lossless.cloud) GitLab Pipline Test Coverage | [![coverage report](https://gitlab.com/pushrocks/smartwhois/badges/master/coverage.svg)](https://lossless.cloud)
npm | [![npm downloads per month](https://badgen.net/npm/dy/@pushrocks/smartwhois)](https://lossless.cloud) npm | [![npm downloads per month](https://badgen.net/npm/dy/@push.rocks/smartwhois)](https://lossless.cloud)
Snyk | [![Known Vulnerabilities](https://badgen.net/snyk/pushrocks/smartwhois)](https://lossless.cloud) Snyk | [![Known Vulnerabilities](https://badgen.net/snyk/pushrocks/smartwhois)](https://lossless.cloud)
TypeScript Support | [![TypeScript](https://badgen.net/badge/TypeScript/>=%203.x/blue?icon=typescript)](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/) 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) 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/smartwhois)](https://lossless.cloud) PackagePhobia (total standalone install weight) | [![PackagePhobia](https://badgen.net/packagephobia/install/@push.rocks/smartwhois)](https://lossless.cloud)
PackagePhobia (package size on registry) | [![PackagePhobia](https://badgen.net/packagephobia/publish/@pushrocks/smartwhois)](https://lossless.cloud) PackagePhobia (package size on registry) | [![PackagePhobia](https://badgen.net/packagephobia/publish/@push.rocks/smartwhois)](https://lossless.cloud)
BundlePhobia (total size when bundled) | [![BundlePhobia](https://badgen.net/bundlephobia/minzip/@pushrocks/smartwhois)](https://lossless.cloud) BundlePhobia (total size when bundled) | [![BundlePhobia](https://badgen.net/bundlephobia/minzip/@push.rocks/smartwhois)](https://lossless.cloud)
## Usage ## Usage

View File

@ -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,11 +6,38 @@ 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 () => {
const comIsValid = await testSmartWhois.isValidTld('.com');
console.log(comIsValid);
expect(comIsValid).toBeTrue();
})
tap.start(); tap.start();

View File

@ -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.3', version: '1.0.15',
description: 'a package for dealing with whois requests' description: 'a package for dealing with whois requests'
} }

View File

@ -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,
@ -21,5 +111,13 @@ export class SmartWhois {
}; };
} }
public async isValidTld(tldArg: string): Promise<boolean> {
const allTlds = await plugins.whoiser.allTlds();
const sanatizedTld = tldArg.startsWith('.')
? tldArg.replace('.', '').toUpperCase()
: tldArg.toUpperCase();
return allTlds.includes(sanatizedTld);
}
public async getWhoisForIp(ipArg: string) {} public async getWhoisForIp(ipArg: string) {}
} }

View File

@ -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,
} }