Compare commits
4 Commits
Author | SHA1 | Date | |
---|---|---|---|
5887eefbca | |||
615fb17baa | |||
cba5c17252 | |||
04604770b1 |
4
.gitignore
vendored
4
.gitignore
vendored
@ -15,8 +15,6 @@ node_modules/
|
|||||||
|
|
||||||
# builds
|
# builds
|
||||||
dist/
|
dist/
|
||||||
dist_web/
|
dist_*/
|
||||||
dist_serve/
|
|
||||||
dist_ts_web/
|
|
||||||
|
|
||||||
# custom
|
# custom
|
@ -19,22 +19,35 @@ mirror:
|
|||||||
stage: security
|
stage: security
|
||||||
script:
|
script:
|
||||||
- npmci git mirror
|
- npmci git mirror
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
tags:
|
tags:
|
||||||
- lossless
|
- lossless
|
||||||
- docker
|
- docker
|
||||||
- notpriv
|
- notpriv
|
||||||
|
|
||||||
snyk:
|
auditProductionDependencies:
|
||||||
image: registry.gitlab.com/hosttoday/ht-docker-node:snyk
|
image: registry.gitlab.com/hosttoday/ht-docker-node:npmci
|
||||||
|
stage: security
|
||||||
|
script:
|
||||||
|
- npmci npm prepare
|
||||||
|
- npmci command npm install --production --ignore-scripts
|
||||||
|
- npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
- npmci command npm audit --audit-level=high --only=prod --production
|
||||||
|
tags:
|
||||||
|
- docker
|
||||||
|
|
||||||
|
auditDevDependencies:
|
||||||
|
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 --ignore-scripts
|
- npmci command npm install --ignore-scripts
|
||||||
- npmci command snyk test
|
- npmci command npm config set registry https://registry.npmjs.org
|
||||||
|
- npmci command npm audit --audit-level=high --only=dev
|
||||||
tags:
|
tags:
|
||||||
- lossless
|
|
||||||
- docker
|
- docker
|
||||||
- notpriv
|
allow_failure: true
|
||||||
|
|
||||||
# ====================
|
# ====================
|
||||||
# test stage
|
# test stage
|
||||||
@ -49,9 +62,7 @@ testStable:
|
|||||||
- npmci npm test
|
- npmci npm test
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- lossless
|
|
||||||
- docker
|
- docker
|
||||||
- priv
|
|
||||||
|
|
||||||
testBuild:
|
testBuild:
|
||||||
stage: test
|
stage: test
|
||||||
@ -62,9 +73,7 @@ testBuild:
|
|||||||
- npmci command npm run build
|
- npmci command npm run build
|
||||||
coverage: /\d+.?\d+?\%\s*coverage/
|
coverage: /\d+.?\d+?\%\s*coverage/
|
||||||
tags:
|
tags:
|
||||||
- lossless
|
|
||||||
- docker
|
- docker
|
||||||
- notpriv
|
|
||||||
|
|
||||||
release:
|
release:
|
||||||
stage: release
|
stage: release
|
||||||
@ -84,6 +93,8 @@ release:
|
|||||||
codequality:
|
codequality:
|
||||||
stage: metadata
|
stage: metadata
|
||||||
allow_failure: true
|
allow_failure: true
|
||||||
|
only:
|
||||||
|
- tags
|
||||||
script:
|
script:
|
||||||
- npmci command npm install -g tslint typescript
|
- npmci command npm install -g tslint typescript
|
||||||
- npmci npm prepare
|
- npmci npm prepare
|
||||||
|
8
.vscode/settings.json
vendored
8
.vscode/settings.json
vendored
@ -11,7 +11,13 @@
|
|||||||
},
|
},
|
||||||
"gitzone": {
|
"gitzone": {
|
||||||
"type": "object",
|
"type": "object",
|
||||||
"description": "settings for gitzone"
|
"description": "settings for gitzone",
|
||||||
|
"properties": {
|
||||||
|
"projectType": {
|
||||||
|
"type": "string",
|
||||||
|
"enum": ["website", "element", "service", "npm", "wcc"]
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,5 +1,6 @@
|
|||||||
{
|
{
|
||||||
"gitzone": {
|
"gitzone": {
|
||||||
|
"projectType": "npm",
|
||||||
"module": {
|
"module": {
|
||||||
"githost": "gitlab.com",
|
"githost": "gitlab.com",
|
||||||
"gitscope": "uptimelink",
|
"gitscope": "uptimelink",
|
||||||
|
27053
package-lock.json
generated
27053
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
27
package.json
27
package.json
@ -1,37 +1,40 @@
|
|||||||
{
|
{
|
||||||
"name": "@uptimelink/interfaces",
|
"name": "@uptimelink/interfaces",
|
||||||
"version": "1.0.8",
|
"version": "1.0.10",
|
||||||
"private": false,
|
"private": false,
|
||||||
"description": "TypeScript interface for the uptime.link API and modules",
|
"description": "TypeScript interface for the uptime.link API and modules",
|
||||||
"main": "dist/index.js",
|
"main": "dist_ts/index.js",
|
||||||
"typings": "dist/index.d.ts",
|
"typings": "dist_ts/index.d.ts",
|
||||||
"author": "Lossless GmbH",
|
"author": "Lossless GmbH",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "(tstest test/)",
|
"test": "(tstest test/)",
|
||||||
"build": "(tsbuild)",
|
"build": "(tsbuild --web)"
|
||||||
"format": "(gitzone format)"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@gitzone/tsbuild": "^2.0.22",
|
"@gitzone/tsbuild": "^2.1.27",
|
||||||
"@gitzone/tstest": "^1.0.15",
|
"@gitzone/tstest": "^1.0.57",
|
||||||
"@pushrocks/tapbundle": "^3.0.7",
|
"@pushrocks/tapbundle": "^3.2.14",
|
||||||
"@types/node": "^10.11.7",
|
"@types/node": "^16.10.1",
|
||||||
"tslint": "^5.11.0",
|
"tslint": "^6.1.3",
|
||||||
"tslint-config-prettier": "^1.15.0"
|
"tslint-config-prettier": "^1.15.0"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@apiglobal/typedrequest-interfaces": "^1.0.10"
|
"@apiglobal/typedrequest-interfaces": "^1.0.15"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"ts/**/*",
|
"ts/**/*",
|
||||||
"ts_web/**/*",
|
"ts_web/**/*",
|
||||||
"dist/**/*",
|
"dist/**/*",
|
||||||
"dist_web/**/*",
|
"dist_*/**/*",
|
||||||
|
"dist_ts/**/*",
|
||||||
"dist_ts_web/**/*",
|
"dist_ts_web/**/*",
|
||||||
"assets/**/*",
|
"assets/**/*",
|
||||||
"cli.js",
|
"cli.js",
|
||||||
"npmextra.json",
|
"npmextra.json",
|
||||||
"readme.md"
|
"readme.md"
|
||||||
|
],
|
||||||
|
"browserslist": [
|
||||||
|
"last 1 chrome versions"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
25
readme.md
25
readme.md
@ -8,16 +8,27 @@ TypeScript interface for the uptime.link API and modules
|
|||||||
* [docs (typedoc)](https://uptimelink.gitlab.io/interfaces/)
|
* [docs (typedoc)](https://uptimelink.gitlab.io/interfaces/)
|
||||||
|
|
||||||
## Status for master
|
## Status for master
|
||||||
[](https://gitlab.com/uptimelink/interfaces/commits/master)
|
|
||||||
[](https://gitlab.com/uptimelink/interfaces/commits/master)
|
Status Category | Status Badge
|
||||||
[](https://www.npmjs.com/package/@uptimelink/interfaces)
|
-- | --
|
||||||
[](https://snyk.io/test/npm/@uptimelink/interfaces)
|
GitLab Pipelines | [](https://lossless.cloud)
|
||||||
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
GitLab Pipline Test Coverage | [](https://lossless.cloud)
|
||||||
[](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
npm | [](https://lossless.cloud)
|
||||||
[](https://prettier.io/)
|
Snyk | [](https://lossless.cloud)
|
||||||
|
TypeScript Support | [](https://lossless.cloud)
|
||||||
|
node Support | [](https://nodejs.org/dist/latest-v10.x/docs/api/)
|
||||||
|
Code Style | [](https://lossless.cloud)
|
||||||
|
PackagePhobia (total standalone install weight) | [](https://lossless.cloud)
|
||||||
|
PackagePhobia (package size on registry) | [](https://lossless.cloud)
|
||||||
|
BundlePhobia (total size when bundled) | [](https://lossless.cloud)
|
||||||
|
Platform support | [](https://lossless.cloud) [](https://lossless.cloud)
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
|
## 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). :)
|
||||||
|
|
||||||
|
|
||||||
## Contribution
|
## Contribution
|
||||||
|
|
||||||
|
@ -2,8 +2,9 @@ import { expect, tap } from '@pushrocks/tapbundle';
|
|||||||
import * as interfaces from '../ts/index';
|
import * as interfaces from '../ts/index';
|
||||||
|
|
||||||
tap.test('first test', async () => {
|
tap.test('first test', async () => {
|
||||||
console.log('hi' as interfaces.pagechecks.IRequest_PageCheck_Assumption['request']['domain']);
|
console.log(
|
||||||
|
'hi' as interfaces.requests.checkRequests.IRequest_PageCheck_Assumption['request']['domain']
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
tap.start();
|
tap.start();
|
||||||
|
22
ts/data/incident.ts
Normal file
22
ts/data/incident.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import * as plugins from '../ul-interfaces.plugins';
|
||||||
|
|
||||||
|
export interface IIncident {
|
||||||
|
timestamp: number;
|
||||||
|
firstResponseTimestamp?: number;
|
||||||
|
/**
|
||||||
|
* indicates
|
||||||
|
*/
|
||||||
|
status: 'discovered' | 'investigating' | 'fixing' | 'fixImplemented' | 'watching' | 'resolved';
|
||||||
|
creationMode: 'monitor' | 'manual';
|
||||||
|
assignedUserId?: string;
|
||||||
|
postMortemLink?: string;
|
||||||
|
|
||||||
|
updates: {
|
||||||
|
markdownText: string;
|
||||||
|
type: 'comment' | 'manualUpdate' | 'automaticUpdate'
|
||||||
|
}[];
|
||||||
|
|
||||||
|
justForLooks: {
|
||||||
|
isoTimestamp: string;
|
||||||
|
}
|
||||||
|
}
|
1
ts/data/index.ts
Normal file
1
ts/data/index.ts
Normal file
@ -0,0 +1 @@
|
|||||||
|
export * from './incident';
|
@ -1,5 +1,4 @@
|
|||||||
import * as checkRequests from './ul-interfaces.checkrequest';
|
import * as requests from './requests';
|
||||||
|
import * as data from './data';
|
||||||
|
|
||||||
export {
|
export { requests, data };
|
||||||
checkRequests as pagechecks
|
|
||||||
};
|
|
||||||
|
3
ts/requests/index.ts
Normal file
3
ts/requests/index.ts
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
import * as checkRequests from './requests.checks';
|
||||||
|
|
||||||
|
export { checkRequests };
|
@ -1,11 +1,15 @@
|
|||||||
import * as plugins from './ul-interfaces.plugins';
|
import * as plugins from '../ul-interfaces.plugins';
|
||||||
|
|
||||||
export type TCheckResultStatus = 'ok' | 'not ok' | 'timed out';
|
export type TCheckResultStatus = 'ok' | 'not ok' | 'timed out';
|
||||||
|
|
||||||
export interface IRequest_PageCheck_PWA {
|
export interface IRequest_PageCheck_PWA
|
||||||
|
extends plugins.typedRequestInterfaces.implementsTR<
|
||||||
|
plugins.typedRequestInterfaces.ITypedRequest,
|
||||||
|
IRequest_PageCheck_PWA
|
||||||
|
> {
|
||||||
method: 'pwa';
|
method: 'pwa';
|
||||||
request: {
|
request: {
|
||||||
intervalMs: number,
|
intervalMs: number;
|
||||||
domain: string;
|
domain: string;
|
||||||
};
|
};
|
||||||
response: {
|
response: {
|
||||||
@ -21,10 +25,14 @@ export interface IRequest_PageCheck_PWA {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface IRequest_PageCheck_Function {
|
export interface IRequest_PageCheck_Function
|
||||||
|
extends plugins.typedRequestInterfaces.implementsTR<
|
||||||
|
plugins.typedRequestInterfaces.ITypedRequest,
|
||||||
|
IRequest_PageCheck_Function
|
||||||
|
> {
|
||||||
method: 'function';
|
method: 'function';
|
||||||
request: {
|
request: {
|
||||||
intervalMs: number,
|
intervalMs: number;
|
||||||
domain: string;
|
domain: string;
|
||||||
functionDef: string;
|
functionDef: string;
|
||||||
};
|
};
|
||||||
@ -38,10 +46,14 @@ export interface IRequest_PageCheck_Function {
|
|||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export interface IRequest_PageCheck_Assumption {
|
export interface IRequest_PageCheck_Assumption
|
||||||
|
extends plugins.typedRequestInterfaces.implementsTR<
|
||||||
|
plugins.typedRequestInterfaces.ITypedRequest,
|
||||||
|
IRequest_PageCheck_Assumption
|
||||||
|
> {
|
||||||
method: 'assumption';
|
method: 'assumption';
|
||||||
request: {
|
request: {
|
||||||
intervalMs: number,
|
intervalMs: number;
|
||||||
domain: string;
|
domain: string;
|
||||||
title?: string;
|
title?: string;
|
||||||
statusCode?: string;
|
statusCode?: string;
|
||||||
@ -64,4 +76,4 @@ export interface IRequest_PageCheck_Assumption {
|
|||||||
};
|
};
|
||||||
checkLog: string[];
|
checkLog: string[];
|
||||||
};
|
};
|
||||||
}
|
}
|
16
ts/requests/requests.incidents.ts
Normal file
16
ts/requests/requests.incidents.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import * as plugins from '../ul-interfaces.plugins';
|
||||||
|
import * as data from '../data';
|
||||||
|
|
||||||
|
export interface IRequest_Incidents_Get extends plugins.typedRequestInterfaces.implementsTR<
|
||||||
|
plugins.typedRequestInterfaces.ITypedRequest,
|
||||||
|
IRequest_Incidents_Get
|
||||||
|
> {
|
||||||
|
method: 'getIncidents',
|
||||||
|
request: {
|
||||||
|
userToken?: string;
|
||||||
|
};
|
||||||
|
response: {
|
||||||
|
currentIncidents: data.IIncident[];
|
||||||
|
pastIncidents: data.IIncident[];
|
||||||
|
}
|
||||||
|
}
|
5
ts/status.ts
Normal file
5
ts/status.ts
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
export type TServiceStatus = 'up' | 'down';
|
||||||
|
|
||||||
|
export interface IHourlyStatus {
|
||||||
|
states: { unixTimes: number; status: TServiceStatus };
|
||||||
|
}
|
@ -1,5 +1,3 @@
|
|||||||
import * as typedRequestInterfaces from '@apiglobal/typedrequest-interfaces';
|
import * as typedRequestInterfaces from '@apiglobal/typedrequest-interfaces';
|
||||||
|
|
||||||
export {
|
export { typedRequestInterfaces };
|
||||||
typedRequestInterfaces
|
|
||||||
};
|
|
||||||
|
Reference in New Issue
Block a user