pangea-server 3.3.88 → 3.3.90
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/auth/access-token.class.d.ts +1 -3
- package/dist/auth/auth.helpers.d.ts +4 -12
- package/dist/auth/base-auth.class.d.ts +1 -3
- package/dist/database/base-service.class.d.ts +2 -2
- package/dist/database/database.types.d.ts +13 -11
- package/dist/database/db.class.d.ts +8 -24
- package/dist/database/models/base-model.class.d.ts +3 -3
- package/dist/database/models/base-model.class.js +1 -1
- package/package.json +1 -1
|
@@ -8,8 +8,6 @@ export declare class AccessToken {
|
|
|
8
8
|
verifyToken(token: string): Record<string, ModelId>;
|
|
9
9
|
getTokenData(userCtor: UserCtor, user: ModelInstance<User>): {
|
|
10
10
|
accessToken: string;
|
|
11
|
-
user:
|
|
12
|
-
omit: never;
|
|
13
|
-
}>;
|
|
11
|
+
user: ModelInstance<User>;
|
|
14
12
|
};
|
|
15
13
|
}
|
|
@@ -4,22 +4,14 @@ import type { UserCtor, AuthMap } from './auth.types';
|
|
|
4
4
|
type AuthHeader = string | undefined;
|
|
5
5
|
export declare function login<U extends User>(authHeader: AuthHeader, db: Db, accessToken: AccessToken, userCtor: BaseModelCtor<U>, extraWhere?: Where<U>): Promise<{
|
|
6
6
|
accessToken: string;
|
|
7
|
-
user:
|
|
8
|
-
omit: never;
|
|
9
|
-
}>;
|
|
7
|
+
user: ModelInstance<User>;
|
|
10
8
|
}>;
|
|
11
9
|
export declare function validateAccessToken(authHeader: AuthHeader, db: Db, accessToken: AccessToken, userCtor: UserCtor): Promise<{
|
|
12
10
|
accessToken: string;
|
|
13
|
-
user:
|
|
14
|
-
omit: never;
|
|
15
|
-
}>;
|
|
11
|
+
user: ModelInstance<User>;
|
|
16
12
|
}>;
|
|
17
|
-
export declare function getUserFromToken(authHeader: AuthHeader, db: Db, accessToken: AccessToken, userCtor: UserCtor): Promise<
|
|
18
|
-
omit: never;
|
|
19
|
-
}> | null> | null;
|
|
13
|
+
export declare function getUserFromToken(authHeader: AuthHeader, db: Db, accessToken: AccessToken, userCtor: UserCtor): Promise<ModelInstance<User> | null> | null;
|
|
20
14
|
export declare function getUsersFromToken(authHeader: AuthHeader, db: Db, accessToken: AccessToken, authMap: AuthMap): Promise<{
|
|
21
|
-
[k: string]:
|
|
22
|
-
omit: never;
|
|
23
|
-
}> | null;
|
|
15
|
+
[k: string]: ModelInstance<User> | null;
|
|
24
16
|
}>;
|
|
25
17
|
export {};
|
|
@@ -7,7 +7,5 @@ export declare abstract class BaseAuth<AM extends AuthMap> {
|
|
|
7
7
|
notAllowed(): never;
|
|
8
8
|
isUserAuth<T extends UserType<AM>>(type: T): boolean;
|
|
9
9
|
getUserAuth<T extends UserType<AM>>(type: T): NonNullable<AuthUsers<AM>[T]>;
|
|
10
|
-
getUsersAuth<const T extends readonly UserType<AM>[]>(types: T): { [I in keyof T]:
|
|
11
|
-
omit: never;
|
|
12
|
-
}> | null; };
|
|
10
|
+
getUsersAuth<const T extends readonly UserType<AM>[]>(types: T): { [I in keyof T]: ModelInstance<InstanceType<AM[T[I]]>> | null; };
|
|
13
11
|
}
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { Db } from './db.class';
|
|
2
2
|
import { BaseModel } from './models';
|
|
3
3
|
type SetArrayConfig<T extends BaseModel, M extends BaseModel> = {
|
|
4
|
-
instances: T[];
|
|
5
|
-
getManyFn: (ids:
|
|
4
|
+
instances: ModelInstance<T>[];
|
|
5
|
+
getManyFn: (ids: ModelId[]) => Promise<M[]>;
|
|
6
6
|
keyName: string;
|
|
7
7
|
relationName: string;
|
|
8
8
|
};
|
|
@@ -1,24 +1,22 @@
|
|
|
1
1
|
import * as seq from 'sequelize-typescript';
|
|
2
2
|
import { BaseModel } from './models';
|
|
3
3
|
import { Db as _Db } from './db.class';
|
|
4
|
-
import type { OptionalFields, OptionalIfNullish } from 'pangea-helpers';
|
|
5
4
|
import type { InferAttributes, InferCreationAttributes, CreationOptional, AbstractDataTypeConstructor, AbstractDataType, Transaction, WhereOptions } from 'sequelize';
|
|
6
5
|
import type { ModelCtor } from 'sequelize-typescript';
|
|
7
6
|
declare global {
|
|
8
7
|
type ModelId = number;
|
|
9
8
|
type ModelName = string;
|
|
10
9
|
type BaseModelCtor<BM extends BaseModel = BaseModel> = typeof BaseModel & ModelCtor<BM>;
|
|
11
|
-
type
|
|
10
|
+
type ColDefault<T> = CreationOptional<T>;
|
|
12
11
|
type ColHidden<T> = T & {
|
|
13
12
|
__brand: 'hidden';
|
|
14
13
|
};
|
|
15
|
-
type ColRelation<T> = T & {
|
|
16
|
-
__brand: 'relation';
|
|
17
|
-
};
|
|
18
14
|
type ColVirtual<T> = CreationOptional<T>;
|
|
19
|
-
type ModelInstance<BM extends BaseModel> = InferAttributes<BM
|
|
15
|
+
type ModelInstance<BM extends BaseModel> = InferAttributes<BM> & {
|
|
16
|
+
id: ModelId;
|
|
17
|
+
};
|
|
20
18
|
type Where<BM extends BaseModel> = WhereOptions<BM> & Record<symbol, any>;
|
|
21
|
-
type InsertParams<BM extends BaseModel> = OptionalIfNullish<
|
|
19
|
+
type InsertParams<BM extends BaseModel> = OptionalIfNullish<IncludeHidden<StripRelations<InferCreationAttributes<BM>>>>;
|
|
22
20
|
type UpdateParams<BM extends BaseModel> = Partial<InsertParams<BM>>;
|
|
23
21
|
type UpdateParamsWithId<BM extends BaseModel> = UpdateParams<BM> & {
|
|
24
22
|
id: ModelId;
|
|
@@ -54,15 +52,19 @@ export type ColVirtualOptions = {
|
|
|
54
52
|
set?: ColVirtualSet;
|
|
55
53
|
};
|
|
56
54
|
export type GetModelFn = () => BaseModelCtor;
|
|
57
|
-
type
|
|
58
|
-
[K in keyof T as
|
|
55
|
+
export type OptionalIfNullish<T> = {
|
|
56
|
+
[K in keyof T as null extends T[K] ? never : undefined extends T[K] ? never : K]: T[K];
|
|
59
57
|
} & {
|
|
60
|
-
[K in keyof T as
|
|
58
|
+
[K in keyof T as null extends T[K] ? K : undefined extends T[K] ? K : never]?: Exclude<T[K], undefined>;
|
|
61
59
|
};
|
|
62
60
|
type IncludeHidden<T> = {
|
|
63
61
|
[K in keyof T]-?: Exclude<T[K], undefined> extends ColHidden<infer U> ? U : T[K];
|
|
64
62
|
};
|
|
65
63
|
type StripRelations<T> = {
|
|
66
|
-
[K in keyof T as T[K] extends
|
|
64
|
+
[K in keyof T as NonNullable<T[K]> extends {
|
|
65
|
+
id: ModelId;
|
|
66
|
+
} | Array<{
|
|
67
|
+
id: ModelId;
|
|
68
|
+
}> ? never : K]: T[K];
|
|
67
69
|
};
|
|
68
70
|
export {};
|
|
@@ -36,47 +36,31 @@ type AggregateManyOptions<BM extends BaseModel> = Omit<FindManyOptions<BM>, 'ord
|
|
|
36
36
|
export declare class Db {
|
|
37
37
|
private __tx?;
|
|
38
38
|
constructor(tx: Tx);
|
|
39
|
-
findOneOrNull<BM extends BaseModel>(model: BaseModelCtor<BM>, filters: Filters<BM>, options?: FindOneOptions): Promise<
|
|
40
|
-
|
|
41
|
-
}> | null>;
|
|
42
|
-
findOne<BM extends BaseModel>(model: BaseModelCtor<BM>, filters: Filters<BM>, options?: FindOneOptions): Promise<import("sequelize").InferAttributes<BM, {
|
|
43
|
-
omit: never;
|
|
44
|
-
}>>;
|
|
39
|
+
findOneOrNull<BM extends BaseModel>(model: BaseModelCtor<BM>, filters: Filters<BM>, options?: FindOneOptions): Promise<ModelInstance<BM> | null>;
|
|
40
|
+
findOne<BM extends BaseModel>(model: BaseModelCtor<BM>, filters: Filters<BM>, options?: FindOneOptions): Promise<ModelInstance<BM>>;
|
|
45
41
|
aggregateOne<BM extends BaseModel>(model: BaseModelCtor<BM>, attributes: Attributes, options?: AggregateOneOptions<BM>): Promise<unknown>;
|
|
46
42
|
private __getFindOneBaseOptions;
|
|
47
|
-
findMany<BM extends BaseModel>(model: BaseModelCtor<BM>, options?: FindManyPagedOptions<BM>): Promise<
|
|
48
|
-
omit: never;
|
|
49
|
-
}>[]>;
|
|
43
|
+
findMany<BM extends BaseModel>(model: BaseModelCtor<BM>, options?: FindManyPagedOptions<BM>): Promise<ModelInstance<BM>[]>;
|
|
50
44
|
count<BM extends BaseModel>(model: BaseModelCtor<BM>, options?: FindManyOptions<BM>): Promise<number>;
|
|
51
45
|
findManyWithCount<BM extends BaseModel>(model: BaseModelCtor<BM>, options?: FindManyPagedOptions<BM>): Promise<{
|
|
52
|
-
instances:
|
|
53
|
-
omit: never;
|
|
54
|
-
}>[];
|
|
46
|
+
instances: ModelInstance<BM>[];
|
|
55
47
|
totalCount: number;
|
|
56
48
|
}>;
|
|
57
49
|
aggregateMany<BM extends BaseModel>(model: BaseModelCtor<BM>, config: AggregateManyConfig, options?: AggregateManyOptions<BM>): Promise<unknown[]>;
|
|
58
50
|
private __getFindManyBaseOptions;
|
|
59
|
-
insertOne<BM extends BaseModel>(model: BaseModelCtor<BM>, params: InsertParams<BM>): Promise<
|
|
60
|
-
omit: never;
|
|
61
|
-
}>>;
|
|
51
|
+
insertOne<BM extends BaseModel>(model: BaseModelCtor<BM>, params: InsertParams<BM>): Promise<ModelInstance<BM>>;
|
|
62
52
|
insertMany<BM extends BaseModel>(model: BaseModelCtor<BM>, data: InsertParams<BM>[]): Promise<number>;
|
|
63
53
|
upsertMany<BM extends BaseModel>(model: BaseModelCtor<BM>, fieldsToUpdate: (keyof BM)[], data: InsertParams<BM>[]): Promise<number>;
|
|
64
54
|
updateOne<BM extends BaseModel>(model: BaseModelCtor<BM>, params: UpdateParamsWithId<BM>): Promise<ModelInstance<BM>>;
|
|
65
55
|
updateOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId, params: UpdateParams<BM>): Promise<ModelInstance<BM>>;
|
|
66
56
|
updateMany<BM extends BaseModel>(model: BaseModelCtor<BM>, where: Where<BM>, params: UpdateParams<BM>): Promise<number>;
|
|
67
|
-
deleteOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId): Promise<
|
|
68
|
-
omit: never;
|
|
69
|
-
}> | null>;
|
|
57
|
+
deleteOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId): Promise<ModelInstance<BM> | null>;
|
|
70
58
|
deleteMany<BM extends BaseModel>(model: BaseModelCtor<BM>, where: Where<BM>): Promise<number>;
|
|
71
|
-
destroyOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId): Promise<
|
|
72
|
-
omit: never;
|
|
73
|
-
}> | null>;
|
|
59
|
+
destroyOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId): Promise<ModelInstance<BM> | null>;
|
|
74
60
|
destroyMany<BM extends BaseModel>(model: BaseModelCtor<BM>, where: Where<BM>): Promise<number>;
|
|
75
61
|
private __deleteOne;
|
|
76
62
|
private __deleteMany;
|
|
77
|
-
restoreOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId): Promise<
|
|
78
|
-
omit: never;
|
|
79
|
-
}>>;
|
|
63
|
+
restoreOne<BM extends BaseModel>(model: BaseModelCtor<BM>, id: ModelId): Promise<ModelInstance<BM>>;
|
|
80
64
|
restoreMany<BM extends BaseModel>(model: BaseModelCtor<BM>, where: Where<BM>): Promise<void>;
|
|
81
65
|
query(sql: string | {
|
|
82
66
|
query: string;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Model, Column } from 'sequelize-typescript';
|
|
2
|
-
import type { NonAttribute } from 'sequelize';
|
|
2
|
+
import type { NonAttribute, CreationOptional } from 'sequelize';
|
|
3
3
|
import type { Index, DefaultValue, GetModelFn } from '../database.types';
|
|
4
4
|
type Column = {
|
|
5
5
|
allowNull: boolean;
|
|
@@ -15,12 +15,12 @@ type Relation = {
|
|
|
15
15
|
};
|
|
16
16
|
type Relations = Record<string, Relation>;
|
|
17
17
|
export declare abstract class BaseModel extends Model {
|
|
18
|
-
version: NonAttribute<number>;
|
|
19
18
|
private static __HiddenAttributes?;
|
|
20
19
|
private static __Columns?;
|
|
21
20
|
private static __ColumnIndexes?;
|
|
22
21
|
private static __Relations?;
|
|
23
|
-
id: ModelId
|
|
22
|
+
id: CreationOptional<ModelId>;
|
|
23
|
+
version: NonAttribute<number>;
|
|
24
24
|
static get HiddenAttributes(): string[];
|
|
25
25
|
static get Columns(): Columns;
|
|
26
26
|
static get ColumnIndexes(): Index[];
|