update deps (#15311)
* wip * bump misskey-dev/eslint-plugin * lint fixes (backend) * lint fixes (frontend) * lint fixes (frontend-embed) * rollback nsfwjs to 4.2.0 ref: infinitered/nsfwjs#904 * rollback openapi-typescript to v6 v7でOpenAPIのバリデーションが入るようになった関係でスコープ外での変更が避けられないため一時的に戻した * lint fixes (misskey-js) * temporarily disable errored lint rule (frontend-shared) * fix lint * temporarily ignore errored file for lint (frontend-shared) * rollback simplewebauthn/server to 12.0.0 v13 contains breaking changes that require some decision making * lint fixes (frontend-shared) * build misskey-js with types * fix(backend): migrate simplewebauthn/server to v12 * fix(misskey-js/autogen): ignore indent rules to generate consistent output * attempt to fix test changes due to capricorn86/happy-dom#1617 (XMLSerializer now produces valid XML) * attempt to fix test changes due to capricorn86/happy-dom#1617 (XMLSerializer now produces valid XML) * fix test * fix test * fix test * Apply suggestions from code review Co-authored-by: anatawa12 <anatawa12@icloud.com> * bump summaly to v5.2.0 * update tabler-icons to v3.30.0-based --------- Co-authored-by: かっこかり <67428053+kakkokari-gtyih@users.noreply.github.com> Co-authored-by: anatawa12 <anatawa12@icloud.com>
This commit is contained in:
		| @@ -105,8 +105,8 @@ type Source = { | ||||
|  | ||||
| 	logging?: { | ||||
| 		sql?: { | ||||
| 			disableQueryTruncation? : boolean, | ||||
| 			enableQueryParamLogging? : boolean, | ||||
| 			disableQueryTruncation?: boolean, | ||||
| 			enableQueryParamLogging?: boolean, | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
| @@ -166,8 +166,8 @@ export type Config = { | ||||
| 	signToActivityPubGet: boolean | undefined; | ||||
| 	logging?: { | ||||
| 		sql?: { | ||||
| 			disableQueryTruncation? : boolean, | ||||
| 			enableQueryParamLogging? : boolean, | ||||
| 			disableQueryTruncation?: boolean, | ||||
| 			enableQueryParamLogging?: boolean, | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
|   | ||||
| @@ -43,7 +43,7 @@ export type CaptchaSetting = { | ||||
| 		siteKey: string | null; | ||||
| 		secretKey: string | null; | ||||
| 	} | ||||
| } | ||||
| }; | ||||
|  | ||||
| export class CaptchaError extends Error { | ||||
| 	public readonly code: CaptchaErrorCode; | ||||
| @@ -59,11 +59,11 @@ export class CaptchaError extends Error { | ||||
|  | ||||
| export type CaptchaSaveSuccess = { | ||||
| 	success: true; | ||||
| } | ||||
| }; | ||||
| export type CaptchaSaveFailure = { | ||||
| 	success: false; | ||||
| 	error: CaptchaError; | ||||
| } | ||||
| }; | ||||
| export type CaptchaSaveResult = CaptchaSaveSuccess | CaptchaSaveFailure; | ||||
|  | ||||
| type CaptchaResponse = { | ||||
|   | ||||
| @@ -9,7 +9,7 @@ import { DI } from '@/di-symbols.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { IdService } from '@/core/IdService.js'; | ||||
|  | ||||
| export type FanoutTimelineName = | ||||
| export type FanoutTimelineName = ( | ||||
| 	// home timeline | ||||
| 	| `homeTimeline:${string}` | ||||
| 	| `homeTimelineWithFiles:${string}` // only notes with files are included | ||||
| @@ -37,6 +37,7 @@ export type FanoutTimelineName = | ||||
|  | ||||
| 	// role timelines | ||||
| 	| `roleTimeline:${string}` // any notes are included | ||||
| ); | ||||
|  | ||||
| @Injectable() | ||||
| export class FanoutTimelineService { | ||||
|   | ||||
| @@ -211,7 +211,7 @@ type SerializedAll<T> = { | ||||
|  | ||||
| type UndefinedAsNullAll<T> = { | ||||
| 	[K in keyof T]: T[K] extends undefined ? null : T[K]; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export interface InternalEventTypes { | ||||
| 	userChangeSuspendedState: { id: MiUser['id']; isSuspended: MiUser['isSuspended']; }; | ||||
|   | ||||
| @@ -492,7 +492,8 @@ export class MfmService { | ||||
|  | ||||
| 		appendChildren(nodes, body); | ||||
|  | ||||
| 		const serialized = new XMLSerializer().serializeToString(body); | ||||
| 		// Remove the unnecessary namespace | ||||
| 		const serialized = new XMLSerializer().serializeToString(body).replace(/^\s*<p xmlns=\"http:\/\/www.w3.org\/1999\/xhtml\">/, '<p>'); | ||||
|  | ||||
| 		happyDOM.close().catch(err => {}); | ||||
|  | ||||
|   | ||||
| @@ -15,7 +15,7 @@ import { QueueService } from '@/core/QueueService.js'; | ||||
| import type { OnApplicationShutdown } from '@nestjs/common'; | ||||
|  | ||||
| export type UserWebhookPayload<T extends WebhookEventTypes> = | ||||
| 	T extends 'note' | 'reply' | 'renote' |'mention' ? { | ||||
| 	T extends 'note' | 'reply' | 'renote' | 'mention' ? { | ||||
| 		note: Packed<'Note'>, | ||||
| 	} : | ||||
| 	T extends 'follow' | 'unfollow' ? { | ||||
|   | ||||
| @@ -127,11 +127,11 @@ export class WebAuthnService { | ||||
| 		const { registrationInfo } = verification; | ||||
|  | ||||
| 		return { | ||||
| 			credentialID: registrationInfo.credentialID, | ||||
| 			credentialPublicKey: registrationInfo.credentialPublicKey, | ||||
| 			credentialID: registrationInfo.credential.id, | ||||
| 			credentialPublicKey: registrationInfo.credential.publicKey, | ||||
| 			attestationObject: registrationInfo.attestationObject, | ||||
| 			fmt: registrationInfo.fmt, | ||||
| 			counter: registrationInfo.counter, | ||||
| 			counter: registrationInfo.credential.counter, | ||||
| 			userVerified: registrationInfo.userVerified, | ||||
| 			credentialDeviceType: registrationInfo.credentialDeviceType, | ||||
| 			credentialBackedUp: registrationInfo.credentialBackedUp, | ||||
| @@ -212,9 +212,9 @@ export class WebAuthnService { | ||||
| 				expectedChallenge: challenge, | ||||
| 				expectedOrigin: relyingParty.origin, | ||||
| 				expectedRPID: relyingParty.rpId, | ||||
| 				authenticator: { | ||||
| 					credentialID: key.id, | ||||
| 					credentialPublicKey: Buffer.from(key.publicKey, 'base64url'), | ||||
| 				credential: { | ||||
| 					id: key.id, | ||||
| 					publicKey: Buffer.from(key.publicKey, 'base64url'), | ||||
| 					counter: key.counter, | ||||
| 					transports: key.transports ? key.transports as AuthenticatorTransportFuture[] : undefined, | ||||
| 				}, | ||||
| @@ -292,9 +292,9 @@ export class WebAuthnService { | ||||
| 				expectedChallenge: challenge, | ||||
| 				expectedOrigin: relyingParty.origin, | ||||
| 				expectedRPID: relyingParty.rpId, | ||||
| 				authenticator: { | ||||
| 					credentialID: key.id, | ||||
| 					credentialPublicKey: Buffer.from(key.publicKey, 'base64url'), | ||||
| 				credential: { | ||||
| 					id: key.id, | ||||
| 					publicKey: Buffer.from(key.publicKey, 'base64url'), | ||||
| 					counter: key.counter, | ||||
| 					transports: key.transports ? key.transports as AuthenticatorTransportFuture[] : undefined, | ||||
| 				}, | ||||
|   | ||||
| @@ -57,12 +57,14 @@ const ajv = new Ajv(); | ||||
|  | ||||
| function isLocalUser(user: MiUser): user is MiLocalUser; | ||||
| function isLocalUser<T extends { host: MiUser['host'] }>(user: T): user is (T & { host: null; }); | ||||
|  | ||||
| function isLocalUser(user: MiUser | { host: MiUser['host'] }): boolean { | ||||
| 	return user.host == null; | ||||
| } | ||||
|  | ||||
| function isRemoteUser(user: MiUser): user is MiRemoteUser; | ||||
| function isRemoteUser<T extends { host: MiUser['host'] }>(user: T): user is (T & { host: string; }); | ||||
|  | ||||
| function isRemoteUser(user: MiUser | { host: MiUser['host'] }): boolean { | ||||
| 	return !isLocalUser(user); | ||||
| } | ||||
| @@ -78,7 +80,7 @@ export type UserRelation = { | ||||
| 	isBlocked: boolean | ||||
| 	isMuted: boolean | ||||
| 	isRenoteMuted: boolean | ||||
| } | ||||
| }; | ||||
|  | ||||
| @Injectable() | ||||
| export class UserEntityService implements OnModuleInit { | ||||
|   | ||||
| @@ -143,7 +143,7 @@ type OfSchema = { | ||||
| 	readonly anyOf?: ReadonlyArray<Schema>; | ||||
| 	readonly oneOf?: ReadonlyArray<Schema>; | ||||
| 	readonly allOf?: ReadonlyArray<Schema>; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export interface Schema extends OfSchema { | ||||
| 	readonly type?: TypeStringef; | ||||
| @@ -217,7 +217,7 @@ type ObjectSchemaTypeDef<p extends Schema> = | ||||
| 	: | ||||
| 	p['anyOf'] extends ReadonlyArray<Schema> ? never : // see CONTRIBUTING.md | ||||
| 	p['allOf'] extends ReadonlyArray<Schema> ? UnionToIntersection<UnionSchemaType<p['allOf']>> : | ||||
| 	any | ||||
| 	any; | ||||
|  | ||||
| type ObjectSchemaType<p extends Schema> = NullOrUndefined<p, ObjectSchemaTypeDef<p>>; | ||||
|  | ||||
|   | ||||
| @@ -4,7 +4,7 @@ | ||||
|  */ | ||||
|  | ||||
| export type JsonValue = JsonArray | JsonObject | string | number | boolean | null; | ||||
| export type JsonObject = {[K in string]?: JsonValue}; | ||||
| export type JsonObject = { [K in string]?: JsonValue }; | ||||
| export type JsonArray = JsonValue[]; | ||||
|  | ||||
| export function isJsonObject(value: JsonValue | undefined): value is JsonObject { | ||||
|   | ||||
| @@ -288,24 +288,24 @@ export class MiUser { | ||||
| export type MiLocalUser = MiUser & { | ||||
| 	host: null; | ||||
| 	uri: null; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type MiPartialLocalUser = Partial<MiUser> & { | ||||
| 	id: MiUser['id']; | ||||
| 	host: null; | ||||
| 	uri: null; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type MiRemoteUser = MiUser & { | ||||
| 	host: string; | ||||
| 	uri: string; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type MiPartialRemoteUser = Partial<MiUser> & { | ||||
| 	id: MiUser['id']; | ||||
| 	host: string; | ||||
| 	uri: string; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export const localUsernameSchema = { type: 'string', pattern: /^\w{1,20}$/.toString().slice(1, -1) } as const; | ||||
| export const passwordSchema = { type: 'string', minLength: 1 } as const; | ||||
|   | ||||
| @@ -92,7 +92,7 @@ const sqlLogger = dbLogger.createSubLogger('sql', 'gray'); | ||||
| export type LoggerProps = { | ||||
| 	disableQueryTruncation?: boolean; | ||||
| 	enableQueryParamLogging?: boolean; | ||||
| } | ||||
| }; | ||||
|  | ||||
| function highlightSql(sql: string) { | ||||
| 	return highlight.highlight(sql, { | ||||
|   | ||||
| @@ -29,7 +29,7 @@ export type ModeratorInactivityEvaluationResult = { | ||||
| 	isModeratorsInactive: boolean; | ||||
| 	inactiveModerators: MiUser[]; | ||||
| 	remainingTime: ModeratorInactivityRemainingTime; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type ModeratorInactivityRemainingTime = { | ||||
| 	time: number; | ||||
|   | ||||
| @@ -38,7 +38,7 @@ export type RelationshipJobData = { | ||||
| 	silent?: boolean; | ||||
| 	requestId?: string; | ||||
| 	withReplies?: boolean; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type DbJobData<T extends keyof DbJobMap> = DbJobMap[T]; | ||||
|  | ||||
| @@ -61,11 +61,11 @@ export type DbJobMap = { | ||||
| 	importUserLists: DbUserImportJobData; | ||||
| 	importCustomEmojis: DbUserImportJobData; | ||||
| 	deleteAccount: DbUserDeleteJobData; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type DbJobDataWithUser = { | ||||
| 	user: ThinUser; | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type DbExportFollowingData = { | ||||
| 	user: ThinUser; | ||||
| @@ -75,7 +75,7 @@ export type DbExportFollowingData = { | ||||
|  | ||||
| export type DBExportAntennasData = { | ||||
| 	user: ThinUser | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type DbUserDeleteJobData = { | ||||
| 	user: ThinUser; | ||||
| @@ -91,7 +91,7 @@ export type DbUserImportJobData = { | ||||
| export type DBAntennaImportJobData = { | ||||
| 	user: ThinUser, | ||||
| 	antenna: Antenna | ||||
| } | ||||
| }; | ||||
|  | ||||
| export type DbUserImportToDbJobData = { | ||||
| 	user: ThinUser; | ||||
|   | ||||
| @@ -122,7 +122,7 @@ export type IEndpointMeta = (Omit<IEndpointMetaBase, 'requireCrential' | 'requir | ||||
| }) | (Omit<IEndpointMetaBase, 'requireAdmin' | 'kind'> & { | ||||
| 	requireAdmin: true, | ||||
| 	kind: (typeof permissions)[number], | ||||
| }) | ||||
| }); | ||||
|  | ||||
| export interface IEndpoint { | ||||
| 	name: string; | ||||
|   | ||||
| @@ -82,8 +82,8 @@ export default abstract class Channel { | ||||
| 		this.connection = connection; | ||||
| 	} | ||||
|  | ||||
| 	public send(payload: { type: string, body: JsonValue }): void | ||||
| 	public send(type: string, payload: JsonValue): void | ||||
| 	public send(payload: { type: string, body: JsonValue }): void; | ||||
| 	public send(type: string, payload: JsonValue): void; | ||||
| 	@bindThis | ||||
| 	public send(typeOrPayload: { type: string, body: JsonValue } | string, payload?: JsonValue) { | ||||
| 		const type = payload === undefined ? (typeOrPayload as { type: string, body: JsonValue }).type : (typeOrPayload as string); | ||||
| @@ -108,4 +108,4 @@ export type MiChannelService<T extends boolean> = { | ||||
| 	requireCredential: T; | ||||
| 	kind: T extends true ? string : string | null | undefined; | ||||
| 	create: (id: string, connection: Connection) => Channel; | ||||
| } | ||||
| }; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 syuilo
					syuilo