From 54c2b1d1e3c4f6aa38b4e3e3060f2aca2e58c869 Mon Sep 17 00:00:00 2001 From: Gao Sun Date: Sat, 16 Mar 2024 14:44:32 +0800 Subject: [PATCH] refactor: fix errors --- packages/cli/package.json | 2 +- packages/core/package.json | 2 +- .../core/src/database/find-all-entities.ts | 3 +- .../core/src/database/find-entity-by-id.ts | 2 +- .../core/src/database/insert-into.test.ts | 2 +- packages/core/src/database/insert-into.ts | 14 ++--- packages/core/src/database/update-where.ts | 2 +- packages/core/src/database/utils.ts | 4 +- packages/core/src/errors/SlonikError/index.ts | 4 +- packages/core/src/libraries/logto-config.ts | 2 +- packages/core/src/libraries/user.ts | 2 +- .../core/src/middleware/koa-auth/utils.ts | 2 +- .../queries/application-sign-in-experience.ts | 2 +- .../application-user-consent-organizations.ts | 2 +- .../application-user-consent-scopes.ts | 2 +- packages/core/src/queries/application.test.ts | 6 +- packages/core/src/queries/application.ts | 4 +- .../core/src/queries/applications-roles.ts | 2 +- packages/core/src/queries/connector.test.ts | 2 +- packages/core/src/queries/connector.ts | 2 +- packages/core/src/queries/custom-phrase.ts | 3 +- .../core/src/queries/daily-active-user.ts | 2 +- .../core/src/queries/daily-token-usage.ts | 3 +- packages/core/src/queries/domains.ts | 3 +- packages/core/src/queries/hooks.ts | 2 +- packages/core/src/queries/log.ts | 2 +- .../core/src/queries/logto-config.test.ts | 2 +- packages/core/src/queries/logto-config.ts | 2 +- .../src/queries/oidc-model-instance.test.ts | 2 +- .../core/src/queries/oidc-model-instance.ts | 2 +- .../core/src/queries/organization/index.ts | 2 +- .../src/queries/organization/relations.ts | 2 +- packages/core/src/queries/passcode.test.ts | 6 +- packages/core/src/queries/passcode.ts | 2 +- packages/core/src/queries/resource.test.ts | 2 +- packages/core/src/queries/resource.ts | 4 +- packages/core/src/queries/roles-scopes.ts | 2 +- packages/core/src/queries/roles.test.ts | 6 +- packages/core/src/queries/roles.ts | 4 +- packages/core/src/queries/scope.ts | 4 +- packages/core/src/queries/sso-connectors.ts | 2 +- packages/core/src/queries/system.ts | 3 +- packages/core/src/queries/tenant.ts | 3 +- .../core/src/queries/user-sso-identities.ts | 2 +- packages/core/src/queries/user.test.ts | 2 +- packages/core/src/queries/user.ts | 4 +- packages/core/src/queries/users-roles.ts | 2 +- .../core/src/queries/verification-status.ts | 2 +- .../src/routes/interaction/actions/helpers.ts | 2 +- packages/core/src/sentinel/basic-sentinel.ts | 3 +- packages/core/src/utils/RelationQueries.ts | 4 +- packages/core/src/utils/SchemaQueries.ts | 4 +- packages/core/src/utils/sql.ts | 15 ++++- packages/schemas/package.json | 2 +- pnpm-lock.yaml | 57 +++++++++++++------ 55 files changed, 143 insertions(+), 84 deletions(-) diff --git a/packages/cli/package.json b/packages/cli/package.json index 342c5fb11..0e41a759c 100644 --- a/packages/cli/package.json +++ b/packages/cli/package.json @@ -65,7 +65,7 @@ "pg-protocol": "^1.6.0", "roarr": "^7.11.0", "semver": "^7.3.8", - "slonik": "^30.0.0", + "slonik": "30.4.0", "slonik-interceptor-preset": "^1.2.10", "slonik-sql-tag-raw": "^1.1.4", "tar": "^6.1.11", diff --git a/packages/core/package.json b/packages/core/package.json index b71c1fe54..7dd1731bd 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -85,7 +85,7 @@ "roarr": "^7.11.0", "samlify": "2.8.10", "semver": "^7.3.8", - "slonik": "^30.0.0", + "slonik": "30.4.0", "slonik-interceptor-preset": "^1.2.10", "slonik-sql-tag-raw": "^1.1.4", "snake-case": "^3.0.4", diff --git a/packages/core/src/database/find-all-entities.ts b/packages/core/src/database/find-all-entities.ts index 6da12f92b..157735e60 100644 --- a/packages/core/src/database/find-all-entities.ts +++ b/packages/core/src/database/find-all-entities.ts @@ -1,7 +1,8 @@ import { type GeneratedSchema, type SchemaLike } from '@logto/schemas'; -import { conditionalSql, convertToIdentifiers, manyRows } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; +import { conditionalSql, convertToIdentifiers, manyRows } from '#src/utils/sql.js'; + import { buildSearchSql, expandFields, type SearchOptions } from './utils.js'; export const buildFindAllEntitiesWithPool = diff --git a/packages/core/src/database/find-entity-by-id.ts b/packages/core/src/database/find-entity-by-id.ts index 95076d9fa..ed37f0e11 100644 --- a/packages/core/src/database/find-entity-by-id.ts +++ b/packages/core/src/database/find-entity-by-id.ts @@ -1,11 +1,11 @@ import type { SchemaLike, GeneratedSchema } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql, NotFoundError } from 'slonik'; import RequestError from '#src/errors/RequestError/index.js'; import assertThat from '#src/utils/assert-that.js'; import { isKeyOf } from '#src/utils/schema.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; type WithId = Key | 'id'; diff --git a/packages/core/src/database/insert-into.test.ts b/packages/core/src/database/insert-into.test.ts index 79e270c6a..76cec8045 100644 --- a/packages/core/src/database/insert-into.test.ts +++ b/packages/core/src/database/insert-into.test.ts @@ -1,9 +1,9 @@ import type { CreateUser } from '@logto/schemas'; import { Users } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import decamelize from 'decamelize'; import { InsertionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; import { createTestPool } from '#src/utils/test-utils.js'; const { buildInsertIntoWithPool } = await import('./insert-into.js'); diff --git a/packages/core/src/database/insert-into.ts b/packages/core/src/database/insert-into.ts index eb76499d7..87ba7e6f8 100644 --- a/packages/core/src/database/insert-into.ts +++ b/packages/core/src/database/insert-into.ts @@ -1,17 +1,17 @@ import type { GeneratedSchema, SchemaLike } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { - convertToIdentifiers, - excludeAutoSetFields, - convertToPrimitiveOrSql, - conditionalSql, -} from '@logto/shared'; import { has } from '@silverhand/essentials'; import type { CommonQueryMethods, IdentifierSqlToken } from 'slonik'; import { sql } from 'slonik'; import { InsertionError } from '#src/errors/SlonikError/index.js'; import assertThat from '#src/utils/assert-that.js'; +import { + type OmitAutoSetFields, + convertToIdentifiers, + excludeAutoSetFields, + convertToPrimitiveOrSql, + conditionalSql, +} from '#src/utils/sql.js'; const setExcluded = (...fields: IdentifierSqlToken[]) => sql.join( diff --git a/packages/core/src/database/update-where.ts b/packages/core/src/database/update-where.ts index 32e559871..a4173d53f 100644 --- a/packages/core/src/database/update-where.ts +++ b/packages/core/src/database/update-where.ts @@ -1,5 +1,4 @@ import type { SchemaLike, GeneratedSchema, SchemaValue } from '@logto/schemas'; -import { convertToIdentifiers, convertToPrimitiveOrSql, conditionalSql } from '@logto/shared'; import type { UpdateWhereData } from '@logto/shared'; import type { Truthy } from '@silverhand/essentials'; import { notFalsy } from '@silverhand/essentials'; @@ -9,6 +8,7 @@ import { sql } from 'slonik'; import { UpdateError } from '#src/errors/SlonikError/index.js'; import assertThat from '#src/utils/assert-that.js'; import { isKeyOf } from '#src/utils/schema.js'; +import { convertToIdentifiers, convertToPrimitiveOrSql, conditionalSql } from '#src/utils/sql.js'; type BuildUpdateWhere = { < diff --git a/packages/core/src/database/utils.ts b/packages/core/src/database/utils.ts index 300d430f6..64432e8c2 100644 --- a/packages/core/src/database/utils.ts +++ b/packages/core/src/database/utils.ts @@ -1,7 +1,9 @@ import { type GeneratedSchema } from '@logto/schemas'; -import { type SchemaLike, conditionalSql, convertToIdentifiers, type Table } from '@logto/shared'; +import { type SchemaLike, type Table } from '@logto/shared'; import { type SqlSqlToken, sql } from 'slonik'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; + /** * Options for searching for a string within a set of fields (case-insensitive). */ diff --git a/packages/core/src/errors/SlonikError/index.ts b/packages/core/src/errors/SlonikError/index.ts index 1f8028464..a816c8d63 100644 --- a/packages/core/src/errors/SlonikError/index.ts +++ b/packages/core/src/errors/SlonikError/index.ts @@ -1,7 +1,9 @@ import type { SchemaLike, GeneratedSchema } from '@logto/schemas'; -import type { OmitAutoSetFields, UpdateWhereData } from '@logto/shared'; +import type { UpdateWhereData } from '@logto/shared'; import { SlonikError } from 'slonik'; +import { type OmitAutoSetFields } from '#src/utils/sql.js'; + export class DeletionError extends SlonikError { public constructor( public readonly table?: string, diff --git a/packages/core/src/libraries/logto-config.ts b/packages/core/src/libraries/logto-config.ts index 11093467a..b633f3418 100644 --- a/packages/core/src/libraries/logto-config.ts +++ b/packages/core/src/libraries/logto-config.ts @@ -7,13 +7,13 @@ import { jwtCustomizerConfigGuard, } from '@logto/schemas'; import type { LogtoOidcConfigType, LogtoJwtTokenKey } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import chalk from 'chalk'; import { z, ZodError } from 'zod'; import RequestError from '#src/errors/RequestError/index.js'; import type Queries from '#src/tenants/Queries.js'; import { consoleLog } from '#src/utils/console.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; export type LogtoConfigLibrary = ReturnType; const { table } = convertToIdentifiers(LogtoConfigs); diff --git a/packages/core/src/libraries/user.ts b/packages/core/src/libraries/user.ts index 4c009aee0..027999ff5 100644 --- a/packages/core/src/libraries/user.ts +++ b/packages/core/src/libraries/user.ts @@ -1,7 +1,6 @@ import type { User, CreateUser, Scope, BindMfa, MfaVerification } from '@logto/schemas'; import { MfaFactor, Users, UsersPasswordEncryptionMethod } from '@logto/schemas'; import { generateStandardShortId, generateStandardId } from '@logto/shared'; -import type { OmitAutoSetFields } from '@logto/shared'; import type { Nullable } from '@silverhand/essentials'; import { deduplicate } from '@silverhand/essentials'; import { argon2Verify, bcryptVerify, md5, sha1, sha256 } from 'hash-wasm'; @@ -14,6 +13,7 @@ import { createUsersRolesQueries } from '#src/queries/users-roles.js'; import type Queries from '#src/tenants/Queries.js'; import assertThat from '#src/utils/assert-that.js'; import { encryptPassword } from '#src/utils/password.js'; +import type { OmitAutoSetFields } from '#src/utils/sql.js'; export const encryptUserPassword = async ( password: string diff --git a/packages/core/src/middleware/koa-auth/utils.ts b/packages/core/src/middleware/koa-auth/utils.ts index c959bf680..19f08310f 100644 --- a/packages/core/src/middleware/koa-auth/utils.ts +++ b/packages/core/src/middleware/koa-auth/utils.ts @@ -7,13 +7,13 @@ import { LogtoOidcConfigKey, LogtoConfigs, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { appendPath } from '@silverhand/essentials'; import type { JWK } from 'jose'; import { sql } from 'slonik'; import { EnvSet, getTenantEndpoint } from '#src/env-set/index.js'; import { exportJWK } from '#src/utils/jwks.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(LogtoConfigs); diff --git a/packages/core/src/queries/application-sign-in-experience.ts b/packages/core/src/queries/application-sign-in-experience.ts index 963cf2b67..b29cd0af8 100644 --- a/packages/core/src/queries/application-sign-in-experience.ts +++ b/packages/core/src/queries/application-sign-in-experience.ts @@ -1,9 +1,9 @@ import { ApplicationSignInExperiences, type ApplicationSignInExperience } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const createApplicationSignInExperienceQueries = (pool: CommonQueryMethods) => { const insert = buildInsertIntoWithPool(pool)(ApplicationSignInExperiences, { diff --git a/packages/core/src/queries/application-user-consent-organizations.ts b/packages/core/src/queries/application-user-consent-organizations.ts index f2cab0f11..d69d6ab07 100644 --- a/packages/core/src/queries/application-user-consent-organizations.ts +++ b/packages/core/src/queries/application-user-consent-organizations.ts @@ -4,10 +4,10 @@ import { Organizations, Users, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import RelationQueries from '#src/utils/RelationQueries.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; class ApplicationUserConsentOrganizationsQuery extends RelationQueries< [typeof Applications, typeof Users, typeof Organizations] diff --git a/packages/core/src/queries/application-user-consent-scopes.ts b/packages/core/src/queries/application-user-consent-scopes.ts index f3fe2ce09..97291b1c7 100644 --- a/packages/core/src/queries/application-user-consent-scopes.ts +++ b/packages/core/src/queries/application-user-consent-scopes.ts @@ -7,12 +7,12 @@ import { OrganizationScopes, Scopes, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import { TwoRelationsQueries } from '#src/utils/RelationQueries.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; export class ApplicationUserConsentOrganizationScopeQueries extends TwoRelationsQueries< typeof Applications, diff --git a/packages/core/src/queries/application.test.ts b/packages/core/src/queries/application.test.ts index 655d9ed3c..3c9a6ff68 100644 --- a/packages/core/src/queries/application.test.ts +++ b/packages/core/src/queries/application.test.ts @@ -1,10 +1,14 @@ import { Applications } from '@logto/schemas'; -import { convertToIdentifiers, convertToPrimitiveOrSql, excludeAutoSetFields } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; import { snakeCase } from 'snake-case'; import { mockApplication } from '#src/__mocks__/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { + convertToIdentifiers, + convertToPrimitiveOrSql, + excludeAutoSetFields, +} from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/application.ts b/packages/core/src/queries/application.ts index 37280a222..eaf7b406d 100644 --- a/packages/core/src/queries/application.ts +++ b/packages/core/src/queries/application.ts @@ -1,7 +1,5 @@ import type { Application, CreateApplication } from '@logto/schemas'; import { ApplicationType, Applications, SearchJointMode } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { convertToIdentifiers, conditionalSql, conditionalArraySql } from '@logto/shared'; import type { CommonQueryMethods, SqlSqlToken } from 'slonik'; import { sql } from 'slonik'; @@ -12,6 +10,8 @@ import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import { buildConditionsFromSearch } from '#src/utils/search.js'; import type { Search } from '#src/utils/search.js'; +import { convertToIdentifiers, conditionalSql, conditionalArraySql } from '#src/utils/sql.js'; +import type { OmitAutoSetFields } from '#src/utils/sql.js'; import ApplicationUserConsentOrganizationsQuery from './application-user-consent-organizations.js'; import { diff --git a/packages/core/src/queries/applications-roles.ts b/packages/core/src/queries/applications-roles.ts index e0497b42c..8c70eb49f 100644 --- a/packages/core/src/queries/applications-roles.ts +++ b/packages/core/src/queries/applications-roles.ts @@ -1,11 +1,11 @@ import type { ApplicationsRole, CreateApplicationsRole, Role } from '@logto/schemas'; import { Roles, ApplicationsRoles, RolesScopes } from '@logto/schemas'; -import { convertToIdentifiers, conditionalSql } from '@logto/shared'; import { type Nullable } from '@silverhand/essentials'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers, conditionalSql } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(ApplicationsRoles, true); const { fields: insertFields } = convertToIdentifiers(ApplicationsRoles); diff --git a/packages/core/src/queries/connector.test.ts b/packages/core/src/queries/connector.test.ts index 10c1ff79a..c2e00f003 100644 --- a/packages/core/src/queries/connector.test.ts +++ b/packages/core/src/queries/connector.test.ts @@ -1,10 +1,10 @@ import { Connectors } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; import { mockConnector } from '#src/__mocks__/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import { MockWellKnownCache } from '#src/test-utils/tenant.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/connector.ts b/packages/core/src/queries/connector.ts index 5f25eb0d6..c5e5b3bad 100644 --- a/packages/core/src/queries/connector.ts +++ b/packages/core/src/queries/connector.ts @@ -1,6 +1,5 @@ import type { Connector } from '@logto/schemas'; import { Connectors } from '@logto/schemas'; -import { manyRows, convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -9,6 +8,7 @@ import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import { type ConnectorWellKnown } from '#src/utils/connectors/types.js'; +import { convertToIdentifiers, manyRows } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Connectors); diff --git a/packages/core/src/queries/custom-phrase.ts b/packages/core/src/queries/custom-phrase.ts index bb77d7b78..49f59e6fc 100644 --- a/packages/core/src/queries/custom-phrase.ts +++ b/packages/core/src/queries/custom-phrase.ts @@ -1,12 +1,13 @@ import type { CustomPhrase, Translation } from '@logto/schemas'; import { CustomPhrases } from '@logto/schemas'; -import { convertToIdentifiers, generateStandardId, manyRows } from '@logto/shared'; +import { generateStandardId } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { type WellKnownCache } from '#src/caches/well-known.js'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers, manyRows } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(CustomPhrases); diff --git a/packages/core/src/queries/daily-active-user.ts b/packages/core/src/queries/daily-active-user.ts index 00ebdcc19..e3b815ab2 100644 --- a/packages/core/src/queries/daily-active-user.ts +++ b/packages/core/src/queries/daily-active-user.ts @@ -1,8 +1,8 @@ import { DailyActiveUsers } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(DailyActiveUsers); diff --git a/packages/core/src/queries/daily-token-usage.ts b/packages/core/src/queries/daily-token-usage.ts index 92f82b9c2..f929a0647 100644 --- a/packages/core/src/queries/daily-token-usage.ts +++ b/packages/core/src/queries/daily-token-usage.ts @@ -1,9 +1,10 @@ import { DailyTokenUsage } from '@logto/schemas'; -import { convertToIdentifiers, generateStandardId } from '@logto/shared'; +import { generateStandardId } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { getUtcStartOfTheDay } from '#src/oidc/utils.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(DailyTokenUsage); const { fields: fieldsWithPrefix } = convertToIdentifiers(DailyTokenUsage, true); diff --git a/packages/core/src/queries/domains.ts b/packages/core/src/queries/domains.ts index 68875f989..5d29b0694 100644 --- a/packages/core/src/queries/domains.ts +++ b/packages/core/src/queries/domains.ts @@ -1,6 +1,4 @@ import { type CreateDomain, type Domain, DomainStatus, Domains } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { convertToIdentifiers, manyRows } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -8,6 +6,7 @@ import { buildFindEntityByIdWithPool } from '#src/database/find-entity-by-id.js' import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers, manyRows, type OmitAutoSetFields } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Domains); diff --git a/packages/core/src/queries/hooks.ts b/packages/core/src/queries/hooks.ts index 2705fec1a..1362a78ba 100644 --- a/packages/core/src/queries/hooks.ts +++ b/packages/core/src/queries/hooks.ts @@ -1,6 +1,5 @@ import type { CreateHook } from '@logto/schemas'; import { Hooks } from '@logto/schemas'; -import { type OmitAutoSetFields, convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -10,6 +9,7 @@ import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { getTotalRowCountWithPool } from '#src/database/row-count.js'; import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers, type OmitAutoSetFields } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Hooks); diff --git a/packages/core/src/queries/log.ts b/packages/core/src/queries/log.ts index d8e632bee..263ee1160 100644 --- a/packages/core/src/queries/log.ts +++ b/packages/core/src/queries/log.ts @@ -7,7 +7,6 @@ import { type interaction, type LogKeyUnknown, } from '@logto/schemas'; -import { conditionalSql, convertToIdentifiers } from '@logto/shared'; import { conditional, conditionalArray } from '@silverhand/essentials'; import { subDays } from 'date-fns'; import { sql } from 'slonik'; @@ -15,6 +14,7 @@ import type { CommonQueryMethods } from 'slonik'; import { buildFindEntityByIdWithPool } from '#src/database/find-entity-by-id.js'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Logs); diff --git a/packages/core/src/queries/logto-config.test.ts b/packages/core/src/queries/logto-config.test.ts index 06d188dc8..10fef41b5 100644 --- a/packages/core/src/queries/logto-config.test.ts +++ b/packages/core/src/queries/logto-config.test.ts @@ -4,9 +4,9 @@ import { LogtoOidcConfigKey, LogtoTenantConfigKey, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; +import { convertToIdentifiers } from '#src/utils/sql.js'; import { expectSqlAssert, type QueryType } from '#src/utils/test-utils.js'; const { jest } = import.meta; diff --git a/packages/core/src/queries/logto-config.ts b/packages/core/src/queries/logto-config.ts index da6aaea3f..861afa726 100644 --- a/packages/core/src/queries/logto-config.ts +++ b/packages/core/src/queries/logto-config.ts @@ -9,12 +9,12 @@ import { type OidcConfigKey, type LogtoJwtTokenKey, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { type z } from 'zod'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(LogtoConfigs); diff --git a/packages/core/src/queries/oidc-model-instance.test.ts b/packages/core/src/queries/oidc-model-instance.test.ts index e6f9065e5..5a8141d9b 100644 --- a/packages/core/src/queries/oidc-model-instance.test.ts +++ b/packages/core/src/queries/oidc-model-instance.test.ts @@ -1,8 +1,8 @@ import type { CreateOidcModelInstance } from '@logto/schemas'; import { OidcModelInstances } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; +import { convertToIdentifiers } from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/oidc-model-instance.ts b/packages/core/src/queries/oidc-model-instance.ts index a81b352df..7e92592c3 100644 --- a/packages/core/src/queries/oidc-model-instance.ts +++ b/packages/core/src/queries/oidc-model-instance.ts @@ -1,6 +1,5 @@ import type { OidcModelInstance, OidcModelInstancePayload } from '@logto/schemas'; import { OidcModelInstances } from '@logto/schemas'; -import { convertToIdentifiers, convertToTimestamp } from '@logto/shared'; import type { Nullable } from '@silverhand/essentials'; import { conditional } from '@silverhand/essentials'; import { addSeconds, isBefore } from 'date-fns'; @@ -8,6 +7,7 @@ import type { CommonQueryMethods, ValueExpression } from 'slonik'; import { sql } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; +import { convertToIdentifiers, convertToTimestamp } from '#src/utils/sql.js'; export type WithConsumed = T & { consumed?: boolean }; export type QueryResult = Pick; diff --git a/packages/core/src/queries/organization/index.ts b/packages/core/src/queries/organization/index.ts index 82aa3b882..bdb648d24 100644 --- a/packages/core/src/queries/organization/index.ts +++ b/packages/core/src/queries/organization/index.ts @@ -18,12 +18,12 @@ import { OrganizationInvitationRoleRelations, OrganizationInvitationStatus, } from '@logto/schemas'; -import { conditionalSql, convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import { type SearchOptions, buildSearchSql } from '#src/database/utils.js'; import { TwoRelationsQueries } from '#src/utils/RelationQueries.js'; import SchemaQueries from '#src/utils/SchemaQueries.js'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; import { RoleUserRelationQueries, UserRelationQueries } from './relations.js'; diff --git a/packages/core/src/queries/organization/relations.ts b/packages/core/src/queries/organization/relations.ts index 95e2f9b01..74ab7c503 100644 --- a/packages/core/src/queries/organization/relations.ts +++ b/packages/core/src/queries/organization/relations.ts @@ -11,7 +11,6 @@ import { type FeaturedUser, type OrganizationScopeEntity, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import { type SearchOptions, buildSearchSql, expandFields } from '#src/database/utils.js'; @@ -19,6 +18,7 @@ import RelationQueries, { type GetEntitiesOptions, TwoRelationsQueries, } from '#src/utils/RelationQueries.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; import { type userSearchKeys } from '../user.js'; diff --git a/packages/core/src/queries/passcode.test.ts b/packages/core/src/queries/passcode.test.ts index fb83fc9ab..59e99e13e 100644 --- a/packages/core/src/queries/passcode.test.ts +++ b/packages/core/src/queries/passcode.test.ts @@ -1,11 +1,15 @@ import { TemplateType } from '@logto/connector-kit'; import { Passcodes } from '@logto/schemas'; -import { convertToIdentifiers, convertToPrimitiveOrSql, excludeAutoSetFields } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; import { snakeCase } from 'snake-case'; import { mockPasscode } from '#src/__mocks__/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { + convertToIdentifiers, + convertToPrimitiveOrSql, + excludeAutoSetFields, +} from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/passcode.ts b/packages/core/src/queries/passcode.ts index 557001fb0..c62394cd4 100644 --- a/packages/core/src/queries/passcode.ts +++ b/packages/core/src/queries/passcode.ts @@ -1,12 +1,12 @@ import type { TemplateType } from '@logto/connector-kit'; import type { Passcode, RequestVerificationCodePayload } from '@logto/schemas'; import { Passcodes } from '@logto/schemas'; -import { conditionalSql, convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Passcodes); diff --git a/packages/core/src/queries/resource.test.ts b/packages/core/src/queries/resource.test.ts index d5cf2ba76..b421da9eb 100644 --- a/packages/core/src/queries/resource.test.ts +++ b/packages/core/src/queries/resource.test.ts @@ -1,9 +1,9 @@ import { Resources } from '@logto/schemas'; -import { convertToIdentifiers, convertToPrimitiveOrSql } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; import { mockResource } from '#src/__mocks__/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers, convertToPrimitiveOrSql } from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/resource.ts b/packages/core/src/queries/resource.ts index 96f7b969c..a0d65f93d 100644 --- a/packages/core/src/queries/resource.ts +++ b/packages/core/src/queries/resource.ts @@ -1,7 +1,5 @@ import type { Resource, CreateResource } from '@logto/schemas'; import { Resources } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -11,6 +9,8 @@ import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; import { getTotalRowCountWithPool } from '#src/database/row-count.js'; import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError, UpdateError } from '#src/errors/SlonikError/index.js'; +import type { OmitAutoSetFields } from '#src/utils/sql.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Resources); diff --git a/packages/core/src/queries/roles-scopes.ts b/packages/core/src/queries/roles-scopes.ts index c0e82d5f7..5b929af26 100644 --- a/packages/core/src/queries/roles-scopes.ts +++ b/packages/core/src/queries/roles-scopes.ts @@ -1,10 +1,10 @@ import type { CreateRolesScope, RolesScope } from '@logto/schemas'; import { RolesScopes } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(RolesScopes); diff --git a/packages/core/src/queries/roles.test.ts b/packages/core/src/queries/roles.test.ts index e89e355cb..fdd51241f 100644 --- a/packages/core/src/queries/roles.test.ts +++ b/packages/core/src/queries/roles.test.ts @@ -1,9 +1,13 @@ import { Roles } from '@logto/schemas'; -import { convertToIdentifiers, convertToPrimitiveOrSql, excludeAutoSetFields } from '@logto/shared'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; import { mockAdminUserRole } from '#src/__mocks__/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { + convertToIdentifiers, + convertToPrimitiveOrSql, + excludeAutoSetFields, +} from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/roles.ts b/packages/core/src/queries/roles.ts index 9b767d8fc..6181ab68b 100644 --- a/packages/core/src/queries/roles.ts +++ b/packages/core/src/queries/roles.ts @@ -1,7 +1,5 @@ import type { CreateRole, Role, RoleType } from '@logto/schemas'; import { internalRolePrefix, SearchJointMode, Roles } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { conditionalArraySql, conditionalSql, convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -11,6 +9,8 @@ import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import type { Search } from '#src/utils/search.js'; import { buildConditionsFromSearch } from '#src/utils/search.js'; +import { conditionalArraySql, conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; +import type { OmitAutoSetFields } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Roles); diff --git a/packages/core/src/queries/scope.ts b/packages/core/src/queries/scope.ts index 52617611f..7ddf2c73e 100644 --- a/packages/core/src/queries/scope.ts +++ b/packages/core/src/queries/scope.ts @@ -1,7 +1,5 @@ import type { CreateScope, Scope } from '@logto/schemas'; import { Resources, Scopes } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { conditionalSql, convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -11,6 +9,8 @@ import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import type { Search } from '#src/utils/search.js'; import { buildConditionsFromSearch } from '#src/utils/search.js'; +import type { OmitAutoSetFields } from '#src/utils/sql.js'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Scopes, true); const resources = convertToIdentifiers(Resources, true); diff --git a/packages/core/src/queries/sso-connectors.ts b/packages/core/src/queries/sso-connectors.ts index a5e5d26c5..04b0d0570 100644 --- a/packages/core/src/queries/sso-connectors.ts +++ b/packages/core/src/queries/sso-connectors.ts @@ -4,10 +4,10 @@ import { type SsoConnectorKeys, SsoConnectors, } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; import SchemaQueries from '#src/utils/SchemaQueries.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; export default class SsoConnectorQueries extends SchemaQueries< SsoConnectorKeys, diff --git a/packages/core/src/queries/system.ts b/packages/core/src/queries/system.ts index 1bc855000..eeb57c354 100644 --- a/packages/core/src/queries/system.ts +++ b/packages/core/src/queries/system.ts @@ -1,8 +1,9 @@ import { type SystemKey, Systems } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; +import { convertToIdentifiers } from '#src/utils/sql.js'; + const { table, fields } = convertToIdentifiers(Systems); export const createSystemsQuery = (pool: CommonQueryMethods) => { diff --git a/packages/core/src/queries/tenant.ts b/packages/core/src/queries/tenant.ts index 15d370dfd..a680e8e70 100644 --- a/packages/core/src/queries/tenant.ts +++ b/packages/core/src/queries/tenant.ts @@ -1,7 +1,8 @@ import { Tenants, type TenantModel } from '@logto/schemas/models'; -import { convertToIdentifiers } from '@logto/shared'; import { sql, type CommonQueryMethods } from 'slonik'; +import { convertToIdentifiers } from '#src/utils/sql.js'; + const createTenantQueries = (pool: CommonQueryMethods) => { const { table, fields } = convertToIdentifiers({ table: Tenants.tableName, diff --git a/packages/core/src/queries/user-sso-identities.ts b/packages/core/src/queries/user-sso-identities.ts index b01bd79c7..f0c258ebc 100644 --- a/packages/core/src/queries/user-sso-identities.ts +++ b/packages/core/src/queries/user-sso-identities.ts @@ -4,11 +4,11 @@ import { type UserSsoIdentity, UserSsoIdentities, } from '@logto/schemas'; -import { manyRows } from '@logto/shared'; import { type Nullable } from '@silverhand/essentials'; import { sql, type CommonQueryMethods } from 'slonik'; import SchemaQueries from '#src/utils/SchemaQueries.js'; +import { manyRows } from '#src/utils/sql.js'; export default class UserSsoIdentityQueries extends SchemaQueries< UserSsoIdentityKeys, diff --git a/packages/core/src/queries/user.test.ts b/packages/core/src/queries/user.test.ts index ca1a5e941..7cef91bc1 100644 --- a/packages/core/src/queries/user.test.ts +++ b/packages/core/src/queries/user.test.ts @@ -1,11 +1,11 @@ import { Users } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import Sinon from 'sinon'; import { createMockPool, createMockQueryResult, sql } from 'slonik'; import { mockUser } from '#src/__mocks__/index.js'; import { EnvSet } from '#src/env-set/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; import type { QueryType } from '#src/utils/test-utils.js'; import { expectSqlAssert } from '#src/utils/test-utils.js'; diff --git a/packages/core/src/queries/user.ts b/packages/core/src/queries/user.ts index 620095b36..690a46092 100644 --- a/packages/core/src/queries/user.ts +++ b/packages/core/src/queries/user.ts @@ -1,7 +1,5 @@ import type { User, CreateUser } from '@logto/schemas'; import { Users } from '@logto/schemas'; -import type { OmitAutoSetFields } from '@logto/shared'; -import { conditionalSql, convertToIdentifiers } from '@logto/shared'; import { conditionalArray, pick } from '@silverhand/essentials'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; @@ -11,6 +9,8 @@ import { EnvSet } from '#src/env-set/index.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; import type { Search } from '#src/utils/search.js'; import { buildConditionsFromSearch } from '#src/utils/search.js'; +import type { OmitAutoSetFields } from '#src/utils/sql.js'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(Users); diff --git a/packages/core/src/queries/users-roles.ts b/packages/core/src/queries/users-roles.ts index 98e0c7005..ea73c1809 100644 --- a/packages/core/src/queries/users-roles.ts +++ b/packages/core/src/queries/users-roles.ts @@ -1,10 +1,10 @@ import type { CreateUsersRole, UsersRole } from '@logto/schemas'; import { UsersRoles } from '@logto/schemas'; -import { conditionalSql, convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { conditionalSql, convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(UsersRoles); diff --git a/packages/core/src/queries/verification-status.ts b/packages/core/src/queries/verification-status.ts index 3225eda6d..73f167135 100644 --- a/packages/core/src/queries/verification-status.ts +++ b/packages/core/src/queries/verification-status.ts @@ -1,10 +1,10 @@ import type { VerificationStatus } from '@logto/schemas'; import { VerificationStatuses } from '@logto/schemas'; -import { convertToIdentifiers } from '@logto/shared'; import type { CommonQueryMethods } from 'slonik'; import { sql } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { table, fields } = convertToIdentifiers(VerificationStatuses); diff --git a/packages/core/src/routes/interaction/actions/helpers.ts b/packages/core/src/routes/interaction/actions/helpers.ts index a2aea3043..d64a4a44d 100644 --- a/packages/core/src/routes/interaction/actions/helpers.ts +++ b/packages/core/src/routes/interaction/actions/helpers.ts @@ -1,7 +1,6 @@ import { defaults, parseAffiliateData } from '@logto/affiliate'; import { consoleLog } from '@logto/cli/lib/utils.js'; import { type CreateUser, type User, adminTenantId } from '@logto/schemas'; -import { type OmitAutoSetFields } from '@logto/shared'; import { conditional, trySafe } from '@silverhand/essentials'; import { type IRouterContext } from 'koa-router'; @@ -11,6 +10,7 @@ import { type ConnectorLibrary } from '#src/libraries/connector.js'; import { encryptUserPassword } from '#src/libraries/user.js'; import type Queries from '#src/tenants/Queries.js'; import type TenantContext from '#src/tenants/TenantContext.js'; +import { type OmitAutoSetFields } from '#src/utils/sql.js'; import { type Identifier, diff --git a/packages/core/src/sentinel/basic-sentinel.ts b/packages/core/src/sentinel/basic-sentinel.ts index b91b2383b..405f90255 100644 --- a/packages/core/src/sentinel/basic-sentinel.ts +++ b/packages/core/src/sentinel/basic-sentinel.ts @@ -8,12 +8,13 @@ import { SentinelActionResult, SentinelActivityAction, } from '@logto/schemas'; -import { convertToIdentifiers, generateStandardId } from '@logto/shared'; +import { generateStandardId } from '@logto/shared'; import { type Nullable } from '@silverhand/essentials'; import { addMinutes } from 'date-fns'; import { sql, type CommonQueryMethods } from 'slonik'; import { buildInsertIntoWithPool } from '#src/database/insert-into.js'; +import { convertToIdentifiers } from '#src/utils/sql.js'; const { fields, table } = convertToIdentifiers(SentinelActivities); diff --git a/packages/core/src/utils/RelationQueries.ts b/packages/core/src/utils/RelationQueries.ts index 7273f6c18..c7e9767d7 100644 --- a/packages/core/src/utils/RelationQueries.ts +++ b/packages/core/src/utils/RelationQueries.ts @@ -1,4 +1,4 @@ -import { type Table, conditionalSql } from '@logto/shared'; +import { type Table } from '@logto/shared'; import { type KeysToCamelCase } from '@silverhand/essentials'; import { sql, type CommonQueryMethods } from 'slonik'; import snakecaseKeys from 'snakecase-keys'; @@ -7,6 +7,8 @@ import { type z } from 'zod'; import { expandFields } from '#src/database/utils.js'; import { DeletionError } from '#src/errors/SlonikError/index.js'; +import { conditionalSql } from './sql.js'; + type AtLeast2 = `${T['length']}` extends '0' | '1' ? never : T; type TableInfo< diff --git a/packages/core/src/utils/SchemaQueries.ts b/packages/core/src/utils/SchemaQueries.ts index f9c481778..9be93e07a 100644 --- a/packages/core/src/utils/SchemaQueries.ts +++ b/packages/core/src/utils/SchemaQueries.ts @@ -1,5 +1,5 @@ import { type GeneratedSchema } from '@logto/schemas'; -import { type UpdateWhereData, type OmitAutoSetFields, type SchemaLike } from '@logto/shared'; +import { type UpdateWhereData, type SchemaLike } from '@logto/shared'; import { type CommonQueryMethods } from 'slonik'; import { buildDeleteByIdWithPool } from '#src/database/delete-by-id.js'; @@ -13,6 +13,8 @@ import { buildGetTotalRowCountWithPool } from '#src/database/row-count.js'; import { buildUpdateWhereWithPool } from '#src/database/update-where.js'; import { type SearchOptions } from '#src/database/utils.js'; +import { type OmitAutoSetFields } from './sql.js'; + /** * Query class that contains all the necessary CRUD queries for a schema. It is * designed to be used with a SchemaRouter. You can also extend this class to add diff --git a/packages/core/src/utils/sql.ts b/packages/core/src/utils/sql.ts index 038327f2a..d81101fcd 100644 --- a/packages/core/src/utils/sql.ts +++ b/packages/core/src/utils/sql.ts @@ -1,13 +1,20 @@ import type { SchemaValue, SchemaValuePrimitive, Table } from '@logto/shared'; import type { Falsy } from '@silverhand/essentials'; import { notFalsy } from '@silverhand/essentials'; -import type { SqlSqlToken, SqlToken, IdentifierSqlToken } from 'slonik'; +import type { SqlSqlToken, SqlToken, IdentifierSqlToken, QueryResult } from 'slonik'; import { sql } from 'slonik'; export const conditionalSql = (value: T, buildSql: (value: Exclude) => SqlSqlToken) => notFalsy(value) ? buildSql(value) : sql``; +export const conditionalArraySql = ( + value: T[], + buildSql: (value: Exclude) => SqlSqlToken +) => (value.length > 0 ? buildSql(value) : sql``); + export const autoSetFields = Object.freeze(['tenantId', 'createdAt', 'updatedAt'] as const); +export type OmitAutoSetFields = Omit; +type ExcludeAutoSetFields = Exclude; export const excludeAutoSetFields = (fields: readonly T[]) => Object.freeze( @@ -85,3 +92,9 @@ export const convertToIdentifiers = ( export const convertToTimestamp = (time = new Date()) => sql`to_timestamp(${time.valueOf() / 1000})`; + +export const manyRows = async (query: Promise>): Promise => { + const { rows } = await query; + + return rows; +}; diff --git a/packages/schemas/package.json b/packages/schemas/package.json index 38f5a725e..f5f41d35d 100644 --- a/packages/schemas/package.json +++ b/packages/schemas/package.json @@ -55,7 +55,7 @@ "pluralize": "^8.0.0", "prettier": "^3.0.0", "roarr": "^7.11.0", - "slonik": "^30.0.0", + "slonik": "30.4.0", "slonik-sql-tag-raw": "^1.1.4", "typescript": "^5.3.3" }, diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 066748a86..c63888f70 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -170,14 +170,14 @@ importers: specifier: ^7.3.8 version: 7.5.2 slonik: - specifier: ^30.0.0 - version: 30.1.2 + specifier: 30.4.0 + version: 30.4.0 slonik-interceptor-preset: specifier: ^1.2.10 version: 1.2.10 slonik-sql-tag-raw: specifier: ^1.1.4 - version: 1.1.4(roarr@7.11.0)(slonik@30.1.2) + version: 1.1.4(roarr@7.11.0)(slonik@30.4.0) tar: specifier: ^6.1.11 version: 6.1.11 @@ -3390,14 +3390,14 @@ importers: specifier: ^7.3.8 version: 7.5.2 slonik: - specifier: ^30.0.0 - version: 30.1.2 + specifier: 30.4.0 + version: 30.4.0 slonik-interceptor-preset: specifier: ^1.2.10 version: 1.2.10 slonik-sql-tag-raw: specifier: ^1.1.4 - version: 1.1.4(roarr@7.11.0)(slonik@30.1.2) + version: 1.1.4(roarr@7.11.0)(slonik@30.4.0) snake-case: specifier: ^3.0.4 version: 3.0.4 @@ -4052,11 +4052,11 @@ importers: specifier: ^7.11.0 version: 7.11.0 slonik: - specifier: ^30.0.0 - version: 30.1.2 + specifier: 30.4.0 + version: 30.4.0 slonik-sql-tag-raw: specifier: ^1.1.4 - version: 1.1.4(roarr@7.11.0)(slonik@30.1.2) + version: 1.1.4(roarr@7.11.0)(slonik@30.4.0) typescript: specifier: ^5.3.3 version: 5.3.3 @@ -18058,17 +18058,25 @@ packages: obuf: 1.1.2 dev: false - /pg-copy-streams@6.0.2: - resolution: {integrity: sha512-74doDsDUI3ti1IzeieA7c/VsTpZkBdgjMeag3BtJFV+3J0m7Z3UMJB8iQW+zUWHZGVF9d/WIRfledEaPfKcPEA==} + /pg-copy-streams@6.0.6: + resolution: {integrity: sha512-Z+Dd2C2NIDTsjyFKmc6a9QLlpM8tjpERx+43RSx0WmL7j3uNChERi3xSvZUL0hWJ1oRUn4S3fhyt3apdSrTyKQ==} dependencies: obuf: 1.1.2 + /pg-cursor@2.10.3(pg@8.8.0): + resolution: {integrity: sha512-rDyBVoqPVnx/PTmnwQAYgusSeAKlTL++gmpf5klVK+mYMFEqsOc6VHHZnPKc/4lOvr4r6fiMuoxSFuBF1dx4FQ==} + peerDependencies: + pg: ^8 + dependencies: + pg: 8.8.0 + /pg-cursor@2.7.3(pg@8.8.0): resolution: {integrity: sha512-vmjXRMD4jZK/oHaaYk6clTypgHNlzCCAqyLCO5d/UeI42egJVE5H4ZfZWACub3jzkHUXXyvibH207zAJg9iBOw==} peerDependencies: pg: ^8 dependencies: pg: 8.8.0 + dev: false /pg-formatter@1.3.0: resolution: {integrity: sha512-y1kNdgD+QWzhmYCm91z/k7VGyx6BekQg6ww/krFEEhw1IIB4zEk2xaB0pmueTcc59YFetpiHIKECgHEuw6gyvg==} @@ -19521,6 +19529,14 @@ packages: globalthis: 1.0.2 semver-compare: 1.0.0 + /roarr@7.21.1: + resolution: {integrity: sha512-3niqt5bXFY1InKU8HKWqqYTYjtrBaxBMnXELXCXUYgtNYGUtZM5rB46HIC430AyacL95iEniGf7RgqsesykLmQ==} + engines: {node: '>=18.0'} + dependencies: + fast-printf: 1.6.9 + safe-stable-stringify: 2.4.3 + semver-compare: 1.0.0 + /rollup-plugin-summary@2.0.0(rollup@4.12.0): resolution: {integrity: sha512-7Av6DQeCmVNpFmCdkkbMya1CneeGWhjSXXQ3B4yDO+BvN/Kbohqi3IEYXAvgHP3iIafSfMyOw+PBLFUlvf1ViA==} engines: {node: '>=14.0.0'} @@ -19597,6 +19613,10 @@ packages: regexp-tree: 0.1.24 dev: true + /safe-stable-stringify@2.4.3: + resolution: {integrity: sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g==} + engines: {node: '>=10'} + /safer-buffer@2.1.2: resolution: {integrity: sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==} @@ -19860,7 +19880,7 @@ packages: - pg-native dev: false - /slonik-sql-tag-raw@1.1.4(roarr@7.11.0)(slonik@30.1.2): + /slonik-sql-tag-raw@1.1.4(roarr@7.11.0)(slonik@30.4.0): resolution: {integrity: sha512-os6iRAkQgKNoVzudRtLBlxjqmyQHJdPHw/eMIBJDnUfD5dle5uIyEKtblayW7eBr5x7blkzUg4BgvRkeDZeZPA==} engines: {node: '>=10.0'} peerDependencies: @@ -19870,7 +19890,7 @@ packages: lodash: 4.17.21 roarr: 7.11.0 serialize-error: 8.1.0 - slonik: 30.1.2 + slonik: 30.4.0 /slonik@22.7.1: resolution: {integrity: sha512-88GidNOWv4Bg0CqYLXajqcD0bbLip2soY6B4JzHP7EGDrWUb1WSlu7mIppTJVfcK99mx+jnX3xQq3FJ0DoOXag==} @@ -19899,8 +19919,8 @@ packages: - pg-native dev: false - /slonik@30.1.2: - resolution: {integrity: sha512-vNCZT4eEr3cKnm83LF8QOCTfm3TH/XSQdMnG4X3A+V1PVJFG3JKjRMB8jwin/3eYeM6nVCSXeZqlPGlHHXrgBQ==} + /slonik@30.4.0: + resolution: {integrity: sha512-1C88SJFBlhQ1bm1H2O2nAktvW1t2tVdpLLZBr86gPxre9LvLIh8Xvkoq0s3aJ0p7zV466TIbRuhI/fq02NP36A==} engines: {node: '>=10.0'} dependencies: concat-stream: 2.0.0 @@ -19912,16 +19932,17 @@ packages: iso8601-duration: 1.3.0 p-defer: 3.0.0 pg: 8.8.0 - pg-copy-streams: 6.0.2 + pg-copy-streams: 6.0.6 pg-copy-streams-binary: 2.2.0 - pg-cursor: 2.7.3(pg@8.8.0) + pg-cursor: 2.10.3(pg@8.8.0) pg-protocol: 1.6.0 pg-types: 4.0.0 postgres-array: 3.0.1 postgres-interval: 4.0.0 - roarr: 7.11.0 + roarr: 7.21.1 serialize-error: 8.1.0 through2: 4.0.2 + zod: 3.22.4 transitivePeerDependencies: - pg-native