@loomcore/common 0.0.30 → 0.0.32

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.
@@ -1,7 +1,7 @@
1
1
  export * from './user.model.js';
2
- export * from './authorization.model.js';
3
2
  export * from './organization.model.js';
4
3
  export * from './user-context.model.js';
4
+ export * from './user-context-authorization.model.js';
5
5
  export * from './entity.model.js';
6
6
  export * from './login-response.model.js';
7
7
  export * from './token-response.model.js';
@@ -1,7 +1,7 @@
1
1
  export * from './user.model.js';
2
- export * from './authorization.model.js';
3
2
  export * from './organization.model.js';
4
3
  export * from './user-context.model.js';
4
+ export * from './user-context-authorization.model.js';
5
5
  export * from './entity.model.js';
6
6
  export * from './login-response.model.js';
7
7
  export * from './token-response.model.js';
@@ -12,7 +12,8 @@ export declare const LoginResponseSchema: import("@sinclair/typebox").TObject<{
12
12
  }>;
13
13
  userContext: import("@sinclair/typebox").TObject<{
14
14
  user: import("@sinclair/typebox").TSchema;
15
- _orgId: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
15
+ authorizations: import("@sinclair/typebox").TArray<import("@sinclair/typebox").TSchema>;
16
+ organization: import("@sinclair/typebox").TSchema;
16
17
  }>;
17
18
  }>;
18
19
  export declare const LoginResponseSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
@@ -9,6 +9,7 @@ export interface IOrganization extends IAuditable {
9
9
  authToken?: string;
10
10
  }
11
11
  export declare const OrganizationSchema: import("@sinclair/typebox").TObject<{
12
+ _id: import("@sinclair/typebox").TString;
12
13
  name: import("@sinclair/typebox").TString;
13
14
  code: import("@sinclair/typebox").TString;
14
15
  description: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
@@ -1,6 +1,9 @@
1
1
  import { Type } from '@sinclair/typebox';
2
2
  import { entityUtils } from '../utils/index.js';
3
3
  export const OrganizationSchema = Type.Object({
4
+ _id: Type.String({
5
+ title: 'ID'
6
+ }),
4
7
  name: Type.String({
5
8
  title: 'Name'
6
9
  }),
@@ -0,0 +1,12 @@
1
+ import { IEntity } from "./entity.model.js";
2
+ export interface IUserContextAuthorization extends IEntity {
3
+ role: string;
4
+ feature: string;
5
+ config?: any;
6
+ }
7
+ export declare const UserContextAuthorizationSchema: import("@sinclair/typebox").TObject<{
8
+ role: import("@sinclair/typebox").TString;
9
+ feature: import("@sinclair/typebox").TString;
10
+ config: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TAny>;
11
+ }>;
12
+ export declare const UserContextAuthorizationSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
@@ -0,0 +1,8 @@
1
+ import { Type } from "@sinclair/typebox";
2
+ import { entityUtils } from "../utils/entity.utils.js";
3
+ export const UserContextAuthorizationSchema = Type.Object({
4
+ role: Type.String(),
5
+ feature: Type.String(),
6
+ config: Type.Optional(Type.Any())
7
+ });
8
+ export const UserContextAuthorizationSpec = entityUtils.getModelSpec(UserContextAuthorizationSchema);
@@ -1,20 +1,25 @@
1
- import { IUserOut } from './user.model.js';
1
+ import { IUser } from './user.model.js';
2
+ import { IOrganization } from './organization.model.js';
3
+ import { IUserContextAuthorization } from './user-context-authorization.model.js';
2
4
  export interface IUserContext {
3
- user: IUserOut;
4
- _orgId?: string;
5
+ user: IUser;
6
+ authorizations: IUserContextAuthorization[];
7
+ organization?: IOrganization;
5
8
  }
6
9
  export declare const EmptyUserContext: IUserContext;
7
10
  export declare const UserContextSchema: import("@sinclair/typebox").TObject<{
8
11
  user: import("@sinclair/typebox").TSchema;
9
- _orgId: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
12
+ authorizations: import("@sinclair/typebox").TArray<import("@sinclair/typebox").TSchema>;
13
+ organization: import("@sinclair/typebox").TSchema;
10
14
  }>;
11
15
  export declare const UserContextSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
12
16
  export declare const PublicUserContextSchema: import("@sinclair/typebox").TObject<{
13
17
  user: import("@sinclair/typebox").TSchema;
14
- _orgId: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
18
+ authorizations: import("@sinclair/typebox").TArray<import("@sinclair/typebox").TSchema>;
19
+ organization: import("@sinclair/typebox").TSchema;
15
20
  }>;
16
21
  export declare const PublicUserContextSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
17
- export declare function initializeSystemUserContext(systemEmail: string, metaOrgId: string | undefined): IUserContext;
22
+ export declare function initializeSystemUserContext(systemEmail: string, metaOrg: IOrganization | undefined): IUserContext;
18
23
  export declare function getSystemUserContext(): IUserContext;
19
24
  export declare function isSystemUserContextInitialized(): boolean;
20
25
  export declare function resetSystemUserContext(): void;
@@ -1,42 +1,48 @@
1
1
  import { PublicUserSpec, UserSpec } from './user.model.js';
2
2
  import { Type } from '@sinclair/typebox';
3
3
  import { entityUtils } from '../utils/entity.utils.js';
4
+ import { OrganizationSpec } from './organization.model.js';
5
+ import { UserContextAuthorizationSpec } from './user-context-authorization.model.js';
4
6
  export const EmptyUserContext = {
5
7
  user: {},
6
- _orgId: undefined
8
+ authorizations: [],
9
+ organization: undefined
7
10
  };
8
11
  let _systemUserContext = null;
9
12
  export const UserContextSchema = Type.Object({
10
13
  user: UserSpec.fullSchema,
11
- _orgId: Type.Optional(Type.String())
14
+ authorizations: Type.Array(UserContextAuthorizationSpec.fullSchema),
15
+ organization: OrganizationSpec.fullSchema
12
16
  });
13
17
  export const UserContextSpec = entityUtils.getModelSpec(UserContextSchema);
14
18
  export const PublicUserContextSchema = Type.Object({
15
19
  user: PublicUserSpec.fullSchema,
16
- _orgId: Type.Optional(Type.String())
20
+ authorizations: Type.Array(UserContextAuthorizationSpec.fullSchema),
21
+ organization: OrganizationSpec.fullSchema
17
22
  });
18
23
  export const PublicUserContextSpec = entityUtils.getModelSpec(PublicUserContextSchema);
19
- export function initializeSystemUserContext(systemEmail, metaOrgId) {
24
+ export function initializeSystemUserContext(systemEmail, metaOrg) {
20
25
  _systemUserContext = {
21
26
  user: {
22
27
  _id: 'system',
23
- _orgId: metaOrgId,
28
+ _orgId: metaOrg?._id,
29
+ email: systemEmail,
24
30
  firstName: 'System',
25
31
  lastName: 'User',
26
32
  displayName: 'System User',
27
- email: systemEmail,
28
- authorizations: [{
29
- _id: 'system-authorization',
30
- _orgId: metaOrgId,
31
- role: 'system',
32
- feature: 'system',
33
- }],
33
+ password: 'systemPassword',
34
34
  _created: new Date(),
35
35
  _createdBy: 'system',
36
36
  _updated: new Date(),
37
37
  _updatedBy: 'system',
38
38
  },
39
- _orgId: metaOrgId,
39
+ authorizations: [{
40
+ _id: 'system-authorization',
41
+ _orgId: metaOrg?._id,
42
+ role: 'system',
43
+ feature: 'system'
44
+ }],
45
+ organization: metaOrg
40
46
  };
41
47
  return _systemUserContext;
42
48
  }
@@ -1,44 +1,30 @@
1
1
  import { IAuditable } from './auditable.model.js';
2
2
  import { IEntity } from './entity.model.js';
3
- import { IAuthorizationOut } from './authorization.model.js';
4
- export interface IUserBase extends IEntity, IAuditable {
3
+ export interface IUser extends IEntity, IAuditable {
5
4
  email: string;
6
5
  firstName?: string;
7
6
  lastName?: string;
8
7
  displayName?: string;
8
+ password: string;
9
9
  _lastLoggedIn?: Date;
10
10
  _lastPasswordChange?: Date;
11
11
  }
12
- export interface IUserIn extends IUserBase {
13
- password?: string;
14
- }
15
12
  export declare const UserPasswordSchema: import("@sinclair/typebox").TObject<{
16
13
  password: import("@sinclair/typebox").TString;
17
14
  }>;
18
15
  export declare const passwordValidator: import("@sinclair/typebox/compiler").TypeCheck<import("@sinclair/typebox").TObject<{
19
16
  password: import("@sinclair/typebox").TString;
20
17
  }>>;
21
- export declare const UserSchemaBase: import("@sinclair/typebox").TObject<{
22
- email: import("@sinclair/typebox").TString;
23
- firstName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
24
- lastName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
25
- displayName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
26
- _lastLoggedIn: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
27
- _lastPasswordChange: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
28
- }>;
29
18
  export declare const UserSchema: import("@sinclair/typebox").TObject<{
30
19
  email: import("@sinclair/typebox").TString;
31
20
  firstName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
32
21
  lastName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
33
22
  displayName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
23
+ password: import("@sinclair/typebox").TString;
34
24
  _lastLoggedIn: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
35
25
  _lastPasswordChange: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
36
- password: import("@sinclair/typebox").TString;
37
26
  }>;
38
27
  export declare const UserSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
39
- export interface IUserOut extends IUserBase {
40
- authorizations?: IAuthorizationOut[];
41
- }
42
28
  export declare const PublicUserSchema: import("@sinclair/typebox").TObject<{
43
29
  email: import("@sinclair/typebox").TString;
44
30
  firstName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
@@ -46,10 +32,5 @@ export declare const PublicUserSchema: import("@sinclair/typebox").TObject<{
46
32
  displayName: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TString>;
47
33
  _lastLoggedIn: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
48
34
  _lastPasswordChange: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
49
- authorizations: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TArray<import("@sinclair/typebox").TObject<{
50
- role: import("@sinclair/typebox").TString;
51
- feature: import("@sinclair/typebox").TString;
52
- config: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TAny>;
53
- }>>>;
54
35
  }>;
55
36
  export declare const PublicUserSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
@@ -2,7 +2,6 @@ import { TypeboxIsoDate } from '../validation/typebox-extensions.js';
2
2
  import { Type } from '@sinclair/typebox';
3
3
  import { entityUtils } from '../utils/entity.utils.js';
4
4
  import { TypeCompiler } from '@sinclair/typebox/compiler';
5
- import { PublicAuthorizationSchema } from './authorization.model.js';
6
5
  export const UserPasswordSchema = Type.Object({
7
6
  password: Type.String({
8
7
  title: 'Password',
@@ -11,7 +10,7 @@ export const UserPasswordSchema = Type.Object({
11
10
  }),
12
11
  });
13
12
  export const passwordValidator = TypeCompiler.Compile(UserPasswordSchema);
14
- export const UserSchemaBase = Type.Object({
13
+ export const UserSchema = Type.Object({
15
14
  email: Type.String({
16
15
  title: 'Email',
17
16
  format: 'email'
@@ -25,20 +24,10 @@ export const UserSchemaBase = Type.Object({
25
24
  displayName: Type.Optional(Type.String({
26
25
  title: 'Display Name'
27
26
  })),
27
+ password: UserPasswordSchema.properties.password,
28
28
  _lastLoggedIn: Type.Optional(TypeboxIsoDate({ title: 'Last Login Date' })),
29
29
  _lastPasswordChange: Type.Optional(TypeboxIsoDate({ title: 'Last Password Change Date' })),
30
30
  });
31
- export const UserSchema = Type.Composite([
32
- UserSchemaBase,
33
- Type.Object({
34
- password: UserPasswordSchema.properties.password,
35
- })
36
- ]);
37
31
  export const UserSpec = entityUtils.getModelSpec(UserSchema, { isAuditable: true });
38
- export const PublicUserSchema = Type.Composite([
39
- UserSchemaBase,
40
- Type.Object({
41
- authorizations: Type.Optional(Type.Array(PublicAuthorizationSchema, { title: 'Authorizations' })),
42
- })
43
- ]);
32
+ export const PublicUserSchema = Type.Omit(UserSchema, ['password']);
44
33
  export const PublicUserSpec = entityUtils.getModelSpec(PublicUserSchema, { isAuditable: true });
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@loomcore/common",
3
- "version": "0.0.30",
3
+ "version": "0.0.32",
4
4
  "private": false,
5
5
  "description": "Loom Core Models- common models, interfaces, types, and utils for Loom Core. All things common to both api and client apps.",
6
6
  "scripts": {
@@ -1,27 +0,0 @@
1
- import { IAuditable, IEntity } from "./index.js";
2
- export interface IAuthorizationIn extends IEntity, IAuditable {
3
- roleId: string;
4
- featureId: string;
5
- startDate?: Date;
6
- endDate?: Date;
7
- config?: any;
8
- }
9
- export declare const AuthorizationSchema: import("@sinclair/typebox").TObject<{
10
- roleId: import("@sinclair/typebox").TString;
11
- featureId: import("@sinclair/typebox").TString;
12
- startDate: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
13
- endDate: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TTransform<import("@sinclair/typebox").TString, Date>>;
14
- config: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TAny>;
15
- }>;
16
- export declare const AuthorizationModelSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
17
- export interface IAuthorizationOut extends IEntity {
18
- role: string;
19
- feature: string;
20
- config?: any;
21
- }
22
- export declare const PublicAuthorizationSchema: import("@sinclair/typebox").TObject<{
23
- role: import("@sinclair/typebox").TString;
24
- feature: import("@sinclair/typebox").TString;
25
- config: import("@sinclair/typebox").TOptional<import("@sinclair/typebox").TAny>;
26
- }>;
27
- export declare const PublicAuthorizationModelSpec: import("./model-spec.interface.js").IModelSpec<import("@sinclair/typebox").TSchema>;
@@ -1,17 +0,0 @@
1
- import { Type } from "@sinclair/typebox";
2
- import { entityUtils } from "../utils/index.js";
3
- import { TypeboxIsoDate } from "../validation/index.js";
4
- export const AuthorizationSchema = Type.Object({
5
- roleId: Type.String({ minLength: 1, title: 'Role ID' }),
6
- featureId: Type.String({ minLength: 1, title: 'Feature ID' }),
7
- startDate: Type.Optional(TypeboxIsoDate({ title: 'Start Date' })),
8
- endDate: Type.Optional(TypeboxIsoDate({ title: 'End Date' })),
9
- config: Type.Optional(Type.Any({ title: 'Config' }))
10
- });
11
- export const AuthorizationModelSpec = entityUtils.getModelSpec(AuthorizationSchema, { isAuditable: true });
12
- export const PublicAuthorizationSchema = Type.Object({
13
- role: Type.String({ minLength: 1, title: 'Role Name' }),
14
- feature: Type.String({ minLength: 1, title: 'Feature Name' }),
15
- config: Type.Optional(Type.Any({ title: 'Config' }))
16
- });
17
- export const PublicAuthorizationModelSpec = entityUtils.getModelSpec(PublicAuthorizationSchema);