@push.rocks/smartregistry 2.3.0 → 2.4.0

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.
Files changed (32) hide show
  1. package/dist_ts/00_commitinfo_data.js +1 -1
  2. package/dist_ts/classes.smartregistry.d.ts +33 -2
  3. package/dist_ts/classes.smartregistry.js +38 -5
  4. package/dist_ts/core/classes.authmanager.d.ts +30 -80
  5. package/dist_ts/core/classes.authmanager.js +63 -337
  6. package/dist_ts/core/classes.defaultauthprovider.d.ts +78 -0
  7. package/dist_ts/core/classes.defaultauthprovider.js +311 -0
  8. package/dist_ts/core/classes.registrystorage.d.ts +70 -4
  9. package/dist_ts/core/classes.registrystorage.js +165 -5
  10. package/dist_ts/core/index.d.ts +3 -0
  11. package/dist_ts/core/index.js +7 -2
  12. package/dist_ts/core/interfaces.auth.d.ts +83 -0
  13. package/dist_ts/core/interfaces.auth.js +2 -0
  14. package/dist_ts/core/interfaces.core.d.ts +35 -0
  15. package/dist_ts/core/interfaces.storage.d.ts +120 -0
  16. package/dist_ts/core/interfaces.storage.js +2 -0
  17. package/dist_ts/upstream/classes.baseupstream.d.ts +2 -2
  18. package/dist_ts/upstream/classes.baseupstream.js +16 -14
  19. package/dist_ts/upstream/classes.upstreamcache.d.ts +69 -22
  20. package/dist_ts/upstream/classes.upstreamcache.js +207 -50
  21. package/package.json +1 -1
  22. package/ts/00_commitinfo_data.ts +1 -1
  23. package/ts/classes.smartregistry.ts +39 -4
  24. package/ts/core/classes.authmanager.ts +74 -412
  25. package/ts/core/classes.defaultauthprovider.ts +393 -0
  26. package/ts/core/classes.registrystorage.ts +199 -5
  27. package/ts/core/index.ts +8 -1
  28. package/ts/core/interfaces.auth.ts +91 -0
  29. package/ts/core/interfaces.core.ts +39 -0
  30. package/ts/core/interfaces.storage.ts +130 -0
  31. package/ts/upstream/classes.baseupstream.ts +20 -15
  32. package/ts/upstream/classes.upstreamcache.ts +256 -53
@@ -3,7 +3,7 @@
3
3
  */
4
4
  export const commitinfo = {
5
5
  name: '@push.rocks/smartregistry',
6
- version: '2.3.0',
6
+ version: '2.4.0',
7
7
  description: 'A composable TypeScript library implementing OCI, NPM, Maven, Cargo, Composer, PyPI, and RubyGems registries for building unified container and package registries'
8
8
  };
9
9
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiMDBfY29tbWl0aW5mb19kYXRhLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vdHMvMDBfY29tbWl0aW5mb19kYXRhLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3hCLElBQUksRUFBRSwyQkFBMkI7SUFDakMsT0FBTyxFQUFFLE9BQU87SUFDaEIsV0FBVyxFQUFFLG9LQUFvSztDQUNsTCxDQUFBIn0=
@@ -3,8 +3,39 @@ import { AuthManager } from './core/classes.authmanager.js';
3
3
  import { BaseRegistry } from './core/classes.baseregistry.js';
4
4
  import type { IRegistryConfig, IRequestContext, IResponse } from './core/interfaces.core.js';
5
5
  /**
6
- * Main registry orchestrator
7
- * Routes requests to appropriate protocol handlers (OCI, NPM, Maven, Cargo, Composer, PyPI, or RubyGems)
6
+ * Main registry orchestrator.
7
+ * Routes requests to appropriate protocol handlers (OCI, NPM, Maven, Cargo, Composer, PyPI, or RubyGems).
8
+ *
9
+ * Supports pluggable authentication and storage hooks:
10
+ *
11
+ * @example
12
+ * ```typescript
13
+ * // Basic usage with default in-memory auth
14
+ * const registry = new SmartRegistry(config);
15
+ *
16
+ * // With custom auth provider (LDAP, OAuth, etc.)
17
+ * const registry = new SmartRegistry({
18
+ * ...config,
19
+ * authProvider: new LdapAuthProvider(ldapClient),
20
+ * });
21
+ *
22
+ * // With storage hooks for quota tracking
23
+ * const registry = new SmartRegistry({
24
+ * ...config,
25
+ * storageHooks: {
26
+ * beforePut: async (ctx) => {
27
+ * const quota = await getQuota(ctx.actor?.orgId);
28
+ * if (ctx.metadata?.size > quota) {
29
+ * return { allowed: false, reason: 'Quota exceeded' };
30
+ * }
31
+ * return { allowed: true };
32
+ * },
33
+ * afterPut: async (ctx) => {
34
+ * await auditLog('storage.put', ctx);
35
+ * }
36
+ * }
37
+ * });
38
+ * ```
8
39
  */
9
40
  export declare class SmartRegistry {
10
41
  private storage;
@@ -9,8 +9,39 @@ import { ComposerRegistry } from './composer/classes.composerregistry.js';
9
9
  import { PypiRegistry } from './pypi/classes.pypiregistry.js';
10
10
  import { RubyGemsRegistry } from './rubygems/classes.rubygemsregistry.js';
11
11
  /**
12
- * Main registry orchestrator
13
- * Routes requests to appropriate protocol handlers (OCI, NPM, Maven, Cargo, Composer, PyPI, or RubyGems)
12
+ * Main registry orchestrator.
13
+ * Routes requests to appropriate protocol handlers (OCI, NPM, Maven, Cargo, Composer, PyPI, or RubyGems).
14
+ *
15
+ * Supports pluggable authentication and storage hooks:
16
+ *
17
+ * @example
18
+ * ```typescript
19
+ * // Basic usage with default in-memory auth
20
+ * const registry = new SmartRegistry(config);
21
+ *
22
+ * // With custom auth provider (LDAP, OAuth, etc.)
23
+ * const registry = new SmartRegistry({
24
+ * ...config,
25
+ * authProvider: new LdapAuthProvider(ldapClient),
26
+ * });
27
+ *
28
+ * // With storage hooks for quota tracking
29
+ * const registry = new SmartRegistry({
30
+ * ...config,
31
+ * storageHooks: {
32
+ * beforePut: async (ctx) => {
33
+ * const quota = await getQuota(ctx.actor?.orgId);
34
+ * if (ctx.metadata?.size > quota) {
35
+ * return { allowed: false, reason: 'Quota exceeded' };
36
+ * }
37
+ * return { allowed: true };
38
+ * },
39
+ * afterPut: async (ctx) => {
40
+ * await auditLog('storage.put', ctx);
41
+ * }
42
+ * }
43
+ * });
44
+ * ```
14
45
  */
15
46
  export class SmartRegistry {
16
47
  storage;
@@ -20,8 +51,10 @@ export class SmartRegistry {
20
51
  initialized = false;
21
52
  constructor(config) {
22
53
  this.config = config;
23
- this.storage = new RegistryStorage(config.storage);
24
- this.authManager = new AuthManager(config.auth);
54
+ // Create storage with optional hooks
55
+ this.storage = new RegistryStorage(config.storage, config.storageHooks);
56
+ // Create auth manager with optional custom provider
57
+ this.authManager = new AuthManager(config.auth, config.authProvider);
25
58
  }
26
59
  /**
27
60
  * Initialize the registry system
@@ -197,4 +230,4 @@ export class SmartRegistry {
197
230
  }
198
231
  }
199
232
  }
200
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"classes.smartregistry.js","sourceRoot":"","sources":["../ts/classes.smartregistry.ts"],"names":[],"mappings":"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"}
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"classes.smartregistry.js","sourceRoot":"","sources":["../ts/classes.smartregistry.ts"],"names":[],"mappings":"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"}
@@ -1,46 +1,47 @@
1
1
  import type { IAuthConfig, IAuthToken, ICredentials, TRegistryProtocol } from './interfaces.core.js';
2
+ import type { IAuthProvider } from './interfaces.auth.js';
2
3
  /**
3
- * Unified authentication manager for all registry protocols
4
- * Handles both NPM UUID tokens and OCI JWT tokens
4
+ * Unified authentication manager for all registry protocols.
5
+ * Delegates to a pluggable IAuthProvider for actual auth operations.
6
+ *
7
+ * @example
8
+ * ```typescript
9
+ * // Use default in-memory provider
10
+ * const auth = new AuthManager(config);
11
+ *
12
+ * // Use custom provider (LDAP, OAuth, etc.)
13
+ * const auth = new AuthManager(config, new LdapAuthProvider(ldapClient));
14
+ * ```
5
15
  */
6
16
  export declare class AuthManager {
7
17
  private config;
8
- private tokenStore;
9
- private userCredentials;
10
- constructor(config: IAuthConfig);
18
+ private provider;
19
+ constructor(config: IAuthConfig, provider?: IAuthProvider);
11
20
  /**
12
21
  * Initialize the auth manager
13
22
  */
14
23
  init(): Promise<void>;
15
24
  /**
16
- * Create a UUID-based token with custom scopes (base method)
17
- * @param userId - User ID
18
- * @param protocol - Protocol type
19
- * @param scopes - Permission scopes
20
- * @param readonly - Whether the token is readonly
21
- * @returns UUID token string
22
- */
23
- private createUuidToken;
24
- /**
25
- * Generic protocol token creation (internal helper)
26
- * @param userId - User ID
27
- * @param protocol - Protocol type (npm, maven, composer, etc.)
28
- * @param readonly - Whether the token is readonly
29
- * @returns UUID token string
25
+ * Authenticate user credentials
26
+ * @param credentials - Username and password
27
+ * @returns User ID or null
30
28
  */
31
- private createProtocolToken;
29
+ authenticate(credentials: ICredentials): Promise<string | null>;
32
30
  /**
33
- * Generic protocol token validation (internal helper)
34
- * @param token - UUID token string
35
- * @param protocol - Expected protocol type
31
+ * Validate any token (NPM, Maven, OCI, PyPI, RubyGems, Composer, Cargo)
32
+ * @param tokenString - Token string (UUID or JWT)
33
+ * @param protocol - Expected protocol type (optional, improves performance)
36
34
  * @returns Auth token object or null
37
35
  */
38
- private validateProtocolToken;
36
+ validateToken(tokenString: string, protocol?: TRegistryProtocol): Promise<IAuthToken | null>;
39
37
  /**
40
- * Generic protocol token revocation (internal helper)
41
- * @param token - UUID token string
38
+ * Check if token has permission for an action
39
+ * @param token - Auth token (or null for anonymous)
40
+ * @param resource - Resource being accessed (e.g., "npm:package:foo")
41
+ * @param action - Action being performed (read, write, push, pull, delete)
42
+ * @returns true if authorized
42
43
  */
43
- private revokeProtocolToken;
44
+ authorize(token: IAuthToken | null, resource: string, action: string): Promise<boolean>;
44
45
  /**
45
46
  * Create an NPM token
46
47
  * @param userId - User ID
@@ -68,13 +69,14 @@ export declare class AuthManager {
68
69
  key: string;
69
70
  readonly: boolean;
70
71
  created: string;
72
+ protocol?: TRegistryProtocol;
71
73
  }>>;
72
74
  /**
73
75
  * Create an OCI JWT token
74
76
  * @param userId - User ID
75
77
  * @param scopes - Permission scopes
76
78
  * @param expiresIn - Expiration time in seconds
77
- * @returns JWT token string (HMAC-SHA256 signed)
79
+ * @returns JWT token string
78
80
  */
79
81
  createOciToken(userId: string, scopes: string[], expiresIn?: number): Promise<string>;
80
82
  /**
@@ -83,12 +85,6 @@ export declare class AuthManager {
83
85
  * @returns Auth token object or null
84
86
  */
85
87
  validateOciToken(jwt: string): Promise<IAuthToken | null>;
86
- /**
87
- * Authenticate user credentials
88
- * @param credentials - Username and password
89
- * @returns User ID or null
90
- */
91
- authenticate(credentials: ICredentials): Promise<string | null>;
92
88
  /**
93
89
  * Create a Maven token
94
90
  * @param userId - User ID
@@ -179,50 +175,4 @@ export declare class AuthManager {
179
175
  * @param token - RubyGems UUID token
180
176
  */
181
177
  revokeRubyGemsToken(token: string): Promise<void>;
182
- /**
183
- * Validate any token (NPM, Maven, OCI, PyPI, RubyGems, Composer, Cargo)
184
- * Optimized: O(1) lookup when protocol hint provided
185
- * @param tokenString - Token string (UUID or JWT)
186
- * @param protocol - Expected protocol type (optional, improves performance)
187
- * @returns Auth token object or null
188
- */
189
- validateToken(tokenString: string, protocol?: TRegistryProtocol): Promise<IAuthToken | null>;
190
- /**
191
- * Check if token has permission for an action
192
- * @param token - Auth token
193
- * @param resource - Resource being accessed (e.g., "package:foo" or "repository:bar")
194
- * @param action - Action being performed (read, write, push, pull, delete)
195
- * @returns true if authorized
196
- */
197
- authorize(token: IAuthToken | null, resource: string, action: string): Promise<boolean>;
198
- /**
199
- * Check if a scope matches a resource and action
200
- * Scope format: "{protocol}:{type}:{name}:{action}"
201
- * Examples:
202
- * - "npm:*:*" - All NPM access
203
- * - "npm:package:foo:*" - All actions on package foo
204
- * - "npm:package:foo:read" - Read-only on package foo
205
- * - "oci:repository:*:pull" - Pull from any OCI repo
206
- */
207
- private matchesScope;
208
- /**
209
- * Convert unified scopes to OCI access array
210
- */
211
- private scopesToOciAccess;
212
- /**
213
- * Convert OCI access array to unified scopes
214
- */
215
- private ociAccessToScopes;
216
- /**
217
- * Generate UUID for NPM tokens
218
- */
219
- private generateUuid;
220
- /**
221
- * Check if string is a valid UUID
222
- */
223
- private isValidUuid;
224
- /**
225
- * Hash a token for identification (SHA-512 mock)
226
- */
227
- private hashToken;
228
178
  }