@scrawn/core 0.0.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/config.d.ts +26 -0
- package/dist/config.d.ts.map +1 -0
- package/dist/config.js +25 -0
- package/dist/config.js.map +1 -0
- package/dist/core/auth/apiKeyAuth.d.ts +67 -0
- package/dist/core/auth/apiKeyAuth.d.ts.map +1 -0
- package/dist/core/auth/apiKeyAuth.js +71 -0
- package/dist/core/auth/apiKeyAuth.js.map +1 -0
- package/dist/core/auth/baseAuth.d.ts +92 -0
- package/dist/core/auth/baseAuth.d.ts.map +1 -0
- package/dist/core/auth/baseAuth.js +28 -0
- package/dist/core/auth/baseAuth.js.map +1 -0
- package/dist/core/grpc/client.d.ts +126 -0
- package/dist/core/grpc/client.d.ts.map +1 -0
- package/dist/core/grpc/client.js +138 -0
- package/dist/core/grpc/client.js.map +1 -0
- package/dist/core/grpc/index.d.ts +12 -0
- package/dist/core/grpc/index.d.ts.map +1 -0
- package/dist/core/grpc/index.js +11 -0
- package/dist/core/grpc/index.js.map +1 -0
- package/dist/core/grpc/requestBuilder.d.ts +116 -0
- package/dist/core/grpc/requestBuilder.d.ts.map +1 -0
- package/dist/core/grpc/requestBuilder.js +146 -0
- package/dist/core/grpc/requestBuilder.js.map +1 -0
- package/dist/core/grpc/types.d.ts +54 -0
- package/dist/core/grpc/types.d.ts.map +1 -0
- package/dist/core/grpc/types.js +9 -0
- package/dist/core/grpc/types.js.map +1 -0
- package/dist/core/scrawn.d.ts +197 -0
- package/dist/core/scrawn.d.ts.map +1 -0
- package/dist/core/scrawn.js +331 -0
- package/dist/core/scrawn.js.map +1 -0
- package/dist/core/types/auth.d.ts +31 -0
- package/dist/core/types/auth.d.ts.map +1 -0
- package/dist/core/types/auth.js +2 -0
- package/dist/core/types/auth.js.map +1 -0
- package/dist/core/types/event.d.ts +119 -0
- package/dist/core/types/event.d.ts.map +1 -0
- package/dist/core/types/event.js +15 -0
- package/dist/core/types/event.js.map +1 -0
- package/dist/gen/auth/v1/auth_connect.d.ts +22 -0
- package/dist/gen/auth/v1/auth_connect.d.ts.map +1 -0
- package/dist/gen/auth/v1/auth_connect.js +26 -0
- package/dist/gen/auth/v1/auth_connect.js.map +1 -0
- package/dist/gen/auth/v1/auth_pb.d.ts +59 -0
- package/dist/gen/auth/v1/auth_pb.d.ts.map +1 -0
- package/dist/gen/auth/v1/auth_pb.js +93 -0
- package/dist/gen/auth/v1/auth_pb.js.map +1 -0
- package/dist/gen/event/v1/event_connect.d.ts +22 -0
- package/dist/gen/event/v1/event_connect.d.ts.map +1 -0
- package/dist/gen/event/v1/event_connect.js +26 -0
- package/dist/gen/event/v1/event_connect.js.map +1 -0
- package/dist/gen/event/v1/event_pb.d.ts +105 -0
- package/dist/gen/event/v1/event_pb.d.ts.map +1 -0
- package/dist/gen/event/v1/event_pb.js +154 -0
- package/dist/gen/event/v1/event_pb.js.map +1 -0
- package/dist/gen/payment/v1/payment_connect.d.ts +22 -0
- package/dist/gen/payment/v1/payment_connect.d.ts.map +1 -0
- package/dist/gen/payment/v1/payment_connect.js +26 -0
- package/dist/gen/payment/v1/payment_connect.js.map +1 -0
- package/dist/gen/payment/v1/payment_pb.d.ts +37 -0
- package/dist/gen/payment/v1/payment_pb.d.ts.map +1 -0
- package/dist/gen/payment/v1/payment_pb.js +66 -0
- package/dist/gen/payment/v1/payment_pb.js.map +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +15 -0
- package/dist/index.js.map +1 -0
- package/dist/utils/logger.d.ts +10 -0
- package/dist/utils/logger.d.ts.map +1 -0
- package/dist/utils/logger.js +62 -0
- package/dist/utils/logger.js.map +1 -0
- package/dist/utils/pathMatcher.d.ts +25 -0
- package/dist/utils/pathMatcher.d.ts.map +1 -0
- package/dist/utils/pathMatcher.js +46 -0
- package/dist/utils/pathMatcher.js.map +1 -0
- package/package.json +37 -0
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
export declare class ScrawnLogger {
|
|
2
|
+
private context;
|
|
3
|
+
constructor(context?: string);
|
|
4
|
+
private log;
|
|
5
|
+
info(msg: string, data?: any): void;
|
|
6
|
+
warn(msg: string, data?: any): void;
|
|
7
|
+
error(msg: string, err?: any): void;
|
|
8
|
+
debug(msg: string, data?: any): void;
|
|
9
|
+
}
|
|
10
|
+
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"AAsBA,qBAAa,YAAY;IACX,OAAO,CAAC,OAAO;gBAAP,OAAO,GAAE,MAAiB;IAE9C,OAAO,CAAC,GAAG;IAiCX,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG;IAI5B,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG;IAI5B,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,GAAG;IAI5B,KAAK,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG;CAG9B"}
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import fs from 'fs';
|
|
2
|
+
import path from 'path';
|
|
3
|
+
import chalk from 'chalk';
|
|
4
|
+
import pino from 'pino';
|
|
5
|
+
import { ScrawnConfig } from 'src/config.js';
|
|
6
|
+
// ensure log file directory exists
|
|
7
|
+
const logFilePath = path.resolve(process.cwd(), 'scrawn.log');
|
|
8
|
+
fs.mkdirSync(path.dirname(logFilePath), { recursive: true });
|
|
9
|
+
// create pino instance writing to file
|
|
10
|
+
const baseLogger = pino({
|
|
11
|
+
name: 'scrawn',
|
|
12
|
+
level: ScrawnConfig.logging.enableDebug ? 'debug' : 'info',
|
|
13
|
+
timestamp: pino.stdTimeFunctions.isoTime,
|
|
14
|
+
}, pino.destination(logFilePath));
|
|
15
|
+
export class ScrawnLogger {
|
|
16
|
+
constructor(context = 'Scrawn') {
|
|
17
|
+
this.context = context;
|
|
18
|
+
}
|
|
19
|
+
log(level, message, ...args) {
|
|
20
|
+
const timestamp = `[${new Date().toLocaleTimeString('en-IN', { timeZone: 'Asia/Kolkata' })}]`;
|
|
21
|
+
const prefix = `[${this.context}]`;
|
|
22
|
+
let colorizedPrefix;
|
|
23
|
+
switch (level) {
|
|
24
|
+
case 'info':
|
|
25
|
+
colorizedPrefix = chalk.cyan(`${timestamp} ${prefix}`);
|
|
26
|
+
baseLogger.info({ context: this.context, ...args[0] }, message);
|
|
27
|
+
break;
|
|
28
|
+
case 'warn':
|
|
29
|
+
colorizedPrefix = chalk.yellow(`${timestamp} ${prefix}`);
|
|
30
|
+
baseLogger.warn({ context: this.context, ...args[0] }, message);
|
|
31
|
+
break;
|
|
32
|
+
case 'error':
|
|
33
|
+
colorizedPrefix = chalk.redBright(`${timestamp} ${prefix}`);
|
|
34
|
+
baseLogger.error({ context: this.context, ...args[0] }, message);
|
|
35
|
+
break;
|
|
36
|
+
case 'debug':
|
|
37
|
+
colorizedPrefix = chalk.magenta(`${timestamp} ${prefix}`);
|
|
38
|
+
baseLogger.debug({ context: this.context, ...args[0] }, message);
|
|
39
|
+
break;
|
|
40
|
+
default:
|
|
41
|
+
colorizedPrefix = `${timestamp} ${prefix}`;
|
|
42
|
+
}
|
|
43
|
+
// skip debug unless enabled
|
|
44
|
+
if (level === 'debug' && !process.env.SCRAWN_DEBUG)
|
|
45
|
+
return;
|
|
46
|
+
// print to console with color
|
|
47
|
+
console.log(`${colorizedPrefix} ${message}`);
|
|
48
|
+
}
|
|
49
|
+
info(msg, data) {
|
|
50
|
+
this.log('info', msg, data);
|
|
51
|
+
}
|
|
52
|
+
warn(msg, data) {
|
|
53
|
+
this.log('warn', msg, data);
|
|
54
|
+
}
|
|
55
|
+
error(msg, err) {
|
|
56
|
+
this.log('error', msg, err instanceof Error ? { err: err.message, stack: err.stack } : err);
|
|
57
|
+
}
|
|
58
|
+
debug(msg, data) {
|
|
59
|
+
this.log('debug', msg, data);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../src/utils/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Match a path against a pattern with wildcard support.
|
|
3
|
+
*
|
|
4
|
+
* Supports:
|
|
5
|
+
* - Exact match: /api/users
|
|
6
|
+
* - Single segment wildcard (*): /api/star matches /api/users but not /api/users/123
|
|
7
|
+
* - Multi-segment wildcard (**): /api/starstar matches /api/users, /api/users/123, etc.
|
|
8
|
+
* - Mixed patterns: /api/star/profile, /api/starstar/data, starstar.php, etc.
|
|
9
|
+
*
|
|
10
|
+
* @param path - The request path to match
|
|
11
|
+
* @param pattern - The pattern to match against
|
|
12
|
+
* @returns true if the path matches the pattern
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```typescript
|
|
16
|
+
* matchPath('/api/users', '/api/users') // true - exact match
|
|
17
|
+
* matchPath('/api/users', '/api/*') // true - single segment wildcard
|
|
18
|
+
* matchPath('/api/users/123', '/api/*') // false - too many segments
|
|
19
|
+
* matchPath('/api/users/123', '/api/**') // true - multi-segment wildcard
|
|
20
|
+
* matchPath('/api/v1/users/data', '/api/** /data') // true - mixed pattern
|
|
21
|
+
* matchPath('/index.php', '**.php') // true - file extension match
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
export declare function matchPath(path: string, pattern: string): boolean;
|
|
25
|
+
//# sourceMappingURL=pathMatcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathMatcher.d.ts","sourceRoot":"","sources":["../../src/utils/pathMatcher.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,wBAAgB,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAuBhE"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Match a path against a pattern with wildcard support.
|
|
3
|
+
*
|
|
4
|
+
* Supports:
|
|
5
|
+
* - Exact match: /api/users
|
|
6
|
+
* - Single segment wildcard (*): /api/star matches /api/users but not /api/users/123
|
|
7
|
+
* - Multi-segment wildcard (**): /api/starstar matches /api/users, /api/users/123, etc.
|
|
8
|
+
* - Mixed patterns: /api/star/profile, /api/starstar/data, starstar.php, etc.
|
|
9
|
+
*
|
|
10
|
+
* @param path - The request path to match
|
|
11
|
+
* @param pattern - The pattern to match against
|
|
12
|
+
* @returns true if the path matches the pattern
|
|
13
|
+
*
|
|
14
|
+
* @example
|
|
15
|
+
* ```typescript
|
|
16
|
+
* matchPath('/api/users', '/api/users') // true - exact match
|
|
17
|
+
* matchPath('/api/users', '/api/*') // true - single segment wildcard
|
|
18
|
+
* matchPath('/api/users/123', '/api/*') // false - too many segments
|
|
19
|
+
* matchPath('/api/users/123', '/api/**') // true - multi-segment wildcard
|
|
20
|
+
* matchPath('/api/v1/users/data', '/api/** /data') // true - mixed pattern
|
|
21
|
+
* matchPath('/index.php', '**.php') // true - file extension match
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
export function matchPath(path, pattern) {
|
|
25
|
+
// Exact match
|
|
26
|
+
if (path === pattern)
|
|
27
|
+
return true;
|
|
28
|
+
// No wildcards, no match
|
|
29
|
+
if (!pattern.includes('*'))
|
|
30
|
+
return false;
|
|
31
|
+
// Convert pattern to regex
|
|
32
|
+
// Escape special regex characters except * and /
|
|
33
|
+
let regexPattern = pattern
|
|
34
|
+
.replace(/[.+?^${}()|[\]\\]/g, '\\$&')
|
|
35
|
+
// Replace ** with a placeholder to handle it separately
|
|
36
|
+
.replace(/\*\*/g, '___DOUBLE_STAR___')
|
|
37
|
+
// Replace * with single segment match (anything except /)
|
|
38
|
+
.replace(/\*/g, '[^/]+')
|
|
39
|
+
// Replace ** placeholder with multi-segment match (anything including /)
|
|
40
|
+
.replace(/___DOUBLE_STAR___/g, '.*');
|
|
41
|
+
// Ensure we match the full path
|
|
42
|
+
regexPattern = `^${regexPattern}$`;
|
|
43
|
+
const regex = new RegExp(regexPattern);
|
|
44
|
+
return regex.test(path);
|
|
45
|
+
}
|
|
46
|
+
//# sourceMappingURL=pathMatcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"pathMatcher.js","sourceRoot":"","sources":["../../src/utils/pathMatcher.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;GAsBG;AACH,MAAM,UAAU,SAAS,CAAC,IAAY,EAAE,OAAe;IACrD,cAAc;IACd,IAAI,IAAI,KAAK,OAAO;QAAE,OAAO,IAAI,CAAC;IAElC,yBAAyB;IACzB,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC;QAAE,OAAO,KAAK,CAAC;IAEzC,2BAA2B;IAC3B,iDAAiD;IACjD,IAAI,YAAY,GAAG,OAAO;SACvB,OAAO,CAAC,oBAAoB,EAAE,MAAM,CAAC;QACtC,wDAAwD;SACvD,OAAO,CAAC,OAAO,EAAE,mBAAmB,CAAC;QACtC,0DAA0D;SACzD,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC;QACxB,yEAAyE;SACxE,OAAO,CAAC,oBAAoB,EAAE,IAAI,CAAC,CAAC;IAEvC,gCAAgC;IAChC,YAAY,GAAG,IAAI,YAAY,GAAG,CAAC;IAEnC,MAAM,KAAK,GAAG,IAAI,MAAM,CAAC,YAAY,CAAC,CAAC;IACvC,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@scrawn/core",
|
|
3
|
+
"version": "0.0.2",
|
|
4
|
+
"type": "module",
|
|
5
|
+
"main": "./dist/index.js",
|
|
6
|
+
"types": "./dist/index.d.ts",
|
|
7
|
+
"exports": {
|
|
8
|
+
".": {
|
|
9
|
+
"types": "./dist/index.d.ts",
|
|
10
|
+
"import": "./dist/index.js"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"scripts": {
|
|
14
|
+
"build": "tsc",
|
|
15
|
+
"clean": "node -e \"require('fs').rmSync('dist', {recursive: true, force: true})\"",
|
|
16
|
+
"gen": "cd proto && bunx buf generate"
|
|
17
|
+
},
|
|
18
|
+
"dependencies": {
|
|
19
|
+
"@bufbuild/protobuf": "^1.10.0",
|
|
20
|
+
"@bufbuild/protoc-gen-es": "^1.10.0",
|
|
21
|
+
"@connectrpc/connect": "^1.7.0",
|
|
22
|
+
"@connectrpc/connect-node": "^1.7.0",
|
|
23
|
+
"@connectrpc/protoc-gen-connect-es": "^1.7.0",
|
|
24
|
+
"@connectrpc/validate": "^0.2.0",
|
|
25
|
+
"buf": "bufbuild/buf",
|
|
26
|
+
"chalk": "^5.6.2",
|
|
27
|
+
"pino": "^10.1.0",
|
|
28
|
+
"typescript": "^5.9.3",
|
|
29
|
+
"zod": "^4.1.12"
|
|
30
|
+
},
|
|
31
|
+
"devDependencies": {
|
|
32
|
+
"@types/node": "^24.10.0"
|
|
33
|
+
},
|
|
34
|
+
"files": [
|
|
35
|
+
"dist"
|
|
36
|
+
]
|
|
37
|
+
}
|