From d68099465af2ae72b7dc5d2340a38ec15162bc3d Mon Sep 17 00:00:00 2001 From: Michael Thomas Date: Sun, 12 Jan 2025 19:20:20 -0500 Subject: [PATCH 01/96] feat: basic OpenID Connect support --- jellyseerr-api.yml | 110 +++++++ package.json | 1 + pnpm-lock.yaml | 9 + server/entity/LinkedAccount.ts | 27 ++ server/entity/User.ts | 4 + server/interfaces/api/oidcInterfaces.ts | 239 ++++++++++++++ server/interfaces/api/settingsInterfaces.ts | 2 + .../interfaces/api/userSettingsInterfaces.ts | 13 +- server/lib/settings/index.ts | 41 +++ server/routes/auth.ts | 297 ++++++++++++++++++ server/routes/user/usersettings.ts | 71 +++++ server/utils/oidc.ts | 202 ++++++++++++ src/components/Login/ErrorCallout.tsx | 26 ++ .../UserLinkedAccountsSettings/index.tsx | 67 +++- src/context/SettingsContext.tsx | 3 +- src/pages/_app.tsx | 6 +- src/pages/login/oidc/callback/[slug].tsx | 74 +++++ src/utils/oidc.ts | 28 ++ 18 files changed, 1206 insertions(+), 14 deletions(-) create mode 100644 server/entity/LinkedAccount.ts create mode 100644 server/interfaces/api/oidcInterfaces.ts create mode 100644 server/utils/oidc.ts create mode 100644 src/components/Login/ErrorCallout.tsx create mode 100644 src/pages/login/oidc/callback/[slug].tsx create mode 100644 src/utils/oidc.ts diff --git a/jellyseerr-api.yml b/jellyseerr-api.yml index 6954992d82..ece894fd7a 100644 --- a/jellyseerr-api.yml +++ b/jellyseerr-api.yml @@ -3700,6 +3700,77 @@ paths: required: - email - password + /auth/oidc/login/{slug}: + get: + security: [] + summary: Redirect to the OpenID Connect provider + description: Constructs the redirect URL to the OpenID Connect provider, and redirects the user to it. + tags: + - auth + parameters: + - in: path + name: slug + required: true + schema: + type: string + example: 'authentik' + responses: + '302': + description: Redirect to the authentication url for the OpenID Connect provider + headers: + Location: + schema: + type: string + example: https://example.com/auth/oidc/callback?response_type=code&client_id=client_id&redirect_uri=https%3A%2F%2Fexample.com%2Fauth%2Foidc%2Fcallback&scope=openid%20email&state=state + Set-Cookie: + schema: + type: string + example: 'oidc-state=123456789; HttpOnly; max-age=60000; Secure' + /auth/oidc/callback/{slug}: + get: + security: [] + summary: The callback endpoint for the OpenID Connect provider redirect + description: Takes the `code` and `state` parameters from the OpenID Connect provider, and exchanges them for a token. + x-allow-unknown-query-parameters: true + tags: + - auth + parameters: + - in: path + name: slug + required: true + schema: + type: string + example: 'authentik' + - in: query + name: code + required: true + schema: + type: string + example: '123456789' + - in: query + name: state + required: true + schema: + type: string + example: '123456789' + - in: cookie + name: oidc-state + required: true + schema: + type: string + example: '123456789' + responses: + '302': + description: A redirect to the home page if successful or back to the login page if not + headers: + Location: + schema: + type: string + example: / + Set-Cookie: + schema: + type: string + example: 'oidc-state=deleted; path=/; expires=Thu, 01 Jan 1970 00:00:00 GMT' /auth/logout: post: summary: Sign out and clear session cookie @@ -4509,6 +4580,23 @@ paths: responses: '204': description: User password updated + /user/{userId}/settings/linked-accounts: + get: + summary: Lists the user's linked OpenID Connect accounts + description: Lists the user's linked OpenID Connect accounts + tags: + - users + parameters: + - in: path + name: userId + required: true + schema: + type: number + responses: + '200': + description: List of linked accounts + '403': + description: Invalid credentials /user/{userId}/settings/linked-accounts/plex: post: summary: Link the provided Plex account to the current user @@ -4607,6 +4695,28 @@ paths: description: Unlink request invalid '404': description: User does not exist + /user/{userId}/settings/linked-accounts/{acctId}: + delete: + summary: Remove a linked account for a user + description: Removes the linked account with the given ID for a specific user. Requires `MANAGE_USERS` permission if editing other users. + tags: + - users + parameters: + - in: path + name: userId + required: true + schema: + type: number + - in: path + name: acctId + required: true + schema: + type: number + responses: + '204': + description: Unlinking account succeeded + '404': + description: User or linked account does not exist /user/{userId}/settings/notifications: get: summary: Get notification settings for a user diff --git a/package.json b/package.json index 143777810f..85a3dad7b2 100644 --- a/package.json +++ b/package.json @@ -63,6 +63,7 @@ "express-session": "1.17.3", "formik": "^2.4.6", "gravatar-url": "3.1.0", + "jwt-decode": "^4.0.0", "lodash": "4.17.21", "mime": "3", "next": "^14.2.25", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 86ec16a6e1..738b00d470 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -101,6 +101,9 @@ importers: gravatar-url: specifier: 3.1.0 version: 3.1.0 + jwt-decode: + specifier: ^4.0.0 + version: 4.0.0 lodash: specifier: 4.17.21 version: 4.17.21 @@ -6333,6 +6336,10 @@ packages: jws@4.0.0: resolution: {integrity: sha512-KDncfTmOZoOMTFG4mBlG0qUIOlc03fmzH+ru6RgYVZhPkyiy/92Owlt/8UEN+a4TXR1FQetfIpJE8ApdvdVxTg==} + jwt-decode@4.0.0: + resolution: {integrity: sha512-+KJGIyHgkGuIq3IEBNftfhW/LfWhXUIY6OmyVWjliu5KH1y0fw7VQ8YndE2O4qZdMSd9SqbnC8GOcZEy0Om7sA==} + engines: {node: '>=18'} + keyv@4.5.4: resolution: {integrity: sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==} @@ -17391,6 +17398,8 @@ snapshots: jwa: 2.0.0 safe-buffer: 5.2.1 + jwt-decode@4.0.0: {} + keyv@4.5.4: dependencies: json-buffer: 3.0.1 diff --git a/server/entity/LinkedAccount.ts b/server/entity/LinkedAccount.ts new file mode 100644 index 0000000000..fba4edbc8a --- /dev/null +++ b/server/entity/LinkedAccount.ts @@ -0,0 +1,27 @@ +import { Column, Entity, ManyToOne, PrimaryGeneratedColumn } from 'typeorm'; +import { User } from './User'; + +@Entity('linked_accounts') +export class LinkedAccount { + constructor(options: Omit) { + Object.assign(this, options); + } + + @PrimaryGeneratedColumn() + id: number; + + @ManyToOne(() => User, (user) => user.linkedAccounts, { onDelete: 'CASCADE' }) + user: User; + + /** Slug of the OIDC provider. */ + @Column({ type: 'varchar', length: 255 }) + provider: string; + + /** Unique ID from the OAuth provider */ + @Column({ type: 'varchar', length: 255 }) + sub: string; + + /** Account username from the OAuth provider */ + @Column() + username: string; +} diff --git a/server/entity/User.ts b/server/entity/User.ts index 91b6674037..c1cf57ad6e 100644 --- a/server/entity/User.ts +++ b/server/entity/User.ts @@ -1,6 +1,7 @@ import { MediaRequestStatus, MediaType } from '@server/constants/media'; import { UserType } from '@server/constants/user'; import { getRepository } from '@server/datasource'; +import { LinkedAccount } from '@server/entity/LinkedAccount'; import { Watchlist } from '@server/entity/Watchlist'; import type { QuotaResponse } from '@server/interfaces/api/userInterfaces'; import PreparedEmail from '@server/lib/email'; @@ -92,6 +93,9 @@ export class User { @Column({ type: 'varchar', nullable: true, select: false }) public plexToken?: string | null; + @OneToMany(() => LinkedAccount, (link) => link.user) + public linkedAccounts: LinkedAccount[]; + @Column({ type: 'integer', default: 0 }) public permissions = 0; diff --git a/server/interfaces/api/oidcInterfaces.ts b/server/interfaces/api/oidcInterfaces.ts new file mode 100644 index 0000000000..68d444b560 --- /dev/null +++ b/server/interfaces/api/oidcInterfaces.ts @@ -0,0 +1,239 @@ +/** + * @internal + */ +type Mandatory = Required> & Omit; + +/** + * Standard OpenID Connect discovery document. + * + * @public + * @see https://openid.net/specs/openid-connect-discovery-1_0.html#ProviderMetadata + */ +export interface OidcProviderMetadata { + issuer: string; // REQUIRED + + authorization_endpoint: string; // REQUIRED + + token_endpoint: string; // REQUIRED + + token_endpoint_auth_methods_supported?: string[]; // OPTIONAL + + token_endpoint_auth_signing_alg_values_supported?: string[]; // OPTIONAL + + userinfo_endpoint: string; // RECOMMENDED + + check_session_iframe: string; // REQUIRED + + end_session_endpoint: string; // REQUIRED + + jwks_uri: string; // REQUIRED + + registration_endpoint: string; // RECOMMENDED + + scopes_supported: string[]; // RECOMMENDED + + response_types_supported: string[]; // REQUIRED + + acr_values_supported?: string[]; // OPTIONAL + + subject_types_supported: string[]; // REQUIRED + + request_object_signing_alg_values_supported?: string[]; // OPTIONAL + + display_values_supported?: string[]; // OPTIONAL + + claim_types_supported?: string[]; // OPTIONAL + + claims_supported: string[]; // RECOMMENDED + + claims_parameter_supported?: boolean; // OPTIONAL + + service_documentation?: string; // OPTIONAL + + ui_locales_supported?: string[]; // OPTIONAL + + revocation_endpoint: string; // REQUIRED + + introspection_endpoint: string; // REQUIRED + + frontchannel_logout_supported?: boolean; // OPTIONAL + + frontchannel_logout_session_supported?: boolean; // OPTIONAL + + backchannel_logout_supported?: boolean; // OPTIONAL + + backchannel_logout_session_supported?: boolean; // OPTIONAL + + grant_types_supported?: string[]; // OPTIONAL + + response_modes_supported?: string[]; // OPTIONAL + + code_challenge_methods_supported?: string[]; // OPTIONAL +} + +/** + * Standard OpenID Connect address claim. + * The Address Claim represents a physical mailing address. + * + * @public + * @see https://openid.net/specs/openid-connect-core-1_0.html#AddressClaim + */ +export interface OidcAddressClaim { + /** Full mailing address, formatted for display or use on a mailing label. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair ("\\r\\n") or as a single line feed character ("\\n"). */ + formatted?: string; + /** Full street address component, which MAY include house number, street name, Post Office Box, and multi-line extended street address information. This field MAY contain multiple lines, separated by newlines. Newlines can be represented either as a carriage return/line feed pair ("\\r\\n") or as a single line feed character ("\\n"). */ + street_address?: string; + /** City or locality component. */ + locality?: string; + /** State, province, prefecture, or region component. */ + region?: string; + /** Zip code or postal code component. */ + postal_code?: string; + /** Country name component. */ + country?: string; +} + +/** + * Standard OpenID Connect claims. + * They can be requested to be returned either in the UserInfo Response or in the ID Token. + * + * @public + * @see https://openid.net/specs/openid-connect-core-1_0.html#StandardClaims + */ +export interface OidcStandardClaims { + /** Subject - Identifier for the End-User at the Issuer. */ + sub?: string; + /** End-User's full name in displayable form including all name parts, possibly including titles and suffixes, ordered according to the End-User's locale and preferences. */ + name?: string; + /** Given name(s) or first name(s) of the End-User. Note that in some cultures, people can have multiple given names; all can be present, with the names being separated by space characters. */ + given_name?: string; + /** Surname(s) or last name(s) of the End-User. Note that in some cultures, people can have multiple family names or no family name; all can be present, with the names being separated by space characters. */ + family_name?: string; + /** Middle name(s) of the End-User. Note that in some cultures, people can have multiple middle names; all can be present, with the names being separated by space characters. Also note that in some cultures, middle names are not used. */ + middle_name?: string; + /** Casual name of the End-User that may or may not be the same as the given_name. For instance, a nickname value of Mike might be returned alongside a given_name value of Michael. */ + nickname?: string; + /** Shorthand name by which the End-User wishes to be referred to at the RP, such as janedoe or j.doe. This value MAY be any valid JSON string including special characters such as \@, /, or whitespace. */ + preferred_username?: string; + /** URL of the End-User's profile page. The contents of this Web page SHOULD be about the End-User. */ + profile?: string; + /** URL of the End-User's profile picture. This URL MUST refer to an image file (for example, a PNG, JPEG, or GIF image file), rather than to a Web page containing an image. Note that this URL SHOULD specifically reference a profile photo of the End-User suitable for displaying when describing the End-User, rather than an arbitrary photo taken by the End-User. */ + picture?: string; + /** URL of the End-User's Web page or blog. This Web page SHOULD contain information published by the End-User or an organization that the End-User is affiliated with. */ + website?: string; + /** End-User's preferred e-mail address. Its value MUST conform to the RFC 5322 addr-spec syntax. */ + email?: string; + /** True if the End-User's e-mail address has been verified; otherwise false. When this Claim Value is true, this means that the OP took affirmative steps to ensure that this e-mail address was controlled by the End-User at the time the verification was performed. The means by which an e-mail address is verified is context-specific, and dependent upon the trust framework or contractual agreements within which the parties are operating. */ + email_verified?: boolean; + /** End-User's gender. Values defined by this specification are female and male. Other values MAY be used when neither of the defined values are applicable. */ + gender?: string; + /** End-User's birthday, represented as an ISO 8601:2004 [ISO8601‑2004] YYYY-MM-DD format. The year MAY be 0000, indicating that it is omitted. To represent only the year, YYYY format is allowed. Note that depending on the underlying platform's date related function, providing just year can result in varying month and day, so the implementers need to take this factor into account to correctly process the dates. */ + birthdate?: string; + /** String from zoneinfo [zoneinfo] time zone database representing the End-User's time zone. For example, Europe/Paris or America/Los_Angeles. */ + zoneinfo?: string; + /** End-User's locale, represented as a BCP47 [RFC5646] language tag. This is typically an ISO 639-1 Alpha-2 [ISO639‑1] language code in lowercase and an ISO 3166-1 Alpha-2 [ISO3166‑1] country code in uppercase, separated by a dash. For example, en-US or fr-CA. As a compatibility note, some implementations have used an underscore as the separator rather than a dash, for example, en_US; */ + locale?: string; + /** End-User's preferred telephone number. E.164 [E.164] is RECOMMENDED as the format of this Claim, for example, +1 (425) 555-1212 or +56 (2) 687 2400. If the phone number contains an extension, it is RECOMMENDED that the extension be represented using the RFC 3966 [RFC3966] extension syntax, for example, +1 (604) 555-1234;ext=5678. */ + phone_number?: string; + /** True if the End-User's phone number has been verified; otherwise false. When this Claim Value is true, this means that the OP took affirmative steps to ensure that this phone number was controlled by the End-User at the time the verification was performed. The means by which a phone number is verified is context-specific, and dependent upon the trust framework or contractual agreements within which the parties are operating. When true, the phone_number Claim MUST be in E.164 format and any extensions MUST be represented in RFC 3966 format. */ + phone_number_verified?: boolean; + /** End-User's preferred postal address. The value of the address member is a JSON [RFC4627] structure containing some or all of the members defined in Section 5.1.1. */ + address?: OidcAddressClaim; + /** Time the End-User's information was last updated. Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z as measured in UTC until the date/time. */ + updated_at?: number; +} + +/** + * Standard JWT claims. + * + * @public + * @see https://datatracker.ietf.org/doc/html/rfc7519#section-4.1 + */ +export interface JwtClaims { + [claim: string]: unknown; + + /** The "iss" (issuer) claim identifies the principal that issued the JWT. The processing of this claim is generally application specific. The "iss" value is a case-sensitive string containing a StringOrURI value. */ + iss?: string; + /** The "sub" (subject) claim identifies the principal that is the subject of the JWT. The claims in a JWT are normally statements about the subject. The subject value MUST either be scoped to be locally unique in the context of the issuer or be globally unique. The processing of this claim is generally application specific. The "sub" value is a case-sensitive string containing a StringOrURI value. */ + sub?: string; + /** The "aud" (audience) claim identifies the recipients that the JWT is intended for. Each principal intended to process the JWT MUST identify itself with a value in the audience claim. If the principal processing the claim does not identify itself with a value in the "aud" claim when this claim is present, then the JWT MUST be rejected. In the general case, the "aud" value is an array of case-sensitive strings, each containing a StringOrURI value. In the special case when the JWT has one audience, the "aud" value MAY be a single case-sensitive string containing a StringOrURI value. The interpretation of audience values is generally application specific. */ + aud?: string | string[]; + /** The "exp" (expiration time) claim identifies the expiration time on or after which the JWT MUST NOT be accepted for processing. The processing of the "exp" claim requires that the current date/time MUST be before the expiration date/time listed in the "exp" claim. Implementers MAY provide for some small leeway, usually no more than a few minutes, to account for clock skew. Its value MUST be a number containing a NumericDate value. */ + exp?: number; + /** The "nbf" (not before) claim identifies the time before which the JWT MUST NOT be accepted for processing. The processing of the "nbf" claim requires that the current date/time MUST be after or equal to the not-before date/time listed in the "nbf" claim. Implementers MAY provide for some small leeway, usually no more than a few minutes, to account for clock skew. Its value MUST be a number containing a NumericDate value. */ + nbf?: number; + /** The "iat" (issued at) claim identifies the time at which the JWT was issued. This claim can be used to determine the age of the JWT. Its value MUST be a number containing a NumericDate value. */ + iat?: number; + /** The "jti" (JWT ID) claim provides a unique identifier for the JWT. The identifier value MUST be assigned in a manner that ensures that there is a negligible probability that the same value will be accidentally assigned to a different data object; if the application uses multiple issuers, collisions MUST be prevented among values produced by different issuers as well. The "jti" claim can be used to prevent the JWT from being replayed. The "jti" value is a case-sensitive string. */ + jti?: string; +} + +/** + * Standard ID Token claims. + * + * @public + * @see https://openid.net/specs/openid-connect-core-1_0.html#IDToken + */ +export interface IdTokenClaims + extends Mandatory, + Mandatory { + [claim: string]: unknown; + + /** Time when the End-User authentication occurred. Its value is a JSON number representing the number of seconds from 1970-01-01T0:0:0Z as measured in UTC until the date/time. When a max_age request is made or when auth_time is requested as an Essential Claim, then this Claim is REQUIRED; otherwise, its inclusion is OPTIONAL. (The auth_time Claim semantically corresponds to the OpenID 2.0 PAPE [OpenID.PAPE] auth_time response parameter.) */ + auth_time?: number; + /** String value used to associate a Client session with an ID Token, and to mitigate replay attacks. The value is passed through unmodified from the Authentication Request to the ID Token. If present in the ID Token, Clients MUST verify that the nonce Claim Value is equal to the value of the nonce parameter sent in the Authentication Request. If present in the Authentication Request, Authorization Servers MUST include a nonce Claim in the ID Token with the Claim Value being the nonce value sent in the Authentication Request. Authorization Servers SHOULD perform no other processing on nonce values used. The nonce value is a case sensitive string. */ + nonce?: string; + /** Authentication Context Class Reference. String specifying an Authentication Context Class Reference value that identifies the Authentication Context Class that the authentication performed satisfied. The value "0" indicates the End-User authentication did not meet the requirements of ISO/IEC 29115 [ISO29115] level 1. Authentication using a long-lived browser cookie, for instance, is one example where the use of "level 0" is appropriate. Authentications with level 0 SHOULD NOT be used to authorize access to any resource of any monetary value. (This corresponds to the OpenID 2.0 PAPE [OpenID.PAPE] nist_auth_level 0.) An absolute URI or an RFC 6711 [RFC6711] registered name SHOULD be used as the acr value; registered names MUST NOT be used with a different meaning than that which is registered. Parties using this claim will need to agree upon the meanings of the values used, which may be context-specific. The acr value is a case sensitive string. */ + acr?: string; + /** Authentication Methods References. JSON array of strings that are identifiers for authentication methods used in the authentication. For instance, values might indicate that both password and OTP authentication methods were used. The definition of particular values to be used in the amr Claim is beyond the scope of this specification. Parties using this claim will need to agree upon the meanings of the values used, which may be context-specific. The amr value is an array of case sensitive strings. */ + amr?: unknown; + /** Authorized party - the party to which the ID Token was issued. If present, it MUST contain the OAuth 2.0 Client ID of this party. This Claim is only needed when the ID Token has a single audience value and that audience is different than the authorized party. It MAY be included even when the authorized party is the same as the sole audience. The azp value is a case sensitive string containing a StringOrURI value. */ + azp?: string; + /** + * Session ID - String identifier for a Session. This represents a Session of a User Agent or device for a logged-in End-User at an RP. Different sid values are used to identify distinct sessions at an OP. The sid value need only be unique in the context of a particular issuer. Its contents are opaque to the RP. Its syntax is the same as an OAuth 2.0 Client Identifier. + * @see https://openid.net/specs/openid-connect-frontchannel-1_0.html#OPLogout + * */ + sid?: string; +} + +type OidcTokenSuccessResponse = { + /** + * REQUIRED. ID Token value associated with the authenticated session. + * + * @see https://openid.net/specs/openid-connect-core-1_0.html#IDToken + */ + id_token: string; + /** + * REQUIRED. The access token issued by the authorization server. + */ + access_token: string; + /** + * REQUIRED. The type of the token issued as described in + * Section 7.1. Value is case insensitive. + * + * @see https://datatracker.ietf.org/doc/html/rfc6749#section-7.1 + */ + token_type: string; + /** + * RECOMMENDED. The lifetime in seconds of the access token. For + * example, the value "3600" denotes that the access token will + * expire in one hour from the time the response was generated. + * If omitted, the authorization server SHOULD provide the + * expiration time via other means or document the default value. + */ + expires_in?: number; +}; + +type OidcTokenErrorResponse = { + error: string; +}; + +/** + * Standard response from the OpenID Connect token request endpoint. + * + * @public + * @see https://openid.net/specs/openid-connect-core-1_0.html#TokenResponse + */ +export type OidcTokenResponse = + | OidcTokenSuccessResponse + | OidcTokenErrorResponse; diff --git a/server/interfaces/api/settingsInterfaces.ts b/server/interfaces/api/settingsInterfaces.ts index 0e97c2bf44..1b194d7894 100644 --- a/server/interfaces/api/settingsInterfaces.ts +++ b/server/interfaces/api/settingsInterfaces.ts @@ -1,3 +1,4 @@ +import type { PublicOidcProvider } from '@server/lib/settings'; import type { PaginatedResponse } from './common'; export type LogMessage = { @@ -45,6 +46,7 @@ export interface PublicSettingsResponse { locale: string; emailEnabled: boolean; newPlexLogin: boolean; + openIdProviders: PublicOidcProvider[]; } export interface CacheItem { diff --git a/server/interfaces/api/userSettingsInterfaces.ts b/server/interfaces/api/userSettingsInterfaces.ts index 327764618e..40e82ba3d8 100644 --- a/server/interfaces/api/userSettingsInterfaces.ts +++ b/server/interfaces/api/userSettingsInterfaces.ts @@ -1,4 +1,7 @@ -import type { NotificationAgentKey } from '@server/lib/settings'; +import type { + NotificationAgentKey, + PublicOidcProvider, +} from '@server/lib/settings'; export interface UserSettingsGeneralResponse { username?: string; @@ -39,3 +42,11 @@ export interface UserSettingsNotificationsResponse { webPushEnabled?: boolean; notificationTypes: Partial; } + +export type UserSettingsLinkedAccount = { + id: number; + username: string; + provider: PublicOidcProvider; +}; + +export type UserSettingsLinkedAccountResponse = UserSettingsLinkedAccount[]; diff --git a/server/lib/settings/index.ts b/server/lib/settings/index.ts index d85f71379e..515f081a6e 100644 --- a/server/lib/settings/index.ts +++ b/server/lib/settings/index.ts @@ -49,6 +49,25 @@ export interface JellyfinSettings { serverId: string; apiKey: string; } + +export type OidcProvider = { + slug: string; + name: string; + issuerUrl: string; + clientId: string; + clientSecret: string; + logo?: string; + requiredClaims?: string; + scopes?: string; + newUserLogin?: boolean; +}; + +export type PublicOidcProvider = Pick; + +export interface OidcSettings { + providers: OidcProvider[]; +} + export interface TautulliSettings { hostname?: string; port?: number; @@ -124,6 +143,7 @@ export interface MainSettings { hideAvailable: boolean; localLogin: boolean; mediaServerLogin: boolean; + oidcLogin: boolean; newPlexLogin: boolean; discoverRegion: string; streamingRegion: string; @@ -169,6 +189,7 @@ interface FullPublicSettings extends PublicSettings { emailEnabled: boolean; userEmailRequired: boolean; newPlexLogin: boolean; + openIdProviders: PublicOidcProvider[]; } export interface NotificationAgentConfig { @@ -311,6 +332,7 @@ export interface AllSettings { main: MainSettings; plex: PlexSettings; jellyfin: JellyfinSettings; + oidc: OidcSettings; tautulli: TautulliSettings; radarr: RadarrSettings[]; sonarr: SonarrSettings[]; @@ -345,6 +367,7 @@ class Settings { hideAvailable: false, localLogin: true, mediaServerLogin: true, + oidcLogin: false, newPlexLogin: true, discoverRegion: '', streamingRegion: '', @@ -373,6 +396,9 @@ class Settings { serverId: '', apiKey: '', }, + oidc: { + providers: [], + }, tautulli: {}, radarr: [], sonarr: [], @@ -550,6 +576,14 @@ class Settings { this.data.jellyfin = data; } + get oidc(): OidcSettings { + return this.data.oidc; + } + + set oidc(data: OidcSettings) { + this.data.oidc = data; + } + get tautulli(): TautulliSettings { return this.data.tautulli; } @@ -612,6 +646,13 @@ class Settings { userEmailRequired: this.data.notifications.agents.email.options.userEmailRequired, newPlexLogin: this.data.main.newPlexLogin, + openIdProviders: this.data.main.oidcLogin + ? this.data.oidc.providers.map((p) => ({ + slug: p.slug, + name: p.name, + logo: p.logo, + })) + : [], }; } diff --git a/server/routes/auth.ts b/server/routes/auth.ts index 4e470831a6..2ccb4b713d 100644 --- a/server/routes/auth.ts +++ b/server/routes/auth.ts @@ -4,7 +4,9 @@ import { ApiErrorCode } from '@server/constants/error'; import { MediaServerType, ServerType } from '@server/constants/server'; import { UserType } from '@server/constants/user'; import { getRepository } from '@server/datasource'; +import { LinkedAccount } from '@server/entity/LinkedAccount'; import { User } from '@server/entity/User'; +import type { IdTokenClaims } from '@server/interfaces/api/oidcInterfaces'; import { startJobs } from '@server/job/schedule'; import { Permission } from '@server/lib/permissions'; import { getSettings } from '@server/lib/settings'; @@ -12,8 +14,20 @@ import logger from '@server/logger'; import { isAuthenticated } from '@server/middleware/auth'; import { ApiError } from '@server/types/error'; import { getHostname } from '@server/utils/getHostname'; +import { + createIdTokenSchema, + fetchOpenIdTokenData, + getOpenIdConfiguration, + getOpenIdRedirectUrl, + getOpenIdUserInfo, + validateUserClaims, + type FullUserInfo, +} from '@server/utils/oidc'; +import { randomBytes } from 'crypto'; import * as EmailValidator from 'email-validator'; import { Router } from 'express'; +import gravatarUrl from 'gravatar-url'; +import { jwtDecode } from 'jwt-decode'; import net from 'net'; const authRoutes = Router(); @@ -689,6 +703,289 @@ authRoutes.post('/local', async (req, res, next) => { } }); +authRoutes.get('/oidc/login/:slug', async (req, res, next) => { + const settings = getSettings(); + const provider = settings.oidc.providers.find( + (p) => p.slug === req.params.slug + ); + + if (!settings.main.oidcLogin || !provider) { + return next({ + status: 403, + message: 'OpenID Connect sign-in is disabled.', + }); + } + + const state = randomBytes(32).toString('hex'); + + let redirectUrl; + try { + redirectUrl = await getOpenIdRedirectUrl(req, provider, state); + } catch (err) { + logger.info('Failed OIDC login attempt', { + cause: 'Failed to fetch OIDC redirect url', + ip: req.ip, + errorMessage: err.message, + }); + return next({ + status: 500, + message: 'Configuration error.', + }); + } + + res.cookie('oidc-state', state, { + maxAge: 60000, + httpOnly: true, + secure: req.protocol === 'https', + }); + + return res.redirect(redirectUrl); +}); + +authRoutes.get('/oidc/callback/:slug', async (req, res, next) => { + const settings = getSettings(); + const provider = settings.oidc.providers.find( + (p) => p.slug === req.params.slug + ); + + if (!settings.main.oidcLogin || !provider) { + return next({ + status: 403, + message: 'OpenID Connect sign-in is disabled', + }); + } + + const requiredClaims = (provider.requiredClaims ?? '') + .split(' ') + .filter((s) => !!s); + + const cookieState = req.cookies['oidc-state']; + const url = new URL(req.url, `${req.protocol}://${req.hostname}`); + const state = url.searchParams.get('state'); + + try { + // Check that the request belongs to the correct state + if (state && cookieState === state) { + res.clearCookie('oidc-state'); + } else { + logger.info('Failed OpenID Connect login attempt', { + cause: 'Invalid state', + ip: req.ip, + state: state, + cookieState: cookieState, + }); + return next({ + status: 400, + message: 'Authorization failed', + }); + } + + // Check that a code has been issued + const code = url.searchParams.get('code'); + if (!code) { + logger.info('Failed OpenID Connect login attempt', { + cause: 'Invalid code', + ip: req.ip, + code: code, + }); + return next({ + status: 400, + message: 'Authorization failed', + }); + } + + const wellKnownInfo = await getOpenIdConfiguration(provider.issuerUrl); + + // Fetch the token data + const body = await fetchOpenIdTokenData(req, provider, wellKnownInfo, code); + + // Validate that the token response is valid and not manipulated + if ('error' in body) { + logger.info('Failed OIDC login attempt', { + cause: 'Invalid token response', + ip: req.ip, + body: body, + }); + return next({ + status: 400, + message: 'Authorization failed', + }); + } + + // Extract the ID token and access token + const { id_token: idToken, access_token: accessToken } = body; + + // Attempt to decode ID token jwt + let decoded: IdTokenClaims; + try { + decoded = jwtDecode(idToken); + } catch (err) { + logger.info('Failed OIDC login attempt', { + cause: 'Invalid jwt', + ip: req.ip, + idToken: idToken, + err, + }); + return next({ + status: 400, + message: 'Authorization failed', + }); + } + + // Merge claims from JWT with data from userinfo endpoint + const userInfo = await getOpenIdUserInfo(wellKnownInfo, accessToken); + const fullUserInfo: FullUserInfo = { ...decoded, ...userInfo }; + + // Validate ID token jwt and user info + try { + const idTokenSchema = createIdTokenSchema({ + oidcClientId: provider.clientId, + oidcDomain: provider.issuerUrl, + requiredClaims, + }); + await idTokenSchema.validate(fullUserInfo); + } catch (err) { + logger.info('Failed OIDC login attempt', { + cause: 'Invalid jwt or missing claims', + ip: req.ip, + idToken: idToken, + errorMessage: err.message, + }); + return next({ + status: 403, + message: 'Authorization failed', + }); + } + + // Validate that user meets required claims + try { + validateUserClaims(fullUserInfo, requiredClaims); + } catch (error) { + logger.info('Failed OIDC login attempt', { + cause: 'Failed to validate required claims', + error, + ip: req.ip, + requiredClaims: provider.requiredClaims, + }); + return next({ + status: 403, + message: 'Insufficient permissions', + }); + } + + // Map identifier to linked account + const userRepository = getRepository(User); + const linkedAccountsRepository = getRepository(LinkedAccount); + + const linkedAccount = await linkedAccountsRepository.findOne({ + relations: { + user: true, + }, + where: { + provider: provider.slug, + sub: fullUserInfo.sub, + }, + }); + let user = linkedAccount?.user; + + // If there is already a user logged in, and no linked account, link the account. + if (req.user != null && linkedAccount == null) { + const linkedAccount = new LinkedAccount({ + user: req.user, + provider: provider.slug, + sub: fullUserInfo.sub, + username: fullUserInfo.preferred_username ?? req.user.displayName, + }); + + await linkedAccountsRepository.save(linkedAccount); + return res + .status(200) + .json({ status: 'ok', to: '/profile/settings/linked-accounts' }); + } + + // Create user if one doesn't already exist + if (!user && fullUserInfo.email != null && provider.newUserLogin) { + logger.info(`Creating user for ${fullUserInfo.email}`, { + ip: req.ip, + email: fullUserInfo.email, + }); + + const avatar = + fullUserInfo.picture ?? + gravatarUrl(fullUserInfo.email, { default: 'mm', size: 200 }); + user = new User({ + avatar: avatar, + username: fullUserInfo.preferred_username, + email: fullUserInfo.email, + permissions: settings.main.defaultPermissions, + plexToken: '', + userType: UserType.LOCAL, + }); + await userRepository.save(user); + + const linkedAccount = new LinkedAccount({ + user, + provider: provider.slug, + sub: fullUserInfo.sub, + username: fullUserInfo.preferred_username ?? fullUserInfo.email, + }); + await linkedAccountsRepository.save(linkedAccount); + + user.linkedAccounts = [linkedAccount]; + await userRepository.save(user); + } + + if (!user) { + logger.debug('Failed OIDC sign-up attempt', { + cause: provider.newUserLogin + ? 'User did not have an account, and was missing an associated email address.' + : 'User did not have an account, and new user login was disabled.', + }); + return next({ + status: 400, + message: provider.newUserLogin + ? 'Unable to create new user account (missing email address)' + : 'Unable to create new user account (new user login is disabled)', + }); + } + + // Set logged in session and return + if (req.session) { + req.session.userId = user.id; + } + + // Success! + return res.status(200).json({ status: 'ok', to: '/' }); + } catch (error) { + logger.error('Failed OIDC login attempt', { + cause: 'Unknown error', + ip: req.ip, + errorMessage: error.message, + }); + return next({ + status: 500, + message: 'An unknown error occurred', + }); + } +}); + +// authRoutes.get('/oidc-logout', async (req, res, next) => { +// const settings = getSettings(); + +// if (!settings.main.oidcLogin || !settings.main.oidc.automaticLogin) { +// return next({ +// status: 403, +// message: 'OpenID Connect sign-in is disabled.', +// }); +// } + +// const oidcEndpoints = await getOIDCWellknownConfiguration( +// settings.main.oidc.providerUrl +// ); + +// return res.redirect(oidcEndpoints.end_session_endpoint); +// }); + authRoutes.post('/logout', (req, res, next) => { req.session?.destroy((err) => { if (err) { diff --git a/server/routes/user/usersettings.ts b/server/routes/user/usersettings.ts index ab6bd73707..e6e3d98a94 100644 --- a/server/routes/user/usersettings.ts +++ b/server/routes/user/usersettings.ts @@ -4,10 +4,13 @@ import { ApiErrorCode } from '@server/constants/error'; import { MediaServerType } from '@server/constants/server'; import { UserType } from '@server/constants/user'; import { getRepository } from '@server/datasource'; +import { LinkedAccount } from '@server/entity/LinkedAccount'; import { User } from '@server/entity/User'; import { UserSettings } from '@server/entity/UserSettings'; import type { UserSettingsGeneralResponse, + UserSettingsLinkedAccount, + UserSettingsLinkedAccountResponse, UserSettingsNotificationsResponse, } from '@server/interfaces/api/userSettingsInterfaces'; import { Permission } from '@server/lib/permissions'; @@ -18,6 +21,7 @@ import { ApiError } from '@server/types/error'; import { getHostname } from '@server/utils/getHostname'; import { Router } from 'express'; import net from 'net'; +import { In, type FindOptionsWhere } from 'typeorm'; import { canMakePermissionsChange } from '.'; const isOwnProfile = (): Middleware => { @@ -542,6 +546,73 @@ userSettingsRoutes.delete<{ id: string }>( } ); +userSettingsRoutes.get<{ id: string }, UserSettingsLinkedAccountResponse>( + '/linked-accounts', + isOwnProfileOrAdmin(), + async (req, res) => { + const settings = getSettings(); + if (!settings.main.oidcLogin) { + // don't show any linked accounts if OIDC login is disabled + return res.status(200).json([]); + } + + const activeProviders = settings.oidc.providers.map((p) => p.slug); + const linkedAccountsRepository = getRepository(LinkedAccount); + + const linkedAccounts = await linkedAccountsRepository.find({ + relations: { + user: true, + }, + where: { + provider: In(activeProviders), + user: { + id: Number(req.params.id), + }, + }, + }); + + const linkedAccountInfo = linkedAccounts.map((acc) => { + // eslint-disable-next-line @typescript-eslint/no-non-null-assertion + const provider = settings.oidc.providers.find( + (p) => p.slug === acc.provider + )!; + + return { + id: acc.id, + username: acc.username, + provider: { + slug: provider.slug, + name: provider.name, + logo: provider.logo, + }, + } satisfies UserSettingsLinkedAccount; + }); + + return res.status(200).json(linkedAccountInfo); + } +); + +userSettingsRoutes.delete<{ id: string; acctId: string }>( + '/linked-accounts/:acctId', + isOwnProfileOrAdmin(), + async (req, res) => { + const linkedAccountsRepository = getRepository(LinkedAccount); + const condition: FindOptionsWhere = { + id: Number(req.params.acctId), + user: { + id: Number(req.params.id), + }, + }; + + if (await linkedAccountsRepository.exist({ where: condition })) { + await linkedAccountsRepository.delete(condition); + return res.status(204).send(); + } else { + return res.status(404).send(); + } + } +); + userSettingsRoutes.get<{ id: string }, UserSettingsNotificationsResponse>( '/notifications', isOwnProfileOrAdmin(), diff --git a/server/utils/oidc.ts b/server/utils/oidc.ts new file mode 100644 index 0000000000..792d3238a3 --- /dev/null +++ b/server/utils/oidc.ts @@ -0,0 +1,202 @@ +import type { + IdTokenClaims, + OidcProviderMetadata, + OidcStandardClaims, + OidcTokenResponse, +} from '@server/interfaces/api/oidcInterfaces'; +import type { OidcProvider } from '@server/lib/settings'; +import type { Request } from 'express'; +import * as yup from 'yup'; + +/** Fetch the issuer configuration from the OpenID Connect Discovery endpoint */ +export async function getOpenIdConfiguration(domain: string) { + // remove trailing slash from url if it exists and add /.well-known/openid-configuration path + const wellKnownUrl = new URL( + domain.replace(/\/$/, '') + '/.well-known/openid-configuration' + ).toString(); + + const wellKnownInfo: OidcProviderMetadata = await fetch(wellKnownUrl, { + headers: { + 'Content-Type': 'application/json', + }, + }).then((r) => r.json()); + + return wellKnownInfo; +} + +/** Generate authentication request url */ +export async function getOpenIdRedirectUrl( + req: Request, + provider: OidcProvider, + state: string +) { + const wellKnownInfo = await getOpenIdConfiguration(provider.issuerUrl); + const url = new URL(wellKnownInfo.authorization_endpoint); + url.searchParams.set('response_type', 'code'); + url.searchParams.set('client_id', provider.clientId); + + const callbackUrl = new URL( + `/login/oidc/callback/${provider.slug}`, + `${req.protocol}://${req.headers.host}` + ).toString(); + url.searchParams.set('redirect_uri', callbackUrl); + url.searchParams.set('scope', 'openid profile email'); + url.searchParams.set('state', state); + return url.toString(); +} + +/** Exchange authorization code for token data */ +export async function fetchOpenIdTokenData( + req: Request, + provider: OidcProvider, + wellKnownInfo: OidcProviderMetadata, + code: string +): Promise { + const callbackUrl = new URL( + `/login/oidc/callback/${provider.slug}`, + `${req.protocol}://${req.headers.host}` + ); + + const formData = new URLSearchParams(); + formData.append('client_secret', provider.clientSecret); + formData.append('grant_type', 'authorization_code'); + formData.append('redirect_uri', callbackUrl.toString()); + formData.append('client_id', provider.clientId); + formData.append('code', code); + + return await fetch(wellKnownInfo.token_endpoint, { + method: 'POST', + body: formData, + }).then((r) => r.json()); +} + +export async function getOpenIdUserInfo( + wellKnownInfo: OidcProviderMetadata, + authToken: string +) { + return fetch(wellKnownInfo.userinfo_endpoint, { + headers: { + Authorization: `Bearer ${authToken}`, + Accept: 'application/json', + }, + }).then((r) => r.json()); +} + +class OidcAuthorizationError extends Error {} + +class OidcMissingKeyError extends OidcAuthorizationError { + constructor(public userInfo: FullUserInfo, public key: string) { + super(`Key ${key} was missing on OIDC userinfo but was expected.`); + } +} + +type PrimitiveString = 'string' | 'boolean'; +type TypeFromName = T extends 'string' + ? string + : T extends 'boolean' + ? boolean + : unknown; + +export function tryGetUserInfoKey( + userInfo: FullUserInfo, + key: string, + expectedType: T +): TypeFromName { + if (!Object.hasOwn(userInfo, key) || typeof userInfo[key] !== expectedType) { + throw new OidcMissingKeyError(userInfo, key); + } + + return userInfo[key] as TypeFromName; +} + +export function validateUserClaims( + userInfo: FullUserInfo, + requiredClaims: string[] +) { + requiredClaims.some((claim) => { + const value = tryGetUserInfoKey(userInfo, claim, 'boolean'); + if (!value) + throw new OidcAuthorizationError('User was missing a required claim.'); + }); +} + +/** Generates a schema to validate ID token JWT and userinfo claims */ +export const createIdTokenSchema = ({ + oidcDomain, + oidcClientId, + requiredClaims, +}: { + oidcDomain: string; + oidcClientId: string; + requiredClaims: string[]; +}) => { + return yup.object().shape({ + iss: yup + .string() + .oneOf( + [oidcDomain, `${oidcDomain}/`], + `The token iss value doesn't match the oidc_DOMAIN (${oidcDomain})` + ) + .required("The token didn't come with an iss value."), + aud: yup.lazy((val) => { + // single audience + if (typeof val === 'string') + return yup + .string() + .oneOf( + [oidcClientId], + `The token aud value doesn't match the oidc_CLIENT_ID (${oidcClientId})` + ) + .required("The token didn't come with an aud value."); + // several audiences + if (typeof val === 'object' && Array.isArray(val)) + return yup + .array() + .of(yup.string()) + .test( + 'contains-client-id', + `The token aud value doesn't contain the oidc_CLIENT_ID (${oidcClientId})`, + (value) => !!(value && value.includes(oidcClientId)) + ); + // invalid type + return yup + .mixed() + .typeError('The token aud value is not a string or array.'); + }), + exp: yup + .number() + .required() + .test( + 'is_before_date', + 'Token exp value is before current time.', + (value) => { + if (!value) return false; + if (value < Math.ceil(Date.now() / 1000)) return false; + return true; + } + ), + iat: yup + .number() + .required() + .test( + 'is_before_one_day', + 'Token was issued before one day ago and is now invalid.', + (value) => { + if (!value) return false; + const date = new Date(); + date.setDate(date.getDate() - 1); + if (value < Math.ceil(Number(date) / 1000)) return false; + return true; + } + ), + // TODO: only require this for new user login + email: yup.string().required(), + // ensure all required claims are present and are booleans + ...requiredClaims.reduce( + (a, v) => ({ ...a, [v]: yup.boolean().required() }), + {} + ), + }); +}; + +export type FullUserInfo = IdTokenClaims & OidcStandardClaims; diff --git a/src/components/Login/ErrorCallout.tsx b/src/components/Login/ErrorCallout.tsx new file mode 100644 index 0000000000..b46c4fb1da --- /dev/null +++ b/src/components/Login/ErrorCallout.tsx @@ -0,0 +1,26 @@ +import Alert from '@app/components/Common/Alert'; +import { Transition } from '@headlessui/react'; +import React from 'react'; + +interface LoginErrorProps { + error: string; +} + +const LoginError: React.FC = ({ error }) => { + return ( + + {error} + + ); +}; + +export default LoginError; diff --git a/src/components/UserProfile/UserSettings/UserLinkedAccountsSettings/index.tsx b/src/components/UserProfile/UserSettings/UserLinkedAccountsSettings/index.tsx index c83a15790c..3ec0fafefd 100644 --- a/src/components/UserProfile/UserSettings/UserLinkedAccountsSettings/index.tsx +++ b/src/components/UserProfile/UserSettings/UserLinkedAccountsSettings/index.tsx @@ -12,6 +12,10 @@ import defineMessages from '@app/utils/defineMessages'; import PlexOAuth from '@app/utils/plex'; import { TrashIcon } from '@heroicons/react/24/solid'; import { MediaServerType } from '@server/constants/server'; +import type { + UserSettingsLinkedAccount, + UserSettingsLinkedAccountResponse, +} from '@server/interfaces/api/userSettingsInterfaces'; import { useRouter } from 'next/router'; import { useMemo, useState } from 'react'; import { useIntl } from 'react-intl'; @@ -41,12 +45,20 @@ enum LinkedAccountType { Plex = 'Plex', Jellyfin = 'Jellyfin', Emby = 'Emby', + OpenIdConnect = 'oidc', } -type LinkedAccount = { - type: LinkedAccountType; - username: string; -}; +type LinkedAccount = + | { + type: + | LinkedAccountType.Plex + | LinkedAccountType.Emby + | LinkedAccountType.Jellyfin; + username: string; + } + | ({ + type: LinkedAccountType.OpenIdConnect; + } & UserSettingsLinkedAccount); const UserLinkedAccountsSettings = () => { const intl = useIntl(); @@ -61,13 +73,21 @@ const UserLinkedAccountsSettings = () => { const { data: passwordInfo } = useSWR<{ hasPassword: boolean }>( user ? `/api/v1/user/${user?.id}/settings/password` : null ); + const { data: linkedOidcAccounts, mutate: revalidateLinkedAccounts } = + useSWR( + user ? `/api/v1/user/${user?.id}/settings/linked-accounts` : null + ); const [showJellyfinModal, setShowJellyfinModal] = useState(false); const [error, setError] = useState(null); const applicationName = settings.currentSettings.applicationTitle; const accounts: LinkedAccount[] = useMemo(() => { - const accounts: LinkedAccount[] = []; + const accounts: LinkedAccount[] = + linkedOidcAccounts?.map((a) => ({ + type: LinkedAccountType.OpenIdConnect, + ...a, + })) ?? []; if (!user) return accounts; if (user.userType === UserType.PLEX && user.plexUsername) accounts.push({ @@ -85,7 +105,7 @@ const UserLinkedAccountsSettings = () => { username: user.jellyfinUsername, }); return accounts; - }, [user]); + }, [user, linkedOidcAccounts]); const linkPlexAccount = async () => { setError(null); @@ -139,6 +159,17 @@ const UserLinkedAccountsSettings = () => { settings.currentSettings.mediaServerType !== MediaServerType.EMBY || accounts.some((a) => a.type === LinkedAccountType.Emby), }, + ...settings.currentSettings.openIdProviders.map((p) => ({ + name: p.name, + action: () => { + window.location.href = `/api/v1/auth/oidc/login/${p.slug}`; + }, + hide: accounts.some( + (a) => + a.type === LinkedAccountType.OpenIdConnect && + a.provider.slug === p.slug + ), + })), ].filter((l) => !l.hide); const deleteRequest = async (account: string) => { @@ -153,6 +184,7 @@ const UserLinkedAccountsSettings = () => { } await revalidateUser(); + await revalidateLinkedAccounts(); }; if ( @@ -224,24 +256,37 @@ const UserLinkedAccountsSettings = () => { ) : acct.type === LinkedAccountType.Emby ? ( - ) : ( + ) : acct.type === LinkedAccountType.Jellyfin ? ( - )} + ) : acct.type === LinkedAccountType.OpenIdConnect ? ( + // eslint-disable-next-line @next/next/no-img-element + {acct.provider.name} + ) : null}
- {acct.type} + {acct.type === LinkedAccountType.OpenIdConnect + ? acct.provider.name + : acct.type}
{acct.username}
- {enableMediaServerUnlink && ( + {(acct.type === LinkedAccountType.OpenIdConnect || + enableMediaServerUnlink) && ( { deleteRequest( - acct.type === LinkedAccountType.Plex ? 'plex' : 'jellyfin' + acct.type === LinkedAccountType.OpenIdConnect + ? String(acct.id) + : acct.type === LinkedAccountType.Plex + ? 'plex' + : 'jellyfin' ); }} confirmText={intl.formatMessage(globalMessages.areyousure)} diff --git a/src/context/SettingsContext.tsx b/src/context/SettingsContext.tsx index a1b69ae222..f78a82a58d 100644 --- a/src/context/SettingsContext.tsx +++ b/src/context/SettingsContext.tsx @@ -8,7 +8,7 @@ export interface SettingsContextProps { children?: React.ReactNode; } -const defaultSettings = { +const defaultSettings: PublicSettingsResponse = { initialized: false, applicationTitle: 'Jellyseerr', applicationUrl: '', @@ -29,6 +29,7 @@ const defaultSettings = { locale: 'en', emailEnabled: false, newPlexLogin: true, + openIdProviders: [], }; export const SettingsContext = React.createContext({ diff --git a/src/pages/_app.tsx b/src/pages/_app.tsx index 1b29d41e80..07c0787278 100644 --- a/src/pages/_app.tsx +++ b/src/pages/_app.tsx @@ -225,6 +225,7 @@ CoreApp.getInitialProps = async (initialProps) => { series4kEnabled: false, localLogin: true, mediaServerLogin: true, + openIdProviders: [], discoverRegion: '', streamingRegion: '', originalLanguage: '', @@ -275,7 +276,10 @@ CoreApp.getInitialProps = async (initialProps) => { if (!res.ok) throw new Error(); user = await res.json(); - if (router.pathname.match(/(setup|login)/)) { + if ( + router.pathname.match(/(setup|login)/) && + !router.pathname.includes('oidc') + ) { ctx.res.writeHead(307, { Location: '/', }); diff --git a/src/pages/login/oidc/callback/[slug].tsx b/src/pages/login/oidc/callback/[slug].tsx new file mode 100644 index 0000000000..cab3cd3b3f --- /dev/null +++ b/src/pages/login/oidc/callback/[slug].tsx @@ -0,0 +1,74 @@ +import LoadingSpinner from '@app/components/Common/LoadingSpinner'; +import LoginError from '@app/components/Login/ErrorCallout'; +import defineMessages from '@app/utils/defineMessages'; +import { processCallback } from '@app/utils/oidc'; +import Link from 'next/link'; +import { useRouter } from 'next/router'; +import { useEffect, useState } from 'react'; +import { useIntl } from 'react-intl'; + +const messages = defineMessages('components.Login', { + loginerror: 'Something went wrong while trying to sign in.', + backtologin: 'Back to Login', +}); + +const OidcCallback = () => { + const router = useRouter(); + const intl = useIntl(); + + const { slug } = router.query as { slug: string }; + + const login = async () => { + const params = new URLSearchParams(window.location.search); + const result = await processCallback(params, slug); + + // is popup window + if (window.opener && window.opener !== window) { + // send result to the opening window + window.opener.postMessage( + result, + `${window.location.protocol}//${window.location.host}` + ); + // close the popup + window.close(); + } else { + if (result.type === 'success') { + // redirect to homepage + router.push(result.message?.to ?? '/'); + } else { + // display login error + setError(result.message); + } + } + }; + + const [error, setError] = useState(null); + + useEffect(() => { + login(); + // eslint-disable-next-line react-hooks/exhaustive-deps + }, []); + + return ( +
+ {error != null ? ( +
+

+ {intl.formatMessage(messages.loginerror)} +

+ + + ←{' '} + + {intl.formatMessage(messages.backtologin)} + + +
+ ) : ( + + )} +
+ ); +}; + +export default OidcCallback; diff --git a/src/utils/oidc.ts b/src/utils/oidc.ts new file mode 100644 index 0000000000..2b574aa8be --- /dev/null +++ b/src/utils/oidc.ts @@ -0,0 +1,28 @@ +export async function processCallback( + params: URLSearchParams, + provider: string +) { + const url = new URL( + `/api/v1/auth/oidc/callback/${encodeURIComponent(provider)}`, + window.location.origin + ); + url.search = params.toString(); + + try { + const result = await fetch(url); + const message = await result.json(); + + if (result.status !== 200) { + return { type: 'error', message: message.message }; + } + return { + type: 'success', + message, + }; + } catch (e) { + return { + type: 'error', + message: e.message, + }; + } +} From 75f4e6be0a6ac34219d949507d90865f161297b2 Mon Sep 17 00:00:00 2001 From: Michael Thomas Date: Sun, 12 Jan 2025 19:20:51 -0500 Subject: [PATCH 02/96] feat: add OpenID Connect options to login screen --- src/components/Login/index.tsx | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/src/components/Login/index.tsx b/src/components/Login/index.tsx index 0b51e86f11..8de6882296 100644 --- a/src/components/Login/index.tsx +++ b/src/components/Login/index.tsx @@ -161,6 +161,21 @@ const Login = () => { )) )), + ...settings.currentSettings.openIdProviders.map((provider) => ( + + )), ].filter((o): o is JSX.Element => !!o); return ( From dc875b0db059793d7387f6afc5858cf59110ede2 Mon Sep 17 00:00:00 2001 From: Michael Thomas Date: Tue, 21 Jan 2025 08:37:41 -0500 Subject: [PATCH 03/96] feat: add openid connect settings interface --- jellyseerr-api.yml | 93 +++++ public/images/openid.svg | 57 +++ server/routes/settings/index.ts | 39 ++ .../Common/LabeledCheckbox/index.tsx | 13 +- .../Settings/EditOidcModal/index.tsx | 373 ++++++++++++++++++ .../Settings/SettingsOidc/index.tsx | 167 ++++++++ .../Settings/SettingsUsers/index.tsx | 59 ++- .../UserLinkedAccountsSettings/index.tsx | 2 +- src/i18n/locale/en.json | 29 +- 9 files changed, 818 insertions(+), 14 deletions(-) create mode 100644 public/images/openid.svg create mode 100644 src/components/Settings/EditOidcModal/index.tsx create mode 100644 src/components/Settings/SettingsOidc/index.tsx diff --git a/jellyseerr-api.yml b/jellyseerr-api.yml index ece894fd7a..ff539edba8 100644 --- a/jellyseerr-api.yml +++ b/jellyseerr-api.yml @@ -185,6 +185,41 @@ components: enableSpecialEpisodes: type: boolean example: false + OidcProvider: + type: object + properties: + slug: + type: string + readOnly: true + name: + type: string + issuerUrl: + type: string + clientId: + type: string + clientSecret: + type: string + logo: + type: string + requiredClaims: + type: string + scopes: + type: string + newUserLogin: + type: boolean + required: + - slug + - name + - issuerUrl + - clientId + - clientSecret + OidcSettings: + type: object + properties: + providers: + type: array + items: + $ref: '#/components/schemas/OidcProvider' NetworkSettings: type: object properties: @@ -2045,6 +2080,64 @@ paths: application/json: schema: $ref: '#/components/schemas/MainSettings' + /settings/oidc: + get: + summary: Get OpenID Connect settings + description: Retrieves all OpenID Connect settings in a JSON object. + tags: + - settings + responses: + '200': + description: OK + content: + application/json: + schema: + $ref: '#/components/schemas/OidcSettings' + /settings/oidc/{provider}: + put: + summary: Update OpenID Connect provider + description: Updates an existing OpenID Connect provider with the provided values. + tags: + - settings + parameters: + - in: path + name: provider + required: true + schema: + type: string + description: Provider slug + requestBody: + required: true + content: + application/json: + schema: + $ref: '#/components/schemas/OidcProvider' + responses: + '200': + description: 'Radarr instance updated' + content: + application/json: + schema: + $ref: '#/components/schemas/RadarrSettings' + delete: + summary: Delete OpenID Connect provider + description: Deletes an existing OpenID Connect provider based on the provider slug parameter. + tags: + - settings + parameters: + - in: path + name: provider + required: true + schema: + type: string + description: Provider slug + responses: + '200': + description: 'OpenID Connect provider deleted' + content: + application/json: + schema: + $ref: '#/components/schemas/OidcSettings' /settings/network: get: summary: Get network settings diff --git a/public/images/openid.svg b/public/images/openid.svg new file mode 100644 index 0000000000..644f473ca6 --- /dev/null +++ b/public/images/openid.svg @@ -0,0 +1,57 @@ + + + + diff --git a/server/routes/settings/index.ts b/server/routes/settings/index.ts index d74d328f35..5c366baba8 100644 --- a/server/routes/settings/index.ts +++ b/server/routes/settings/index.ts @@ -105,6 +105,45 @@ settingsRoutes.post('/main/regenerate', async (req, res, next) => { return res.status(200).json(filteredMainSettings(req.user, main)); }); +settingsRoutes.get('/oidc', async (req, res) => { + const settings = getSettings(); + + return res.status(200).json(settings.oidc); +}); + +settingsRoutes.put('/oidc/:slug', async (req, res) => { + const settings = getSettings(); + let provider = settings.oidc.providers.findIndex( + (p) => p.slug === req.params.slug + ); + + if (provider !== -1) { + Object.assign(settings.oidc.providers[provider], req.body); + } else { + settings.oidc.providers.push({ slug: req.params.slug, ...req.body }); + provider = settings.oidc.providers.length - 1; + } + + await settings.save(); + + return res.status(200).json(settings.oidc.providers[provider]); +}); + +settingsRoutes.delete('/oidc/:slug', async (req, res) => { + const settings = getSettings(); + const provider = settings.oidc.providers.findIndex( + (p) => p.slug === req.params.slug + ); + + if (provider === -1) + return res.status(404).json({ message: 'Provider not found' }); + + settings.oidc.providers.splice(provider, 1); + await settings.save(); + + return res.status(200).json(settings.oidc); +}); + settingsRoutes.get('/plex', (_req, res) => { const settings = getSettings(); diff --git a/src/components/Common/LabeledCheckbox/index.tsx b/src/components/Common/LabeledCheckbox/index.tsx index ff7e1f5604..c2d74244ab 100644 --- a/src/components/Common/LabeledCheckbox/index.tsx +++ b/src/components/Common/LabeledCheckbox/index.tsx @@ -1,31 +1,34 @@ import { Field } from 'formik'; +import { useId } from 'react'; import { twMerge } from 'tailwind-merge'; interface LabeledCheckboxProps { - id: string; + name: string; className?: string; label: string; description: string; - onChange: () => void; + onChange?: () => void; children?: React.ReactNode; } const LabeledCheckbox: React.FC = ({ - id, + name, className, label, description, onChange, children, }) => { + const id = useId(); + return ( <>
- +
-
+ {values.oidcLogin && ( + setShowOidcDialog(false)} + /> + )} +
+
+ +
+ + +
+
+
+ +
+ + +
+
+
+ +
+ + +
+
-
- -
- - -
-
+
+ +
+ ) => + setFieldValue('supportVariables', e.target.checked) + } + /> +
+
+ {values.supportVariables && ( +
+ + + +
+ )}
@@ -312,7 +376,7 @@ const NotificationsWebhook = () => { {intl.formatMessage(messages.resetPayload)} diff --git a/src/i18n/locale/en.json b/src/i18n/locale/en.json index 63a207c177..7153d5a36a 100644 --- a/src/i18n/locale/en.json +++ b/src/i18n/locale/en.json @@ -683,6 +683,8 @@ "components.Settings.Notifications.NotificationsWebhook.customJson": "JSON Payload", "components.Settings.Notifications.NotificationsWebhook.resetPayload": "Reset to Default", "components.Settings.Notifications.NotificationsWebhook.resetPayloadSuccess": "JSON payload reset successfully!", + "components.Settings.Notifications.NotificationsWebhook.supportVariables": "Support URL Variables", + "components.Settings.Notifications.NotificationsWebhook.supportVariablesTip": "Available variables are documented in the webhook template variables section", "components.Settings.Notifications.NotificationsWebhook.templatevariablehelp": "Template Variable Help", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestFailed": "Webhook test notification failed to send.", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSending": "Sending webhook test notification…", @@ -691,6 +693,7 @@ "components.Settings.Notifications.NotificationsWebhook.validationTypes": "You must select at least one notification type", "components.Settings.Notifications.NotificationsWebhook.validationWebhookUrl": "You must provide a valid URL", "components.Settings.Notifications.NotificationsWebhook.webhookUrl": "Webhook URL", + "components.Settings.Notifications.NotificationsWebhook.webhookUrlTip": "Test Notification URL is set to {testUrl} instead of the actual webhook URL.", "components.Settings.Notifications.NotificationsWebhook.webhooksettingsfailed": "Webhook notification settings failed to save.", "components.Settings.Notifications.NotificationsWebhook.webhooksettingssaved": "Webhook notification settings saved successfully!", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Enable Agent", From d5bf17574f4128c4cd3393f31ad42789aa0adf5c Mon Sep 17 00:00:00 2001 From: Gauthier Date: Mon, 15 Sep 2025 10:23:59 +0200 Subject: [PATCH 12/96] fix(prettier): include sw.js file in .prettierignore (#1885) --- .prettierignore | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/.prettierignore b/.prettierignore index 736c402cb1..969f1bc6f9 100644 --- a/.prettierignore +++ b/.prettierignore @@ -9,7 +9,11 @@ cypress/config/settings.cypress.json # assets src/assets/ public/ +!public/sw.js docs/ +!/public/ +/public/* +!/public/sw.js # helm charts **/charts From e9f2f4490fe535e3117804048eef50d0d6d33071 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Tue, 16 Sep 2025 15:42:41 +0200 Subject: [PATCH 13/96] fix(api): catch error when watchlist item doesn't exist anymore (#1907) --- server/api/plextv.ts | 27 +++++++++++++++++++++------ 1 file changed, 21 insertions(+), 6 deletions(-) diff --git a/server/api/plextv.ts b/server/api/plextv.ts index ef2cee4286..410df72a20 100644 --- a/server/api/plextv.ts +++ b/server/api/plextv.ts @@ -312,12 +312,25 @@ class PlexTvAPI extends ExternalAPI { const watchlistDetails = await Promise.all( (cachedWatchlist?.response.MediaContainer.Metadata ?? []).map( async (watchlistItem) => { - const detailedResponse = await this.getRolling( - `/library/metadata/${watchlistItem.ratingKey}`, - { - baseURL: 'https://discover.provider.plex.tv', + let detailedResponse: MetadataResponse; + try { + detailedResponse = await this.getRolling( + `/library/metadata/${watchlistItem.ratingKey}`, + { + baseURL: 'https://discover.provider.plex.tv', + } + ); + } catch (e) { + if (e.response?.status === 404) { + logger.warn( + `Item with ratingKey ${watchlistItem.ratingKey} not found, it may have been removed from the server.`, + { label: 'Plex.TV Metadata API' } + ); + return null; + } else { + throw e; } - ); + } const metadata = detailedResponse.MediaContainer.Metadata[0]; @@ -343,7 +356,9 @@ class PlexTvAPI extends ExternalAPI { ) ); - const filteredList = watchlistDetails.filter((detail) => detail.tmdbId); + const filteredList = watchlistDetails.filter( + (detail) => detail?.tmdbId + ) as PlexWatchlistItem[]; return { offset, From cd479d0d1787bd8c289e111844ba3f85cb4ec23a Mon Sep 17 00:00:00 2001 From: 0xsysr3ll <31414959+0xSysR3ll@users.noreply.github.com> Date: Tue, 16 Sep 2025 21:32:39 +0200 Subject: [PATCH 14/96] feat(api): add excludeKeywords parameter to discovery queries (#1908) Signed-off-by: 0xsysr3ll <0xsysr3ll@pm.me> --- jellyseerr-api.yml | 12 ++++++++++++ server/api/themoviedb/index.ts | 6 ++++++ server/routes/discover.ts | 5 +++++ src/components/Discover/FilterSlideover/index.tsx | 14 ++++++++++++++ src/components/Discover/constants.ts | 5 +++++ src/i18n/locale/en.json | 1 + 6 files changed, 43 insertions(+) diff --git a/jellyseerr-api.yml b/jellyseerr-api.yml index 2535059ac4..69484e24a2 100644 --- a/jellyseerr-api.yml +++ b/jellyseerr-api.yml @@ -5198,6 +5198,12 @@ paths: schema: type: string example: 1,2 + - in: query + name: excludeKeywords + schema: + type: string + example: 3,4 + description: Comma-separated list of keyword IDs to exclude from results - in: query name: sortBy schema: @@ -5518,6 +5524,12 @@ paths: schema: type: string example: 1,2 + - in: query + name: excludeKeywords + schema: + type: string + example: 3,4 + description: Comma-separated list of keyword IDs to exclude from results - in: query name: sortBy schema: diff --git a/server/api/themoviedb/index.ts b/server/api/themoviedb/index.ts index 9fc19c729f..a01f356c8a 100644 --- a/server/api/themoviedb/index.ts +++ b/server/api/themoviedb/index.ts @@ -86,6 +86,7 @@ interface DiscoverMovieOptions { genre?: string; studio?: string; keywords?: string; + excludeKeywords?: string; sortBy?: SortOptions; watchRegion?: string; watchProviders?: string; @@ -111,6 +112,7 @@ interface DiscoverTvOptions { genre?: string; network?: number; keywords?: string; + excludeKeywords?: string; sortBy?: SortOptions; watchRegion?: string; watchProviders?: string; @@ -495,6 +497,7 @@ class TheMovieDb extends ExternalAPI implements TvShowProvider { genre, studio, keywords, + excludeKeywords, withRuntimeGte, withRuntimeLte, voteAverageGte, @@ -545,6 +548,7 @@ class TheMovieDb extends ExternalAPI implements TvShowProvider { with_genres: genre, with_companies: studio, with_keywords: keywords, + without_keywords: excludeKeywords, 'with_runtime.gte': withRuntimeGte, 'with_runtime.lte': withRuntimeLte, 'vote_average.gte': voteAverageGte, @@ -577,6 +581,7 @@ class TheMovieDb extends ExternalAPI implements TvShowProvider { genre, network, keywords, + excludeKeywords, withRuntimeGte, withRuntimeLte, voteAverageGte, @@ -628,6 +633,7 @@ class TheMovieDb extends ExternalAPI implements TvShowProvider { with_genres: genre, with_networks: network, with_keywords: keywords, + without_keywords: excludeKeywords, 'with_runtime.gte': withRuntimeGte, 'with_runtime.lte': withRuntimeLte, 'vote_average.gte': voteAverageGte, diff --git a/server/routes/discover.ts b/server/routes/discover.ts index 4fdd116786..c6dab52a6a 100644 --- a/server/routes/discover.ts +++ b/server/routes/discover.ts @@ -61,6 +61,7 @@ const QueryFilterOptions = z.object({ studio: z.coerce.string().optional(), genre: z.coerce.string().optional(), keywords: z.coerce.string().optional(), + excludeKeywords: z.coerce.string().optional(), language: z.coerce.string().optional(), withRuntimeGte: z.coerce.string().optional(), withRuntimeLte: z.coerce.string().optional(), @@ -90,6 +91,7 @@ discoverRoutes.get('/movies', async (req, res, next) => { try { const query = ApiQuerySchema.parse(req.query); const keywords = query.keywords; + const excludeKeywords = query.excludeKeywords; const data = await tmdb.getDiscoverMovies({ page: Number(query.page), @@ -105,6 +107,7 @@ discoverRoutes.get('/movies', async (req, res, next) => { ? new Date(query.primaryReleaseDateGte).toISOString().split('T')[0] : undefined, keywords, + excludeKeywords, withRuntimeGte: query.withRuntimeGte, withRuntimeLte: query.withRuntimeLte, voteAverageGte: query.voteAverageGte, @@ -381,6 +384,7 @@ discoverRoutes.get('/tv', async (req, res, next) => { try { const query = ApiQuerySchema.parse(req.query); const keywords = query.keywords; + const excludeKeywords = query.excludeKeywords; const data = await tmdb.getDiscoverTv({ page: Number(query.page), sortBy: query.sortBy as SortOptions, @@ -395,6 +399,7 @@ discoverRoutes.get('/tv', async (req, res, next) => { : undefined, originalLanguage: query.language, keywords, + excludeKeywords, withRuntimeGte: query.withRuntimeGte, withRuntimeLte: query.withRuntimeLte, voteAverageGte: query.voteAverageGte, diff --git a/src/components/Discover/FilterSlideover/index.tsx b/src/components/Discover/FilterSlideover/index.tsx index 1f06cf0a2f..abdd010501 100644 --- a/src/components/Discover/FilterSlideover/index.tsx +++ b/src/components/Discover/FilterSlideover/index.tsx @@ -33,6 +33,7 @@ const messages = defineMessages('components.Discover.FilterSlideover', { studio: 'Studio', genres: 'Genres', keywords: 'Keywords', + excludeKeywords: 'Exclude Keywords', originalLanguage: 'Original Language', runtimeText: '{minValue}-{maxValue} minute runtime', ratingText: 'Ratings between {minValue} and {maxValue}', @@ -181,6 +182,19 @@ const FilterSlideover = ({ updateQueryParams('keywords', value?.map((v) => v.value).join(',')); }} /> + + {intl.formatMessage(messages.excludeKeywords)} + + { + updateQueryParams( + 'excludeKeywords', + value?.map((v) => v.value).join(',') + ); + }} + /> {intl.formatMessage(messages.originalLanguage)} diff --git a/src/components/Discover/constants.ts b/src/components/Discover/constants.ts index 425ee7de44..4ce5e34f66 100644 --- a/src/components/Discover/constants.ts +++ b/src/components/Discover/constants.ts @@ -99,6 +99,7 @@ export const QueryFilterOptions = z.object({ studio: z.string().optional(), genre: z.string().optional(), keywords: z.string().optional(), + excludeKeywords: z.string().optional(), language: z.string().optional(), withRuntimeGte: z.string().optional(), withRuntimeLte: z.string().optional(), @@ -161,6 +162,10 @@ export const prepareFilterValues = ( filterValues.keywords = values.keywords; } + if (values.excludeKeywords) { + filterValues.excludeKeywords = values.excludeKeywords; + } + if (values.language) { filterValues.language = values.language; } diff --git a/src/i18n/locale/en.json b/src/i18n/locale/en.json index 7153d5a36a..69573dc0ba 100644 --- a/src/i18n/locale/en.json +++ b/src/i18n/locale/en.json @@ -78,6 +78,7 @@ "components.Discover.FilterSlideover.activefilters": "{count, plural, one {# Active Filter} other {# Active Filters}}", "components.Discover.FilterSlideover.certification": "Content Rating", "components.Discover.FilterSlideover.clearfilters": "Clear Active Filters", + "components.Discover.FilterSlideover.excludeKeywords": "Exclude Keywords", "components.Discover.FilterSlideover.filters": "Filters", "components.Discover.FilterSlideover.firstAirDate": "First Air Date", "components.Discover.FilterSlideover.from": "From", From 9e737576ded0f3bdffaccff1da21c60a377a9d04 Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Thu, 18 Sep 2025 16:30:42 +0500 Subject: [PATCH 15/96] fix(dnscaching): check dnsCache before init & support forceipv4 with caching (#1910) * fix: ensure dnsCache is checked for when its enabled before initialization previously dnsCache was being initialized even if it was disabled because the previous check was always returning truthy. fix #1857 * chore: update dns-caching to 0.2.6 This will allow dns-caching to respect forceIpv4 flag. * chore: update dns-caching to 0.2.7 --- package.json | 2 +- pnpm-lock.yaml | 536 +++++++++++++++++++++++++----------------------- server/index.ts | 2 +- 3 files changed, 280 insertions(+), 260 deletions(-) diff --git a/package.json b/package.json index 38c6b6605a..224ab91b05 100644 --- a/package.json +++ b/package.json @@ -57,7 +57,7 @@ "cronstrue": "2.23.0", "date-fns": "2.29.3", "dayjs": "1.11.7", - "dns-caching": "^0.2.5", + "dns-caching": "^0.2.7", "email-templates": "12.0.1", "email-validator": "2.0.4", "express": "4.21.2", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 6e3f5b6943..768fd450a3 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -84,8 +84,8 @@ importers: specifier: 1.11.7 version: 1.11.7 dns-caching: - specifier: ^0.2.5 - version: 0.2.5 + specifier: ^0.2.7 + version: 0.2.7 email-templates: specifier: 12.0.1 version: 12.0.1(@babel/core@7.24.7)(encoding@0.1.13)(handlebars@4.7.8)(mustache@4.2.0)(pug@3.0.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(underscore@1.13.7) @@ -473,24 +473,24 @@ packages: resolution: {integrity: sha512-qJzAIcv03PyaWqxRgO4mSU3lihncDT296vnyuE2O8uA4w3UHWI4S3hgeZd1L8W1Bft40w9JxJ2b412iDUFFRhw==} engines: {node: '>=6.9.0'} - '@babel/compat-data@7.28.0': - resolution: {integrity: sha512-60X7qkglvrap8mn1lh2ebxXdZYtUcpd7gsmy9kLaBJ4i/WdY8PqTSdxyA8qraikqKQK5C1KRBKXqznrVapyNaw==} + '@babel/compat-data@7.28.4': + resolution: {integrity: sha512-YsmSKC29MJwf0gF8Rjjrg5LQCmyh+j/nD8/eP7f+BeoQTKYqs9RoWbjGOdy0+1Ekr68RJZMUOPVQaQisnIo4Rw==} engines: {node: '>=6.9.0'} '@babel/core@7.24.7': resolution: {integrity: sha512-nykK+LEK86ahTkX/3TgauT0ikKoNCfKHEaZYTUVupJdTLzGNvrblu4u6fa7DhZONAltdf8e662t/abY8idrd/g==} engines: {node: '>=6.9.0'} - '@babel/core@7.28.0': - resolution: {integrity: sha512-UlLAnTPrFdNGoFtbSXwcGFQBtQZJCNjaN6hQNP3UPvuNXT1i82N26KL3dZeIpNalWywr9IuQuncaAfUaS1g6sQ==} + '@babel/core@7.28.4': + resolution: {integrity: sha512-2BCOP7TN8M+gVDj7/ht3hsaO/B/n5oDbiAyyvnRlNOs+u1o+JWNYTQrmpuNp1/Wq2gcFrI01JAW+paEKDMx/CA==} engines: {node: '>=6.9.0'} '@babel/generator@7.24.7': resolution: {integrity: sha512-oipXieGC3i45Y1A41t4tAqpnEZWgB/lC6Ehh6+rOviR5XWpTtMmLN+fGjz9vOiNRt0p6RtO6DtD0pdU3vpqdSA==} engines: {node: '>=6.9.0'} - '@babel/generator@7.28.0': - resolution: {integrity: sha512-lJjzvrbEeWrhB4P3QBsH7tey117PjLZnDbLiQEKjQ/fNJTjuq4HSqgFA+UNSwZT8D7dxxbnuSBMsa1lrWzKlQg==} + '@babel/generator@7.28.3': + resolution: {integrity: sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==} engines: {node: '>=6.9.0'} '@babel/helper-annotate-as-pure@7.24.7': @@ -519,8 +519,8 @@ packages: peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-create-class-features-plugin@7.27.1': - resolution: {integrity: sha512-QwGAmuvM17btKU5VqXfb+Giw4JcN0hjuufz3DYnpeVDvZLAObloM77bhMXiqry3Iio+Ai4phVRDwl6WU10+r5A==} + '@babel/helper-create-class-features-plugin@7.28.3': + resolution: {integrity: sha512-V9f6ZFIYSLNEbuGA/92uOvYsGCJNsuA8ESZ4ldc09bWk/j8H8TKiPw8Mk1eG6olpnO0ALHJmYfZvF4MEE4gajg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 @@ -585,8 +585,8 @@ packages: peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-module-transforms@7.27.3': - resolution: {integrity: sha512-dSOvYwvyLsWBeIRyOeHXp5vPj5l1I011r52FM1+r1jCERv+aFXYk4whgQccYEGYxK2H3ZAIA8nuPkQ0HaUo3qg==} + '@babel/helper-module-transforms@7.28.3': + resolution: {integrity: sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 @@ -683,16 +683,16 @@ packages: resolution: {integrity: sha512-N9JIYk3TD+1vq/wn77YnJOqMtfWhNewNE+DJV4puD2X7Ew9J4JvrzrFDfTfyv5EgEXVy9/Wt8QiOErzEmv5Ifw==} engines: {node: '>=6.9.0'} - '@babel/helper-wrap-function@7.27.1': - resolution: {integrity: sha512-NFJK2sHUvrjo8wAU/nQTWU890/zB2jj0qBcCbZbbf+005cAsv6tMjXz31fBign6M5ov1o0Bllu+9nbqkfsjjJQ==} + '@babel/helper-wrap-function@7.28.3': + resolution: {integrity: sha512-zdf983tNfLZFletc0RRXYrHrucBEg95NIFMkn6K9dbeMYnsgHaSBGcQqdsCSStG2PYwRre0Qc2NNSCXbG+xc6g==} engines: {node: '>=6.9.0'} '@babel/helpers@7.24.7': resolution: {integrity: sha512-NlmJJtvcw72yRJRcnCmGvSi+3jDEg8qFu3z0AFoymmzLx5ERVWyzd9kVXr7Th9/8yIJi2Zc6av4Tqz3wFs8QWg==} engines: {node: '>=6.9.0'} - '@babel/helpers@7.28.2': - resolution: {integrity: sha512-/V9771t+EgXz62aCcyofnQhGM8DQACbRhvzKFsXKC9QM+5MadF8ZmIm0crDMaz3+o0h0zXfJnd4EhbYbxsrcFw==} + '@babel/helpers@7.28.4': + resolution: {integrity: sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==} engines: {node: '>=6.9.0'} '@babel/highlight@7.24.7': @@ -709,8 +709,8 @@ packages: engines: {node: '>=6.0.0'} hasBin: true - '@babel/parser@7.28.0': - resolution: {integrity: sha512-jVZGvOxOuNSsuQuLRTh13nU0AogFlw32w/MT+LV6D3sP5WdbW61E77RnkbaO2dUvmPAYrBDJXGn5gGS6tH4j8g==} + '@babel/parser@7.28.4': + resolution: {integrity: sha512-yZbBqeM6TkpP9du/I2pUZnJsRMGGvOuIrhjzC1AwHwW+6he4mni6Bp/m8ijn0iOuZuPI2BfkCoSRunpyjnrQKg==} engines: {node: '>=6.0.0'} hasBin: true @@ -980,8 +980,8 @@ packages: peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-block-scoping@7.28.0': - resolution: {integrity: sha512-gKKnwjpdx5sER/wl0WN0efUBFzF/56YZO0RJrSYP4CljXnP31ByY7fol89AzomdlLNzI36AvOTmYHsnZTCkq8Q==} + '@babel/plugin-transform-block-scoping@7.28.4': + resolution: {integrity: sha512-1yxmvN0MJHOhPVmAsmoW5liWwoILobu/d/ShymZmj867bAdxGbehIrew1DuLpw2Ukv+qDSSPQdYW1dLNE7t11A==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 @@ -1004,8 +1004,8 @@ packages: peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-classes@7.28.0': - resolution: {integrity: sha512-IjM1IoJNw72AZFlj33Cu8X0q2XK/6AaVC3jQu+cgQ5lThWD5ajnuUAml80dqRmOhmPkTH8uAwnpMu9Rvj0LTRA==} + '@babel/plugin-transform-classes@7.28.4': + resolution: {integrity: sha512-cFOlhIYPBv/iBoc+KS3M6et2XPtbT2HiCRfBXWtfpc9OAyostldxIf9YAYB6ypURBBbx+Qv6nyrLzASfJe+hBA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 @@ -1310,8 +1310,8 @@ packages: peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-runtime@7.28.0': - resolution: {integrity: sha512-dGopk9nZrtCs2+nfIem25UuHyt5moSJamArzIoh9/vezUQPmYDOzjaHDCkAzuGJibCIkPup8rMT2+wYB6S73cA==} + '@babel/plugin-transform-runtime@7.28.3': + resolution: {integrity: sha512-Y6ab1kGqZ0u42Zv/4a7l0l72n9DKP/MKoKWaUSBylrhNZO2prYuqFOLbn5aW5SIFXwSH93yfjbgllL8lxuGKLg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 @@ -1441,8 +1441,8 @@ packages: peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/register@7.27.1': - resolution: {integrity: sha512-K13lQpoV54LATKkzBpBAEu1GGSIRzxR9f4IN4V8DCDgiUMo2UDGagEZr3lPeVNJPLkWUi5JE4hCHKneVTwQlYQ==} + '@babel/register@7.28.3': + resolution: {integrity: sha512-CieDOtd8u208eI49bYl4z1J22ySFw87IGwE+IswFEExH7e3rLgKb0WNQeumnacQ1+VoDJLYI5QFA3AJZuyZQfA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 @@ -1458,8 +1458,8 @@ packages: resolution: {integrity: sha512-FDSOghenHTiToteC/QRlv2q3DhPZ/oOXTBoirfWNx1Cx3TMVcGWQtMMmQcSvb/JjpNeGzx8Pq/b4fKEJuWm1sw==} engines: {node: '>=6.9.0'} - '@babel/runtime@7.28.2': - resolution: {integrity: sha512-KHp2IflsnGywDjBWDkR9iEqiWSpc8GIi0lgTT3mOElT0PP1tG26P4tmFI2YvAdzgq9RGyoHZQEIEdZy6Ec5xCA==} + '@babel/runtime@7.28.4': + resolution: {integrity: sha512-Q/N6JNWvIvPnLDvjlE1OUBLPQHH6l3CltCEsHIujp45zQUSSh8K+gHnaEX45yAT1nyngnINhvWtzN+Nb9D8RAQ==} engines: {node: '>=6.9.0'} '@babel/template@7.24.7': @@ -1474,8 +1474,8 @@ packages: resolution: {integrity: sha512-yb65Ed5S/QAcewNPh0nZczy9JdYXkkAbIsEo+P7BE7yO3txAY30Y/oPa3QkQ5It3xVG2kpKMg9MsdxZaO31uKA==} engines: {node: '>=6.9.0'} - '@babel/traverse@7.28.0': - resolution: {integrity: sha512-mGe7UK5wWyh0bKRfupsUchrQGqvDbZDbKJw+kcRGSmdHVYrv+ltd0pnpDTVpiTqnaBru9iEvA8pz8W46v0Amwg==} + '@babel/traverse@7.28.4': + resolution: {integrity: sha512-YEzuboP2qvQavAcjgQNVgsvHIDv6ZpwXvcvjmyySP2DIMuByS/6ioU5G9pYrWHM6T2YDfc7xga9iNzYOs12CFQ==} engines: {node: '>=6.9.0'} '@babel/types@7.24.7': @@ -1486,8 +1486,8 @@ packages: resolution: {integrity: sha512-Y3IR1cRnOxOCDvMmNiym7XpXQ93iGDDPHx+Zj+NM+rg0fBaShfQLkg+hKPaZCEvg5N/LeCo4+Rj/i3FuJsIQaw==} engines: {node: '>=6.9.0'} - '@babel/types@7.28.2': - resolution: {integrity: sha512-ruv7Ae4J5dUYULmeXw1gmb7rYRz57OWCPM57pHojnLq/3Z1CK2lNSLTCVjxVk1F/TZHwOZZrOWi0ur95BbLxNQ==} + '@babel/types@7.28.4': + resolution: {integrity: sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==} engines: {node: '>=6.9.0'} '@codedependant/semantic-release-docker@5.1.0': @@ -1985,6 +1985,9 @@ packages: resolution: {integrity: sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==} engines: {node: '>=6.0.0'} + '@jridgewell/remapping@2.3.5': + resolution: {integrity: sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==} + '@jridgewell/resolve-uri@3.1.2': resolution: {integrity: sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==} engines: {node: '>=6.0.0'} @@ -2005,8 +2008,8 @@ packages: '@jridgewell/trace-mapping@0.3.25': resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==} - '@jridgewell/trace-mapping@0.3.30': - resolution: {integrity: sha512-GQ7Nw5G2lTu/BtHTKfXhKHok2WGetd4XYcVKGx00SjAk8GMwgJM3zr6zORiPGuOE+/vkc90KtTosSSvaCjKb2Q==} + '@jridgewell/trace-mapping@0.3.31': + resolution: {integrity: sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==} '@jridgewell/trace-mapping@0.3.9': resolution: {integrity: sha512-3Belt6tdc8bPgAtbcmdtNJlirVoTmEb5e2gC94PnkwEW9jI6CAHUeoG85tjWP5WquqfavoMtMwiG4P926ZKKuQ==} @@ -3232,8 +3235,8 @@ packages: '@swc/helpers@0.5.5': resolution: {integrity: sha512-KGYxvIOXcceOAbEk4bi/dVLEK9z8sZ0uBB3Il5b1rhfClSpcX0yfRO0KmTkqR2cnQDymwLB+25ZyMzICg/cm/A==} - '@swc/types@0.1.24': - resolution: {integrity: sha512-tjTMh3V4vAORHtdTprLlfoMptu1WfTZG9Rsca6yOKyNYsRr+MUXutKmliB17orgSZk5DpnDxs8GUdd/qwYxOng==} + '@swc/types@0.1.25': + resolution: {integrity: sha512-iAoY/qRhNH8a/hBvm3zKj9qQ4oc2+3w1unPJa2XvTK3XjeLXtzcCingVPw/9e5mn1+0yPqxcBGp9Jf0pkfMb1g==} '@tailwindcss/aspect-ratio@0.4.2': resolution: {integrity: sha512-8QPrypskfBa7QIMuKHg2TA7BqES6vhBrDLOv8Unb6FcFyd3TjKbc6lcmb9UPQHxfl24sXoJ41ux/H7qQQvfaSQ==} @@ -3385,8 +3388,8 @@ packages: '@types/multer@1.4.12': resolution: {integrity: sha512-pQ2hoqvXiJt2FP9WQVLPRO+AmiIm/ZYkavPlIQnx282u4ZrVdztx0pkh3jjpQt0Kz+YI0YhSG264y08UJKoUQg==} - '@types/node-forge@1.3.13': - resolution: {integrity: sha512-zePQJSW5QkwSHKRApqWCVKeKoSOt4xvEnLENZPjyvm9Ezdf/EyDeJM7jqLzOwjVICQQzvLZ63T55MKdJB5H6ww==} + '@types/node-forge@1.3.14': + resolution: {integrity: sha512-mhVF2BnD4BO+jtOp7z1CdzaK4mbuK0LLQYAvdOLqHTavxFNq4zA1EmYkpnFjP8HOUzedfQkRnp0E2ulSAYSzAw==} '@types/node-schedule@2.1.0': resolution: {integrity: sha512-NiTwl8YN3v/1YCKrDFSmCTkVxFDylueEqsOFdgF+vPsm+AlyJKGAo5yzX1FiOxPsZiN6/r8gJitYx2EaSuBmmg==} @@ -3394,8 +3397,8 @@ packages: '@types/node@17.0.45': resolution: {integrity: sha512-w+tIMs3rq2afQdsPJlODhoUEKzFP1ayaoyl1CcnwtIlsVe7K7bA1NGm4s3PraqTLlXnbIN84zuBlxBWo1u9BLw==} - '@types/node@18.19.122': - resolution: {integrity: sha512-yzegtT82dwTNEe/9y+CM8cgb42WrUfMMCg2QqSddzO1J6uPmBD7qKCZ7dOHZP2Yrpm/kb0eqdNMn2MUyEiqBmA==} + '@types/node@18.19.127': + resolution: {integrity: sha512-gSjxjrnKXML/yo0BO099uPixMqfpJU0TKYjpfLU7TrtA2WWDki412Np/RSTPRil1saKBhvVVKzVx/p/6p94nVA==} '@types/node@20.5.1': resolution: {integrity: sha512-4tT2UrL5LBqDwoed9wZ6N3umC4Yhz3W3FloMmiiG4JwmUJWpie0c7lcnUNd4gtMKuDEO4wRVS8B6Xa0uMRsMKg==} @@ -3447,8 +3450,8 @@ packages: '@types/react-transition-group@4.4.5': resolution: {integrity: sha512-juKD/eiSM3/xZYzjuzH6ZwpP+/lejltmiS3QEzV/vmb/Q8+HfDmxu+Baga8UEMGBqV88Nbg4l2hY/K2DkyaLLA==} - '@types/react@18.3.23': - resolution: {integrity: sha512-/LDXMQh55EzZQ0uVAZmKKhfENivEvWz6E+EYzh+/MCjMhNsotd+ZHhBGIjFDTi6+fz0OhQQQLbTgdQIxxCsC0w==} + '@types/react@18.3.24': + resolution: {integrity: sha512-0dLEBsA1kI3OezMBF8nSsb7Nk19ZnsyE1LLhB8r27KbgU5H4pvuqZLdtE+aUkJVoXgTVuA+iLIwmZ0TuK4tx6A==} '@types/react@18.3.3': resolution: {integrity: sha512-hti/R0pS0q1/xx+TsI73XIqk26eBsISZ2R0wUijXIngRK9R/e7Xw/cXVxQK7R5JjW+SV4zGcn5hXjudkN/pLIw==} @@ -3492,8 +3495,8 @@ packages: '@types/web-push@3.3.2': resolution: {integrity: sha512-JxWGVL/m7mWTIg4mRYO+A6s0jPmBkr4iJr39DqJpRJAc+jrPiEe1/asmkwerzRon8ZZDxaZJpsxpv0Z18Wo9gw==} - '@types/webxr@0.5.22': - resolution: {integrity: sha512-Vr6Stjv5jPRqH690f5I5GLjVk8GSsoQSYJ2FVd/3jJF7KaqfwPi3ehfBS96mlQ2kPCwZaX6U0rG2+NGHBKkA/A==} + '@types/webxr@0.5.23': + resolution: {integrity: sha512-GPe4AsfOSpqWd3xA/0gwoKod13ChcfV67trvxaW2krUbgb9gxQjnCx8zGshzMl8LSHZlNH5gQ8LNScsDuc7nGQ==} '@types/wink-jaro-distance@2.0.2': resolution: {integrity: sha512-Q79orp7qA/g/uLdFmqd5MtEa0ZfJW5X1WXikAu8IVHt24IrHWrcTNYNdPpLK5mwVg34C6FQnrv/DMtcUhjE/zA==} @@ -4026,6 +4029,10 @@ packages: base64-js@1.5.1: resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==} + baseline-browser-mapping@2.8.5: + resolution: {integrity: sha512-TiU4qUT9jdCuh4aVOG7H1QozyeI2sZRqoRPdqBIaslfNt4WUSanRBueAwl2x5jt4rXBMim3lIN2x6yT8PDi24Q==} + hasBin: true + bcrypt-pbkdf@1.0.2: resolution: {integrity: sha512-qeFIXtP4MSoi6NLqO12WfqARWWuCKi2Rn/9hJLEmtB5yTNr9DqFWkJRCf2qShWzPeAMRnOgCrq0sg/KLv5ES9w==} @@ -4090,8 +4097,8 @@ packages: engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7} hasBin: true - browserslist@4.25.1: - resolution: {integrity: sha512-KGj0KoOMXLpSNkkEI6Z6mShmQy0bc1I+T7K9N81k4WWMrfz+6fQ6es80B/YLAeRoKvjYE1YSHHOW1qe9xIVzHw==} + browserslist@4.26.2: + resolution: {integrity: sha512-ECFzp6uFOSB+dcZ5BK/IBaGWssbSYBHvuMeMt3MMFyhI0Z8SqGgEkBLARgpRH3hutIgPVsALcMwbDrJqPxQ65A==} engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7} hasBin: true @@ -4194,8 +4201,8 @@ packages: caniuse-lite@1.0.30001700: resolution: {integrity: sha512-2S6XIXwaE7K7erT8dY+kLQcpa5ms63XlRkMkReXjle+kf6c5g38vyMl+Z5y8dSxOFDhcFe+nxnn261PLxBSQsQ==} - caniuse-lite@1.0.30001734: - resolution: {integrity: sha512-uhE1Ye5vgqju6OI71HTQqcBCZrvHugk0MjLak7Q+HfoBgoq5Bi+5YnwjP4fjDgrtYr/l8MVRBvzz9dPD4KyK0A==} + caniuse-lite@1.0.30001743: + resolution: {integrity: sha512-e6Ojr7RV14Un7dz6ASD0aZDmQPT/A+eZU+nuTNfjqmRrmkmQlnTNWH0SKmqagx9PeW87UVqapSurtAXifmtdmw==} caseless@0.12.0: resolution: {integrity: sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==} @@ -4545,8 +4552,8 @@ packages: core-js-compat@3.37.1: resolution: {integrity: sha512-9TNiImhKvQqSUkOvk/mMRZzOANTiEVC7WaBNhHcKM7x+/5E1l5NvsysR19zuDQScE8k+kfQXWRN3AtS/eOSHpg==} - core-js-compat@3.45.0: - resolution: {integrity: sha512-gRoVMBawZg0OnxaVv3zpqLLxaHmsubEGyTnqdpI/CEBvX4JadI1dMSHxagThprYRtSVbuQxvi6iUatdPxohHpA==} + core-js-compat@3.45.1: + resolution: {integrity: sha512-tqTt5T4PzsMIZ430XGviK4vzYSoeNJ6CXODi6c/voxOT6IZqBht5/EKaSNnYiEjjRYxjVz7DQIsOsY0XNi8PIA==} core-util-is@1.0.2: resolution: {integrity: sha512-3lqz5YjWTYnW6dlDa5TLaTCcShfar1e40rmcJVwCBJC6mWlFuj0eCHIElmG1g5kyuJ/GD+8Wn4FFCcz4gJPfaQ==} @@ -4732,8 +4739,8 @@ packages: supports-color: optional: true - debug@4.4.1: - resolution: {integrity: sha512-KcKCqiftBJcZr++7ykoDIEwSa3XWowTfNPo92BYxjXiyYEVrUQh2aLyhxBCwww+heortUFxEJYcRzosstTEBYQ==} + debug@4.4.3: + resolution: {integrity: sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==} engines: {node: '>=6.0'} peerDependencies: supports-color: '*' @@ -4864,8 +4871,8 @@ packages: dlv@1.1.3: resolution: {integrity: sha512-+HlytyjlPKnIG8XuRG8WvmBP8xs8P71y+SKKS6ZXWoEgLuePxtDoUEiH7WkdePWrQ5JBpE6aoVqfZfJUQkjXwA==} - dns-caching@0.2.5: - resolution: {integrity: sha512-1cnB6i/OG4zfYbRnDjWZDT+FGLvOBuJlFIxVZvHBiaa62SCfaGoP4Si50O14HyoHmx1gadeGWigYXdX5LQAFvg==} + dns-caching@0.2.7: + resolution: {integrity: sha512-48fgJWH9aUHPN+TOmbozx1hxX9YoCsEkZzR/wHKRFPFx0NZtmSgtZY3M0Vsl7x/fDcq3mCI3SMgyTKVgZZrogg==} doctrine@2.1.0: resolution: {integrity: sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==} @@ -4938,8 +4945,8 @@ packages: electron-to-chromium@1.4.810: resolution: {integrity: sha512-Kaxhu4T7SJGpRQx99tq216gCq2nMxJo+uuT6uzz9l8TVN2stL7M06MIIXAtr9jsrLs2Glflgf2vMQRepxawOdQ==} - electron-to-chromium@1.5.200: - resolution: {integrity: sha512-rFCxROw7aOe4uPTfIAx+rXv9cEcGx+buAF4npnhtTqCJk5KDFRnh3+KYj7rdVh6lsFt5/aPs+Irj9rZ33WMA7w==} + electron-to-chromium@1.5.221: + resolution: {integrity: sha512-/1hFJ39wkW01ogqSyYoA4goOXOtMRy6B+yvA1u42nnsEGtHzIzmk93aPISumVQeblj47JUHLC9coCjUxb1EvtQ==} email-templates@12.0.1: resolution: {integrity: sha512-849pjBFVUAWWTa3HqhDjxlXHaSWmxf4CZOlZ9iVkrSAbQ8YCYi+7KiKqt35L6F20WhSViWX7lmMjno6zBv2rNQ==} @@ -5507,8 +5514,8 @@ packages: flow-enums-runtime@0.0.6: resolution: {integrity: sha512-3PYnM29RFXwvAN6Pc/scUfkI7RwhQ/xqyLUyPNlXUp9S40zI8nup9tUSrTLSVnWGBN38FNiGWbwZOB6uR4OGdw==} - flow-parser@0.278.0: - resolution: {integrity: sha512-9oUcYDHf9n+E/t0FXndgBqGbaUsGEcmWqIr1ldqCzTzctsJV5E/bHusOj4ThB72Ss2mqWpLFNz0+o2c1O8J6+A==} + flow-parser@0.283.0: + resolution: {integrity: sha512-PNpYZX8guJSDiHv7DQo+BLgiRNjbUQrag52b/8/znK+n0kGBbGtG9Smklb0VRdBdHg+UYKk9hSpWez3nXI5nEw==} engines: {node: '>=0.4.0'} fn.name@1.1.0: @@ -6745,8 +6752,11 @@ packages: resolution: {integrity: sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ==} engines: {node: 14 || >=16.14} - lru-cache@11.1.0: - resolution: {integrity: sha512-QIXZUBJUx+2zHUdQujWejBkcD9+cs94tLn0+YL8UrCh+D5sCXZ4c7LaEH48pNwRY3MLDgqUFyhlCyjJPf1WP0A==} + lru-cache@10.4.3: + resolution: {integrity: sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==} + + lru-cache@11.2.1: + resolution: {integrity: sha512-r8LA6i4LP4EeWOhqBaZZjDWwehd1xUJPCJd9Sv300H0ZmcUER4+JPh7bqqZeqs1o5pgtgvXm+d9UGrB5zZGDiQ==} engines: {node: 20 || >=22} lru-cache@5.1.1: @@ -7303,8 +7313,8 @@ packages: node-releases@2.0.14: resolution: {integrity: sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==} - node-releases@2.0.19: - resolution: {integrity: sha512-xxOWJsBKtzAq7DY0J+DTzuz58K8e7sJbdgwkbMWQe8UYB6ekmsQ45q0M/tJDsGaZmbC+l7n57UV8Hl5tHxO9uw==} + node-releases@2.0.21: + resolution: {integrity: sha512-5b0pgg78U3hwXkCM8Z9b2FJdPZlr9Psr9V2gQPESdGHqbntyFJKFW4r5TeWGFzafGY3hzs1JC62VEQMbl1JFkw==} node-schedule@2.1.1: resolution: {integrity: sha512-OXdegQq03OmXEjt2hZP33W2YPs/E5BcFQks46+G2gAxs4gHOIVD1u7EqlYLYSKsaIpyKCK9Gbk0ta1/gjRSMRQ==} @@ -8420,8 +8430,8 @@ packages: resolution: {integrity: sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==} engines: {node: '>=4'} - regenerate-unicode-properties@10.2.0: - resolution: {integrity: sha512-DqHn3DwbmmPVzeKj9woBadqmXxLvQoQIwu7nopMc72ztvxVmVk2SBhSnx67zuye5TP+lJsb/TBQsjLKhnDf3MA==} + regenerate-unicode-properties@10.2.2: + resolution: {integrity: sha512-m03P+zhBeQd1RGnYxrGyDAPpWX/epKirLrp8e3qevZdVkKtnCrjjWczIbYc8+xd6vcTStVlqfycTx1KR4LOr0g==} engines: {node: '>=4'} regenerate@1.4.2: @@ -8448,8 +8458,8 @@ packages: resolution: {integrity: sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ==} engines: {node: '>=4'} - regexpu-core@6.2.0: - resolution: {integrity: sha512-H66BPQMrv+V16t8xtmq+UC0CBpiTBA60V8ibS1QVReIp8T1z8hwFxqcGzm9K6lgsN7sB5edVH8a+ze6Fqm4weA==} + regexpu-core@6.3.1: + resolution: {integrity: sha512-DzcswPr252wEr7Qz8AyAVbfyBDKLoYp6eRA1We2Fa9qirRFSdtkP5sHr3yglDKy2BbA0fd2T+j/CUSKes3FeVQ==} engines: {node: '>=4'} registry-auth-token@5.0.2: @@ -9147,8 +9157,8 @@ packages: resolution: {integrity: sha512-7jDLIdD2Zp0bDe5r3D2qtkd1QOCacylBuL7oa4udvN6v2pqr4+LcCr67C8DR1zkpaZ8XosF5m1yQSabKAW6f2g==} engines: {node: '>=14.16'} - terser@5.43.1: - resolution: {integrity: sha512-+6erLbBm0+LROX2sPXlUYx/ux5PyE9K/a92Wrt6oA+WDAoFTdpHE5tCYCI5PNzq2y8df4rA+QgHLJuR4jNymsg==} + terser@5.44.0: + resolution: {integrity: sha512-nIVck8DK+GM/0Frwd+nIhZ84pR/BX7rmXMfYwyg+Sri5oGVE99/E3KvXqpC2xHFxyqXyGHTKBSioxxplrO4I4w==} engines: {node: '>=10'} hasBin: true @@ -9558,8 +9568,8 @@ packages: resolution: {integrity: sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==} engines: {node: '>=4'} - unicode-match-property-value-ecmascript@2.2.0: - resolution: {integrity: sha512-4IehN3V/+kkr5YeSSDDQG8QLqO26XpL2XP3GQtqwlT/QYSECAwFztxVHjlbh0+gjJ3XmNLS0zDsbgs9jWKExLg==} + unicode-match-property-value-ecmascript@2.2.1: + resolution: {integrity: sha512-JQ84qTuMg4nVkx8ga4A16a1epI9H6uTXAknqxkGF/aFfRLw1xC/Bp24HNLaZhHSkWd3+84t8iXnp1J0kYcZHhg==} engines: {node: '>=4'} unicode-property-aliases-ecmascript@2.1.0: @@ -10018,7 +10028,7 @@ snapshots: '@babel/compat-data@7.24.7': {} - '@babel/compat-data@7.28.0': {} + '@babel/compat-data@7.28.4': {} '@babel/core@7.24.7': dependencies: @@ -10040,20 +10050,20 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/core@7.28.0': + '@babel/core@7.28.4': dependencies: - '@ampproject/remapping': 2.3.0 '@babel/code-frame': 7.27.1 - '@babel/generator': 7.28.0 + '@babel/generator': 7.28.3 '@babel/helper-compilation-targets': 7.27.2 - '@babel/helper-module-transforms': 7.27.3(@babel/core@7.28.0) - '@babel/helpers': 7.28.2 - '@babel/parser': 7.28.0 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) + '@babel/helpers': 7.28.4 + '@babel/parser': 7.28.4 '@babel/template': 7.27.2 - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 + '@jridgewell/remapping': 2.3.5 convert-source-map: 2.0.0 - debug: 4.4.1 + debug: 4.4.3 gensync: 1.0.0-beta.2 json5: 2.2.3 semver: 6.3.1 @@ -10067,12 +10077,12 @@ snapshots: '@jridgewell/trace-mapping': 0.3.25 jsesc: 2.5.2 - '@babel/generator@7.28.0': + '@babel/generator@7.28.3': dependencies: - '@babel/parser': 7.28.0 - '@babel/types': 7.28.2 + '@babel/parser': 7.28.4 + '@babel/types': 7.28.4 '@jridgewell/gen-mapping': 0.3.13 - '@jridgewell/trace-mapping': 0.3.30 + '@jridgewell/trace-mapping': 0.3.31 jsesc: 3.1.0 '@babel/helper-annotate-as-pure@7.24.7': @@ -10081,7 +10091,7 @@ snapshots: '@babel/helper-annotate-as-pure@7.27.3': dependencies: - '@babel/types': 7.28.2 + '@babel/types': 7.28.4 '@babel/helper-builder-binary-assignment-operator-visitor@7.24.7': dependencies: @@ -10100,9 +10110,9 @@ snapshots: '@babel/helper-compilation-targets@7.27.2': dependencies: - '@babel/compat-data': 7.28.0 + '@babel/compat-data': 7.28.4 '@babel/helper-validator-option': 7.27.1 - browserslist: 4.25.1 + browserslist: 4.26.2 lru-cache: 5.1.1 semver: 6.3.1 @@ -10121,7 +10131,7 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/helper-create-class-features-plugin@7.27.1(@babel/core@7.24.7)': + '@babel/helper-create-class-features-plugin@7.28.3(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 '@babel/helper-annotate-as-pure': 7.27.3 @@ -10129,20 +10139,20 @@ snapshots: '@babel/helper-optimise-call-expression': 7.27.1 '@babel/helper-replace-supers': 7.27.1(@babel/core@7.24.7) '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 semver: 6.3.1 transitivePeerDependencies: - supports-color - '@babel/helper-create-class-features-plugin@7.27.1(@babel/core@7.28.0)': + '@babel/helper-create-class-features-plugin@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-annotate-as-pure': 7.27.3 '@babel/helper-member-expression-to-functions': 7.27.1 '@babel/helper-optimise-call-expression': 7.27.1 - '@babel/helper-replace-supers': 7.27.1(@babel/core@7.28.0) + '@babel/helper-replace-supers': 7.27.1(@babel/core@7.28.4) '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 semver: 6.3.1 transitivePeerDependencies: - supports-color @@ -10158,7 +10168,7 @@ snapshots: dependencies: '@babel/core': 7.24.7 '@babel/helper-annotate-as-pure': 7.27.3 - regexpu-core: 6.2.0 + regexpu-core: 6.3.1 semver: 6.3.1 '@babel/helper-define-polyfill-provider@0.6.2(@babel/core@7.24.7)': @@ -10177,7 +10187,7 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-compilation-targets': 7.27.2 '@babel/helper-plugin-utils': 7.27.1 - debug: 4.4.1 + debug: 4.4.3 lodash.debounce: 4.0.8 resolve: 1.22.10 transitivePeerDependencies: @@ -10207,8 +10217,8 @@ snapshots: '@babel/helper-member-expression-to-functions@7.27.1': dependencies: - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 transitivePeerDependencies: - supports-color @@ -10221,8 +10231,8 @@ snapshots: '@babel/helper-module-imports@7.27.1': dependencies: - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 transitivePeerDependencies: - supports-color @@ -10237,21 +10247,21 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/helper-module-transforms@7.27.3(@babel/core@7.24.7)': + '@babel/helper-module-transforms@7.28.3(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 '@babel/helper-module-imports': 7.27.1 '@babel/helper-validator-identifier': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-module-transforms@7.27.3(@babel/core@7.28.0)': + '@babel/helper-module-transforms@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-module-imports': 7.27.1 '@babel/helper-validator-identifier': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color @@ -10261,7 +10271,7 @@ snapshots: '@babel/helper-optimise-call-expression@7.27.1': dependencies: - '@babel/types': 7.28.2 + '@babel/types': 7.28.4 '@babel/helper-plugin-utils@7.24.7': {} @@ -10280,8 +10290,8 @@ snapshots: dependencies: '@babel/core': 7.24.7 '@babel/helper-annotate-as-pure': 7.27.3 - '@babel/helper-wrap-function': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/helper-wrap-function': 7.28.3 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color @@ -10299,16 +10309,16 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-member-expression-to-functions': 7.27.1 '@babel/helper-optimise-call-expression': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-replace-supers@7.27.1(@babel/core@7.28.0)': + '@babel/helper-replace-supers@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-member-expression-to-functions': 7.27.1 '@babel/helper-optimise-call-expression': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color @@ -10328,8 +10338,8 @@ snapshots: '@babel/helper-skip-transparent-expression-wrappers@7.27.1': dependencies: - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 transitivePeerDependencies: - supports-color @@ -10362,11 +10372,11 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/helper-wrap-function@7.27.1': + '@babel/helper-wrap-function@7.28.3': dependencies: '@babel/template': 7.27.2 - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 transitivePeerDependencies: - supports-color @@ -10375,10 +10385,10 @@ snapshots: '@babel/template': 7.24.7 '@babel/types': 7.24.7 - '@babel/helpers@7.28.2': + '@babel/helpers@7.28.4': dependencies: '@babel/template': 7.27.2 - '@babel/types': 7.28.2 + '@babel/types': 7.28.4 '@babel/highlight@7.24.7': dependencies: @@ -10395,9 +10405,9 @@ snapshots: dependencies: '@babel/types': 7.26.9 - '@babel/parser@7.28.0': + '@babel/parser@7.28.4': dependencies: - '@babel/types': 7.28.2 + '@babel/types': 7.28.4 '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.24.7(@babel/core@7.24.7)': dependencies: @@ -10438,15 +10448,15 @@ snapshots: '@babel/plugin-proposal-class-properties@7.18.6(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.24.7) + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.24.7) '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color - '@babel/plugin-proposal-class-properties@7.18.6(@babel/core@7.28.0)': + '@babel/plugin-proposal-class-properties@7.18.6(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 - '@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.28.0) + '@babel/core': 7.28.4 + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color @@ -10468,11 +10478,11 @@ snapshots: '@babel/helper-plugin-utils': 7.27.1 '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-proposal-nullish-coalescing-operator@7.18.6(@babel/core@7.28.0)': + '@babel/plugin-proposal-nullish-coalescing-operator@7.18.6(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.28.0) + '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.28.4) '@babel/plugin-proposal-numeric-separator@7.18.6(@babel/core@7.24.7)': dependencies: @@ -10482,7 +10492,7 @@ snapshots: '@babel/plugin-proposal-object-rest-spread@7.20.7(@babel/core@7.24.7)': dependencies: - '@babel/compat-data': 7.28.0 + '@babel/compat-data': 7.28.4 '@babel/core': 7.24.7 '@babel/helper-compilation-targets': 7.27.2 '@babel/helper-plugin-utils': 7.27.1 @@ -10504,12 +10514,12 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/plugin-proposal-optional-chaining@7.21.0(@babel/core@7.28.0)': + '@babel/plugin-proposal-optional-chaining@7.21.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 - '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.28.0) + '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.28.4) transitivePeerDependencies: - supports-color @@ -10552,9 +10562,9 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-flow@7.27.1(@babel/core@7.28.0)': + '@babel/plugin-syntax-flow@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 '@babel/plugin-syntax-import-assertions@7.24.7(@babel/core@7.24.7)': @@ -10587,9 +10597,9 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-jsx@7.27.1(@babel/core@7.28.0)': + '@babel/plugin-syntax-jsx@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 '@babel/plugin-syntax-logical-assignment-operators@7.10.4(@babel/core@7.24.7)': @@ -10602,9 +10612,9 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-nullish-coalescing-operator@7.8.3(@babel/core@7.28.0)': + '@babel/plugin-syntax-nullish-coalescing-operator@7.8.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.24.7 '@babel/plugin-syntax-numeric-separator@7.10.4(@babel/core@7.24.7)': @@ -10627,9 +10637,9 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-optional-chaining@7.8.3(@babel/core@7.28.0)': + '@babel/plugin-syntax-optional-chaining@7.8.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.24.7 '@babel/plugin-syntax-private-property-in-object@7.14.5(@babel/core@7.24.7)': @@ -10652,9 +10662,9 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-typescript@7.27.1(@babel/core@7.28.0)': + '@babel/plugin-syntax-typescript@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 '@babel/plugin-syntax-unicode-sets-regex@7.18.6(@babel/core@7.24.7)': @@ -10711,7 +10721,7 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-transform-block-scoping@7.28.0(@babel/core@7.24.7)': + '@babel/plugin-transform-block-scoping@7.28.4(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.27.1 @@ -10747,7 +10757,7 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/plugin-transform-classes@7.28.0(@babel/core@7.24.7)': + '@babel/plugin-transform-classes@7.28.4(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 '@babel/helper-annotate-as-pure': 7.27.3 @@ -10755,7 +10765,7 @@ snapshots: '@babel/helper-globals': 7.28.0 '@babel/helper-plugin-utils': 7.27.1 '@babel/helper-replace-supers': 7.27.1(@babel/core@7.24.7) - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color @@ -10780,7 +10790,7 @@ snapshots: dependencies: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color @@ -10821,11 +10831,11 @@ snapshots: '@babel/helper-plugin-utils': 7.27.1 '@babel/plugin-syntax-flow': 7.27.1(@babel/core@7.24.7) - '@babel/plugin-transform-flow-strip-types@7.27.1(@babel/core@7.28.0)': + '@babel/plugin-transform-flow-strip-types@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-flow': 7.27.1(@babel/core@7.28.0) + '@babel/plugin-syntax-flow': 7.27.1(@babel/core@7.28.4) '@babel/plugin-transform-for-of@7.24.7(@babel/core@7.24.7)': dependencies: @@ -10847,7 +10857,7 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-compilation-targets': 7.27.2 '@babel/helper-plugin-utils': 7.27.1 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color @@ -10898,15 +10908,15 @@ snapshots: '@babel/plugin-transform-modules-commonjs@7.27.1(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 - '@babel/helper-module-transforms': 7.27.3(@babel/core@7.24.7) + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.24.7) '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-modules-commonjs@7.27.1(@babel/core@7.28.0)': + '@babel/plugin-transform-modules-commonjs@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 - '@babel/helper-module-transforms': 7.27.3(@babel/core@7.28.0) + '@babel/core': 7.28.4 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color @@ -11010,7 +11020,7 @@ snapshots: '@babel/plugin-transform-private-methods@7.27.1(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.24.7) + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.24.7) '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color @@ -11029,7 +11039,7 @@ snapshots: dependencies: '@babel/core': 7.24.7 '@babel/helper-annotate-as-pure': 7.27.3 - '@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.24.7) + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.24.7) '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color @@ -11089,7 +11099,7 @@ snapshots: '@babel/helper-module-imports': 7.27.1 '@babel/helper-plugin-utils': 7.27.1 '@babel/plugin-syntax-jsx': 7.27.1(@babel/core@7.24.7) - '@babel/types': 7.28.2 + '@babel/types': 7.28.4 transitivePeerDependencies: - supports-color @@ -11110,7 +11120,7 @@ snapshots: '@babel/core': 7.24.7 '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-transform-runtime@7.28.0(@babel/core@7.24.7)': + '@babel/plugin-transform-runtime@7.28.3(@babel/core@7.24.7)': dependencies: '@babel/core': 7.24.7 '@babel/helper-module-imports': 7.27.1 @@ -11182,21 +11192,21 @@ snapshots: dependencies: '@babel/core': 7.24.7 '@babel/helper-annotate-as-pure': 7.27.3 - '@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.24.7) + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.24.7) '@babel/helper-plugin-utils': 7.27.1 '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 '@babel/plugin-syntax-typescript': 7.27.1(@babel/core@7.24.7) transitivePeerDependencies: - supports-color - '@babel/plugin-transform-typescript@7.28.0(@babel/core@7.28.0)': + '@babel/plugin-transform-typescript@7.28.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-annotate-as-pure': 7.27.3 - '@babel/helper-create-class-features-plugin': 7.27.1(@babel/core@7.28.0) + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) '@babel/helper-plugin-utils': 7.27.1 '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 - '@babel/plugin-syntax-typescript': 7.27.1(@babel/core@7.28.0) + '@babel/plugin-syntax-typescript': 7.27.1(@babel/core@7.28.4) transitivePeerDependencies: - supports-color @@ -11316,12 +11326,12 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/preset-flow@7.27.1(@babel/core@7.28.0)': + '@babel/preset-flow@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 '@babel/helper-validator-option': 7.27.1 - '@babel/plugin-transform-flow-strip-types': 7.27.1(@babel/core@7.28.0) + '@babel/plugin-transform-flow-strip-types': 7.27.1(@babel/core@7.28.4) '@babel/preset-modules@0.1.6-no-external-plugins(@babel/core@7.24.7)': dependencies: @@ -11353,20 +11363,20 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/preset-typescript@7.27.1(@babel/core@7.28.0)': + '@babel/preset-typescript@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 '@babel/helper-plugin-utils': 7.27.1 '@babel/helper-validator-option': 7.27.1 - '@babel/plugin-syntax-jsx': 7.27.1(@babel/core@7.28.0) - '@babel/plugin-transform-modules-commonjs': 7.27.1(@babel/core@7.28.0) - '@babel/plugin-transform-typescript': 7.28.0(@babel/core@7.28.0) + '@babel/plugin-syntax-jsx': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-modules-commonjs': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-typescript': 7.28.0(@babel/core@7.28.4) transitivePeerDependencies: - supports-color - '@babel/register@7.27.1(@babel/core@7.28.0)': + '@babel/register@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 clone-deep: 4.0.1 find-cache-dir: 2.1.0 make-dir: 2.1.0 @@ -11383,7 +11393,7 @@ snapshots: dependencies: regenerator-runtime: 0.14.1 - '@babel/runtime@7.28.2': {} + '@babel/runtime@7.28.4': {} '@babel/template@7.24.7': dependencies: @@ -11394,8 +11404,8 @@ snapshots: '@babel/template@7.27.2': dependencies: '@babel/code-frame': 7.27.1 - '@babel/parser': 7.28.0 - '@babel/types': 7.28.2 + '@babel/parser': 7.28.4 + '@babel/types': 7.28.4 '@babel/traverse@7.24.7': dependencies: @@ -11412,15 +11422,15 @@ snapshots: transitivePeerDependencies: - supports-color - '@babel/traverse@7.28.0': + '@babel/traverse@7.28.4': dependencies: '@babel/code-frame': 7.27.1 - '@babel/generator': 7.28.0 + '@babel/generator': 7.28.3 '@babel/helper-globals': 7.28.0 - '@babel/parser': 7.28.0 + '@babel/parser': 7.28.4 '@babel/template': 7.27.2 - '@babel/types': 7.28.2 - debug: 4.4.1 + '@babel/types': 7.28.4 + debug: 4.4.3 transitivePeerDependencies: - supports-color @@ -11435,7 +11445,7 @@ snapshots: '@babel/helper-string-parser': 7.25.9 '@babel/helper-validator-identifier': 7.25.9 - '@babel/types@7.28.2': + '@babel/types@7.28.4': dependencies: '@babel/helper-string-parser': 7.27.1 '@babel/helper-validator-identifier': 7.27.1 @@ -12103,7 +12113,7 @@ snapshots: '@jridgewell/gen-mapping@0.3.13': dependencies: '@jridgewell/sourcemap-codec': 1.5.5 - '@jridgewell/trace-mapping': 0.3.30 + '@jridgewell/trace-mapping': 0.3.31 '@jridgewell/gen-mapping@0.3.5': dependencies: @@ -12111,6 +12121,11 @@ snapshots: '@jridgewell/sourcemap-codec': 1.4.15 '@jridgewell/trace-mapping': 0.3.25 + '@jridgewell/remapping@2.3.5': + dependencies: + '@jridgewell/gen-mapping': 0.3.13 + '@jridgewell/trace-mapping': 0.3.31 + '@jridgewell/resolve-uri@3.1.2': {} '@jridgewell/set-array@1.2.1': {} @@ -12118,7 +12133,7 @@ snapshots: '@jridgewell/source-map@0.3.11': dependencies: '@jridgewell/gen-mapping': 0.3.13 - '@jridgewell/trace-mapping': 0.3.30 + '@jridgewell/trace-mapping': 0.3.31 '@jridgewell/sourcemap-codec@1.4.15': {} @@ -12129,7 +12144,7 @@ snapshots: '@jridgewell/resolve-uri': 3.1.2 '@jridgewell/sourcemap-codec': 1.4.15 - '@jridgewell/trace-mapping@0.3.30': + '@jridgewell/trace-mapping@0.3.31': dependencies: '@jridgewell/resolve-uri': 3.1.2 '@jridgewell/sourcemap-codec': 1.5.5 @@ -13011,8 +13026,8 @@ snapshots: '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.24.7) '@babel/plugin-transform-arrow-functions': 7.27.1(@babel/core@7.24.7) '@babel/plugin-transform-async-to-generator': 7.27.1(@babel/core@7.24.7) - '@babel/plugin-transform-block-scoping': 7.28.0(@babel/core@7.24.7) - '@babel/plugin-transform-classes': 7.28.0(@babel/core@7.24.7) + '@babel/plugin-transform-block-scoping': 7.28.4(@babel/core@7.24.7) + '@babel/plugin-transform-classes': 7.28.4(@babel/core@7.24.7) '@babel/plugin-transform-computed-properties': 7.27.1(@babel/core@7.24.7) '@babel/plugin-transform-destructuring': 7.28.0(@babel/core@7.24.7) '@babel/plugin-transform-flow-strip-types': 7.27.1(@babel/core@7.24.7) @@ -13027,7 +13042,7 @@ snapshots: '@babel/plugin-transform-react-jsx': 7.27.1(@babel/core@7.24.7) '@babel/plugin-transform-react-jsx-self': 7.27.1(@babel/core@7.24.7) '@babel/plugin-transform-react-jsx-source': 7.27.1(@babel/core@7.24.7) - '@babel/plugin-transform-runtime': 7.28.0(@babel/core@7.24.7) + '@babel/plugin-transform-runtime': 7.28.3(@babel/core@7.24.7) '@babel/plugin-transform-shorthand-properties': 7.27.1(@babel/core@7.24.7) '@babel/plugin-transform-spread': 7.27.1(@babel/core@7.24.7) '@babel/plugin-transform-sticky-regex': 7.27.1(@babel/core@7.24.7) @@ -13043,7 +13058,7 @@ snapshots: '@react-native/codegen@0.74.84(@babel/preset-env@7.24.7(@babel/core@7.24.7))': dependencies: - '@babel/parser': 7.28.0 + '@babel/parser': 7.28.4 '@babel/preset-env': 7.24.7(@babel/core@7.24.7) glob: 7.2.3 hermes-parser: 0.19.1 @@ -13401,9 +13416,9 @@ snapshots: '@react-three/fiber@8.16.8(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react-native@0.74.2(@babel/core@7.24.7)(@babel/preset-env@7.24.7(@babel/core@7.24.7))(@types/react@18.3.3)(encoding@0.1.13)(react@18.3.1))(react@18.3.1)(three@0.165.0)': dependencies: - '@babel/runtime': 7.28.2 + '@babel/runtime': 7.28.4 '@types/react-reconciler': 0.26.7 - '@types/webxr': 0.5.22 + '@types/webxr': 0.5.23 base64-js: 1.5.1 buffer: 6.0.3 its-fine: 1.2.5(@types/react@18.3.3)(react@18.3.1) @@ -13556,7 +13571,7 @@ snapshots: '@rnx-kit/chromium-edge-launcher@1.0.0': dependencies: - '@types/node': 18.19.122 + '@types/node': 18.19.127 escape-string-regexp: 4.0.0 is-wsl: 2.2.0 lighthouse-logger: 1.4.2 @@ -13819,7 +13834,7 @@ snapshots: '@swc/core@1.6.5(@swc/helpers@0.5.11)': dependencies: '@swc/counter': 0.1.3 - '@swc/types': 0.1.24 + '@swc/types': 0.1.25 optionalDependencies: '@swc/core-darwin-arm64': 1.6.5 '@swc/core-darwin-x64': 1.6.5 @@ -13844,7 +13859,7 @@ snapshots: '@swc/counter': 0.1.3 tslib: 2.8.1 - '@swc/types@0.1.24': + '@swc/types@0.1.25': dependencies: '@swc/counter': 0.1.3 @@ -14012,7 +14027,7 @@ snapshots: dependencies: '@types/express': 4.17.17 - '@types/node-forge@1.3.13': + '@types/node-forge@1.3.14': dependencies: '@types/node': 22.10.5 @@ -14022,7 +14037,7 @@ snapshots: '@types/node@17.0.45': {} - '@types/node@18.19.122': + '@types/node@18.19.127': dependencies: undici-types: 5.26.5 @@ -14060,7 +14075,7 @@ snapshots: '@types/react-reconciler@0.26.7': dependencies: - '@types/react': 18.3.23 + '@types/react': 18.3.24 '@types/react-reconciler@0.28.9(@types/react@18.3.3)': dependencies: @@ -14074,7 +14089,7 @@ snapshots: dependencies: '@types/react': 18.3.3 - '@types/react@18.3.23': + '@types/react@18.3.24': dependencies: '@types/prop-types': 15.7.15 csstype: 3.1.3 @@ -14122,7 +14137,7 @@ snapshots: dependencies: '@types/node': 22.10.5 - '@types/webxr@0.5.22': {} + '@types/webxr@0.5.23': {} '@types/wink-jaro-distance@2.0.2': {} @@ -14637,9 +14652,9 @@ snapshots: dependencies: deep-equal-json: 1.0.0 - babel-core@7.0.0-bridge.0(@babel/core@7.28.0): + babel-core@7.0.0-bridge.0(@babel/core@7.28.4): dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 babel-plugin-emotion@10.2.2: dependencies: @@ -14679,7 +14694,7 @@ snapshots: babel-plugin-polyfill-corejs2@0.4.14(@babel/core@7.24.7): dependencies: - '@babel/compat-data': 7.28.0 + '@babel/compat-data': 7.28.4 '@babel/core': 7.24.7 '@babel/helper-define-polyfill-provider': 0.6.5(@babel/core@7.24.7) semver: 6.3.1 @@ -14698,7 +14713,7 @@ snapshots: dependencies: '@babel/core': 7.24.7 '@babel/helper-define-polyfill-provider': 0.6.5(@babel/core@7.24.7) - core-js-compat: 3.45.0 + core-js-compat: 3.45.1 transitivePeerDependencies: - supports-color @@ -14734,6 +14749,8 @@ snapshots: base64-js@1.5.1: {} + baseline-browser-mapping@2.8.5: {} + bcrypt-pbkdf@1.0.2: dependencies: tweetnacl: 0.14.5 @@ -14813,12 +14830,13 @@ snapshots: node-releases: 2.0.14 update-browserslist-db: 1.0.16(browserslist@4.23.1) - browserslist@4.25.1: + browserslist@4.26.2: dependencies: - caniuse-lite: 1.0.30001734 - electron-to-chromium: 1.5.200 - node-releases: 2.0.19 - update-browserslist-db: 1.1.3(browserslist@4.25.1) + baseline-browser-mapping: 2.8.5 + caniuse-lite: 1.0.30001743 + electron-to-chromium: 1.5.221 + node-releases: 2.0.21 + update-browserslist-db: 1.1.3(browserslist@4.26.2) bser@2.1.1: dependencies: @@ -14947,7 +14965,7 @@ snapshots: caniuse-lite@1.0.30001700: {} - caniuse-lite@1.0.30001734: {} + caniuse-lite@1.0.30001743: {} caseless@0.12.0: {} @@ -15334,9 +15352,9 @@ snapshots: dependencies: browserslist: 4.23.1 - core-js-compat@3.45.0: + core-js-compat@3.45.1: dependencies: - browserslist: 4.25.1 + browserslist: 4.26.2 core-util-is@1.0.2: {} @@ -15578,7 +15596,7 @@ snapshots: optionalDependencies: supports-color: 8.1.1 - debug@4.4.1: + debug@4.4.3: dependencies: ms: 2.1.3 @@ -15700,9 +15718,9 @@ snapshots: dlv@1.1.3: {} - dns-caching@0.2.5: + dns-caching@0.2.7: dependencies: - lru-cache: 11.1.0 + lru-cache: 11.2.1 doctrine@2.1.0: dependencies: @@ -15788,7 +15806,7 @@ snapshots: electron-to-chromium@1.4.810: {} - electron-to-chromium@1.5.200: {} + electron-to-chromium@1.5.221: {} email-templates@12.0.1(@babel/core@7.24.7)(encoding@0.1.13)(handlebars@4.7.8)(mustache@4.2.0)(pug@3.0.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(underscore@1.13.7): dependencies: @@ -16093,7 +16111,7 @@ snapshots: debug: 4.4.0(supports-color@5.5.0) enhanced-resolve: 5.17.0 eslint: 8.35.0 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.35.0))(eslint@8.35.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1)(eslint@8.35.0) eslint-plugin-import: 2.29.1(@typescript-eslint/parser@5.54.0(eslint@8.35.0)(typescript@4.9.5))(eslint@8.35.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 @@ -16115,7 +16133,7 @@ snapshots: transitivePeerDependencies: - supports-color - eslint-module-utils@2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.35.0))(eslint@8.35.0): + eslint-module-utils@2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1)(eslint@8.35.0): dependencies: debug: 3.2.7(supports-color@8.1.1) optionalDependencies: @@ -16708,7 +16726,7 @@ snapshots: flow-enums-runtime@0.0.6: {} - flow-parser@0.278.0: {} + flow-parser@0.283.0: {} fn.name@1.1.0: {} @@ -17120,7 +17138,7 @@ snapshots: hosted-git-info@7.0.2: dependencies: - lru-cache: 10.2.2 + lru-cache: 10.4.3 hosted-git-info@8.1.0: dependencies: @@ -17679,19 +17697,19 @@ snapshots: jscodeshift@0.14.0(@babel/preset-env@7.24.7(@babel/core@7.24.7)): dependencies: - '@babel/core': 7.28.0 - '@babel/parser': 7.28.0 - '@babel/plugin-proposal-class-properties': 7.18.6(@babel/core@7.28.0) - '@babel/plugin-proposal-nullish-coalescing-operator': 7.18.6(@babel/core@7.28.0) - '@babel/plugin-proposal-optional-chaining': 7.21.0(@babel/core@7.28.0) - '@babel/plugin-transform-modules-commonjs': 7.27.1(@babel/core@7.28.0) + '@babel/core': 7.28.4 + '@babel/parser': 7.28.4 + '@babel/plugin-proposal-class-properties': 7.18.6(@babel/core@7.28.4) + '@babel/plugin-proposal-nullish-coalescing-operator': 7.18.6(@babel/core@7.28.4) + '@babel/plugin-proposal-optional-chaining': 7.21.0(@babel/core@7.28.4) + '@babel/plugin-transform-modules-commonjs': 7.27.1(@babel/core@7.28.4) '@babel/preset-env': 7.24.7(@babel/core@7.24.7) - '@babel/preset-flow': 7.27.1(@babel/core@7.28.0) - '@babel/preset-typescript': 7.27.1(@babel/core@7.28.0) - '@babel/register': 7.27.1(@babel/core@7.28.0) - babel-core: 7.0.0-bridge.0(@babel/core@7.28.0) + '@babel/preset-flow': 7.27.1(@babel/core@7.28.4) + '@babel/preset-typescript': 7.27.1(@babel/core@7.28.4) + '@babel/register': 7.28.3(@babel/core@7.28.4) + babel-core: 7.0.0-bridge.0(@babel/core@7.28.4) chalk: 4.1.2 - flow-parser: 0.278.0 + flow-parser: 0.283.0 graceful-fs: 4.2.11 micromatch: 4.0.8 neo-async: 2.6.2 @@ -18042,7 +18060,9 @@ snapshots: lru-cache@10.2.2: {} - lru-cache@11.1.0: {} + lru-cache@10.4.3: {} + + lru-cache@11.2.1: {} lru-cache@5.1.1: dependencies: @@ -18248,7 +18268,7 @@ snapshots: metro-babel-transformer@0.80.12: dependencies: - '@babel/core': 7.28.0 + '@babel/core': 7.28.4 flow-enums-runtime: 0.0.6 hermes-parser: 0.23.1 nullthrows: 1.1.1 @@ -18307,7 +18327,7 @@ snapshots: metro-minify-terser@0.80.12: dependencies: flow-enums-runtime: 0.0.6 - terser: 5.43.1 + terser: 5.44.0 metro-resolver@0.80.12: dependencies: @@ -18315,13 +18335,13 @@ snapshots: metro-runtime@0.80.12: dependencies: - '@babel/runtime': 7.28.2 + '@babel/runtime': 7.28.4 flow-enums-runtime: 0.0.6 metro-source-map@0.80.12: dependencies: - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 flow-enums-runtime: 0.0.6 invariant: 2.2.4 metro-symbolicate: 0.80.12 @@ -18346,10 +18366,10 @@ snapshots: metro-transform-plugins@0.80.12: dependencies: - '@babel/core': 7.28.0 - '@babel/generator': 7.28.0 + '@babel/core': 7.28.4 + '@babel/generator': 7.28.3 '@babel/template': 7.27.2 - '@babel/traverse': 7.28.0 + '@babel/traverse': 7.28.4 flow-enums-runtime: 0.0.6 nullthrows: 1.1.1 transitivePeerDependencies: @@ -18357,10 +18377,10 @@ snapshots: metro-transform-worker@0.80.12: dependencies: - '@babel/core': 7.28.0 - '@babel/generator': 7.28.0 - '@babel/parser': 7.28.0 - '@babel/types': 7.28.2 + '@babel/core': 7.28.4 + '@babel/generator': 7.28.3 + '@babel/parser': 7.28.4 + '@babel/types': 7.28.4 flow-enums-runtime: 0.0.6 metro: 0.80.12 metro-babel-transformer: 0.80.12 @@ -18378,12 +18398,12 @@ snapshots: metro@0.80.12: dependencies: '@babel/code-frame': 7.27.1 - '@babel/core': 7.28.0 - '@babel/generator': 7.28.0 - '@babel/parser': 7.28.0 + '@babel/core': 7.28.4 + '@babel/generator': 7.28.3 + '@babel/parser': 7.28.4 '@babel/template': 7.27.2 - '@babel/traverse': 7.28.0 - '@babel/types': 7.28.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 accepts: 1.3.8 chalk: 4.1.2 ci-info: 2.0.0 @@ -18832,7 +18852,7 @@ snapshots: node-releases@2.0.14: {} - node-releases@2.0.19: {} + node-releases@2.0.21: {} node-schedule@2.1.1: dependencies: @@ -19207,7 +19227,7 @@ snapshots: path-scurry@1.11.1: dependencies: - lru-cache: 10.2.2 + lru-cache: 10.4.3 minipass: 7.1.2 path-to-regexp@0.1.12: {} @@ -20005,7 +20025,7 @@ snapshots: dependencies: regenerate: 1.4.2 - regenerate-unicode-properties@10.2.0: + regenerate-unicode-properties@10.2.2: dependencies: regenerate: 1.4.2 @@ -20037,14 +20057,14 @@ snapshots: unicode-match-property-ecmascript: 2.0.0 unicode-match-property-value-ecmascript: 2.1.0 - regexpu-core@6.2.0: + regexpu-core@6.3.1: dependencies: regenerate: 1.4.2 - regenerate-unicode-properties: 10.2.0 + regenerate-unicode-properties: 10.2.2 regjsgen: 0.8.0 regjsparser: 0.12.0 unicode-match-property-ecmascript: 2.0.0 - unicode-match-property-value-ecmascript: 2.2.0 + unicode-match-property-value-ecmascript: 2.2.1 registry-auth-token@5.0.2: dependencies: @@ -20251,7 +20271,7 @@ snapshots: selfsigned@2.4.1: dependencies: - '@types/node-forge': 1.3.13 + '@types/node-forge': 1.3.14 node-forge: 1.3.1 semantic-release@24.2.7(typescript@4.9.5): @@ -20879,7 +20899,7 @@ snapshots: type-fest: 2.19.0 unique-string: 3.0.0 - terser@5.43.1: + terser@5.44.0: dependencies: '@jridgewell/source-map': 0.3.11 acorn: 8.15.0 @@ -21227,7 +21247,7 @@ snapshots: unicode-match-property-value-ecmascript@2.1.0: {} - unicode-match-property-value-ecmascript@2.2.0: {} + unicode-match-property-value-ecmascript@2.2.1: {} unicode-property-aliases-ecmascript@2.1.0: {} @@ -21308,9 +21328,9 @@ snapshots: escalade: 3.1.2 picocolors: 1.0.1 - update-browserslist-db@1.1.3(browserslist@4.25.1): + update-browserslist-db@1.1.3(browserslist@4.26.2): dependencies: - browserslist: 4.25.1 + browserslist: 4.26.2 escalade: 3.2.0 picocolors: 1.1.1 diff --git a/server/index.ts b/server/index.ts index 24b7f2250a..9d7a74b88d 100644 --- a/server/index.ts +++ b/server/index.ts @@ -82,7 +82,7 @@ app } // Add DNS caching - if (settings.network.dnsCache) { + if (settings.network.dnsCache?.enabled) { initializeDnsCache({ forceMinTtl: settings.network.dnsCache.forceMinTtl, forceMaxTtl: settings.network.dnsCache.forceMaxTtl, From 328517cc0a42c249d0ef6fc913977876b1bba625 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Sun, 21 Sep 2025 17:46:29 +0200 Subject: [PATCH 16/96] fix(watchlist): handle undefined Guid for Plex watchlist metadata (#1914) --- server/api/plextv.ts | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/server/api/plextv.ts b/server/api/plextv.ts index 410df72a20..bfc75bc15f 100644 --- a/server/api/plextv.ts +++ b/server/api/plextv.ts @@ -113,7 +113,7 @@ interface MetadataResponse { ratingKey: string; type: 'movie' | 'show'; title: string; - Guid: { + Guid?: { id: `imdb://tt${number}` | `tmdb://${number}` | `tvdb://${number}`; }[]; }[]; @@ -334,10 +334,10 @@ class PlexTvAPI extends ExternalAPI { const metadata = detailedResponse.MediaContainer.Metadata[0]; - const tmdbString = metadata.Guid.find((guid) => + const tmdbString = metadata.Guid?.find((guid) => guid.id.startsWith('tmdb') ); - const tvdbString = metadata.Guid.find((guid) => + const tvdbString = metadata.Guid?.find((guid) => guid.id.startsWith('tvdb') ); From 1518dc01e543f9eb3cb7b70c1d016602a7ca141c Mon Sep 17 00:00:00 2001 From: Sergii Bogomolov Date: Tue, 23 Sep 2025 11:01:34 +0200 Subject: [PATCH 17/96] chore(helm): switch from Deployment to StatefulSet (#1901) Jellyseerr is not designed to support multiple concurrently running instances. To ensure that only one instance can run at any given time we: - Replace Deployment with StatefulSet: switch from running "at least N pods" to "at most N pods". - Remove replicaCount value: default is 1, we do not want to support more. --- charts/jellyseerr-chart/Chart.yaml | 2 +- charts/jellyseerr-chart/README.md | 19 ++++++++++++++----- charts/jellyseerr-chart/README.md.gotmpl | 11 +++++++++++ .../{deployment.yaml => statefulset.yaml} | 6 ++---- charts/jellyseerr-chart/values.yaml | 10 ++-------- 5 files changed, 30 insertions(+), 18 deletions(-) rename charts/jellyseerr-chart/templates/{deployment.yaml => statefulset.yaml} (97%) diff --git a/charts/jellyseerr-chart/Chart.yaml b/charts/jellyseerr-chart/Chart.yaml index 831a4ff2f8..72e2c3bbe7 100644 --- a/charts/jellyseerr-chart/Chart.yaml +++ b/charts/jellyseerr-chart/Chart.yaml @@ -3,7 +3,7 @@ kubeVersion: ">=1.23.0-0" name: jellyseerr-chart description: Jellyseerr helm chart for Kubernetes type: application -version: 2.6.2 +version: 2.7.0 appVersion: "2.7.3" maintainers: - name: Jellyseerr diff --git a/charts/jellyseerr-chart/README.md b/charts/jellyseerr-chart/README.md index 32e3fe0ff3..88c374658c 100644 --- a/charts/jellyseerr-chart/README.md +++ b/charts/jellyseerr-chart/README.md @@ -1,6 +1,6 @@ # jellyseerr-chart -![Version: 2.6.2](https://img.shields.io/badge/Version-2.6.2-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 2.7.3](https://img.shields.io/badge/AppVersion-2.7.3-informational?style=flat-square) +![Version: 2.7.0](https://img.shields.io/badge/Version-2.7.0-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 2.7.3](https://img.shields.io/badge/AppVersion-2.7.3-informational?style=flat-square) Jellyseerr helm chart for Kubernetes @@ -20,6 +20,17 @@ Jellyseerr helm chart for Kubernetes Kubernetes: `>=1.23.0-0` +## Update Notes + +### Updating to 2.7.0 + +Jellyseerr is a stateful application and it is not designed to have multiple replicas. In version 2.7.0 we address this by: + +- replacing `Deployment` with `StatefulSet` +- removing `replicaCount` value + +If `replicaCount` value was used - remove it. Helm update should work fine after that. + ## Values | Key | Type | Default | Description | @@ -55,7 +66,6 @@ Kubernetes: `>=1.23.0-0` | probes.livenessProbe | object | `{}` | Configure liveness probe | | probes.readinessProbe | object | `{}` | Configure readiness probe | | probes.startupProbe | string | `nil` | Configure startup probe | -| replicaCount | int | `1` | | | resources | object | `{}` | | | securityContext | object | `{}` | | | service.port | int | `80` | | @@ -64,7 +74,6 @@ Kubernetes: `>=1.23.0-0` | serviceAccount.automount | bool | `true` | Automatically mount a ServiceAccount's API credentials? | | serviceAccount.create | bool | `true` | Specifies whether a service account should be created | | serviceAccount.name | string | `""` | If not set and create is true, a name is generated using the fullname template | -| strategy | object | `{"type":"Recreate"}` | Deployment strategy | | tolerations | list | `[]` | | -| volumeMounts | list | `[]` | Additional volumeMounts on the output Deployment definition. | -| volumes | list | `[]` | Additional volumes on the output Deployment definition. | +| volumeMounts | list | `[]` | Additional volumeMounts on the output StatefulSet definition. | +| volumes | list | `[]` | Additional volumes on the output StatefulSet definition. | diff --git a/charts/jellyseerr-chart/README.md.gotmpl b/charts/jellyseerr-chart/README.md.gotmpl index c58fe7d5f1..a057a11bd0 100644 --- a/charts/jellyseerr-chart/README.md.gotmpl +++ b/charts/jellyseerr-chart/README.md.gotmpl @@ -14,4 +14,15 @@ {{ template "chart.requirementsSection" . }} +## Update Notes + +### Updating to 2.7.0 + +Jellyseerr is a stateful application and it is not designed to have multiple replicas. In version 2.7.0 we address this by: + +- replacing `Deployment` with `StatefulSet` +- removing `replicaCount` value + +If `replicaCount` value was used - remove it. Helm update should work fine after that. + {{ template "chart.valuesSection" . }} diff --git a/charts/jellyseerr-chart/templates/deployment.yaml b/charts/jellyseerr-chart/templates/statefulset.yaml similarity index 97% rename from charts/jellyseerr-chart/templates/deployment.yaml rename to charts/jellyseerr-chart/templates/statefulset.yaml index 50dd82d5cd..ecdd9fce73 100644 --- a/charts/jellyseerr-chart/templates/deployment.yaml +++ b/charts/jellyseerr-chart/templates/statefulset.yaml @@ -1,13 +1,11 @@ apiVersion: apps/v1 -kind: Deployment +kind: StatefulSet metadata: name: {{ include "jellyseerr.fullname" . }} labels: {{- include "jellyseerr.labels" . | nindent 4 }} spec: - replicas: {{ .Values.replicaCount }} - strategy: - type: {{ .Values.strategy.type }} + serviceName: {{ include "jellyseerr.fullname" . }} selector: matchLabels: {{- include "jellyseerr.selectorLabels" . | nindent 6 }} diff --git a/charts/jellyseerr-chart/values.yaml b/charts/jellyseerr-chart/values.yaml index 5b703d2f37..09aa757f27 100644 --- a/charts/jellyseerr-chart/values.yaml +++ b/charts/jellyseerr-chart/values.yaml @@ -1,5 +1,3 @@ -replicaCount: 1 - image: registry: ghcr.io repository: fallenbagel/jellyseerr @@ -12,10 +10,6 @@ imagePullSecrets: [] nameOverride: "" fullnameOverride: "" -# -- Deployment strategy -strategy: - type: Recreate - # Liveness / Readiness / Startup Probes probes: # -- Configure liveness probe @@ -115,14 +109,14 @@ resources: {} # cpu: 100m # memory: 128Mi -# -- Additional volumes on the output Deployment definition. +# -- Additional volumes on the output StatefulSet definition. volumes: [] # - name: foo # secret: # secretName: mysecret # optional: false -# -- Additional volumeMounts on the output Deployment definition. +# -- Additional volumeMounts on the output StatefulSet definition. volumeMounts: [] # - name: foo # mountPath: "/etc/foo" From f045274a307d017345a2a8f948996f5d043e590e Mon Sep 17 00:00:00 2001 From: Gauthier Date: Tue, 23 Sep 2025 14:14:50 +0200 Subject: [PATCH 18/96] docs: add AI assistance notice (#1917) * docs: add AI assistance notice * docs: add TODO item for AI disclosure --- .github/PULL_REQUEST_TEMPLATE.md | 1 + CONTRIBUTING.md | 41 +++++++++++++++++++++++++++++++- 2 files changed, 41 insertions(+), 1 deletion(-) diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index 35464dc0d5..985ca5f6a6 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -4,6 +4,7 @@ #### To-Dos +- [ ] Disclosed any use of AI (see our [policy](https://github.com/fallenbagel/jellyseerr/blob/docs-contributing/CONTRIBUTING.md#ai-assistance-notice)) - [ ] Successful build `pnpm build` - [ ] Translation keys `pnpm i18n:extract` - [ ] Database migration (if required) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 855cecfbfd..fec9b93a3e 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -2,6 +2,45 @@ All help is welcome and greatly appreciated! If you would like to contribute to the project, the following instructions should get you started... +## AI Assistance Notice + +> [!IMPORTANT] +> +> If you are using **any kind of AI assistance** to contribute to Jellyseerr, +> it must be disclosed in the pull request. + +If you are using any kind of AI assistance while contributing to Jellyseerr, +**this must be disclosed in the pull request**, along with the extent to +which AI assistance was used (e.g. docs only vs. code generation). +If PR responses are being generated by an AI, disclose that as well. +As a small exception, trivial tab-completion doesn't need to be disclosed, +so long as it is limited to single keywords or short phrases. + +An example disclosure: + +> This PR was written primarily by Claude Code. + +Or a more detailed disclosure: + +> I consulted ChatGPT to understand the codebase but the solution +> was fully authored manually by myself. + +Failure to disclose this is first and foremost rude to the human operators +on the other end of the pull request, but it also makes it difficult to +determine how much scrutiny to apply to the contribution. + +In a perfect world, AI assistance would produce equal or higher quality +work than any human. That isn't the world we live in today, and in most cases +it's generating slop. I say this despite being a fan of and using them +successfully myself (with heavy supervision)! + +When using AI assistance, we expect contributors to understand the code +that is produced and be able to answer critical questions about it. It +isn't a maintainers job to review a PR so broken that it requires +significant rework to be acceptable. + +Please be respectful to maintainers and disclose AI assistance. + ## Development ### Tools Required @@ -158,4 +197,4 @@ DB_TYPE="postgres" DB_USER=postgres DB_PASS=postgres pnpm migration:generate ser ## Attribution -This contribution guide was inspired by the [Next.js](https://github.com/vercel/next.js), [Radarr](https://github.com/Radarr/Radarr), and [Overseerr](https://github.com/sct/Overseerr) contribution guides. +This contribution guide was inspired by the [Next.js](https://github.com/vercel/next.js), [Radarr](https://github.com/Radarr/Radarr), [Overseerr](https://github.com/sct/Overseerr) and [Ghostty](https://github.com/ghostty-org/ghostty) contribution guides. From 837629ec471efa6baaf33b3a4045d2a7f85cd603 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Wed, 24 Sep 2025 07:24:12 +0200 Subject: [PATCH 19/96] fix(api): remove spaces from tags in *arr (#1913) This PR removes the spaces in the tags sent to *arr when the Tag Requests option is enabled. Spaces in tags are an unintended behavior and are not longer supported. fix #1897 --- server/subscriber/MediaRequestSubscriber.ts | 28 ++++++++++++++++----- 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/server/subscriber/MediaRequestSubscriber.ts b/server/subscriber/MediaRequestSubscriber.ts index 530b3a5a2e..52c3482648 100644 --- a/server/subscriber/MediaRequestSubscriber.ts +++ b/server/subscriber/MediaRequestSubscriber.ts @@ -292,9 +292,17 @@ export class MediaRequestSubscriber } if (radarrSettings.tagRequests) { - let userTag = (await radarr.getTags()).find((v) => + const radarrTags = await radarr.getTags(); + // old tags had space around the hyphen + let userTag = radarrTags.find((v) => v.label.startsWith(entity.requestedBy.id + ' - ') ); + // new tags do not have spaces around the hyphen, since spaces are not allowed anymore + if (!userTag) { + userTag = radarrTags.find((v) => + v.label.startsWith(entity.requestedBy.id + '-') + ); + } if (!userTag) { logger.info(`Requester has no active tag. Creating new`, { label: 'Media Request', @@ -302,11 +310,11 @@ export class MediaRequestSubscriber mediaId: entity.media.id, userId: entity.requestedBy.id, newTag: - entity.requestedBy.id + ' - ' + entity.requestedBy.displayName, + entity.requestedBy.id + '-' + entity.requestedBy.displayName, }); userTag = await radarr.createTag({ label: - entity.requestedBy.id + ' - ' + entity.requestedBy.displayName, + entity.requestedBy.id + '-' + entity.requestedBy.displayName, }); } if (userTag.id) { @@ -601,9 +609,17 @@ export class MediaRequestSubscriber } if (sonarrSettings.tagRequests) { - let userTag = (await sonarr.getTags()).find((v) => + const sonarrTags = await sonarr.getTags(); + // old tags had space around the hyphen + let userTag = sonarrTags.find((v) => v.label.startsWith(entity.requestedBy.id + ' - ') ); + // new tags do not have spaces around the hyphen, since spaces are not allowed anymore + if (!userTag) { + userTag = sonarrTags.find((v) => + v.label.startsWith(entity.requestedBy.id + '-') + ); + } if (!userTag) { logger.info(`Requester has no active tag. Creating new`, { label: 'Media Request', @@ -611,11 +627,11 @@ export class MediaRequestSubscriber mediaId: entity.media.id, userId: entity.requestedBy.id, newTag: - entity.requestedBy.id + ' - ' + entity.requestedBy.displayName, + entity.requestedBy.id + '-' + entity.requestedBy.displayName, }); userTag = await sonarr.createTag({ label: - entity.requestedBy.id + ' - ' + entity.requestedBy.displayName, + entity.requestedBy.id + '-' + entity.requestedBy.displayName, }); } if (userTag.id) { From c024799daec10e6d9c8dbdc2ba8b0c8152b495a3 Mon Sep 17 00:00:00 2001 From: 0xsysr3ll <31414959+0xSysR3ll@users.noreply.github.com> Date: Wed, 24 Sep 2025 14:03:33 +0200 Subject: [PATCH 20/96] feat(api): add completed count to request count API (#1824) --- jellyseerr-api.yml | 4 +++- server/routes/request.ts | 7 +++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/jellyseerr-api.yml b/jellyseerr-api.yml index 69484e24a2..767e336ba2 100644 --- a/jellyseerr-api.yml +++ b/jellyseerr-api.yml @@ -6153,7 +6153,7 @@ paths: get: summary: Gets request counts description: | - Returns the number of pending and approved requests. + Returns the number of requests by status including pending, approved, available, and completed requests. tags: - request responses: @@ -6180,6 +6180,8 @@ paths: type: number available: type: number + completed: + type: number /request/{requestId}: get: summary: Get MediaRequest diff --git a/server/routes/request.ts b/server/routes/request.ts index 8773b87f2f..a142a6c063 100644 --- a/server/routes/request.ts +++ b/server/routes/request.ts @@ -381,6 +381,12 @@ requestRoutes.get('/count', async (_req, res, next) => { ) .getCount(); + const completedCount = await query + .where('request.status = :requestStatus', { + requestStatus: MediaRequestStatus.COMPLETED, + }) + .getCount(); + return res.status(200).json({ total: totalCount, movie: movieCount, @@ -390,6 +396,7 @@ requestRoutes.get('/count', async (_req, res, next) => { declined: declinedCount, processing: processingCount, available: availableCount, + completed: completedCount, }); } catch (e) { logger.error('Something went wrong retrieving request counts', { From f46a7631529f172fe3fcb4c57406966c81dc42db Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Thu, 25 Sep 2025 02:57:23 +0100 Subject: [PATCH 21/96] ci: tidy up workflows and implement a consistent style (#1905) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * feat(ci): tidy up workflows and implement a consistent style all workflows now use ubuntu-24.04 as the runner type to match the release workflows codeql.yml - bump actions to v3 - add least-privilege perms + concurrency to stop duplicate runs - ignore docs only changes conflict_labeler.yml - run on opened, reopened, and synchronize - bump action version - add concurrency group to avoid duplicate labeling cypress.yml - skip docs-only changes; don’t run on draft PRs - add concurrency to stop duplicate runs + 10m timeout docs-deploy.yml - add configure-pages@v5 and bump upload-pages-artifact to v4 - set explicit pages/id-token perms + concurrency - minor cleanups (working-directory, ubuntu-24.04) helm.yml - switch oras discover to oras manifest fetch - add concurrency to stop duplicate runs lint-helm-charts.yml - bump action versions - enforce version bumps (--check-version-increment=true) - add least-privilege perms + concurrency to stop duplicate runs support.yml - add least-privilege perms test-docs-deploy.yml - add least-privilege perms + concurrency to stop duplicate runs * fixed line 5 syntax error * Updated based on comments from @M0NsTeRRR in PR-1905 discussion * updated based on 2nd review from @M0NsTeRRR in PR-1905 * Merge of PR-1904 and PR-1905 * chore(pnpm-lock.yaml): updated the pnpm-lockfile * ci(release.yml): fix the latest tag to use context labels * ci: fix new lines at eof, removed cypress timeout, removed legacy qemu actions * @M0NsTeRRR self review Signed-off-by: Ludovic Ortega * fix: support workflow Signed-off-by: Ludovic Ortega * fix: newline --------- Signed-off-by: Ludovic Ortega Co-authored-by: Ludovic Ortega Co-authored-by: Ludovic Ortega --- .github/workflows/ci.yml | 159 +-- .github/workflows/codeql.yml | 29 +- .github/workflows/conflict_labeler.yml | 20 +- .github/workflows/cypress.yml | 37 +- .github/workflows/docs-deploy.yml | 46 +- .github/workflows/helm.yml | 29 +- .github/workflows/lint-helm-charts.yml | 29 +- .github/workflows/preview.yml | 130 ++- .github/workflows/release.yml | 238 +++-- .github/workflows/snap.yaml.disabled | 94 -- .github/workflows/support.yml | 29 +- .github/workflows/test-docs-deploy.yml | 23 +- .vscode/settings.json | 5 +- Dockerfile | 31 +- package.json | 28 +- pnpm-lock.yaml | 1361 +----------------------- 16 files changed, 568 insertions(+), 1720 deletions(-) delete mode 100644 .github/workflows/snap.yaml.disabled diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 8189522f01..2dc7bf023f 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -7,6 +7,14 @@ on: push: branches: - develop + workflow_dispatch: + +permissions: + contents: read + +concurrency: + group: ci-${{ github.ref }} + cancel-in-progress: true jobs: test: @@ -17,14 +25,24 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Get PNPM version from package.json + id: pnpm-version + shell: sh + run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT + - name: Pnpm Setup uses: pnpm/action-setup@v4 with: - version: 9 + version: ${{ steps.pnpm-version.outputs.pnpm_version }} + - name: Get pnpm store directory shell: sh run: | echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV + - name: Setup pnpm cache uses: actions/cache@v4 with: @@ -32,137 +50,144 @@ jobs: key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} restore-keys: | ${{ runner.os }}-pnpm-store- + - name: Install dependencies env: HUSKY: 0 run: pnpm install + - name: Lint run: pnpm lint + - name: Formatting run: pnpm format:check + - name: Build run: pnpm build build: - name: Build & Publish Docker Images + name: Build (per-arch, native runners) if: github.ref == 'refs/heads/develop' && !contains(github.event.head_commit.message, '[skip ci]') strategy: matrix: include: - runner: ubuntu-24.04 platform: linux/amd64 + arch: amd64 - runner: ubuntu-24.04-arm platform: linux/arm64 + arch: arm64 runs-on: ${{ matrix.runner }} - outputs: - digest-amd64: ${{ steps.set_outputs.outputs.digest-amd64 }} - digest-arm64: ${{ steps.set_outputs.outputs.digest-arm64 }} steps: - name: Checkout uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Commit timestamp + id: ts + run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 - - name: Log in to Docker Hub - uses: docker/login-action@v3 - with: - username: ${{ secrets.DOCKER_USERNAME }} - password: ${{ secrets.DOCKER_TOKEN }} - - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 - with: - registry: ghcr.io - username: ${{ github.repository_owner }} - password: ${{ secrets.GITHUB_TOKEN }} - - name: Set lower case owner name - run: | - echo "OWNER_LC=${OWNER,,}" >>${GITHUB_ENV} - env: - OWNER: ${{ github.repository_owner }} - - name: Docker metadata - id: meta - uses: docker/metadata-action@v4 - with: - images: | - fallenbagel/jellyseerr - ghcr.io/${{ env.OWNER_LC }}/jellyseerr - tags: | - type=ref,event=branch - type=sha,prefix=,suffix=,format=short - - name: Build and push by digest - id: build - uses: docker/build-push-action@v5 + + - name: Warm cache (no push) — ${{ matrix.platform }} + uses: docker/build-push-action@v6 with: context: . file: ./Dockerfile platforms: ${{ matrix.platform }} - push: true + push: false build-args: | COMMIT_TAG=${{ github.sha }} BUILD_VERSION=develop - BUILD_DATE=${{ github.event.repository.updated_at }} - outputs: | - type=image,push-by-digest=true,name=fallenbagel/jellyseerr,push=true - type=image,push-by-digest=true,name=ghcr.io/${{ env.OWNER_LC }}/jellyseerr,push=true + SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} cache-from: type=gha,scope=${{ matrix.platform }} cache-to: type=gha,mode=max,scope=${{ matrix.platform }} provenance: false - - name: Set outputs - id: set_outputs - run: | - platform="${{ matrix.platform == 'linux/amd64' && 'amd64' || 'arm64' }}" - echo "digest-${platform}=${{ steps.build.outputs.digest }}" >> $GITHUB_OUTPUT - merge_and_push: - name: Create and Push Multi-arch Manifest + publish: + name: Publish multi-arch image needs: build runs-on: ubuntu-24.04 + permissions: + contents: read + packages: write + id-token: write steps: + - name: Checkout + uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Commit timestamp + id: ts + run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Log in to Docker Hub uses: docker/login-action@v3 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} + - name: Log in to GitHub Container Registry uses: docker/login-action@v3 with: registry: ghcr.io username: ${{ github.repository_owner }} password: ${{ secrets.GITHUB_TOKEN }} - - name: Set lower case owner name - run: | - echo "OWNER_LC=${OWNER,,}" >>${GITHUB_ENV} - env: - OWNER: ${{ github.repository_owner }} - - name: Create and push manifest - run: | - docker manifest create fallenbagel/jellyseerr:develop \ - --amend fallenbagel/jellyseerr@${{ needs.build.outputs.digest-amd64 }} \ - --amend fallenbagel/jellyseerr@${{ needs.build.outputs.digest-arm64 }} - docker manifest push fallenbagel/jellyseerr:develop - # GHCR manifest - docker manifest create ghcr.io/${{ env.OWNER_LC }}/jellyseerr:develop \ - --amend ghcr.io/${{ env.OWNER_LC }}/jellyseerr@${{ needs.build.outputs.digest-amd64 }} \ - --amend ghcr.io/${{ env.OWNER_LC }}/jellyseerr@${{ needs.build.outputs.digest-arm64 }} - docker manifest push ghcr.io/${{ env.OWNER_LC }}/jellyseerr:develop + - name: Extract metadata + id: meta + uses: docker/metadata-action@v5 + with: + images: | + ${{ github.repository }} + ghcr.io/${{ github.repository }} + tags: | + type=raw,value=develop + type=sha + labels: | + org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} + + - name: Build & Push (multi-arch, single tag) + uses: docker/build-push-action@v6 + with: + context: . + file: ./Dockerfile + platforms: linux/amd64,linux/arm64 + push: true + build-args: | + COMMIT_TAG=${{ github.sha }} + BUILD_VERSION=develop + SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} + labels: ${{ steps.meta.outputs.labels }} + tags: ${{ steps.meta.outputs.tags }} + cache-from: | + type=gha,scope=linux/amd64 + type=gha,scope=linux/arm64 + cache-to: type=gha,mode=max + provenance: false discord: name: Send Discord Notification - needs: merge_and_push + needs: publish if: always() && github.event_name != 'pull_request' && !contains(github.event.head_commit.message, '[skip ci]') runs-on: ubuntu-24.04 steps: - - name: Get Build Job Status - uses: technote-space/workflow-conclusion-action@v3 - name: Combine Job Status id: status run: | failures=(neutral, skipped, timed_out, action_required) - if [[ ${array[@]} =~ $WORKFLOW_CONCLUSION ]]; then + if [[ ${array[@]} =~ ${{ needs.publish.result }} ]]; then echo "status=failure" >> $GITHUB_OUTPUT else - echo "status=$WORKFLOW_CONCLUSION" >> $GITHUB_OUTPUT + echo "status=${{ needs.publish.result }}" >> $GITHUB_OUTPUT fi + - name: Post Status to Discord uses: sarisia/actions-status-discord@v1 with: diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index ed34d7c8b1..b2266728ef 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -3,39 +3,52 @@ name: 'CodeQL' on: push: branches: ['develop'] + paths-ignore: + - '**/*.md' + - 'docs/**' pull_request: branches: ['develop'] + paths-ignore: + - '**/*.md' + - 'docs/**' schedule: - cron: '50 7 * * 5' +permissions: + contents: read + +concurrency: + group: codeql-${{ github.ref }} + cancel-in-progress: true + jobs: analyze: name: Analyze - runs-on: ubuntu-latest + runs-on: ubuntu-24.04 + timeout-minutes: 10 permissions: - actions: read contents: read security-events: write - strategy: fail-fast: false matrix: - language: [javascript] - + language: [actions, javascript] steps: - name: Checkout uses: actions/checkout@v4 + with: + persist-credentials: false - name: Initialize CodeQL - uses: github/codeql-action/init@v2 + uses: github/codeql-action/init@v3 with: languages: ${{ matrix.language }} queries: +security-and-quality - name: Autobuild - uses: github/codeql-action/autobuild@v2 + uses: github/codeql-action/autobuild@v3 - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@v2 + uses: github/codeql-action/analyze@v3 with: category: '/language:${{ matrix.language }}' diff --git a/.github/workflows/conflict_labeler.yml b/.github/workflows/conflict_labeler.yml index 3e3d00f18b..a9c885d0f3 100644 --- a/.github/workflows/conflict_labeler.yml +++ b/.github/workflows/conflict_labeler.yml @@ -2,18 +2,24 @@ name: Merge Conflict Labeler on: push: - branches: - - develop + branches: [develop] + pull_request_target: - branches: - - develop - types: [synchronize] + branches: [develop] + types: [opened, synchronize, reopened] + +permissions: + contents: read + +concurrency: + group: merge-conflict-${{ github.ref }} + cancel-in-progress: true jobs: label: name: Labeling - runs-on: ubuntu-latest - if: ${{ github.repository == 'Fallenbagel/jellyseerr' }} + runs-on: ubuntu-24.04 + timeout-minutes: 10 permissions: contents: read pull-requests: write diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index 6f8e2d8af3..72871db597 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -2,26 +2,48 @@ name: Cypress Tests on: pull_request: - branches: - - '*' + branches: ['*'] + paths-ignore: + - '**/*.md' + - 'docs/**' push: - branches: - - develop + branches: [develop] + paths-ignore: + - '**/*.md' + - 'docs/**' + +permissions: + contents: read + +concurrency: + group: cypress-${{ github.ref }} + cancel-in-progress: true jobs: cypress-run: - runs-on: ubuntu-latest + name: Cypress Run + runs-on: ubuntu-24.04 steps: - name: Checkout uses: actions/checkout@v4 + with: + persist-credentials: false + - name: Set up Node.js uses: actions/setup-node@v4 with: - node-version: 22 + node-version-file: package.json + + - name: Get PNPM version from package.json + id: pnpm-version + shell: bash + run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT + - name: Pnpm Setup uses: pnpm/action-setup@v4 with: - version: 9 + version: ${{ steps.pnpm-version.outputs.pnpm_version }} + - name: Cypress run uses: cypress-io/github-action@v6 with: @@ -36,6 +58,7 @@ jobs: # Fix test titles in cypress dashboard COMMIT_INFO_MESSAGE: ${{github.event.pull_request.title}} COMMIT_INFO_SHA: ${{github.event.pull_request.head.sha}} + - name: Upload video files if: always() uses: actions/upload-artifact@v4 diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index 6d9adb8a87..e542bb6b39 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -8,24 +8,38 @@ on: - 'docs/**' - 'gen-docs/**' +permissions: + contents: read + +concurrency: + group: pages + cancel-in-progress: true + jobs: build: name: Build Docusaurus - runs-on: ubuntu-latest + runs-on: ubuntu-24.04 steps: - uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false - name: Set up Node.js uses: actions/setup-node@v4 with: - node-version: 20 + node-version-file: package.json + cache: 'pnpm' + + - name: Get PNPM version from package.json + id: pnpm-version + shell: bash + run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - name: Pnpm Setup uses: pnpm/action-setup@v4 with: - version: 9 + version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Get pnpm store directory shell: sh @@ -46,38 +60,26 @@ jobs: pnpm install --frozen-lockfile - name: Build website - run: | - cd gen-docs - pnpm build + working-directory: gen-docs + run: pnpm build - name: Upload Build Artifact - uses: actions/upload-pages-artifact@v3 + uses: actions/upload-pages-artifact@v4 with: path: gen-docs/build deploy: name: Deploy to GitHub Pages needs: build - concurrency: build-deploy-pages - - # Grant GITHUB_TOKEN the permissions required to make a Pages deployment + runs-on: ubuntu-24.04 permissions: - pages: write # to deploy to Pages - id-token: write # to verify the deployment originates from an appropriate source - - # Deploy to the github-pages environment + contents: read + pages: write + id-token: write environment: name: github-pages url: ${{ steps.deployment.outputs.page_url }} - - runs-on: ubuntu-latest steps: - # - name: Download Build Artifact - # uses: actions/download-artifact@v4 - # with: - # name: docusaurus-build - # path: gen-docs/build - - name: Deploy to GitHub Pages id: deployment uses: actions/deploy-pages@v4 diff --git a/.github/workflows/helm.yml b/.github/workflows/helm.yml index 131e6102f1..914264c681 100644 --- a/.github/workflows/helm.yml +++ b/.github/workflows/helm.yml @@ -4,11 +4,21 @@ on: push: branches: - develop + paths: + - 'charts/**' + - '.github/workflows/release-charts.yml' + +permissions: + contents: read + +concurrency: + group: helm-charts + cancel-in-progress: true jobs: package-helm-chart: name: Package helm chart - runs-on: ubuntu-latest + runs-on: ubuntu-24.04 permissions: contents: read packages: read @@ -19,6 +29,7 @@ jobs: uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false - name: Install helm uses: azure/setup-helm@v4 @@ -42,16 +53,11 @@ jobs: # get current version current_version=$(grep '^version:' "$chart_path/Chart.yaml" | awk '{print $2}') # try to get current release version - set +e - oras discover ghcr.io/${GITHUB_REPOSITORY@L}/${chart_name}:${current_version} - oras_exit_code=$? - set -e - - if [ $oras_exit_code -ne 0 ]; then + if oras manifest fetch "ghcr.io/${GITHUB_REPOSITORY@L}/${chart_name}:${current_version}" >/dev/null 2>&1; then + echo "No version change for $chart_name. Skipping." + else helm dependency build "$chart_path" helm package "$chart_path" --destination ./.cr-release-packages - else - echo "No version change for $chart_name. Skipping." fi else echo "Skipping $chart_name: Not a valid Helm chart" @@ -61,7 +67,7 @@ jobs: - name: Check if artifacts exist id: check-artifacts run: | - if ls .cr-release-packages/* >/dev/null 2>&1; then + if ls .cr-release-packages/*.tgz >/dev/null 2>&1; then echo "has_artifacts=true" >> $GITHUB_OUTPUT else echo "has_artifacts=false" >> $GITHUB_OUTPUT @@ -77,7 +83,7 @@ jobs: publish: name: Publish to ghcr.io - runs-on: ubuntu-latest + runs-on: ubuntu-24.04 permissions: packages: write # needed for pushing to github registry id-token: write # needed for signing the images with GitHub OIDC Token @@ -88,6 +94,7 @@ jobs: uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false - name: Install helm uses: azure/setup-helm@v4 diff --git a/.github/workflows/lint-helm-charts.yml b/.github/workflows/lint-helm-charts.yml index e46a11eecf..585dbb902b 100644 --- a/.github/workflows/lint-helm-charts.yml +++ b/.github/workflows/lint-helm-charts.yml @@ -7,27 +7,48 @@ on: paths: - '.github/workflows/lint-helm-charts.yml' - 'charts/**' + push: + branches: [develop] + paths: + - 'charts/**' + +permissions: + contents: read + +concurrency: + group: charts-lint-${{ github.ref }} + cancel-in-progress: true + jobs: lint-test: - runs-on: ubuntu-latest + runs-on: ubuntu-24.04 + permissions: + contents: read steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false + - name: Set up Helm - uses: azure/setup-helm@v4.2.0 + uses: azure/setup-helm@v4 + + - name: Set up chart-testing + uses: helm/chart-testing-action@v2 + - name: Ensure documentation is updated uses: docker://jnorwood/helm-docs:v1.14.2 - - name: Set up chart-testing - uses: helm/chart-testing-action@v2.6.1 + - name: Run chart-testing (list-changed) id: list-changed run: | changed=$(ct list-changed --target-branch ${{ github.event.repository.default_branch }}) if [[ -n "$changed" ]]; then echo "changed=true" >> "$GITHUB_OUTPUT" + echo "$changed" fi + - name: Run chart-testing if: steps.list-changed.outputs.changed == 'true' run: ct lint --target-branch ${{ github.event.repository.default_branch }} --validate-maintainers=false diff --git a/.github/workflows/preview.yml b/.github/workflows/preview.yml index 0084f27b4c..51f3b52dde 100644 --- a/.github/workflows/preview.yml +++ b/.github/workflows/preview.yml @@ -4,28 +4,125 @@ on: push: tags: - 'preview-*' + workflow_dispatch: + +permissions: + contents: read + +concurrency: + group: preview-${{ github.ref }} + cancel-in-progress: true jobs: - build_and_push: - name: Build & Publish Docker Preview Images - runs-on: ubuntu-22.04 + build: + name: Build (per-arch, native runners) + strategy: + matrix: + include: + - runner: ubuntu-24.04 + platform: linux/amd64 + arch: amd64 + - runner: ubuntu-24.04-arm + platform: linux/arm64 + arch: arm64 + runs-on: ${{ matrix.runner }} steps: - name: Checkout uses: actions/checkout@v4 - - name: Get the version - id: get_version - run: echo "VERSION=${GITHUB_REF#refs/tags/}" >> $GITHUB_OUTPUT - - name: Set up QEMU - uses: docker/setup-qemu-action@v3 + with: + persist-credentials: false + + - name: Commit timestamp + id: ts + run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" + - name: Set up Docker Buildx uses: docker/setup-buildx-action@v3 + + - name: Derive preview version from tag + id: ver + shell: bash + run: | + TAG="${GITHUB_REF_NAME}" + VER="${TAG#preview-}" + VER="${VER#v}" + echo "version=${VER}" >> "$GITHUB_OUTPUT" + echo "Building preview version: ${VER}" + + - name: Warm cache (no push) — ${{ matrix.platform }} + uses: docker/build-push-action@v6 + with: + context: . + file: ./Dockerfile + platforms: ${{ matrix.platform }} + push: false + build-args: | + COMMIT_TAG=${{ github.sha }} + BUILD_VERSION=${{ steps.ver.outputs.version }} + SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} + cache-from: type=gha,scope=${{ matrix.platform }} + cache-to: type=gha,mode=max,scope=${{ matrix.platform }} + provenance: false + + publish: + name: Publish multi-arch image + needs: build + runs-on: ubuntu-24.04 + permissions: + contents: read + packages: write + id-token: write + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Commit timestamp + id: ts + run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + - name: Log in to Docker Hub uses: docker/login-action@v3 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - - name: Build and push - uses: docker/build-push-action@v5 + + - name: Log in to GitHub Container Registry + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Derive preview version from tag + id: ver + shell: bash + run: | + TAG="${GITHUB_REF_NAME}" + VER="${TAG#preview-}" + VER="${VER#v}" + echo "version=${VER}" >> "$GITHUB_OUTPUT" + echo "Publishing preview version: ${VER}" + + - name: Extract metadata + id: meta + uses: docker/metadata-action@v5 + with: + images: | + ${{ github.repository }} + ghcr.io/${{ github.repository }} + tags: | + type=raw,value=preview-${{ steps.ver.outputs.version }} + labels: | + org.opencontainers.image.version=preview-${{ steps.ver.outputs.version }} + org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} + + - name: Build & Push (multi-arch, single tag) + uses: docker/build-push-action@v6 with: context: . file: ./Dockerfile @@ -33,7 +130,12 @@ jobs: push: true build-args: | COMMIT_TAG=${{ github.sha }} - BUILD_VERSION=${{ steps.get_version.outputs.VERSION }} - BUILD_DATE=${{ github.event.repository.updated_at }} - tags: | - fallenbagel/jellyseerr:${{ steps.get_version.outputs.VERSION }} + BUILD_VERSION=${{ steps.ver.outputs.version }} + SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} + labels: ${{ steps.meta.outputs.labels }} + tags: ${{ steps.meta.outputs.tags }} + cache-from: | + type=gha,scope=linux/amd64 + type=gha,scope=linux/arm64 + cache-to: type=gha,mode=max + provenance: false diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index d0c36976dc..dd06c2a87f 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,6 +1,14 @@ -name: Jellyseer Release +name: Jellyseerr Release -on: workflow_dispatch +on: + workflow_dispatch: + +permissions: + contents: read + +concurrency: + group: release-${{ github.ref }} + cancel-in-progress: true jobs: semantic-release: @@ -8,38 +16,37 @@ jobs: runs-on: ubuntu-22.04 env: HUSKY: 0 + outputs: + new_release_published: ${{ steps.release.outputs.new_release_published }} + new_release_version: ${{ steps.release.outputs.new_release_version }} steps: - name: Checkout uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false + - name: Set up Node.js uses: actions/setup-node@v4 with: - node-version: 22 - - name: Set up QEMU - uses: docker/setup-qemu-action@v3 - - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 - - name: Log in to Docker Hub - uses: docker/login-action@v3 - with: - username: ${{ secrets.DOCKER_USERNAME }} - password: ${{ secrets.DOCKER_TOKEN }} - - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 - with: - registry: ghcr.io - username: ${{ github.repository_owner }} - password: ${{ secrets.GH_TOKEN }} + node-version-file: package.json + cache: 'pnpm' + + - name: Get PNPM version from package.json + id: pnpm-version + shell: bash + run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT + - name: Pnpm Setup uses: pnpm/action-setup@v4 with: - version: 9 + version: ${{ steps.pnpm-version.outputs.pnpm_version }} + - name: Get pnpm store directory shell: sh run: | echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV + - name: Setup pnpm cache uses: actions/cache@v4 with: @@ -47,77 +54,151 @@ jobs: key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} restore-keys: | ${{ runner.os }}-pnpm-store- + - name: Install dependencies run: pnpm install + - name: Release + id: release + uses: cycjimmy/semantic-release-action@v5 + with: + extra_plugins: | + @semantic-release/git@10 + @semantic-release/changelog@6 + @codedependant/semantic-release-docker@5 env: GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} - DOCKER_USERNAME: ${{ secrets.DOCKER_USERNAME }} - DOCKER_PASSWORD: ${{ secrets.DOCKER_PASSWORD }} - run: npx semantic-release - - # build-snap: - # name: Build Snap Package (${{ matrix.architecture }}) - # needs: semantic-release - # runs-on: ubuntu-22.04 - # strategy: - # fail-fast: false - # matrix: - # architecture: - # - amd64 - # - arm64 - # steps: - # - name: Checkout Code - # uses: actions/checkout@v4 - # with: - # fetch-depth: 0 - # - name: Switch to main branch - # run: git checkout main - # - name: Pull latest changes - # run: git pull - # - name: Prepare - # id: prepare - # run: | - # git fetch --prune --tags - # if [[ $GITHUB_REF == refs/tags/* || $GITHUB_REF == refs/heads/master ]]; then - # echo "RELEASE=stable" >> $GITHUB_OUTPUT - # else - # echo "RELEASE=edge" >> $GITHUB_OUTPUT - # fi - # - name: Set Up QEMU - # uses: docker/setup-qemu-action@v3 - # with: - # image: tonistiigi/binfmt@sha256:df15403e06a03c2f461c1f7938b171fda34a5849eb63a70e2a2109ed5a778bde - # - name: Build Snap Package - # uses: diddlesnaps/snapcraft-multiarch-action@v1 - # id: build - # with: - # architecture: ${{ matrix.architecture }} - # - name: Upload Snap Package - # uses: actions/upload-artifact@v4 - # with: - # name: jellyseerr-snap-package-${{ matrix.architecture }} - # path: ${{ steps.build.outputs.snap }} - # - name: Review Snap Package - # uses: diddlesnaps/snapcraft-review-tools-action@v1 - # with: - # snap: ${{ steps.build.outputs.snap }} - # - name: Publish Snap Package - # uses: snapcore/action-publish@v1 - # env: - # SNAPCRAFT_STORE_CREDENTIALS: ${{ secrets.SNAP_LOGIN }} - # with: - # snap: ${{ steps.build.outputs.snap }} - # release: ${{ steps.prepare.outputs.RELEASE }} + + build: + name: Build (per-arch, native runners) + needs: semantic-release + if: needs.semantic-release.outputs.new_release_published == 'true' + strategy: + matrix: + include: + - runner: ubuntu-24.04 + platform: linux/amd64 + arch: amd64 + - runner: ubuntu-24.04-arm + platform: linux/arm64 + arch: arm64 + runs-on: ${{ matrix.runner }} + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Commit timestamp + id: ts + run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + + - name: Warm cache (no push) — ${{ matrix.platform }} + uses: docker/build-push-action@v6 + with: + context: . + file: ./Dockerfile + platforms: ${{ matrix.platform }} + push: false + build-args: | + COMMIT_TAG=${{ github.sha }} + BUILD_VERSION=${{ needs.semantic-release.outputs.new_release_version }} + SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} + cache-from: type=gha,scope=${{ matrix.platform }} + cache-to: type=gha,mode=max,scope=${{ matrix.platform }} + provenance: false + + publish: + name: Publish multi-arch image + needs: [semantic-release, build] + if: needs.semantic-release.outputs.new_release_published == 'true' + runs-on: ubuntu-24.04 + permissions: + contents: read + id-token: write + packages: write + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Commit timestamp + id: ts + run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" + + - name: Set up Docker Buildx + uses: docker/setup-buildx-action@v3 + + - name: Log in to Docker Hub + uses: docker/login-action@v3 + with: + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_TOKEN }} + + - name: Log in to GitHub Container Registry + uses: docker/login-action@v3 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Extract metadata + id: meta + uses: docker/metadata-action@v5 + with: + images: | + ${{ github.repository }} + ghcr.io/${{ github.repository }} + tags: | + type=raw,value=${{ needs.semantic-release.outputs.new_release_version }} + labels: | + org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} + + - name: Build & Push (multi-arch, single tag) + uses: docker/build-push-action@v6 + with: + context: . + file: ./Dockerfile + platforms: linux/amd64,linux/arm64 + push: true + build-args: | + COMMIT_TAG=${{ github.sha }} + BUILD_VERSION=${{ needs.semantic-release.outputs.new_release_version }} + SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} + labels: ${{ steps.meta.outputs.labels }} + tags: ${{ steps.meta.outputs.tags }} + cache-from: | + type=gha,scope=linux/amd64 + type=gha,scope=linux/arm64 + cache-to: type=gha,mode=max + provenance: false + + - name: Also tag :latest (non-pre-release only) + shell: bash + run: | + VER="${{ needs.semantic-release.outputs.new_release_version }}" + if [[ "$VER" != *"-"* ]]; then + docker buildx imagetools create \ + -t ${{ github.repository }}:latest \ + ${{ github.repository }}:${VER} + docker buildx imagetools create \ + -t ghcr.io/${{ github.repository }}:latest \ + ghcr.io/${{ github.repository }}:${VER} + fi discord: name: Send Discord Notification - needs: semantic-release + needs: publish if: always() - runs-on: ubuntu-22.04 + runs-on: ubuntu-24.04 steps: - name: Get Build Job Status uses: technote-space/workflow-conclusion-action@v3 + - name: Combine Job Status id: status run: | @@ -127,6 +208,7 @@ jobs: else echo "status=$WORKFLOW_CONCLUSION" >> $GITHUB_OUTPUT fi + - name: Post Status to Discord uses: sarisia/actions-status-discord@v1 with: diff --git a/.github/workflows/snap.yaml.disabled b/.github/workflows/snap.yaml.disabled deleted file mode 100644 index 70d577c911..0000000000 --- a/.github/workflows/snap.yaml.disabled +++ /dev/null @@ -1,94 +0,0 @@ -name: Publish Snap - -# turn off edge snap builds temporarily and make it manual - -# on: -# push: -# branches: -# - develop - -on: workflow_dispatch - -jobs: - jobs: - name: Job Check - runs-on: ubuntu-22.04 - if: "!contains(github.event.head_commit.message, '[skip ci]')" - steps: - - name: Cancel Previous Runs - uses: styfle/cancel-workflow-action@0.12.1 - with: - access_token: ${{ secrets.GITHUB_TOKEN }} - - build-snap: - name: Build Snap Package (${{ matrix.architecture }}) - needs: jobs - runs-on: ubuntu-22.04 - strategy: - fail-fast: false - matrix: - architecture: - - amd64 - - arm64 - steps: - - name: Checkout Code - uses: actions/checkout@v4 - - name: Prepare - id: prepare - run: | - git fetch --prune --unshallow --tags - if [[ $GITHUB_REF == refs/tags/* || $GITHUB_REF == refs/heads/master ]]; then - echo "RELEASE=stable" >> $GITHUB_OUTPUT - else - echo "RELEASE=edge" >> $GITHUB_OUTPUT - fi - - name: Set Up QEMU - uses: docker/setup-qemu-action@v3 - - name: Configure Git - run: git config --add safe.directory /data/parts/jellyseerr/src - - name: Build Snap Package - uses: diddlesnaps/snapcraft-multiarch-action@v1 - id: build - with: - architecture: ${{ matrix.architecture }} - - name: Upload Snap Package - uses: actions/upload-artifact@v4 - with: - name: jellyseerr-snap-package-${{ matrix.architecture }} - path: ${{ steps.build.outputs.snap }} - - name: Review Snap Package - uses: diddlesnaps/snapcraft-review-tools-action@v1 - with: - snap: ${{ steps.build.outputs.snap }} - - name: Publish Snap Package - uses: snapcore/action-publish@v1 - env: - SNAPCRAFT_STORE_CREDENTIALS: ${{ secrets.SNAP_LOGIN }} - with: - snap: ${{ steps.build.outputs.snap }} - release: ${{ steps.prepare.outputs.RELEASE }} - - discord: - name: Send Discord Notification - needs: build-snap - if: always() && !contains(github.event.head_commit.message, '[skip ci]') - runs-on: ubuntu-22.04 - steps: - - name: Get Build Job Status - uses: technote-space/workflow-conclusion-action@v3 - - name: Combine Job Status - id: status - run: | - failures=(neutral, skipped, timed_out, action_required) - if [[ ${array[@]} =~ $WORKFLOW_CONCLUSION ]]; then - echo "status=failure" >> $GITHUB_OUTPUT - else - echo "status=$WORKFLOW_CONCLUSION" >> $GITHUB_OUTPUT - fi - - name: Post Status to Discord - uses: sarisia/actions-status-discord@v1 - with: - webhook: ${{ secrets.DISCORD_WEBHOOK }} - status: ${{ steps.status.outputs.status }} - title: ${{ github.workflow }} - nofail: true diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index fd81754d66..3589de9864 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -4,15 +4,27 @@ on: issues: types: [labeled, unlabeled, reopened] +permissions: {} + +concurrency: + group: support-${{ github.ref }} + cancel-in-progress: true + jobs: support: - runs-on: ubuntu-latest + if: github.event.label.name == 'support' + runs-on: ubuntu-24.04 + permissions: + issues: write + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + GH_REPO: ${{ github.repository }} + NUMBER: ${{ github.event.issue.number }} steps: - - uses: dessant/support-requests@v4 - with: - github-token: ${{ github.token }} - support-label: 'support' - issue-comment: > + - name: Comment and close issue + run: gh issue close "$NUMBER" -r "off-topic" -c "$BODY" + env: + BODY: > :wave: @{issue-author}, we use the issue tracker exclusively for bug reports and feature requests. However, this issue appears to be a support request. Please use our support channels @@ -20,6 +32,5 @@ jobs: - [Discord](https://discord.gg/ckbvBtDJgC) - close-issue: true - lock-issue: true - issue-lock-reason: 'off-topic' + - name: Lock issue + run: gh issue lock "$NUMBER" -r "off_topic" diff --git a/.github/workflows/test-docs-deploy.yml b/.github/workflows/test-docs-deploy.yml index 5526af0941..e447e46c70 100644 --- a/.github/workflows/test-docs-deploy.yml +++ b/.github/workflows/test-docs-deploy.yml @@ -8,24 +8,39 @@ on: - 'docs/**' - 'gen-docs/**' +permissions: + contents: read + +concurrency: + group: docs-pr-${{ github.ref }} + cancel-in-progress: true + jobs: test-deploy: name: Test deployment - runs-on: ubuntu-latest + runs-on: ubuntu-24.04 + permissions: + contents: read steps: - uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false - name: Set up Node.js uses: actions/setup-node@v4 with: - node-version: 20 + node-version-file: package.json + + - name: Get PNPM version from package.json + id: pnpm-version + shell: bash + run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - name: Pnpm Setup uses: pnpm/action-setup@v4 with: - version: 9 + version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Get pnpm store directory shell: sh @@ -42,7 +57,7 @@ jobs: - name: Install dependencies run: | - cd gen-docs + cd gen-docs pnpm install --frozen-lockfile - name: Build website diff --git a/.vscode/settings.json b/.vscode/settings.json index 589cec3680..dbb4a2ccf8 100644 --- a/.vscode/settings.json +++ b/.vscode/settings.json @@ -20,5 +20,8 @@ "files.associations": { "globals.css": "tailwindcss" }, - "i18n-ally.localesPaths": ["src/i18n/locale"] + "i18n-ally.localesPaths": [ + "src/i18n/locale" + ], + "yaml.format.singleQuote": true } diff --git a/Dockerfile b/Dockerfile index bb2776547a..f331b62dbe 100644 --- a/Dockerfile +++ b/Dockerfile @@ -2,8 +2,11 @@ FROM node:22-alpine AS BUILD_IMAGE WORKDIR /app +ARG SOURCE_DATE_EPOCH ARG TARGETPLATFORM +ARG COMMIT_TAG ENV TARGETPLATFORM=${TARGETPLATFORM:-linux/amd64} +ENV COMMIT_TAG=${COMMIT_TAG} RUN \ case "${TARGETPLATFORM}" in \ @@ -20,36 +23,16 @@ COPY package.json pnpm-lock.yaml postinstall-win.js ./ RUN CYPRESS_INSTALL_BINARY=0 pnpm install --frozen-lockfile COPY . ./ - -ARG COMMIT_TAG -ENV COMMIT_TAG=${COMMIT_TAG} - RUN pnpm build # remove development dependencies -RUN pnpm prune --prod --ignore-scripts - -RUN rm -rf src server .next/cache charts gen-docs docs - -RUN touch config/DOCKER - -RUN echo "{\"commitTag\": \"${COMMIT_TAG}\"}" > committag.json - +RUN pnpm prune --prod --ignore-scripts && \ + rm -rf src server .next/cache charts gen-docs docs && \ + touch config/DOCKER && \ + echo "{\"commitTag\": \"${COMMIT_TAG}\"}" > committag.json FROM node:22-alpine -# OCI Meta information -ARG BUILD_DATE -ARG BUILD_VERSION -LABEL \ - org.opencontainers.image.authors="Fallenbagel" \ - org.opencontainers.image.source="https://github.com/fallenbagel/jellyseerr" \ - org.opencontainers.image.created=${BUILD_DATE} \ - org.opencontainers.image.version=${BUILD_VERSION} \ - org.opencontainers.image.title="Jellyseerr" \ - org.opencontainers.image.description="Open-source media request and discovery manager for Jellyfin, Plex, and Emby." \ - org.opencontainers.image.licenses="MIT" - WORKDIR /app RUN apk add --no-cache tzdata tini && rm -rf /tmp/* diff --git a/package.json b/package.json index 224ab91b05..f95dcdc984 100644 --- a/package.json +++ b/package.json @@ -2,6 +2,7 @@ "name": "jellyseerr", "version": "0.1.0", "private": true, + "packageManager": "pnpm@9.0.0", "scripts": { "preinstall": "npx only-allow pnpm", "postinstall": "node postinstall-win.js", @@ -116,11 +117,8 @@ "zod": "3.24.2" }, "devDependencies": { - "@codedependant/semantic-release-docker": "^5.1.0", "@commitlint/cli": "17.4.4", "@commitlint/config-conventional": "17.4.4", - "@semantic-release/changelog": "6.0.3", - "@semantic-release/git": "10.0.1", "@tailwindcss/aspect-ratio": "0.4.2", "@tailwindcss/forms": "0.5.10", "@tailwindcss/typography": "0.5.16", @@ -170,7 +168,6 @@ "prettier": "2.8.4", "prettier-plugin-organize-imports": "3.2.2", "prettier-plugin-tailwindcss": "0.2.3", - "semantic-release": "24.2.7", "tailwindcss": "3.2.7", "ts-node": "10.9.1", "tsc-alias": "1.8.2", @@ -178,8 +175,7 @@ "typescript": "4.9.5" }, "engines": { - "node": "^22.0.0", - "pnpm": "^9.0.0" + "node": "^22.0.0" }, "overrides": { "sqlite3/node-gyp": "8.4.1", @@ -208,28 +204,12 @@ "plugins": [ "@semantic-release/commit-analyzer", "@semantic-release/release-notes-generator", - [ - "@semantic-release/changelog", - { - "changelogFile": "CHANGELOG.md" - } - ], "@semantic-release/npm", - [ - "@semantic-release/git", - { - "assets": [ - "package.json", - "CHANGELOG.md" - ], - "message": "chore(release): ${nextRelease.version}" - } - ], [ "@codedependant/semantic-release-docker", { "dockerArgs": { - "COMMIT_TAG": "$GIT_SHA" + "COMMIT_TAG": "${GITHUB_SHA}" }, "dockerLogin": false, "dockerProject": "fallenbagel", @@ -250,7 +230,7 @@ "@codedependant/semantic-release-docker", { "dockerArgs": { - "COMMIT_TAG": "$GIT_SHA" + "COMMIT_TAG": "${GITHUB_SHA}" }, "dockerLogin": false, "dockerRegistry": "ghcr.io", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 768fd450a3..5247889dad 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -255,21 +255,12 @@ importers: specifier: 3.24.2 version: 3.24.2 devDependencies: - '@codedependant/semantic-release-docker': - specifier: ^5.1.0 - version: 5.1.0 '@commitlint/cli': specifier: 17.4.4 version: 17.4.4(@swc/core@1.6.5(@swc/helpers@0.5.11)) '@commitlint/config-conventional': specifier: 17.4.4 version: 17.4.4 - '@semantic-release/changelog': - specifier: 6.0.3 - version: 6.0.3(semantic-release@24.2.7(typescript@4.9.5)) - '@semantic-release/git': - specifier: 10.0.1 - version: 10.0.1(semantic-release@24.2.7(typescript@4.9.5)) '@tailwindcss/aspect-ratio': specifier: 0.4.2 version: 0.4.2(tailwindcss@3.2.7(postcss@8.4.31)(ts-node@10.9.1(@swc/core@1.6.5(@swc/helpers@0.5.11))(@types/node@22.10.5)(typescript@4.9.5))) @@ -417,9 +408,6 @@ importers: prettier-plugin-tailwindcss: specifier: 0.2.3 version: 0.2.3(prettier-plugin-organize-imports@3.2.2(prettier@2.8.4)(typescript@4.9.5))(prettier@2.8.4) - semantic-release: - specifier: 24.2.7 - version: 24.2.7(typescript@4.9.5) tailwindcss: specifier: 3.2.7 version: 3.2.7(postcss@8.4.31)(ts-node@10.9.1(@swc/core@1.6.5(@swc/helpers@0.5.11))(@types/node@22.10.5)(typescript@4.9.5)) @@ -438,18 +426,6 @@ importers: packages: - '@actions/core@1.11.1': - resolution: {integrity: sha512-hXJCSrkwfA46Vd9Z3q4cpEpHB1rL5NG04+/rbqW9d3+CSvtB1tYe8UTpAlixa1vj0m/ULglfEK2UKxMGxCxv5A==} - - '@actions/exec@1.1.1': - resolution: {integrity: sha512-+sCcHHbVdk93a0XT19ECtO/gIXoxvdsgQLzb2fE2/5sIZmWQuluYyjPQtrtTHdU1YzTZ7bAPN4sITq2xi1679w==} - - '@actions/http-client@2.2.3': - resolution: {integrity: sha512-mx8hyJi/hjFvbPokCg4uRd4ZX78t+YyRPtnKWwIl+RzNaVuFpQHfmlGVfsKEJN8LwTCvL+DfVgAM04XaHkm6bA==} - - '@actions/io@1.1.3': - resolution: {integrity: sha512-wi9JjgKLYS7U/z8PPbco+PvTb/nRWjeoFlJ1Qer83k/3C5PHQi28hiVdeE2kHXmIL99mQFawx8qt/JPjZilJ8Q==} - '@ampproject/remapping@2.3.0': resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} engines: {node: '>=6.0.0'} @@ -461,10 +437,6 @@ packages: resolution: {integrity: sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==} engines: {node: '>=6.9.0'} - '@babel/code-frame@7.26.2': - resolution: {integrity: sha512-RJlIHRueQgwWitWgF8OdFYGZX328Ax5BCemNGlqHfplnRT9ESi8JkFlvaVYbS+UubVY6dpv87Fs2u5M29iNFVQ==} - engines: {node: '>=6.9.0'} - '@babel/code-frame@7.27.1': resolution: {integrity: sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg==} engines: {node: '>=6.9.0'} @@ -1490,9 +1462,6 @@ packages: resolution: {integrity: sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==} engines: {node: '>=6.9.0'} - '@codedependant/semantic-release-docker@5.1.0': - resolution: {integrity: sha512-Ok37Hrj3y2AeZA4nBHzXNPR+twZHbAnGY2vXV3V3MC9xP676PnP67eBpzP5zLodxBXqRFKixo8QiQhQJ8nnXbQ==} - '@colors/colors@1.5.0': resolution: {integrity: sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==} engines: {node: '>=0.1.90'} @@ -1607,6 +1576,7 @@ packages: '@dr.pogodin/csurf@1.14.1': resolution: {integrity: sha512-ijqJsKSDlepDYbprkEEcqbiYero2y4DeL4X5ivnkbKonliLtH8SfHCEtdUwoRZLPTUy2WeFPHI+gveU+Z8ZxLA==} engines: {node: '>= 18'} + deprecated: 'Update to v1.15.0: see https://github.com/birdofpreyru/csurf/releases/tag/v1.15.0' '@emnapi/runtime@1.2.0': resolution: {integrity: sha512-bV21/9LQmcQeCPEg3BDFtvwL6cwiTMksYNWQQ4KOxCZikEGalWtenoZ0wCiukJINlGCIi2KXx01g4FoH/LxpzQ==} @@ -1695,10 +1665,6 @@ packages: resolution: {integrity: sha512-JXdzbRiWclLVoD8sNUjR443VVlYqiYmDVT6rGUEIEHU5YJW0gaVZwV2xgM7D4arkvASqD0IlLUVjHiFuxaftRw==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} - '@fastify/busboy@2.1.1': - resolution: {integrity: sha512-vBZP4NlzfOlerQTnba4aqZoMhE/a9HY7HRqoOPaETQcSQuWEIyZMHGfVu6w9wGtGK5fED5qRs2DteVCjOH60sA==} - engines: {node: '>=14'} - '@floating-ui/core@1.6.2': resolution: {integrity: sha512-+2XpQV9LLZeanU4ZevzRnGFg2neDeKHgFLjP6YLW+tly0IvrhqT4u8enLGjLH3qeh85g19xY5rsAusfwTdn5lg==} @@ -1770,6 +1736,7 @@ packages: '@formatjs/swc-plugin-experimental@0.4.0': resolution: {integrity: sha512-LMepVQLKpWbU29rBXoNgJilr+nmRq7x9Uz1Oh5bL32EX4dg7bSLGWiPYv/X2wKjmFNLs1zD7YFebwsVmNds6hA==} + deprecated: Please use @swc/plugin-formatjs peerDependencies: '@swc/core': ^1.6.0 @@ -2286,70 +2253,10 @@ packages: engines: {node: ^12.13.0 || ^14.15.0 || >=16.0.0} deprecated: This functionality has been moved to @npmcli/fs - '@octokit/auth-token@6.0.0': - resolution: {integrity: sha512-P4YJBPdPSpWTQ1NU4XYdvHvXJJDxM6YwpS0FZHRgP7YFkdVxsWcpWGy/NVqlAA7PcPCnMacXlRm1y2PFZRWL/w==} - engines: {node: '>= 20'} - - '@octokit/core@7.0.3': - resolution: {integrity: sha512-oNXsh2ywth5aowwIa7RKtawnkdH6LgU1ztfP9AIUCQCvzysB+WeU8o2kyyosDPwBZutPpjZDKPQGIzzrfTWweQ==} - engines: {node: '>= 20'} - - '@octokit/endpoint@11.0.0': - resolution: {integrity: sha512-hoYicJZaqISMAI3JfaDr1qMNi48OctWuOih1m80bkYow/ayPw6Jj52tqWJ6GEoFTk1gBqfanSoI1iY99Z5+ekQ==} - engines: {node: '>= 20'} - - '@octokit/graphql@9.0.1': - resolution: {integrity: sha512-j1nQNU1ZxNFx2ZtKmL4sMrs4egy5h65OMDmSbVyuCzjOcwsHq6EaYjOTGXPQxgfiN8dJ4CriYHk6zF050WEULg==} - engines: {node: '>= 20'} - - '@octokit/openapi-types@25.1.0': - resolution: {integrity: sha512-idsIggNXUKkk0+BExUn1dQ92sfysJrje03Q0bv0e+KPLrvyqZF8MnBpFz8UNfYDwB3Ie7Z0TByjWfzxt7vseaA==} - - '@octokit/plugin-paginate-rest@13.1.1': - resolution: {integrity: sha512-q9iQGlZlxAVNRN2jDNskJW/Cafy7/XE52wjZ5TTvyhyOD904Cvx//DNyoO3J/MXJ0ve3rPoNWKEg5iZrisQSuw==} - engines: {node: '>= 20'} - peerDependencies: - '@octokit/core': '>=6' - - '@octokit/plugin-retry@8.0.1': - resolution: {integrity: sha512-KUoYR77BjF5O3zcwDQHRRZsUvJwepobeqiSSdCJ8lWt27FZExzb0GgVxrhhfuyF6z2B2zpO0hN5pteni1sqWiw==} - engines: {node: '>= 20'} - peerDependencies: - '@octokit/core': '>=7' - - '@octokit/plugin-throttling@11.0.1': - resolution: {integrity: sha512-S+EVhy52D/272L7up58dr3FNSMXWuNZolkL4zMJBNIfIxyZuUcczsQAU4b5w6dewJXnKYVgSHSV5wxitMSW1kw==} - engines: {node: '>= 20'} - peerDependencies: - '@octokit/core': ^7.0.0 - - '@octokit/request-error@7.0.0': - resolution: {integrity: sha512-KRA7VTGdVyJlh0cP5Tf94hTiYVVqmt2f3I6mnimmaVz4UG3gQV/k4mDJlJv3X67iX6rmN7gSHCF8ssqeMnmhZg==} - engines: {node: '>= 20'} - - '@octokit/request@10.0.3': - resolution: {integrity: sha512-V6jhKokg35vk098iBqp2FBKunk3kMTXlmq+PtbV9Gl3TfskWlebSofU9uunVKhUN7xl+0+i5vt0TGTG8/p/7HA==} - engines: {node: '>= 20'} - - '@octokit/types@14.1.0': - resolution: {integrity: sha512-1y6DgTy8Jomcpu33N+p5w58l6xyt55Ar2I91RPiIA0xCJBXyUAhXCcmZaDWSANiha7R9a6qJJ2CRomGPZ6f46g==} - '@pkgjs/parseargs@0.11.0': resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==} engines: {node: '>=14'} - '@pnpm/config.env-replace@1.1.0': - resolution: {integrity: sha512-htyl8TWnKL7K/ESFa1oW2UB5lVDxuF5DpM7tBi6Hu2LNL3mWkIzNLG6N4zoCUP1lCKNxWy/3iu8mS8MvToGd6w==} - engines: {node: '>=12.22.0'} - - '@pnpm/network.ca-file@1.0.2': - resolution: {integrity: sha512-YcPQ8a0jwYU9bTdJDpXjMi7Brhkr1mXsXrUJvjqM2mQDgkRiz8jFaQGOdaLxgjtUfQgZhKy/O3cG/YwmgKaxLA==} - engines: {node: '>=12.22.0'} - - '@pnpm/npm-conf@2.2.2': - resolution: {integrity: sha512-UA91GwWPhFExt3IizW6bOeY/pQ0BkuNwKjk9iQW9KqxluGCrg4VenZ0/L+2Y0+ZOtme72EVvg6v0zo3AMQRCeA==} - engines: {node: '>=12'} - '@popperjs/core@2.11.8': resolution: {integrity: sha512-P1st0aksCrn9sGZhp8GMYwBnQsbvAWsZAX44oXNNvLHGqAOcoVxmjZiohstwQ7SqKnbR47akdNi+uleWD8+g6A==} @@ -2993,56 +2900,9 @@ packages: '@rushstack/eslint-patch@1.10.3': resolution: {integrity: sha512-qC/xYId4NMebE6w/V33Fh9gWxLgURiNYgVNObbJl2LZv0GUUItCcCqC5axQSwRaAgaxl2mELq1rMzlswaQ0Zxg==} - '@sec-ant/readable-stream@0.4.1': - resolution: {integrity: sha512-831qok9r2t8AlxLko40y2ebgSDhenenCatLVeW/uBtnHPyhHOvG0C7TvfgecV+wHzIm5KUICgzmVpWS+IMEAeg==} - '@selderee/plugin-htmlparser2@0.11.0': resolution: {integrity: sha512-P33hHGdldxGabLFjPPpaTxVolMrzrcegejx+0GxjrIb9Zv48D8yAIA/QTDR2dFl7Uz7urX8aX6+5bCZslr+gWQ==} - '@semantic-release/changelog@6.0.3': - resolution: {integrity: sha512-dZuR5qByyfe3Y03TpmCvAxCyTnp7r5XwtHRf/8vD9EAn4ZWbavUX8adMtXYzE86EVh0gyLA7lm5yW4IV30XUag==} - engines: {node: '>=14.17'} - peerDependencies: - semantic-release: '>=18.0.0' - - '@semantic-release/commit-analyzer@13.0.1': - resolution: {integrity: sha512-wdnBPHKkr9HhNhXOhZD5a2LNl91+hs8CC2vsAVYxtZH3y0dV3wKn+uZSN61rdJQZ8EGxzWB3inWocBHV9+u/CQ==} - engines: {node: '>=20.8.1'} - peerDependencies: - semantic-release: '>=20.1.0' - - '@semantic-release/error@3.0.0': - resolution: {integrity: sha512-5hiM4Un+tpl4cKw3lV4UgzJj+SmfNIDCLLw0TepzQxz9ZGV5ixnqkzIVF+3tp0ZHgcMKE+VNGHJjEeyFG2dcSw==} - engines: {node: '>=14.17'} - - '@semantic-release/error@4.0.0': - resolution: {integrity: sha512-mgdxrHTLOjOddRVYIYDo0fR3/v61GNN1YGkfbrjuIKg/uMgCd+Qzo3UAXJ+woLQQpos4pl5Esuw5A7AoNlzjUQ==} - engines: {node: '>=18'} - - '@semantic-release/git@10.0.1': - resolution: {integrity: sha512-eWrx5KguUcU2wUPaO6sfvZI0wPafUKAMNC18aXY4EnNcrZL86dEmpNVnC9uMpGZkmZJ9EfCVJBQx4pV4EMGT1w==} - engines: {node: '>=14.17'} - peerDependencies: - semantic-release: '>=18.0.0' - - '@semantic-release/github@11.0.3': - resolution: {integrity: sha512-T2fKUyFkHHkUNa5XNmcsEcDPuG23hwBKptfUVcFXDVG2cSjXXZYDOfVYwfouqbWo/8UefotLaoGfQeK+k3ep6A==} - engines: {node: '>=20.8.1'} - peerDependencies: - semantic-release: '>=24.1.0' - - '@semantic-release/npm@12.0.2': - resolution: {integrity: sha512-+M9/Lb35IgnlUO6OSJ40Ie+hUsZLuph2fqXC/qrKn0fMvUU/jiCjpoL6zEm69vzcmaZJ8yNKtMBEKHWN49WBbQ==} - engines: {node: '>=20.8.1'} - peerDependencies: - semantic-release: '>=20.1.0' - - '@semantic-release/release-notes-generator@14.0.3': - resolution: {integrity: sha512-XxAZRPWGwO5JwJtS83bRdoIhCiYIx8Vhr+u231pQAsdFIAbm19rSVJLdnBN+Avvk7CKvNQE/nJ4y7uqKH6WTiw==} - engines: {node: '>=20.8.1'} - peerDependencies: - semantic-release: '>=20.1.0' - '@sideway/address@4.1.5': resolution: {integrity: sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==} @@ -3055,18 +2915,6 @@ packages: '@sinclair/typebox@0.27.8': resolution: {integrity: sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==} - '@sindresorhus/is@4.6.0': - resolution: {integrity: sha512-t09vSN3MdfsyCHoFcTRCH/iUtG7OJ0CsjzB8cjAmKc/va/kIgeDI/TxsigdncE/4be734m0cvIYwNaV4i2XqAw==} - engines: {node: '>=10'} - - '@sindresorhus/merge-streams@2.3.0': - resolution: {integrity: sha512-LtoMMhxAlorcGhmFYI+LhPgbPZCkgP6ra1YL604EeF6U98pLlQ3iWIGMdWSC+vWmPBWBNgmDBAhnAobLROJmwg==} - engines: {node: '>=18'} - - '@sindresorhus/merge-streams@4.0.0': - resolution: {integrity: sha512-tlqY9xq5ukxTUZBmoOp+m61cqwQD5pHJtFY3Mn8CA8ps6yghLH/Hw8UPdqg4OLmFW3IFlcXnQNmo/dh8HzXYIQ==} - engines: {node: '>=18'} - '@sinonjs/commons@3.0.1': resolution: {integrity: sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==} @@ -3704,10 +3552,6 @@ packages: resolution: {integrity: sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==} engines: {node: '>=8'} - aggregate-error@5.0.0: - resolution: {integrity: sha512-gOsf2YwSlleG6IjRYG2A7k0HmBMEo6qVNk9Bp/EaLgAJT5ngH6PXbqa4ItvnEwCm/velL5jAnQgsHsWnjhGmvw==} - engines: {node: '>=18'} - ajv@6.12.6: resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==} @@ -3729,10 +3573,6 @@ packages: resolution: {integrity: sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==} engines: {node: '>=8'} - ansi-escapes@7.0.0: - resolution: {integrity: sha512-GdYO7a61mR0fOlAsvC9/rIHf7L96sBc6dEWzeOu+KAea5bZyQRPIpojrVoI4AXGJS/ycu/fBTdLrUkA4ODrvjw==} - engines: {node: '>=18'} - ansi-fragments@0.2.1: resolution: {integrity: sha512-DykbNHxuXQwUDRv5ibc2b0x7uw7wmwOGLBUd5RmaQ5z8Lhx19vwvKV+FAsM5rEA6dEcHxX+/Ad5s9eF2k2bB+w==} @@ -3748,10 +3588,6 @@ packages: resolution: {integrity: sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==} engines: {node: '>=12'} - ansi-regex@6.1.0: - resolution: {integrity: sha512-7HSX4QQb4CspciLpVFwyRe79O3xsIZDDLER21kERQ71oaPodF8jL725AgJMFAYbooIqolJoRLuM81SpeUkpkvA==} - engines: {node: '>=12'} - ansi-styles@3.2.1: resolution: {integrity: sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==} engines: {node: '>=4'} @@ -3813,9 +3649,6 @@ packages: argparse@2.0.1: resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} - argv-formatter@1.0.0: - resolution: {integrity: sha512-F2+Hkm9xFaRg+GkaNnbwXNDV5O6pnCFEmqyhvfC/Ic5LbgOWjJh3L+mN/s91rxVL3znE7DYVpW0GJFT+4YBgWw==} - aria-query@5.1.3: resolution: {integrity: sha512-R5iJ5lkuHybztUfuOAznmboyjWq8O6sqNqtK7CLOqdydi54VNbORp49mb14KbWgG1QD3JFO9hJdZ+y4KutfdOQ==} @@ -4040,9 +3873,6 @@ packages: resolution: {integrity: sha512-RHBS7HI5N5tEnGTmtR/pppX0mmDSBpQ4aCBsj7CEQfYXDcO74A8sIBYcJMuCsis2E81zDxeENYhv66oZwLiA+Q==} engines: {node: '>= 10.0.0'} - before-after-hook@4.0.0: - resolution: {integrity: sha512-q6tR3RPqIB1pMiTRMFcZwuG5T8vwp+vUvEG0vuI6B+Rikh5BfPp2fQ82c925FOs+b0lcFQ8CFrL+KbilfZFhOQ==} - binary-extensions@2.3.0: resolution: {integrity: sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==} engines: {node: '>=8'} @@ -4076,9 +3906,6 @@ packages: resolution: {integrity: sha512-d0II/GO9uf9lfUHH2BQsjxzRJZBdsjgsBiW4BvhWk/3qoKwQFjIDVN19PfX8F2D/r9PCMTtLWjYVCFrpeYUzsw==} deprecated: Package no longer supported. Contact Support at https://www.npmjs.com/support for more info. - bottleneck@2.19.5: - resolution: {integrity: sha512-VHiNCbI1lKdl44tGrhNfU3lup0Tj/ZBMJB5/2ZbNXRCPuRCO7ed2mgcK4r17y+KB2EfuYuRaVlwNbAeaWGSpbw==} - bowser@2.11.0: resolution: {integrity: sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA==} @@ -4223,14 +4050,6 @@ packages: resolution: {integrity: sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==} engines: {node: ^12.17.0 || ^14.13 || >=16.0.0} - chalk@5.4.1: - resolution: {integrity: sha512-zgVZuo2WcZgfUEmsn6eO3kINexW8RAE4maiQ8QNs8CtpPCSyMiYsULR3HQYkm3w8FIA3SberyMJMSldGsW+U3w==} - engines: {node: ^12.17.0 || ^14.13 || >=16.0.0} - - char-regex@1.0.2: - resolution: {integrity: sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw==} - engines: {node: '>=10'} - character-entities@2.0.2: resolution: {integrity: sha512-shx7oQ0Awen/BRIdkjkvz54PnEEI/EjwXDSIZp86/KKdbafHh1Df/RYGBhn4hbe2+uKC9FnT5UCEdyPz3ai9hQ==} @@ -4285,10 +4104,6 @@ packages: resolution: {integrity: sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==} engines: {node: '>=6'} - clean-stack@5.2.0: - resolution: {integrity: sha512-TyUIUJgdFnCISzG5zu3291TAsE77ddchd0bepon1VVQrKLGKFED4iXFEDQ24mIPdPBbyE16PK3F8MYE1CmcBEQ==} - engines: {node: '>=14.16'} - cli-cursor@3.1.0: resolution: {integrity: sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==} engines: {node: '>=8'} @@ -4445,9 +4260,6 @@ packages: resolution: {integrity: sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==} engines: {'0': node >= 0.8} - config-chain@1.1.13: - resolution: {integrity: sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==} - connect-typeorm@1.1.4: resolution: {integrity: sha512-1/0b1aFzip0UBzuaSUkVZE4EW3n4UZzi3x2fmKeCaOb+sB4VZGj79txzLvtWIHLYY6kls/PKNcQHfEurdEjsUw==} peerDependencies: @@ -4475,40 +4287,18 @@ packages: resolution: {integrity: sha512-6qLgrBF4gueoC7AFVHu51nHL9pF9FRjXrH+ceVf7WmAfH3gs+gEYOkvxhjMPjZu57I4AGUGoNTY8V7Hrgf1uqg==} engines: {node: '>=14'} - conventional-changelog-angular@8.0.0: - resolution: {integrity: sha512-CLf+zr6St0wIxos4bmaKHRXWAcsCXrJU6F4VdNDrGRK3B8LDLKoX3zuMV5GhtbGkVR/LohZ6MT6im43vZLSjmA==} - engines: {node: '>=18'} - conventional-changelog-conventionalcommits@5.0.0: resolution: {integrity: sha512-lCDbA+ZqVFQGUj7h9QBKoIpLhl8iihkO0nCTyRNzuXtcd7ubODpYB04IFy31JloiJgG0Uovu8ot8oxRzn7Nwtw==} engines: {node: '>=10'} - conventional-changelog-writer@8.2.0: - resolution: {integrity: sha512-Y2aW4596l9AEvFJRwFGJGiQjt2sBYTjPD18DdvxX9Vpz0Z7HQ+g1Z+6iYDAm1vR3QOJrDBkRHixHK/+FhkR6Pw==} - engines: {node: '>=18'} - hasBin: true - conventional-commit-types@3.0.0: resolution: {integrity: sha512-SmmCYnOniSsAa9GqWOeLqc179lfr5TRu5b4QFDkbsrJ5TZjPJx85wtOr3zn+1dbeNiXDKGPbZ72IKbPhLXh/Lg==} - conventional-commits-filter@5.0.0: - resolution: {integrity: sha512-tQMagCOC59EVgNZcC5zl7XqO30Wki9i9J3acbUvkaosCT6JX3EeFwJD7Qqp4MCikRnzS18WXV3BLIQ66ytu6+Q==} - engines: {node: '>=18'} - conventional-commits-parser@4.0.0: resolution: {integrity: sha512-WRv5j1FsVM5FISJkoYMR6tPk07fkKT0UodruX4je86V4owk451yjXAKzKAPOs9l7y59E2viHUS9eQ+dfUA9NSg==} engines: {node: '>=14'} hasBin: true - conventional-commits-parser@6.2.0: - resolution: {integrity: sha512-uLnoLeIW4XaoFtH37qEcg/SXMJmKF4vi7V0H2rnPueg+VEtFGA/asSCNTcq4M/GQ6QmlzchAEtOoDTtKqWeHag==} - engines: {node: '>=18'} - hasBin: true - - convert-hrtime@5.0.0: - resolution: {integrity: sha512-lOETlkIeYSJWcbbcvjRKGxVMXJR+8+OQb/mTPbA4ObPMytYIsUbuOE0Jzy60hjARYszq1id0j8KgVhC+WGZVTg==} - engines: {node: '>=12'} - convert-source-map@1.9.0: resolution: {integrity: sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==} @@ -4630,10 +4420,6 @@ packages: resolution: {integrity: sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==} engines: {node: '>= 8'} - crypto-random-string@4.0.0: - resolution: {integrity: sha512-x8dy3RnvYdlUcPOjkEHqozhiwzKNSq7GcPuXFbnyMOCHxX8V3OgIg/pYuabl2sbUPfIJaeAQB7PMOK8DFIdoRA==} - engines: {node: '>=12'} - css-select@4.3.0: resolution: {integrity: sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==} @@ -4927,9 +4713,6 @@ packages: resolution: {integrity: sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==} engines: {node: '>= 0.4'} - duplexer2@0.1.4: - resolution: {integrity: sha512-asLFVfWWtJ90ZyOUHMqk7/S2w2guQKxUI2itj3d92ADHhxUSbCMGi1f1cBcJ7xM1To+pE/Khbwo1yuNbMEPKeA==} - eastasianwidth@0.2.0: resolution: {integrity: sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==} @@ -4965,9 +4748,6 @@ packages: emoji-regex@9.2.2: resolution: {integrity: sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==} - emojilib@2.4.0: - resolution: {integrity: sha512-5U0rVMU5Y2n2+ykNLQqMoqklN9ICBT/KsvC1Gz6vqHbz2AXXGkG+Pm5rMWk/8Vjrr/mY9985Hi8DYzn1F09Nyw==} - emojis-list@3.0.0: resolution: {integrity: sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==} engines: {node: '>= 4'} @@ -5008,10 +4788,6 @@ packages: resolution: {integrity: sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==} engines: {node: '>=0.12'} - env-ci@11.1.1: - resolution: {integrity: sha512-mT3ks8F0kwpo7SYNds6nWj0PaRh+qJxIeBVBXAKTN9hphAzZv7s0QAZQbqnB1fAv/r4pJUGE15BV9UrS31FP2w==} - engines: {node: ^18.17 || >=20.6.1} - env-paths@2.2.1: resolution: {integrity: sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==} engines: {node: '>=6'} @@ -5021,10 +4797,6 @@ packages: engines: {node: '>=4'} hasBin: true - environment@1.1.0: - resolution: {integrity: sha512-xUtoPkMggbz0MPyPiIWr1Kp4aeWJjDZ6SMvURhimjdZgsRuDplF5/s9hcgGhyXMhs+6vpnuoiZ2kFiu3FMnS8Q==} - engines: {node: '>=18'} - err-code@2.0.3: resolution: {integrity: sha512-2bmlRpNKBxT/CRmPOlyISQpNj+qSeYvcym/uT0Jx2bMOlKLtSy1ZmLuVxSEKKyor/N5yhvp/ZiG1oE3DEYMSFA==} @@ -5115,10 +4887,6 @@ packages: resolution: {integrity: sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==} engines: {node: '>=10'} - escape-string-regexp@5.0.0: - resolution: {integrity: sha512-/veY75JbMK4j1yjvuUxuVsiS/hr/4iHs9FTT6cgTexxdE0Ly/glccBAkloH/DofkjRbZU3bnoj38mOmhkZ0lHw==} - engines: {node: '>=12'} - eslint-config-next@14.2.4: resolution: {integrity: sha512-Qr0wMgG9m6m4uYy2jrYJmyuNlYZzPRQq5Kvb9IDlYwn+7yq6W6sfMNFgb+9guM1KYwuIo6TIaiFhZJ6SnQ/Efw==} peerDependencies: @@ -5255,6 +5023,7 @@ packages: eslint@8.35.0: resolution: {integrity: sha512-BxAf1fVL7w+JLRQhWl2pzGeSiGqbWumV4WNvc9Rhp6tiCtm4oHnyPBSEtMGZwrQgudFQ+otqzWoPB7x+hxoWsw==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + deprecated: This version is no longer supported. Please see https://eslint.org/version-support for other options. hasBin: true espree@9.6.1: @@ -5322,14 +5091,6 @@ packages: resolution: {integrity: sha512-QVWlX2e50heYJcCPG0iWtf8r0xjEYfz/OYLGDYH+IyjWezzPNxz63qNFOu0l4YftGWuizFVZHHs8PrLU5p2IDA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - execa@8.0.1: - resolution: {integrity: sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==} - engines: {node: '>=16.17'} - - execa@9.6.0: - resolution: {integrity: sha512-jpWzZ1ZhwUmeWRhS7Qv3mhpOhLfwI+uAX4e5fOcXqwMR7EcJ0pj2kV1CVzHVMX/LphnKWD3LObjZCoJ71lKpHw==} - engines: {node: ^18.19.0 || >=20.5.0} - executable@4.1.1: resolution: {integrity: sha512-8iA79xD3uAch729dUG8xaaBBFGaEa0wdD2VkYLFHwlqosEj/jT66AzcreRDSgV7ehnNLBW2WR5jIXwGKjVdTLg==} engines: {node: '>=4'} @@ -5385,9 +5146,6 @@ packages: resolution: {integrity: sha512-Wrk35e8ydCKDj/ArClo1VrPVmN8zph5V4AtHwIuHhvMXsKf73UT3BOD+azBIW+3wOJ4FhEH7zyaJCFvChjYvMA==} engines: {'0': node >=0.6.0} - fast-content-type-parse@3.0.0: - resolution: {integrity: sha512-ZvLdcY8P+N8mGQJahJV5G4U88CSvT1rP8ApL6uETe88MBXrBHAkZlSEySdUlyztF7ccb+Znos3TFqaepHxdhBg==} - fast-deep-equal@3.1.3: resolution: {integrity: sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==} @@ -5428,18 +5186,10 @@ packages: fecha@4.2.3: resolution: {integrity: sha512-OP2IUU6HeYKJi3i0z4A19kHMQoLVs4Hc+DPqqxI2h/DPZHTm/vjsfC6P0b4jCMy14XizLBqvndQ+UilD7707Jw==} - figures@2.0.0: - resolution: {integrity: sha512-Oa2M9atig69ZkfwiApY8F2Yy+tzMbazyvqv21R0NsSC8floSOC09BbT1ITWAdoMGQvJ/aZnR1KMwdx9tvHnTNA==} - engines: {node: '>=4'} - figures@3.2.0: resolution: {integrity: sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==} engines: {node: '>=8'} - figures@6.1.0: - resolution: {integrity: sha512-d+l3qxjSesT4V7v2fh+QnmFnUWv9lSpjarhShNTgBOfA0ttejbQUAlHLitbjkoRiDulW0OPoQPYIGhIC8ohejg==} - engines: {node: '>=18'} - file-entry-cache@6.0.1: resolution: {integrity: sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==} engines: {node: ^10.12.0 || >=12.0.0} @@ -5472,14 +5222,6 @@ packages: find-root@1.1.0: resolution: {integrity: sha512-NKfW6bec6GfKc0SGx1e07QZY9PE99u0Bft/0rzSD5k3sO/vwkVUpDUKVm5Gpp5Ue3YfShPFTX2070tDs5kB9Ng==} - find-up-simple@1.0.1: - resolution: {integrity: sha512-afd4O7zpqHeRyg4PfDQsXmlDe2PfdHtJt6Akt8jOWaApLOZk5JXs6VMR29lz03pRe9mpykrRCYIYxaJYcfpncQ==} - engines: {node: '>=18'} - - find-up@2.1.0: - resolution: {integrity: sha512-NWzkk0jSJtTt08+FBFMvXoeZnOJD+jTtsRmBYbAIzJdX6l7dLgR7CTubCM5/eDdPUBvLCeVasP1brfVR/9/EZQ==} - engines: {node: '>=4'} - find-up@3.0.0: resolution: {integrity: sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==} engines: {node: '>=6'} @@ -5492,10 +5234,6 @@ packages: resolution: {integrity: sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==} engines: {node: '>=10'} - find-versions@6.0.0: - resolution: {integrity: sha512-2kCCtc+JvcZ86IGAz3Z2Y0A1baIz9fL31pH/0S1IqZr9Iwnjq8izfPtrCyQKO6TLMPELLsQMre7VDqeIKCsHkA==} - engines: {node: '>=18'} - findup-sync@4.0.0: resolution: {integrity: sha512-6jvvn/12IC4quLBL1KNokxC7wWTvYncaVUYSoxWw7YykPLuRrnv4qdHcSOywOI5RpkOVGeQRtWM8/q+G6W6qfQ==} engines: {node: '>= 8'} @@ -5568,9 +5306,6 @@ packages: resolution: {integrity: sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==} engines: {node: '>= 0.6'} - from2@2.3.0: - resolution: {integrity: sha512-OMcX/4IC/uqEPVgGeyfN22LJk6AZrMkRZHxcHBMBvHScDGgwTm2GT2Wkgtocyd3JfZffjj2kYUDXXII0Fk9W0g==} - fs-constants@1.0.0: resolution: {integrity: sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==} @@ -5601,10 +5336,6 @@ packages: function-bind@1.1.2: resolution: {integrity: sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==} - function-timeout@1.0.2: - resolution: {integrity: sha512-939eZS4gJ3htTHAldmyyuzlrD58P03fHG49v2JfFXbV6OhvZKRC9j2yAtdHw/zrp2zXHuv05zMIy40F0ge7spA==} - engines: {node: '>=18'} - function.prototype.name@1.1.6: resolution: {integrity: sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==} engines: {node: '>= 0.4'} @@ -5662,18 +5393,6 @@ packages: resolution: {integrity: sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==} engines: {node: '>=10'} - get-stream@7.0.1: - resolution: {integrity: sha512-3M8C1EOFN6r8AMUhwUAACIoXZJEOufDU5+0gFFN5uNs6XYOralD2Pqkl7m046va6x77FwposWXbAhPPIOus7mQ==} - engines: {node: '>=16'} - - get-stream@8.0.1: - resolution: {integrity: sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==} - engines: {node: '>=16'} - - get-stream@9.0.1: - resolution: {integrity: sha512-kVCxPF3vQM/N0B1PmoqVUqgHP+EeVjmZSQn+1oCRPxd2P21P2F19lIgbR3HBosbB1PUhOAoctJnfEn2GbN2eZA==} - engines: {node: '>=18'} - get-symbol-description@1.0.2: resolution: {integrity: sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==} engines: {node: '>= 0.4'} @@ -5687,9 +5406,6 @@ packages: getpass@0.1.7: resolution: {integrity: sha512-0fzj9JxOLfJ+XGLhR8ze3unN0KZCgZwiSSDz168VERjK8Wl8kVSdcu2kspd4s4wtAa1y/qrVRiAA0WclVsu0ng==} - git-log-parser@1.2.0: - resolution: {integrity: sha512-rnCVNfkTL8tdNryFuaY0fYiBWEBcgF748O6ZI61rslBvr2o7U65c2/6npCRqH40vuAhtgtDiqLTJjBVdrejCzA==} - git-raw-commits@2.0.11: resolution: {integrity: sha512-VnctFhw+xfj8Va1xtfEqCUD2XDrbAPSJx+hSrE5K7fGdjZruW7XV+QOrN7LF/RJyvspRiD2I0asWsxFp0ya26A==} engines: {node: '>=10'} @@ -5756,10 +5472,6 @@ packages: resolution: {integrity: sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==} engines: {node: '>=10'} - globby@14.1.0: - resolution: {integrity: sha512-0Ia46fDOaT7k4og1PDW4YbodWWr3scS2vAr2lTbsplOt2WkKp0vQbkI9wKis/T5LV/dqPjO3bpS/z6GTJB82LA==} - engines: {node: '>=18'} - gopd@1.0.1: resolution: {integrity: sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==} @@ -5767,9 +5479,6 @@ packages: resolution: {integrity: sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==} engines: {node: '>= 0.4'} - graceful-fs@4.2.10: - resolution: {integrity: sha512-9ByhssR2fPVsNZj478qUUbKfmL0+t5BDVyjShtyZZLiK7ZDAArFFfopyOTj0M05wE2tJPisA4iTnnXl2YoPvOA==} - graceful-fs@4.2.11: resolution: {integrity: sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==} @@ -5872,10 +5581,6 @@ packages: resolution: {integrity: sha512-eSmmWE5bZTK2Nou4g0AI3zZ9rswp7GRKoKXS1BLUkvPviOqs4YTN1djQIqrXy9k5gEtdLPy86JjRwsNM9tnDcA==} engines: {node: '>=0.10.0'} - hook-std@3.0.0: - resolution: {integrity: sha512-jHRQzjSDzMtFy34AGj1DN+vq54WVuhSvKgrHf0OMiFQTwDD4L/qqofVEWjLOBMTn5+lCD3fPg32W9yOfnEJTTw==} - engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - hosted-git-info@2.8.9: resolution: {integrity: sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==} @@ -5883,14 +5588,6 @@ packages: resolution: {integrity: sha512-kyCuEOWjJqZuDbRHzL8V93NzQhwIB71oFWSyzVo+KPZI+pnQPPxucdkrOZvkLRnrf5URsQM+IJ09Dw29cRALIA==} engines: {node: '>=10'} - hosted-git-info@7.0.2: - resolution: {integrity: sha512-puUZAUKT5m8Zzvs72XWy3HtvVbTWljRE66cP60bxJzAqf2DgICo7lYTY2IHUmLnNpjYvw5bvmoHvPc0QO2a62w==} - engines: {node: ^16.14.0 || >=18.0.0} - - hosted-git-info@8.1.0: - resolution: {integrity: sha512-Rw/B2DNQaPBICNXEm8balFz9a6WpZrkCGpcWFpy7nCj+NyhSdqXipmfvtmWt9xGfp0wZnBxB+iVpLmQMYt47Tw==} - engines: {node: ^18.17.0 || >=20.5.0} - html-to-text@9.0.5: resolution: {integrity: sha512-qY60FjREgVZL03vJU6IfMV4GDjGBIoOyvuFdpBDIX9yTlDw0TjxVBQp+P8NvpdIXNJvfWBTNul7fsAQJq2FNpg==} engines: {node: '>=14'} @@ -5955,14 +5652,6 @@ packages: resolution: {integrity: sha512-rQLskxnM/5OCldHo+wNXbpVgDn5A17CUoKX+7Sokwaknlq7CdSnphy0W39GU8dw59XiCXmFXDg4fRuckQRKewQ==} engines: {node: '>=12.20.0'} - human-signals@5.0.0: - resolution: {integrity: sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==} - engines: {node: '>=16.17.0'} - - human-signals@8.0.1: - resolution: {integrity: sha512-eKCa6bwnJhvxj14kZk5NCPc6Hb6BdsU9DZcOnmQKSnO1VKrfV0zCvtttPZUsBvjmNDn8rpcJfpwSYnHBjc95MQ==} - engines: {node: '>=18.18.0'} - humanize-ms@1.2.1: resolution: {integrity: sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==} @@ -5996,10 +5685,6 @@ packages: resolution: {integrity: sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==} engines: {node: '>= 4'} - ignore@7.0.5: - resolution: {integrity: sha512-Hs59xBNfUIunMFgWAbGX5cq6893IbWg4KnrjbYwX3tx0ztorVgTDA6B2sxf8ejHJ4wz8BqGUMYlnzNBer5NvGg==} - engines: {node: '>= 4'} - image-size@1.2.1: resolution: {integrity: sha512-rH+46sQJ2dlwfjfhCyNx5thzrv+dtmBIhPHk0zgRUukHzZ/kRueTJXoYYsclBaKcSMBWuGbOFXtioLpzTb5euw==} engines: {node: '>=16.x'} @@ -6013,10 +5698,6 @@ packages: resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==} engines: {node: '>=6'} - import-from-esm@2.0.0: - resolution: {integrity: sha512-YVt14UZCgsX1vZQ3gKjkWVdBdHQ6eu3MPU1TBgL1H5orXe2+jWD006WCPPtOuwlQm10NuzOW5WawiF1Q9veW8g==} - engines: {node: '>=18.20'} - import-meta-resolve@4.1.0: resolution: {integrity: sha512-I6fiaX09Xivtk+THaMfAwnA3MVA5Big1WHF1Dfx9hFuvNIWpXnorlkzhcQf6ehrqQiiZECRt1poOAkPmer3ruw==} @@ -6028,14 +5709,6 @@ packages: resolution: {integrity: sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==} engines: {node: '>=8'} - indent-string@5.0.0: - resolution: {integrity: sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==} - engines: {node: '>=12'} - - index-to-position@1.1.0: - resolution: {integrity: sha512-XPdx9Dq4t9Qk1mTMbWONJqU7boCoumEH7fRET37HX5+khDUl3J2W6PdALxhILYlIYx2amlwYcRPp28p0tSiojg==} - engines: {node: '>=18'} - infer-owner@1.0.4: resolution: {integrity: sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==} @@ -6071,10 +5744,6 @@ packages: intl-messageformat@10.5.14: resolution: {integrity: sha512-IjC6sI0X7YRjjyVH9aUgdftcmZK7WXdHeil4KwbjDnRWjnVitKpAx3rr6t6di1joFp5188VqKcobOPA6mCLG/w==} - into-stream@7.0.0: - resolution: {integrity: sha512-2dYz766i9HprMBasCMvHMuazJ7u4WzhJwo5kb3iPSiW/iRYV6uPari3zHoqZlnuaR7V1bEiNMxikhp37rdBXbw==} - engines: {node: '>=12'} - invariant@2.2.4: resolution: {integrity: sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==} @@ -6256,10 +5925,6 @@ packages: resolution: {integrity: sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - is-stream@4.0.1: - resolution: {integrity: sha512-Dnz92NInDqYckGEUJv689RbRiTSEHCQ7wOVeALbkOz999YpqT46yMRIGtSNl2iCL1waAZSx40+h59NV/EwzV/A==} - engines: {node: '>=18'} - is-string@1.0.7: resolution: {integrity: sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==} engines: {node: '>= 0.4'} @@ -6283,10 +5948,6 @@ packages: resolution: {integrity: sha512-knxG2q4UC3u8stRGyAVJCOdxFmv5DZiRcdlIaAQXAbSfJya+OhopNotLQrstBhququ4ZpuKbDc/8S6mgXgPFPw==} engines: {node: '>=10'} - is-unicode-supported@2.1.0: - resolution: {integrity: sha512-mE00Gnza5EEB3Ds0HfMyllZzbBrmLOX3vfWoj9A9PEnTfratQ/BcaJOuMhnkhjXvb2+FkY3VuHqtAGpTPmglFQ==} - engines: {node: '>=18'} - is-utf8@0.2.1: resolution: {integrity: sha512-rMYPYvCzsXywIsldgLaSoPlw5PfoB/ssr7hY4pLfcodrA5M/eArza1a9VmTiNIBNMjOGr1Ow9mTyU2o69U6U9Q==} @@ -6332,10 +5993,6 @@ packages: isstream@0.1.2: resolution: {integrity: sha512-Yljz7ffyPbrLpLngrMtZ7NduUgVvi6wG9RJ9IUcyCd59YQ911PBJphODUcbOVbqYfxe1wuYf/LJ8PauMRwsM/g==} - issue-parser@7.0.1: - resolution: {integrity: sha512-3YZcUUR2Wt1WsapF+S/WiA2WmlW0cWAoPccMqne7AxEBhCdFeTPjfv/Axb8V2gyCgY3nRw+ksZ3xSUX+R47iAg==} - engines: {node: ^18.17 || >=20.6.1} - iterator.prototype@1.1.2: resolution: {integrity: sha512-DR33HMMr8EzwuRL8Y9D3u2BMj8+RqSE850jfGu59kS7tbmPLzGkZmVSfyCFSDxuZiEY6Rzt3T2NA/qU+NwVj1w==} @@ -6348,10 +6005,6 @@ packages: resolution: {integrity: sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==} engines: {node: '>=14'} - java-properties@1.0.2: - resolution: {integrity: sha512-qjdpeo2yKlYTH7nFdK0vbZWuTCesk4o63v5iVOlhMQPfuIZQfW/HI35SjfhA+4qpg36rnFSvUK5b1m+ckIblQQ==} - engines: {node: '>= 0.6.0'} - jest-environment-node@29.7.0: resolution: {integrity: sha512-DOSwCRqXirTOyheM+4d5YZOrWcdu0LNZ87ewUoywbcb2XR4wKgqiG8vNeYwhjFMbEkfju7wx2GYH0P2gevGvFw==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} @@ -6626,14 +6279,6 @@ packages: enquirer: optional: true - load-json-file@4.0.0: - resolution: {integrity: sha512-Kx8hMakjX03tiGTLAIdJ+lL0htKnXjEZN6hk/tozf/WOuYGdZBJrZ+rCJRbVCugsjB3jMLn9746NsQIf5VjBMw==} - engines: {node: '>=4'} - - locate-path@2.0.0: - resolution: {integrity: sha512-NCI2kiDkyR7VeEKm27Kda/iQHyKJe1Bu0FlTbYp3CqJu+9IFe9bLyAjMxf5ZDDbEg+iMPzB5zYyUTSm8wVTKmA==} - engines: {node: '>=4'} - locate-path@3.0.0: resolution: {integrity: sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==} engines: {node: '>=6'} @@ -6652,9 +6297,6 @@ packages: lodash.camelcase@4.3.0: resolution: {integrity: sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==} - lodash.capitalize@4.2.1: - resolution: {integrity: sha512-kZzYOKspf8XVX5AvmQF94gQW0lejFVgb80G85bU4ZWzoJ6C03PQg3coYAUpSTpQWelrZELd3XWgHzw4Ck5kaIw==} - lodash.castarray@4.4.0: resolution: {integrity: sha512-aVx8ztPv7/2ULbArGJ2Y42bG1mEQ5mGjpdvrbJcJFU3TbYybe+QlLS4pst9zV52ymy2in1KpFPiZnAOATxD4+Q==} @@ -6664,14 +6306,13 @@ packages: lodash.debounce@4.0.8: resolution: {integrity: sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==} - lodash.escaperegexp@4.1.2: - resolution: {integrity: sha512-TM9YBvyC84ZxE3rgfefxUWiQKLilstD6k7PTGt6wfbtXF8ixIJLOL3VYyV/z+ZiPLsVxAsKAFVwWlWeb2Y8Yyw==} - lodash.get@4.4.2: resolution: {integrity: sha512-z+Uw/vLuy6gQe8cfaFWD7p0wVv8fJl3mbzXh33RS+0oW2wvUqiRXiQ69gLWSLpgB5/6sU+r6BlQR0MBILadqTQ==} + deprecated: This package is deprecated. Use the optional chaining (?.) operator instead. lodash.isequal@4.5.0: resolution: {integrity: sha512-pDo3lu8Jhfjqls6GkMgpahsF9kCyayhgykjyLMNFTKWrpVdAQtYyB4muAMWozBB4ig/dtWAmsMxLEI8wuz+DYQ==} + deprecated: This package is deprecated. Use require('node:util').isDeepStrictEqual instead. lodash.isfunction@3.0.9: resolution: {integrity: sha512-AirXNj15uRIMMPihnkInB4i3NHeb4iBtNg9WRWuK2o31S+ePwwNmDPaTL3o7dTJ+VXNZim7rFs4rxN4YU1oUJw==} @@ -6679,9 +6320,6 @@ packages: lodash.isplainobject@4.0.6: resolution: {integrity: sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==} - lodash.isstring@4.0.1: - resolution: {integrity: sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==} - lodash.kebabcase@4.1.1: resolution: {integrity: sha512-N8XRTIMMqqDgSy4VLKPnJ/+hpGZN+PHQiJnSenYqPaVV/NCqEogTnAdZLQiGKhxX+JCs8waWq2t1XHWKOmlY8g==} @@ -6709,9 +6347,6 @@ packages: lodash.uniq@4.5.0: resolution: {integrity: sha512-xfBaXQd9ryd9dlSDvnvI0lvxfLJlYAZzXomUYzLKtUeOQvOP5piqAWuGtrhWeqaXK9hhoM/iyJc5AV+XfsX3HQ==} - lodash.uniqby@4.7.0: - resolution: {integrity: sha512-e/zcLx6CSbmaEgFHCA7BnoQKyCtKMxnuWrJygbwPs/AIn+IMKl66L8/s+wBUn5LRw2pZx3bUHibiV1b6aTWIww==} - lodash.upperfirst@4.3.1: resolution: {integrity: sha512-sReKOYJIJf74dhJONhU4e0/shzi1trVbSWDOhKYE5XV2O+H7Sb2Dihwuc7xWxVl+DgFPyTqIN3zMfT9cq5iWDg==} @@ -6748,10 +6383,6 @@ packages: resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==} hasBin: true - lru-cache@10.2.2: - resolution: {integrity: sha512-9hp3Vp2/hFQUiIwKo8XCeFVnrg8Pk3TYNPIR7tJADKi5YfcF7vEaK7avFHTlSy3kOKYaJQaalfEo6YuXdceBOQ==} - engines: {node: 14 || >=16.14} - lru-cache@10.4.3: resolution: {integrity: sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==} @@ -6817,17 +6448,6 @@ packages: resolution: {integrity: sha512-hdN1wVrZbb29eBGiGjJbeP8JbKjq1urkHJ/LIP/NY48MZ1QVXUsQBV1G1zvYFHn1XE06cwjBsOI2K3Ulnj1YXQ==} engines: {node: '>=8'} - marked-terminal@7.3.0: - resolution: {integrity: sha512-t4rBvPsHc57uE/2nJOLmMbZCQ4tgAccAED3ngXQqW6g+TxA488JzJ+FK3lQkzBQOI1mRV/r/Kq+1ZlJ4D0owQw==} - engines: {node: '>=16.0.0'} - peerDependencies: - marked: '>=1 <16' - - marked@15.0.12: - resolution: {integrity: sha512-8dD6FusOQSrpv9Z1rdNMdlSgQOIP880DHqnohobOmYLElGEqAL/JvxvuxZO16r4HtjTlfPRDC1hbvxC9dPN2nA==} - engines: {node: '>= 18'} - hasBin: true - marky@1.3.0: resolution: {integrity: sha512-ocnPZQLNpvbedwTy9kNrQEsknEfgvcLMvOtz3sFeWApDq1MXH1TqkCIx58xlpESsfwQOnuBO9beyQuNGzVvuhQ==} @@ -6875,10 +6495,6 @@ packages: mensch@0.3.4: resolution: {integrity: sha512-IAeFvcOnV9V0Yk+bFhYR07O3yNina9ANIN5MoXBKYJ/RLYPurd2d0yw14MDhpr9/momp0WofT1bPUh3hkzdi/g==} - meow@13.2.0: - resolution: {integrity: sha512-pxQJQzB6djGPXh08dacEloMFopsOqGVRKFPYvPOt9XDZ1HasbgDZA74CJGreSU4G3Ak7EFJGoiH2auq+yXISgA==} - engines: {node: '>=18'} - meow@8.1.2: resolution: {integrity: sha512-r85E3NdZ+mpYk1C6RjPFEMSE+s1iZMuHtsHAqY0DT3jZczl0diWUZ8g6oU7h0M9cD2EL+PzaYghhCLzR0ZNn5Q==} engines: {node: '>=10'} @@ -7052,11 +6668,6 @@ packages: engines: {node: '>=10.0.0'} hasBin: true - mime@4.0.7: - resolution: {integrity: sha512-2OfDPL+e03E0LrXaGYOtTFIYhiuzep94NSsuhrNULq+stylcJedcHdzHtz0atMUuGwJfFYs0YL5xeC/Ca2x0eQ==} - engines: {node: '>=16'} - hasBin: true - mimic-fn@2.1.0: resolution: {integrity: sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==} engines: {node: '>=6'} @@ -7184,6 +6795,7 @@ packages: multer@1.4.5-lts.1: resolution: {integrity: sha512-ywPWvcDMeH+z9gQq5qYHCCy+ethsk4goepZ45GLD63fOu0YcNecQxi64nDs3qluZB+murG3/D4dJ7+dGctcCQQ==} engines: {node: '>= 6.0.0'} + deprecated: Multer 1.x is impacted by a number of vulnerabilities, which have been patched in 2.x. You should upgrade to the latest 2.x version. multimatch@5.0.0: resolution: {integrity: sha512-ypMKuglUrZUD99Tk2bUQ+xNQj43lPEfAeX2o9cTteAmShXy2VHDJpuwu1o0xqoKCt9jLVAvwyFKdLTPXKAfJyA==} @@ -7231,9 +6843,6 @@ packages: neo-async@2.6.2: resolution: {integrity: sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==} - nerf-dart@1.0.0: - resolution: {integrity: sha512-EZSPZB70jiVsivaBLYDCyntd5eH8NTSMOn3rB+HxwdmKThGELLdYv8qVIMWvZEFy9w8ZZpW9h9OB32l1rGtj7g==} - next@14.2.25: resolution: {integrity: sha512-N5M7xMc4wSb4IkPvEV5X2BRRXUmhVHNyaXwEM86+voXthSZz8ZiRyQW4p9mwAoAPIm6OzuVZtn7idgEJeAJN3Q==} engines: {node: '>=18.17.0'} @@ -7280,10 +6889,6 @@ packages: resolution: {integrity: sha512-tmPX422rYgofd4epzrNoOXiE8XFZYOcCq1vD7MAXCDO+O+zndlA2ztdKKMa+EeuBG5tHETpr4ml4RGgpqDCCAg==} engines: {node: '>= 0.10.5'} - node-emoji@2.2.0: - resolution: {integrity: sha512-Z3lTE9pLaJF47NyMhd4ww1yFTAP8YhYI8SleJiHzM46Fgpm5cnNzSl9XfzFNqbaz+VlJrIj3fXQ4DeN1Rjm6cw==} - engines: {node: '>=18'} - node-fetch@2.7.0: resolution: {integrity: sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==} engines: {node: 4.x || >=6.0.0} @@ -7357,10 +6962,6 @@ packages: resolution: {integrity: sha512-p2W1sgqij3zMMyRC067Dg16bfzVH+w7hyegmpIvZ4JNjqtGOVAIvLmjBx3yP7YTe9vKJgkoNOPjwQGogDoMXFA==} engines: {node: '>=10'} - normalize-package-data@6.0.2: - resolution: {integrity: sha512-V6gygoYb/5EmNI+MEGrWkC+e6+Rr7mTmfHrxDbLzxQogBkgzo76rkok0Am6thgSF7Mv2nLOajAJj5vDJZEFn7g==} - engines: {node: ^16.14.0 || >=18.0.0} - normalize-path@3.0.0: resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==} engines: {node: '>=0.10.0'} @@ -7369,10 +6970,6 @@ packages: resolution: {integrity: sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==} engines: {node: '>=0.10.0'} - normalize-url@8.0.2: - resolution: {integrity: sha512-Ee/R3SyN4BuynXcnTaekmaVdbDAEiNrHqjQIA37mHU8G9pf7aaAD4ZX3XjBLo6rsdcxA/gtkcNYZLt30ACgynw==} - engines: {node: '>=14.16'} - npm-run-path@2.0.2: resolution: {integrity: sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw==} engines: {node: '>=4'} @@ -7385,84 +6982,6 @@ packages: resolution: {integrity: sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - npm-run-path@6.0.0: - resolution: {integrity: sha512-9qny7Z9DsQU8Ou39ERsPU4OZQlSTP47ShQzuKZ6PRXpYLtIFgl/DEBYEXKlvcEa+9tHVcK8CF81Y2V72qaZhWA==} - engines: {node: '>=18'} - - npm@10.9.3: - resolution: {integrity: sha512-6Eh1u5Q+kIVXeA8e7l2c/HpnFFcwrkt37xDMujD5be1gloWa9p6j3Fsv3mByXXmqJHy+2cElRMML8opNT7xIJQ==} - engines: {node: ^18.17.0 || >=20.5.0} - hasBin: true - bundledDependencies: - - '@isaacs/string-locale-compare' - - '@npmcli/arborist' - - '@npmcli/config' - - '@npmcli/fs' - - '@npmcli/map-workspaces' - - '@npmcli/package-json' - - '@npmcli/promise-spawn' - - '@npmcli/redact' - - '@npmcli/run-script' - - '@sigstore/tuf' - - abbrev - - archy - - cacache - - chalk - - ci-info - - cli-columns - - fastest-levenshtein - - fs-minipass - - glob - - graceful-fs - - hosted-git-info - - ini - - init-package-json - - is-cidr - - json-parse-even-better-errors - - libnpmaccess - - libnpmdiff - - libnpmexec - - libnpmfund - - libnpmhook - - libnpmorg - - libnpmpack - - libnpmpublish - - libnpmsearch - - libnpmteam - - libnpmversion - - make-fetch-happen - - minimatch - - minipass - - minipass-pipeline - - ms - - node-gyp - - nopt - - normalize-package-data - - npm-audit-report - - npm-install-checks - - npm-package-arg - - npm-pick-manifest - - npm-profile - - npm-registry-fetch - - npm-user-validate - - p-map - - pacote - - parse-conflict-json - - proc-log - - qrcode-terminal - - read - - semver - - spdx-expression-parse - - ssri - - supports-color - - tar - - text-table - - tiny-relative-date - - treeverse - - validate-npm-package-name - - which - - write-file-atomic - npmlog@5.0.1: resolution: {integrity: sha512-AqZtDUWOMKs1G/8lwylVjrdYgqA4d9nu8hc+0gzRxlDb1I10+FHBGMXs6aiQHFdCUUlqH99MUMuLfzWDNDtfxw==} deprecated: This package is no longer supported. @@ -7581,6 +7100,7 @@ packages: openpgp@5.11.2: resolution: {integrity: sha512-f8dJFVLwdkvPvW3VPFs6q9Vs2+HNhdvwls7a/MIFcQUB+XiQzRe7alfa3RtwfGJU7oUDDMAWPZ0nYsHa23Az+A==} engines: {node: '>= 8.0.0'} + deprecated: This version is deprecated and will no longer receive security patches. Please refer to https://github.com/openpgpjs/openpgpjs/wiki/Updating-from-previous-versions for details on how to upgrade to a newer supported version. optionator@0.9.4: resolution: {integrity: sha512-6IpQ7mKUxRcZNLIObR0hz7lxsapSSIYNZJwXPGeF0mTVqGKFIXj1DQcMoT22S3ROcLyY/rz0PWaWZ9ayWmad9g==} @@ -7597,30 +7117,14 @@ packages: ospath@1.2.2: resolution: {integrity: sha512-o6E5qJV5zkAbIDNhGSIlyOhScKXgQrSRMilfph0clDfM0nEnBOlKlH4sWDmG95BW/CvwNz0vmm7dJVtU2KlMiA==} - p-each-series@3.0.0: - resolution: {integrity: sha512-lastgtAdoH9YaLyDa5i5z64q+kzOcQHsQ5SsZJD3q0VEyI8mq872S3geuNbRUQLVAE9siMfgKrpj7MloKFHruw==} - engines: {node: '>=12'} - p-event@4.2.0: resolution: {integrity: sha512-KXatOjCRXXkSePPb1Nbi0p0m+gQAwdlbhi4wQKJPI1HsMQS9g+Sqp2o+QHziPr7eYJyOZet836KoHEVM1mwOrQ==} engines: {node: '>=8'} - p-filter@4.1.0: - resolution: {integrity: sha512-37/tPdZ3oJwHaS3gNJdenCDB3Tz26i9sjhnguBtvN0vYlRIiDNnvTWkuh+0hETV9rLPdJ3rlL3yVOYPIAnM8rw==} - engines: {node: '>=18'} - p-finally@1.0.0: resolution: {integrity: sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==} engines: {node: '>=4'} - p-is-promise@3.0.0: - resolution: {integrity: sha512-Wo8VsW4IRQSKVXsJCn7TomUaVtyfjVDn3nUP7kE967BQk0CwFpdbZs0X0uk5sW9mkBa9eNM7hCMaG93WUAwxYQ==} - engines: {node: '>=8'} - - p-limit@1.3.0: - resolution: {integrity: sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==} - engines: {node: '>=4'} - p-limit@2.3.0: resolution: {integrity: sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==} engines: {node: '>=6'} @@ -7629,10 +7133,6 @@ packages: resolution: {integrity: sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==} engines: {node: '>=10'} - p-locate@2.0.0: - resolution: {integrity: sha512-nQja7m7gSKuewoVRen45CtVfODR3crN3goVQ0DDZ9N3yHxgpkuBhZqsaiotSQRrADUrne346peY7kT3TSACykg==} - engines: {node: '>=4'} - p-locate@3.0.0: resolution: {integrity: sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==} engines: {node: '>=6'} @@ -7649,26 +7149,10 @@ packages: resolution: {integrity: sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==} engines: {node: '>=10'} - p-map@7.0.3: - resolution: {integrity: sha512-VkndIv2fIB99swvQoA65bm+fsmt6UNdGeIB0oxBs+WhAhdh08QA04JXpI7rbB9r08/nkbysKoya9rtDERYOYMA==} - engines: {node: '>=18'} - - p-reduce@2.1.0: - resolution: {integrity: sha512-2USApvnsutq8uoxZBGbbWM0JIYLiEMJ9RlaN7fAzVNb9OZN0SHjjTTfIcb667XynS5Y1VhwDJVDa72TnPzAYWw==} - engines: {node: '>=8'} - - p-reduce@3.0.0: - resolution: {integrity: sha512-xsrIUgI0Kn6iyDYm9StOpOeK29XM1aboGji26+QEortiFST1hGZaUQOLhtEbqHErPpGW/aSz6allwK2qcptp0Q==} - engines: {node: '>=12'} - p-timeout@3.2.0: resolution: {integrity: sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==} engines: {node: '>=8'} - p-try@1.0.0: - resolution: {integrity: sha512-U1etNYuMJoIz3ZXSrrySFjsXQTWOx2/jdi86L+2pRvph/qMKL6sbcCYdH23fqsbm8TH2Gn0OybpT4eSFlCVHww==} - engines: {node: '>=4'} - p-try@2.2.0: resolution: {integrity: sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==} engines: {node: '>=6'} @@ -7692,14 +7176,6 @@ packages: resolution: {integrity: sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==} engines: {node: '>=8'} - parse-json@8.3.0: - resolution: {integrity: sha512-ybiGyvspI+fAoRQbIPRddCcSTV9/LsJbf0e/S85VLowVGzRmokfneg2kwVW/KU5rOXrPSbF1qAKPMgNTqqROQQ==} - engines: {node: '>=18'} - - parse-ms@4.0.0: - resolution: {integrity: sha512-TXfryirbmq34y8QBwgqCVLi+8oA3oWx2eAnSn62ITyEhEYaWRlVZ2DvMM9eZbMs/RfxPu/PK/aBLyGj4IrqMHw==} - engines: {node: '>=18'} - parse-passwd@1.0.0: resolution: {integrity: sha512-1Y1A//QUXEZK7YKz+rD9WydcE1+EuPr6ZBgKecAB8tmoW6UFv0NREVJe1p+jRxtThkcbbKkfwIbWJe/IeE6m2Q==} engines: {node: '>=0.10.0'} @@ -7767,10 +7243,6 @@ packages: resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==} engines: {node: '>=8'} - path-type@6.0.0: - resolution: {integrity: sha512-Vj7sf++t5pBD637NSfkxpHSMfWaeig5+DKWLhcqIYx6mWQz5hdJTGDVMQiJcw1ZYkhs7AazKDGpRVji1LJCZUQ==} - engines: {node: '>=18'} - peberminta@0.9.0: resolution: {integrity: sha512-XIxfHpEuSJbITd1H3EeQwpcZbTLHc+VVr8ANI9t5sit565tsI4/xK3KWTUFE2e6QiangUkh3B0jihzmGnNrRsQ==} @@ -7833,10 +7305,6 @@ packages: resolution: {integrity: sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==} engines: {node: '>=0.10.0'} - pify@3.0.0: - resolution: {integrity: sha512-C3FsVNH1udSEX48gGX1xfvwTWfsYWj5U+8/uK15BGzIGrKoUpghX8hWZwa/OFnakBiiVNmBvemTJR5mcy7iPcg==} - engines: {node: '>=4'} - pify@4.0.1: resolution: {integrity: sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==} engines: {node: '>=6'} @@ -7845,10 +7313,6 @@ packages: resolution: {integrity: sha512-TfySrs/5nm8fQJDcBDuUng3VOUKsd7S+zqvbOTiGXHfxX4wK31ard+hoNuvkicM/2YFzlpDgABOevKSsB4G/FA==} engines: {node: '>= 6'} - pkg-conf@2.1.0: - resolution: {integrity: sha512-C+VUP+8jis7EsQZIhDYmS5qlNtjv2yP4SNtjXK9AP1ZcTRlnSfuumaTnRfYZnYgUUYVIKqL0fRvmUGDV2fmp6g==} - engines: {node: '>=4'} - pkg-dir@3.0.0: resolution: {integrity: sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==} engines: {node: '>=6'} @@ -8029,10 +7493,6 @@ packages: resolution: {integrity: sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} - pretty-ms@9.2.0: - resolution: {integrity: sha512-4yf0QO/sllf/1zbZWYnvWw3NxCQwLXKzIj0G849LSufP15BXKM0rbD2Z3wVnkMfjdn/CB0Dpp444gYAACdsplg==} - engines: {node: '>=18'} - preview-email@3.1.0: resolution: {integrity: sha512-ZtV1YrwscEjlrUzYrTSs6Nwo49JM3pXLM4fFOBSC3wSni+bxaWlw9/Qgk75PZO8M7cX2EybmL2iwvaV3vkAttw==} engines: {node: '>=14'} @@ -8075,9 +7535,6 @@ packages: property-information@6.5.0: resolution: {integrity: sha512-PgTgs/BlvHxOu8QuEN7wi5A0OmXaBcHpmCSTehcs6Uuu9IkDIEo13Hy7n898RHfrQ49vKCoGeWZSaAK01nwVig==} - proto-list@1.2.4: - resolution: {integrity: sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==} - proxy-addr@2.0.7: resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==} engines: {node: '>= 0.10'} @@ -8378,10 +7835,6 @@ packages: read-cache@1.0.0: resolution: {integrity: sha512-Owdv/Ft7IjOgm/i0xvNDZ1LrRANRfew4b2prF3OWMQLxLfu3bS8FVhCsrSCMK4lR56Y9ya+AThoTpDCTxCmpRA==} - read-package-up@11.0.0: - resolution: {integrity: sha512-MbgfoNPANMdb4oRBNg5eqLbB2t2r+o5Ua1pNt8BqGp4I0FJZhuVSOj3PaBPni4azWuSzEdNn2evevzVmEk1ohQ==} - engines: {node: '>=18'} - read-pkg-up@7.0.1: resolution: {integrity: sha512-zK0TB7Xd6JpCLmlLmufqykGE+/TlOePD6qKClNW7hHDKFh/J7/7gCWGR7joEQEW1bKq3a3yUZSObOoWLFQ4ohg==} engines: {node: '>=8'} @@ -8390,10 +7843,6 @@ packages: resolution: {integrity: sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==} engines: {node: '>=8'} - read-pkg@9.0.1: - resolution: {integrity: sha512-9viLL4/n1BJUCT1NXVTdS1jtm80yDEgR5T4yCelII49Mbj0v1rZdKqj7zCiYdbB0CuCgdrvHcNogAKTFPBocFA==} - engines: {node: '>=18'} - readable-stream@1.0.34: resolution: {integrity: sha512-ok1qVCJuRkNmvebYikljxJA/UEsKwLl2nI1OmaqAu4/UE+h0wKCHok4XkL/gvi39OacXvw59RJUOFUkDib2rHg==} @@ -8462,10 +7911,6 @@ packages: resolution: {integrity: sha512-DzcswPr252wEr7Qz8AyAVbfyBDKLoYp6eRA1We2Fa9qirRFSdtkP5sHr3yglDKy2BbA0fd2T+j/CUSKes3FeVQ==} engines: {node: '>=4'} - registry-auth-token@5.0.2: - resolution: {integrity: sha512-o/3ikDxtXaA59BmZuZrJZDJv8NMDGSj+6j6XaeBmHw8eY1i1qd9+6H+LjVvQXx3HN6aRCGa1cUdJ9RaJZUugnQ==} - engines: {node: '>=14'} - regjsgen@0.8.0: resolution: {integrity: sha512-RvwtGe3d7LvWiDQXeQw8p5asZUmfU1G/l6WbUXeHta7Y2PEIvBTwH6E2EfmYUK8pxcxEdEmaomqyp0vZZ7C+3Q==} @@ -8652,19 +8097,6 @@ packages: resolution: {integrity: sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q==} engines: {node: '>=10'} - semantic-release@24.2.7: - resolution: {integrity: sha512-g7RssbTAbir1k/S7uSwSVZFfFXwpomUB9Oas0+xi9KStSCmeDXcA7rNhiskjLqvUe/Evhx8fVCT16OSa34eM5g==} - engines: {node: '>=20.8.1'} - hasBin: true - - semver-diff@4.0.0: - resolution: {integrity: sha512-0Ju4+6A8iOnpL/Thra7dZsSlOHYAHIeMxfhWQRI1/VLcT3WDBZKKtQt/QkBOsiIN9ZpuvHE6cGZ0x4glCMmfiA==} - engines: {node: '>=12'} - - semver-regex@4.0.5: - resolution: {integrity: sha512-hunMQrEy1T6Jr2uEVjrAIqjwWcQTgOAcIM52C8MY1EZSD3DDNft04XzvYKPqjED65bNVVko0YI38nYeEHCX3yw==} - engines: {node: '>=12'} - semver@5.7.2: resolution: {integrity: sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==} hasBin: true @@ -8768,10 +8200,6 @@ packages: resolution: {integrity: sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==} engines: {node: '>=14'} - signale@1.4.0: - resolution: {integrity: sha512-iuh+gPf28RkltuJC7W5MRi6XAjTDCAPC/prJUpQoG4vIP3MJZ+GTydVnodXA7pwvTKb2cA0m9OFZW/cdWy/I/w==} - engines: {node: '>=6'} - simple-concat@1.0.1: resolution: {integrity: sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==} @@ -8788,18 +8216,10 @@ packages: sisteransi@1.0.5: resolution: {integrity: sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==} - skin-tone@2.0.0: - resolution: {integrity: sha512-kUMbT1oBJCpgrnKoSr0o6wPtvRWT9W9UKvGLwfJYO2WuahZRHOpEyL1ckyMGgMWh0UdpmaoFqKKD29WTomNEGA==} - engines: {node: '>=8'} - slash@3.0.0: resolution: {integrity: sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==} engines: {node: '>=8'} - slash@5.1.0: - resolution: {integrity: sha512-ZA6oR3T/pEyuqwMgAKT0/hAv8oAXckzbkmR0UkUosQ+Mc4RxGoJkRmwHgHufaenlyAgE1Mxgpdcrf75y6XcnDg==} - engines: {node: '>=14.16'} - slice-ansi@2.1.0: resolution: {integrity: sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==} engines: {node: '>=6'} @@ -8864,9 +8284,6 @@ packages: space-separated-tokens@2.0.2: resolution: {integrity: sha512-PEGlAwrG8yXGXRjW32fGbg66JAlOAwbObuqVoJpv/mRgoWDQfgH1wDPvtzWyUSNAXBGSk8h755YDbbcEy3SH2Q==} - spawn-error-forwarder@1.0.0: - resolution: {integrity: sha512-gRjMgK5uFjbCvdibeGJuy3I5OYz6VLoVdsOJdA6wV0WlfQVLFueoqMxwwYD9RODdgb6oUIvlRlsyFSiQkMKu0g==} - spdx-correct@3.2.0: resolution: {integrity: sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==} @@ -8879,9 +8296,6 @@ packages: spdx-license-ids@3.0.18: resolution: {integrity: sha512-xxRs31BqRYHwiMzudOrpSiHtZ8i/GeionCBDSilhYRj+9gIcI8wCZTlXZKu9vZIVqViP3dcp9qE5G6AlIaD+TQ==} - split2@1.0.0: - resolution: {integrity: sha512-NKywug4u4pX/AZBB1FCPzZ6/7O+Xhz1qMVbzTvvKvikjO99oPN87SkK08mEY9P63/5lWjK+wgOOgApnTg5r6qg==} - split2@3.2.2: resolution: {integrity: sha512-9NThjpgZnifTkJpzTZ7Eue85S49QwpNhZTq6GRJwObb6jnLFNGB7Qm73V5HewTROPyxD0C29xqmaI68bQtV+hg==} @@ -8945,9 +8359,6 @@ packages: resolution: {integrity: sha512-iCGQj+0l0HOdZ2AEeBADlsRC+vsnDsZsbdSiH1yNSjcfKM7fdpCMfqAL/dwF5BLiw/XhRft/Wax6zQbhq2BcjQ==} engines: {node: '>= 0.4'} - stream-combiner2@1.1.1: - resolution: {integrity: sha512-3PnJbYgS56AeWgtKF5jtJRT6uFJe56Z0Hc5Ngg/6sI6rIt8iiMBTa9cvdyFfpMQjaVHr8dusbNeFGIIonxOvKw==} - streamsearch@1.1.0: resolution: {integrity: sha512-Mcc5wHehp9aXz1ax6bZUyY5afg9u2rv5cqQI3mRrYkGC8rW2hM02jWuwjtL++LS5qinSyhj2QfLyNsuc+VsExg==} engines: {node: '>=10.0.0'} @@ -9023,10 +8434,6 @@ packages: resolution: {integrity: sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==} engines: {node: '>=12'} - strip-final-newline@4.0.0: - resolution: {integrity: sha512-aulFJcD6YK8V1G7iRB5tigAP4TsHBZZrOV8pjV++zdUwmeV8uzbY7yn6h9MswN62adStNZFuCIx4haBnRuMDaw==} - engines: {node: '>=18'} - strip-indent@3.0.0: resolution: {integrity: sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==} engines: {node: '>=8'} @@ -9065,10 +8472,6 @@ packages: resolution: {integrity: sha512-Mu7R0g4ig9TUuGSxJavny5Rv0egCEtpZRNMrZaYS1vxkiIxGiGUwoezU3LazIQ+KE04hTrTfNPgxU5gzi7F5Pw==} deprecated: Package no longer supported. Contact Support at https://www.npmjs.com/support for more info. - super-regex@1.0.0: - resolution: {integrity: sha512-CY8u7DtbvucKuquCmOFEKhr9Besln7n9uN8eFbwcoGYWXOMW07u2o8njWaiXt11ylS3qoGF55pILjRmPlbodyg==} - engines: {node: '>=18'} - supports-color@5.5.0: resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} engines: {node: '>=4'} @@ -9081,10 +8484,6 @@ packages: resolution: {integrity: sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q==} engines: {node: '>=10'} - supports-hyperlinks@3.2.0: - resolution: {integrity: sha512-zFObLMyZeEwzAoKCyu1B91U79K2t7ApXuQfo8OuxwXLDgcKxuwM+YvcbIhm6QWqz7mHUH1TVytR1PwVVjEuMig==} - engines: {node: '>=14.18'} - supports-preserve-symlinks-flag@1.0.0: resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==} engines: {node: '>= 0.4'} @@ -9145,18 +8544,10 @@ packages: resolution: {integrity: sha512-aoBAniQmmwtcKp/7BzsH8Cxzv8OL736p7v1ihGb5e9DJ9kTwGWHrQrVB5+lfVDzfGrdRzXch+ig7LHaY1JTOrg==} engines: {node: '>=8'} - temp-dir@3.0.0: - resolution: {integrity: sha512-nHc6S/bwIilKHNRgK/3jlhDoIHcp45YgyiwcAk46Tr0LfEqGBVpmiAyuiuxeVE44m3mXnEeVhaipLOEWmH+Njw==} - engines: {node: '>=14.16'} - temp@0.8.4: resolution: {integrity: sha512-s0ZZzd0BzYv5tLSptZooSjK8oj6C+c19p7Vqta9+6NPOf7r+fxq0cJe6/oN4LTC79sy5NY8ucOJNgwsKCSbfqg==} engines: {node: '>=6.0.0'} - tempy@3.1.0: - resolution: {integrity: sha512-7jDLIdD2Zp0bDe5r3D2qtkd1QOCacylBuL7oa4udvN6v2pqr4+LcCr67C8DR1zkpaZ8XosF5m1yQSabKAW6f2g==} - engines: {node: '>=14.16'} - terser@5.44.0: resolution: {integrity: sha512-nIVck8DK+GM/0Frwd+nIhZ84pR/BX7rmXMfYwyg+Sri5oGVE99/E3KvXqpC2xHFxyqXyGHTKBSioxxplrO4I4w==} engines: {node: '>=10'} @@ -9197,10 +8588,6 @@ packages: through@2.3.8: resolution: {integrity: sha512-w89qg7PI8wAdvX60bMDP+bFoD5Dvhm9oLheFp5O4a2QF0cSBGsBX4qZmadPMvVqlLJBBci+WqGGOAPvcDeNSVg==} - time-span@5.1.0: - resolution: {integrity: sha512-75voc/9G4rDIJleOo4jPvN4/YC4GRZrY8yy1uU4lwrB3XEQbWve8zXoO5No4eFrGcTAMYyoY67p8jRQdtA1HbA==} - engines: {node: '>=12'} - tiny-warning@1.0.3: resolution: {integrity: sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA==} @@ -9266,10 +8653,6 @@ packages: tr46@0.0.3: resolution: {integrity: sha512-N3WMsuqV66lT30CrXNbEjx4GEwlow3v6rr4mCcv6prnfwhS01rkgyFdjPNBYd9br7LpXV1+Emh01fHnq2Gdgrw==} - traverse@0.6.9: - resolution: {integrity: sha512-7bBrcF+/LQzSgFmT0X5YclVqQxtv7TDJ1f8Wj7ibBu/U6BMLeOpUxuZjV7rMc44UtKxlnMFigdhFAIszSX1DMg==} - engines: {node: '>= 0.4'} - tree-kill@1.2.2: resolution: {integrity: sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==} hasBin: true @@ -9358,10 +8741,6 @@ packages: tunnel-agent@0.6.0: resolution: {integrity: sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==} - tunnel@0.0.6: - resolution: {integrity: sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==} - engines: {node: '>=0.6.11 <=0.7.0 || >=0.7.3'} - tweetnacl@0.14.5: resolution: {integrity: sha512-KXXFFdAbFXY4geFIwoyNK+f5Z1b7swfXABfL7HXCmoIWMKU3dmS26672A4EeQtDzLKy7SXmfBu51JolvEKwtGA==} @@ -9397,18 +8776,6 @@ packages: resolution: {integrity: sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==} engines: {node: '>=8'} - type-fest@1.4.0: - resolution: {integrity: sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA==} - engines: {node: '>=10'} - - type-fest@2.19.0: - resolution: {integrity: sha512-RAH822pAdBgcNMAfWnCBU3CFZcfZ/i1eZjwFU/dsLKumyuuP3niueg2UAukXYF0E2AAoc82ZSSf9J0WQBinzHA==} - engines: {node: '>=12.20'} - - type-fest@4.41.0: - resolution: {integrity: sha512-TeTSQ6H5YHvpqVwBRcnLDCBnDOHWYu7IvGbHT6N8AOymcr9PJGjc1GTtiWZTYg0NCgYwvnYWEkVChQAr9bjfwA==} - engines: {node: '>=16'} - type-is@1.6.18: resolution: {integrity: sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==} engines: {node: '>= 0.6'} @@ -9429,10 +8796,6 @@ packages: resolution: {integrity: sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==} engines: {node: '>= 0.4'} - typedarray.prototype.slice@1.0.3: - resolution: {integrity: sha512-8WbVAQAUlENo1q3c3zZYuy5k9VzBQvp8AX9WOtbvyWlLM1v5JaSRmjubLjzHF4JFtptjH/5c/i95yaElvcjC0A==} - engines: {node: '>= 0.4'} - typedarray@0.0.6: resolution: {integrity: sha512-/aCDEGatGvZ2BIk+HmLf4ifCJFwvKFNb9/JeZPMulfgFracn9QFcAf5GO8B/mweUjSoblS5In0cWhqpfs/5PQA==} @@ -9541,10 +8904,6 @@ packages: undici-types@6.20.0: resolution: {integrity: sha512-Ny6QZ2Nju20vw1SRHe3d9jVu6gJ+4e3+MMpqu7pqE5HT6WsTSlce++GQmK5UXS8mzV8DSYHrQH+Xrf2jVcuKNg==} - undici@5.29.0: - resolution: {integrity: sha512-raqeBD6NQK4SkWhQzeYKd1KmIG6dllBOTt55Rmkt4HtI9mwdWtJljnrXjAFUBLTSN67HWrOIZ3EPF4kjUw80Bg==} - engines: {node: '>=14.0'} - undici@7.3.0: resolution: {integrity: sha512-Qy96NND4Dou5jKoSJ2gm8ax8AJM/Ey9o9mz7KN1bb9GP+G0l20Zw8afxTnY2f4b7hmhn/z8aC2kfArVQlAhFBw==} engines: {node: '>=20.18.1'} @@ -9553,10 +8912,6 @@ packages: resolution: {integrity: sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==} engines: {node: '>=4'} - unicode-emoji-modifier-base@1.0.0: - resolution: {integrity: sha512-yLSH4py7oFH3oG/9K+XWrz1pSi3dfUrWEnInbxMfArOfc1+33BlGPQtLsOYwvdMy11AwUBetYuaRxSPqgkq+8g==} - engines: {node: '>=4'} - unicode-emoji-utils@1.2.0: resolution: {integrity: sha512-djUB91p/6oYpgps4W5K/MAvM+UspoAANHSUW495BrxeLRoned3iNPEDQgrKx9LbLq93VhNz0NWvI61vcfrwYoA==} @@ -9576,14 +8931,6 @@ packages: resolution: {integrity: sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==} engines: {node: '>=4'} - unicorn-magic@0.1.0: - resolution: {integrity: sha512-lRfVq8fE8gz6QMBuDM6a+LO3IAzTi05H6gCVaUpir2E1Rwpo4ZUog45KpNXKC/Mn3Yb9UDuHumeFTo9iV/D9FQ==} - engines: {node: '>=18'} - - unicorn-magic@0.3.0: - resolution: {integrity: sha512-+QBBXBCvifc56fsbuxZQ6Sic3wqqc3WWaqxs58gvJrcOuN83HGTCwz3oS5phzU9LthRNE9VrJCFCLUgHeeFnfA==} - engines: {node: '>=18'} - unified@10.1.2: resolution: {integrity: sha512-pUSWAi/RAnVy1Pif2kAoeWNBa3JVrx0MId2LASj8G+7AiHWoKZNTomq6LG326T68U7/e263X6fTdcXIy7XnF7Q==} @@ -9601,10 +8948,6 @@ packages: resolution: {integrity: sha512-8EyMynh679x/0gqE9fT9oilG+qEt+ibFyqjuVTsZn1+CMxH+XLlpvr2UZx4nVcCwTpx81nICr2JQFkM+HPLq4w==} engines: {node: ^12.13.0 || ^14.15.0 || >=16.0.0} - unique-string@3.0.0: - resolution: {integrity: sha512-VGXBUVwxKMBUznyffQweQABPRRW1vHZAbadFZud4pLFAqRGvv/96vafgjWFqzourzr8YonlQiPgH0YCJfawoGQ==} - engines: {node: '>=12'} - unist-util-generated@2.0.1: resolution: {integrity: sha512-qF72kLmPxAw0oN2fwpWIqbXAVyEqUzDHMsbtPvOudIlUzXYFIeQIuxXQCRCFh22B7cixvU0MG7m3MW8FTq/S+A==} @@ -9623,9 +8966,6 @@ packages: unist-util-visit@4.1.2: resolution: {integrity: sha512-MSd8OUGISqHdVvfY9TPhyK2VdUrPgxkUtWSuMHF6XAAFuL4LokseigBnZtPnJMu+FbynTkFNnFlyjxpVKujMRg==} - universal-user-agent@7.0.3: - resolution: {integrity: sha512-TmnEAEAsBJVZM/AADELsK76llnwcf9vMKuPz8JflO1frO8Lchitr0fNaN9d+Ap0BjKtqWqd/J17qeDnXh8CL2A==} - universalify@0.1.2: resolution: {integrity: sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==} engines: {node: '>= 4.0.0'} @@ -9657,10 +8997,6 @@ packages: uri-js@4.4.1: resolution: {integrity: sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==} - url-join@5.0.0: - resolution: {integrity: sha512-n2huDr9h9yzd6exQVnH/jU5mr+Pfx08LRXXZhkLLetAMESRj+anQsTAh940iMrIetKAmry9coFuZQ2jY8/p3WA==} - engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - urlsafe-base64@1.0.0: resolution: {integrity: sha512-RtuPeMy7c1UrHwproMZN9gN6kiZ0SvJwRaEzwZY0j9MypEkFqyBaKv176jvlPtg58Zh36bOkS0NFABXMHvvGCA==} @@ -9956,10 +9292,6 @@ packages: resolution: {integrity: sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==} engines: {node: '>=10'} - yoctocolors@2.1.1: - resolution: {integrity: sha512-GQHQqAopRhwU8Kt1DDM8NjibDXHC8eoh1erhGAJPEyveY9qqVeXvVikNKrDz69sHowPMorbPUrH/mx8c50eiBQ==} - engines: {node: '>=18'} - yup@0.32.11: resolution: {integrity: sha512-Z2Fe1bn+eLstG8DRR6FTavGD+MeAwyfmouhHsIUgaADz8jvFKbO/fXc2trJKZg+5EBjh4gGm3iU/t3onKlXHIg==} engines: {node: '>=10'} @@ -9981,22 +9313,6 @@ packages: snapshots: - '@actions/core@1.11.1': - dependencies: - '@actions/exec': 1.1.1 - '@actions/http-client': 2.2.3 - - '@actions/exec@1.1.1': - dependencies: - '@actions/io': 1.1.3 - - '@actions/http-client@2.2.3': - dependencies: - tunnel: 0.0.6 - undici: 5.29.0 - - '@actions/io@1.1.3': {} - '@ampproject/remapping@2.3.0': dependencies: '@jridgewell/gen-mapping': 0.3.5 @@ -10014,12 +9330,6 @@ snapshots: '@babel/highlight': 7.24.7 picocolors: 1.0.1 - '@babel/code-frame@7.26.2': - dependencies: - '@babel/helper-validator-identifier': 7.25.9 - js-tokens: 4.0.0 - picocolors: 1.1.1 - '@babel/code-frame@7.27.1': dependencies: '@babel/helper-validator-identifier': 7.27.1 @@ -11450,17 +10760,6 @@ snapshots: '@babel/helper-string-parser': 7.27.1 '@babel/helper-validator-identifier': 7.27.1 - '@codedependant/semantic-release-docker@5.1.0': - dependencies: - '@actions/core': 1.11.1 - '@semantic-release/error': 3.0.0 - debug: 4.4.0(supports-color@5.5.0) - execa: 4.1.0 - handlebars: 4.7.8 - semver: 7.7.1 - transitivePeerDependencies: - - supports-color - '@colors/colors@1.5.0': {} '@colors/colors@1.6.0': {} @@ -11804,8 +11103,6 @@ snapshots: '@eslint/js@8.35.0': {} - '@fastify/busboy@2.1.1': {} - '@floating-ui/core@1.6.2': dependencies: '@floating-ui/utils': 0.2.2 @@ -12293,80 +11590,9 @@ snapshots: mkdirp: 1.0.4 rimraf: 3.0.2 - '@octokit/auth-token@6.0.0': {} - - '@octokit/core@7.0.3': - dependencies: - '@octokit/auth-token': 6.0.0 - '@octokit/graphql': 9.0.1 - '@octokit/request': 10.0.3 - '@octokit/request-error': 7.0.0 - '@octokit/types': 14.1.0 - before-after-hook: 4.0.0 - universal-user-agent: 7.0.3 - - '@octokit/endpoint@11.0.0': - dependencies: - '@octokit/types': 14.1.0 - universal-user-agent: 7.0.3 - - '@octokit/graphql@9.0.1': - dependencies: - '@octokit/request': 10.0.3 - '@octokit/types': 14.1.0 - universal-user-agent: 7.0.3 - - '@octokit/openapi-types@25.1.0': {} - - '@octokit/plugin-paginate-rest@13.1.1(@octokit/core@7.0.3)': - dependencies: - '@octokit/core': 7.0.3 - '@octokit/types': 14.1.0 - - '@octokit/plugin-retry@8.0.1(@octokit/core@7.0.3)': - dependencies: - '@octokit/core': 7.0.3 - '@octokit/request-error': 7.0.0 - '@octokit/types': 14.1.0 - bottleneck: 2.19.5 - - '@octokit/plugin-throttling@11.0.1(@octokit/core@7.0.3)': - dependencies: - '@octokit/core': 7.0.3 - '@octokit/types': 14.1.0 - bottleneck: 2.19.5 - - '@octokit/request-error@7.0.0': - dependencies: - '@octokit/types': 14.1.0 - - '@octokit/request@10.0.3': - dependencies: - '@octokit/endpoint': 11.0.0 - '@octokit/request-error': 7.0.0 - '@octokit/types': 14.1.0 - fast-content-type-parse: 3.0.0 - universal-user-agent: 7.0.3 - - '@octokit/types@14.1.0': - dependencies: - '@octokit/openapi-types': 25.1.0 - '@pkgjs/parseargs@0.11.0': optional: true - '@pnpm/config.env-replace@1.1.0': {} - - '@pnpm/network.ca-file@1.0.2': - dependencies: - graceful-fs: 4.2.10 - - '@pnpm/npm-conf@2.2.2': - dependencies: - '@pnpm/config.env-replace': 1.1.0 - '@pnpm/network.ca-file': 1.0.2 - config-chain: 1.1.13 - '@popperjs/core@2.11.8': {} '@react-aria/breadcrumbs@3.5.13(react@18.3.1)': @@ -13582,108 +12808,11 @@ snapshots: '@rushstack/eslint-patch@1.10.3': {} - '@sec-ant/readable-stream@0.4.1': {} - '@selderee/plugin-htmlparser2@0.11.0': dependencies: domhandler: 5.0.3 selderee: 0.11.0 - '@semantic-release/changelog@6.0.3(semantic-release@24.2.7(typescript@4.9.5))': - dependencies: - '@semantic-release/error': 3.0.0 - aggregate-error: 3.1.0 - fs-extra: 11.2.0 - lodash: 4.17.21 - semantic-release: 24.2.7(typescript@4.9.5) - - '@semantic-release/commit-analyzer@13.0.1(semantic-release@24.2.7(typescript@4.9.5))': - dependencies: - conventional-changelog-angular: 8.0.0 - conventional-changelog-writer: 8.2.0 - conventional-commits-filter: 5.0.0 - conventional-commits-parser: 6.2.0 - debug: 4.4.0(supports-color@5.5.0) - import-from-esm: 2.0.0 - lodash-es: 4.17.21 - micromatch: 4.0.8 - semantic-release: 24.2.7(typescript@4.9.5) - transitivePeerDependencies: - - supports-color - - '@semantic-release/error@3.0.0': {} - - '@semantic-release/error@4.0.0': {} - - '@semantic-release/git@10.0.1(semantic-release@24.2.7(typescript@4.9.5))': - dependencies: - '@semantic-release/error': 3.0.0 - aggregate-error: 3.1.0 - debug: 4.3.5 - dir-glob: 3.0.1 - execa: 5.1.1 - lodash: 4.17.21 - micromatch: 4.0.8 - p-reduce: 2.1.0 - semantic-release: 24.2.7(typescript@4.9.5) - transitivePeerDependencies: - - supports-color - - '@semantic-release/github@11.0.3(semantic-release@24.2.7(typescript@4.9.5))': - dependencies: - '@octokit/core': 7.0.3 - '@octokit/plugin-paginate-rest': 13.1.1(@octokit/core@7.0.3) - '@octokit/plugin-retry': 8.0.1(@octokit/core@7.0.3) - '@octokit/plugin-throttling': 11.0.1(@octokit/core@7.0.3) - '@semantic-release/error': 4.0.0 - aggregate-error: 5.0.0 - debug: 4.4.0(supports-color@5.5.0) - dir-glob: 3.0.1 - globby: 14.1.0 - http-proxy-agent: 7.0.2 - https-proxy-agent: 7.0.6 - issue-parser: 7.0.1 - lodash-es: 4.17.21 - mime: 4.0.7 - p-filter: 4.1.0 - semantic-release: 24.2.7(typescript@4.9.5) - url-join: 5.0.0 - transitivePeerDependencies: - - supports-color - - '@semantic-release/npm@12.0.2(semantic-release@24.2.7(typescript@4.9.5))': - dependencies: - '@semantic-release/error': 4.0.0 - aggregate-error: 5.0.0 - execa: 9.6.0 - fs-extra: 11.2.0 - lodash-es: 4.17.21 - nerf-dart: 1.0.0 - normalize-url: 8.0.2 - npm: 10.9.3 - rc: 1.2.8 - read-pkg: 9.0.1 - registry-auth-token: 5.0.2 - semantic-release: 24.2.7(typescript@4.9.5) - semver: 7.7.1 - tempy: 3.1.0 - - '@semantic-release/release-notes-generator@14.0.3(semantic-release@24.2.7(typescript@4.9.5))': - dependencies: - conventional-changelog-angular: 8.0.0 - conventional-changelog-writer: 8.2.0 - conventional-commits-filter: 5.0.0 - conventional-commits-parser: 6.2.0 - debug: 4.4.0(supports-color@5.5.0) - get-stream: 7.0.1 - import-from-esm: 2.0.0 - into-stream: 7.0.0 - lodash-es: 4.17.21 - read-package-up: 11.0.0 - semantic-release: 24.2.7(typescript@4.9.5) - transitivePeerDependencies: - - supports-color - '@sideway/address@4.1.5': dependencies: '@hapi/hoek': 9.3.0 @@ -13694,12 +12823,6 @@ snapshots: '@sinclair/typebox@0.27.8': {} - '@sindresorhus/is@4.6.0': {} - - '@sindresorhus/merge-streams@2.3.0': {} - - '@sindresorhus/merge-streams@4.0.0': {} - '@sinonjs/commons@3.0.1': dependencies: type-detect: 4.0.8 @@ -14379,11 +13502,6 @@ snapshots: clean-stack: 2.2.0 indent-string: 4.0.0 - aggregate-error@5.0.0: - dependencies: - clean-stack: 5.2.0 - indent-string: 5.0.0 - ajv@6.12.6: dependencies: fast-deep-equal: 3.1.3 @@ -14412,10 +13530,6 @@ snapshots: dependencies: type-fest: 0.21.3 - ansi-escapes@7.0.0: - dependencies: - environment: 1.1.0 - ansi-fragments@0.2.1: dependencies: colorette: 1.4.0 @@ -14428,8 +13542,6 @@ snapshots: ansi-regex@6.0.1: {} - ansi-regex@6.1.0: {} - ansi-styles@3.2.1: dependencies: color-convert: 1.9.3 @@ -14479,8 +13591,6 @@ snapshots: argparse@2.0.1: {} - argv-formatter@1.0.0: {} - aria-query@5.1.3: dependencies: deep-equal: 2.2.3 @@ -14763,8 +13873,6 @@ snapshots: - encoding - supports-color - before-after-hook@4.0.0: {} - binary-extensions@2.3.0: {} bindings@1.5.0: @@ -14806,8 +13914,6 @@ snapshots: boolean@3.2.0: {} - bottleneck@2.19.5: {} - bowser@2.11.0: {} brace-expansion@1.1.11: @@ -14989,10 +14095,6 @@ snapshots: chalk@5.3.0: optional: true - chalk@5.4.1: {} - - char-regex@1.0.2: {} - character-entities@2.0.2: {} character-parser@2.2.0: @@ -15057,10 +14159,6 @@ snapshots: clean-stack@2.2.0: {} - clean-stack@5.2.0: - dependencies: - escape-string-regexp: 5.0.0 - cli-cursor@3.1.0: dependencies: restore-cursor: 3.1.0 @@ -15238,11 +14336,6 @@ snapshots: readable-stream: 2.3.8 typedarray: 0.0.6 - config-chain@1.1.13: - dependencies: - ini: 1.3.8 - proto-list: 1.2.4 - connect-typeorm@1.1.4(typeorm@0.3.12(pg@8.11.0)(sqlite3@5.1.7)(ts-node@10.9.1(@swc/core@1.6.5(@swc/helpers@0.5.11))(@types/node@22.10.5)(typescript@4.9.5))): dependencies: '@types/debug': 0.0.31 @@ -15279,27 +14372,14 @@ snapshots: dependencies: compare-func: 2.0.0 - conventional-changelog-angular@8.0.0: - dependencies: - compare-func: 2.0.0 - conventional-changelog-conventionalcommits@5.0.0: dependencies: compare-func: 2.0.0 lodash: 4.17.21 q: 1.5.1 - conventional-changelog-writer@8.2.0: - dependencies: - conventional-commits-filter: 5.0.0 - handlebars: 4.7.8 - meow: 13.2.0 - semver: 7.7.1 - conventional-commit-types@3.0.0: {} - conventional-commits-filter@5.0.0: {} - conventional-commits-parser@4.0.0: dependencies: JSONStream: 1.3.5 @@ -15307,12 +14387,6 @@ snapshots: meow: 8.1.2 split2: 3.2.2 - conventional-commits-parser@6.2.0: - dependencies: - meow: 13.2.0 - - convert-hrtime@5.0.0: {} - convert-source-map@1.9.0: {} convert-source-map@2.0.0: {} @@ -15415,6 +14489,7 @@ snapshots: parse-json: 5.2.0 optionalDependencies: typescript: 4.9.5 + optional: true country-flag-icons@1.5.5: {} @@ -15441,10 +14516,6 @@ snapshots: shebang-command: 2.0.0 which: 2.0.2 - crypto-random-string@4.0.0: - dependencies: - type-fest: 1.4.0 - css-select@4.3.0: dependencies: boolbase: 1.0.0 @@ -15787,10 +14858,6 @@ snapshots: es-errors: 1.3.0 gopd: 1.2.0 - duplexer2@0.1.4: - dependencies: - readable-stream: 2.3.8 - eastasianwidth@0.2.0: {} ecc-jsbn@0.1.2: @@ -15878,8 +14945,6 @@ snapshots: emoji-regex@9.2.2: {} - emojilib@2.4.0: {} - emojis-list@3.0.0: {} enabled@2.0.0: {} @@ -15914,17 +14979,10 @@ snapshots: entities@4.5.0: {} - env-ci@11.1.1: - dependencies: - execa: 8.0.1 - java-properties: 1.0.2 - env-paths@2.2.1: {} envinfo@7.14.0: {} - environment@1.1.0: {} - err-code@2.0.3: {} error-ex@1.3.2: @@ -16074,8 +15132,6 @@ snapshots: escape-string-regexp@4.0.0: {} - escape-string-regexp@5.0.0: {} - eslint-config-next@14.2.4(eslint@8.35.0)(typescript@4.9.5): dependencies: '@next/eslint-plugin-next': 14.2.4 @@ -16111,7 +15167,7 @@ snapshots: debug: 4.4.0(supports-color@5.5.0) enhanced-resolve: 5.17.0 eslint: 8.35.0 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1)(eslint@8.35.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.35.0))(eslint@8.35.0) eslint-plugin-import: 2.29.1(@typescript-eslint/parser@5.54.0(eslint@8.35.0)(typescript@4.9.5))(eslint@8.35.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 @@ -16133,7 +15189,7 @@ snapshots: transitivePeerDependencies: - supports-color - eslint-module-utils@2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1)(eslint@8.35.0): + eslint-module-utils@2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.35.0))(eslint@8.35.0): dependencies: debug: 3.2.7(supports-color@8.1.1) optionalDependencies: @@ -16433,33 +15489,6 @@ snapshots: signal-exit: 3.0.7 strip-final-newline: 3.0.0 - execa@8.0.1: - dependencies: - cross-spawn: 7.0.6 - get-stream: 8.0.1 - human-signals: 5.0.0 - is-stream: 3.0.0 - merge-stream: 2.0.0 - npm-run-path: 5.3.0 - onetime: 6.0.0 - signal-exit: 4.1.0 - strip-final-newline: 3.0.0 - - execa@9.6.0: - dependencies: - '@sindresorhus/merge-streams': 4.0.0 - cross-spawn: 7.0.6 - figures: 6.1.0 - get-stream: 9.0.1 - human-signals: 8.0.1 - is-plain-obj: 4.1.0 - is-stream: 4.0.1 - npm-run-path: 6.0.0 - pretty-ms: 9.2.0 - signal-exit: 4.1.0 - strip-final-newline: 4.0.0 - yoctocolors: 2.1.1 - executable@4.1.1: dependencies: pify: 2.3.0 @@ -16565,8 +15594,6 @@ snapshots: extsprintf@1.4.1: {} - fast-content-type-parse@3.0.0: {} - fast-deep-equal@3.1.3: {} fast-diff@1.3.0: {} @@ -16611,18 +15638,10 @@ snapshots: fecha@4.2.3: {} - figures@2.0.0: - dependencies: - escape-string-regexp: 1.0.5 - figures@3.2.0: dependencies: escape-string-regexp: 1.0.5 - figures@6.1.0: - dependencies: - is-unicode-supported: 2.1.0 - file-entry-cache@6.0.1: dependencies: flat-cache: 3.2.0 @@ -16674,12 +15693,6 @@ snapshots: find-root@1.1.0: {} - find-up-simple@1.0.1: {} - - find-up@2.1.0: - dependencies: - locate-path: 2.0.0 - find-up@3.0.0: dependencies: locate-path: 3.0.0 @@ -16694,11 +15707,6 @@ snapshots: locate-path: 6.0.0 path-exists: 4.0.0 - find-versions@6.0.0: - dependencies: - semver-regex: 4.0.5 - super-regex: 1.0.0 - findup-sync@4.0.0: dependencies: detect-file: 1.0.0 @@ -16782,11 +15790,6 @@ snapshots: fresh@0.5.2: {} - from2@2.3.0: - dependencies: - inherits: 2.0.4 - readable-stream: 2.3.8 - fs-constants@1.0.0: {} fs-extra@11.2.0: @@ -16819,8 +15822,6 @@ snapshots: function-bind@1.1.2: {} - function-timeout@1.0.2: {} - function.prototype.name@1.1.6: dependencies: call-bind: 1.0.7 @@ -16899,15 +15900,6 @@ snapshots: get-stream@6.0.1: {} - get-stream@7.0.1: {} - - get-stream@8.0.1: {} - - get-stream@9.0.1: - dependencies: - '@sec-ant/readable-stream': 0.4.1 - is-stream: 4.0.1 - get-symbol-description@1.0.2: dependencies: call-bind: 1.0.7 @@ -16926,15 +15918,6 @@ snapshots: dependencies: assert-plus: 1.0.0 - git-log-parser@1.2.0: - dependencies: - argv-formatter: 1.0.0 - spawn-error-forwarder: 1.0.0 - split2: 1.0.0 - stream-combiner2: 1.1.1 - through2: 2.0.5 - traverse: 0.6.9 - git-raw-commits@2.0.11: dependencies: dargs: 7.0.0 @@ -17025,23 +16008,12 @@ snapshots: merge2: 1.4.1 slash: 3.0.0 - globby@14.1.0: - dependencies: - '@sindresorhus/merge-streams': 2.3.0 - fast-glob: 3.3.3 - ignore: 7.0.5 - path-type: 6.0.0 - slash: 5.1.0 - unicorn-magic: 0.3.0 - gopd@1.0.1: dependencies: get-intrinsic: 1.2.4 gopd@1.2.0: {} - graceful-fs@4.2.10: {} - graceful-fs@4.2.11: {} grapheme-splitter@1.0.4: {} @@ -17059,6 +16031,7 @@ snapshots: wordwrap: 1.0.0 optionalDependencies: uglify-js: 3.18.0 + optional: true har-schema@2.0.0: {} @@ -17128,22 +16101,12 @@ snapshots: dependencies: parse-passwd: 1.0.0 - hook-std@3.0.0: {} - hosted-git-info@2.8.9: {} hosted-git-info@4.1.0: dependencies: lru-cache: 6.0.0 - hosted-git-info@7.0.2: - dependencies: - lru-cache: 10.4.3 - - hosted-git-info@8.1.0: - dependencies: - lru-cache: 10.2.2 - html-to-text@9.0.5: dependencies: '@selderee/plugin-htmlparser2': 0.11.0 @@ -17243,10 +16206,6 @@ snapshots: human-signals@3.0.1: {} - human-signals@5.0.0: {} - - human-signals@8.0.1: {} - humanize-ms@1.2.1: dependencies: ms: 2.1.3 @@ -17283,8 +16242,6 @@ snapshots: ignore@5.3.1: {} - ignore@7.0.5: {} - image-size@1.2.1: dependencies: queue: 6.0.2 @@ -17299,23 +16256,13 @@ snapshots: parent-module: 1.0.1 resolve-from: 4.0.0 - import-from-esm@2.0.0: - dependencies: - debug: 4.4.0(supports-color@5.5.0) - import-meta-resolve: 4.1.0 - transitivePeerDependencies: - - supports-color - - import-meta-resolve@4.1.0: {} + import-meta-resolve@4.1.0: + optional: true imurmurhash@0.1.4: {} indent-string@4.0.0: {} - indent-string@5.0.0: {} - - index-to-position@1.1.0: {} - infer-owner@1.0.4: {} inflight@1.0.6: @@ -17365,11 +16312,6 @@ snapshots: '@formatjs/icu-messageformat-parser': 2.7.8 tslib: 2.6.3 - into-stream@7.0.0: - dependencies: - from2: 2.3.0 - p-is-promise: 3.0.0 - invariant@2.2.4: dependencies: loose-envify: 1.4.0 @@ -17519,8 +16461,6 @@ snapshots: is-stream@3.0.0: {} - is-stream@4.0.1: {} - is-string@1.0.7: dependencies: has-tostringtag: 1.0.2 @@ -17541,8 +16481,6 @@ snapshots: is-unicode-supported@0.1.0: {} - is-unicode-supported@2.1.0: {} - is-utf8@0.2.1: {} is-weakmap@2.0.2: {} @@ -17576,14 +16514,6 @@ snapshots: isstream@0.1.2: {} - issue-parser@7.0.1: - dependencies: - lodash.capitalize: 4.2.1 - lodash.escaperegexp: 4.1.2 - lodash.isplainobject: 4.0.6 - lodash.isstring: 4.0.1 - lodash.uniqby: 4.7.0 - iterator.prototype@1.1.2: dependencies: define-properties: 1.2.1 @@ -17605,8 +16535,6 @@ snapshots: optionalDependencies: '@pkgjs/parseargs': 0.11.0 - java-properties@1.0.2: {} - jest-environment-node@29.7.0: dependencies: '@jest/environment': 29.7.0 @@ -17948,18 +16876,6 @@ snapshots: optionalDependencies: enquirer: 2.4.1 - load-json-file@4.0.0: - dependencies: - graceful-fs: 4.2.11 - parse-json: 4.0.0 - pify: 3.0.0 - strip-bom: 3.0.0 - - locate-path@2.0.0: - dependencies: - p-locate: 2.0.0 - path-exists: 3.0.0 - locate-path@3.0.0: dependencies: p-locate: 3.0.0 @@ -17977,16 +16893,12 @@ snapshots: lodash.camelcase@4.3.0: {} - lodash.capitalize@4.2.1: {} - lodash.castarray@4.4.0: {} lodash.clonedeep@4.5.0: {} lodash.debounce@4.0.8: {} - lodash.escaperegexp@4.1.2: {} - lodash.get@4.4.2: {} lodash.isequal@4.5.0: {} @@ -17995,8 +16907,6 @@ snapshots: lodash.isplainobject@4.0.6: {} - lodash.isstring@4.0.1: {} - lodash.kebabcase@4.1.1: {} lodash.map@4.6.0: {} @@ -18015,8 +16925,6 @@ snapshots: lodash.uniq@4.5.0: {} - lodash.uniqby@4.7.0: {} - lodash.upperfirst@4.3.1: {} lodash.zipobject@4.1.3: {} @@ -18058,8 +16966,6 @@ snapshots: dependencies: js-tokens: 4.0.0 - lru-cache@10.2.2: {} - lru-cache@10.4.3: {} lru-cache@11.2.1: {} @@ -18167,19 +17073,6 @@ snapshots: map-obj@4.3.0: {} - marked-terminal@7.3.0(marked@15.0.12): - dependencies: - ansi-escapes: 7.0.0 - ansi-regex: 6.1.0 - chalk: 5.4.1 - cli-highlight: 2.1.11 - cli-table3: 0.6.5 - marked: 15.0.12 - node-emoji: 2.2.0 - supports-hyperlinks: 3.2.0 - - marked@15.0.12: {} - marky@1.3.0: {} math-interval-parser@2.0.1: {} @@ -18240,8 +17133,6 @@ snapshots: mensch@0.3.4: {} - meow@13.2.0: {} - meow@8.1.2: dependencies: '@types/minimist': 1.2.5 @@ -18596,8 +17487,6 @@ snapshots: mime@3.0.0: {} - mime@4.0.7: {} - mimic-fn@2.1.0: {} mimic-fn@4.0.0: {} @@ -18750,8 +17639,6 @@ snapshots: neo-async@2.6.2: {} - nerf-dart@1.0.0: {} - next@14.2.25(@babel/core@7.24.7)(react-dom@18.3.1(react@18.3.1))(react@18.3.1): dependencies: '@next/env': 14.2.25 @@ -18800,13 +17687,6 @@ snapshots: dependencies: minimatch: 3.1.2 - node-emoji@2.2.0: - dependencies: - '@sindresorhus/is': 4.6.0 - char-regex: 1.0.2 - emojilib: 2.4.0 - skin-tone: 2.0.0 - node-fetch@2.7.0(encoding@0.1.13): dependencies: whatwg-url: 5.0.0 @@ -18907,18 +17787,10 @@ snapshots: semver: 7.7.1 validate-npm-package-license: 3.0.4 - normalize-package-data@6.0.2: - dependencies: - hosted-git-info: 7.0.2 - semver: 7.7.1 - validate-npm-package-license: 3.0.4 - normalize-path@3.0.0: {} normalize-range@0.1.2: {} - normalize-url@8.0.2: {} - npm-run-path@2.0.2: dependencies: path-key: 2.0.1 @@ -18932,13 +17804,6 @@ snapshots: dependencies: path-key: 4.0.0 - npm-run-path@6.0.0: - dependencies: - path-key: 4.0.0 - unicorn-magic: 0.3.0 - - npm@10.9.3: {} - npmlog@5.0.1: dependencies: are-we-there-yet: 2.0.0 @@ -19090,26 +17955,14 @@ snapshots: ospath@1.2.2: {} - p-each-series@3.0.0: {} - p-event@4.2.0: dependencies: p-timeout: 3.2.0 optional: true - p-filter@4.1.0: - dependencies: - p-map: 7.0.3 - p-finally@1.0.0: optional: true - p-is-promise@3.0.0: {} - - p-limit@1.3.0: - dependencies: - p-try: 1.0.0 - p-limit@2.3.0: dependencies: p-try: 2.2.0 @@ -19118,10 +17971,6 @@ snapshots: dependencies: yocto-queue: 0.1.0 - p-locate@2.0.0: - dependencies: - p-limit: 1.3.0 - p-locate@3.0.0: dependencies: p-limit: 2.3.0 @@ -19138,19 +17987,11 @@ snapshots: dependencies: aggregate-error: 3.1.0 - p-map@7.0.3: {} - - p-reduce@2.1.0: {} - - p-reduce@3.0.0: {} - p-timeout@3.2.0: dependencies: p-finally: 1.0.0 optional: true - p-try@1.0.0: {} - p-try@2.2.0: {} p-wait-for@3.2.0: @@ -19176,14 +18017,6 @@ snapshots: json-parse-even-better-errors: 2.3.1 lines-and-columns: 1.2.4 - parse-json@8.3.0: - dependencies: - '@babel/code-frame': 7.26.2 - index-to-position: 1.1.0 - type-fest: 4.41.0 - - parse-ms@4.0.0: {} - parse-passwd@1.0.0: {} parse5-htmlparser2-tree-adapter@6.0.1: @@ -19236,8 +18069,6 @@ snapshots: path-type@4.0.0: {} - path-type@6.0.0: {} - peberminta@0.9.0: {} pend@1.2.0: {} @@ -19291,17 +18122,10 @@ snapshots: pify@2.3.0: {} - pify@3.0.0: {} - pify@4.0.1: {} pirates@4.0.7: {} - pkg-conf@2.1.0: - dependencies: - find-up: 2.1.0 - load-json-file: 4.0.0 - pkg-dir@3.0.0: dependencies: find-up: 3.0.0 @@ -19433,10 +18257,6 @@ snapshots: ansi-styles: 5.2.0 react-is: 18.3.1 - pretty-ms@9.2.0: - dependencies: - parse-ms: 4.0.0 - preview-email@3.1.0: dependencies: ci-info: 3.9.0 @@ -19486,8 +18306,6 @@ snapshots: property-information@6.5.0: {} - proto-list@1.2.4: {} - proxy-addr@2.0.7: dependencies: forwarded: 0.2.0 @@ -19941,12 +18759,6 @@ snapshots: dependencies: pify: 2.3.0 - read-package-up@11.0.0: - dependencies: - find-up-simple: 1.0.1 - read-pkg: 9.0.1 - type-fest: 4.41.0 - read-pkg-up@7.0.1: dependencies: find-up: 4.1.0 @@ -19960,14 +18772,6 @@ snapshots: parse-json: 5.2.0 type-fest: 0.6.0 - read-pkg@9.0.1: - dependencies: - '@types/normalize-package-data': 2.4.4 - normalize-package-data: 6.0.2 - parse-json: 8.3.0 - type-fest: 4.41.0 - unicorn-magic: 0.1.0 - readable-stream@1.0.34: dependencies: core-util-is: 1.0.3 @@ -20066,10 +18870,6 @@ snapshots: unicode-match-property-ecmascript: 2.0.0 unicode-match-property-value-ecmascript: 2.2.1 - registry-auth-token@5.0.2: - dependencies: - '@pnpm/npm-conf': 2.2.2 - regjsgen@0.8.0: {} regjsparser@0.12.0: @@ -20274,47 +19074,6 @@ snapshots: '@types/node-forge': 1.3.14 node-forge: 1.3.1 - semantic-release@24.2.7(typescript@4.9.5): - dependencies: - '@semantic-release/commit-analyzer': 13.0.1(semantic-release@24.2.7(typescript@4.9.5)) - '@semantic-release/error': 4.0.0 - '@semantic-release/github': 11.0.3(semantic-release@24.2.7(typescript@4.9.5)) - '@semantic-release/npm': 12.0.2(semantic-release@24.2.7(typescript@4.9.5)) - '@semantic-release/release-notes-generator': 14.0.3(semantic-release@24.2.7(typescript@4.9.5)) - aggregate-error: 5.0.0 - cosmiconfig: 9.0.0(typescript@4.9.5) - debug: 4.4.0(supports-color@5.5.0) - env-ci: 11.1.1 - execa: 9.6.0 - figures: 6.1.0 - find-versions: 6.0.0 - get-stream: 6.0.1 - git-log-parser: 1.2.0 - hook-std: 3.0.0 - hosted-git-info: 8.1.0 - import-from-esm: 2.0.0 - lodash-es: 4.17.21 - marked: 15.0.12 - marked-terminal: 7.3.0(marked@15.0.12) - micromatch: 4.0.8 - p-each-series: 3.0.0 - p-reduce: 3.0.0 - read-package-up: 11.0.0 - resolve-from: 5.0.0 - semver: 7.7.1 - semver-diff: 4.0.0 - signale: 1.4.0 - yargs: 17.7.2 - transitivePeerDependencies: - - supports-color - - typescript - - semver-diff@4.0.0: - dependencies: - semver: 7.7.1 - - semver-regex@4.0.5: {} - semver@5.7.2: {} semver@6.3.1: {} @@ -20464,12 +19223,6 @@ snapshots: signal-exit@4.1.0: {} - signale@1.4.0: - dependencies: - chalk: 2.4.2 - figures: 2.0.0 - pkg-conf: 2.1.0 - simple-concat@1.0.1: {} simple-get@4.0.1: @@ -20488,14 +19241,8 @@ snapshots: sisteransi@1.0.5: {} - skin-tone@2.0.0: - dependencies: - unicode-emoji-modifier-base: 1.0.0 - slash@3.0.0: {} - slash@5.1.0: {} - slice-ansi@2.1.0: dependencies: ansi-styles: 3.2.1 @@ -20568,8 +19315,6 @@ snapshots: space-separated-tokens@2.0.2: {} - spawn-error-forwarder@1.0.0: {} - spdx-correct@3.2.0: dependencies: spdx-expression-parse: 3.0.1 @@ -20584,10 +19329,6 @@ snapshots: spdx-license-ids@3.0.18: {} - split2@1.0.0: - dependencies: - through2: 2.0.5 - split2@3.2.2: dependencies: readable-stream: 3.6.2 @@ -20655,11 +19396,6 @@ snapshots: dependencies: internal-slot: 1.0.7 - stream-combiner2@1.1.1: - dependencies: - duplexer2: 0.1.4 - readable-stream: 2.3.8 - streamsearch@1.1.0: {} string-argv@0.3.2: {} @@ -20748,8 +19484,6 @@ snapshots: strip-final-newline@3.0.0: {} - strip-final-newline@4.0.0: {} - strip-indent@3.0.0: dependencies: min-indent: 1.0.1 @@ -20775,11 +19509,6 @@ snapshots: sudo-prompt@9.2.1: {} - super-regex@1.0.0: - dependencies: - function-timeout: 1.0.2 - time-span: 5.1.0 - supports-color@5.5.0: dependencies: has-flag: 3.0.0 @@ -20792,11 +19521,6 @@ snapshots: dependencies: has-flag: 4.0.0 - supports-hyperlinks@3.2.0: - dependencies: - has-flag: 4.0.0 - supports-color: 7.2.0 - supports-preserve-symlinks-flag@1.0.0: {} suspend-react@0.1.3(react@18.3.1): @@ -20886,19 +19610,10 @@ snapshots: temp-dir@2.0.0: {} - temp-dir@3.0.0: {} - temp@0.8.4: dependencies: rimraf: 2.6.3 - tempy@3.1.0: - dependencies: - is-stream: 3.0.0 - temp-dir: 3.0.0 - type-fest: 2.19.0 - unique-string: 3.0.0 - terser@5.44.0: dependencies: '@jridgewell/source-map': 0.3.11 @@ -20937,10 +19652,6 @@ snapshots: through@2.3.8: {} - time-span@5.1.0: - dependencies: - convert-hrtime: 5.0.0 - tiny-warning@1.0.3: {} titleize@2.1.0: {} @@ -20988,12 +19699,6 @@ snapshots: tr46@0.0.3: {} - traverse@0.6.9: - dependencies: - gopd: 1.2.0 - typedarray.prototype.slice: 1.0.3 - which-typed-array: 1.1.15 - tree-kill@1.2.2: {} trim-lines@3.0.1: {} @@ -21089,8 +19794,6 @@ snapshots: dependencies: safe-buffer: 5.2.1 - tunnel@0.0.6: {} - tweetnacl@0.14.5: {} type-check@0.4.0: @@ -21111,12 +19814,6 @@ snapshots: type-fest@0.8.1: {} - type-fest@1.4.0: {} - - type-fest@2.19.0: {} - - type-fest@4.41.0: {} - type-is@1.6.18: dependencies: media-typer: 0.3.0 @@ -21154,15 +19851,6 @@ snapshots: is-typed-array: 1.1.13 possible-typed-array-names: 1.0.0 - typedarray.prototype.slice@1.0.3: - dependencies: - call-bind: 1.0.7 - define-properties: 1.2.1 - es-abstract: 1.23.3 - es-errors: 1.3.0 - typed-array-buffer: 1.0.2 - typed-array-byte-offset: 1.0.2 - typedarray@0.0.6: {} typeorm@0.3.12(pg@8.11.0)(sqlite3@5.1.7)(ts-node@10.9.1(@swc/core@1.6.5(@swc/helpers@0.5.11))(@types/node@22.10.5)(typescript@4.9.5)): @@ -21226,16 +19914,10 @@ snapshots: undici-types@6.20.0: {} - undici@5.29.0: - dependencies: - '@fastify/busboy': 2.1.1 - undici@7.3.0: {} unicode-canonical-property-names-ecmascript@2.0.0: {} - unicode-emoji-modifier-base@1.0.0: {} - unicode-emoji-utils@1.2.0: dependencies: emoji-regex: 10.3.0 @@ -21251,10 +19933,6 @@ snapshots: unicode-property-aliases-ecmascript@2.1.0: {} - unicorn-magic@0.1.0: {} - - unicorn-magic@0.3.0: {} - unified@10.1.2: dependencies: '@types/unist': 2.0.10 @@ -21283,10 +19961,6 @@ snapshots: dependencies: imurmurhash: 0.1.4 - unique-string@3.0.0: - dependencies: - crypto-random-string: 4.0.0 - unist-util-generated@2.0.1: {} unist-util-is@5.2.1: @@ -21312,8 +19986,6 @@ snapshots: unist-util-is: 5.2.1 unist-util-visit-parents: 5.1.3 - universal-user-agent@7.0.3: {} - universalify@0.1.2: {} universalify@2.0.1: {} @@ -21338,8 +20010,6 @@ snapshots: dependencies: punycode: 2.3.1 - url-join@5.0.0: {} - urlsafe-base64@1.0.0: {} use-isomorphic-layout-effect@1.1.2(@types/react@18.3.3)(react@18.3.1): @@ -21547,7 +20217,8 @@ snapshots: word-wrap@1.2.5: {} - wordwrap@1.0.0: {} + wordwrap@1.0.0: + optional: true wrap-ansi@6.2.0: dependencies: @@ -21677,8 +20348,6 @@ snapshots: yocto-queue@0.1.0: {} - yoctocolors@2.1.1: {} - yup@0.32.11: dependencies: '@babel/runtime': 7.24.7 From fed772a8e7445c4856d52aa215ef0dfab44765cf Mon Sep 17 00:00:00 2001 From: "allcontributors[bot]" <46447321+allcontributors[bot]@users.noreply.github.com> Date: Thu, 25 Sep 2025 10:15:26 +0500 Subject: [PATCH 22/96] docs: add sudo-kraken as a contributor for infra (#1919) * docs: update README.md [skip ci] * docs: update .all-contributorsrc [skip ci] --------- Co-authored-by: allcontributors[bot] <46447321+allcontributors[bot]@users.noreply.github.com> --- .all-contributorsrc | 9 +++++++++ README.md | 3 ++- 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/.all-contributorsrc b/.all-contributorsrc index 6f3cafc0a6..482c7a906e 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -642,6 +642,15 @@ "contributions": [ "code" ] + }, + { + "login": "sudo-kraken", + "name": "Joe Harrison", + "avatar_url": "https://avatars.githubusercontent.com/u/53116754?v=4", + "profile": "https://sudo-kraken.github.io/docs/", + "contributions": [ + "infra" + ] } ] } diff --git a/README.md b/README.md index 30e6370892..2f8d548f8f 100644 --- a/README.md +++ b/README.md @@ -11,7 +11,7 @@ Translation status GitHub -All Contributors +All Contributors **Jellyseerr** is a free and open source software application for managing requests for your media library. It integrates with the media server of your choice: [Jellyfin](https://jellyfin.org), [Plex](https://plex.tv), and [Emby](https://emby.media/). In addition, it integrates with your existing services, such as **[Sonarr](https://sonarr.tv/)**, **[Radarr](https://radarr.video/)**. @@ -173,6 +173,7 @@ Thanks goes to these wonderful people from Overseerr ([emoji key](https://allcon Jam
Jam

💻 Joe Lowrance
Joe Lowrance

💻 0xsysr3ll
0xsysr3ll

💻 + Joe Harrison
Joe Harrison

🚇 From b209e7fdf9ea5d639fe6f8bb8ae041e771b900d7 Mon Sep 17 00:00:00 2001 From: ale183 Date: Thu, 25 Sep 2025 16:04:42 +0200 Subject: [PATCH 23/96] feat: add anidb support to jellyfin scanner (#1533) * feat: anidb on jellyfin scanner * fix: handle 4k movies if the provider is anidb * fix: add nullish coalescing for anidbId * Update server/lib/scanners/jellyfin/index.ts Co-authored-by: Gauthier * fix: await getEpisodes call in JellyfinScanner to handle async behavior --------- Co-authored-by: Gauthier --- server/api/animelist.ts | 2 + server/api/jellyfin.ts | 1 + server/lib/scanners/jellyfin/index.ts | 119 +++++++++++++++++++++++++- 3 files changed, 118 insertions(+), 4 deletions(-) diff --git a/server/api/animelist.ts b/server/api/animelist.ts index 7f859eaedc..9351a9ae4f 100644 --- a/server/api/animelist.ts +++ b/server/api/animelist.ts @@ -48,6 +48,7 @@ export interface AnidbItem { tvdbId?: number; tmdbId?: number; imdbId?: string; + tvdbSeason?: number; } class AnimeListMapping { @@ -97,6 +98,7 @@ class AnimeListMapping { tvdbId: anime.$.defaulttvdbseason === '0' ? undefined : tvdbId, tmdbId: tmdbId, imdbId: imdbIds[0], // this is used for one AniDB -> one imdb movie mapping + tvdbSeason: Number(anime.$.defaulttvdbseason), }; if (tvdbId) { diff --git a/server/api/jellyfin.ts b/server/api/jellyfin.ts index a8e5286983..2c5b05936d 100644 --- a/server/api/jellyfin.ts +++ b/server/api/jellyfin.ts @@ -103,6 +103,7 @@ export interface JellyfinLibraryItemExtended extends JellyfinLibraryItem { Tmdb?: string; Imdb?: string; Tvdb?: string; + AniDB?: string; }; MediaSources?: JellyfinMediaSource[]; Width?: number; diff --git a/server/lib/scanners/jellyfin/index.ts b/server/lib/scanners/jellyfin/index.ts index 3283e34206..50bb7f252f 100644 --- a/server/lib/scanners/jellyfin/index.ts +++ b/server/lib/scanners/jellyfin/index.ts @@ -1,3 +1,4 @@ +import animeList from '@server/api/animelist'; import type { JellyfinLibraryItem } from '@server/api/jellyfin'; import JellyfinAPI from '@server/api/jellyfin'; import { getMetadataProvider } from '@server/api/metadata'; @@ -45,6 +46,7 @@ class JellyfinScanner { private enable4kMovie = false; private enable4kShow = false; private asyncLock = new AsyncLock(); + private processedAnidbSeason: Map>; constructor({ isRecentOnly }: { isRecentOnly?: boolean } = {}) { this.tmdb = new TheMovieDb(); @@ -66,7 +68,7 @@ class JellyfinScanner { const mediaRepository = getRepository(Media); try { - const metadata = await this.jfClient.getItemData(jellyfinitem.Id); + let metadata = await this.jfClient.getItemData(jellyfinitem.Id); const newMedia = new Media(); if (!metadata?.Id) { @@ -77,8 +79,18 @@ class JellyfinScanner { return; } + const anidbId = Number(metadata.ProviderIds.AniDB ?? null); + newMedia.tmdbId = Number(metadata.ProviderIds.Tmdb ?? null); newMedia.imdbId = metadata.ProviderIds.Imdb; + + // We use anidb only if we have the anidbId and nothing else + if (anidbId && !newMedia.imdbId && !newMedia.tmdbId) { + const result = animeList.getFromAnidbId(anidbId); + newMedia.tmdbId = Number(result?.tmdbId ?? null); + newMedia.imdbId = result?.imdbId; + } + if (newMedia.imdbId && !isNaN(newMedia.tmdbId)) { const tmdbMovie = await this.tmdb.getMediaByImdbId({ imdbId: newMedia.imdbId, @@ -89,6 +101,40 @@ class JellyfinScanner { throw new Error('Unable to find TMDb ID'); } + // With AniDB we can have mixed libraries with movies in a "show" library + // We take the first episode of the first season (the movie) and use it to + // get more information, like the MediaSource + if (anidbId && metadata.Type === 'Series') { + const season = (await this.jfClient.getSeasons(jellyfinitem.Id)).find( + (md) => { + return md.IndexNumber === 1; + } + ); + if (!season) { + this.log('No season found for anidb movie', 'debug', { + jellyfinitem, + }); + return; + } + const episodes = await this.jfClient.getEpisodes( + jellyfinitem.Id, + season.Id + ); + if (!episodes[0]) { + this.log('No episode found for anidb movie', 'debug', { + jellyfinitem, + }); + return; + } + metadata = await this.jfClient.getItemData(episodes[0].Id); + if (!metadata) { + this.log('No metadata found for anidb movie', 'debug', { + jellyfinitem, + }); + return; + } + } + const has4k = metadata.MediaSources?.some((MediaSource) => { return MediaSource.MediaStreams.filter( (MediaStream) => MediaStream.Type === 'Video' @@ -106,6 +152,12 @@ class JellyfinScanner { }); await this.asyncLock.dispatch(newMedia.tmdbId, async () => { + if (!metadata) { + // this will never execute, but typescript thinks somebody could reset tvShow from + // outer scope back to null before this async gets called + return; + } + const existing = await this.getExisting( newMedia.tmdbId, MediaType.MOVIE @@ -274,6 +326,28 @@ class JellyfinScanner { }); } } + let tvdbSeasonFromAnidb: number | undefined; + if (!tvShow && metadata.ProviderIds.AniDB) { + const anidbId = Number(metadata.ProviderIds.AniDB); + const result = animeList.getFromAnidbId(anidbId); + tvdbSeasonFromAnidb = result?.tvdbSeason; + if (result?.tvdbId) { + try { + tvShow = await this.tmdb.getShowByTvdbId({ + tvdbId: result.tvdbId, + }); + } catch { + this.log('Unable to find AniDB ID for this title.', 'debug', { + jellyfinitem, + }); + } + } + // With AniDB we can have mixed libraries with movies in a "show" library + else if (result?.imdbId || result?.tmdbId) { + await this.processMovie(jellyfinitem); + return; + } + } if (tvShow) { await this.asyncLock.dispatch(tvShow.id, async () => { @@ -302,9 +376,20 @@ class JellyfinScanner { for (const season of seasons) { const JellyfinSeasons = await this.jfClient.getSeasons(Id); - const matchedJellyfinSeason = JellyfinSeasons.find( - (md) => Number(md.IndexNumber) === season.season_number - ); + const matchedJellyfinSeason = JellyfinSeasons.find((md) => { + if (tvdbSeasonFromAnidb) { + // In AniDB we don't have the concept of seasons, + // we have multiple shows with only Season 1 (and sometimes a season with index 0 for specials). + // We use tvdbSeasonFromAnidb to check if we are on the correct TMDB season and + // md.IndexNumber === 1 to be sure to find the correct season on jellyfin + return ( + tvdbSeasonFromAnidb === season.season_number && + md.IndexNumber === 1 + ); + } else { + return Number(md.IndexNumber) === season.season_number; + } + }); const existingSeason = media?.seasons.find( (es) => es.seasonNumber === season.season_number @@ -357,6 +442,29 @@ class JellyfinScanner { } } + // With AniDB we can have multiple shows for one season, so we need to save + // the episode from all the jellyfin entries to get the total + if (tvdbSeasonFromAnidb) { + if (this.processedAnidbSeason.has(tvShow.id)) { + const show = this.processedAnidbSeason.get(tvShow.id)!; + if (show.has(season.season_number)) { + show.set( + season.season_number, + show.get(season.season_number)! + totalStandard + ); + + totalStandard = show.get(season.season_number)!; + } else { + show.set(season.season_number, totalStandard); + } + } else { + this.processedAnidbSeason.set( + tvShow.id, + new Map([[season.season_number, totalStandard]]) + ); + } + } + if ( media && (totalStandard > 0 || (total4k > 0 && !this.enable4kShow)) && @@ -569,6 +677,7 @@ class JellyfinScanner { } private async processItems(slicedItems: JellyfinLibraryItem[]) { + this.processedAnidbSeason = new Map(); await Promise.all( slicedItems.map(async (item) => { if (item.Type === 'Movie') { @@ -666,6 +775,8 @@ class JellyfinScanner { (library) => library.enabled ); + await animeList.sync(); + this.enable4kMovie = settings.radarr.some((radarr) => radarr.is4k); if (this.enable4kMovie) { this.log( From 0b1ad8ca1c3bd356a049509a467a0c5b7a2f4635 Mon Sep 17 00:00:00 2001 From: "allcontributors[bot]" <46447321+allcontributors[bot]@users.noreply.github.com> Date: Thu, 25 Sep 2025 19:37:02 +0500 Subject: [PATCH 24/96] docs: add ale183 as a contributor for code (#1920) * docs: update README.md [skip ci] * docs: update .all-contributorsrc [skip ci] --------- Co-authored-by: allcontributors[bot] <46447321+allcontributors[bot]@users.noreply.github.com> --- .all-contributorsrc | 9 +++++++++ README.md | 5 ++++- 2 files changed, 13 insertions(+), 1 deletion(-) diff --git a/.all-contributorsrc b/.all-contributorsrc index 482c7a906e..a22b044ad1 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -651,6 +651,15 @@ "contributions": [ "infra" ] + }, + { + "login": "ale183", + "name": "ale183", + "avatar_url": "https://avatars.githubusercontent.com/u/8809439?v=4", + "profile": "https://github.com/ale183", + "contributions": [ + "code" + ] } ] } diff --git a/README.md b/README.md index 2f8d548f8f..164311b7cb 100644 --- a/README.md +++ b/README.md @@ -11,7 +11,7 @@ Translation status GitHub -All Contributors +All Contributors **Jellyseerr** is a free and open source software application for managing requests for your media library. It integrates with the media server of your choice: [Jellyfin](https://jellyfin.org), [Plex](https://plex.tv), and [Emby](https://emby.media/). In addition, it integrates with your existing services, such as **[Sonarr](https://sonarr.tv/)**, **[Radarr](https://radarr.video/)**. @@ -175,6 +175,9 @@ Thanks goes to these wonderful people from Overseerr ([emoji key](https://allcon 0xsysr3ll
0xsysr3ll

💻 Joe Harrison
Joe Harrison

🚇 + + ale183
ale183

💻 + From 1143f88b6e0b78958e28b276355bfee83ae924e1 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Fri, 26 Sep 2025 16:28:51 +0100 Subject: [PATCH 25/96] test(cypress): added cypress cache and syntax fix (#1923) * added cypress cache and syntax fix * removal of pnpm version logic --- .github/workflows/ci.yml | 5 ----- .github/workflows/cypress.yml | 13 ++++++++----- .github/workflows/docs-deploy.yml | 5 ----- .github/workflows/release.yml | 5 ----- .github/workflows/test-docs-deploy.yml | 5 ----- 5 files changed, 8 insertions(+), 25 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 2dc7bf023f..3b22f31668 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -28,11 +28,6 @@ jobs: with: persist-credentials: false - - name: Get PNPM version from package.json - id: pnpm-version - shell: sh - run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - - name: Pnpm Setup uses: pnpm/action-setup@v4 with: diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index 72871db597..a93a332408 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -34,16 +34,19 @@ jobs: with: node-version-file: package.json - - name: Get PNPM version from package.json - id: pnpm-version - shell: bash - run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - - name: Pnpm Setup uses: pnpm/action-setup@v4 with: version: ${{ steps.pnpm-version.outputs.pnpm_version }} + - name: Setup cypress cache + uses: actions/cache@v4 + with: + path: ~/.cache/Cypress + key: ${{ runner.os }}-cypress-store-${{ hashFiles('**/pnpm-lock.yaml') }} + restore-keys: | + ${{ runner.os }}-cypress-store- + - name: Cypress run uses: cypress-io/github-action@v6 with: diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index e542bb6b39..5736691886 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -31,11 +31,6 @@ jobs: node-version-file: package.json cache: 'pnpm' - - name: Get PNPM version from package.json - id: pnpm-version - shell: bash - run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - - name: Pnpm Setup uses: pnpm/action-setup@v4 with: diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index dd06c2a87f..1ebf5bced3 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -32,11 +32,6 @@ jobs: node-version-file: package.json cache: 'pnpm' - - name: Get PNPM version from package.json - id: pnpm-version - shell: bash - run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - - name: Pnpm Setup uses: pnpm/action-setup@v4 with: diff --git a/.github/workflows/test-docs-deploy.yml b/.github/workflows/test-docs-deploy.yml index e447e46c70..1d119323f9 100644 --- a/.github/workflows/test-docs-deploy.yml +++ b/.github/workflows/test-docs-deploy.yml @@ -32,11 +32,6 @@ jobs: with: node-version-file: package.json - - name: Get PNPM version from package.json - id: pnpm-version - shell: bash - run: echo "pnpm_version=$(node -p 'require(`./package.json`).packageManager.split(\"@\")[1]')" >> $GITHUB_OUTPUT - - name: Pnpm Setup uses: pnpm/action-setup@v4 with: From e9db34ea07de1bfa8dfed4564a06288cd37f6c43 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Sat, 27 Sep 2025 09:20:05 +0100 Subject: [PATCH 26/96] ci: updated support workflow concurrency and logic (#1926) --- .github/workflows/support.yml | 37 ++++++++++++++++++++++++++--------- 1 file changed, 28 insertions(+), 9 deletions(-) diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index 3589de9864..a8da614462 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -4,33 +4,52 @@ on: issues: types: [labeled, unlabeled, reopened] -permissions: {} +permissions: + issues: read concurrency: - group: support-${{ github.ref }} + group: support-${{ github.event.issue.number }} cancel-in-progress: true jobs: support: - if: github.event.label.name == 'support' + if: github.event.label.name == 'support' || github.event.action == 'reopened' runs-on: ubuntu-24.04 permissions: issues: write env: GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} - GH_REPO: ${{ github.repository }} NUMBER: ${{ github.event.issue.number }} + ISSUE_AUTHOR: ${{ github.event.issue.user.login }} steps: - - name: Comment and close issue - run: gh issue close "$NUMBER" -r "off-topic" -c "$BODY" + - name: Label added, comment and close issue + if: github.event.action == 'labeled' && github.event.label.name == 'support' + shell: bash env: BODY: > - :wave: @{issue-author}, we use the issue tracker exclusively + :wave: @${{ env.ISSUE_AUTHOR }}, we use the issue tracker exclusively for bug reports and feature requests. However, this issue appears to be a support request. Please use our support channels to get help with Jellyseerr. - [Discord](https://discord.gg/ckbvBtDJgC) + run: | + retry() { n=0; until "$@"; do n=$((n+1)); [ $n -ge 3 ] && break; echo "retry $n: $*" >&2; sleep 2; done; } + retry gh issue comment "$NUMBER" -b "$BODY" || true + retry gh issue close "$NUMBER" || true + gh issue lock "$NUMBER" -r "off_topic" || true - - name: Lock issue - run: gh issue lock "$NUMBER" -r "off_topic" + - name: Reopened or label removed, unlock issue + if: github.event.action == 'unlabeled' && github.event.label.name == 'support' + shell: bash + run: | + retry() { n=0; until "$@"; do n=$((n+1)); [ $n -ge 3 ] && break; echo "retry $n: $*" >&2; sleep 2; done; } + retry gh issue reopen "$NUMBER" || true + gh issue unlock "$NUMBER" || true + + - name: Remove support label on manual reopen + if: github.event.action == 'reopened' + shell: bash + run: | + gh issue edit "$NUMBER" --remove-label "support" || true + gh issue unlock "$NUMBER" || true From da57ccc5a73f85c5d1b804f912c1c12a6857db44 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Sat, 27 Sep 2025 12:20:45 +0100 Subject: [PATCH 27/96] Update support.yml fixed the gh -R issue (#1928) --- .github/workflows/support.yml | 15 ++++++++------- 1 file changed, 8 insertions(+), 7 deletions(-) diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index a8da614462..2a351482de 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -19,6 +19,7 @@ jobs: issues: write env: GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + GH_REPO: ${{ github.repository }} NUMBER: ${{ github.event.issue.number }} ISSUE_AUTHOR: ${{ github.event.issue.user.login }} steps: @@ -35,21 +36,21 @@ jobs: - [Discord](https://discord.gg/ckbvBtDJgC) run: | retry() { n=0; until "$@"; do n=$((n+1)); [ $n -ge 3 ] && break; echo "retry $n: $*" >&2; sleep 2; done; } - retry gh issue comment "$NUMBER" -b "$BODY" || true - retry gh issue close "$NUMBER" || true - gh issue lock "$NUMBER" -r "off_topic" || true + retry gh issue comment "$NUMBER" -R "$GH_REPO" -b "$BODY" || true + retry gh issue close "$NUMBER" -R "$GH_REPO" || true + gh issue lock "$NUMBER" -R "$GH_REPO" -r "off_topic" || true - name: Reopened or label removed, unlock issue if: github.event.action == 'unlabeled' && github.event.label.name == 'support' shell: bash run: | retry() { n=0; until "$@"; do n=$((n+1)); [ $n -ge 3 ] && break; echo "retry $n: $*" >&2; sleep 2; done; } - retry gh issue reopen "$NUMBER" || true - gh issue unlock "$NUMBER" || true + retry gh issue reopen "$NUMBER" -R "$GH_REPO" || true + gh issue unlock "$NUMBER" -R "$GH_REPO" || true - name: Remove support label on manual reopen if: github.event.action == 'reopened' shell: bash run: | - gh issue edit "$NUMBER" --remove-label "support" || true - gh issue unlock "$NUMBER" || true + gh issue edit "$NUMBER" -R "$GH_REPO" --remove-label "support" || true + gh issue unlock "$NUMBER" -R "$GH_REPO" || true From eec3319ba679951f322f0d93a51d32493e561477 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Sun, 28 Sep 2025 18:20:31 +0200 Subject: [PATCH 28/96] chore: update to pnpm v10 (#1349) --- docs/getting-started/buildfromsource.mdx | 2 +- package.json | 11 +++++++++-- pnpm-lock.yaml | 4 ++-- 3 files changed, 12 insertions(+), 5 deletions(-) diff --git a/docs/getting-started/buildfromsource.mdx b/docs/getting-started/buildfromsource.mdx index 9bfff1a243..fe3235648c 100644 --- a/docs/getting-started/buildfromsource.mdx +++ b/docs/getting-started/buildfromsource.mdx @@ -15,7 +15,7 @@ import TabItem from '@theme/TabItem'; ### Prerequisites - [Node.js 22.x](https://nodejs.org/en/download/) - - [Pnpm 9.x](https://pnpm.io/installation) + - [Pnpm 10.x](https://pnpm.io/installation) - [Git](https://git-scm.com/downloads) ## Unix (Linux, macOS) diff --git a/package.json b/package.json index f95dcdc984..fe6857b47b 100644 --- a/package.json +++ b/package.json @@ -2,7 +2,7 @@ "name": "jellyseerr", "version": "0.1.0", "private": true, - "packageManager": "pnpm@9.0.0", + "packageManager": "pnpm@10.17.1", "scripts": { "preinstall": "npx only-allow pnpm", "postinstall": "node postinstall-win.js", @@ -175,7 +175,8 @@ "typescript": "4.9.5" }, "engines": { - "node": "^22.0.0" + "node": "^22.0.0", + "pnpm": "^10.0.0" }, "overrides": { "sqlite3/node-gyp": "8.4.1", @@ -263,5 +264,11 @@ "@codedependant/semantic-release-docker", "@semantic-release/github" ] + }, + "pnpm": { + "onlyBuiltDependencies": [ + "sqlite3", + "bcrypt" + ] } } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 5247889dad..2f39de3ea5 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -15167,7 +15167,7 @@ snapshots: debug: 4.4.0(supports-color@5.5.0) enhanced-resolve: 5.17.0 eslint: 8.35.0 - eslint-module-utils: 2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.35.0))(eslint@8.35.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1)(eslint@8.35.0) eslint-plugin-import: 2.29.1(@typescript-eslint/parser@5.54.0(eslint@8.35.0)(typescript@4.9.5))(eslint@8.35.0) fast-glob: 3.3.2 get-tsconfig: 4.7.5 @@ -15189,7 +15189,7 @@ snapshots: transitivePeerDependencies: - supports-color - eslint-module-utils@2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-plugin-import@2.29.1)(eslint@8.35.0))(eslint@8.35.0): + eslint-module-utils@2.8.1(@typescript-eslint/parser@7.2.0(eslint@8.35.0)(typescript@4.9.5))(eslint-import-resolver-node@0.3.9)(eslint-import-resolver-typescript@3.6.1)(eslint@8.35.0): dependencies: debug: 3.2.7(supports-color@8.1.1) optionalDependencies: From f427bc26df5ed2414d451e12a727eec8ddd098b4 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Sun, 28 Sep 2025 17:55:38 +0100 Subject: [PATCH 29/96] ci: remove the with step from the pnpm setup steps (#1932) --- .github/workflows/ci.yml | 2 -- .github/workflows/cypress.yml | 2 -- .github/workflows/docs-deploy.yml | 2 -- .github/workflows/release.yml | 2 -- .github/workflows/test-docs-deploy.yml | 2 -- 5 files changed, 10 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 3b22f31668..866c2f661f 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -30,8 +30,6 @@ jobs: - name: Pnpm Setup uses: pnpm/action-setup@v4 - with: - version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Get pnpm store directory shell: sh diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index a93a332408..15c1566b84 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -36,8 +36,6 @@ jobs: - name: Pnpm Setup uses: pnpm/action-setup@v4 - with: - version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Setup cypress cache uses: actions/cache@v4 diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index 5736691886..aa0ec3f50b 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -33,8 +33,6 @@ jobs: - name: Pnpm Setup uses: pnpm/action-setup@v4 - with: - version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Get pnpm store directory shell: sh diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 1ebf5bced3..23687cd746 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -34,8 +34,6 @@ jobs: - name: Pnpm Setup uses: pnpm/action-setup@v4 - with: - version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Get pnpm store directory shell: sh diff --git a/.github/workflows/test-docs-deploy.yml b/.github/workflows/test-docs-deploy.yml index 1d119323f9..6091c38caf 100644 --- a/.github/workflows/test-docs-deploy.yml +++ b/.github/workflows/test-docs-deploy.yml @@ -34,8 +34,6 @@ jobs: - name: Pnpm Setup uses: pnpm/action-setup@v4 - with: - version: ${{ steps.pnpm-version.outputs.pnpm_version }} - name: Get pnpm store directory shell: sh From 420e320f1fd8e254cb2f4b04633615d9d1d36296 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Sun, 28 Sep 2025 19:04:11 +0200 Subject: [PATCH 30/96] ci: fix pnpm version in Dockerfile (#1933) --- Dockerfile | 4 ++-- Dockerfile.local | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Dockerfile b/Dockerfile index f331b62dbe..00a4a13aef 100644 --- a/Dockerfile +++ b/Dockerfile @@ -17,7 +17,7 @@ RUN \ ;; \ esac -RUN npm install --global pnpm@9 +RUN npm install --global pnpm@10 COPY package.json pnpm-lock.yaml postinstall-win.js ./ RUN CYPRESS_INSTALL_BINARY=0 pnpm install --frozen-lockfile @@ -37,7 +37,7 @@ WORKDIR /app RUN apk add --no-cache tzdata tini && rm -rf /tmp/* -RUN npm install -g pnpm@9 +RUN npm install -g pnpm@10 # copy from build image COPY --from=BUILD_IMAGE /app ./ diff --git a/Dockerfile.local b/Dockerfile.local index 666fa74fb8..1f7708d982 100644 --- a/Dockerfile.local +++ b/Dockerfile.local @@ -3,7 +3,7 @@ FROM node:22-alpine COPY . /app WORKDIR /app -RUN npm install --global pnpm@9 +RUN npm install --global pnpm@10 RUN pnpm install From efba8474527ef5dabc2e94cbff3492107d9fbdaa Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Sun, 28 Sep 2025 22:30:41 +0500 Subject: [PATCH 31/96] docs: update weblate translations (#1934) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Update translation files Updated by "Cleanup translation files" hook in Weblate. Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/ * Translated using Weblate (French) Currently translated at 94.7% (1409 of 1487 strings) Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (Ukrainian) Currently translated at 91.0% (1354 of 1487 strings) Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/uk/ * Translated using Weblate (Turkish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/tr/ * Translated using Weblate (French) Currently translated at 94.8% (1411 of 1487 strings) Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (Dutch) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/nl/ * Translated using Weblate (Dutch) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/nl/ * Translated using Weblate (French) Currently translated at 95.0% (1414 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (Dutch) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/nl/ * Translated using Weblate (Turkish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/tr/ * Translated using Weblate (French) Currently translated at 99.9% (1486 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (French) Currently translated at 99.9% (1486 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (German) Currently translated at 98.6% (1467 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (Norwegian Bokmål) Currently translated at 71.6% (1066 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/nb_NO/ * Translated using Weblate (French) Currently translated at 99.9% (1486 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (Norwegian Bokmål) Currently translated at 76.4% (1137 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/nb_NO/ * Translated using Weblate (Chinese (Simplified Han script)) Currently translated at 86.8% (1291 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/zh_Hans/ * Translated using Weblate (Spanish) Currently translated at 87.2% (1297 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/es/ * Translated using Weblate (Basque) Currently translated at 93.8% (1395 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/eu/ * Translated using Weblate (Polish) Currently translated at 91.5% (1362 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/pl/ * Translated using Weblate (Basque) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/eu/ * Translated using Weblate (Russian) Currently translated at 89.9% (1338 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/ru/ * Translated using Weblate (Ukrainian) Currently translated at 91.0% (1354 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/uk/ * Translated using Weblate (Swedish) Currently translated at 87.6% (1304 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 87.6% (1304 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (Bulgarian) Currently translated at 83.3% (1239 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (French) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (French) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (Hebrew) Currently translated at 43.2% (643 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/he/ * Translated using Weblate (Hebrew) Currently translated at 44.3% (659 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/he/ * Translated using Weblate (Bulgarian) Currently translated at 85.5% (1272 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Russian) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/ru/ * Translated using Weblate (Bulgarian) Currently translated at 85.5% (1272 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Hebrew) Currently translated at 44.4% (661 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/he/ * Translated using Weblate (Hebrew) Currently translated at 46.9% (698 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/he/ * Translated using Weblate (Norwegian Bokmål) Currently translated at 76.5% (1138 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/nb_NO/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Hebrew) Currently translated at 50.8% (756 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/he/ * Translated using Weblate (Hebrew) Currently translated at 51.1% (760 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/he/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (French) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fr/ * Translated using Weblate (Swedish) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/sv/ * Translated using Weblate (Polish) Currently translated at 91.5% (1362 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/pl/ * Translated using Weblate (Polish) Currently translated at 91.5% (1362 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/pl/ * Translated using Weblate (Chinese (Simplified Han script)) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/zh_Hans/ * Translated using Weblate (Romanian) Currently translated at 41.9% (624 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/ro/ * Translated using Weblate (German) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/de/ * Translated using Weblate (Bulgarian) Currently translated at 87.6% (1304 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Bulgarian) Currently translated at 87.7% (1305 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Bulgarian) Currently translated at 87.8% (1306 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Bulgarian) Currently translated at 87.8% (1307 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Bulgarian) Currently translated at 88.8% (1321 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/bg/ * Translated using Weblate (Italian) Currently translated at 87.4% (1300 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/it/ * Translated using Weblate (Italian) Currently translated at 89.5% (1332 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/it/ * Translated using Weblate (Italian) Currently translated at 90.0% (1339 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/it/ * Translated using Weblate (Italian) Currently translated at 100.0% (1487 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/it/ * Translated using Weblate (Hungarian) Currently translated at 79.6% (1184 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/hu/ * Translated using Weblate (Finnish) Currently translated at 17.2% (257 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fi/ * Translated using Weblate (Finnish) Currently translated at 24.8% (370 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fi/ * Translated using Weblate (Finnish) Currently translated at 25.5% (380 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fi/ * Translated using Weblate (Finnish) Currently translated at 34.9% (520 of 1487 strings) Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/fi/ * Update translation files Updated by "Cleanup translation files" hook in Weblate. Translate-URL: http://translate.jellyseerr.dev/projects/jellyseerr/jellyseerr-frontend/ --------- Co-authored-by: Weblate Co-authored-by: HanaO00 Co-authored-by: michael Co-authored-by: Gökhan GÜRBÜZ Co-authored-by: Julien Cordeau Co-authored-by: Bas <910100490+weblate@proton.me> Co-authored-by: Dennis van J Co-authored-by: 0xsysr3ll <0xsysr3ll@protonmail.com> Co-authored-by: bogomil22 Co-authored-by: Mikael Wessel Co-authored-by: chenhui_li Co-authored-by: Miguel Pacheco Co-authored-by: Thadah Co-authored-by: zulimazuli Co-authored-by: Stefan Co-authored-by: Blackflexxy Co-authored-by: Nik Co-authored-by: Mattias Magnusson Co-authored-by: NilsKarlssonPyssling Co-authored-by: Manu Co-authored-by: Georgi Sariev Co-authored-by: big man Co-authored-by: Veselin Co-authored-by: Gallyam Co-authored-by: Dj5YsFXf#!pc@DQA7#8j$cc*Z6tq9Xeq Co-authored-by: uqlel Co-authored-by: 宿命 <331874545@qq.com> Co-authored-by: enderice2 Co-authored-by: Jamal R. Co-authored-by: ReDFiRe Co-authored-by: bunz <66bunz@gmail.com> Co-authored-by: Gábor Pikó Co-authored-by: dogiex --- src/i18n/locale/ar.json | 15 -- src/i18n/locale/bg.json | 122 +++++++++--- src/i18n/locale/ca.json | 15 -- src/i18n/locale/cs.json | 16 -- src/i18n/locale/da.json | 15 -- src/i18n/locale/de.json | 361 +++++++++++++++++------------------ src/i18n/locale/el.json | 15 -- src/i18n/locale/es.json | 16 -- src/i18n/locale/es_MX.json | 15 -- src/i18n/locale/eu.json | 17 -- src/i18n/locale/fi.json | 282 ++++++++++++++++++++++++++- src/i18n/locale/fr.json | 19 +- src/i18n/locale/he.json | 158 +++++++++++---- src/i18n/locale/hr.json | 15 -- src/i18n/locale/hu.json | 72 +++++-- src/i18n/locale/it.json | 292 ++++++++++++++++++++++++---- src/i18n/locale/ja.json | 13 -- src/i18n/locale/ko.json | 15 -- src/i18n/locale/nb_NO.json | 18 +- src/i18n/locale/nl.json | 17 -- src/i18n/locale/pl.json | 20 +- src/i18n/locale/pt_BR.json | 16 -- src/i18n/locale/pt_PT.json | 15 -- src/i18n/locale/ro.json | 19 +- src/i18n/locale/ru.json | 17 -- src/i18n/locale/sq.json | 15 -- src/i18n/locale/sr.json | 2 - src/i18n/locale/sv.json | 55 ++---- src/i18n/locale/tr.json | 17 -- src/i18n/locale/uk.json | 16 -- src/i18n/locale/zh_Hans.json | 255 ++++++++++++++++++++----- src/i18n/locale/zh_Hant.json | 13 -- 32 files changed, 1212 insertions(+), 756 deletions(-) diff --git a/src/i18n/locale/ar.json b/src/i18n/locale/ar.json index d7466351b0..957351c31d 100644 --- a/src/i18n/locale/ar.json +++ b/src/i18n/locale/ar.json @@ -371,19 +371,7 @@ "components.Settings.Notifications.NotificationsGotify.validationTypes": "يجب عليك إختيار نوع تنبيه واحد على الأقل", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "تم إرسال تنبيه تجريبي لقونتفاي!", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "يجب عليك كتابة رابط صحيح", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "تم حفظ اعدادات تنبيه لوناسي بنجاح!", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "الرابط يجب أن لا ينتهي بعلامة السلاش /", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "تفعيل الخدمة", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "إسم ملف التعريف", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "مطلوب فقط في حالة عدم إستخدام ملف التعريف الإفتراضي default", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "فشل في حفظ اعدادات تنبيه تطبيق لونا سي.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "فشل في ارسال التنبيه التجريبي الى لوناسي.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "جاري إرسال تنبيه تجريبي الى لوناسي…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "تم ارسال التنبيه!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "يجب عليك اختيار نوع تنبيه واحد على الاقل", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "يجب عليك تزويد رابط صحيح", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "رابط webhook", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "رابط المستخدم أو الجهاز notification webhook URL", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "مفتاح الدخول Token", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "جاري ارسال التنبيه…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "فشل إرسال تنبيه تجريبي Pushbullet.", @@ -701,7 +689,6 @@ "components.Settings.address": "العناوين", "components.Settings.addsonarr": "إضافة سيرفر سونار", "components.Settings.cancelscan": "إلغاء الفحص", - "components.Settings.copied": "نسخ مفتاح الـ API.", "components.Settings.currentlibrary": "المكتبة الحالية: {name}", "components.Settings.default": "الإفتراضي", "components.Settings.default4k": "فور كي الإفتراضي", @@ -791,7 +778,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.pushoverApplicationTokenTip": "تسجيل تطبيق application للإستخدام مع {applicationTitle}", "i18n.approve": "موافقة", "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "يجب ذكر مفتاح عام PGP صحيح", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "فشل حفظ إعدادات تنبيه web Push.", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "كلمة سر جديد", "components.UserProfile.UserSettings.UserPermissions.unauthorizedDescription": "لا تستطيع تعديل صلاحياتك المُعطاة.", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "حساب هذا المستخدم بدون كلمة سر حاليا. قم بإعداد كلمة سر بالإسفل لإتاحة هذا الحساب من تسجيل الدخول \"كمستخدم محلي.\"", @@ -908,7 +894,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverUserKey": "يجب ذكر مفتاح مستخدم او مجموعة صحيح", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "يجب ذكر رقم هوية محادثة صحيحة", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "ويب بوش Web Push", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "تم حفظ إعدادات تنبيه Web Push بنجاح!", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "تأكيد كلمة السر", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "كلمة السر الحالية", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSetOwnAccount": "حسابك حاليا بدون كلمة سر. قم بإعداد كلمة سر بالأسفل لإتاحة تسجيل الدخول كـ\"مستخدم محلي\" بإستخدام البريد الإلكتروني.", diff --git a/src/i18n/locale/bg.json b/src/i18n/locale/bg.json index c4282365e0..7225202502 100644 --- a/src/i18n/locale/bg.json +++ b/src/i18n/locale/bg.json @@ -199,7 +199,7 @@ "components.Settings.Notifications.encryptionOpportunisticTls": "Винаги използвайте STARTTLS", "components.Discover.FilterSlideover.ratingText": "Оценки между {minValue} и {maxValue}", "components.PermissionEdit.autoapproveSeries": "Автоматично одобряване на сериали", - "components.RequestButton.approverequests": "Одобряване {requestCount, plural, one {заявка} other {{requestCount} заявки}}", + "components.RequestButton.approverequests": "Одобри {requestCount, plural, one {заявка} other {{requestCount} заявки}}", "components.PersonDetails.crewmember": "Екип", "components.RequestButton.requestmore4k": "Заявете повече в 4К", "components.PersonDetails.ascharacter": "като {character}", @@ -239,7 +239,6 @@ "components.ManageSlideOver.manageModalRequests": "Заявки", "components.NotificationTypeSelector.issuecreatedDescription": "Изпращайте известия при докладване на проблеми.", "components.NotificationTypeSelector.mediaavailableDescription": "Изпращайте известия, когато медийните заявки станат налични.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Вашият базиран на потребител или устройство URL адрес за webhook за известия", "components.RequestModal.requestmovie4ktitle": "Заявете филм в 4K", "components.RequestModal.requestSuccess": "{title} е заявен успешно!", "components.Settings.Notifications.webhookUrlTip": "Създайте интегриране на webhook във вашия сървър", @@ -263,9 +262,7 @@ "components.Discover.resetsuccess": "Успешно нулиране на настройките за персонализиране на откриването.", "components.Settings.RadarrModal.minimumAvailability": "Минимална наличност", "components.Settings.Notifications.agentenabled": "Активиране на агент", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Неуспешно изпращане на тестово известие към LunaSea.", "components.Settings.SettingsAbout.Releases.releases": "Издания", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Активиране на агент", "components.Settings.RadarrModal.validationApiKeyRequired": "Трябва да предоставите API ключ", "components.Settings.RadarrModal.validationMinimumAvailabilityRequired": "Трябва да изберете минимална наличност", "components.RequestModal.requestseasons": "Заявете {seasonCount} {seasonCount, plural, one {сезон} other {сезони}}", @@ -296,7 +293,6 @@ "components.NotificationTypeSelector.issuecomment": "Коментар на проблема", "components.RequestBlock.seasons": "{seasonCount, plural, one {Сезон} other {Сезони}}", "components.Settings.RadarrModal.selectMinimumAvailability": "Изберете минимална наличност", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Настройките за известяване към LunaSea са запазени успешно!", "components.Selector.showmore": "Покажи повече", "components.Settings.RadarrModal.selectRootFolder": "Изберете главна папка", "components.RequestList.RequestItem.modifieduserdate": "{date} от {user}", @@ -309,12 +305,11 @@ "components.PermissionEdit.autoapproveMoviesDescription": "Гарантирано автоматично одобрение за заявки за не-4K филми.", "components.Settings.Notifications.NotificationsPushover.validationUserTokenRequired": "Трябва да предоставите валиден потребителски или групов ключ", "components.Settings.SettingsAbout.Releases.versionChangelog": "{version} Дневник на промените", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Изисква се само ако не използвате профила по подразбиране", "components.ManageSlideOver.manageModalMedia": "Медия", "components.NotificationTypeSelector.issueresolved": "Проблемът е решен", "components.MovieDetails.originaltitle": "Оригинално заглавие", "components.Discover.trending": "Тендеция", - "components.RequestButton.declinerequests": "Decline {requestCount, plural, one {Заявка} other {{requestCount} Заявки}}", + "components.RequestButton.declinerequests": "Отхвърли {requestCount, plural, one {заявка} other {{requestCount} заявки}}", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Създайте токен от вашите Настройки на акаунта", "components.MovieDetails.rtcriticsscore": "Rotten Tomatoes Tomatometer", "components.PermissionEdit.requestMoviesDescription": "Дайте разрешение за изпращане на заявки за не-4K филми.", @@ -330,7 +325,6 @@ "components.RequestModal.selectmovies": "Изберете филм(и)", "components.RequestModal.requestApproved": "Заявката за {title} е одобрена!", "components.Settings.RadarrModal.testFirstQualityProfiles": "Тествайте връзката, за да заредите профилите за качество", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Изпраща се тестово известие към LunaSea…", "components.QuotaSelector.unlimited": "Неограничен", "components.ResetPassword.validationpasswordminchars": "Паролата е твърде кратка; трябва да съдържа минимум 8 знака", "components.Settings.RadarrModal.syncEnabled": "Активирайте сканирането", @@ -344,7 +338,6 @@ "components.RequestBlock.profilechanged": "Профил качество", "components.Settings.RadarrModal.create4kradarr": "Добавяне на нов 4K Radarr сървър", "components.Settings.Notifications.senderName": "Име на изпращача", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Трябва да предоставите валиден URL адрес", "components.PermissionEdit.autoapprove4kMovies": "Автоматично одобряване на 4К филми", "components.ManageSlideOver.playedby": "Изигран от", "components.Settings.RadarrModal.default4kserver": "4K сървър по подразбиране", @@ -360,13 +353,11 @@ "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "За да получава уеб насочени известия, Overseerr трябва да се работи през HTTPS.", "components.MovieDetails.cast": "В ролите", "components.PermissionEdit.viewissues": "Преглед на проблемите", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", "components.NotificationTypeSelector.mediaautorequestedDescription": "Получавайте известия, когато автоматично се изпращат заявки за елементи от вашия списък за гледане в Plex.", "components.Discover.MovieGenreSlider.moviegenres": "Филмови жанрове", "components.PermissionEdit.viewrecent": "Преглед на наскоро добавените", "components.Discover.networks": "Мрежи", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL адресът не трябва да завършва с наклонена черта в края", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Трябва да изберете поне един тип известие", "components.MovieDetails.budget": "Бюджет", "components.RequestList.showallrequests": "Покажи всички заявки", "components.Settings.Notifications.validationTypes": "Трябва да изберете поне един тип известие", @@ -375,7 +366,6 @@ "components.PermissionEdit.autoapprove4kDescription": "Гарантирано автоматично одобрение за заявки за 4K медии.", "components.RequestModal.requestmovies": "Заявка {count} {count, plural, one {филм} other {филми}}", "components.Settings.Notifications.validationSmtpHostRequired": "Трябва да предоставите валидно име на хост или IP адрес", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Известието за тест към LunaSea е изпратено!", "components.RequestModal.requestedited": "Заявката за {title} е редактирана успешно!", "components.Discover.TvGenreSlider.tvgenres": "Жанрове сериали", "components.RequestModal.selectseason": "Изберете сезон(и)", @@ -459,9 +449,8 @@ "components.Settings.Notifications.pgpPasswordTip": "Подписвайте шифровани имейл съобщения с помощта на OpenPGP", "components.RequestList.RequestItem.failedretry": "Нещо се обърка при повторен опит за заявка.", "components.MovieDetails.imdbuserscore": "IMDB потребителска оценка", - "components.RequestButton.decline4krequests": "Отхвърляне {requestCount, plural, one {заявка} other {{requestCount} заявки}}", + "components.RequestButton.decline4krequests": "Отхвърли {requestCount, plural, one {4K заявка} other {{requestCount} 4K заявки}}", "components.RequestButton.declinerequest4k": "Отказ на 4К заявка", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Профилно име", "components.Settings.Notifications.NotificationsGotify.url": "URL адрес на сървъра", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Трябва да изберете поне един тип известие", "components.NotificationTypeSelector.mediarequestedDescription": "Изпращайте известия, когато потребителите изпращат нови медийни заявки, които изискват одобрение.", @@ -470,7 +459,6 @@ "components.ManageSlideOver.manageModalClearMediaWarning": "* Това ще премахне необратимо всички данни за този {mediaType}, включително всички заявки. Ако този елемент съществува във вашата Plex библиотека, медийната информация ще бъде отново създадена по време на следващото сканиране.", "components.Settings.Notifications.encryptionDefault": "Използвайте STARTTLS, ако има такъв", "components.Settings.SettingsAbout.uptodate": "Актуално", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Настройките за известяване на LunaSea не успяха да бъдат запазени.", "components.Settings.Notifications.pgpPassword": "PGP Парола", "components.RequestModal.QuotaDisplay.requiredquotaUser": "Този потребител трябва да има най-малко {seasons} {seasons, plural, one {заявка за сезон} other {заявки за сезони}} оставащи, за да изпрати заявка за този сериал.", "components.Settings.Notifications.NotificationsWebhook.authheader": "Хедър за удостоверяване", @@ -482,7 +470,7 @@ "components.Settings.SettingsAbout.totalmedia": "Общо медия", "components.RegionSelector.regionServerDefault": "По подразбиране ({region})", "components.PermissionEdit.request4kMovies": "Заявка за 4K филми", - "components.RequestButton.approve4krequests": "Одобрете {requestCount, plural, one {4K заявка} other {{requestCount} 4K Заявки}}", + "components.RequestButton.approve4krequests": "Одобри {requestCount, plural, one {4K заявка} other {{requestCount} 4K Заявки}}", "components.Discover.FilterSlideover.releaseDate": "Дата на излизане", "components.Settings.Notifications.webhookUrl": "Webhook URL", "components.RequestModal.errorediting": "Нещо се обърка при редактирането на заявката.", @@ -745,7 +733,7 @@ "components.StatusChecker.reloadApp": "Презареди {applicationTitle}", "components.Settings.toastTautulliSettingsSuccess": "Tautulli настройките са запазени успешно!", "components.Settings.default4k": "По подразбиране 4К", - "components.Settings.SettingsJobsCache.editJobScheduleSelectorMinutes": "Всяка {jobScheduleMinutes, plural, one {минута} other {{jobScheduleMinutes} минути}}", + "components.Settings.SettingsJobsCache.editJobScheduleSelectorMinutes": "На всяка {jobScheduleMinutes, plural, one {минута} other {{jobScheduleMinutes} минути}}", "components.Settings.SettingsJobsCache.imagecachesize": "Общ размер на кеша", "components.Settings.SonarrModal.validationLanguageProfileRequired": "Трябва да изберете езиков профил", "components.Settings.SonarrModal.loadingTags": "Етикетите се зареждат…", @@ -828,12 +816,10 @@ "components.UserProfile.UserSettings.UserNotificationSettings.pushoverApplicationToken": "Токън за API към приложение", "components.UserProfile.UserSettings.UserGeneralSettings.validationDiscordId": "Трябва да предоставите валиден потребителски идентификатор (User ID) в Discord", "i18n.importing": "Импортиране.…", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Настройките за известяване чрез Web push не успяха да бъдат запазени.", "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncseries": "Автоматична заявка на сериали", "components.UserList.create": "Създавайте", "i18n.restartRequired": "Изисква се рестартиране", "components.Settings.tautulliSettingsDescription": "По желание конфигурирайте настройките за вашия сървър Tautulli. Overseerr извлича данни от хронологията на гледане за вашата Plex медия от Tautulli.", - "components.Settings.copied": "Копиран API ключ в клипборда.", "i18n.request": "Заявка", "components.Settings.validationApiKey": "Трябва да предоставите API ключ", "components.Settings.SonarrModal.editsonarr": "Редактирай Sonarr сървър", @@ -1069,7 +1055,7 @@ "components.UserProfile.UserSettings.UserGeneralSettings.admin": "Админ", "components.UserList.userlist": "Списък с потребители", "components.UserProfile.limit": "{remaining} от {limit}", - "components.Settings.SettingsJobsCache.editJobScheduleSelectorSeconds": "Всяка {jobScheduleSeconds, plural, one {секунда} other {{jobScheduleSeconds} секунди}}", + "components.Settings.SettingsJobsCache.editJobScheduleSelectorSeconds": "На всяка {jobScheduleSeconds, plural, one {секунда} other {{jobScheduleSeconds} секунда}}", "components.Settings.deleteserverconfirm": "Сигурни ли сте, че искате да изтриете този сървър?", "components.UserProfile.UserSettings.UserGeneralSettings.applanguage": "Език на дисплея", "components.TvDetails.watchtrailer": "Гледайте трейлър", @@ -1157,7 +1143,7 @@ "components.UserList.plexuser": "Plex потребител", "components.UserProfile.plexwatchlist": "Plex списък за гледане", "components.TvDetails.streamingproviders": "В момента се излъчва по", - "components.Settings.SettingsJobsCache.editJobScheduleSelectorHours": "Всеки {jobScheduleHours, plural, one {час} other {{jobScheduleHours} часа}}", + "components.Settings.SettingsJobsCache.editJobScheduleSelectorHours": "На всеки {jobScheduleHours, plural, one {час} other {{jobScheduleHours} часа}}", "components.TvDetails.originaltitle": "Оригинално заглавие", "components.Settings.noDefault4kServer": "4K {serverType} сървър трябва да бъде маркиран като стандартен, за да може потребителите да изпращат 4K {mediaType} заявки.", "components.Settings.SettingsUsers.tvRequestLimitLabel": "Глобален лимит за заявка на сериали", @@ -1165,7 +1151,6 @@ "components.UserProfile.UserSettings.UserGeneralSettings.languageDefault": "По подразбиране ({language})", "components.Settings.validationUrlBaseTrailingSlash": "URL адресът не трябва да завършва с наклонена черта в края", "components.Settings.SettingsJobsCache.imagecacheDescription": "Когато е активиран в настройките, Overseerr ще бъде прокси и ще кешира изображения от предварително конфигурирани външни източници. Кешираните изображения се записват във вашата конфигурационна папка. Можете да намерите файловете в {appDataPath}/cache/images.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Настройките за известяване чрез Web push са запазени успешно!", "components.UserProfile.UserSettings.UserNotificationSettings.pgpPublicKey": "PGP публичен ключ", "components.TitleCard.cleardata": "Изчистване на данните", "components.UserProfile.UserSettings.UserPasswordChange.nopermissionDescription": "Нямате права, за да промените паролата на този потребител.", @@ -1245,7 +1230,6 @@ "components.Login.validationemailformat": "Изисква се валиден имейл адрес", "components.Login.username": "Потребителско име", "components.Login.validationhostformat": "Изисква се валиден URL адрес", - "components.Login.validationHostnameRequired": "Трябва да въведете валидно име на хост или IP адрес", "components.Login.validationUrlBaseTrailingSlash": "Базовият URL адрес не трябва да завършва с наклонена черта", "components.Login.validationhostrequired": "Изисква се {mediaServerName} URL адрес", "components.Login.description": "Тъй като това е първото Ви влизане в {applicationName}, трябва да добавите валиден имейл адрес.", @@ -1270,5 +1254,95 @@ "components.Login.validationUrlTrailingSlash": "URL адресът не трябва да завършва с наклонена черта", "components.Login.validationservertyperequired": "Моля изберете тип на сървъра", "components.Login.validationusernamerequired": "Изисква се потребителско име", - "components.Login.saving": "Добавяне…" + "components.Login.saving": "Добавяне…", + "components.MovieDetails.openradarr": "Отвори филма в Radarr", + "components.Settings.OverrideRuleModal.qualityprofile": "Профил за качество", + "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "НЕ активирайте тази настройка освен ако не знаете какво правите!", + "components.MovieDetails.play": "Пусни на {mediaServerName}", + "components.MovieDetails.watchlistDeleted": "{title} Успешно премахнат от листата за гледане!", + "components.Selector.canceled": "Отказано", + "components.Selector.searchUsers": "Избери потребители…", + "components.Settings.OverrideRuleModal.serviceDescription": "Приложи това правило за избраната услуга.", + "components.Settings.SettingsNetwork.toastSettingsFailure": "Нещо се обърка докато запаметявахте настройките.", + "components.Settings.SettingsJobsCache.usersavatars": "Потребителски аватари", + "components.Settings.apiKey": "API ключ", + "components.Settings.SettingsNetwork.proxyBypassFilter": "Игнорирани прокси адреси", + "components.MovieDetails.addtowatchlist": "Добави към листата за гледане", + "components.PermissionEdit.blacklistedItems": "Черен списък за медия.", + "components.Settings.OverrideRuleModal.genres": "Жанрове", + "components.ManageSlideOver.removearr": "Премахни от {arr}", + "components.ManageSlideOver.removearr4k": "Премахни от 4К {arr}", + "components.MovieDetails.downloadstatus": "Статус на сваляне", + "components.MovieDetails.openradarr4k": "Отвори филма в 4К Radarr", + "components.MovieDetails.play4k": "Пусни 4К на {mediaServerName}", + "components.MovieDetails.removefromwatchlist": "Премахни от листата за гледане", + "components.MovieDetails.watchlistError": "Нещо се обърка.Моля опитайте отново.", + "components.MovieDetails.watchlistSuccess": "{title} Успешно добавен към листата за гледане!", + "components.RequestList.RequestItem.profileName": "Профил", + "components.RequestList.RequestItem.removearr": "Премахване от {arr}", + "components.Selector.inProduction": "В продукция", + "components.Settings.OverrideRuleModal.conditions": "Състояние", + "components.Settings.OverrideRuleModal.create": "Създайте правило", + "components.Settings.OverrideRuleModal.keywords": "Ключови думи", + "components.Settings.OverrideRuleModal.languages": "Езици", + "components.Settings.OverrideRuleModal.notagoptions": "Без тагове.", + "components.Settings.OverrideRuleModal.selectQualityProfile": "Изберете профил за капество", + "components.Settings.OverrideRuleModal.selectService": "Изберете услуга", + "components.Settings.OverrideRuleModal.selecttags": "Изберете тагове", + "components.Settings.OverrideRuleModal.service": "Услуга", + "components.Settings.OverrideRuleModal.settings": "Настройки", + "components.Settings.OverrideRuleModal.tags": "Тагове", + "components.Settings.OverrideRuleModal.users": "Потребители", + "components.Settings.OverrideRuleTile.genre": "Жанр", + "components.Settings.OverrideRuleTile.keywords": "Ключови думи", + "components.Settings.OverrideRuleTile.language": "Език", + "components.Settings.OverrideRuleTile.qualityprofile": "Профил за капество", + "components.Settings.OverrideRuleTile.settings": "Настройки", + "components.Settings.OverrideRuleTile.tags": "Тагове", + "components.Settings.OverrideRuleTile.users": "Потребители", + "components.Settings.SettingsJobsCache.jellyfin-full-scan": "Пълно сканиране на библиотеката Jellyfin", + "components.Settings.SettingsMain.enableSpecialEpisodes": "Позволи искане за специални епизоди", + "components.Settings.SettingsNetwork.docs": "Документация", + "components.Settings.SettingsNetwork.network": "Мрежа", + "components.Settings.SettingsNetwork.networksettings": "Мрежови настройки", + "components.Settings.SettingsNetwork.proxyPassword": "Прокси парола", + "components.Settings.SettingsNetwork.proxyPort": "Прокси порт", + "components.Settings.SettingsNetwork.proxySsl": "Използвайте SSL за прокси", + "components.Settings.SettingsNetwork.proxyUser": "Прокси потребител", + "components.Settings.SettingsNetwork.toastSettingsSuccess": "Настройките са запаметени успешно!", + "components.Settings.SettingsNetwork.trustProxy": "Активирай прокси поддръжка", + "components.Settings.SettingsNetwork.validationProxyPort": "Трябва да предоставите валиден порт", + "components.Settings.SettingsUsers.loginMethods": "Метод за влизане", + "components.Settings.SettingsUsers.loginMethodsTip": "Настройте методи за влизане напотребителите", + "components.Settings.SettingsUsers.mediaServerLoginTip": "Позволи на потребителите да се вписват с техния {mediaServerName} акаунт", + "components.Settings.Notifications.userEmailRequired": "Изисква потребителски е-майл", + "components.Settings.SettingsAbout.supportjellyseerr": "Поддръжка Jellyseerr", + "components.Settings.jellyfinSettings": "{mediaServerName} Настройки", + "components.Settings.jellyfinSettingsFailure": "Нещо се обърка докато запаметявахте {mediaServerName} настройките.", + "components.Settings.jellyfinSettingsSuccess": "{mediaServerName} настройките са запазени успешно!", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmailEmpty": "Друг потребител вече използва това потребителско име. Трябва да въведете е-майл", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorExists": "Този акаунт вече е свързан с {applicationName} потребител", + "components.TvDetails.removefromwatchlist": "Премахни от листата за гледане", + "components.UserList.validationUsername": "Трябва да предоставите потребителско име", + "components.UserProfile.UserSettings.LinkJellyfinModal.usernameRequired": "Трябва да предоставите потребителско име", + "components.UserProfile.UserSettings.menuLinkedAccounts": "Свързани акаунти", + "i18n.addToBlacklist": "Добави в черният списък", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmail": "Този е-майл вече се използва!", + "components.UserProfile.localWatchlist": "Списък за гледане на {username}", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnknown": "Появи се непозната грешка", + "components.UserProfile.UserSettings.LinkJellyfinModal.password": "Парола", + "components.UserProfile.UserSettings.LinkJellyfinModal.passwordRequired": "Трябва да предоставите парола", + "components.UserProfile.UserSettings.LinkJellyfinModal.saving": "Добавяне…", + "components.UserProfile.UserSettings.LinkJellyfinModal.username": "Потребителско име", + "components.UserProfile.UserSettings.UserGeneralSettings.email": "Е-майл", + "components.UserProfile.UserSettings.UserGeneralSettings.mediaServerUser": "{mediaServerName} Потребител", + "components.UserProfile.UserSettings.UserGeneralSettings.save": "Запамети промените", + "components.UserProfile.UserSettings.UserGeneralSettings.saving": "Запазване…", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.errorUnknown": "Появи се непозната грешка", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccounts": "Свързани акаунти", + "i18n.blacklist": "Черен списък", + "i18n.blacklistError": "Нещо се обърка. Моля опитайте отново.", + "i18n.removeFromBlacklistSuccess": "{title} е успешно премахнат от Черния списък.", + "i18n.removefromBlacklist": "Премахни ит Черния списък", + "i18n.specials": "Специални" } diff --git a/src/i18n/locale/ca.json b/src/i18n/locale/ca.json index b0ec1fb98c..223f38b878 100644 --- a/src/i18n/locale/ca.json +++ b/src/i18n/locale/ca.json @@ -463,7 +463,6 @@ "components.Settings.email": "Adreça electrònica", "components.Settings.default4k": "4K predeterminat", "components.Settings.default": "Predeterminat", - "components.Settings.copied": "S'ha copiat la clau API al porta-retalls.", "components.Settings.address": "Adreça", "components.Settings.addradarr": "Afegeix un servidor Radarr", "components.Settings.SonarrModal.validationRootFolderRequired": "Heu de seleccionar una carpeta arrel", @@ -712,11 +711,7 @@ "components.RequestList.RequestItem.editrequest": "Edita la sol·licitud", "components.UserProfile.UserSettings.UserGeneralSettings.languageDefault": "Predeterminat ({language})", "components.Settings.Notifications.toastTelegramTestFailed": "No s'ha pogut enviar la notificació de prova de Telegram.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "No s'ha pogut enviar la notificació de prova de LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "No s'ha pogut desar la configuració de notificacions de LunaSea.", "components.DownloadBlock.estimatedtime": "{time} de temps estimat", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "La configuració de notificacions de Push Web s'ha desat correctament!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "No s'ha pogut desar la configuració de notificacions de Push Web.", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", "components.UserProfile.UserSettings.UserGeneralSettings.applanguage": "Idioma de visualització", "components.Settings.webpush": "Web Push", @@ -750,19 +745,10 @@ "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "S'ha enviat la notificació de prova Pushbullet!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "S'està enviant la notificació de prova de Pushbullet…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "No s'ha pogut enviar la notificació de prova Pushbullet.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL del Webhook", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Has de proporcionar un URL vàlid", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "S'ha enviat la notificació de prova de LunaSea!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "S'està enviant la notificació de prova de LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "La configuració de les notificacions de LunaSea s'ha desat correctament!", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Només és necessari si no s'utilitza el perfil default", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nom de perfil", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Activa l'agent", "components.PermissionEdit.requestTvDescription": "Concedeix permís per sol·licitar sèries no 4K.", "components.PermissionEdit.requestTv": "Sol·licita sèries", "components.PermissionEdit.requestMoviesDescription": "Concedeix permís per sol·licitar pel·lícules no 4K.", "components.PermissionEdit.requestMovies": "Sol·liciteu pel·lícules", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "El vostre URL del webhook de notificació basat en l'usuari o el dispositiu", "components.UserList.localLoginDisabled": "El paràmetre Activa l'inici de sessió local està desactivat actualment.", "components.Settings.webAppUrlTip": "Opcionalment, dirigiu els usuaris a l'aplicació web del vostre servidor en lloc de l'aplicació web \"allotjada\"", "components.Settings.webAppUrl": "URL de l'aplicació web", @@ -790,7 +776,6 @@ "components.Settings.Notifications.NotificationsSlack.validationTypes": "Heu de seleccionar com a mínim un tipus de notificació", "components.Settings.Notifications.NotificationsPushover.validationTypes": "Heu de seleccionar com a mínim un tipus de notificació", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Heu de seleccionar com a mínim un tipus de notificació", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Heu de seleccionar com a mínim un tipus de notificació", "components.QuotaSelector.tvRequests": "{quotaLimit} {temporades} per {quotaDays} {dies}", "components.QuotaSelector.seasons": "{count, plural, one {temporada} other {temporades}}", "components.QuotaSelector.movies": "{count, plural, one {pel·lícula} other {pel·lícules}}", diff --git a/src/i18n/locale/cs.json b/src/i18n/locale/cs.json index b54459d5ee..efe0f7eb47 100644 --- a/src/i18n/locale/cs.json +++ b/src/i18n/locale/cs.json @@ -79,9 +79,6 @@ "components.Settings.Notifications.NotificationsPushover.agentenabled": "Povolit agenta", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Povolit agenta", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Přístupový token", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Jméno profilu", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Povolit agenta", "components.Search.searchresults": "Výsledky vyhledávání", "components.ResetPassword.passwordreset": "Obnovení hesla", "components.ResetPassword.email": "E-mailová adresa", @@ -597,11 +594,9 @@ "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "Oznámení o testu Gotify odesláno!", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "Adresa URL nesmí končit koncovým lomítkem", "components.Settings.Notifications.NotificationsGotify.validationTypes": "Musíte vybrat alespoň jeden typ oznámení", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Oznámení o testu LunaSea odesláno!", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "Musíte zadat platnou adresu URL", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Testovací oznámení Pushbullet odesláno!", "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "Musíte zadat přístupový token", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Musíte vybrat alespoň jeden typ oznámení", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Odeslání testovacího oznámení Pushbullet…", "components.Settings.RadarrModal.validationApplicationUrl": "Musíte zadat platnou adresu URL", "components.Settings.RadarrModal.validationApplicationUrlTrailingSlash": "Adresa URL nesmí končit koncovým lomítkem", @@ -702,7 +697,6 @@ "components.RequestModal.QuotaDisplay.requiredquota": "Abyste mohli zažádat o tento seriál, musíte mít alespoň {seasons} {seasons, plural, one {zbývající žádost o sezónu} few {zbývající žádosti o sezónu} other {zbývajících žádostí o sezónu}}.", "components.RequestModal.requestfrom": "Žádost od {username} čeká na schválení.", "components.RequestModal.requesterror": "Při odesílání žádosti se něco pokazilo.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Vaše adresa URL notification webhook pro uživatele nebo zařízení", "components.Settings.Notifications.toastEmailTestSuccess": "E-mailové oznámení o testu odesláno!", "components.Settings.RadarrModal.baseUrl": "Základní adresa URL", "components.Settings.RadarrModal.default4kserver": "Výchozí server 4K", @@ -731,8 +725,6 @@ "components.RequestBlock.languageprofile": "Jazykový profil", "components.RequestModal.QuotaDisplay.quotaLinkUser": "Souhrn limitů požadavků tohoto uživatele můžete zobrazit na jeho profilové stránce.", "components.Settings.Notifications.NotificationsGotify.token": "Token aplikace", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Testovací oznámení LunaSea se nepodařilo odeslat.", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Musíte zadat platnou adresu URL", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "Označení kanálu", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Nastavení oznámení Pushbullet se nepodařilo uložit.", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Musíte vybrat alespoň jeden typ oznámení", @@ -775,7 +767,6 @@ "components.Settings.SonarrModal.validationApplicationUrlTrailingSlash": "Adresa URL nesmí končit koncovým lomítkem", "components.Settings.addradarr": "Přidání serveru Radarr", "components.Settings.addsonarr": "Adding a Radarr server", - "components.Settings.copied": "Zkopírování klíče API do schránky.", "components.Settings.externalUrl": "Externí adresa URL", "components.Settings.hostname": "Název hostitele nebo IP adresa", "components.Settings.manualscan": "Manuální skenování knihovny", @@ -853,7 +844,6 @@ "components.RequestModal.AdvancedRequester.animenote": "* Tento seriál je anime.", "components.Settings.Notifications.NotificationsPushover.userToken": "Klíč uživatele nebo skupiny", "components.RequestCard.failedretry": "Při opakovaném pokusu o zadání požadavku se něco pokazilo.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Vyžaduje se pouze v případě, že nepoužíváte profil default", "components.RequestCard.mediaerror": "{mediaType} Nenalezeno", "components.RequestList.RequestItem.mediaerror": "{mediaType} Nenalezeno", "components.RequestModal.QuotaDisplay.allowedRequests": "Můžete požádat o {limit} {type} každé {days} dny.", @@ -866,7 +856,6 @@ "components.Settings.SonarrModal.selectRootFolder": "Vyberte kořenovou složku", "components.ResetPassword.requestresetlinksuccessmessage": "Na zadanou e-mailovou adresu bude zaslán odkaz pro obnovení hesla, pokud je spojena s platným uživatelem.", "components.RequestModal.pendingrequest": "Čekající žádost", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Nastavení oznámení LunaSea úspěšně uloženo!", "components.Settings.SonarrModal.default4kserver": "Výchozí server 4K", "components.UserProfile.UserSettings.UserNotificationSettings.pushoverUserKeyTip": "Váš 30znakový identifikátor uživatele nebo skupiny", "components.UserProfile.UserSettings.UserNotificationSettings.pushoversettingssaved": "Nastavení oznámení Pushover úspěšně uloženo!", @@ -878,7 +867,6 @@ "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Oznámení o testu Pushover odesláno!", "components.Settings.Notifications.NotificationsSlack.slacksettingsfailed": "Nastavení oznámení služby Slack se nepodařilo uložit.", "components.Settings.toastPlexConnectingSuccess": "Připojení k systému Plex úspěšně navázáno!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Odeslání oznámení o testu LunaSea…", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Vytvořte token ze svého Nastavení účtu", "components.Settings.Notifications.encryptionTip": "Ve většině případů používá implicitní TLS port 465 a STARTTLS port 587", "components.Settings.Notifications.toastDiscordTestFailed": "Oznámení o testu Discord se nepodařilo odeslat.", @@ -887,7 +875,6 @@ "components.TvDetails.firstAirDate": "Datum prvního vysílání", "components.Settings.RadarrModal.validationApiKeyRequired": "Musíte zadat klíč API", "components.Settings.toastPlexConnectingFailure": "Nepodařilo se připojit k systému Plex.", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Nastavení oznámení LunaSea se nepodařilo uložit.", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registrace aplikace pro použití s aplikací Jellyseerr", "components.Settings.Notifications.NotificationsPushover.validationAccessTokenRequired": "Musíte zadat platný token aplikace", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Testovací oznámení Pushover se nepodařilo odeslat.", @@ -949,7 +936,6 @@ "components.UserProfile.UserSettings.UserGeneralSettings.validationDiscordId": "Musíte zadat platné ID uživatele služby Discord", "components.UserProfile.UserSettings.UserNotificationSettings.pgpPublicKey": "Veřejný klíč PGP", "components.UserProfile.UserSettings.UserNotificationSettings.pgpPublicKeyTip": "Šifrování e-mailových zpráv pomocí OpenPGP", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Nastavení webových oznámení push bylo úspěšně uloženo!", "components.UserProfile.UserSettings.UserNotificationSettings.discordIdTip": "vícemístné identifikační číslo spojené s vaším uživatelským účtem", "components.UserProfile.UserSettings.UserNotificationSettings.pushbulletAccessToken": "Přístupový token", "components.UserProfile.UserSettings.UserNotificationSettings.pushoverUserKey": "Klíč uživatele nebo skupiny", @@ -958,7 +944,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.pushoversettingsfailed": "Nastavení oznámení Pushover se nepodařilo uložit.", "components.UserProfile.UserSettings.UserNotificationSettings.pushoverApplicationTokenTip": "Registrace aplikace pro použití s {applicationTitle}", "components.UserProfile.UserSettings.UserNotificationSettings.telegramsettingssaved": "Nastavení oznámení Telegramu úspěšně uloženo!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Nastavení webových push oznámení se nepodařilo uložit.", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "Tento uživatelský účet v současné době nemá nastavené heslo. Níže nastavte heslo, aby se tento účet mohl přihlašovat jako \"místní uživatel.\"", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSetOwnAccount": "Váš účet v současné době nemá nastavené heslo. Níže nastavte heslo, abyste se mohli přihlásit jako \"místní uživatel\" pomocí své e-mailové adresy.", "i18n.importing": "Importování…", @@ -1250,7 +1235,6 @@ "components.Settings.Notifications.validationWebhookRoleId": "Musíte poskytnout platné ID Discord role", "components.Blacklist.blacklistedby": "{date} uživatelem {user}", "components.Layout.UserWarnings.passwordRequired": "Heslo je povinné.", - "components.Login.validationHostnameRequired": "Musíte poskytnout platné hostitelské jméno nebo IP adresu", "components.Selector.searchStatus": "Vyberte status…", "components.TvDetails.watchlistSuccess": "{title} úspěšně přidáno na seznam sledování!", "components.Blacklist.blacklistNotFoundError": "{title} není na černé listině.", diff --git a/src/i18n/locale/da.json b/src/i18n/locale/da.json index 4de9715197..b98474fa80 100644 --- a/src/i18n/locale/da.json +++ b/src/i18n/locale/da.json @@ -258,7 +258,6 @@ "components.RegionSelector.regionDefault": "Alle Regioner", "components.RequestBlock.rootfolder": "Rodmappe", "components.RequestButton.viewrequest4k": "Vis 4K Forespørgsel", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Aktivér Agent", "components.RequestModal.seasonnumber": "Sæson {number}", "components.NotificationTypeSelector.mediadeclinedDescription": "Send notifikationer når medieforespørgsler afvises.", "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "For at kunne modtage web push-notifikationer skal Jellyseerr benytte HTTPS.", @@ -286,9 +285,6 @@ "components.RequestModal.pending4krequest": "Afventende 4K Forespørgsler", "components.RequestModal.pendingapproval": "Din forespørgsel afventer godkendelse.", "components.ResetPassword.resetpasswordsuccessmessage": "Kodeord er nulstillet!", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profilnavn", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea testnotifikation er afsendt!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Du skal vælge mindst én notifikationstype", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet testnotifikation kunne ikke sendes.", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registrér en applikation til brug med Jellyseerr", "components.Settings.Notifications.NotificationsPushover.pushoversettingssaved": "Pushover notifikationsindstillinger er blevet gemt!", @@ -334,14 +330,6 @@ "components.ResetPassword.validationpasswordminchars": "Kodeordet er for kort; det skal være mindst 8 tegn", "components.ResetPassword.validationpasswordrequired": "Du skal angive et kodeord", "components.Search.search": "Søg", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Kun påkrævet hvis du benytter en anden profil end default", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea notifikationsindstillinger kunne ikke gemmes.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea notifikationsindstillinger er blevet gemt!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea testnotifikation kunne ikke afsendes.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Sender LunaSea testnotifikation…", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Du skal angive en gyldig URL", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Din bruger- eller enhedsbaserede webhook URL for notifikationer", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Adgangstoken", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Opret en token fra dine Kontoindstillinger", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Aktivér Agent", @@ -595,7 +583,6 @@ "components.Settings.SonarrModal.validationRootFolderRequired": "Du skal angive en rodmappe", "components.Settings.address": "Adresse", "components.Settings.addsonarr": "Tilføj Sonarr Server", - "components.Settings.copied": "API-nøgle er kopieret til udklipsholder.", "components.Settings.currentlibrary": "Nuværende Bibliotek: {name}", "components.Settings.email": "Email", "components.Settings.enablessl": "Benyt SSL", @@ -843,8 +830,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Du skal angive et gyldigt chat-ID", "components.UserProfile.UserSettings.UserNotificationSettings.validationDiscordId": "Du skal angive et bruger-ID", "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "Du skal angive en gyldig offentlig PGP-nøgle", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Notifikationsindstillingerne for web push kunne ikke gemmes.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Notifikationsindstillingerne for web push er blevet gemt!", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Bekræft Kodeord", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Nyt Kodeord", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "Denne brugerkonto har i øjeblikket ikke et kodeord. Konfigurér et kodeord nedenfor så denne konto kan logge ind som en \"lokal bruger.\"", diff --git a/src/i18n/locale/de.json b/src/i18n/locale/de.json index de8587cb66..2b6cc081d9 100644 --- a/src/i18n/locale/de.json +++ b/src/i18n/locale/de.json @@ -16,7 +16,7 @@ "components.Discover.DiscoverWatchlist.watchlist": "Plex Merkliste", "components.Discover.MovieGenreList.moviegenres": "Film-Genres", "components.Discover.MovieGenreSlider.moviegenres": "Film-Genres", - "components.Discover.NetworkSlider.networks": "Sender", + "components.Discover.NetworkSlider.networks": "Dienste", "components.Discover.StudioSlider.studios": "Filmstudio", "components.Discover.TvGenreList.seriesgenres": "Serien-Genres", "components.Discover.TvGenreSlider.tvgenres": "Serien-Genres", @@ -28,17 +28,17 @@ "components.Discover.populartv": "Beliebte Serien", "components.Discover.recentlyAdded": "Kürzlich hinzugefügt", "components.Discover.recentrequests": "Bisherige Anfragen", - "components.Discover.trending": "Trends", + "components.Discover.trending": "Im Trend", "components.Discover.upcoming": "Demnächst erscheinende Filme", "components.Discover.upcomingmovies": "Demnächst erscheinende Filme", "components.Discover.upcomingtv": "Demnächst erscheinende Serien", - "components.DownloadBlock.estimatedtime": "Geschätzte {time}", - "components.DownloadBlock.formattedTitle": "{title}: Staffel {seasonNumber} Episode {episodeNumber}", + "components.DownloadBlock.estimatedtime": "Geschätzt {time}", + "components.DownloadBlock.formattedTitle": "{title}: Staffel {seasonNumber} Folge {episodeNumber}", "components.IssueDetails.IssueComment.areyousuredelete": "Soll dieser Kommentar wirklich gelöscht werden?", "components.IssueDetails.IssueComment.delete": "Kommentar löschen", "components.IssueDetails.IssueComment.edit": "Kommentar bearbeiten", - "components.IssueDetails.IssueComment.postedby": "Gepostet {relativeTime} von {username}", - "components.IssueDetails.IssueComment.postedbyedited": "Gepostet {relativeTime} von {username} (Bearbeitet)", + "components.IssueDetails.IssueComment.postedby": "Verfasst {relativeTime} von {username}", + "components.IssueDetails.IssueComment.postedbyedited": "Verfasst {relativeTime} von {username} (Bearbeitet)", "components.IssueDetails.IssueComment.validationComment": "Du musst eine Nachricht eingeben", "components.IssueDetails.IssueDescription.deleteissue": "Problem löschen", "components.IssueDetails.IssueDescription.description": "Beschreibung", @@ -54,9 +54,9 @@ "components.IssueDetails.episode": "Folge {episodeNumber}", "components.IssueDetails.issuepagetitle": "Problem", "components.IssueDetails.issuetype": "Art", - "components.IssueDetails.lastupdated": "Letzte Aktualisierung", + "components.IssueDetails.lastupdated": "Letzte Änderung", "components.IssueDetails.leavecomment": "Kommentar", - "components.IssueDetails.nocomments": "Keine Kommentare.", + "components.IssueDetails.nocomments": "Es gibt keine Kommentare.", "components.IssueDetails.openedby": "#{issueId} geöffnet {relativeTime} von {username}", "components.IssueDetails.openin4karr": "In {arr} 4K öffnen", "components.IssueDetails.openinarr": "In {arr} öffnen", @@ -71,8 +71,8 @@ "components.IssueDetails.toasteditdescriptionsuccess": "Problembeschreibung erfolgreich bearbeitet!", "components.IssueDetails.toastissuedeleted": "Problem erfolgreich gelöscht!", "components.IssueDetails.toastissuedeletefailed": "Beim Löschen des Problems ist ein Fehler aufgetreten.", - "components.IssueDetails.toaststatusupdated": "Problemstatus erfolgreich aktualisiert!", - "components.IssueDetails.toaststatusupdatefailed": "Beim Aktualisieren des Problemstatus ist ein Fehler aufgetreten.", + "components.IssueDetails.toaststatusupdated": "Status des Problems erfolgreich aktualisiert!", + "components.IssueDetails.toaststatusupdatefailed": "Beim Aktualisieren des Status des Problems ist ein Fehler aufgetreten.", "components.IssueDetails.unknownissuetype": "Unbekannt", "components.IssueList.IssueItem.episodes": "{episodeCount, plural, one {Folge} other {Folgen}}", "components.IssueList.IssueItem.issuestatus": "Status", @@ -103,29 +103,29 @@ "components.IssueModal.CreateIssueModal.validationMessageRequired": "Du musst eine Beschreibung eingeben", "components.IssueModal.CreateIssueModal.whatswrong": "Was ist das Problem?", "components.IssueModal.issueAudio": "Ton", - "components.IssueModal.issueOther": "Andere", + "components.IssueModal.issueOther": "Sonstige", "components.IssueModal.issueSubtitles": "Untertitel", "components.IssueModal.issueVideo": "Video", "components.LanguageSelector.languageServerDefault": "Standard ({language})", "components.LanguageSelector.originalLanguageDefault": "Alle Sprachen", "components.Layout.LanguagePicker.displaylanguage": "Anzeigesprache", - "components.Layout.SearchInput.searchPlaceholder": "Nach Filmen und Serien suchen", + "components.Layout.SearchInput.searchPlaceholder": "Nach Filmen & Serien suchen", "components.Layout.Sidebar.dashboard": "Entdecken", "components.Layout.Sidebar.issues": "Probleme", "components.Layout.Sidebar.requests": "Anfragen", "components.Layout.Sidebar.settings": "Einstellungen", "components.Layout.Sidebar.users": "Benutzer", - "components.Layout.UserDropdown.MiniQuotaDisplay.movierequests": "Film-Anfragen", - "components.Layout.UserDropdown.MiniQuotaDisplay.seriesrequests": "Serien-Anfragen", + "components.Layout.UserDropdown.MiniQuotaDisplay.movierequests": "Filmanfragen", + "components.Layout.UserDropdown.MiniQuotaDisplay.seriesrequests": "Serienanfragen", "components.Layout.UserDropdown.myprofile": "Profil", "components.Layout.UserDropdown.requests": "Anfragen", "components.Layout.UserDropdown.settings": "Einstellungen", "components.Layout.UserDropdown.signout": "Abmelden", "components.Layout.VersionStatus.commitsbehind": "{commitsBehind} {commitsBehind, plural, one {Version} other {Versionen}} hinterher", "components.Layout.VersionStatus.outofdate": "Veraltet", - "components.Layout.VersionStatus.streamdevelop": "Jellyseerr Entwicklung", - "components.Layout.VersionStatus.streamstable": "Jellyseerr stabil", - "components.Login.email": "E-Mail Adresse", + "components.Layout.VersionStatus.streamdevelop": "Jellyseerr (Entwicklung)", + "components.Layout.VersionStatus.streamstable": "Jellyseerr (Stabil)", + "components.Login.email": "E-Mail-Adresse", "components.Login.forgotpassword": "Passwort vergessen?", "components.Login.loginerror": "Beim Anmelden ist etwas schief gelaufen.", "components.Login.password": "Passwort", @@ -172,60 +172,60 @@ "components.MovieDetails.originaltitle": "Originaltitel", "components.MovieDetails.overview": "Übersicht", "components.MovieDetails.overviewunavailable": "Übersicht nicht verfügbar.", - "components.MovieDetails.physicalrelease": "DVD/Bluray-Veröffentlichung", - "components.MovieDetails.productioncountries": "Produktions {countryCount, plural, one {Land} other {Länder}}", + "components.MovieDetails.physicalrelease": "Physische Veröffentlichung", + "components.MovieDetails.productioncountries": "Produktions{countryCount, plural, one {land} other {länder}}", "components.MovieDetails.recommendations": "Empfehlungen", - "components.MovieDetails.releasedate": "{releaseCount, plural, one {Veröffentlichungstermin} other {Veröffentlichungstermine}}", + "components.MovieDetails.releasedate": "{releaseCount, plural, one {Erscheinungsdatum} other {Erscheinungsdatum}}", "components.MovieDetails.reportissue": "Problem melden", "components.MovieDetails.revenue": "Einnahmen", - "components.MovieDetails.rtaudiencescore": "Rotten Tomatoes Publikumswertung", - "components.MovieDetails.rtcriticsscore": "Rotten Tomatoes Tomatometer", + "components.MovieDetails.rtaudiencescore": "Rotten Tomatoes - Nutzerwertung", + "components.MovieDetails.rtcriticsscore": "Rotten Tomatoes - Tomatometer", "components.MovieDetails.runtime": "{minutes} Minuten", "components.MovieDetails.showless": "Weniger Anzeigen", "components.MovieDetails.showmore": "Mehr Anzeigen", "components.MovieDetails.similar": "Ähnliche Titel", - "components.MovieDetails.streamingproviders": "Streamt derzeit auf", + "components.MovieDetails.streamingproviders": "Derzeit verfügbar auf", "components.MovieDetails.studio": "{studioCount, plural, one {Studio} other {Studios}}", "components.MovieDetails.theatricalrelease": "Kinostart", - "components.MovieDetails.tmdbuserscore": "TMDB-Nutzerwertung", + "components.MovieDetails.tmdbuserscore": "TMDB - Nutzerwertung", "components.MovieDetails.viewfullcrew": "Komplette Crew anzeigen", "components.MovieDetails.watchtrailer": "Trailer ansehen", - "components.NotificationTypeSelector.adminissuecommentDescription": "Sende eine Benachrichtigung, wenn andere Benutzer Kommentare zu Problemen abgeben.", - "components.NotificationTypeSelector.adminissuereopenedDescription": "Sende eine Benachrichtigung, wenn Probleme von anderen Benutzern wieder geöffnet werden.", - "components.NotificationTypeSelector.adminissueresolvedDescription": "Sende eine Benachrichtigung, wenn andere Benutzer Kommentare zu Themen abgeben.", + "components.NotificationTypeSelector.adminissuecommentDescription": "Benachrichtigung erhalten, wenn andere Benutzer Kommentare zu Problemen verfassen.", + "components.NotificationTypeSelector.adminissuereopenedDescription": "Benachrichtigung erhalten, wenn Probleme von anderen Benutzern wieder geöffnet werden.", + "components.NotificationTypeSelector.adminissueresolvedDescription": "Benachrichtigung erhalten, wenn Probleme von anderen Benutzern gelöst werden.", "components.NotificationTypeSelector.issuecomment": "Problem Kommentar", - "components.NotificationTypeSelector.issuecommentDescription": "Sende eine Benachrichtigungen, wenn Probleme neue Kommentare erhalten.", + "components.NotificationTypeSelector.issuecommentDescription": "Benachrichtigung erhalten, wenn Probleme neue Kommentare erhalten.", "components.NotificationTypeSelector.issuecreated": "Problem gemeldet", - "components.NotificationTypeSelector.issuecreatedDescription": "Senden eine Benachrichtigungen, wenn Probleme gemeldet werden.", + "components.NotificationTypeSelector.issuecreatedDescription": "Benachrichtigung erhalten, wenn Probleme gemeldet werden.", "components.NotificationTypeSelector.issuereopened": "Problem wiedereröffnet", - "components.NotificationTypeSelector.issuereopenedDescription": "Sende eine Benachrichtigung, wenn Probleme wieder geöffnet werden.", + "components.NotificationTypeSelector.issuereopenedDescription": "Benachrichtigung erhalten, wenn Probleme wieder geöffnet werden.", "components.NotificationTypeSelector.issueresolved": "Problem gelöst", - "components.NotificationTypeSelector.issueresolvedDescription": "Senden Benachrichtigungen, wenn Probleme gelöst sind.", + "components.NotificationTypeSelector.issueresolvedDescription": "Benachrichtigung erhalten, wenn Probleme gelöst sind.", "components.NotificationTypeSelector.mediaAutoApproved": "Anfrage automatisch genehmigt", - "components.NotificationTypeSelector.mediaAutoApprovedDescription": "Sende eine Benachrichtigung, wenn das angeforderte Medium automatisch genehmigt wird.", + "components.NotificationTypeSelector.mediaAutoApprovedDescription": "Benachrichtigung erhalten, wenn das angeforderte Medium automatisch genehmigt wird.", "components.NotificationTypeSelector.mediaapproved": "Anfrage genehmigt", - "components.NotificationTypeSelector.mediaapprovedDescription": "Sende Benachrichtigungen, wenn angeforderte Medien manuell genehmigt wurden.", + "components.NotificationTypeSelector.mediaapprovedDescription": "Benachrichtigung erhalten, wenn angeforderte Medien manuell genehmigt wurden.", "components.NotificationTypeSelector.mediaautorequested": "Anfrage automatisch übermittelt", - "components.NotificationTypeSelector.mediaautorequestedDescription": "Erhalten eine Benachrichtigung, wenn neue Medienanfragen für Objekte auf deiner Merkliste automatisch übermittelt werden.", + "components.NotificationTypeSelector.mediaautorequestedDescription": "Benachrichtigung erhalten, wenn neue Medienanfragen für Objekte auf deiner Merkliste automatisch übermittelt werden.", "components.NotificationTypeSelector.mediaavailable": "Anfrage verfügbar", - "components.NotificationTypeSelector.mediaavailableDescription": "Sendet Benachrichtigungen, wenn angeforderte Medien verfügbar werden.", + "components.NotificationTypeSelector.mediaavailableDescription": "Benachrichtigung erhalten, wenn angeforderte Medien verfügbar werden.", "components.NotificationTypeSelector.mediadeclined": "Anfrage abgelehnt", - "components.NotificationTypeSelector.mediadeclinedDescription": "Sende eine Benachrichtigungen, wenn Medienanfragen abgelehnt wurden.", + "components.NotificationTypeSelector.mediadeclinedDescription": "Benachrichtigung erhalten, wenn Medienanfragen abgelehnt wurden.", "components.NotificationTypeSelector.mediafailed": "Anfrageverarbeitung fehlgeschlagen", - "components.NotificationTypeSelector.mediafailedDescription": "Sende Benachrichtigungen, wenn angeforderte Medien nicht zu Radarr oder Sonarr hinzugefügt werden konnten.", + "components.NotificationTypeSelector.mediafailedDescription": "Benachrichtigungen senden, wenn angeforderte Medien nicht zu Radarr oder Sonarr hinzugefügt werden konnten.", "components.NotificationTypeSelector.mediarequested": "Anfrage in Bearbeitung", - "components.NotificationTypeSelector.mediarequestedDescription": "Sende Benachrichtigungen, wenn neue Medien angefordert wurden und auf Genehmigung warten.", + "components.NotificationTypeSelector.mediarequestedDescription": "Benachrichtigungen senden, wenn neue Medien angefordert wurden und auf Genehmigung warten.", "components.NotificationTypeSelector.notificationTypes": "Benachrichtigungstypen", - "components.NotificationTypeSelector.userissuecommentDescription": "Sende eine Benachrichtigung, wenn dein Problem neue Kommentare erhält.", - "components.NotificationTypeSelector.userissuecreatedDescription": "Lassen dich benachrichtigen, wenn andere Benutzer Probleme melden.", - "components.NotificationTypeSelector.userissuereopenedDescription": "Sende eine Benachrichtigung, wenn die von dir gemeldeten Probleme wieder geöffnet werden.", - "components.NotificationTypeSelector.userissueresolvedDescription": "Sende eine Benachrichtigung, wenn dein Problem gelöst wurde.", - "components.NotificationTypeSelector.usermediaAutoApprovedDescription": "Werde benachrichtigt, wenn andere Nutzer Medien anfordern, welche automatisch angenommen werden.", - "components.NotificationTypeSelector.usermediaapprovedDescription": "Werde benachrichtigt, wenn deine Medienanfrage angenommen wurde.", - "components.NotificationTypeSelector.usermediaavailableDescription": "Sende eine Benachrichtigung, wenn deine Medienanfragen verfügbar sind.", - "components.NotificationTypeSelector.usermediadeclinedDescription": "Werde benachrichtigt, wenn deine Medienanfrage abgelehnt wurde.", - "components.NotificationTypeSelector.usermediafailedDescription": "Werde benachrichtigt, wenn die angeforderten Medien bei der Hinzufügung zu Radarr oder Sonarr fehlschlagen.", - "components.NotificationTypeSelector.usermediarequestedDescription": "Werde benachrichtigt, wenn andere Nutzer eine Medie anfordern, welches eine Genehmigung erfordert.", + "components.NotificationTypeSelector.userissuecommentDescription": "Benachrichtigung erhalten, wenn dein Problem neue Kommentare erhält.", + "components.NotificationTypeSelector.userissuecreatedDescription": "Benachrichtigung erhalten, wenn andere Benutzer Probleme melden.", + "components.NotificationTypeSelector.userissuereopenedDescription": "Benachrichtigung erhalten, wenn von dir gemeldete Probleme wieder geöffnet werden.", + "components.NotificationTypeSelector.userissueresolvedDescription": "Benachrichtigung erhalten, wenn dein Problem gelöst wurde.", + "components.NotificationTypeSelector.usermediaAutoApprovedDescription": "Benachrichtigung erhalten, wenn andere Benutzer neue Medienanfragen stellen, die automatisch genehmigt werden.", + "components.NotificationTypeSelector.usermediaapprovedDescription": "Benachrichtigung erhalten, wenn deine Medienanfragen genehmigt werden.", + "components.NotificationTypeSelector.usermediaavailableDescription": "Benachrichtigung erhalten, wenn deine Medienanfragen verfügbar sind.", + "components.NotificationTypeSelector.usermediadeclinedDescription": "Benachrichtigung erhalten, wenn deine Medienanfrage abgelehnt wurde.", + "components.NotificationTypeSelector.usermediafailedDescription": "Benachrichtigung erhalten, wenn die angeforderten Medien bei der Hinzufügung zu Radarr oder Sonarr fehlschlagen.", + "components.NotificationTypeSelector.usermediarequestedDescription": "Benachrichtigung erhalten, wenn andere Nutzer eine Medie anfordern, welches eine Genehmigung erfordert.", "components.PermissionEdit.admin": "Admin", "components.PermissionEdit.adminDescription": "Voller Administratorzugriff. Umgeht alle anderen Rechteabfragen.", "components.PermissionEdit.advancedrequest": "Erweiterte Anfragen", @@ -242,7 +242,7 @@ "components.PermissionEdit.autoapproveMoviesDescription": "Autorisierung der automatischen Freigabe von Anfragen für nicht-4K-Filme.", "components.PermissionEdit.autoapproveSeries": "Automatische Genehmigung von Serien", "components.PermissionEdit.autoapproveSeriesDescription": "Autorisierung der automatischen Freigabe von Anfragen für nicht-4K-Serien.", - "components.PermissionEdit.autorequest": "Automatische Anfrage aus Plex-Merkliste", + "components.PermissionEdit.autorequest": "Automatische Anfrage aus Plex Merkliste", "components.PermissionEdit.autorequestDescription": "Autorisierung zur automatischen Anfrage von Nicht-4K-Medien über die Plex Merkliste.", "components.PermissionEdit.autorequestMovies": "Filme automatisch anfragen", "components.PermissionEdit.autorequestMoviesDescription": "Autorisierung zur automatischen Anfrage von Nicht-4K-Medien über die Plex Merkliste.", @@ -297,7 +297,7 @@ "components.RequestBlock.languageprofile": "Sprachprofil", "components.RequestBlock.lastmodifiedby": "Zuletzt geändert von", "components.RequestBlock.profilechanged": "Qualitätsprofil", - "components.RequestBlock.requestdate": "Anfrage-Datum", + "components.RequestBlock.requestdate": "Anfragedatum", "components.RequestBlock.requestedby": "Angefragt von", "components.RequestBlock.requestoverrides": "Anfrage Überschreibungen", "components.RequestBlock.rootfolder": "Stammordner", @@ -323,7 +323,7 @@ "components.RequestCard.failedretry": "Beim erneuten Versuch die Anfrage zu senden ist ein Fehler aufgetreten.", "components.RequestCard.mediaerror": "{mediaType} wurde nicht gefunden", "components.RequestCard.seasons": "{seasonCount, plural, one {Staffel} other {Staffeln}}", - "components.RequestCard.tmdbid": "TMDB-ID", + "components.RequestCard.tmdbid": "TMDB ID", "components.RequestCard.tvdbid": "TheTVDB-ID", "components.RequestCard.unknowntitle": "Unbekannter Titel", "components.RequestList.RequestItem.cancelRequest": "Anfrage abbrechen", @@ -336,11 +336,11 @@ "components.RequestList.RequestItem.requested": "Angefragt", "components.RequestList.RequestItem.requesteddate": "Angefordert", "components.RequestList.RequestItem.seasons": "{seasonCount, plural, one {Staffel} other {Staffeln}}", - "components.RequestList.RequestItem.tmdbid": "TMDB-ID", + "components.RequestList.RequestItem.tmdbid": "TMDB ID", "components.RequestList.RequestItem.tvdbid": "TheTVDB-ID", "components.RequestList.RequestItem.unknowntitle": "Unbekannter Titel", "components.RequestList.requests": "Anfragen", - "components.RequestList.showallrequests": "Zeige alle Anfragen", + "components.RequestList.showallrequests": "Alle Anfragen anzeigen", "components.RequestList.sortAdded": "Zuletzt angefragt", "components.RequestList.sortModified": "Zuletzt geändert", "components.RequestModal.AdvancedRequester.advancedoptions": "Erweiterte Einstellungen", @@ -402,8 +402,8 @@ "components.RequestModal.selectmovies": "Wähle Film(e)", "components.RequestModal.selectseason": "Staffel(n) Auswählen", "components.ResetPassword.confirmpassword": "Passwort bestätigen", - "components.ResetPassword.email": "E-Mail Adresse", - "components.ResetPassword.emailresetlink": "Wiederherstellungs-Link per E-Mail senden", + "components.ResetPassword.email": "E-Mail-Adresse", + "components.ResetPassword.emailresetlink": "Wiederherstellungs-Link an E-Mail-Adresse senden", "components.ResetPassword.gobacklogin": "Zurück zur Anmeldeseite", "components.ResetPassword.password": "Passwort", "components.ResetPassword.passwordreset": "Passwort zurücksetzen", @@ -412,7 +412,7 @@ "components.ResetPassword.resetpasswordsuccessmessage": "Passwort wurde erfolgreich zurückgesetzt!", "components.ResetPassword.validationemailrequired": "Du musst eine gültige E-Mail Adresse angeben", "components.ResetPassword.validationpasswordmatch": "Passwörter müssen übereinstimmen", - "components.ResetPassword.validationpasswordminchars": "Passwort ist zu kurz; es sollte mindestens 8 Zeichen lang sein", + "components.ResetPassword.validationpasswordminchars": "Das Passwort ist zu kurz, es sollte mindestens 8 Zeichen lang sein", "components.ResetPassword.validationpasswordrequired": "Du musst ein Passwort angeben", "components.Search.search": "Suchen", "components.Search.searchresults": "Suchergebnisse", @@ -428,37 +428,25 @@ "components.Settings.Notifications.NotificationsGotify.validationTypes": "Es muss mindestens eine Benachrichtigungsart ausgewählt werden", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "Es muss eine gültige URL angegeben werden", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL darf nicht mit einem abschließenden Schrägstrich enden", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Dienst aktivieren", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profil Name", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Wird nur benötigt wenn default Profil nicht verwendet wird", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea Benachrichtigungseinstellungen konnten nicht gespeichert werden.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea Benachrichtigungseinstellungen wurden gespeichert!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea Test Benachrichtigung gesendet!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Sie müssen mindestens einen Benachrichtigungstypen auswählen", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Geben sie eine gültige URL an", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Deine Benutzer oder Geräte basierende Benachrichtigungs-Webhook URL", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Zugangstoken", - "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Erstellen Sie einen Token in Ihren Account Einstellungen", + "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Erstelle ein Token in deinen Kontoeinstellungen", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Agent aktivieren", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "Channel Tag", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Pushbullet-Benachrichtigungseinstellungen konnten nicht gespeichert werden.", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "Pushbullet-Benachrichtigungseinstellungen erfolgreich gespeichert!", - "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Pushbullet Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Pushbullet Test Benachrichtigung gesendet!", + "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Pushbullet Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Pushbullet Testbenachrichtigung gesendet!", "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "Du musst ein Zugangstoken angeben", - "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Sie müssen mindestens einen Benachrichtigungstypen auswählen", + "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Es muss mindestens ein Benachrichtigungstyp ausgewählt sein", "components.Settings.Notifications.NotificationsPushover.accessToken": "Anwendungs API-Token", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registriere eine Anwendung , um diese mit Jellyseerr benutzen zu können", "components.Settings.Notifications.NotificationsPushover.agentenabled": "Agent aktivieren", "components.Settings.Notifications.NotificationsPushover.pushoversettingsfailed": "Pushover-Benachrichtigungseinstellungen konnten nicht gespeichert werden.", "components.Settings.Notifications.NotificationsPushover.pushoversettingssaved": "Pushover-Benachrichtigungseinstellungen erfolgreich gespeichert!", - "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Pushover Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSending": "Pushover Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Pushover Test Benachrichtigung gesendet!", + "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Pushover Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSending": "Pushover Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Pushover Testbenachrichtigung gesendet!", "components.Settings.Notifications.NotificationsPushover.userToken": "Benutzer- oder Gruppenschlüssel", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Ihr 30-stelliger Nutzer oder Gruppen Identifikator", "components.Settings.Notifications.NotificationsPushover.validationAccessTokenRequired": "Du musst ein gültiges Anwendungstoken angeben", @@ -467,18 +455,18 @@ "components.Settings.Notifications.NotificationsSlack.agentenabled": "Agent aktivieren", "components.Settings.Notifications.NotificationsSlack.slacksettingsfailed": "Slack-Benachrichtigungseinstellungen konnten nicht gespeichert werden.", "components.Settings.Notifications.NotificationsSlack.slacksettingssaved": "Slack-Benachrichtigungseinstellungen erfolgreich gespeichert!", - "components.Settings.Notifications.NotificationsSlack.toastSlackTestFailed": "Slack Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.NotificationsSlack.toastSlackTestSending": "Slack Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.NotificationsSlack.toastSlackTestSuccess": "Slack Test Benachrichtigung gesendet!", + "components.Settings.Notifications.NotificationsSlack.toastSlackTestFailed": "Slack Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.NotificationsSlack.toastSlackTestSending": "Slack Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.NotificationsSlack.toastSlackTestSuccess": "Slack Testbenachrichtigung gesendet!", "components.Settings.Notifications.NotificationsSlack.validationTypes": "Du musst mindestens einen Benachrichtigungstypen auswählen", "components.Settings.Notifications.NotificationsSlack.validationWebhookUrl": "Du musst eine gültige URL angeben", "components.Settings.Notifications.NotificationsSlack.webhookUrl": "Webhook URL", "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "Erstelle eine Eingehende Webhook integration", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Agent aktivieren", "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "Jellyseerr muss via HTTPS bereitgestellt werden, um Web-Push Benachrichtigungen empfangen zu können.", - "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestFailed": "Web push Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "Web push Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "Web push Test Benachrichtigung gesendet!", + "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestFailed": "Web push Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "Web push Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "Web push Testbenachrichtigung gesendet!", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Web push Benachrichtigungseinstellungen konnten nicht gespeichert werden.", "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Web push Benachrichtigungseinstellungen erfolgreich gespeichert!", "components.Settings.Notifications.NotificationsWebhook.agentenabled": "Dienst aktivieren", @@ -487,9 +475,9 @@ "components.Settings.Notifications.NotificationsWebhook.resetPayload": "Auf Standard zurücksetzen", "components.Settings.Notifications.NotificationsWebhook.resetPayloadSuccess": "JSON-Inhalt erfolgreich zurückgesetzt!", "components.Settings.Notifications.NotificationsWebhook.templatevariablehelp": "Hilfe zu Vorlagenvariablen", - "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestFailed": "Webhook Test Benachrichtigung konnte nicht gesendet werden.", - "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSending": "Webhook Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSuccess": "Webhook Test Benachrichtigung gesendet!", + "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestFailed": "Webhook Testbenachrichtigung konnte nicht gesendet werden.", + "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSending": "Webhook Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSuccess": "Webhook Testbenachrichtigung gesendet!", "components.Settings.Notifications.NotificationsWebhook.validationJsonPayloadRequired": "Du musst einen gültigen JSON-Inhalt angeben", "components.Settings.Notifications.NotificationsWebhook.validationTypes": "Du musst mindestens einen Benachrichtigungstypen auswählen", "components.Settings.Notifications.NotificationsWebhook.validationWebhookUrl": "Du musst eine gültige URL angeben", @@ -523,22 +511,22 @@ "components.Settings.Notifications.pgpPasswordTip": "Signiere verschlüsselte E-Mail-Nachrichten mit OpenPGP", "components.Settings.Notifications.pgpPrivateKey": "PGP Privater Schlüssel", "components.Settings.Notifications.pgpPrivateKeyTip": "Signiere verschlüsselte E-Mail-Nachrichten mit OpenPGP", - "components.Settings.Notifications.sendSilently": "Sende stumm", + "components.Settings.Notifications.sendSilently": "Lautlos senden", "components.Settings.Notifications.sendSilentlyTip": "Sende Benachrichtigungen ohne Ton", "components.Settings.Notifications.senderName": "Absendername", "components.Settings.Notifications.smtpHost": "SMTP-Host", "components.Settings.Notifications.smtpPort": "SMTP-Port", "components.Settings.Notifications.telegramsettingsfailed": "Telegram-Benachrichtigungseinstellungen konnten nicht gespeichert werden.", "components.Settings.Notifications.telegramsettingssaved": "Telegram-Benachrichtigungseinstellungen erfolgreich gespeichert!", - "components.Settings.Notifications.toastDiscordTestFailed": "Discord Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.toastDiscordTestSending": "Discord Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.toastDiscordTestSuccess": "Discord Test Benachrichtigung gesendet!", - "components.Settings.Notifications.toastEmailTestFailed": "E-Mail Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.toastEmailTestSending": "Email Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.toastEmailTestSuccess": "Email Test Benachrichtigung gesendet!", - "components.Settings.Notifications.toastTelegramTestFailed": "Telegram Test Benachrichtigung fehlgeschlagen.", - "components.Settings.Notifications.toastTelegramTestSending": "Telegram Test Benachrichtigung wird gesendet…", - "components.Settings.Notifications.toastTelegramTestSuccess": "Telegram Test Benachrichtigung gesendet!", + "components.Settings.Notifications.toastDiscordTestFailed": "Discord Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.toastDiscordTestSending": "Discord Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.toastDiscordTestSuccess": "Discord Testbenachrichtigung gesendet!", + "components.Settings.Notifications.toastEmailTestFailed": "E-Mail Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.toastEmailTestSending": "Email Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.toastEmailTestSuccess": "Email Testbenachrichtigung gesendet!", + "components.Settings.Notifications.toastTelegramTestFailed": "Telegram Testbenachrichtigung fehlgeschlagen.", + "components.Settings.Notifications.toastTelegramTestSending": "Telegram Testbenachrichtigung wird gesendet…", + "components.Settings.Notifications.toastTelegramTestSuccess": "Telegram Testbenachrichtigung gesendet!", "components.Settings.Notifications.validationBotAPIRequired": "Du musst ein Bot-Autorisierungstoken angeben", "components.Settings.Notifications.validationChatIdRequired": "Du musst eine gültige Chat-ID angeben", "components.Settings.Notifications.validationEmail": "Du musst eine gültige E-Mail-Adresse angeben", @@ -579,13 +567,13 @@ "components.Settings.RadarrModal.selecttags": "Tags auswählen", "components.Settings.RadarrModal.server4k": "4K-Server", "components.Settings.RadarrModal.servername": "Servername", - "components.Settings.RadarrModal.ssl": "SSL aktivieren", + "components.Settings.RadarrModal.ssl": "SSL verwenden", "components.Settings.RadarrModal.syncEnabled": "Scannen aktivieren", "components.Settings.RadarrModal.tags": "Tags", "components.Settings.RadarrModal.testFirstQualityProfiles": "Teste die Verbindung, um Qualitätsprofile zu laden", "components.Settings.RadarrModal.testFirstRootFolders": "Teste die Verbindung, um Stammordner zu laden", - "components.Settings.RadarrModal.testFirstTags": "Teste Verbindung, um Tags zu laden", - "components.Settings.RadarrModal.toastRadarrTestFailure": "Verbindung zu Radarr fehlgeschlagen.", + "components.Settings.RadarrModal.testFirstTags": "Teste die Verbindung, um Tags zu laden", + "components.Settings.RadarrModal.toastRadarrTestFailure": "Die Verbindung zu Radarr fehlgeschlagen.", "components.Settings.RadarrModal.toastRadarrTestSuccess": "Radarr-Verbindung erfolgreich hergestellt!", "components.Settings.RadarrModal.validationApiKeyRequired": "Du musst einen API-Schlüssel angeben", "components.Settings.RadarrModal.validationApplicationUrl": "Du musst eine gültige URL angeben", @@ -607,7 +595,7 @@ "components.Settings.SettingsAbout.Releases.viewongithub": "Auf GitHub anzeigen", "components.Settings.SettingsAbout.about": "Über", "components.Settings.SettingsAbout.appDataPath": "Datenverzeichnis", - "components.Settings.SettingsAbout.betawarning": "Das ist eine BETA Software. Einige Funktionen könnten nicht richtig/stabil funktionieren. Bitte sämtliche Fehler auf GitHub melden!", + "components.Settings.SettingsAbout.betawarning": "BETA-Software: Funktionen können fehlerhaft oder instabil sein. Probleme bitte auf GitHub melden!", "components.Settings.SettingsAbout.documentation": "Dokumentation", "components.Settings.SettingsAbout.gettingsupport": "Hilfe erhalten", "components.Settings.SettingsAbout.githubdiscussions": "GitHub-Diskussionen", @@ -615,8 +603,8 @@ "components.Settings.SettingsAbout.outofdate": "Veraltet", "components.Settings.SettingsAbout.overseerrinformation": "Über Jellyseerr", "components.Settings.SettingsAbout.preferredmethod": "Bevorzugt", - "components.Settings.SettingsAbout.runningDevelop": "Sie benutzen den Branchdevelop von Jellyseerr, welcher nur für Entwickler, bzw. \"Bleeding-Edge\" Tests empfohlen wird.", - "components.Settings.SettingsAbout.supportoverseerr": "Unterstütze Overseerr", + "components.Settings.SettingsAbout.runningDevelop": "Es wird der develop-Branch von Jellyseerr verwendet, der nur für Mitwirkende an der Entwicklung oder für Tests der neuesten Funktionen empfohlen wird.", + "components.Settings.SettingsAbout.supportoverseerr": "Overseerr unterstützen", "components.Settings.SettingsAbout.timezone": "Zeitzone", "components.Settings.SettingsAbout.totalmedia": "Medien insgesamt", "components.Settings.SettingsAbout.totalrequests": "Anfragen insgesamt", @@ -729,14 +717,14 @@ "components.Settings.SonarrModal.selecttags": "Wähle Tags", "components.Settings.SonarrModal.server4k": "4K-Server", "components.Settings.SonarrModal.servername": "Servername", - "components.Settings.SonarrModal.ssl": "SSL aktivieren", + "components.Settings.SonarrModal.ssl": "SSL verwenden", "components.Settings.SonarrModal.syncEnabled": "Scannen aktivieren", "components.Settings.SonarrModal.tags": "Tags", "components.Settings.SonarrModal.testFirstLanguageProfiles": "Teste die Verbindung zum Laden von Sprachprofilen", "components.Settings.SonarrModal.testFirstQualityProfiles": "Teste die Verbindung, um Qualitätsprofile zu laden", "components.Settings.SonarrModal.testFirstRootFolders": "Teste die Verbindung, um Stammordner zu laden", - "components.Settings.SonarrModal.testFirstTags": "Teste Verbindung, um Tags zu laden", - "components.Settings.SonarrModal.toastSonarrTestFailure": "Verbindung zu Sonarr fehlgeschlagen.", + "components.Settings.SonarrModal.testFirstTags": "Teste die Verbindung, um Tags zu laden", + "components.Settings.SonarrModal.toastSonarrTestFailure": "Die Verbindung zu Sonarr ist fehlgeschlagen.", "components.Settings.SonarrModal.toastSonarrTestSuccess": "Sonarr-Verbindung erfolgreich hergestellt!", "components.Settings.SonarrModal.validationApiKeyRequired": "Du musst einen API-Schlüssel angeben", "components.Settings.SonarrModal.validationApplicationUrl": "Du musst eine gültige URL angeben", @@ -755,14 +743,13 @@ "components.Settings.addsonarr": "Sonarr Server hinzufügen", "components.Settings.advancedTooltip": "Bei falscher Konfiguration dieser Einstellung, kann dies zu einer Funktionsstörung führen", "components.Settings.cancelscan": "Durchsuchung abbrechen", - "components.Settings.copied": "API-Schlüssel in die Zwischenablage kopiert.", "components.Settings.currentlibrary": "Aktuelle Bibliothek: {name}", "components.Settings.default": "Standardmäßig", "components.Settings.default4k": "Standard-4K", "components.Settings.deleteServer": "{serverType} Server löschen", "components.Settings.deleteserverconfirm": "Bist du sicher, dass du diesen Server löschen möchtest?", "components.Settings.email": "E-Mail", - "components.Settings.enablessl": "SSL aktivieren", + "components.Settings.enablessl": "SSL verwenden", "components.Settings.experimentalTooltip": "Die Aktivierung dieser Einstellung kann zu einem unerwarteten Verhalten der Anwendung führen", "components.Settings.externalUrl": "Externe URL", "components.Settings.hostname": "Hostname oder IP-Adresse", @@ -853,16 +840,16 @@ "components.StatusChecker.restartRequiredDescription": "Starte bitte den Server neu, um die aktualisierten Einstellungen zu übernehmen.", "components.TitleCard.cleardata": "Daten löschen", "components.TitleCard.mediaerror": "{mediaType} wurde nicht gefunden", - "components.TitleCard.tmdbid": "TMDB-ID", + "components.TitleCard.tmdbid": "TMDB ID", "components.TitleCard.tvdbid": "TheTVDB-ID", - "components.TvDetails.Season.noepisodes": "Liste der Episoden nicht verfügbar.", + "components.TvDetails.Season.noepisodes": "Liste der Folgen nicht verfügbar.", "components.TvDetails.Season.somethingwentwrong": "Beim Datenabruf der Staffel ist etwas schief gelaufen.", "components.TvDetails.TvCast.fullseriescast": "Komplette Serien Besetzung", "components.TvDetails.TvCrew.fullseriescrew": "Komplette Serien-Crew", "components.TvDetails.anime": "Anime", "components.TvDetails.cast": "Besetzung", - "components.TvDetails.episodeCount": "{episodeCount, plural, one {# Episode} other {# Episoden}}", - "components.TvDetails.episodeRuntime": "Episodenlaufzeit", + "components.TvDetails.episodeCount": "{episodeCount, plural, one {# Folge} other {# Folgen}}", + "components.TvDetails.episodeRuntime": "Laufzeit der Folge", "components.TvDetails.episodeRuntimeMinutes": "{runtime} Minuten", "components.TvDetails.firstAirDate": "Erstausstrahlung", "components.TvDetails.manageseries": "Serie verwalten", @@ -872,11 +859,11 @@ "components.TvDetails.originaltitle": "Originaltitel", "components.TvDetails.overview": "Übersicht", "components.TvDetails.overviewunavailable": "Übersicht nicht verfügbar.", - "components.TvDetails.productioncountries": "Produktions {countryCount, plural, one {Land} other {Länder}}", + "components.TvDetails.productioncountries": "Produktions{countryCount, plural, one {land} other {länder}}", "components.TvDetails.recommendations": "Empfehlungen", "components.TvDetails.reportissue": "Problem melden", - "components.TvDetails.rtaudiencescore": "Rotten Tomatoes Publikumswertung", - "components.TvDetails.rtcriticsscore": "Rotten Tomatoes Tomatometer", + "components.TvDetails.rtaudiencescore": "Rotten Tomatoes - Nutzerwertung", + "components.TvDetails.rtcriticsscore": "Rotten Tomatoes - Tomatometer", "components.TvDetails.seasonnumber": "Staffel {seasonNumber}", "components.TvDetails.seasons": "{seasonCount, plural, one {# Staffel} other {# Staffeln}}", "components.TvDetails.seasonstitle": "Staffeln", @@ -884,7 +871,7 @@ "components.TvDetails.similar": "Ähnliche Serien", "components.TvDetails.status4k": "4K {status}", "components.TvDetails.streamingproviders": "Streamt derzeit auf", - "components.TvDetails.tmdbuserscore": "TMDB-Nutzerwertung", + "components.TvDetails.tmdbuserscore": "TMDB - Nutzerwertung", "components.TvDetails.viewfullcrew": "Komplette Crew anzeigen", "components.TvDetails.watchtrailer": "Trailer ansehen", "components.UserList.accounttype": "Art", @@ -898,8 +885,8 @@ "components.UserList.creating": "Erstelle…", "components.UserList.deleteconfirm": "Möchtest du diesen Benutzer wirklich löschen? Alle seine Anfragendaten werden dauerhaft entfernt.", "components.UserList.deleteuser": "Benutzer löschen", - "components.UserList.edituser": "Benutzerberechtigungen Bearbeiten", - "components.UserList.email": "E-Mail Adresse", + "components.UserList.edituser": "Benutzerberechtigungen bearbeiten", + "components.UserList.email": "E-Mail-Adresse", "components.UserList.importedfromplex": "{userCount} Plex {userCount, Plural, one {Benutzer} other {Benutzer}} erfolgreich importiert!", "components.UserList.importfrommediaserver": "{mediaServerName}-Benutzer importieren", "components.UserList.importfromplex": "Plex Benutzer importieren", @@ -933,7 +920,7 @@ "components.UserProfile.UserSettings.UserPermissions.toastSettingsSuccess": "Berechtigungen erfolgreich gespeichert!", "components.UserProfile.UserSettings.UserPermissions.toastSettingsFailure": "Beim Speichern der Einstellungen ist etwas schief gelaufen.", "components.UserProfile.UserSettings.UserPermissions.permissions": "Berechtigungen", - "components.UserProfile.UserSettings.UserPasswordChange.validationNewPasswordLength": "Passwort ist zu kurz; es sollte mindestens 8 Zeichen lang sein", + "components.UserProfile.UserSettings.UserPasswordChange.validationNewPasswordLength": "Das Passwort ist zu kurz, es sollte mindestens 8 Zeichen lang sein", "components.UserProfile.UserSettings.UserPasswordChange.validationNewPassword": "Du musst ein neues Passwort angeben", "components.UserProfile.UserSettings.UserPasswordChange.validationCurrentPassword": "Du musst dein aktuelles Passwort angeben", "components.UserProfile.UserSettings.UserPasswordChange.validationConfirmPasswordSame": "Das Passwort muss übereinstimmen", @@ -961,7 +948,7 @@ "components.UserProfile.UserSettings.UserGeneralSettings.region": "Region Entdecken", "components.UserProfile.UserSettings.UserGeneralSettings.originallanguageTip": "Filtere Inhalte nach Originalsprache", "components.UserProfile.UserSettings.UserGeneralSettings.originallanguage": "Sprache des Bereiches \"Entdecken\"", - "components.UserProfile.UserSettings.UserPasswordChange.nopermissionDescription": "Sie haben keine Berechtigung, das Kennwort dieses Benutzers zu ändern.", + "components.UserProfile.UserSettings.UserPasswordChange.nopermissionDescription": "Es besteht keine Berechtigung, das Passwort dieses Benutzers zu ändern.", "components.UserProfile.UserSettings.UserGeneralSettings.user": "Benutzer", "components.UserProfile.UserSettings.UserGeneralSettings.role": "Rolle", "components.UserProfile.UserSettings.UserGeneralSettings.owner": "Besitzer", @@ -1001,7 +988,7 @@ "i18n.requesting": "Anfordern…", "i18n.request4k": "In 4K anfragen", "i18n.previous": "Zurück", - "i18n.notrequested": "Nicht Angefragt", + "i18n.notrequested": "Nicht angefragt", "i18n.noresults": "Keine Ergebnisse.", "i18n.next": "Weiter", "i18n.movie": "Film", @@ -1063,12 +1050,12 @@ "components.UserProfile.emptywatchlist": "Hier erscheinen deine zur Plex Merkliste hinzugefügte Medien.", "components.UserProfile.plexwatchlist": "Plex Merkliste", "components.Discover.DiscoverTvKeyword.keywordSeries": "{keywordTitle} Serien", - "components.Discover.moviegenres": "Film Genre", + "components.Discover.moviegenres": "Film-Genres", "components.Discover.studios": "Studios", - "components.Discover.tmdbmoviegenre": "TMDB Film Genre", - "components.Discover.tmdbtvgenre": "TMDB Serien Genre", + "components.Discover.tmdbmoviegenre": "TMDB Film-Genre", + "components.Discover.tmdbtvgenre": "TMDB Serien-Genre", "components.Discover.tmdbtvkeyword": "TMDB Serien Stichwort", - "components.Discover.tvgenres": "Serien Genre", + "components.Discover.tvgenres": "Serien-Genres", "components.Settings.SettingsMain.apikey": "API-Schlüssel", "components.Settings.SettingsMain.applicationTitle": "Anwendungstitel", "components.Settings.SettingsMain.general": "Allgemein", @@ -1083,11 +1070,11 @@ "components.Discover.tmdbsearch": "TMDB Suche", "components.Settings.SettingsMain.toastApiKeyFailure": "Etwas ist schiefgelaufen während der Generierung eines neuen API Schlüssels.", "components.Settings.SettingsMain.toastSettingsSuccess": "Einstellungen erfolgreich gespeichert!", - "components.Discover.tmdbmoviekeyword": "TMDB Film Stichwort", + "components.Discover.tmdbmoviekeyword": "TMDB Film-Stichwort", "components.Settings.SettingsMain.validationApplicationTitle": "Du musst einen Anwendungstitel angeben", "components.Discover.PlexWatchlistSlider.emptywatchlist": "Medien in deiner Plex Merkliste erscheinen hier.", "components.Settings.SettingsMain.cacheImagesTip": "Cache extern gehostete Bilder (erfordert eine beträchtliche Menge an Speicherplatz)", - "components.Discover.networks": "Sender", + "components.Discover.networks": "Dienste", "components.Discover.tmdbstudio": "TMDB Studio", "components.Settings.SettingsMain.applicationurl": "Anwendung URL", "components.Settings.SettingsMain.cacheImages": "Bild-Caching aktivieren", @@ -1095,27 +1082,27 @@ "components.Settings.SettingsMain.originallanguage": "Sprache des Bereiches \"Entdecken\"", "components.Settings.SettingsMain.partialRequestsEnabled": "Teilweise Serienanfragen zulassen", "components.Settings.SettingsMain.toastSettingsFailure": "Beim Speichern der Einstellungen ist ein Fehler aufgetreten.", - "components.Discover.tmdbnetwork": "TMDB Sender", + "components.Discover.tmdbnetwork": "TMDB Netzwerk", "components.Settings.SettingsMain.originallanguageTip": "Inhalt nach Originalsprache filtern", - "components.Discover.CreateSlider.addSlider": "Slider hinzufügen", - "components.Discover.CreateSlider.addcustomslider": "Benutzerdefinierten Slider erstellen", - "components.Discover.CreateSlider.addfail": "Neuer Slider konnte nicht erstellt werden.", - "components.Discover.CreateSlider.addsuccess": "Ein neuer Slider wurde erstellt und die Einstellungen wurden gespeichert.", - "components.Discover.CreateSlider.editSlider": "Slider bearbeiten", - "components.Discover.CreateSlider.editfail": "Slider konnte nicht bearbeitet werden.", - "components.Discover.CreateSlider.editsuccess": "Slider bearbeitet und Einstellung gespeichert.", + "components.Discover.CreateSlider.addSlider": "Schieberegler hinzufügen", + "components.Discover.CreateSlider.addcustomslider": "Benutzerdefinierten Schieberegler erstellen", + "components.Discover.CreateSlider.addfail": "Neuer Schieberegler konnte nicht erstellt werden.", + "components.Discover.CreateSlider.addsuccess": "Ein neuer Schieberegler wurde erstellt und die Einstellungen wurden gespeichert.", + "components.Discover.CreateSlider.editSlider": "Schieberegler bearbeiten", + "components.Discover.CreateSlider.editfail": "Schieberegler konnte nicht bearbeitet werden.", + "components.Discover.CreateSlider.editsuccess": "Schieberegler bearbeitet und Einstellung gespeichert.", "components.Discover.CreateSlider.needresults": "Es muss mindestens 1 Ergebnis vorhanden sein.", "components.Layout.Sidebar.browsemovies": "Filme", "components.Layout.Sidebar.browsetv": "Serien", "components.Discover.CreateSlider.nooptions": "Keine Ergebnisse.", "components.Discover.CreateSlider.providetmdbgenreid": "Hinterlege eine TMDB Genre ID", - "components.Discover.CreateSlider.providetmdbkeywordid": "Hinterlege eine TMDB Keyword ID", + "components.Discover.CreateSlider.providetmdbkeywordid": "Hinterlege eine TMDB Schlüsselwort ID", "components.Discover.CreateSlider.providetmdbnetwork": "Hinterlege eine TMDB Netzwerk ID", - "components.Discover.CreateSlider.providetmdbsearch": "Geben Sie eine Suchanfrage an", + "components.Discover.CreateSlider.providetmdbsearch": "Gib eine Suchanfrage ein", "components.Discover.CreateSlider.validationTitlerequired": "Du musst einen Titel eingeben.", "components.Discover.DiscoverSliderEdit.remove": "Entfernen", - "components.Discover.DiscoverSliderEdit.deletefail": "Slider konnte nicht gelöscht werden.", - "components.Discover.DiscoverSliderEdit.deletesuccess": "Slider erfolgreich entfernt.", + "components.Discover.DiscoverSliderEdit.deletefail": "Schieberegler konnte nicht gelöscht werden.", + "components.Discover.DiscoverSliderEdit.deletesuccess": "Schieberegler erfolgreich entfernt.", "components.Discover.DiscoverMovies.discovermovies": "Filme", "components.Discover.DiscoverMovies.sortReleaseDateAsc": "Erscheinungsdatum (aufsteigend)", "components.Discover.DiscoverMovies.sortReleaseDateDesc": "Erscheinungsdatum (absteigend)", @@ -1126,9 +1113,9 @@ "components.Discover.DiscoverTv.sortFirstAirDateAsc": "Erstausstrahlung (aufsteigend)", "components.Discover.DiscoverTv.sortPopularityAsc": "Beliebtheit (aufsteigend)", "components.Discover.DiscoverTv.sortPopularityDesc": "Beliebtheit (absteigend)", - "components.Discover.CreateSlider.slidernameplaceholder": "Name des Slider", + "components.Discover.CreateSlider.slidernameplaceholder": "Name des Schiebereglers", "components.Settings.SettingsJobsCache.availability-sync": "Medienverfügbarkeit Sync", - "components.Discover.FilterSlideover.activefilters": "{count, plural, one {# Aktiver Filter} other {# Aktive Filter}}", + "components.Discover.FilterSlideover.activefilters": "{count, plural, one {# aktiver Filter} other {# aktive Filter}}", "components.Discover.FilterSlideover.originalLanguage": "Originalsprache", "components.Settings.SettingsJobsCache.editJobScheduleSelectorSeconds": "Alle {jobScheduleSeconds, plural, one {Sekunde} other {{jobScheduleSeconds} Sekunden}}", "components.Discover.updatefailed": "Bei der Aktualisierung der Entdecken-Einstellungen ist ein Fehler aufgetreten.", @@ -1149,50 +1136,50 @@ "components.Discover.resetsuccess": "Die Entdecken-Einstellungen wurden erfolgreich zurückgesetzt.", "components.Discover.stopediting": "Bearbeitung stoppen", "components.Discover.resettodefault": "Zurücksetzen auf Standard", - "components.Discover.resetwarning": "Setzt alle Slider auf die Standardwerte zurück. Dadurch werden auch alle benutzerdefinierten Slider gelöscht!", - "components.Discover.DiscoverMovies.activefilters": "{count, plural, one {# Aktiver Filter} other {# Aktive Filter}}", + "components.Discover.resetwarning": "Setzt alle Schieberegler auf die Standardwerte zurück. Dadurch werden auch alle benutzerdefinierten Schieberegler gelöscht!", + "components.Discover.DiscoverMovies.activefilters": "{count, plural, one {# aktiver Filter} other {# aktive Filter}}", "components.Discover.DiscoverMovies.sortPopularityAsc": "Beliebtheit (aufsteigend)", "components.Discover.DiscoverMovies.sortPopularityDesc": "Beliebtheit (absteigend)", - "components.Discover.DiscoverMovies.sortTmdbRatingAsc": "TMDB-Bewertung (aufsteigend)", - "components.Discover.DiscoverMovies.sortTmdbRatingDesc": "TMDB-Bewertung (absteigend)", - "components.Discover.DiscoverTv.activefilters": "{count, plural, one {# Aktiver Filter} other {# Aktive Filter}}", + "components.Discover.DiscoverMovies.sortTmdbRatingAsc": "TMDB Bewertung (aufsteigend)", + "components.Discover.DiscoverMovies.sortTmdbRatingDesc": "TMDB Bewertung (absteigend)", + "components.Discover.DiscoverTv.activefilters": "{count, plural, one {# aktiver Filter} other {# aktive Filter}}", "components.Discover.DiscoverTv.sortTitleAsc": "Titel (A-Z) (aufsteigend)", "components.Discover.DiscoverTv.sortTitleDesc": "Titel (Z-A) (absteigend)", - "components.Discover.DiscoverTv.sortTmdbRatingAsc": "TMDB-Bewertung (aufsteigend)", - "components.Discover.DiscoverTv.sortTmdbRatingDesc": "TMDB-Bewertung (absteigend)", + "components.Discover.DiscoverTv.sortTmdbRatingAsc": "TMDB Bewertung (aufsteigend)", + "components.Discover.DiscoverTv.sortTmdbRatingDesc": "TMDB Bewertung (absteigend)", "components.Discover.FilterSlideover.clearfilters": "Aktive Filter löschen", "components.Discover.FilterSlideover.filters": "Filter", "components.Discover.FilterSlideover.firstAirDate": "Datum der Erstausstrahlung", - "components.Discover.FilterSlideover.from": "Vom", + "components.Discover.FilterSlideover.from": "Von", "components.Discover.FilterSlideover.genres": "Genres", "components.Discover.FilterSlideover.keywords": "Stichwörter", "components.Discover.FilterSlideover.ratingText": "Bewertungen zwischen {minValue} und {maxValue}", "components.Discover.FilterSlideover.releaseDate": "Erscheinungsdatum", "components.Discover.FilterSlideover.runtime": "Laufzeit", "components.Discover.FilterSlideover.runtimeText": "{minValue}-{maxValue} Minuten Laufzeit", - "components.Discover.FilterSlideover.tmdbuserscore": "TMDB-Benutzerbewertung", + "components.Discover.FilterSlideover.tmdbuserscore": "TMDB - Nutzerwertung", "components.Discover.FilterSlideover.to": "Bis", - "components.Discover.createnewslider": "Neuen Slider erstellen", + "components.Discover.createnewslider": "Neuen Schieberegler erstellen", "components.Discover.FilterSlideover.studio": "Studio", - "components.Discover.FilterSlideover.streamingservices": "Streaming-Dienste", + "components.Discover.FilterSlideover.streamingservices": "Streamingdienste", "components.Selector.nooptions": "Keine Ergebnisse.", "components.Selector.searchKeywords": "Stichwörter suchen…", "components.Selector.searchStudios": "Studios suchen…", - "components.Discover.tmdbmoviestreamingservices": "TMDB Film-Streaming-Dienste", - "components.Discover.tmdbtvstreamingservices": "TMDB TV-Streaming-Dienste", + "components.Discover.tmdbmoviestreamingservices": "TMDB Film-Streamingdienste", + "components.Discover.tmdbtvstreamingservices": "TMDB TV-Streamingdienste", "i18n.collection": "Sammlung", - "components.Discover.FilterSlideover.tmdbuservotecount": "Anzahl an TMDB-Benutzerbewertungen", + "components.Discover.FilterSlideover.tmdbuservotecount": "Anzahl der TMDB-Nutzerwertungen", "components.Settings.RadarrModal.tagRequestsInfo": "Füge automatisch ein Tag hinzu mit der ID und dem Namen des anfordernden Nutzers", - "components.MovieDetails.imdbuserscore": "IMDB Nutzer Bewertung", + "components.MovieDetails.imdbuserscore": "IMDb - Nutzerwertung", "components.Settings.SonarrModal.tagRequests": "Tag Anforderungen", - "components.Discover.FilterSlideover.voteCount": "Anzahl Abstimmungen zwischen {minValue} und {maxValue}", + "components.Discover.FilterSlideover.voteCount": "Anzahl der Abstimmungen zwischen {minValue} und {maxValue}", "components.Settings.SonarrModal.tagRequestsInfo": "Füge automatisch einen zusätzlichen Tag mit der ID & Namen des anfordernden Nutzers", "components.Layout.UserWarnings.passwordRequired": "Ein Passwort ist erforderlich.", "components.Login.description": "Da du dich zum ersten Mal bei {applicationName} anmeldest, musst du eine gültige E-Mail-Adresse angeben.", - "components.Layout.UserWarnings.emailRequired": "E-Mail Adresse ist erforderlich.", - "components.Layout.UserWarnings.emailInvalid": "E-Mail Adresse ist nicht gültig.", + "components.Layout.UserWarnings.emailRequired": "Eine E-Mail-Adresse ist erforderlich.", + "components.Layout.UserWarnings.emailInvalid": "Die E-Mail-Adresse ist ungültig.", "components.Login.credentialerror": "Der Benutzername oder das Passwort ist falsch.", - "components.Login.emailtooltip": "Die Adresse muss nicht mit Ihrer {mediaServerName}-Instanz verbunden sein.", + "components.Login.emailtooltip": "Die Adresse muss nicht mit deiner {mediaServerName}-Instanz verbunden sein.", "components.Login.initialsignin": "Verbinde", "components.Login.initialsigningin": "Verbinden…", "components.Login.save": "Hinzufügen", @@ -1200,9 +1187,9 @@ "components.Login.signinwithjellyfin": "Verwende dein {mediaServerName} Konto", "components.Login.title": "E-Mail hinzufügen", "components.Login.username": "Benutzername", - "components.Login.validationEmailFormat": "Ungültige E-Mail", - "components.Login.validationEmailRequired": "Du musst eine E-Mail angeben", - "components.Login.validationemailformat": "Gültige E-Mail erforderlich", + "components.Login.validationEmailFormat": "Ungültige E-Mail-Adresse", + "components.Login.validationEmailRequired": "Du musst eine E-Mail-Adresse angeben", + "components.Login.validationemailformat": "Gültige E-Mail-Adresse erforderlich", "components.Login.validationhostformat": "Gültige URL erforderlich", "components.Login.validationhostrequired": "{mediaServerName} URL erforderlich", "components.Login.validationusernamerequired": "Benutzername erforderlich", @@ -1210,7 +1197,7 @@ "components.ManageSlideOver.removearr4k": "Aus 4K {arr} entfernen", "components.MovieDetails.downloadstatus": "Download-Status", "components.MovieDetails.openradarr4k": "Film in 4K Radarr öffnen", - "components.MovieDetails.play": "Wiedergabe auf {mediaServerName}", + "components.MovieDetails.play": "Auf {mediaServerName} wiedergeben", "components.MovieDetails.play4k": "4K abspielen auf {mediaServerName}", "components.Settings.SonarrModal.animeSeriesType": "Anime-Serien Typ", "components.Settings.jellyfinSettings": "{mediaServerName} Einstellungen", @@ -1229,7 +1216,7 @@ "components.TitleCard.watchlistDeleted": "{title} Erfolgreich aus der Merkliste entfernt!", "components.TitleCard.watchlistError": "Ein Fehler ist aufgetreten. Bitte versuche es erneut.", "components.TitleCard.watchlistSuccess": "{title} erfolgreich zur Merkliste hinzugefügt!", - "components.TvDetails.play": "Wiedergabe auf {mediaServerName}", + "components.TvDetails.play": "Auf {mediaServerName} wiedergeben", "components.TvDetails.play4k": "4K abspielen auf {mediaServerName}", "components.UserList.importfromJellyfin": "Importieren von {mediaServerName} Benutzern", "components.UserList.mediaServerUser": "{mediaServerName} Benutzer", @@ -1240,7 +1227,6 @@ "components.UserProfile.UserSettings.UserGeneralSettings.email": "E-Mail", "components.UserProfile.UserSettings.UserGeneralSettings.mediaServerUser": "{mediaServerName} Benutzer", "components.UserProfile.UserSettings.UserGeneralSettings.saving": "Speichern…", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Web-Push-Benachrichtigungseinstellungen erfolgreich gespeichert!", "i18n.close": "Schließen", "i18n.decline": "Ablehnen", "i18n.declined": "Abgelehnt", @@ -1250,7 +1236,7 @@ "i18n.movies": "Filme", "i18n.open": "Offen", "i18n.pending": "Ausstehend", - "i18n.processing": "Verarbeitung", + "i18n.processing": "Verarbeiten", "i18n.request": "Anfrage senden", "i18n.requested": "Angefragt", "i18n.retry": "Wiederholen", @@ -1280,32 +1266,30 @@ "components.UserList.usercreatedsuccess": "Benutzer erfolgreich angelegt!", "components.ManageSlideOver.manageModalRemoveMediaWarning": "* Dadurch wird dieser {mediaType} unwiderruflich aus {arr} entfernt, einschließlich aller Dateien.", "components.UserList.importedfromJellyfin": "{userCount} {mediaServerName} {userCount, plural, one {Benutzer} other {Benutzer}} erfolgreich importiert!", - "components.UserList.validationpasswordminchars": "Das Passwort ist zu kurz; es sollte mindestens 8 Zeichen lang sein", + "components.UserList.validationpasswordminchars": "Das Passwort ist zu kurz, es sollte mindestens 8 Zeichen lang sein", "components.UserProfile.UserSettings.UserNotificationSettings.deviceDefault": "Gerätestandard", "i18n.approve": "Genehmigen", "i18n.partiallyavailable": "Teilweise verfügbar", "components.UserList.newJellyfinsigninenabled": "Die Einstellung Aktiviere neuen {mediaServerName} Sign-In ist derzeit aktiviert. {mediaServerName}-Benutzer mit Bibliothekszugang müssen nicht importiert werden, um sich anmelden zu können.", "components.UserProfile.UserSettings.UserNotificationSettings.sound": "Benachrichtigungston", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Die Einstellungen für Web-Push-Benachrichtigungen konnten nicht gespeichert werden.", "components.UserProfile.localWatchlist": "Merkliste von {username}", "i18n.approved": "Genehmigt", "pages.returnHome": "Zurück zur Startseite", "components.Discover.FilterSlideover.status": "Status", "components.UserList.username": "Benutzername", - "components.Login.adminerror": "Du musst einen Adminaccount für den Zugang benutzen.", - "components.MovieDetails.watchlistError": "Es ist ein Fehler aufgetreten. Bitte versuchen Sie es erneut.", + "components.Login.adminerror": "Für die Anmeldung ist ein Administratorkonto erforderlich.", + "components.MovieDetails.watchlistError": "Es ist ein Fehler aufgetreten. Bitte erneut versuchen.", "components.RequestList.RequestItem.profileName": "Profil", "components.Selector.searchStatus": "Status auswählen...", "components.Settings.invalidurlerror": "Es kann keine Verbindung zu {mediaServerName} hergestellt werden.", "components.Settings.jellyfinSyncFailedGenericError": "Es trat ein unbekannter Fehler während der Bibliothekssynchronisation auf", "components.UserList.validationUsername": "Du musst einen Benutzernamen angeben", - "components.UserProfile.UserSettings.UserGeneralSettings.validationemailrequired": "E-Mail Adresse benötigt", + "components.UserProfile.UserSettings.UserGeneralSettings.validationemailrequired": "E-Mail-Adresse benötigt", "components.Login.invalidurlerror": "Es kann keine Verbindung zu {mediaServerName} hergestellt werden.", "components.MovieDetails.removefromwatchlist": "Von der Merkliste entfernen", "components.TvDetails.watchlistDeleted": "{title} erfolgreich aus der Merkliste entfernt!", "components.Login.back": "Zurück", "components.Login.servertype": "Servertyp", - "components.Login.validationHostnameRequired": "Du musst eine gültige IP-Adresse oder einen gültigen Hostnamen angeben", "components.Login.validationPortRequired": "Du musst einen gültigen Port angeben", "components.Login.validationUrlBaseLeadingSlash": "Der URL muss ein Slash vorangestellt sein", "components.Login.validationUrlBaseTrailingSlash": "Die URL-Basis darf nicht auf einem Slash enden", @@ -1332,7 +1316,7 @@ "components.TvDetails.removefromwatchlist": "Von der Merkliste entfernen", "components.TvDetails.watchlistError": "Ein Fehler ist aufgetreten. Bitte versuche es erneut.", "components.TvDetails.watchlistSuccess": "{title} erfolgreich zur Merkliste hinzugefügt!", - "components.UserProfile.UserSettings.UserGeneralSettings.validationemailformat": "Gültige E-Mail Adresse benötigt", + "components.UserProfile.UserSettings.UserGeneralSettings.validationemailformat": "Gültige E-Mail-Adresse benötigt", "components.Login.hostname": "{mediaServerName} URL", "components.Login.port": "Port", "components.Login.urlBase": "URL-Basis", @@ -1340,20 +1324,20 @@ "components.Settings.jellyfinForgotPasswordUrl": "Passwort vergessen URL", "components.Settings.jellyfinSyncFailedAutomaticGroupedFolders": "Eine benutzerdefinierte Authentifizierung mit automatischer Bibliotheksbündelung wird nicht unterstützt", "components.Settings.jellyfinSyncFailedNoLibrariesFound": "Es wurden keine Bibliotheken gefunden", - "components.Settings.scanbackground": "Der Scanvorgang wird im Hintergrund ausgeführt. Sie können in der Zwischenzeit den Einrichtungsprozess fortsetzen.", + "components.Settings.scanbackground": "Der Scan läuft im Hintergrund. Die Einrichtung kann in der Zwischenzeit fortgesetzt werden.", "components.Blacklist.blacklistdate": "Datum", "components.PermissionEdit.viewblacklistedItems": "Medien auf der Sperrliste anzeigen.", - "components.Settings.SettingsMain.discoverRegion": "Region entdecken", + "components.Settings.SettingsMain.discoverRegion": "Region für \"Entdecken\"", "components.Blacklist.blacklistNotFoundError": "{title} ist nicht auf der Sperrliste.", "components.PermissionEdit.manageblacklist": "Sperrliste verwalten", "components.Settings.SettingsJobsCache.plex-refresh-token": "Plex Refresh Token", - "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegion": "Region entdecken", + "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegion": "Region für \"Entdecken\"", "i18n.blacklistDuplicateError": "{title} wurde bereits auf die Sperrliste gesetzt.", "components.Settings.Notifications.validationWebhookRoleId": "Du musst eine gültige Discord Rollen-ID angeben", "components.Settings.Notifications.webhookRoleIdTip": "Die Rollen ID, die in der Webhook Nachricht erwähnt werden soll. Leer lassen, um Erwähnungen zu deaktivieren", "i18n.addToBlacklist": "Zur Sperrliste hinzufügen", "components.PermissionEdit.blacklistedItemsDescription": "Autorisierung zum Sperren von Medien.", - "components.Settings.SettingsMain.streamingRegion": "Streaming Region", + "components.Settings.SettingsMain.streamingRegion": "Region des Streamings", "i18n.removeFromBlacklistSuccess": "{title} wurde erfolgreich von der Sperrliste entfernt.", "components.UserProfile.UserSettings.UserGeneralSettings.streamingRegion": "Streaming Region", "components.UserProfile.UserSettings.UserGeneralSettings.streamingRegionTip": "Streaming Seiten nach regionaler Verfügbarkeit anzeigen", @@ -1379,8 +1363,8 @@ "components.Settings.apiKey": "API-Schlüssel", "components.Settings.tip": "Tipp", "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegionTip": "Inhalte nach regionaler Verfügbarkeit filtern", - "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmail": "Diese E-Mail ist bereits vergeben!", - "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmailEmpty": "Ein anderer Benutzer hat bereits diesen Benutzernamen. Sie müssen eine E-Mail festlegen", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmail": "Diese E-Mail-Adresse ist bereits vergeben!", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmailEmpty": "Dieser Benutzername ist bereits vergeben. Eine E-Mail-Adresse muss angegeben werden", "i18n.blacklist": "Sperrliste", "i18n.blacklistError": "Etwas ist schief gelaufen, versuche es noch einmal.", "i18n.blacklistSuccess": "{title} wurde erfolgreich auf die Sperrliste gesetzt.", @@ -1393,20 +1377,20 @@ "components.Settings.OverrideRuleModal.rootfolder": "Stammverzeichnis", "components.UserProfile.UserSettings.menuLinkedAccounts": "Verknüpfte Konten", "components.UserProfile.UserSettings.UserLinkedAccountsSettings.deleteFailed": "Verknüpftes Konto kann nicht gelöscht werden.", - "components.UserProfile.UserSettings.LinkJellyfinModal.usernameRequired": "Sie müssen einen Benutzernamen angeben", + "components.UserProfile.UserSettings.LinkJellyfinModal.usernameRequired": "Es muss ein Benutzername eingegeben werden", "components.Setup.librarieserror": "Validierung fehlgeschlagen. Bitte schalte die Bibliotheken erneut um, um fortzufahren.", "components.Settings.SettingsNetwork.proxyBypassFilterTip": "Verwende ',' als Trennzeichen und '*.' als Platzhalter für Subdomains", "components.Settings.OverrideRuleModal.settingsDescription": "Gibt an, welche Einstellungen geändert werden, wenn die oben genannten Bedingungen erfüllt sind.", "components.Settings.SettingsUsers.mediaServerLogin": "Aktiviere {mediaServerName} Anmeldung", "components.UserProfile.UserSettings.UserLinkedAccountsSettings.plexErrorExists": "Dieses Konto ist bereits mit einem Plex Benutzer verknüpft", - "components.UserProfile.UserSettings.LinkJellyfinModal.description": "Geben Sie Ihre {mediaServerName}-Anmeldeinformationen ein, um Ihr Konto mit {applicationName} zu verknüpfen.", - "components.Settings.SettingsNetwork.networkDisclaimer": "Anstelle dieser Einstellungen sollten Netzwerkparameter aus Ihrem Container/System verwendet werden. Weitere Informationen finden Sie in den {docs}.", + "components.UserProfile.UserSettings.LinkJellyfinModal.description": "Anmeldedaten von {mediaServerName} eingeben, um das Konto mit {applicationName} zu verbinden.", + "components.Settings.SettingsNetwork.networkDisclaimer": "Netzwerkparameter des Containers bzw. Systems sollten statt dieser Einstellungen verwendet werden. Weitere Informationen in den {docs}.", "components.Selector.searchUsers": "Benutzer auswählen…", "components.Settings.overrideRules": "Override-Regeln", "components.Settings.Notifications.messageThreadId": "Thread-/Themen-ID", "components.Settings.OverrideRuleModal.conditions": "Bedingungen", "components.Settings.OverrideRuleTile.settings": "Einstellungen", - "components.Login.noadminerror": "Kein Admin-Benutzer auf dem Server gefunden.", + "components.Login.noadminerror": "Auf dem Server wurde kein Administrator gefunden.", "components.UserProfile.UserSettings.UserLinkedAccountsSettings.plexErrorUnauthorized": "Mit Ihren Anmeldeinformationen kann keine Verbindung zu Plex hergestellt werden", "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnknown": "Ein unbekannter Fehler ist aufgetreten", "components.Settings.addrule": "Neue Override-Regel", @@ -1435,15 +1419,14 @@ "components.Settings.OverrideRuleModal.settings": "Einstellungen", "components.Settings.OverrideRuleModal.serviceDescription": "Wende diese Regel auf den ausgewählten Dienst an.", "components.Settings.OverrideRuleModal.service": "Dienst", - "components.Settings.SettingsMain.enableSpecialEpisodes": "Anfragen zu Spezial-Episoden zulassen", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Erweiterte Netzwerkeinstellungen", - "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "Aktivieren Sie diese Einstellung NICHT, wenn Sie nicht wissen, was Sie tun!", + "components.Settings.SettingsMain.enableSpecialEpisodes": "Anfragen zu Spezial-Folgen zulassen", + "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "Diese Einstellung nur aktivieren, wenn die Auswirkungen bekannt sind!", "components.Settings.SettingsNetwork.docs": "Dokumentation/Hilfe", "components.Settings.SettingsNetwork.networksettings": "Netzwerkeinstellungen", "components.Settings.SettingsNetwork.networksettingsDescription": "Konfiguriere die Netzwerkeinstellungen deiner Jellyseerr-Instanz.", "components.Settings.SettingsNetwork.toastSettingsSuccess": "Einstellungen erfolgreich gespeichert!", "components.Settings.SettingsNetwork.trustProxy": "Aktiviere Proxy-Unterstützung", - "components.Settings.SettingsNetwork.validationProxyPort": "Sie müssen einen gültigen Port angeben", + "components.Settings.SettingsNetwork.validationProxyPort": "Es muss ein gültiger Port eingetragen werden", "components.Settings.SettingsUsers.atLeastOneAuth": "Es muss mindestens eine Authentifizierungsmethode ausgewählt werden.", "components.Settings.SettingsUsers.loginMethods": "Anmeldemethoden", "components.Settings.SettingsUsers.loginMethodsTip": "Anmeldemethoden für Benutzer konfigurieren.", @@ -1466,12 +1449,12 @@ "components.UserProfile.UserSettings.LinkJellyfinModal.username": "Benutzername", "components.UserProfile.UserSettings.LinkJellyfinModal.title": "{mediaServerName}-Konto verknüpfen", "components.UserProfile.UserSettings.LinkJellyfinModal.saving": "Hinzufügen…", - "components.UserProfile.UserSettings.LinkJellyfinModal.passwordRequired": "Sie müssen ein Passwort angeben", + "components.UserProfile.UserSettings.LinkJellyfinModal.passwordRequired": "Es muss ein Passwort eingegeben werden", "components.UserProfile.UserSettings.LinkJellyfinModal.password": "Passwort", "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnauthorized": "Mit Ihren Anmeldeinformationen kann keine Verbindung zu {mediaServerName} hergestellt werden", "components.UserProfile.UserSettings.LinkJellyfinModal.errorExists": "Dieses Konto ist bereits mit einem {applicationName}-Benutzer verknüpft", - "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noPermissionDescription": "Sie sind nicht berechtigt, die verknüpften Konten dieses Benutzers zu ändern.", - "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noLinkedAccounts": "Sie haben keine externen Konten mit Ihrem Konto verknüpft.", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noPermissionDescription": "Es besteht keine Berechtigung, die verknüpften Konten dieses Benutzers zu bearbeiten.", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noLinkedAccounts": "Es sind keine externen Konten mit deinem Account verknüpft.", "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccountsHint": "Diese externen Konten sind mit Ihrem {applicationName}-Konto verknüpft.", "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccounts": "Verknüpfte Konten", "components.UserProfile.UserSettings.UserLinkedAccountsSettings.errorUnknown": "Ein unbekannter Fehler ist aufgetreten", diff --git a/src/i18n/locale/el.json b/src/i18n/locale/el.json index 07992d23ef..62402cac0d 100644 --- a/src/i18n/locale/el.json +++ b/src/i18n/locale/el.json @@ -110,16 +110,6 @@ "components.Discover.recentrequests": "Πρόσφατα Αιτήματα", "components.Discover.recentlyAdded": "Προστέθηκαν πρόσφατα", "components.Discover.populartv": "Δημοφιλείς Σειρές", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Πρέπει να βάλεις μια έγκυρη διεύθυνση URL", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Η δοκιμαστική ειδοποίηση LunaSea εστάλη!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Αποστολή δοκιμαστικής ειδοποίησης LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Αποτυχία αποστολής δοκιμαστικής ειδοποίησης LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Οι ρυθμίσεις ειδοποιήσεων LunaSea αποθηκεύτηκαν με επιτυχία!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Οι ρυθμίσεις των ειδοποιήσεων LunaSea δεν κατάφεραν να αποθηκευτούν.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Χρειάζεται μόνο εφόσον δεν χρησιμοποιείται το default προφίλ", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Όνομα Προφίλ", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Ενεργοποίηση του Μεταφορέα", "components.Search.searchresults": "Αποτελέσματα αναζήτησης", "components.Search.search": "Αναζήτηση", "components.ResetPassword.validationpasswordrequired": "Πρέπει να βάλεις έναν κωδικό πρόσβασης", @@ -516,8 +506,6 @@ "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Νέος κωδικός πρόσβασης", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Τρέχων κωδικός πρόσβασης", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Επιβεβαίωση κωδικού πρόσβασης", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Οι ρυθμίσεις των ειδοποιήσεων push αποθηκεύτηκαν επιτυχώς!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Οι ρυθμίσεις των ειδοποιήσεων push δεν κατάφεραν να αποθηκευτούν.", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Πρέπει να δώσεις ένα έγκυρο αναγνωριστικό συνομιλίας", "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "Πρέπει να βάλεις ένα έγκυρο δημόσιο κλειδί PGP", @@ -693,7 +681,6 @@ "components.Settings.default4k": "Προεπιλεγμένο 4K", "components.Settings.default": "Προκαθορισμένο", "components.Settings.currentlibrary": "Τρέχουσα βιβλιοθήκη: {name}", - "components.Settings.copied": "Αντιγράφηκε το κλειδί API στο πρόχειρο.", "components.Settings.cancelscan": "Ακύρωση σάρωσης", "components.Settings.addsonarr": "Προσθήκη διακομιστή Sonarr", "components.Settings.address": "Διεύθυνση", @@ -761,7 +748,6 @@ "components.Settings.SettingsUsers.newPlexLogin": "Ενεργοποίηση νέας σύνδεσης {mediaServerName}", "components.Settings.SettingsJobsCache.jobsDescription": "Το Jellyseerr εκτελεί ορισμένες εργασίες συντήρησης ως τακτικά προγραμματισμένες εργασίες, αλλά μπορούν επίσης να ενεργοποιηθούν χειροκίνητα παρακάτω. Η χειροκίνητη εκτέλεση μιας εργασίας δεν θα αλλάξει το χρονοδιάγραμμα του.", "components.Settings.Notifications.NotificationsWebhook.templatevariablehelp": "Template Variable Help", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Ο χρήστης σου ή η συσκευή ειδοποίηση webhook URL", "components.RequestModal.numberofepisodes": "# Αριθμός Επεισοδίων", "components.MovieDetails.studio": "{studioCount, plural, one {Στούντιο} other {Στούντιο}}", "components.Layout.VersionStatus.commitsbehind": "{commitsBehind} {commitsBehind, plural, one {commit} other {commits}} πίσω", @@ -962,7 +948,6 @@ "components.Selector.showmore": "Εμφάνιση περισσότερων", "components.Selector.starttyping": "Αρχίστε να πληκτρολογείτε για αναζήτηση.", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSending": "Αποστολή δοκιμαστικής ειδοποίησης Gotify…", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Πρέπει να επιλέξετε τουλάχιστον έναν τύπο ειδοποιήσεων", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "Ετικέτα καναλιού", "components.Settings.RadarrModal.announced": "Ανακοινώθηκε", "components.Settings.RadarrModal.inCinemas": "Στους Κινηματογράφους", diff --git a/src/i18n/locale/es.json b/src/i18n/locale/es.json index f053bab715..ed087d8ae6 100644 --- a/src/i18n/locale/es.json +++ b/src/i18n/locale/es.json @@ -174,7 +174,6 @@ "components.Settings.default4k": "4K predeterminado", "components.Settings.default": "Predeterminado", "components.Settings.currentlibrary": "Biblioteca actual: {name}", - "components.Settings.copied": "Clave API copiada en el portapapeles.", "components.Settings.cancelscan": "Cancelar Escaneo", "i18n.deleting": "Eliminando…", "components.UserList.userdeleteerror": "Algo salió mal al eliminar al usuario.", @@ -707,8 +706,6 @@ "components.Settings.RadarrModal.enableSearch": "Habilitar Búsqueda Automática", "components.RequestModal.edit": "Editar Solicitud", "components.RequestList.RequestItem.editrequest": "Editar Solicitud", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "¡Ajustes de notificacion de Web Push guardados con éxito!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Fallo al guardar los ajustes de notificaciones de Web Push.", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", "components.UserProfile.UserSettings.UserGeneralSettings.applanguage": "Mostrar Idioma", "components.Settings.webpush": "Web Push", @@ -743,22 +740,11 @@ "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "¡Notificación de prueba de Pushbullet enviada!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Enviando notificación de prueba de Pushbullet…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Fallo al enviar notificación de prueba de Pushbullet.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL del Webhook", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Debes indicar una URL válida", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "¡Notificación de LunaSea enviada!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Enviando notificación de prueba de LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Fallo al enviar la notificación de prueba de LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "¡Los ajustes de notificación se han guardado con éxito!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Fallo al guardar los ajustes de notificación de LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Requerido solo si no se usa el perfil por default", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nombre de Perfil", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Habilitar Agente", "components.PermissionEdit.requestTvDescription": "Conceder permisos para solicitar series que no sean 4k.", "components.PermissionEdit.requestTv": "Solicitar Series", "components.PermissionEdit.requestMoviesDescription": "Conceder permisos para solicitar películas que no sean 4K.", "components.PermissionEdit.requestMovies": "Solicitar películas", "components.Settings.SettingsAbout.betawarning": "¡Este es un software BETA. Algunas funcionalidades podrían fallar. Por favor, reporta cualquier problema en Github!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Debes seleccionar, al menos, un tipo de notificacion", "components.RequestList.RequestItem.requesteddate": "Solicitado", "components.RequestCard.failedretry": "Algo fue mal al reintentar la solicitud.", "components.NotificationTypeSelector.usermediarequestedDescription": "Notificar cuando otros usuarios envíen nuevas solicitudes que requieran aprobación.", @@ -782,7 +768,6 @@ "components.Settings.Notifications.encryption": "Método de Encriptación", "components.Settings.Notifications.encryptionDefault": "Usa STARTTLS si está disponible", "components.Settings.Notifications.encryptionNone": "Ninguna", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Tu URL del webhook de notificación basado en tu usuario o dispositivo", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Crea un token desde tu Opciones de Cuenta", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registrar una aplicación para su uso con Jellyseerr", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Tu identificador de usuario o grupo de 30 caracteres", @@ -1305,7 +1290,6 @@ "components.Login.noadminerror": "No se ha encontrado un usuario administrativo en el servidor.", "components.Login.orsigninwith": "O inicia sesión con", "components.Login.port": "Puerto", - "components.Login.validationHostnameRequired": "Debes proveer un nombre de host o dirección IP válida", "components.Login.validationPortRequired": "Debes proveer un número de puerto válido", "components.Blacklist.blacklistSettingsDescription": "Gestionar contenido en la lista negra.", "components.Blacklist.blacklistdate": "Fecha", diff --git a/src/i18n/locale/es_MX.json b/src/i18n/locale/es_MX.json index 7435704116..b93490c6e1 100644 --- a/src/i18n/locale/es_MX.json +++ b/src/i18n/locale/es_MX.json @@ -174,7 +174,6 @@ "components.Settings.default4k": "4K predeterminado", "components.Settings.default": "Predeterminado", "components.Settings.currentlibrary": "Biblioteca actual: {name}", - "components.Settings.copied": "Clave API copiada en el portapapeles.", "components.Settings.cancelscan": "Cancelar Escaneo", "i18n.deleting": "Eliminando…", "components.UserList.userdeleteerror": "Algo salió mal al eliminar al usuario.", @@ -707,8 +706,6 @@ "components.Settings.RadarrModal.enableSearch": "Habilitar Búsqueda Automática", "components.RequestModal.edit": "Editar Solicitud", "components.RequestList.RequestItem.editrequest": "Editar Solicitud", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "¡Ajustes de notificacion de Web Push guardados con éxito!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Fallo al guardar los ajustes de notificaciones de Web Push.", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", "components.UserProfile.UserSettings.UserGeneralSettings.applanguage": "Mostrar Idioma", "components.Settings.webpush": "Web Push", @@ -743,22 +740,11 @@ "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "¡Notificación de prueba de Pushbullet enviada!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Enviando notificación de prueba de Pushbullet…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Fallo al enviar notificación de prueba de Pushbullet.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL del Webhook", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Debes indicar una URL válida", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "¡Notificación de LunaSea enviada!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Enviando notificación de prueba de LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Fallo al enviar la notificación de prueba de LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "¡Los ajustes de notificación se han guardado con éxito!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Fallo al guardar los ajustes de notificación de LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Requerido solo si no se usa el perfil por default", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nombre de Perfil", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Habilitar Agente", "components.PermissionEdit.requestTvDescription": "Conceder permisos para solicitar series que no sean 4k.", "components.PermissionEdit.requestTv": "Solicitar Series", "components.PermissionEdit.requestMoviesDescription": "Conceder permisos para solicitar películas que no sean 4K.", "components.PermissionEdit.requestMovies": "Solicitar películas", "components.Settings.SettingsAbout.betawarning": "¡Este es un software BETA. Algunas funcionalidades podrían fallar. Por favor, reporta cualquier problema en Github!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Debes seleccionar, al menos, un tipo de notificacion", "components.RequestList.RequestItem.requesteddate": "Solicitado", "components.RequestCard.failedretry": "Algo fue mal al reintentar la solicitud.", "components.NotificationTypeSelector.usermediarequestedDescription": "Notificar cuando otros usuarios envíen nuevas solicitudes que requieran aprobación.", @@ -782,7 +768,6 @@ "components.Settings.Notifications.encryption": "Método de Encriptación", "components.Settings.Notifications.encryptionDefault": "Usa STARTTLS si está disponible", "components.Settings.Notifications.encryptionNone": "Ninguna", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Tu URL del webhook de notificación basado en tu usuario o dispositivo", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Crea un token desde tu Opciones de Cuenta", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registrar una aplicación para su uso con Jellyseerr", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Tu identificador de usuario o grupo de 30 caracteres", diff --git a/src/i18n/locale/eu.json b/src/i18n/locale/eu.json index 144133bf75..996277ce18 100644 --- a/src/i18n/locale/eu.json +++ b/src/i18n/locale/eu.json @@ -495,7 +495,6 @@ "components.IssueDetails.IssueComment.areyousuredelete": "Ziur zaude iruzkin hau ezabatu nahi duzula?", "components.IssueDetails.deleteissueconfirm": "Ziur zaude intzidentzia hau ezabatu nahi duzula?", "components.Login.adminerror": "Administratzaile kontu bat erabili behar duzu saioa hasteko.", - "components.Login.validationHostnameRequired": "Baliozko ostalari-izen edo IP helbide bat eman behar duzu", "components.Login.validationUrlBaseTrailingSlash": "URLa ez du amaierako barra batean amaitu behar", "components.NotificationTypeSelector.adminissuereopenedDescription": "Jakinarazi beste erabiltzaile batzuek intzidentziak berriro irekitzen dituztenean.", "components.NotificationTypeSelector.adminissueresolvedDescription": "Jakinarazi beste erabiltzaile batzuek intzidentziak konpontzen dituztenean.", @@ -643,7 +642,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationDiscordId": "Baliozko erabiltzaile ID bat eman behar duzu", "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverApplicationToken": "Baliozko aplikazio token bat eman behar duzu", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Baliozko txat ID bat eman behar duzu", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Web push jakinarazpenen ezarpenak gordetzeak huts egin du.", "components.UserProfile.UserSettings.UserPasswordChange.toastSettingsFailure": "Zerbait gaizki joan da pasahitza gordetzean.", "i18n.removeFromBlacklistSuccess": "{title} zerrenda beltzetik ondo kendu da.", "i18n.showingresults": "{total}(e)tik {from}(e)tik {to}(e)ra emaitza erakusten", @@ -652,17 +650,11 @@ "components.IssueDetails.toastissuedeletefailed": "Zerbait gaizki joan da intzidentzia ezabatzean.", "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncseriestip": "Automatikoki eskatu zure Plex jarraipen zerrendan dauden telesailak", "components.Settings.Notifications.NotificationsGotify.validationTypes": "Gutxienez jakinarazpen mota bat aukeratu behar duzu", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Ez da beharrezkoa profil lehenetsia erabiltzen ari bazara", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Gutxienez jakinarazpen mota bat aukeratu behar duzu", "components.RequestModal.QuotaDisplay.movielimit": "{limit, plural, one {film} other {film}}", "components.RequestModal.requestadmin": "Eskaera hau automatikoki onartuko da.", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestFailed": "Gotify proba jakinarazpena bidaltzeak huts egin du.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea proba jakinarazpena bidaltzeak huts egin du.", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Baliozko URL bat eman behar duzu", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Pushbullet jakinarazpen ezarpenak gordetzeak huts egin du.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Zure erabiltzaile edo gailuan oinarritutako jakinarazpen WebHook URLa", "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "Aplikazio token bat eman behar duzu", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea jakinarazpen ezarpenak gordetzeak huts egin du.", "components.UserProfile.UserSettings.UserNotificationSettings.pushoverApplicationTokenTip": "Erregistratu aplikazio bat {applicationTitle}-(r)ekin erabiltzeko", "components.Blacklist.blacklistNotFoundError": "{title} ez dago zerrenda beltzean.", "components.Blacklist.blacklistSettingsDescription": "Kudeatu zerrenda beltzean dagoen multimedia.", @@ -868,8 +860,6 @@ "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "Gotify proba jakinarazpena bidalita!", "components.Settings.Notifications.NotificationsGotify.token": "Aplikazioaren tokena", "components.Settings.Notifications.NotificationsGotify.url": "Zerbitzariaren URLa", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Gaitu agentea", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URLa", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Sarbide tokena", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "Kanalaren etiketa", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Pushbullet proba jakinarazpena bidaltzen…", @@ -1105,7 +1095,6 @@ "components.Settings.SonarrModal.validationRootFolderRequired": "Erro karpeta bat hautatu behar duzu", "components.Settings.SonarrModal.testFirstTags": "Probatu konexioa etiketak kargatzeko", "components.Settings.SonarrModal.toastSonarrTestFailure": "Sonarr-era konektatzeak huts egin du.", - "components.Settings.copied": "API gakoa arbelera kopiatuta.", "components.Settings.hostname": "Ostalari-izena edo IP helbidea", "components.Settings.addradarr": "Gehitu Radarr zerbitzaria", "components.Settings.addsonarr": "Gehitu Sonarr zerbitzaria", @@ -1300,7 +1289,6 @@ "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Uneko pasahitza", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Pasahitz berria", "components.UserProfile.UserSettings.UserNotificationSettings.telegramsettingssaved": "Telegram jakinarazpenen ezarpenak ondo gorde dira!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Web push jakinarazpen ezarpenak ondo gorde dira!", "components.UserProfile.UserSettings.UserPasswordChange.toastSettingsSuccess": "Pasahitza ondo gorde da!", "components.UserProfile.UserSettings.UserPermissions.toastSettingsFailure": "Zerbait gaizki joan da ezarpenak gordetzean.", "components.UserProfile.UserSettings.UserPermissions.unauthorizedDescription": "Ezin dituzu zure baimenak aldatu.", @@ -1348,7 +1336,6 @@ "components.RequestModal.QuotaDisplay.notenoughseasonrequests": "Ez dituzu denboraldi nahiko eskaerarik", "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "Sortu Sarrera Webhook integrazio bat", "components.Discover.CreateSlider.providetmdbstudio": "Eman TMDB estudioaren IDa", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea proba jakinarazpena bidalita!", "components.Discover.DiscoverTv.sortTmdbRatingAsc": "TMDB puntuazioa gorantz", "components.Settings.RadarrModal.selectMinimumAvailability": "Hautatu gutxieneko erabilgarritasuna", "components.Settings.SonarrModal.editsonarr": "Editatu Sonarr zerbitzaria", @@ -1361,7 +1348,6 @@ "components.Selector.searchGenres": "Hautatu generoak…", "components.Selector.searchStatus": "Hautatu egoera...", "components.Selector.showless": "Erakutsi gutxiago", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profilaren izena", "components.Settings.RadarrModal.rootfolder": "Erro karpeta", "components.IssueDetails.toasteditdescriptionsuccess": "Intzidentziaren deskribapena ondo editatu da!", "components.RequestModal.requestedited": "{title}-(e)rako eskaera ondo editatu da!", @@ -1370,7 +1356,6 @@ "components.RequestModal.requestApproved": "{title} eskaera onartuta!", "components.RequestModal.requestseries4ktitle": "Eskatu telesaila 4K-n", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSending": "Gotify proba jakinarazpena bidaltzen…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea proba jakinarazpena bidaltzen…", "components.Settings.RadarrModal.hostname": "Ostalari-izena edo IP helbidea", "components.Discover.DiscoverTv.sortTmdbRatingDesc": "TMDB puntuazioa beherantz", "components.TvDetails.addtowatchlist": "Gehitu jarraipen zerrendara", @@ -1386,7 +1371,6 @@ "components.Settings.SettingsMain.toastApiKeySuccess": "API gako berria ondo sortu da!", "components.TvDetails.episodeRuntime": "Atalaren iraupena", "components.Settings.Notifications.NotificationsGotify.gotifysettingssaved": "Gotify jakinarazpenen ezarpenak ondo gorde dira!", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea jakinarazpenen ezarpenak ondo gorde dira!", "components.Settings.OverrideRuleModal.qualityprofile": "Kalitate profila", "components.Settings.OverrideRuleModal.selectRootFolder": "Hautatu erro-karpeta", "components.DiscoverTvUpcoming.upcomingtv": "Hurrengo telesailak", @@ -1428,7 +1412,6 @@ "components.Settings.SettingsNetwork.forceIpv4First": "Behartu IPv4 ebazpena lehen", "components.Settings.OverrideRuleModal.editrule": "Editatu gainidazte araua", "components.Settings.OverrideRuleModal.selectQualityProfile": "Hautatu kalitate profila", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Sare ezarpen aurreratuak", "components.Settings.SettingsNetwork.csrfProtection": "Gaitu CSRF babesa", "components.Settings.OverrideRuleModal.create": "Sortu araua", "components.Settings.OverrideRuleModal.notagoptions": "Etiketarik ez.", diff --git a/src/i18n/locale/fi.json b/src/i18n/locale/fi.json index 83f5cec094..9de03ea5a9 100644 --- a/src/i18n/locale/fi.json +++ b/src/i18n/locale/fi.json @@ -72,7 +72,7 @@ "components.Blacklist.blacklistsettings": "Estämisen Asetukset", "components.Blacklist.mediaName": "Nimi", "components.Blacklist.mediaType": "Tyyppi", - "components.Blacklist.mediaTmdbId": "", + "components.Blacklist.mediaTmdbId": "tmdb Id", "components.Discover.DiscoverMovies.sortReleaseDateAsc": "Julkaisupäivä nousevassa järjestyksessä", "components.Discover.DiscoverMovies.sortTitleAsc": "Otsikko (A-Z) nousevassa järjestyksessä", "components.Discover.DiscoverMovies.sortTitleDesc": "Otsikko (A-Z) laskevassa järjestyksessä", @@ -129,7 +129,7 @@ "components.Discover.popularmovies": "Suositut Elokuvat", "components.Discover.populartv": "Suositut Sarjat", "components.Discover.recentlyAdded": "Viimeksi Lisätty", - "components.Discover.recentrequests": "Viimeksi Pyydetty", + "components.Discover.recentrequests": "Viimeaikaiset pyynnöt", "components.Discover.resetsuccess": "Tutustumisen mukautusasetukset tyhjennetty.", "components.Discover.resettodefault": "Palauta Oletusasetukset", "components.Discover.resetwarning": "Palauta liukusäätimet. Tämä poistaa myös mukautetut säätimet!", @@ -192,8 +192,8 @@ "components.IssueList.IssueItem.viewissue": "Näytä ongelma", "components.IssueList.issues": "Ongelmat", "components.IssueList.showallissues": "Näytä kaikki ongelmat", - "components.IssueList.sortAdded": "Viimeisin lisätty", - "components.IssueList.sortModified": "Viimeisin muokattu", + "components.IssueList.sortAdded": "Uusin", + "components.IssueList.sortModified": "Viimeksi muokattu", "components.IssueModal.CreateIssueModal.allepisodes": "Kaikki jaksot", "components.IssueModal.CreateIssueModal.allseasons": "Kaikki kaudet", "components.IssueModal.CreateIssueModal.extras": "Ekstrat", @@ -245,5 +245,277 @@ "i18n.requesting": "Pyydetään…", "i18n.requested": "Pyydetty", "i18n.request4k": "Pyydä 4K:na", - "i18n.request": "Pyydä" + "i18n.request": "Pyydä", + "components.DiscoverTvUpcoming.upcomingtv": "Tulossa olevat sarjat", + "components.ManageSlideOver.manageModalRequests": "Pyynnöt", + "i18n.usersettings": "Käyttäjäasetukset", + "i18n.view": "Näytä", + "i18n.save": "Tallenna muutokset", + "i18n.unavailable": "Ei saatavilla", + "i18n.tvshows": "Sarjat", + "i18n.tvshow": "Sarja", + "i18n.testing": "Kokeillaan…", + "i18n.test": "Kokeile", + "i18n.status": "Tila", + "i18n.specials": "Erikoisjaksot", + "i18n.settings": "Asetukset", + "i18n.saving": "Tallennetaan…", + "i18n.movies": "Elokuvat", + "components.MovieDetails.addtowatchlist": "Lisää katselulistalle", + "i18n.loading": "Ladataan…", + "i18n.available": "Saatavilla", + "components.UserProfile.recentrequests": "Viimeaikaiset pyynnöt", + "i18n.cancel": "Peruuta", + "i18n.blacklist": "Estolista", + "components.Discover.DiscoverTv.activefilters": "{count, plural, one {# Aktiivinen suodatin} other {# Aktiivista suodatinta}}", + "components.Discover.DiscoverMovies.activefilters": "{count, plural, one {# Aktiivinen suodatin} other {# Aktiivista suodatinta}}", + "components.MovieDetails.overviewunavailable": "Yhteenveto ei saatavilla.", + "components.Login.signingin": "Kirjaudutaan sisään…", + "components.MovieDetails.digitalrelease": "Digitaalinen julkaisu", + "components.Login.description": "Koska tämä on ensimmäinen kirjautumisesi sovellukseen {applicationName}, sinun täytyy lisätä toimiva sähköpostiosoite.", + "components.Login.noadminerror": "Järjestelmänvalvojan käyttäjää ei löytynyt palvelimelta.", + "components.Login.username": "Käyttäjänimi", + "components.ManageSlideOver.manageModalClearMediaWarning": "* Tämä poistaa peruuttamattomasti kaikki tämän {mediaType}-kohteen tiedot, mukaan lukien kaikki pyynnöt. Jos tämä kohde on {mediaServerName}-kirjastossasi, mediatiedot luodaan uudelleen seuraavan skannauksen aikana.", + "components.ManageSlideOver.manageModalAdvanced": "Lisäasetukset", + "components.Login.password": "Salasana", + "components.Login.port": "Portti", + "components.Login.save": "Lisää", + "components.Login.saving": "Lisätään…", + "components.Login.servertype": "Palvelimen tyyppi", + "components.Login.signin": "Kirjaudu sisään", + "components.Login.signinheader": "Kirjaudu sisään jatkaaksesi", + "components.Login.email": "Sähköpostiosoite", + "components.Login.emailtooltip": "Osoitteen ei tarvitse olla liitettynä {mediaServerName}-instanssiisi.", + "components.Login.enablessl": "Käytä SSL", + "components.Login.forgotpassword": "Unohtuiko salasana?", + "components.Login.hostname": "{mediaServerName} URL-osoite", + "components.Login.initialsignin": "Yhdistä", + "components.Login.initialsigningin": "Yhdistetään…", + "components.Login.invalidurlerror": "Yhdistäminen palvelimeen {mediaServerName} ei onnistunut.", + "components.Login.loginerror": "Jotain meni pieleen kirjautumisessa.", + "components.Login.loginwithapp": "Kirjaudu sisään sovelluksella {appName}", + "components.Login.orsigninwith": "Tai kirjaudu sisään käyttäen", + "components.Login.signinwithjellyfin": "Käytä palvelimesi {mediaServerName} tiliä", + "components.Login.signinwithoverseerr": "Käytä {applicationTitle}-tiliä", + "components.Login.signinwithplex": "Käytä Plex-tiliäsi", + "components.Login.title": "Lisää sähköposti", + "components.ManageSlideOver.downloadstatus": "Lataukset", + "components.ManageSlideOver.manageModalMedia": "Media", + "components.ManageSlideOver.manageModalNoRequests": "Ei pyyntöjä.", + "components.ManageSlideOver.markavailable": "Merkitse saatavilla", + "components.ManageSlideOver.openarr": "Avaa ohjelmassa {arr}", + "components.ManageSlideOver.openarr4k": "Avaa ohjelmassa 4K {arr}", + "components.ManageSlideOver.opentautulli": "Avaa Tautullissa", + "components.ManageSlideOver.playedby": "Toistanut", + "components.ManageSlideOver.tvshow": "sarja", + "components.MediaSlider.ShowMoreCard.seemore": "Näytä lisää", + "components.Login.urlBase": "URL-osoitteen pohja", + "components.Login.validationEmailFormat": "Virheellinen sähköposti", + "components.Login.validationEmailRequired": "Sinun täytyy antaa sähköposti", + "components.Login.validationPortRequired": "Sinun täytyy antaa toimiva portin numero", + "components.Login.validationemailformat": "Toimiva sähköposti vaaditaan", + "components.Login.validationemailrequired": "Sinun täytyy antaa toimiva sähköpostiosoite", + "components.Login.validationhostformat": "Toimiva URL-osoite vaaditaan", + "components.Login.validationhostrequired": "{mediaServerName} URL vaaditaan", + "components.Login.validationpasswordrequired": "Sinun täytyy antaa salasana", + "components.Login.validationservertyperequired": "Valitse palvelimen tyyppi", + "components.Login.validationusernamerequired": "Käyttäjänimi vaaditaan", + "components.ManageSlideOver.alltime": "Koko ajan", + "components.ManageSlideOver.manageModalClearMedia": "Tyhjennä Data", + "components.ManageSlideOver.manageModalIssues": "Avoimet ongelmat", + "components.ManageSlideOver.manageModalMedia4k": "4K Media", + "components.ManageSlideOver.manageModalRemoveMediaWarning": "* Tämä poistaa tämän {mediaType}-tiedoston peruuttamattomasti ohjelmasta {arr}, kaikki tiedostot mukaan lukien.", + "components.ManageSlideOver.manageModalTitle": "Hallinnoi {mediaType}", + "components.ManageSlideOver.mark4kavailable": "Merkitse saatavilla olevaksi 4K-laadulla", + "components.ManageSlideOver.markallseasons4kavailable": "Merkitse kaikki tuotantokaudet saataville 4K-laadulla", + "components.ManageSlideOver.markallseasonsavailable": "Merkitse kaikki tuotantokaudet saataville", + "components.ManageSlideOver.removearr": "Poista ohjelmasta {arr}", + "components.MovieDetails.budget": "Budjetti", + "components.MovieDetails.cast": "Näyttelijät", + "components.MovieDetails.downloadstatus": "Latauksen tila", + "components.MovieDetails.markavailable": "Merkitse saatavilla", + "components.MovieDetails.openradarr": "Avaa elokuva ohjelmassa Radarr", + "components.MovieDetails.openradarr4k": "Avaa elokuva ohjelmassa 4K Radarr", + "components.MovieDetails.originallanguage": "Alkuperäinen kieli", + "components.MovieDetails.originaltitle": "Alkuperäinen nimi", + "components.MovieDetails.overview": "Yhteenveto", + "components.MovieDetails.physicalrelease": "Fyysinen julkaisu", + "i18n.areyousure": "Oletko varma?", + "i18n.back": "Takaisin", + "i18n.approve": "Hyväksy", + "i18n.all": "Kaikki", + "i18n.advanced": "Lisäasetukset", + "i18n.addToBlacklist": "Lisää estolistalle", + "i18n.approved": "Hyväksytty", + "components.UserProfile.requestsperdays": "{limit} jäljellä", + "i18n.movie": "Elokuva", + "i18n.importing": "Tuodaan…", + "i18n.import": "Tuo", + "i18n.failed": "Epäonnistui", + "i18n.experimental": "Kokeellinen", + "i18n.edit": "Muokkaa", + "i18n.deleting": "Poistetaan…", + "i18n.delete": "Poista", + "i18n.next": "Seuraava", + "i18n.decline": "Hylkää", + "i18n.collection": "Kokoelma", + "i18n.close": "Sulje", + "i18n.canceling": "Perutaan…", + "i18n.declined": "Hylätty", + "components.Discover.FilterSlideover.activefilters": "{count, plural, one {# Aktiivinen suodatin} other {# Aktiivista suodatinta}}", + "components.IssueList.IssueItem.episodes": "{episodeCount, plural, one {Jakso} other {Jaksoa}}", + "components.IssueList.IssueItem.seasons": "{seasonCount, plural, one {Tuotantokausi} other {Tuotantokautta}}", + "components.ManageSlideOver.movie": "elokuva", + "components.UserProfile.recentlywatched": "Viimeaikaiset katselut", + "components.UserProfile.plexwatchlist": "Plex-katselulista", + "components.NotificationTypeSelector.mediaapprovedDescription": "Lähetä ilmoituksia, kun mediapyyntöjä hyväksytään manuaalisesti.", + "components.NotificationTypeSelector.mediaapproved": "Pyyntö hyväksytty", + "i18n.pending": "Odottaa", + "components.Layout.VersionStatus.streamdevelop": "Jellyseerr kehittäjä", + "components.Layout.VersionStatus.streamstable": "Jellyseerr vakaa", + "i18n.partiallyavailable": "Osittain saatavilla", + "i18n.previous": "Edellinen", + "i18n.processing": "Käsitellään", + "i18n.removeFromBlacklistSuccess": "{title} poistettiin onnistuneesti estolistalta.", + "i18n.removefromBlacklist": "Poista estolistalta", + "components.Settings.SonarrModal.validationApplicationUrlTrailingSlash": "URL-osoite ei saa päättyä kauttaviivaan", + "components.NotificationTypeSelector.mediaautorequestedDescription": "Saat ilmoituksen, kun seurantalistallasi oleville kohteille lähetetään automaattisesti uusia mediapyyntöjä.", + "components.QuotaSelector.days": "{count, plural, one {päivä} other {päivää}}", + "components.Settings.mediaTypeMovie": "elokuva", + "components.TvDetails.recommendations": "Suositukset", + "components.Selector.showmore": "Näytä lisää", + "components.Settings.validationUrlBaseTrailingSlash": "URL-osoitteen pohja ei saa päättyä kauttaviivaan", + "components.PersonDetails.alsoknownas": "Tunnetaan myös nimeltä: {names}", + "components.Settings.RadarrModal.validationBaseUrlLeadingSlash": "URL-osoitteen pohjassa on oltava alussa kauttaviiva", + "components.RequestCard.approverequest": "Hyväksy pyyntö", + "components.RequestModal.cancel": "Peruuta pyyntö", + "components.Settings.validationUrlBaseLeadingSlash": "URL-osoitteen pohjassa on oltava alussa kauttaviiva", + "components.Settings.RadarrModal.validationApplicationUrlTrailingSlash": "URL-osoite ei saa päättyä kauttaviivaan", + "components.QuotaSelector.unlimited": "Rajoittamaton", + "components.RequestBlock.decline": "Hylkää pyyntö", + "components.RequestModal.errorediting": "Pyyntöä muokattaessa tapahtui virhe.", + "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL-osoite ei saa päättyä kauttaviivaan", + "components.RequestList.RequestItem.failedretry": "Jotain meni pieleen, kun pyyntöä yritettiin uudelleen.", + "components.NotificationTypeSelector.mediaAutoApproved": "Pyyntö hyväksytään automaattisesti", + "components.RequestCard.seasons": "{seasonCount, plural, one {Tuotantokausi} other {Tuotantokautta}}", + "components.RequestBlock.seasons": "{seasonCount, plural, one {Tuotantokausi} other {Tuotantokautta}}", + "components.RequestList.RequestItem.seasons": "{seasonCount, plural, one {Tuotantokausi} other {Tuotantokautta}}", + "components.RequestButton.approve4krequests": "Hyväksy {requestCount, plural, one {4K Pyyntö} other {{requestCount} 4K Pyyntöä}}", + "components.PersonDetails.lifespan": "{birthdate} – {deathdate}", + "components.PermissionEdit.request": "Pyydä", + "components.ManageSlideOver.removearr4k": "Poista ohjelmasta 4K {arr}", + "components.Login.validationUrlBaseLeadingSlash": "URL-osoitteen pohjassa on oltava alussa kauttaviiva", + "components.Login.validationUrlBaseTrailingSlash": "URL-osoitteen pohja ei saa päättyä kauttaviivaan", + "components.Login.validationUrlTrailingSlash": "URL-osoite ei saa päättyä kauttaviivaan", + "components.ManageSlideOver.plays": "{playCount, number} {playCount, plural, one {toisto} other {toistoa}}", + "components.MovieDetails.recommendations": "Suositukset", + "components.MovieDetails.MovieCast.fullcast": "Kaikki näyttelijät", + "components.MovieDetails.managemovie": "Hallinnoi elokuvaa", + "components.MovieDetails.imdbuserscore": "IMDB-käyttäjän pisteet", + "components.MovieDetails.mark4kavailable": "Merkitse saatavilla olevaksi 4K-laadulla", + "components.MovieDetails.play": "Toista kohteessa {mediaServerName}", + "components.MovieDetails.play4k": "Toista 4K kohteessa {mediaServerName}", + "components.MovieDetails.productioncountries": "Tuotanto {countryCount, plural, one {Maa} other {Maata}}", + "components.MovieDetails.releasedate": "{releaseCount, plural, one {Julkaisupäivä} other {Julkaisupäivää}}", + "components.MovieDetails.removefromwatchlist": "Poista katselulistalta", + "components.MovieDetails.reportissue": "Ilmoita ongelmasta", + "components.MovieDetails.revenue": "Tulot", + "components.MovieDetails.rtaudiencescore": "Rotten Tomatoesin yleisöpisteet", + "components.MovieDetails.rtcriticsscore": "Rotten Tomatoes -tomaattimittari", + "components.MovieDetails.runtime": "{minutes} minuuttia", + "components.MovieDetails.showless": "Näytä vähemmän", + "components.MovieDetails.showmore": "Näytä lisää", + "components.MovieDetails.similar": "Samankaltaisia nimikkeitä", + "components.MovieDetails.streamingproviders": "Suoratoistettavat palvelut", + "components.MovieDetails.studio": "{studioCount, plural, one {Studio} other {Studiota}}", + "components.MovieDetails.theatricalrelease": "Teatterijulkaisu", + "components.MovieDetails.tmdbuserscore": "TMDB-käyttäjän pisteet", + "components.MovieDetails.viewfullcrew": "Näytä koko ryhmä", + "components.MovieDetails.MovieCrew.fullcrew": "Koko ryhmä", + "components.MovieDetails.watchlistDeleted": "{title} Poistettiin katselulistalta onnistuneesti!", + "components.MovieDetails.watchlistError": "Jotain meni pieleen. Yritä uudelleen.", + "components.MovieDetails.watchlistSuccess": "{title} lisättiin katselulistalle onnistuneesti!", + "components.MovieDetails.watchtrailer": "Katso traileri", + "components.NotificationTypeSelector.adminissuecommentDescription": "Saat ilmoituksen, kun muut käyttäjät kommentoivat ongelmia.", + "components.NotificationTypeSelector.adminissuereopenedDescription": "Saat ilmoituksen, kun muut käyttäjät avaavat ongelmia uudelleen.", + "components.NotificationTypeSelector.adminissueresolvedDescription": "Saat ilmoituksen, kun muut käyttäjät ovat ratkaisseet ongelmia.", + "components.NotificationTypeSelector.issuecomment": "Ongelman kommentti", + "components.NotificationTypeSelector.issuecommentDescription": "Lähetä ilmoituksia, kun ongelmiin tulee uusia kommentteja.", + "components.NotificationTypeSelector.issuecreated": "Ongelma ilmoitettu", + "components.NotificationTypeSelector.issuecreatedDescription": "Lähetä ilmoituksia, kun ongelmista ilmoitetaan.", + "components.NotificationTypeSelector.issuereopened": "Ongelma avattu uudelleen", + "components.NotificationTypeSelector.issuereopenedDescription": "Lähetä ilmoituksia, kun ongelmia avataan uudelleen.", + "components.NotificationTypeSelector.issueresolved": "Ongelma ratkaistu", + "components.NotificationTypeSelector.issueresolvedDescription": "Lähetä ilmoituksia, kun ongelmat on ratkaistu.", + "components.NotificationTypeSelector.mediaAutoApprovedDescription": "Lähetä ilmoituksia, kun käyttäjät lähettävät uusia mediapyyntöjä, jotka hyväksytään automaattisesti.", + "components.NotificationTypeSelector.mediaautorequested": "Pyyntö lähetetty automaattisesti", + "components.NotificationTypeSelector.mediaavailable": "Pyyntö saatavilla", + "components.NotificationTypeSelector.mediaavailableDescription": "Lähetä ilmoituksia, kun mediapyyntöjä tulee saataville.", + "components.NotificationTypeSelector.mediadeclined": "Pyyntö hylätty", + "components.NotificationTypeSelector.mediadeclinedDescription": "Lähetä ilmoituksia, kun mediapyyntöjä hylätään.", + "components.NotificationTypeSelector.notificationTypes": "Ilmoitustyypit", + "components.PersonDetails.appearsin": "Esiintymiset", + "components.PersonDetails.ascharacter": "hahmona {character}", + "components.PersonDetails.birthdate": "Syntynyt {birthdate}", + "components.PermissionEdit.request4k": "Pyydä 4K-laadulla", + "components.RegionSelector.regionDefault": "Kaikki alueet", + "components.RegionSelector.regionServerDefault": "Oletus ({region})", + "components.RequestBlock.approve": "Hyväksy pyyntö", + "components.RequestBlock.delete": "Poista pyyntö", + "components.RequestBlock.edit": "Muokkaa pyyntöä", + "components.RequestBlock.languageprofile": "Kieliprofiili", + "components.RequestBlock.lastmodifiedby": "Viimeksi muokannut", + "components.RequestBlock.profilechanged": "Laatuprofiili", + "components.RequestBlock.requestdate": "Pyyntöpäivämäärä", + "components.RequestBlock.requestedby": "Pyytäjä", + "components.RequestBlock.requestoverrides": "Pyyntöjen ohitukset", + "components.RequestBlock.rootfolder": "Juurikansio", + "components.RequestBlock.server": "Kohdepalvelin", + "components.RequestButton.approverequest": "Hyväksy pyyntö", + "components.RequestButton.approverequest4k": "Hyväksy 4K Pyyntö", + "components.RequestButton.declinerequest": "Hylkää pyyntö", + "components.RequestButton.declinerequest4k": "Hylkää 4K Pyyntö", + "components.RequestButton.requestmore": "Pyydä lisää", + "components.RequestButton.requestmore4k": "Pyydä lisää 4K-laadulla", + "components.RequestButton.viewrequest": "Näytä pyyntö", + "components.RequestButton.viewrequest4k": "Näytä 4K Pyyntö", + "components.RequestCard.cancelrequest": "Peruuta pyyntö", + "components.RequestCard.declinerequest": "Hylkää pyyntö", + "components.RequestCard.deleterequest": "Poista pyyntö", + "components.RequestCard.editrequest": "Muokkaa pyyntöä", + "components.RequestCard.failedretry": "Jotain meni pieleen uudelleenpyytäessä.", + "components.RequestCard.mediaerror": "{mediaType} Ei löydy", + "components.RequestCard.tmdbid": "TMDB ID", + "components.RequestCard.tvdbid": "TheTVDB ID", + "components.RequestCard.unknowntitle": "Tuntematon nimike", + "components.RequestList.RequestItem.cancelRequest": "Peruuta pyyntö", + "components.RequestList.RequestItem.deleterequest": "Poista pyyntö", + "components.RequestList.RequestItem.editrequest": "Muokkaa pyyntöä", + "components.RequestList.RequestItem.mediaerror": "{mediaType} Ei löydy", + "components.RequestList.RequestItem.modified": "Muokattu", + "components.RequestList.RequestItem.modifieduserdate": "{date} käyttäjältä {user}", + "components.RequestList.RequestItem.profileName": "Profiili", + "components.RequestList.RequestItem.removearr": "Poista ohjelmasta {arr}", + "components.RequestList.RequestItem.requested": "Pyydetty", + "components.RequestList.RequestItem.requesteddate": "Pyydetty", + "components.RequestList.RequestItem.tmdbid": "TMDB ID", + "components.RequestList.RequestItem.tvdbid": "TheTVDB ID", + "components.RequestList.RequestItem.unknowntitle": "Tuntematon nimike", + "components.RequestList.requests": "Pyynnöt", + "components.RequestList.showallrequests": "Näytä kaikki pyynnöt", + "components.RequestList.sortAdded": "Uusin", + "components.RequestList.sortModified": "Viimeksi muokattu", + "components.RequestModal.AdvancedRequester.advancedoptions": "Lisäasetukset", + "components.RequestModal.QuotaDisplay.movie": "elokuva", + "components.RequestModal.edit": "Muokkaa pyyntöä", + "components.RequestModal.requestcollectiontitle": "Pyydä kokoelma", + "components.RequestModal.pendingrequest": "Odottava pyyntö", + "components.RequestModal.approve": "Hyväksy pyyntö", + "components.RequestModal.autoapproval": "Automaattinen hyväksyntä", + "components.RequestModal.alreadyrequested": "Pyydetty jo", + "components.Settings.RadarrModal.validationBaseUrlTrailingSlash": "URL-osoitteen pohja ei saa päättyä kauttaviivaan", + "components.Settings.SettingsAbout.about": "Tietoja", + "components.Settings.SonarrModal.validationBaseUrlLeadingSlash": "URL-osoitteen alussa on oltava kauttaviiva", + "components.Settings.mediaTypeSeries": "sarja", + "components.Settings.menuAbout": "Tietoja" } diff --git a/src/i18n/locale/fr.json b/src/i18n/locale/fr.json index 5b918bb927..99ed0e0001 100644 --- a/src/i18n/locale/fr.json +++ b/src/i18n/locale/fr.json @@ -211,7 +211,6 @@ "components.Settings.address": "Adresse", "components.Settings.addsonarr": "Ajouter un serveur Sonarr", "components.Settings.cancelscan": "Annuler le scan", - "components.Settings.copied": "Clé d'API copiée dans le presse-papier.", "components.Settings.currentlibrary": "Bibliothèque actuelle : {name}", "components.Settings.default": "Par défaut", "components.Settings.default4k": "4K par défaut", @@ -807,21 +806,11 @@ "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Les paramètres de la notification Web push ont été enregistrés avec succès !", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Les paramètres de la notification Web push n'ont pas été enregistrés.", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Activer l'agent", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL de webhook", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Vous devez fournir une URL valide", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Paramètres de notification de LunaSea sauvegardés avec succès !", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Les paramètres de notification LunaSea n'ont pas pu être enregistrés.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Uniquement nécessaire si vous n'utilisez pas le profil default", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nom du Profil", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Activer l'agent", "components.PermissionEdit.requestMoviesDescription": "Autorise à demander des films non-4K.", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestFailed": "La notification de test Web Push n’a pas été envoyée.", "components.PermissionEdit.requestMovies": "Demander des films", "components.PermissionEdit.requestTv": "Demander des séries", "components.PermissionEdit.requestTvDescription": "Autorise à demander des séries non-4K.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Notification test LunaSea envoyée !", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Envoi de la notification test LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "L'envoi de la notification test LunaSea a échoué.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Envoi de la notification test Pushbullet…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "L'envoi de la notification test Pushbullet a échoué.", "components.Settings.Notifications.toastTelegramTestFailed": "L'envoi de la notification test à Telegram a échoué.", @@ -840,7 +829,6 @@ "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Enregistrer une application à utiliser avec Jellyseerr", "components.RequestList.RequestItem.requesteddate": "Demandé", "components.RequestCard.failedretry": "Une erreur s'est produite lors du renvoi de la demande.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Paramètres de notification Web Push enregistrés avec succès !", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "Notification de test web push envoyée !", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "Envoi d'une notification de test web push…", "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "Afin de recevoir des notifications push web, Jellyseerr doit fonctionner en HTTPS.", @@ -851,13 +839,11 @@ "components.Settings.Notifications.NotificationsSlack.toastSlackTestSending": "Envoi de la notification test Slack…", "components.Settings.Notifications.NotificationsSlack.toastSlackTestFailed": "L'envoi de la notification test Slack a échoué.", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Créer un jeton à partir de vos paramètres de compte", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Votre URL de webhook de notification basée sur l'utilisateur ou l'appareil", "components.QuotaSelector.seasons": "{count, plural, one {saison} other {saisons}}", "components.QuotaSelector.movies": "{count, plural, one {film} other {films}}", "components.QuotaSelector.movieRequests": "{quotaLimit} {movies} tous les {quotaDays} {days}", "components.QuotaSelector.days": "{count, plural, one {jour} other {jours}}", "components.Settings.SettingsAbout.betawarning": "Ceci est un logiciel BÊTA. Les fonctionnalités peuvent être non opérationnelles ou instables. Veuillez signaler tout problème sur GitHub !", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Échec de l'enregistrement des paramètres de notification Web push.", "components.UserProfile.UserSettings.UserGeneralSettings.languageDefault": "Langage par défaut ({language})", "components.Settings.webAppUrlTip": "Dirigez éventuellement les utilisateurs vers l'application Web sur votre serveur au lieu de l'application Web « hébergée »", "components.Settings.webAppUrl": "URL Application Web", @@ -883,7 +869,6 @@ "components.Settings.Notifications.NotificationsSlack.validationTypes": "Vous devez sélectionner au moins un type de notification", "components.Settings.Notifications.NotificationsPushover.validationTypes": "Vous devez sélectionner au moins un type de notification", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Vous devez sélectionner au moins un type de notification", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Vous devez sélectionner au moins un type de notification", "components.QuotaSelector.tvRequests": "{quotaLimit} {seasons} tous les {quotaDays} {days}", "components.NotificationTypeSelector.usermediarequestedDescription": "Être averti(e) lorsque d'autres utilisateurs soumettent une demande de média qui nécessite une validation.", "components.NotificationTypeSelector.usermediafailedDescription": "Être averti(e) lorsqu'une demande de média n'a pas pu être ajoutée à Radarr ou Sonarr.", @@ -1304,7 +1289,6 @@ "components.Login.hostname": "URL de {mediaServerName}", "components.Login.port": "Port", "components.Login.urlBase": "URL de base", - "components.Login.validationHostnameRequired": "Vous devez fournir un nom d'hôte ou une adresse IP valide", "components.Login.validationPortRequired": "Vous devez fournir un numéro de port valide", "components.Login.validationUrlBaseLeadingSlash": "L'URL de base doit avoir une barre oblique initiale", "components.Login.validationUrlTrailingSlash": "L'URL ne doit pas se terminer par une barre oblique finale", @@ -1330,7 +1314,7 @@ "components.Selector.inProduction": "En production", "components.Selector.pilot": "Pilote", "components.Selector.planned": "Planifié(e)", - "components.Selector.returningSeries": "Séries de retour", + "components.Selector.returningSeries": "Série de retour", "components.Selector.searchStatus": "Sélectionner statut...", "components.Setup.back": "Retourner en arrière", "components.Setup.configemby": "Configurer Emby", @@ -1394,7 +1378,6 @@ "components.Settings.OverrideRuleModal.selectQualityProfile": "Choisir le profil de qualité", "components.Settings.OverrideRuleModal.selectRootFolder": "Choisir le dossier racine", "components.Settings.SettingsNetwork.networksettings": "Paramètres réseau", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Paramètres réseau avancés", "components.DiscoverTvUpcoming.upcomingtv": "Séries à venir", "components.Login.noadminerror": "Aucun compte administrateur trouvé sur ce serveur.", "components.Login.orsigninwith": "Ou se connecter avec", diff --git a/src/i18n/locale/he.json b/src/i18n/locale/he.json index 8902f46928..868d833bc2 100644 --- a/src/i18n/locale/he.json +++ b/src/i18n/locale/he.json @@ -1,6 +1,6 @@ { "components.ManageSlideOver.alltime": "כל הזמנים", - "components.Login.validationemailrequired": "יש לספק מייל חוקי", + "components.Login.validationemailrequired": "יש לספק כתובת מייל תקינה", "components.NotificationTypeSelector.userissuereopenedDescription": "קבל התראה כשבעיות שפתחת נפתחות מחדש.", "components.AppDataWarning.dockerVolumeMissingDescription": "ה {appDataPath} אחסון לא הוגדר כראוי. כל המידע יוסר כאשר הקונטיינר יעצור או יותחל מחדש.", "components.CollectionDetails.overview": "תצוגה כללית", @@ -98,7 +98,7 @@ "components.IssueDetails.toaststatusupdated": "סטאטוס המקרה עודכן בהצלחה!", "components.IssueDetails.toaststatusupdatefailed": "משהו השתבש בזמן עדכון סטאטוס המקרה.", "components.IssueDetails.unknownissuetype": "לא ידוע", - "components.IssueList.IssueItem.issuestatus": "סטאטוס", + "components.IssueList.IssueItem.issuestatus": "סטטוס", "components.IssueList.IssueItem.unknownissuetype": "לא ידוע", "components.IssueList.IssueItem.viewissue": "צפה במקרה", "components.IssueList.issues": "מקרים", @@ -148,8 +148,8 @@ "components.Discover.CreateSlider.searchKeywords": "חפש מילות מפתח…", "components.Discover.CreateSlider.searchStudios": "חפש אולפנים…", "components.Discover.CreateSlider.slidernameplaceholder": "שם הסליידר", - "components.Discover.CreateSlider.validationDatarequired": "עליך לספק ערך.", - "components.Discover.CreateSlider.validationTitlerequired": "עליך לספק כותר.", + "components.Discover.CreateSlider.validationDatarequired": "יש לספק ערך.", + "components.Discover.CreateSlider.validationTitlerequired": "יש לספק כותרת.", "components.Discover.DiscoverMovieKeyword.keywordMovies": "סרטים {keywordTitle}", "components.Discover.DiscoverMovies.discovermovies": "סרטים", "components.Discover.DiscoverMovies.sortPopularityAsc": "פופולריות בסדר עולה", @@ -190,7 +190,7 @@ "components.Discover.CreateSlider.addsuccess": "סליידר חדש נוצר בהצלחה ונשמרו הגדרות התאמה.", "components.Discover.CreateSlider.providetmdbnetwork": "ספק מזהה רשת TMDB", "components.Discover.DiscoverTv.sortFirstAirDateDesc": "תאריך שידור ראשון בסדר יורד", - "components.Discover.CreateSlider.starttyping": "התחל להזין כדי לחפש.", + "components.Discover.CreateSlider.starttyping": "התחל להקליד כדי לחפש.", "components.Discover.FilterSlideover.runtimeText": "זמן ריצה בין {minValue} ל {maxValue}", "components.Discover.DiscoverMovies.activefilters": "{count, plural, one {פילטר פעיל} other {# פילטרים פעילים}}", "components.Discover.DiscoverSliderEdit.deletefail": "כשל במחיקת סליידר.", @@ -357,7 +357,6 @@ "components.PermissionEdit.autoapproveSeriesDescription": "אישור בקשות סדרות אוטומטי (ללא 4K).", "component.BlacklistBlock.blacklistdate": "תאריך חסימה", "components.Login.hostname": "{mediaServerName} כתובת URL", - "components.Login.validationHostnameRequired": "עליך להזין שם מארח או כתובת IP תקינה", "components.Login.validationUrlBaseTrailingSlash": "בסיס ה-URL לא יכול להסתיים בסלאש", "components.MovieDetails.watchlistSuccess": "{title} נוסף לרשימת הצפייה בהצלחה!", "components.NotificationTypeSelector.usermediaAutoApprovedDescription": "קבלת התראות כאשר משתמשים אחרים מגישים בקשות מדיה חדשות אשר מאושרות אוטומטית.", @@ -387,10 +386,9 @@ "components.Selector.canceled": "בוטל", "components.Selector.ended": "נגמר", "components.Selector.searchStudios": "חיפוש אולפנים…", - "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "עליך לספק אסימון יישום", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "הפעל סוכן", + "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "יש לספק אסימון יישום", "components.Settings.Notifications.NotificationsSlack.slacksettingsfailed": "הגדרות ההתראות של Slack נכשלו להישמר.", - "components.Settings.Notifications.NotificationsSlack.validationWebhookUrl": "עליך לספק כתובת URL תקינה", + "components.Settings.Notifications.NotificationsSlack.validationWebhookUrl": "יש לספק כתובת URL תקינה", "components.Layout.Sidebar.blacklist": "רשימת חסימות", "components.Login.back": "חזרה", "components.PermissionEdit.viewissuesDescription": "הענקת גישה לראות בעיות מדיה שדווחו על ידי משתמשים אחרים.", @@ -400,10 +398,9 @@ "components.RequestModal.pending4krequest": "בקשת 4K ממתינה", "components.RequestModal.requestedited": "בקשה עבור {title} נערכה בהצלחה!", "components.Settings.Notifications.NotificationsGotify.gotifysettingsfailed": "הגדרות ההתראות של Gotify נכשלו להישמר.", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "עליך לספק כתובת URL תקינה", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "שולח התראת בדיקה של Pushbullet…", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "מזהה המשתמש או הקבוצה בעל ה-30 תווים שלך", - "components.Login.adminerror": "עליך להשתמש בחשבון מנהל בשביל להתחבר.", + "components.Login.adminerror": "יש להשתמש בחשבון מנהל בשביל להתחבר.", "components.NotificationTypeSelector.userissueresolvedDescription": "קבלת התראות כאשר הבעיות שדיווחת נפתרות.", "components.Discover.FilterSlideover.status": "סטטוס", "components.PermissionEdit.blacklistedItemsDescription": "הענקת גישה לחסימת מדיה.", @@ -412,9 +409,8 @@ "components.ResetPassword.validationpasswordrequired": "יש לספק סיסמה", "components.Selector.inProduction": "בהפקה", "components.Selector.pilot": "פרק דוגמה", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "הגדרות ההתראות של LunaSea נשמרו בהצלחה!", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "יצירת אסימון מתוך הגדרות המשתמש שלך", - "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "עליך לספק אסימון גישה", + "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "יש לספק אסימון גישה", "components.PermissionEdit.manageblacklistDescription": "הענקת גישה לניהול מדיה חסומה.", "components.PersonDetails.appearsin": "מופעים", "components.RequestCard.tmdbid": "מזהה TMDB", @@ -427,7 +423,7 @@ "components.Login.port": "פורט", "components.Login.servertype": "סוג שרת", "components.Login.urlBase": "בסיס URL", - "components.Login.validationPortRequired": "עליך להזין מספר פורט תקין", + "components.Login.validationPortRequired": "יש לספק מספר פורט תקין", "components.Login.validationUrlBaseLeadingSlash": "בסיס ה-URL חייב להתחיל בסלאש", "components.Login.validationUrlTrailingSlash": "ה-URL לא יכול להסתיים בסלאש", "components.Login.validationservertyperequired": "אנא בחר סוג שרת", @@ -594,14 +590,6 @@ "components.Settings.Notifications.NotificationsGotify.toastGotifyTestFailed": "התראת הבדיקה של Gotify נכשלה להשלח.", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSending": "שולח התראת בדיקה של Gotify…", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "התראת הבדיקה של Gotify נשלחה!", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "שם פרופיל", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "רק דרוש אם הפרופיל default לא בשימוש", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "הגדרות ההתראות של LunaSea נכשלו להישמר.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "התראת הבדיקה של LunaSea נכשלה להשלח.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "שולח התראת בדיקה של LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "התראת הבדיקה של LunaSea נשלחה!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "עליך לבחור לפחות סוג התראות אחד", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL של ה-Webhook", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "אסימון גישה", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "הפעל סוכן", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "תג ערוץ", @@ -609,23 +597,23 @@ "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "הגדרות ההתראות של Pushbullet נשמרו בהצלחה!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "התראת הבדיקה של Pushbullet נכשלה להשלח.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "התראת הבדיקה של Pushbullet נשלחה!", - "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "עליך לבחור לפחות סוג התראה אחד", + "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "יש לבחור לפחות סוג התראה אחד", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "התראת הבדיקה של Pushover נכשלה להשלח.", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSending": "שולח התראת בדיקה של Pushover…", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "התראת הבדיקה של Pushover נשלחה!", "components.Settings.Notifications.NotificationsPushover.userToken": "מפתח משתמש או קבוצה", - "components.Settings.Notifications.NotificationsPushover.validationAccessTokenRequired": "עליך לספק אסימון יישום תקין", - "components.Settings.Notifications.NotificationsPushover.validationTypes": "עליך לבחור לפחות סוג התראה אחד", - "components.Settings.Notifications.NotificationsPushover.validationUserTokenRequired": "עליך לספק משתמש או מפתח קבוצה תקין", + "components.Settings.Notifications.NotificationsPushover.validationAccessTokenRequired": "יש לספק אסימון יישום תקין", + "components.Settings.Notifications.NotificationsPushover.validationTypes": "יש לבחור לפחות סוג התראה אחד", + "components.Settings.Notifications.NotificationsPushover.validationUserTokenRequired": "יש לספק משתמש או מפתח קבוצה תקין", "components.Settings.Notifications.NotificationsSlack.agentenabled": "הפעל סוכן", "components.Settings.Notifications.NotificationsSlack.slacksettingssaved": "הגדרות ההתראות של Slack נשמרו בהצלחה!", "components.Settings.Notifications.NotificationsSlack.toastSlackTestFailed": "התראת הבדיקה של Slack נכשלה להשלח.", "components.Settings.Notifications.NotificationsSlack.toastSlackTestSending": "שולח התראת בדיקה של Slack…", "components.Settings.Notifications.NotificationsSlack.toastSlackTestSuccess": "התראת הבדיקה של Slack נשלחה!", - "components.Settings.Notifications.NotificationsSlack.validationTypes": "עליך לבחור לפחות סוג התראה אחד", + "components.Settings.Notifications.NotificationsSlack.validationTypes": "יש לבחור לפחות סוג התראה אחד", "components.Settings.Notifications.NotificationsSlack.webhookUrl": "URL של ה-Webhook", "component.BlacklistModal.blacklisting": "חסימה", - "components.Blacklist.blacklistNotFoundError": "{title} לא חסום.", + "components.Blacklist.blacklistNotFoundError": "{title} לא ברשימת החסימה.", "components.Blacklist.blacklistSettingsDescription": "ניהול מדיה חסומה.", "components.Blacklist.blacklistdate": "תאריך", "components.Blacklist.blacklistedby": "{date} על ידי {user}", @@ -644,8 +632,8 @@ "components.RequestModal.QuotaDisplay.movie": "סרט", "components.Settings.Notifications.NotificationsGotify.token": "אסימון יישום", "components.Settings.Notifications.NotificationsGotify.url": "כתובת URL של שרת", - "components.Settings.Notifications.NotificationsGotify.validationTypes": "עליך לבחור לפחות סוג התראות אחד", - "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "עליך לספק כתובת URL תקינה", + "components.Settings.Notifications.NotificationsGotify.validationTypes": "יש לבחור לפחות סוג התראות אחד", + "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "יש לספק כתובת URL תקינה", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "על כתובת ה-URL לא להסתיים בסלאש", "components.Settings.Notifications.NotificationsPushover.accessToken": "אסימון API של היישום", "components.Settings.Notifications.NotificationsPushover.agentenabled": "הפעל סוכן", @@ -654,19 +642,119 @@ "components.Settings.Notifications.NotificationsPushover.pushoversettingssaved": "הגדרות ההתראות של Pushover נשמרו בהצלחה!", "components.Settings.Notifications.NotificationsPushover.sound": "צליל התראה", "components.Settings.Notifications.NotificationsWebhook.resetPayload": "איפוס לברירת מחדל", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "קישור Webhook להתראות מבוסס מכשיר או משתמש", "components.Settings.Notifications.NotificationsWebhook.agentenabled": "הפעל סוכן", "components.Settings.Notifications.NotificationsWebhook.authheader": "כותרת עליונה של הרשאות", "components.Settings.Notifications.NotificationsWebhook.customJson": "מטען JSON", "components.Settings.Notifications.NotificationsWebhook.resetPayloadSuccess": "מטען JSON התאפס בהצלחה!", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSuccess": "התראת הבדיקה של ה-Webhook נשלחה!", - "components.Settings.Notifications.NotificationsWebhook.validationJsonPayloadRequired": "עליך לספק מטען JSON תקין", - "components.Settings.Notifications.NotificationsWebhook.validationTypes": "עליך לבחור לפחות סוג התראה אחד", - "components.Settings.Notifications.NotificationsWebhook.validationWebhookUrl": "עליך לספק כתובת URL תקינה", + "components.Settings.Notifications.NotificationsWebhook.validationJsonPayloadRequired": "יש לספק מטען JSON תקין", + "components.Settings.Notifications.NotificationsWebhook.validationTypes": "יש לבחור לפחות סוג התראה אחד", + "components.Settings.Notifications.NotificationsWebhook.validationWebhookUrl": "יש לספק כתובת URL תקינה", "components.Settings.Notifications.NotificationsWebhook.webhookUrl": "URL של ה-Webhook", "components.Settings.Notifications.NotificationsWebhook.webhooksettingsfailed": "הגדרות ההתראות של ה-Webhook נכשלו להשמר.", "components.Settings.Notifications.NotificationsWebhook.webhooksettingssaved": "הגדרות ההתראות של ה-Webhook נשמרו בהצלחה!", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "הפעל סוכן", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestFailed": "התראת הבדיקה של ה-Webhook נכשלה להשלח.", - "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSending": "שולח התראת בדיקה של ה-Webhook…" + "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSending": "שולח התראת בדיקה של ה-Webhook…", + "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "על מנת לקבל התראות אינטרנט, על Jellyseerr להיות מוגש בעזרת HTTPS.", + "components.Settings.Notifications.NotificationsWebhook.templatevariablehelp": "תבנית משתנה עזרה", + "i18n.noresults": "אין תוצאות.", + "i18n.removefromBlacklist": "הסרה מרשימת החסימה", + "i18n.removeFromBlacklistSuccess": "{title} הוסר בהצלחה מרשימת החסימה.", + "i18n.requested": "התבקש", + "i18n.notrequested": "לא נתבקש", + "i18n.open": "פתוח", + "i18n.partiallyavailable": "זמין חלקית", + "i18n.pending": "ממתין", + "i18n.previous": "קודם", + "i18n.processing": "מעבד", + "i18n.request": "בקשה", + "i18n.request4k": "בקשה ב-4K", + "i18n.requesting": "מבקש…", + "i18n.resolved": "נפתר", + "i18n.restartRequired": "נדרשת הפעלה מחדש", + "i18n.resultsperpage": "הצג {pageSize} תוצאות בכל דף", + "i18n.retry": "נסה שוב", + "i18n.retrying": "מנסה שוב…", + "i18n.save": "שמירת שינויים", + "i18n.saving": "שומר…", + "i18n.settings": "הגדרות", + "i18n.showingresults": "מציג {from} ל-{to} מתוך {total} תוצאות", + "i18n.specials": "פרקים מיוחדים", + "i18n.status": "סטטוס", + "i18n.test": "בדיקה", + "i18n.testing": "בודק…", + "i18n.tvshow": "סדרה", + "i18n.tvshows": "סדרות", + "i18n.unavailable": "לא זמין", + "i18n.usersettings": "הגדרות משתמש", + "pages.errormessagewithcode": "{statusCode} - {error}", + "pages.internalservererror": "שגיאת שרת פנימית", + "pages.oops": "אופס", + "pages.pagenotfound": "דף לא נמצא", + "pages.returnHome": "חזרה לדף הבית", + "pages.serviceunavailable": "שירות לא זמין", + "pages.somethingwentwrong": "משהו השתבש", + "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestFailed": "התראת הבדיקה דרך הרשת נכשלה להשלח.", + "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "הגדרות ההתראות דרך הרשת נשמרו בהצלחה!", + "components.Settings.SonarrModal.hostname": "שם מארח או כתובת IP", + "components.Settings.Notifications.validationSmtpPortRequired": "יש לספק מספר פורט תקין", + "components.Settings.Notifications.botAvatarUrl": "כתובת URL של תמונת הבוט", + "components.Settings.Notifications.botUsername": "שם משתמש של הבוט", + "components.Settings.Notifications.pgpPasswordTip": "חתימת הודעות אי-מייל מוצפנות בעזרת OpenPGP", + "components.Settings.RadarrModal.hostname": "שם מארח או כתובת IP", + "components.Settings.Notifications.chatIdTip": "התחל שיחה עם הבוט שלך, הוסף @get_id_bot, ובצע את הפקודה /my_id", + "components.Settings.Notifications.encryptionDefault": "שימוש ב-STARTTLS אם זמין", + "components.Settings.Notifications.toastDiscordTestSuccess": "התראת בדיקה של Discord נשלחה!", + "components.Settings.validationHostnameRequired": "יש לספק שם מארח או כתובת IP תקינה", + "components.Settings.Notifications.encryptionTip": "ברוב המקרים, Implicit TLS משתמש בפורט 465 ו-STARTTLS משתמש בפורט 587", + "components.Settings.SonarrModal.validationHostnameRequired": "יש לספק שם מארח או כתובת IP תקינה", + "components.Settings.Notifications.toastDiscordTestSending": "שולח התראת בדיקה של Discord…", + "components.Settings.Notifications.toastTelegramTestFailed": "התראת הבדיקה של Telegram נכשלה להשלח.", + "components.Settings.Notifications.validationChatIdRequired": "יש לספק מזהה צ'אט תקין", + "components.Settings.SettingsNetwork.proxyHostname": "שם מארח Proxy", + "components.Settings.RadarrModal.validationHostnameRequired": "יש לספק שם מארח או כתובת IP תקינה", + "components.Settings.hostname": "שם מארח או כתובת IP", + "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "שולח התראת בדיקה דרך הרשת…", + "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "התראת הבדיקה דרך הרשת נשלחה!", + "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "הגדרות ההתראות דרך הרשת נכשלו להשמר.", + "components.Settings.Notifications.agentenabled": "הפעל סוכן", + "components.Settings.Notifications.authPass": "סיסמת SMTP", + "components.Settings.Notifications.authUser": "שם משתמש SMTP", + "components.Settings.Notifications.botAPI": "אסימון הרשאת בוט", + "components.Settings.Notifications.botApiTip": "יצירת בוט לשימוש עם Jellyseerr", + "components.Settings.Notifications.botUsernameTip": "אפשר למשתמשים גם להתחיל שיחה עם הבוט שלך ולהגדיר התראות אישיות", + "components.Settings.Notifications.discordsettingsfailed": "הגדרות ההתראות של Discord נכשלו להשמר.", + "components.Settings.Notifications.discordsettingssaved": "הגדרות ההתראות של Discord נשמרו בהצלחה!", + "components.Settings.Notifications.emailsender": "כתובת מוען", + "components.Settings.Notifications.emailsettingsfailed": "הגדרות התראות ה-Email נכשלו להשמר.", + "components.Settings.Notifications.emailsettingssaved": "הגדרות התראות ה-Email נשמרו בהצלחה!", + "components.Settings.Notifications.enableMentions": "הפעל תיוגים", + "components.Settings.Notifications.encryption": "שיטת הצפנה", + "components.Settings.Notifications.encryptionImplicitTls": "שימוש ב Implicit TLS", + "components.Settings.Notifications.encryptionNone": "ללא", + "components.Settings.Notifications.encryptionOpportunisticTls": "תמיד השתמש ב-STARTTLS", + "components.Settings.Notifications.pgpPassword": "סיסמת PGP", + "components.Settings.Notifications.pgpPrivateKey": "מפתח PGP פרטי", + "components.Settings.Notifications.sendSilentlyTip": "שליחת התראות ללא קול", + "components.Settings.Notifications.sendSilently": "שליחה בשקט", + "components.Settings.Notifications.toastEmailTestFailed": "התראת הבדיקה דרך אימייל נכשלה להשלח.", + "components.Settings.Notifications.toastEmailTestSending": "שולח התראת בדיקה דרך אימייל…", + "components.Settings.Notifications.toastEmailTestSuccess": "התראת בדיקה דרך אימייל נשלחה בהצלחה!", + "components.Settings.Notifications.toastTelegramTestSuccess": "התראת הבדיקה של Telegram נשלחה!", + "components.Settings.Notifications.toastTelegramTestSending": "שולח התראת בדיקה של Telegram…", + "components.Settings.Notifications.userEmailRequired": "דרוש אימייל משתמש", + "components.Settings.Notifications.validationPgpPassword": "יש לספק סיסמת PGP", + "components.Settings.Notifications.validationBotAPIRequired": "יש לספק אסימון הרשאת בוט", + "components.Settings.Notifications.validationEmail": "יש לספק כתובת מייל תקינה", + "components.Settings.Notifications.validationPgpPrivateKey": "יש לספק מפתח PGP פרטי תקין", + "components.Settings.Notifications.validationSmtpHostRequired": "יש לספק שם מארח או כתובת IP תקינה", + "components.Settings.Notifications.validationTypes": "יש לבחור לפחות סוג התראות אחד", + "components.Settings.Notifications.validationUrl": "יש לספק כתובת URL תקינה", + "components.Settings.Notifications.webhookUrl": "URL של ה-Webhook", + "components.Settings.Notifications.chatId": "מזהה צ'אט", + "i18n.addToBlacklist": "הוספה לרשימת החסימות", + "i18n.blacklistDuplicateError": "{title} כבר נוסף לרשימת החסימה.", + "i18n.blacklistSuccess": "{title} נוסף לרשימת החסימה בהצלחה.", + "i18n.blacklisted": "חסום" } diff --git a/src/i18n/locale/hr.json b/src/i18n/locale/hr.json index 44572d3241..f17ec31dad 100644 --- a/src/i18n/locale/hr.json +++ b/src/i18n/locale/hr.json @@ -340,7 +340,6 @@ "components.Settings.addradarr": "Dodaj Radarr poslužitelj", "components.Settings.address": "Adresa", "components.Settings.addsonarr": "Dodaj Sonarr poslužitelj", - "components.Settings.copied": "API ključ je kopiran u međuspremnik.", "components.Settings.currentlibrary": "Aktualna biblioteka: {name}", "components.Settings.default": "Zadano", "components.Settings.default4k": "Zadano 4K", @@ -598,15 +597,8 @@ "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSending": "Slanje Gotify obavijesti provjere …", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "Gotify obavijest provjere je poslana!", "components.Settings.Notifications.NotificationsGotify.token": "Token programa", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Aktiviraj agenta", "components.Settings.Notifications.NotificationsGotify.url": "URL poslužitelja", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL ne smije završiti s kosom crtom", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Ime profila", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Potrebno je samo ako se ne koristi zadani profil", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Neuspjelo slanje LunaSea obavijesti provjere.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Slanje LunaSea obavijesti provjere …", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea obavijest provjere je poslana!", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Token za pristup", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Neuspjelo spremanje postavki Pushbullet obavijesti.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Neuspjelo slanje Pushbullet obavijesti provjere.", @@ -792,10 +784,6 @@ "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "Moraš navesti token programa", "components.Settings.Notifications.NotificationsGotify.validationTypes": "Moraš odabrati barem jednu vrstu obavijesti", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "Moraš navesti valjani URL", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Neuspjelo spremanje postavki LunaSea obavijesti.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea postavke obavijesti su uspješno spremljene!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Moraš odabrati barem jednu vrstu obavijesti", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Moraš navesti valjani URL", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Stvori token iz tvojih postavki računa", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Aktiviraj agenta", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "Oznaka kanala", @@ -992,8 +980,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPushbulletAccessToken": "Moraš navesti valjani token za pristup", "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverApplicationToken": "Moraš navesti valjani token programa", "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverUserKey": "Moraš navesti valjani ključ korisnika ili grupe", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Neuspjelo spremanje Web push postavki obavijesti.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Web push postavke obavijesti su uspješno spremljene!", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Potvrdi lozinku", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Nova lozinka", "components.UserProfile.UserSettings.UserPasswordChange.validationConfirmPassword": "Moraš potvrditi novu lozinku", @@ -1057,7 +1043,6 @@ "components.RequestModal.SearchByNameModal.notvdbiddescription": "Nismo uspjeli automatski naći odgovarajuću seriju. Dolje odaberi odgovarajuću seriju.", "components.RequestModal.requestadmin": "Ovaj će se zahtjev automatski odobriti.", "components.ResetPassword.emailresetlink": "E-mail poveznica za obnavljanje lozinke", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Tvoj korisničke ili na osnovi uređaja webhook URL obavijesti", "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "Za primanje web push obavijesti, Jellyseerr se mora posluživati putem HTTPS-a.", "components.Settings.Notifications.NotificationsWebhook.templatevariablehelp": "Pomoć za varijablu predloška", "components.Settings.Notifications.chatIdTip": "Započni chat s tvojim botom, dodaj @get_id_bot i zadaj naredbu /my_id", diff --git a/src/i18n/locale/hu.json b/src/i18n/locale/hu.json index b491a95a26..5be406a647 100644 --- a/src/i18n/locale/hu.json +++ b/src/i18n/locale/hu.json @@ -217,8 +217,6 @@ "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Új jelszó", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Jelenlegi jelszó", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Jelszó megerősítése", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "A webes push értesítés beállításai sikeresen mentésre kerültek!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "A webes push-értesítés beállításait nem sikerült elmenteni.", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Meg kell adnia egy érvényes chat azonosítót", "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "Érvényes PGP- kulcsot kell megadnia", @@ -343,7 +341,6 @@ "components.Settings.default4k": "Alapértelmezett 4K", "components.Settings.default": "Alapértelmezett", "components.Settings.currentlibrary": "Jelenlegi könyvtár: {name}", - "components.Settings.copied": "API-kulcs másolva a vágólapra.", "components.Settings.cancelscan": "Beolvasás megszakítása", "components.Settings.addsonarr": "Sonarr szerver hozzáadása", "components.Settings.address": "Cím", @@ -755,7 +752,6 @@ "components.Settings.SettingsUsers.newPlexLoginTip": "Lehetővé teszi a {mediaServerName} felhasználók számára, hogy első importálás nélkül jelentkezzenek be", "components.Settings.SettingsUsers.newPlexLogin": "Engedélyezze az új {mediaServerName} bejelentkezést", "components.QuotaSelector.tvRequests": "{quotaLimit} {seasons} per {quotaDays} {days}", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL-je", "components.RequestModal.QuotaDisplay.allowedRequests": "Napi {limit} {type} kérés engedélyezett minden {days} naponta.", "components.Settings.Notifications.NotificationsSlack.agentenabled": "\"ügynök\" engedélyezése", "components.Settings.Notifications.NotificationsPushover.validationUserTokenRequired": "Meg kell adnia egy érvényes felhasználói vagy csoportos kulcsot", @@ -779,17 +775,6 @@ "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Agent engedélyezése", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Hozzon létre egy Tokent a Fiók beállításokba", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Hozzáférési Token (Access Token)", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Felhasználói vagy eszközalapú értesitési webhook URL", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Érvényes URL-t kell megadnia", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Legalább egy értesítési típust ki kell választania", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "A LunaSea teszt értesítése elküldve!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea teszt értesítés küldése …", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "A LunaSea teszt értesítését nem sikerült elküldeni.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "A LunaSea értesítési beállításainak mentése sikerült!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "A LunaSea értesítési beállításainak mentése nem sikerült.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Csak akkor szükséges, ha nem használja a default profil", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profil név", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "\"Ügynök\" engedélyezése", "components.Search.search": "Keresés", "components.ResetPassword.validationpasswordrequired": "Meg kell adnia egy jelszót", "components.ResetPassword.validationpasswordminchars": "A jelszó túl rövid; minimum 8 karakter hosszú legyen", @@ -979,7 +964,7 @@ "components.RequestCard.cancelrequest": "Kérés visszavonása", "components.RequestCard.declinerequest": "Kérelem elutasítása", "components.RequestCard.editrequest": "Kérelem szerkesztése", - "components.Discover.DiscoverWatchlist.discoverwatchlist": "", + "components.Discover.DiscoverWatchlist.discoverwatchlist": "Saját Watchlist", "components.PermissionEdit.autorequest": "Automatikus kérés", "components.NotificationTypeSelector.mediaautorequested": "A kérelem automatikusan elküldve", "components.MovieDetails.reportissue": "Probléma bejelentése", @@ -1145,5 +1130,58 @@ "components.Discover.FilterSlideover.runtimeText": "{minValue}-{maxValue} percnyi műsoridő", "components.Discover.FilterSlideover.studio": "Stúdió", "components.Discover.FilterSlideover.tmdbuserscore": "TMDB Felhasználói Értékelés", - "components.Discover.FilterSlideover.streamingservices": "Streaming Szolgáltatók" + "components.Discover.FilterSlideover.streamingservices": "Streaming Szolgáltatók", + "component.BlacklistBlock.blacklistdate": "Feketelistás dátum", + "components.Discover.resetsuccess": "A felfedezés testreszabási beállításainak visszaállítása sikeresen megtörtént.", + "components.DownloadBlock.formattedTitle": "{title}: {seasonNumber}. Évad {episodeNumber}. Rész", + "components.Layout.Sidebar.blacklist": "Feketelista", + "components.Login.username": "Felhasználónév", + "components.Blacklist.blacklistNotFoundError": "{title} nincs feketelistán.", + "components.DiscoverTvUpcoming.upcomingtv": "Soron következő Sorozatok", + "components.Discover.createnewslider": "Új Csúszka Létrehozása", + "components.Discover.FilterSlideover.status": "Státusz", + "components.Layout.UserWarnings.emailInvalid": "Az email cím hibás.", + "components.Login.invalidurlerror": "Nem lehet a {mediaServerName} szerverhez kapcsolódni.", + "components.Discover.customizediscover": "Felfedezés Testreszabása", + "components.Login.adminerror": "Egy adminisztrátor fiókot kell használnod a belépéshez.", + "components.Login.back": "Ugorj Vissza", + "components.Discover.studios": "Stúdiók", + "components.Discover.FilterSlideover.from": "Től", + "components.Discover.FilterSlideover.to": "Ig", + "components.Discover.networks": "Hálózatok", + "components.Layout.Sidebar.browsemovies": "Filmek", + "components.Layout.Sidebar.browsetv": "Sorozatok", + "components.Layout.UserWarnings.emailRequired": "Egy email cím szükséges.", + "components.Layout.UserWarnings.passwordRequired": "Jelszó szükséges.", + "components.Login.credentialerror": "A felhasználónév vagy a jelszó hibás.", + "components.Login.description": "Mivel ez az első belépésed a {applicationName}-be meg kell adnod egy valós email címet.", + "components.Login.enablessl": "SSL használata", + "components.Login.initialsignin": "Csatlakozás", + "components.Login.initialsigningin": "Csatlakozás folyamatban…", + "components.Login.loginwithapp": "Belépés {appName}-el", + "components.Login.noadminerror": "Nem található adminisztrátor a szerveren.", + "components.Login.orsigninwith": "Vagy belépés ezzel:", + "components.Login.port": "Port", + "components.Login.save": "Hozzáadás", + "components.Login.saving": "Hozzáadás folyamatban…", + "components.Login.servertype": "Szerver Típus", + "components.Login.signinwithjellyfin": "Használd a {mediaServerName} fiókodat", + "components.Login.title": "Email hozzáadása", + "components.Login.urlBase": "URL Törzs", + "components.Login.validationEmailFormat": "Érvénytelen email", + "components.Login.validationEmailRequired": "Meg kell adnod egy email címet", + "component.BlacklistBlock.blacklistedby": "Feketelistára rakta", + "component.BlacklistModal.blacklisting": "Feketelista", + "components.Blacklist.blacklistSettingsDescription": "Feketelistás média kezelése.", + "components.Blacklist.blacklistdate": "dátum", + "components.Blacklist.blacklistedby": "{date}-kor {user} által", + "components.Blacklist.blacklistsettings": "Feketelista beállítások", + "components.Blacklist.mediaName": "Név", + "components.Blacklist.mediaTmdbId": "tmdb Id", + "components.Blacklist.mediaType": "Típus", + "components.Discover.resetfailed": "Hiba történt a felfedezés testreszabási beállításainak visszaállításakor.", + "components.Discover.resettodefault": "Visszaállítás Alapértelmezettre", + "components.Discover.resetwarning": "Össze csőszka visszaállítása alapértelmezettre. Ez a saját csúszkákat is kitörli!", + "components.Discover.stopediting": "Módosítás abbahagyása", + "components.Discover.tmdbmoviegenre": "TMDB film műfaja" } diff --git a/src/i18n/locale/it.json b/src/i18n/locale/it.json index 29b823881a..4af30cb1a8 100644 --- a/src/i18n/locale/it.json +++ b/src/i18n/locale/it.json @@ -115,7 +115,6 @@ "components.Settings.default4k": "4K predefinito", "components.Settings.default": "Predefinito", "components.Settings.currentlibrary": "Libreria corrente: {name}", - "components.Settings.copied": "Chiave API copiata negli appunti.", "components.Settings.cancelscan": "Annulla l'analisi", "components.Settings.addsonarr": "Aggiungi un server Sonarr", "components.Settings.addradarr": "Aggiungi un server Radarr", @@ -185,7 +184,7 @@ "components.TvDetails.network": "{networkCount, plural, one {Rete} other {Reti}}", "components.Setup.finishing": "Finalizzazione…", "components.Settings.menuJobs": "Processi & Cache", - "components.Setup.signinMessage": "Comincia accedendo con il tuo account Plex", + "components.Setup.signinMessage": "Comincia facendo l'accesso", "components.Settings.sonarrsettings": "Impostazioni Sonarr", "components.Settings.plexsettingsDescription": "Configura le impostazioni per il tuo server Plex. Jellyseerr scansiona le tue librerie Plex per determinare la disponibilità dei contenuti.", "components.Settings.plexlibrariesDescription": "Le librerie che Jellyseerr scansiona per i titoli. Configura e salva le impostazioni di connessione Plex, quindi fai clic sul pulsante qui sotto se non sono elencate librerie.", @@ -485,12 +484,12 @@ "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Conferma la password", "components.UserProfile.UserSettings.UserNotificationSettings.validationDiscordId": "È necessario fornire un ID utente valido", "components.CollectionDetails.requestcollection4k": "Richiedi Raccolta in 4K", - "components.UserProfile.UserSettings.UserGeneralSettings.region": "Regione da scoprire", + "components.UserProfile.UserSettings.UserGeneralSettings.region": "Ricerca per Regione", "components.UserProfile.UserSettings.UserGeneralSettings.originallanguage": "Lingua da scoprire", "components.Settings.webhook": "Webhook", - "components.Settings.email": "E-mail", + "components.Settings.email": "Email", "components.RegionSelector.regionDefault": "Tutte le regioni", - "components.UserProfile.UserSettings.UserGeneralSettings.regionTip": "Filtra i contenuti per disponibilità regionale", + "components.UserProfile.UserSettings.UserGeneralSettings.regionTip": "Filtra i contenuti in base alla disponibilità della regione", "components.UserProfile.UserSettings.UserGeneralSettings.originallanguageTip": "Filtra i contenuti per lingua originale", "components.Discover.upcomingtv": "Serie in uscita", "components.RegionSelector.regionServerDefault": "Predefinito ({region})", @@ -577,7 +576,7 @@ "components.Settings.SettingsLogs.resumeLogs": "Riprendi", "components.Settings.SettingsLogs.pauseLogs": "Pausa", "components.Settings.SettingsLogs.message": "Messaggio", - "components.Settings.SettingsLogs.logsDescription": "Puoi anche visualizzare questi registri direttamente tramite stdout, o in {appDataPath}/logs/overseerr.log.", + "components.Settings.SettingsLogs.logsDescription": "Puoi anche visualizzare questi registri direttamente tramite stdout, o in {appDataPath}/logs/jellyseerr.log.", "components.Settings.SettingsLogs.level": "Gravità", "components.Settings.SettingsLogs.label": "Etichetta", "components.Settings.SettingsLogs.filterWarn": "Attenzione", @@ -592,7 +591,7 @@ "components.Settings.SettingsLogs.extraData": "Dati aggiuntivi", "components.Settings.SettingsLogs.copyToClipboard": "Copia negli appunti", "components.Settings.SettingsLogs.copiedLogMessage": "Messaggio di registro copiato negli appunti.", - "components.UserList.nouserstoimport": "Non ci sono utenti PLex da importare.", + "components.UserList.nouserstoimport": "Non ci sono utenti Plex da importare.", "components.PersonDetails.lifespan": "{birthdate} – {deathdate}", "components.PersonDetails.birthdate": "Data di nascita {birthdate}", "components.PersonDetails.alsoknownas": "Altri nomi: {names}", @@ -605,7 +604,7 @@ "i18n.status": "Stato", "i18n.showingresults": "Mostrando {from} a {to} di {total} risultati", "i18n.resultsperpage": "Mostra {pageSize} risultati per pagina", - "i18n.saving": "Salvataggio…", + "i18n.saving": "Salvando…", "i18n.save": "Salva Modifiche", "i18n.requesting": "Richiesta in corso…", "i18n.request4k": "Richiedi in 4K", @@ -713,17 +712,8 @@ "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Impostazioni di notifica web salvate con successo!", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Impossibile salvare le impostazioni di notifica web.", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Abilita Agente", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Impostazioni di notifica Web push salvate correttamente!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Impossibile salvare le impostazioni di notifica via Web push.", "components.Settings.noDefault4kServer": "Un server 4K {serverType} deve essere contrassegnato come predefinito per permettere agli utenti di inviare richieste 4K {mediaType}.", "components.Settings.is4k": "4K", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "È necessario fornire un URL valido", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Impostazioni LunaSea salvate con successo!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Impossibile salvare le impostazioni di notifica LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Richiesto solo se non si usa il profilo default", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nome Profilo", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Abilita Agente", "components.PermissionEdit.requestTvDescription": "Concedere l'autorizzazione per richiedere serie non 4K.", "components.PermissionEdit.requestTv": "Richiedi Serie", "components.PermissionEdit.requestMoviesDescription": "Concedere il permesso di richiedere film non in 4K.", @@ -742,9 +732,6 @@ "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Notifica di prova Pushbullet inviata!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Invio notifica di prova Pushbullet …", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Invio della notifica di prova Pushbullet non riuscito.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Notifica di test LunaSea inviata!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Invio notifica di prova con LunaSea …", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Impossibile inviare notifica con LunaSea.", "components.DownloadBlock.estimatedtime": "Stimato {time}", "components.Settings.Notifications.encryptionImplicitTls": "Usa TLS Implicito", "components.Settings.Notifications.encryptionTip": "Solitamente, TLS Implicito usa la porta 465 e STARTTLS usa la porta 587", @@ -757,7 +744,7 @@ "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSuccess": "Notifica Webhook di prova inviata!", "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "Crea un'integrazione Incoming Webhook", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Il tuo identificatore utente o gruppo di 30 caratteri", - "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registra un'applicazione per l'uso con Jellyseerr", + "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registra un'applicazione per l'uso con Jellyseerr", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Crea un token dalle tue Impostazioni account", "components.Settings.Notifications.toastDiscordTestFailed": "Invio della notifica di prova Discord non riuscito.", "components.Settings.Notifications.webhookUrlTip": "Crea un integrazione webhook nel server", @@ -772,14 +759,13 @@ "components.UserList.localLoginDisabled": "L'impostazione Abilita Accesso Locale è attualmente disabilitata.", "components.UserProfile.UserSettings.UserGeneralSettings.languageDefault": "Predefinito ({language})", "components.Settings.webAppUrlTip": "Indirizza opzionalmente gli utenti alla web app sul tuo server invece che alla web app \"ospitata\"", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "La tua notifica webhook URL basata su utente o dispositivo", "components.Settings.webAppUrl": "URL Web App", - "components.Settings.SettingsUsers.newPlexLoginTip": "Permetti agli utenti di Plex di accedere senza essere prima importati", - "components.Settings.SettingsUsers.newPlexLogin": "Abilita nuovo accesso con Plex", + "components.Settings.SettingsUsers.newPlexLoginTip": "Permetti agli utenti di {mediaServerName} di accedere senza essere prima importati", + "components.Settings.SettingsUsers.newPlexLogin": "Abilita nuovo accesso con {mediaServerName}", "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "Per ricevere notifiche push web, Jellyseerr deve essere servito tramite HTTPS.", "components.RequestList.RequestItem.requesteddate": "Richiesto", "components.RequestCard.failedretry": "Qualcosa è andato storto nel riprovare la richiesta.", - "components.Settings.SettingsUsers.localLoginTip": "Consentire agli utenti di accedere utilizzando l'indirizzo di posta elettronica e la password, anziché Plex OAuth", + "components.Settings.SettingsUsers.localLoginTip": "Consenti agli utenti di accedere utilizzando la mail e la password", "components.Settings.SettingsUsers.defaultPermissionsTip": "Permessi assegnati ai nuovi utenti", "components.QuotaSelector.movieRequests": "{quotaLimit} {movies} per {quotaDays} {days}", "components.QuotaSelector.tvRequests": "{quotaLimit} {seasons} per {quotaDays} {days}", @@ -789,7 +775,6 @@ "components.Settings.Notifications.validationTypes": "È necessario selezionare almeno un tipo di notifica", "components.Settings.Notifications.NotificationsSlack.validationTypes": "È necessario selezionare almeno un tipo di notifica", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "È necessario selezionare almeno un tipo di notifica", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "È necessario selezionare almeno un tipo di notifica", "components.Settings.Notifications.NotificationsWebhook.validationTypes": "È necessario selezionare almeno un tipo di notifica", "components.Settings.Notifications.NotificationsPushover.validationTypes": "È necessario selezionare almeno un tipo di notifica", "components.Settings.SettingsAbout.betawarning": "Questo software è in BETA. Alcuni componenti potrebbero non funzionare correttamente. Aiutaci segnalando i problemi su GitHub!", @@ -877,7 +862,7 @@ "components.ManageSlideOver.manageModalTitle": "Gestisci {mediaType}", "components.ManageSlideOver.mark4kavailable": "Segna come disponibile in 4K", "components.IssueDetails.openinarr": "Apri in {arr}", - "components.IssueDetails.playonplex": "Guarda su Plex", + "components.IssueDetails.playonplex": "Guarda su {mediaServerName}", "components.ManageSlideOver.openarr": "Apri in {arr}", "components.ManageSlideOver.openarr4k": "Apri in 4K {arr}", "components.IssueDetails.play4konplex": "Guarda in 4K su Plex", @@ -914,7 +899,7 @@ "components.NotificationTypeSelector.issuecreatedDescription": "Invia una notifica quando un problema viene segnalato.", "components.NotificationTypeSelector.issueresolved": "Problema risolto", "components.NotificationTypeSelector.issueresolvedDescription": "Invia una notifica quando un problema viene risolto.", - "components.UserProfile.UserSettings.UserNotificationSettings.pushbulletAccessToken": "Access Token", + "components.UserProfile.UserSettings.UserNotificationSettings.pushbulletAccessToken": "Token di accesso", "components.UserProfile.UserSettings.UserNotificationSettings.pushoverApplicationToken": "API Token applicazione", "components.UserProfile.UserSettings.UserNotificationSettings.pushoverUserKey": "Chiave utente o di un gruppo", "components.UserProfile.UserSettings.UserNotificationSettings.pushbulletAccessTokenTip": "Crea un token dalle tue Impostazioni Account", @@ -991,10 +976,10 @@ "components.Settings.SettingsAbout.appDataPath": "Cartella applicazione", "components.RequestBlock.languageprofile": "Lingua Profilo", "components.MovieDetails.digitalrelease": "Uscita versione digitale", - "components.Discover.DiscoverWatchlist.discoverwatchlist": "La tua lista da guardare Plex", + "components.Discover.DiscoverWatchlist.discoverwatchlist": "La tua lista", "components.Discover.plexwatchlist": "La tua lista da guardare Plex", "components.PermissionEdit.autorequest": "Richiesta automatica", - "components.Discover.DiscoverWatchlist.watchlist": "Lista da guardare Plex", + "components.Discover.DiscoverWatchlist.watchlist": "Plex Watchlist", "components.MovieDetails.managemovie": "Gestisci Film", "components.MovieDetails.physicalrelease": "Uscita versione fisica", "components.MovieDetails.theatricalrelease": "Uscita nelle sale", @@ -1091,7 +1076,7 @@ "components.Settings.SettingsMain.toastApiKeySuccess": "Nuova chiave API generata con successo!", "components.Settings.SettingsMain.toastSettingsFailure": "Qualcosa è andato storto durante il salvataggio delle impostazioni.", "components.StatusBadge.managemedia": "Gestisci {mediaType}", - "components.StatusBadge.playonplex": "Riproduci su Plex", + "components.StatusBadge.playonplex": "Riproduci su {mediaServerName}", "components.StatusBadge.seasonepisodenumber": "S{seasonNumber}E{episodeNumber}", "components.StatusChecker.appUpdated": "{applicationTitle} aggiornato", "components.TvDetails.Season.somethingwentwrong": "Qualcosa è andato storto durante il recupero dei dati della stagione.", @@ -1111,7 +1096,7 @@ "components.Settings.SettingsMain.validationApplicationTitle": "Devi fornire un titolo dell'applicazione", "components.Settings.SettingsMain.validationApplicationUrl": "Devi fornire un URL valido", "components.Settings.restartrequiredTooltip": "Jellyseerr deve essere riavviato per rendere effettive le modifiche", - "components.TitleCard.tvdbid": "TheTVDB ID", + "components.TitleCard.tvdbid": "ID TheTVDB", "components.UserProfile.emptywatchlist": "I media aggiunti alla tua Plex Watchlist appariranno qui.", "components.TvDetails.status4k": "4K {status}", "i18n.restartRequired": "Riavvio necessario", @@ -1149,7 +1134,6 @@ "components.Login.urlBase": "Base URL", "components.Login.username": "Nome utente", "components.Login.validationEmailRequired": "Devi fornire un'email", - "components.Login.validationHostnameRequired": "Devi fornire un hostname o un indirizzo IP valido", "components.Login.validationPortRequired": "Devi fornire un numero di porta valido", "components.Login.validationUrlBaseTrailingSlash": "L'URL di base non deve terminare con una barra finale", "components.Login.validationUrlTrailingSlash": "L'URL non deve terminare con una barra finale", @@ -1166,7 +1150,7 @@ "components.MovieDetails.rtaudiencescore": "Punteggio del pubblico di Rotten Tomatoes", "components.MovieDetails.rtcriticsscore": "Tomatometro di Rotten Tomatoes", "components.MovieDetails.tmdbuserscore": "Punteggio Utente TMDB", - "components.MovieDetails.watchlistError": "Qualcosa è andato storto, riprova.", + "components.MovieDetails.watchlistError": "Qualcosa è andato storto. Riprova.", "components.MovieDetails.watchlistSuccess": "{title} aggiunto alla lista di visione con successo!", "components.PermissionEdit.autorequestMovies": "Richiesta automatica dei film", "components.PermissionEdit.autorequestSeries": "Richiesta automatica di serie", @@ -1190,7 +1174,7 @@ "components.RequestList.RequestItem.unknowntitle": "Titolo sconosciuto", "components.RequestModal.requestcollection4ktitle": "Richiedi Collezione in 4K", "components.RequestModal.requestcollectiontitle": "Richiedi Collezione", - "components.Settings.Notifications.NotificationsPushover.deviceDefault": "Predefinito dispositivo", + "components.Settings.Notifications.NotificationsPushover.deviceDefault": "Predefinito del dispositivo", "components.Settings.SettingsAbout.supportjellyseerr": "Supporta Jellyseerr", "components.Settings.SettingsJobsCache.availability-sync": "Sincronizzazione della disponibilità dei media", "components.Settings.SettingsJobsCache.editJobScheduleCurrent": "Frequenza Attuale", @@ -1229,7 +1213,7 @@ "components.RequestList.RequestItem.tmdbid": "ID TMDB", "components.Settings.Notifications.NotificationsPushover.sound": "Suono di notifica", "components.Settings.SettingsMain.cacheImagesTip": "Cache le immagini provenienti da fonti esterne (richiede una quantità significativa di spazio su disco)", - "components.Settings.SettingsMain.generalsettingsDescription": "Configure global and default settings for Jellyseerr.", + "components.Settings.SettingsMain.generalsettingsDescription": "Configura le impostazioni globali e predefinite per Jellyseerr.", "components.RequestModal.SearchByNameModal.nomatches": "Non siamo riusciti a trovare una corrispondenza per questa serie.", "components.Settings.RadarrModal.tagRequests": "Tagga richieste", "components.Settings.SettingsJobsCache.imagecacheDescription": "Quando abilitato nelle impostazioni, Jellyseerr farà da proxy e memorizzerà nella cache le immagini provenienti da fonti esterne preconfigurate. Le immagini memorizzate nella cache vengono salvate nella tua cartella di configurazione. Puoi trovare i file in `{appDataPath}/cache/images`.", @@ -1250,5 +1234,239 @@ "components.Layout.UserWarnings.emailInvalid": "L'indirizzo email non è valido.", "components.Layout.UserWarnings.emailRequired": "È necessario un indirizzo email.", "components.Layout.UserWarnings.passwordRequired": "È richiesta una password.", - "components.Settings.SettingsMain.partialRequestsEnabled": "Consenti richieste parziali di serie" + "components.Settings.SettingsMain.partialRequestsEnabled": "Consenti richieste parziali di serie", + "components.Login.back": "Torna Indietro", + "components.Settings.Notifications.webhookRoleId": "ID ruolo di notifica", + "components.Blacklist.blacklistSettingsDescription": "Gestisci i media esclusi.", + "components.PermissionEdit.blacklistedItemsDescription": "Concedi l'autorizzazione per escludere i media.", + "components.Settings.Notifications.messageThreadId": "Thread/ID Argomento", + "components.Setup.configplex": "Configura Plex", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.plexErrorExists": "Questo account è già collegato ad un utente Plex", + "components.Settings.Notifications.messageThreadIdTip": "Se nella tua chat di gruppo sono abilitati gli argomenti, puoi specificare qui l'ID di un thread/argomento", + "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncmovies": "Richiedi automaticamente i film", + "components.Selector.canceled": "Cancellato", + "components.Selector.inProduction": "In Produzione", + "components.Discover.FilterSlideover.status": "Stato", + "components.Layout.Sidebar.blacklist": "Esclusioni", + "components.RequestList.RequestItem.removearr": "Rimuovi da {arr}", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.plexErrorUnauthorized": "Impossible connettersi a Plex usando le tue credenziali", + "component.BlacklistBlock.blacklistdate": "Data esclusa", + "components.DiscoverTvUpcoming.upcomingtv": "Serie in arrivo", + "components.PermissionEdit.viewblacklistedItems": "Visualizza media esclusi.", + "components.Settings.Notifications.webhookRoleIdTip": "L'ID del ruolo da menzionare nel messaggio webhook. Lasciare vuoto per disabilitare le menzioni", + "components.Login.validationservertyperequired": "Seleziona un tipo di server", + "components.Settings.Notifications.validationMessageThreadId": "L'ID del thread/argomento deve essere un numero intero positivo", + "components.PermissionEdit.blacklistedItems": "Media esclusi.", + "components.RequestList.sortDirection": "Cambia direzione di ordinamento", + "components.Login.loginwithapp": "Login con {appName}", + "components.Login.noadminerror": "Non è stato trovato nessun amministratore nel server.", + "components.Login.orsigninwith": "O fai l'accesso con", + "components.Login.servertype": "Tipo Server", + "components.PermissionEdit.manageblacklist": "Gestisci le esclusioni", + "components.PermissionEdit.manageblacklistDescription": "Concedi l'autorizzazione a gestire i media esclusi.", + "components.PermissionEdit.viewblacklistedItemsDescription": "Concedi l'autorizzazione a visualizzare i media esclusi.", + "components.Selector.ended": "Terminato", + "components.Selector.pilot": "Pilota", + "components.Selector.planned": "Pianificato", + "components.Selector.returningSeries": "Serie Ricorrente", + "components.Selector.searchStatus": "Seleziona stato...", + "components.Selector.searchUsers": "Seleziona utenti…", + "components.Settings.Notifications.validationWebhookRoleId": "È necessario fornire un ID ruolo Discord valido", + "components.Settings.OverrideRuleModal.conditions": "Condizioni", + "components.Setup.signinWithPlex": "Inserisci le tue credenziali di Plex", + "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncseries": "Richiedi automaticamente le serie", + "component.BlacklistBlock.blacklistedby": "Escluso da", + "component.BlacklistModal.blacklisting": "Aggiungendo alle esclusioni", + "components.Blacklist.blacklistNotFoundError": "{title} non è escluso.", + "components.Blacklist.blacklistdate": "data", + "components.Blacklist.blacklistedby": "{date} di {user}", + "components.Blacklist.blacklistsettings": "Impostazioni delle esclusioni", + "components.Blacklist.mediaName": "Nome", + "components.Blacklist.mediaTmdbId": "ID tmdb", + "components.Blacklist.mediaType": "Tipo", + "components.Settings.OverrideRuleModal.selectRootFolder": "Seleziona cartella principale", + "components.Settings.OverrideRuleModal.conditionsDescription": "Specifica le condizioni prima di applicare le modifiche ai parametri. Ogni campo deve essere convalidato affinché le regole possano essere applicate (operazione AND). Un campo è considerato verificato se una qualsiasi delle sue proprietà corrisponde (operazione OR).", + "components.Settings.OverrideRuleModal.selectQualityProfile": "Seleziona profilo di qualità", + "components.Settings.OverrideRuleModal.ruleUpdated": "Regola di sostituzione aggiornata con successo!", + "components.Settings.OverrideRuleModal.settingsDescription": "Specifica quali impostazioni verranno modificate quando saranno soddisfatte le condizioni sopra indicate.", + "components.Settings.OverrideRuleModal.create": "Crea regola", + "components.Settings.OverrideRuleModal.createrule": "Nuova regola di sostituzione", + "components.Settings.OverrideRuleModal.editrule": "Modifica regola di sostituzione", + "components.Settings.OverrideRuleModal.genres": "Generi", + "components.Settings.OverrideRuleModal.keywords": "Parole Chiave", + "components.Settings.OverrideRuleModal.languages": "Lingue", + "components.Settings.OverrideRuleModal.notagoptions": "Nessun tag.", + "components.Settings.OverrideRuleModal.qualityprofile": "Profilo di qualità", + "components.Settings.OverrideRuleModal.rootfolder": "Cartella Principale", + "components.Settings.OverrideRuleModal.ruleCreated": "Regola di sostituzione creata con successo!", + "components.Settings.OverrideRuleModal.selectService": "Seleziona servizio", + "components.Settings.OverrideRuleModal.selecttags": "Seleziona i tag", + "components.Settings.OverrideRuleModal.service": "Servizio", + "components.Settings.OverrideRuleModal.serviceDescription": "Applica questa regola al servizio selezionato.", + "components.Settings.OverrideRuleModal.settings": "Impostazioni", + "components.Settings.OverrideRuleModal.tags": "Tags", + "components.Settings.OverrideRuleModal.users": "Utenti", + "components.Settings.OverrideRuleTile.conditions": "Condizioni", + "components.Settings.OverrideRuleTile.genre": "Genere", + "components.Settings.OverrideRuleTile.keywords": "Parole chiave", + "components.Settings.OverrideRuleTile.language": "Lingua", + "components.Settings.OverrideRuleTile.qualityprofile": "Profilo di qualità", + "components.Settings.OverrideRuleTile.rootfolder": "Cartella Principale", + "components.Settings.OverrideRuleTile.settings": "Impostazioni", + "components.Settings.OverrideRuleTile.tags": "Tags", + "components.Settings.OverrideRuleTile.users": "Utenti", + "components.Settings.SettingsJobsCache.plex-refresh-token": "Token di aggiornamento Plex", + "components.Settings.SettingsMain.discoverRegionTip": "Filtra i contenuti in base alla disponibilità della regione", + "components.Settings.SettingsMain.discoverRegion": "Ricerca per Regione", + "components.Settings.SettingsMain.streamingRegionTip": "Mostra i siti di streaming in base alla disponibilità della regione", + "components.Settings.SettingsMain.enableSpecialEpisodes": "Consenti richieste di episodi speciali", + "components.Settings.SettingsJobsCache.usersavatars": "Avatar degli utenti", + "components.Settings.SettingsMain.streamingRegion": "Regione di streaming", + "components.Settings.SettingsNetwork.toastSettingsFailure": "Si è verificato un errore durante il salvataggio delle impostazioni.", + "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegion": "Ricerca per Regione", + "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "Non abilitare questa impostazione se non sei sicuro di ciò che stai facendo!", + "components.TitleCard.watchlistSuccess": "{title} aggiunto alla lista con successo!", + "components.UserProfile.UserSettings.UserNotificationSettings.sound": "Suono di notifica", + "i18n.blacklistDuplicateError": "{title} è già stato inserito nelle esclusioni.", + "components.Settings.jellyfinSettingsDescription": "Se vuoi, puoi configurare gli endpoint interni ed esterni per il tuo server {mediaServerName}. Di solito, l'URL esterno è diverso da quello interno. Puoi anche impostare un URL personalizzato per reimpostare la password di accesso a {mediaServerName}, se vuoi reindirizzare a una pagina diversa per reimpostare la password. Puoi anche cambiare la chiave API Jellyfin, che è stata generata automaticamente in precedenza.", + "components.Settings.jellyfinsettings": "Impostazioni {mediaServerName}", + "components.Settings.scanbackground": "La scansione verrà eseguita in background. Nel frattempo è possibile continuare con la procedura di configurazione.", + "components.UserProfile.UserSettings.menuLinkedAccounts": "Account Collegati", + "components.Settings.syncing": "Sincronizzando", + "components.StatusChecker.restartRequiredDescription": "Riavvia il server per applicare le impostazioni aggiornate.", + "components.TvDetails.rtaudiencescore": "Punteggio del pubblico su Rotten Tomatoes", + "components.TvDetails.watchlistDeleted": "{title} rimosso dalla lista con successo!", + "components.Settings.SettingsNetwork.networkDisclaimer": "È necessario utilizzare i parametri di rete del proprio container/sistema anziché queste impostazioni. Per ulteriori informazioni, consultare i {docs}.", + "components.UserList.importedfromJellyfin": "{userCount} {mediaServerName} {userCount, plural, one {utente} other {utenti}} importati con successo!", + "components.Settings.SonarrModal.tagRequestsInfo": "Aggiungi automaticamente un tag aggiuntivo con l'ID utente e il nome visualizzato del richiedente", + "components.Settings.deleteServer": "Elimina Server {serverType}", + "components.Settings.overrideRulesDescription": "Le regole di sostituzione consentono di specificare le proprietà che verranno sostituite se una richiesta corrisponde alla regola.", + "components.UserList.newJellyfinsigninenabled": "L'impostazione Abilita nuovo accesso {mediaServerName} è attualmente abilitata. Gli utenti {mediaServerName} con accesso alla libreria non devono essere importati per poter effettuare l'accesso.", + "components.UserProfile.UserSettings.UserNotificationSettings.telegramMessageThreadId": "Thread/ID Argomento", + "components.Settings.SettingsUsers.atLeastOneAuth": "È necessario selezionare almeno un metodo di autenticazione.", + "components.Settings.SonarrModal.tagRequests": "Aggiungi tag alle richieste", + "components.Settings.invalidurlerror": "Impossibile connettersi al server {mediaServerName}.", + "components.Settings.jellyfinsettingsDescription": "Configura le impostazioni per il tuo server {mediaServerName}. {mediaServerName} esegue la scansione delle tue librerie {mediaServerName} per vedere quali contenuti sono disponibili.", + "components.Setup.librarieserror": "Convalida non riuscita. Attivare nuovamente le librerie per continuare.", + "components.TvDetails.episodeCount": "{episodeCount, plural, one {# Episodio} other {# Episodi}}", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnauthorized": "Impossibile connettersi a {mediaServerName} utilizzando le credenziali fornite", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.deleteFailed": "Impossibile eliminare l'account collegato.", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noPermissionDescription": "Non hai il permesso di modificare gli account collegati a questo utente.", + "i18n.removeFromBlacklistSuccess": "{title} è stato rimosso con successo dalle esclusioni.", + "components.Settings.overrideRules": "Regole di sostituzione", + "components.Settings.save": "Salva Modifiche", + "components.Settings.saving": "Salvando…", + "components.Setup.signinWithEmby": "Inserisci le tue credenziali Emby", + "components.TitleCard.addToWatchList": "Aggiungi alla lista", + "components.TvDetails.removefromwatchlist": "Rimuovi dalla Lista", + "components.Setup.signin": "Accedi", + "components.Settings.jellyfinSyncFailedNoLibrariesFound": "Nessuna libreria trovata", + "components.Settings.SettingsNetwork.csrfProtection": "Abilita Protezione CSRF", + "components.Settings.SettingsNetwork.csrfProtectionTip": "Imposta l'accesso API esterno in sola lettura (richiede HTTPS)", + "components.Settings.SettingsNetwork.docs": "documentazione", + "components.Settings.SettingsNetwork.forceIpv4First": "Forza prima la risoluzione IPv4", + "components.Settings.SettingsNetwork.forceIpv4FirstTip": "Forza Jellyseerr a risolvere prima gli indirizzi IPv4 invece di quelli IPv6", + "components.Settings.SettingsNetwork.network": "Rete", + "components.Settings.SettingsNetwork.networksettings": "Impostazioni di Rete", + "components.Settings.SettingsNetwork.networksettingsDescription": "Configura le impostazioni di rete per la tua istanza Jellyseerr.", + "components.Settings.SettingsNetwork.proxyBypassFilter": "Indirizzi Proxy Ignorati", + "components.Settings.SettingsNetwork.proxyBypassFilterTip": "Utilizza “,” come separatore e “*.” come carattere jolly per i sottodomini", + "components.Settings.SettingsNetwork.proxyBypassLocalAddresses": "Bypassare il Proxy per gli Indirizzi Locali", + "components.Settings.SettingsNetwork.proxyEnabled": "Proxy HTTP(S)", + "components.Settings.SettingsNetwork.proxyHostname": "Nome Host Proxy", + "components.Settings.SettingsNetwork.proxyPassword": "Password del Proxy", + "components.Settings.SettingsNetwork.proxyPort": "Porta del Proxy", + "components.Settings.SettingsNetwork.proxySsl": "Usa SSL per il Proxy", + "components.Settings.SettingsNetwork.proxyUser": "Username del Proxy", + "components.Settings.SettingsNetwork.toastSettingsSuccess": "Impostazioni salvate con successo!", + "components.Settings.SettingsNetwork.trustProxy": "Abilita Supporto Proxy", + "components.Settings.SettingsNetwork.trustProxyTip": "Consenti a Jellyseerr di registrare correttamente gli indirizzi IP dei client dietro un proxy", + "components.Settings.SettingsNetwork.validationProxyPort": "È necessario fornire una porta valida", + "components.Settings.SettingsUsers.loginMethods": "Metodi di Login", + "components.Settings.SettingsUsers.loginMethodsTip": "Configura i metodi di accesso per gli utenti.", + "components.Settings.SettingsUsers.mediaServerLogin": "Abilita accesso tramite {mediaServerName}", + "components.Settings.SettingsUsers.mediaServerLoginTip": "Consenti agli utenti di accedere utilizzando il proprio account {mediaServerName}", + "components.Settings.addrule": "Nuova regola di sostituzione", + "components.Settings.advancedTooltip": "Una configurazione errata di questa impostazione può causare dei malfunzionamenti", + "components.Settings.apiKey": "Chiave API", + "components.Settings.experimentalTooltip": "L'attivazione di questa impostazione può causare un comportamento imprevisto dell'applicazione", + "components.Settings.jellyfinForgotPasswordUrl": "URL Password dimenticata", + "components.Settings.jellyfinSettings": "Impostazioni {mediaServerName}", + "components.Settings.jellyfinSettingsFailure": "Si è verificato un errore durante il salvataggio delle impostazioni di {mediaServerName}.", + "components.Settings.jellyfinSettingsSuccess": "Impostazioni {mediaServerName} salvate con successo!", + "components.Settings.jellyfinSyncFailedAutomaticGroupedFolders": "Autenticazione personalizzata con raggruppamento automatico delle librerie non supportata", + "components.Settings.jellyfinSyncFailedGenericError": "Si è verificato un errore durante la sincronizzazione delle librerie", + "components.Settings.jellyfinlibraries": "Librerie di {mediaServerName}", + "components.Settings.jellyfinlibrariesDescription": "Le librerie {mediaServerName} cercano i titoli. Se non sono elencate librerie, fare clic sul pulsante sottostante.", + "components.Settings.manualscanDescriptionJellyfin": "Normalmente, questa operazione viene eseguita una volta ogni 24 ore. Jellyseerr controllerà in modo più aggressivo gli elementi aggiunti di recente al tuo server {mediaServerName}. Se è la prima volta che configuri Jellyseerr, ti consigliamo di eseguire una scansione manuale completa della libreria!", + "components.Settings.manualscanJellyfin": "Scansione Libreria Manuale", + "components.Settings.menuJellyfinSettings": "{mediaServerName}", + "components.Settings.menuNetwork": "Rete", + "components.Settings.syncJellyfin": "Sincronizza Librerie", + "components.Settings.timeout": "Tempo scaduto", + "components.Settings.tip": "Suggerimento", + "components.Setup.back": "Torna indietro", + "components.Setup.configemby": "Configura Emby", + "components.Setup.configjellyfin": "Configura Jellyfin", + "components.Setup.configuremediaserver": "Configura Media Server", + "components.Setup.servertype": "Scegli il tipo di server", + "components.Setup.signinWithJellyfin": "Inserisci le tue credenziali Jellyfin", + "components.Setup.subtitle": "Inizia scegliendo il tuo media server", + "components.StatusBadge.seasonnumber": "S{seasonNumber}", + "components.TitleCard.cleardata": "Cancella dati", + "components.TitleCard.watchlistCancel": "Lista per {title} eliminata.", + "components.TitleCard.watchlistError": "Qualcosa è andato storto. Riprova.", + "components.TvDetails.Season.noepisodes": "Elenco episodi non disponibile.", + "components.TvDetails.addtowatchlist": "Aggiungi alla Lista", + "components.TvDetails.play": "Riproduci su {mediaServerName}", + "components.TvDetails.play4k": "Riproduci in 4K su {mediaServerName}", + "components.TitleCard.watchlistDeleted": "{title} rimosso dalla lista con successo!", + "components.TvDetails.rtcriticsscore": "Tomatometer di Rotten Tomatoes", + "components.TvDetails.tmdbuserscore": "Punteggio utente TMDB", + "components.TvDetails.watchlistSuccess": "{title} aggiunto alla lista con successo!", + "components.UserList.importfromJellyfin": "Importa utenti da {mediaServerName}", + "components.UserList.importfromJellyfinerror": "Si è verificato un errore durante l'importazione degli utenti da {mediaServerName}.", + "components.UserList.mediaServerUser": "Utente {mediaServerName}", + "components.UserProfile.UserSettings.LinkJellyfinModal.password": "Password", + "components.TvDetails.watchlistError": "Qualcosa è andato storto. Riprova.", + "components.UserList.importfrommediaserver": "Importa utenti da {mediaServerName}", + "components.UserList.noJellyfinuserstoimport": "Non ci sono utenti {mediaServerName} da importare.", + "components.UserList.username": "Nome Utente", + "components.UserList.validationUsername": "È necessario fornire un nome utente", + "components.UserProfile.UserSettings.LinkJellyfinModal.description": "Inserisci le credenziali {mediaServerName} per collegare il tuo account a {applicationName}.", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorExists": "Questo account è già collegato a un utente {applicationName}", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnknown": "Si è verificato un errore sconosciuto", + "components.UserProfile.UserSettings.LinkJellyfinModal.passwordRequired": "È necessario fornire una password", + "components.UserProfile.UserSettings.LinkJellyfinModal.save": "Collega", + "components.UserProfile.UserSettings.LinkJellyfinModal.saving": "Aggiungendo…", + "components.UserProfile.UserSettings.LinkJellyfinModal.title": "Collega Account {mediaServerName}", + "components.UserProfile.UserSettings.LinkJellyfinModal.username": "Nome Utente", + "components.UserProfile.UserSettings.LinkJellyfinModal.usernameRequired": "È necessario fornire un nome utente", + "components.UserProfile.UserSettings.UserGeneralSettings.email": "Email", + "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegionTip": "Filtra i contenuti in base alla disponibilità della regione", + "components.UserProfile.UserSettings.UserGeneralSettings.mediaServerUser": "Utente {mediaServerName}", + "components.UserProfile.UserSettings.UserGeneralSettings.save": "Salva Modifiche", + "components.UserProfile.UserSettings.UserGeneralSettings.saving": "Salvando…", + "components.UserProfile.UserSettings.UserGeneralSettings.streamingRegion": "Regione di streaming", + "components.UserProfile.UserSettings.UserGeneralSettings.streamingRegionTip": "Mostra i siti di streaming in base alla disponibilità della regione", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmail": "Questo indirizzo e-mail è già stato utilizzato!", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmailEmpty": "Un altro utente ha già questo nome utente. Devi impostare un indirizzo e-mail", + "components.UserProfile.UserSettings.UserGeneralSettings.validationemailformat": "È richiesta un'email valida", + "components.UserProfile.UserSettings.UserGeneralSettings.validationemailrequired": "Email richiesta", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.errorUnknown": "Si è verificato un errore sconosciuto", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccounts": "Account Collegati", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccountsHint": "Questi account esterni sono collegati al tuo account {applicationName}.", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noLinkedAccounts": "Non hai alcun account esterno collegato al tuo account.", + "components.UserProfile.UserSettings.UserNotificationSettings.deviceDefault": "Predefinito del dispositivo", + "components.UserProfile.UserSettings.UserNotificationSettings.telegramMessageThreadIdTip": "Se nella tua chat di gruppo sono abilitati gli argomenti, puoi specificare qui l'ID di un thread/argomento", + "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramMessageThreadId": "L'ID del thread/argomento deve essere un numero intero positivo", + "components.UserProfile.localWatchlist": "Lista di {username}", + "i18n.addToBlacklist": "Aggiungi alle esclusioni", + "i18n.blacklist": "Esclusioni", + "i18n.blacklistError": "Qualcosa è andato storto. Riprova.", + "i18n.blacklistSuccess": "{title} è stato inserito con successo nelle esclusioni.", + "i18n.blacklisted": "Aggiunto alle esclusioni", + "i18n.removefromBlacklist": "Rimuovi dalle esclusioni", + "i18n.specials": "Speciali", + "components.Settings.SettingsMain.validationApplicationUrlTrailingSlash": "L'URL non deve terminare con una barra \"/\" finale" } diff --git a/src/i18n/locale/ja.json b/src/i18n/locale/ja.json index dc5a0a52c4..840505650c 100644 --- a/src/i18n/locale/ja.json +++ b/src/i18n/locale/ja.json @@ -99,7 +99,6 @@ "components.Settings.address": "アドレス", "components.Settings.addsonarr": "Sonarr サーバーを追加", "components.Settings.cancelscan": "スキャンをキャンセル", - "components.Settings.copied": "API キーをクリップボードにコピーされた。", "components.Settings.currentlibrary": "現在のライブラリー:{name}", "components.Settings.default": "デフォルト", "components.Settings.default4k": "デフォルト 4K", @@ -302,7 +301,6 @@ "components.Settings.Notifications.toastTelegramTestSuccess": "Telegram のテスト通知が送信されました。", "components.Settings.Notifications.toastEmailTestSuccess": "メールテスト通知が送信されました。", "components.Settings.Notifications.toastDiscordTestSuccess": "Discord のテスト通知が送信されました。", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea のテスト通知が送信されました。", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Pushbullet のテスト通知が送信されました。", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Pushover のテスト通知が送信されました。", "components.Settings.Notifications.NotificationsSlack.toastSlackTestSuccess": "Slack のテスト通知が送信されました。", @@ -310,14 +308,12 @@ "components.UserProfile.UserSettings.UserNotificationSettings.emailsettingsfailed": "メール通知設定の保存に失敗しました。", "components.UserProfile.UserSettings.UserNotificationSettings.discordsettingsfailed": "Discord の通知設定の保存に失敗しました。", "components.Settings.Notifications.telegramsettingsfailed": "Telegram の通知設定の保存に失敗しました。", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea の通知設定の保存に失敗しました。", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Pushbullet の通知設定の保存に失敗しました。", "components.Settings.Notifications.NotificationsPushover.pushoversettingsfailed": "Pushover の通知設定の保存に失敗しました。", "components.UserProfile.UserSettings.UserNotificationSettings.telegramsettingssaved": "Telegram の通知設定が保存されました。", "components.UserProfile.UserSettings.UserNotificationSettings.emailsettingssaved": "メール通知設定が保存されました。", "components.UserProfile.UserSettings.UserNotificationSettings.discordsettingssaved": "Discord の通知設定が保存されました。", "components.Settings.Notifications.telegramsettingssaved": "Telegram の通知設定が保存されました。", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea の通知設定が保存されました。", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "Pushbullet の通知設定が保存されました。", "components.Settings.Notifications.NotificationsPushover.pushoversettingssaved": "Pushover の通知設定が保存されました。", "components.ResetPassword.validationpasswordrequired": "パスワードを入力してください", @@ -562,7 +558,6 @@ "components.NotificationTypeSelector.issuecomment": "チケットのコメント", "components.NotificationTypeSelector.userissueresolvedDescription": "自分が報告したチケットが解決された際に通知を受ける", "components.PermissionEdit.viewissuesDescription": "他ユーザーが作成されたチケットを確認できる", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "エージェントを有効にする", "components.TvDetails.seasons": "{seasonCount, plural, one {#シーズン} other {#シーズン}}", "components.Search.search": "検索", "components.ManageSlideOver.opentautulli": "Tautulliで開く", @@ -578,7 +573,6 @@ "components.NotificationTypeSelector.userissuereopenedDescription": "自ら報告したチケットが再度開いた際に通知を受ける", "components.PermissionEdit.manageissuesDescription": "メディアのチケットを管理する権限を付与する", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL の末尾にスラッシュ( / )を入力してないでください", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "プロフィール名", "components.IssueList.sortModified": "最終更新", "components.IssueModal.CreateIssueModal.allepisodes": "すべてのエピソード", "components.IssueModal.CreateIssueModal.problemepisode": "該当エピソード", @@ -637,13 +631,6 @@ "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "Gotify のテスト通知を送信しました!", "components.Settings.Notifications.NotificationsGotify.token": "アプリケーショントークン", "components.Settings.Notifications.NotificationsGotify.url": "サーバーの URL", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "通知の種類は一つ以上を選択してください", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "ユーザーまたはデバイスベースの notification webhook URL を指定します。", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "有効な URL を入力してください", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "default プロファイルを使用しない場合のみ必要です。", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea テスト通知送信中…", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "ウェブフック URL", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea のテスト通知の送信に失敗しました。", "components.Settings.Notifications.NotificationsSlack.validationWebhookUrl": "有効な URL を入力してください", "components.Settings.RadarrModal.validationApplicationUrl": "有効な URL を入力してください", "components.Settings.Notifications.validationUrl": "有効な URL を入力してください", diff --git a/src/i18n/locale/ko.json b/src/i18n/locale/ko.json index 43bf6af99e..fede8d64bf 100644 --- a/src/i18n/locale/ko.json +++ b/src/i18n/locale/ko.json @@ -409,7 +409,6 @@ "components.Settings.SonarrModal.validationRootFolderRequired": "루트 폴더를 선택해야 합니다", "components.Settings.advancedTooltip": "이 설정을 잘못 구성하면 기능이 제대로 작동하지 않을 수 있습니다", "components.Settings.cancelscan": "스캔 취소", - "components.Settings.copied": "클립보드에 API 키를 복사했습니다.", "components.Settings.currentlibrary": "현재 라이브러리: {name}", "components.Settings.default4k": "기본 4K", "components.Settings.deleteServer": "{serverType} 서버 삭제", @@ -759,14 +758,7 @@ "components.Selector.starttyping": "검색하시려면 입력해주세요.", "components.Settings.Notifications.NotificationsGotify.agentenabled": "에이전트 활성화", "components.Settings.Notifications.NotificationsGotify.toastGotifyTestSuccess": "Gotify 테스트 알림이 전송되었습니다!", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "프로필을 사용하지 않는 경우 default 프로필이 필요", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea 알림 설정을 저장하지 못했습니다.", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL은 슬래시로 끝나서는 안 됩니다", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "에이전트 활성화", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "프로필 이름", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea 테스트 알림이 전송되었습니다!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "적어도 하나 이상의 알림 유형을 선택해야 합니다", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "사용자 또는 장치 기반 notification webhook URL", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "채널 태그", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Pushbullet 테스트 알림이 전송되었습니다!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet 테스트 알림을 보내지 못했습니다.", @@ -1012,10 +1004,6 @@ "components.Settings.Notifications.NotificationsGotify.gotifysettingsfailed": "Gotify 알림 설정을 저장하지 못했습니다.", "components.Settings.Notifications.NotificationsGotify.token": "애플리케이션 토큰", "components.Settings.Notifications.NotificationsGotify.url": "서버 URL", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea 테스트 알림을 보내지 못했습니다.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea 알림 설정이 성공적으로 저장되었습니다!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea 테스트 알림을 보내는 중…", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "웹훅 URL", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "에이전트 활성화", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "액세스 토큰", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "사용자의 토큰 생성 Account Settings", @@ -1059,7 +1047,6 @@ "components.Settings.RadarrModal.validationMinimumAvailabilityRequired": "최소 요구 사항을 선택해야 합니다", "components.ResetPassword.requestresetlinksuccessmessage": "만약 입력된 이메일 주소가 유효한 사용자와 연결되어 있다면, 비밀번호 재설정 링크가 해당 이메일 주소로 전송될 것입니다.", "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "애플리케이션 토큰을 입력해야 합니다", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "유효한 URL을 입력해야 합니다", "components.Settings.Notifications.NotificationsPushover.validationUserTokenRequired": "유효한 사용자 또는 그룹 키를 입력해야 합니다", "components.Settings.Notifications.NotificationsWebhook.validationWebhookUrl": "유효한 URL을 입력해야 합니다", "components.Settings.Notifications.validationSmtpHostRequired": "유효한 호스트 네임 또는 IP 주소를 입력해야 합니다", @@ -1181,11 +1168,9 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "유효한 PGP 공개 키를 입력해야 합니다", "components.UserProfile.UserSettings.UserNotificationSettings.validationPushbulletAccessToken": "액세스 토큰을 입력해야 합니다", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "이 사용자 계정에는 현재 암호가 설정되어 있지 않습니다. 이 계정이 \"로컬 사용자\"로 로그인할 수 있도록 하려면 아래 암호를 구성하세요", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "웹 푸시 알림 설정을 저장하지 못했습니다.", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "새 암호", "components.UserProfile.UserSettings.UserPasswordChange.validationConfirmPassword": "새 비밀번호를 확인해야 합니다", "components.UserProfile.UserSettings.menuChangePass": "비밀번호", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "웹 푸시 알림 설정이 성공적으로 저장되었습니다!", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSetOwnAccount": "당신의 계정에는 현재 비밀번호가 설정되어 있지 않습니다. 이메일 주소를 사용하여 \"로컬 사용자\" 로 로그인하려면 아래 비밀번호를 구성하세요.", "components.UserProfile.UserSettings.UserPasswordChange.nopermissionDescription": "이 사용자의 암호를 수정할 수 있는 권한이 없습니다.", "components.UserProfile.UserSettings.UserPasswordChange.password": "비밀번호", diff --git a/src/i18n/locale/nb_NO.json b/src/i18n/locale/nb_NO.json index 7b13cbce48..1da5483873 100644 --- a/src/i18n/locale/nb_NO.json +++ b/src/i18n/locale/nb_NO.json @@ -99,7 +99,6 @@ "components.Settings.address": "Adresse", "components.Settings.addsonarr": "Legg til Sonarr-tjener", "components.Settings.cancelscan": "Avbryt skanning", - "components.Settings.copied": "API-nøkkel kopiert til utklippstavle.", "components.Settings.currentlibrary": "Nåværende bibliotek: {name}", "components.Settings.default": "Standard", "components.Settings.default4k": "Standard 4K", @@ -564,18 +563,6 @@ "components.UserProfile.ProfileHeader.userid": "BrukerID: {userid}", "components.UserProfile.unlimited": "Ubegrenset", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Gå til Pushbullet sinekontoinnstillinger for opprette en tilgangsnøkkel", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Ditt bruker- eller enhetsbaserte webhook-nettadresse for varsler", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook-nettadresse", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Du må oppgi en gyldig nettadresse", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Du må velge minst én varseltype", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Test-varsel ble sendt med LunaSea!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea sender test-varsel…", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Kunne ikke lagre instillingene for LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Innstillingene for LunaSea ble lagret!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea mislykkes med å sende test-varsel.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Kun nødvendig dersom en annen profil enn default er i bruk", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profilnavn", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Aktiver Tjeneste", "components.RequestModal.edit": "Rediger forespørsel", "components.RequestList.RequestItem.requesteddate": "Forespurt", "components.RequestList.RequestItem.editrequest": "Rediger forespørsel", @@ -857,8 +844,6 @@ "components.UserProfile.UserSettings.UserPasswordChange.password": "Passord", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Gjenta Passord", "components.UserProfile.UserSettings.UserPasswordChange.nopermissionDescription": "Du har ikke tillatelse til å endre denne brukerens passord.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Kunne ikke lagre instillingene for Web Push.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Innstillingene for Web Push ble lagret!", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Nytt Passord", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Nåværende Passord", "components.UserProfile.UserSettings.UserPasswordChange.toastSettingsFailure": "Noe gikk galt under lagring av passordet.", @@ -1151,5 +1136,6 @@ "components.Discover.FilterSlideover.firstAirDate": "Første Sendingsdato", "components.Discover.FilterSlideover.from": "Fra", "components.Discover.FilterSlideover.genres": "Sjangere", - "components.Discover.PlexWatchlistSlider.plexwatchlist": "Din Visningsliste" + "components.Discover.PlexWatchlistSlider.plexwatchlist": "Din Visningsliste", + "components.Discover.FilterSlideover.ratingText": "Vurderinger mellom {minValue} og {maxValue}" } diff --git a/src/i18n/locale/nl.json b/src/i18n/locale/nl.json index 250974394f..9edea1d626 100644 --- a/src/i18n/locale/nl.json +++ b/src/i18n/locale/nl.json @@ -99,7 +99,6 @@ "components.Settings.address": "Adres", "components.Settings.addsonarr": "Sonarr-server toevoegen", "components.Settings.cancelscan": "Scan annuleren", - "components.Settings.copied": "API-sleutel gekopieerd naar klembord.", "components.Settings.currentlibrary": "Huidige bibliotheek: {name}", "components.Settings.default": "Standaard", "components.Settings.default4k": "Standaard 4K", @@ -716,17 +715,8 @@ "components.Settings.webpush": "Web-push", "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Instellingen voor web-pushmeldingen opgeslagen!", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Instellingen voor web-pushmeldingen zijn niet opgeslagen.", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profielnaam", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Dienst inschakelen", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Instellingen voor web-pushmeldingen opgeslagen!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Instellingen voor web-pushmeldingen konden niet worden opgeslagen.", "components.Settings.noDefault4kServer": "Een 4K-{serverType}server moet als standaard worden gemarkeerd om gebruikers toe te laten om 4K-{mediaType} aan te vragen.", "components.Settings.is4k": "4K", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Alleen vereist als je niet het default profiel gebruikt", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook-URL", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Je moet een geldige URL opgeven", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Instellingen voor meldingen LunaSea opgeslagen!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Instellingen voor meldingen LunaSea niet opgeslagen.", "components.Settings.SettingsUsers.newPlexLoginTip": "{mediaServerName}-gebruikers toestaan zich aan te melden zonder eerst geïmporteerd te zijn", "components.Settings.SettingsUsers.newPlexLogin": "Nieuwe {mediaServerName}-aanmelding inschakelen", "components.Settings.Notifications.toastTelegramTestSuccess": "Testmelding Telegram verzonden!", @@ -751,11 +741,8 @@ "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSending": "Testmelding Pushover verzenden…", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Testmelding Pushover niet verzonden.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Testmelding Pushbullet verzonden!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Testmelding LunaSea verzenden…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Testmelding Pushbullet verzenden…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Testmelding Pushbullet niet verzonden.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Testmelding LunaSea verzonden!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Testmelding LunaSea niet verzonden.", "components.PermissionEdit.requestMoviesDescription": "Toestemming geven om niet-4K-films aan te vragen.", "components.PermissionEdit.requestTvDescription": "Toestemming geven om niet-4K-series aan te vragen.", "components.PermissionEdit.requestTv": "Series aanvragen", @@ -769,7 +756,6 @@ "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Je gebruikers- of groepsidentifier van 30 tekens", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Een toepassing registreren om te gebruiken met Jellyseerr", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Maak een token aan vanuit je accountinstellingen", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Je 'User' of 'Device' meldingswebhook-URL", "components.Settings.Notifications.encryptionTip": "In de meeste gevallen gebruikt impliciete TLS poort 465 en STARTTLS poort 587", "components.Settings.Notifications.encryptionOpportunisticTls": "Altijd STARTTLS gebruiken", "components.Settings.Notifications.encryptionNone": "Geen", @@ -795,7 +781,6 @@ "components.Settings.Notifications.NotificationsSlack.validationTypes": "Je moet ten minste één meldingstype selecteren", "components.Settings.Notifications.NotificationsPushover.validationTypes": "Je moet ten minste één meldingstype selecteren", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Je moet ten minste één meldingstype selecteren", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Je moet ten minste één meldingstype selecteren", "components.NotificationTypeSelector.usermediarequestedDescription": "Een melding ontvangen wanneer andere gebruikers nieuwe media-aanvragen indienen waarvoor goedkeuring vereist is.", "components.NotificationTypeSelector.usermediafailedDescription": "Een melding ontvangen wanneer media-aanvragen niet kunnen worden toegevoegd aan Radarr of Sonarr.", "components.NotificationTypeSelector.usermediadeclinedDescription": "Een melding ontvangen wanneer je media-aanvragen worden geweigerd.", @@ -1306,7 +1291,6 @@ "components.Login.hostname": "{mediaServerName} URL", "components.Login.port": "Poort", "components.Login.servertype": "Servertype", - "components.Login.validationHostnameRequired": "Je moet een geldige hostnaam of IP-adres opgeven", "components.Login.validationPortRequired": "Je moet een geldig poortnummer opgeven", "components.Login.validationUrlBaseLeadingSlash": "URL-basis moet beginnen met een schuine streep", "components.Login.validationUrlTrailingSlash": "URL mag niet eindigen met een schuine streep", @@ -1444,7 +1428,6 @@ "components.Settings.OverrideRuleTile.qualityprofile": "Kwaliteitsprofiel", "components.Settings.OverrideRuleTile.rootfolder": "Hoofdmap", "components.Settings.OverrideRuleTile.settings": "Instellingen", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Geavanceerde netwerkinstellingen", "components.Settings.SettingsNetwork.csrfProtection": "CSRF-bescherming inschakelen", "components.Settings.SettingsNetwork.docs": "documentatie", "components.Settings.SettingsNetwork.csrfProtectionTip": "Stel externe API-toegang in op alleen-lezen (HTTPS vereist)", diff --git a/src/i18n/locale/pl.json b/src/i18n/locale/pl.json index adb70fa438..70ed0d8d3b 100644 --- a/src/i18n/locale/pl.json +++ b/src/i18n/locale/pl.json @@ -274,15 +274,6 @@ "components.ResetPassword.validationpasswordminchars": "Hasło jest zbyt krótkie; powinno mieć co najmniej 8 znaków", "components.ResetPassword.validationpasswordrequired": "Musisz podać hasło", "components.Search.search": "Szukaj", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Włącz agenta", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Wymagane tylko wtedy, gdy nie używasz profilu default", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Nie udało się zapisać ustawień powiadomień LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Ustawienia powiadomień LunaSea zostały pomyślnie zapisane!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Nie udało się wysłać powiadomienia testowego LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Wysyłanie powiadomienia testowego LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Wysłano powiadomienie testowe LunaSea!", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Musisz podać poprawny adres URL", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL Webhook", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Token dostępu (Access Token)", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": " Zarejestruj aplikację do użytku z Jellyseerr", "components.Settings.Notifications.NotificationsPushover.pushoversettingsfailed": "Nie udało się zapisać ustawień powiadomień Pushover.", @@ -329,7 +320,6 @@ "components.Settings.SettingsAbout.Releases.versionChangelog": "{version} Lista zmian", "components.RequestModal.QuotaDisplay.season": "sezon", "components.RequestModal.requestcancelled": "Prośba o {title} została anulowana.", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Musisz wybrać co najmniej jeden typ powiadomienia", "components.RequestModal.requestSuccess": "Prośba o {title} wysłana pomyślnie!", "components.RequestModal.season": "sezon", "components.ResetPassword.emailresetlink": "Link do odzyskiwania przez adres e-mail", @@ -340,10 +330,8 @@ "components.ResetPassword.email": "Adres e-mail", "components.ResetPassword.password": "Hasło", "components.ResetPassword.resetpasswordsuccessmessage": "Hasło zostało zresetowane pomyślnie!", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nazwa profilu", "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "Musisz podać token dostępu", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Musisz wybrać co najmniej jeden typ powiadomienia", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Twój adres URL obiektu webhook powiadomienia oparty na użytkowniku lub urządzeniu", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "Ustawienia powiadomień pushbullet zostały pomyślnie zapisane!", "components.Settings.Notifications.NotificationsPushover.agentenabled": "Włącz agenta", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Powiadomienie testowe Pushover wysłane!", @@ -617,7 +605,6 @@ "components.Settings.SonarrModal.validationNameRequired": "Musisz podać nazwę serwera", "components.Settings.SonarrModal.validationRootFolderRequired": "Musisz wybrać folder główny", "components.Settings.activeProfile": "Aktywny profil", - "components.Settings.copied": "Skopiowano klucz API do schowka.", "components.Settings.default": "Domyślny", "components.Settings.default4k": "Domyślne 4K", "components.Settings.deleteserverconfirm": "Czy na pewno chcesz usunąć ten serwer?", @@ -679,7 +666,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.sendSilentlyDescription": "Wysyłaj powiadomienia bez dźwięku", "components.UserProfile.UserSettings.UserNotificationSettings.telegramChatId": "Identyfikator czatu", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Potwierdź hasło", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Ustawienia powiadomień web push zostały pomyślnie zapisane!", "i18n.noresults": "Brak wyników.", "i18n.notrequested": "Brak próśb", "i18n.partiallyavailable": "Częściowo dostępne", @@ -802,7 +788,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverUserKey": "Musisz podać prawidłowy klucz użytkownika lub grupy", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Musisz podać prawidłowy identyfikator czatu", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Nie udało się zapisać ustawień powiadomień Web Push.", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Aktualne hasło", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Nowe hasło", "components.UserProfile.UserSettings.UserPasswordChange.toastSettingsSuccess": "Hasło zostało zapisane pomyślnie!", @@ -937,7 +922,7 @@ "components.RequestModal.selectmovies": "Wybierz film(y)", "components.RequestModal.requestmovies": "Prośba o {count} {count, plural, one {film} other {filmów}}", "components.IssueDetails.commentplaceholder": "Dodaj komentarz…", - "components.MovieDetails.productioncountries": "Produkcja {countryCount, plural, one {kraj} other {kraje}}", + "components.MovieDetails.productioncountries": "{countryCount, plural, one {Kraj} other {Kraje}} produkcji", "components.RequestModal.requestseasons4k": "Prośba o {seasonCount} {seasonCount, plural, one {sezon} other {sezony}} w 4K", "components.TvDetails.productioncountries": "Produkcja {countryCount, plural, one {kraj} other {kraje}}", "components.RequestModal.approve": "Zatwierdź prośbę", @@ -1223,13 +1208,12 @@ "components.Settings.manualscanDescriptionJellyfin": "Zwykle będzie to uruchamiane tylko raz na 24 godziny. Jellyseerr będzie bardziej agresywnie sprawdzać ostatnio dodane biblioteki serwera {mediaServerName}. Jeśli po raz pierwszy konfigurujesz Jellyseerr, zalecane jest jednorazowe pełne ręczne skanowanie biblioteki!", "components.Discover.DiscoverTv.activefilters": "{count, plural, one {# Aktywny filtr} other {# Aktywne filtry}}", "components.Login.back": "Wróć", - "components.Login.validationHostnameRequired": "Musisz wprowadzić prawidłowy adres IP lub nazwę hosta", "components.MovieDetails.watchlistDeleted": "{title} został z powodzeniem usunięty z listy Do obejrzenia!", "components.MovieDetails.watchlistSuccess": "{title} został z powodzeniem dodany do listy Do obejrzenia!", "components.Settings.SettingsJobsCache.editJobScheduleSelectorSeconds": "Co {jobScheduleSeconds, plural, one {sekundę} other {{jobScheduleSeconds} sekundy}}", "components.Settings.SettingsJobsCache.image-cache-cleanup": "Czyszczenie pamięci podręcznej obrazów", "components.Settings.SettingsJobsCache.imagecache": "Pamięć podręczna obrazów", - "components.Discover.DiscoverMovies.activefilters": "{count, plural, one {# Aktywny filtr} other {# Aktywne filtry}}", + "components.Discover.DiscoverMovies.activefilters": "{count, plural, one {# aktywny filtr} few {# aktywne filtry} other {# aktywnych filtrów}}", "components.Login.enablessl": "Użyj SSL", "components.Login.invalidurlerror": "Niepowodzenie połączenia z serwerem {mediaServerName}.", "components.Login.port": "Port", diff --git a/src/i18n/locale/pt_BR.json b/src/i18n/locale/pt_BR.json index 630d3dd3d5..e6dc5d0f58 100644 --- a/src/i18n/locale/pt_BR.json +++ b/src/i18n/locale/pt_BR.json @@ -49,7 +49,6 @@ "components.Settings.default4k": "Padrão 4K", "components.Settings.default": "Padrão", "components.Settings.currentlibrary": "Biblioteca Atual: {name}", - "components.Settings.copied": "Chave de API copiada.", "components.Settings.cancelscan": "Cancelar Escaneamento", "components.Settings.addsonarr": "Adicionar Servidor Sonarr", "components.Settings.address": "Endereço", @@ -709,7 +708,6 @@ "components.Settings.RadarrModal.enableSearch": "Habilitar Busca Automática", "components.PermissionEdit.requestMovies": "Solicitar Filmes", "components.DownloadBlock.estimatedtime": "Estimativa {time}", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Configurações de notificação via web push salvas com sucesso!", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", "components.UserProfile.UserSettings.UserGeneralSettings.languageDefault": "Padrão ({language})", "components.UserProfile.UserSettings.UserGeneralSettings.applanguage": "Idioma da Interface", @@ -726,7 +724,6 @@ "components.Settings.Notifications.encryption": "Método de Encriptação", "components.Settings.Notifications.botApiTip": "Criar um bot para usar com Jellyseerr", "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Configurações de notificação via web push salvas com sucesso!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Falha ao salvar configurações de notificação via web push.", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Falha ao salvar configurações de notificação via web push.", "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "Para receber notificações via web push, o Jellyseerr deve ser acessível via HTTPS.", "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "Criar integração para um webhook de entrada", @@ -757,18 +754,7 @@ "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Falha ao enviar notificação de teste via Pushover.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Falha ao enviar notificação de teste via Pushbullet.", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Criar um token à partir de sua Configuração de Conta", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Sua URL de webhook para notificação baseada em usuário ou dispositivo", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL de Webhook", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Você deve prover uma URL válida", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Notificação de teste via LunaSea enviada!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Enviando notificação de teste via LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Falha ao enviar notificação de teste via LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Configurações de notificação via LunaSea salvas com sucesso!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Falha ao salvar configurações de notificação via LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Necessário apenas quando não estiver usando o perfil default", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nome de Perfil", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Habilitar Agente", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Habilitar Agente", "components.PermissionEdit.requestTvDescription": "Concede permissão para solicitar séries em não 4K.", "components.PermissionEdit.requestTv": "Solicitar Séries", "components.PermissionEdit.requestMoviesDescription": "Concede permissão para solicitar filmes em não 4K.", @@ -786,7 +772,6 @@ "components.Settings.Notifications.NotificationsSlack.validationTypes": "Você deve selecionar ao menos um tipo de notificação", "components.Settings.Notifications.NotificationsPushover.validationTypes": "Você deve selecionar ao menos um tipo de notificação", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Você deve selecionar ao menos um tipo de notificação", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Você deve selecionar ao menos um tipo de notificação", "components.QuotaSelector.tvRequests": "{quotaLimit} {temporadas} a cada {quotaDays} {dias}", "components.QuotaSelector.seasons": "{count, plural, one {temporada} other {temporadas}}", "components.QuotaSelector.movies": "{count, plural, one {file} other {filmes}}", @@ -1254,7 +1239,6 @@ "components.TitleCard.addToWatchList": "Adicionar a lista para assistir", "components.Login.port": "Porta", "components.Login.servertype": "Tipo de Servidor", - "components.Login.validationHostnameRequired": "Você deve fornecer um nome de host ou endereço IP válido", "components.Login.validationPortRequired": "Você deve fornecer um número de porta válido", "components.Login.validationUrlBaseTrailingSlash": "A URL base não deve terminar com uma barra", "components.Login.validationUrlTrailingSlash": "A URL não deve terminar com uma barra", diff --git a/src/i18n/locale/pt_PT.json b/src/i18n/locale/pt_PT.json index a602ab2780..3851d11db4 100644 --- a/src/i18n/locale/pt_PT.json +++ b/src/i18n/locale/pt_PT.json @@ -236,7 +236,6 @@ "components.Settings.default4k": "Predefinição 4K", "components.Settings.default": "Predefinição", "components.Settings.currentlibrary": "Biblioteca Atual: {name}", - "components.Settings.copied": "Chave API copiada.", "components.Settings.addsonarr": "Adicionar Servidor Sonarr", "components.Settings.address": "Endereço", "components.Settings.addradarr": "Adicionar Servidor Radarr", @@ -716,15 +715,6 @@ "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Definições de notificação web push gravadas com sucesso!", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Falha ao gravar as definições de notificação web push.", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Ativar Agente", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Requerido apenas se não estiver a usar o perfil default", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Definições de notificação LunaSea gravadas com sucesso!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Falha ao gravar as definições de notificação do LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL de Webhook", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Deve fornecer uma URL valido", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nome do Perfil", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Ativar Agente", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Definições de notificação web push gravadas com sucesso!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Falha ao gravar as definições de notificação web push.", "components.Settings.noDefault4kServer": "Um servidor 4K {serverType} deve ser marcado como predefinido para permitir que os utilizador enviem pedidos 4K de {mediaType}.", "components.Settings.is4k": "4K", "components.Settings.SettingsUsers.newPlexLoginTip": "Permitir que Utilizadores do {mediaServerName} iniciem sessão sem primeiro serem importados", @@ -737,7 +727,6 @@ "components.Settings.Notifications.NotificationsSlack.toastSlackTestSuccess": "Notificação de teste Slack enviada!", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Notificação de teste Pushover enviada!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Notificação de teste Pushbullet enviada!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Notificação de teste LunaSea enviada!", "components.Settings.Notifications.toastTelegramTestSending": "A enviar notificação de teste Telegram…", "components.Settings.Notifications.toastEmailTestSending": "A enviar notificação de teste e-mail…", "components.Settings.Notifications.toastDiscordTestSending": "A enviar notificação de teste Discord…", @@ -745,7 +734,6 @@ "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "A enviar notificação de teste web push…", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSending": "A enviar notificação de teste Pushover…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "A enviar notificação de teste Pushbullet…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "A enviar notificação de teste ao LunaSea…", "components.Settings.Notifications.toastTelegramTestFailed": "Falha ao enviar notificação de teste Telegram.", "components.Settings.Notifications.toastEmailTestFailed": "Falha ao enviar notificação de teste e-mail.", "components.Settings.Notifications.toastDiscordTestFailed": "Falha ao enviar notificação de teste Discord.", @@ -755,7 +743,6 @@ "components.Settings.Notifications.NotificationsSlack.toastSlackTestFailed": "Falha ao enviar notificação de teste Slack.", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Falha ao enviar notificação de teste Pushover.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Falha ao enviar notificação de teste Pushbullet.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Falha ao enviar notificação de teste ao LunaSea.", "components.PermissionEdit.requestTvDescription": "Conceder permissão para pedir séries não 4K.", "components.PermissionEdit.requestTv": "Pedir Séries", "components.PermissionEdit.requestMoviesDescription": "Conceder permissão para pedir filmes não 4K.", @@ -778,7 +765,6 @@ "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "Criar integração para um Webhook de Entrada", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "O seu identificador de utilizador ou grupo contendo 30 caractéres", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Criar um token a partir das suas Definições de Conta", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Sua URL de webhook para notificação baseada em utilizador ou dispositivo", "components.RequestList.RequestItem.requesteddate": "Pedido", "components.RequestCard.failedretry": "Ocorreu um erro ao voltar a tentar o pedido.", "components.DownloadBlock.estimatedtime": "Estimativa {time}", @@ -795,7 +781,6 @@ "components.Settings.Notifications.NotificationsSlack.validationTypes": "Deve selecionar pelo menos um tipo de notificação", "components.Settings.Notifications.NotificationsPushover.validationTypes": "Deve selecionar pelo menos um tipo de notificação", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Deve selecionar pelo menos um tipo de notificação", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Deve selecionar pelo menos um tipo de notificação", "components.NotificationTypeSelector.usermediarequestedDescription": "Notificar quando outros utilizadores enviarem novos pedidos de multimédia que requeiram aprovação.", "components.NotificationTypeSelector.usermediafailedDescription": "Notificar quando os pedidos de multimédia não forem adicionados ao Radarr ou Sonarr.", "components.NotificationTypeSelector.usermediadeclinedDescription": "Notificar quando seus pedidos de multimédia forem recusados.", diff --git a/src/i18n/locale/ro.json b/src/i18n/locale/ro.json index c6b22bb340..027b078b67 100644 --- a/src/i18n/locale/ro.json +++ b/src/i18n/locale/ro.json @@ -441,7 +441,6 @@ "components.RequestModal.errorediting": "Ceva nu a funcționat în cursul editării solicitării.", "components.RequestModal.selectseason": "Selectați Sezoane", "components.Settings.Notifications.NotificationsGotify.validationTypes": "Trebuie să selectați cel puțin un tip de notificare", - "components.Login.validationHostnameRequired": "Trebuie să introduceți un hostname sau o adresă IP valide", "components.RequestModal.AdvancedRequester.languageprofile": "Profil Limbă", "components.RequestModal.QuotaDisplay.requiredquota": "Trebuie să aveți cel puțin {seasons} {seasons, plural, one {season request} other {season requests}} rămase pentru a putea trimite o solicitare pentru această serie.", "components.RequestModal.requestmovies": "Solicitați {count} {count, plural, one {Movie} alte {Movies}}", @@ -456,10 +455,8 @@ "components.RequestModal.SearchByNameModal.notvdbiddescription": "Nu am reușit să găsim automat un rezultat pentru aceast serial. Vă rugăm să selectați mai jos rezultatul corect.", "components.RequestModal.edit": "Editați Solicitare", "components.Settings.Notifications.NotificationsGotify.gotifysettingsfailed": "Setările de notificare Gotify nu au reușit să fie salvate.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Setările de notificare LunaSea au fost salvate cu success!", "components.RequestModal.QuotaDisplay.quotaLinkUser": "Puteți vizualiza un rezumat al limitelor de solicitare ale acestui utilizator pe pagina sa profile.", "components.Selector.showmore": "Afișează mai mult", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Testul de notificare LunaSea a fost trimis!", "components.RequestCard.tmdbid": "ID TMDB", "components.RequestCard.tvdbid": "ID TheTVDB", "components.ResetPassword.email": "Adresă Email", @@ -585,15 +582,6 @@ "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "Trebuie să furnizați un token de aplicație", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "Trebuie să furnizați un URL valid", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL-ul nu trebuie să se termine cu o bară oblică", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Activați Agentul", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Nume Profil", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Necesar doar dacă nu este folosit profilul default", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Setările de notificare LunaSea nu au reușit să fie salvate.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Setările de notificare LunaSea nu au reușit să fie trimise.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Trimitere test notificare LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Trebuie să selectați cel puțin un tip de notificare", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Trebuie să furnizați un URL valid", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL Webhook", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Token Acces", "components.Settings.Notifications.NotificationsPushbullet.channelTag": "Etichetă Canal", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "Setările de notificare Pushbullet au fost salvate cu success!", @@ -618,5 +606,10 @@ "components.Settings.Notifications.NotificationsSlack.agentenabled": "Activați Agentul", "components.Settings.Notifications.NotificationsSlack.slacksettingsfailed": "Setările de notificare Slack nu au reușit să fie salvate.", "components.Settings.Notifications.NotificationsSlack.slacksettingssaved": "Setările de notificare Slack au fost salvate cu success!", - "components.Discover.FilterSlideover.status": "Status" + "components.Discover.FilterSlideover.status": "Status", + "components.Blacklist.mediaName": "Nume", + "components.Blacklist.mediaType": "Tip", + "components.Blacklist.blacklistedby": "{date} de către {user}", + "components.Blacklist.blacklistdate": "dată", + "components.Blacklist.mediaTmdbId": "Id tmdb" } diff --git a/src/i18n/locale/ru.json b/src/i18n/locale/ru.json index efdb032e65..e8f1b27c38 100644 --- a/src/i18n/locale/ru.json +++ b/src/i18n/locale/ru.json @@ -99,7 +99,6 @@ "components.Settings.address": "Адрес", "components.Settings.addsonarr": "Добавить сервер Sonarr", "components.Settings.cancelscan": "Отменить сканирование", - "components.Settings.copied": "Ключ API скопирован в буфер обмена.", "components.Settings.currentlibrary": "Текущая библиотека: {name}", "components.Settings.default": "По умолчанию", "components.Settings.default4k": "4К по умолчанию", @@ -274,8 +273,6 @@ "components.StatusBadge.status4k": "4K {status}", "pages.errormessagewithcode": "{statusCode} - {error}", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Токен доступа", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Вы должны указать действительный URL-адрес", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Название профиля", "components.ResetPassword.resetpasswordsuccessmessage": "Пароль сброшен успешно!", "components.ResetPassword.passwordreset": "Сбросить пароль", "components.RequestModal.edit": "Редактировать запрос", @@ -498,7 +495,6 @@ "components.Settings.Notifications.NotificationsWebhook.validationTypes": "Вы должны выбрать хотя бы один тип уведомлений", "components.Settings.Notifications.NotificationsSlack.validationTypes": "Вы должны выбрать хотя бы один тип уведомлений", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Вы должны выбрать хотя бы один тип уведомлений", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Вы должны выбрать хотя бы один тип уведомлений", "components.Settings.Notifications.NotificationsPushover.validationTypes": "Вы должны выбрать хотя бы один тип уведомлений", "components.Settings.Notifications.NotificationsPushover.validationAccessTokenRequired": "Вы должны предоставить действительный токен приложения", "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Ваш тридцатизначный идентификатор пользователя или группы", @@ -512,8 +508,6 @@ "i18n.notrequested": "Не запрошен", "i18n.noresults": "Нет результатов.", "i18n.delimitedlist": "{a}, {b}", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL веб-перехватчика", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "URL веб-перехватчика для уведомлений на основе вашего пользователя или устройства", "components.Settings.Notifications.NotificationsPushover.accessToken": "Токен API приложения", "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "Вы должны предоставить токен доступа", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Тестовое уведомление отправлено в Pushbullet!", @@ -522,15 +516,8 @@ "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "Настройки уведомлений Pushbullet успешно сохранены!", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Не удалось сохранить настройки уведомлений Pushbullet.", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Создайте токен в настройках учётной записи", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Тестовое уведомление отправлено в LunaSea!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Отправка тестового уведомления в LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Не удалось отправить тестовое уведомление в LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Настройки уведомлений LunaSea успешно сохранены!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Не удалось сохранить настройки уведомлений LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Требуется только в том случае, если не используется профиль default", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Активировать службу", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Активировать службу", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Активировать службу", "components.Settings.notificationAgentSettingsDescription": "Настройте и активируйте службы уведомлений.", "components.ResetPassword.emailresetlink": "Отправить ссылку для восстановления по электронной почте", "pages.somethingwentwrong": "Что-то пошло не так", @@ -726,8 +713,6 @@ "components.UserProfile.UserSettings.UserPasswordChange.toastSettingsFailure": "Что-то пошло не так при сохранении пароля.", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "В настоящее время для этой учётной записи не установлен пароль. Установите пароль ниже, чтобы с этой учётной записью можно было войти в систему как \"локальный пользователь\".", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSetOwnAccount": "В настоящее время для вашей учётной записи не установлен пароль. Установите пароль ниже, чтобы иметь возможность войти в систему как \"локальный пользователь\", используя свой адрес электронной почты.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Настройки веб-push-уведомлений успешно сохранены!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Не удалось сохранить настройки веб-push-уведомлений.", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Веб-push", "components.UserProfile.UserSettings.UserNotificationSettings.telegramsettingssaved": "Настройки уведомлений Telegram успешно сохранены!", "components.UserProfile.UserSettings.UserNotificationSettings.telegramsettingsfailed": "Не удалось сохранить настройки уведомлений Telegram.", @@ -1304,7 +1289,6 @@ "components.Login.port": "Порт", "components.Login.servertype": "Тип сервера", "components.Login.urlBase": "Базовый URL", - "components.Login.validationHostnameRequired": "Вы должны указать корректный домен или IP адрес", "components.Login.validationPortRequired": "Вы должны указать корректный порт", "components.Login.validationUrlBaseTrailingSlash": "Базовый URL не может оканчиваться слэшем", "components.Login.validationUrlTrailingSlash": "URL не может оканчиваться слэшем", @@ -1397,7 +1381,6 @@ "i18n.blacklistDuplicateError": "{title} уже добавлен в черный список.", "components.Settings.SettingsJobsCache.usersavatars": "Аватары пользователей", "components.Settings.SettingsNetwork.toastSettingsFailure": "Что-то пошло не так при сохранении настроек.", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Расширенные сетевые настройки", "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "НЕ включайте эту настройку, если не знаете, для чего она нужна!", "components.Settings.SettingsNetwork.docs": "документация", "components.Settings.SettingsNetwork.forceIpv4First": "Принудительно использовать сначала IPv4", diff --git a/src/i18n/locale/sq.json b/src/i18n/locale/sq.json index 6241fcc68a..c33895ac68 100644 --- a/src/i18n/locale/sq.json +++ b/src/i18n/locale/sq.json @@ -317,13 +317,6 @@ "components.Settings.Notifications.NotificationsGotify.url": "URL e serverit", "components.Settings.Notifications.NotificationsGotify.validationTokenRequired": "Duhet të japësh një token aplikacioni", "components.Settings.Notifications.NotificationsGotify.validationTypes": "Duhet të zgjedhësh të paktën një tip njoftimi", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Emri i profilit", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Kërkohet vetëm nëse nuk përdoret profili default", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Cilësimet e njoftimit të LunaSea nuk u ruajtën.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Rregullimet e njoftimeve LunaSea u ruajtën me sukses!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Njoftimi i testit të LunaSea nuk u dërgua.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Duke dërguar njoftimin e testit LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Duhet të jepni një URL të vlefshme", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Token Aksesimi", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Krijo një token nga Cilësimet e llogarisë", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Aktivizo agjentin", @@ -419,8 +412,6 @@ "components.RequestModal.AdvancedRequester.selecttags": "Zgjidh etiketat", "components.RequestModal.requestcancelled": "Kërkesa për {title} u anullua.", "components.ResetPassword.password": "Fjalëkalimi", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Aktivizo agjentin", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Duhet të zgjedhësh të paktën një tip njoftimi", "components.Settings.RadarrModal.released": "Lëshuar", "components.RequestModal.QuotaDisplay.allowedRequestsUser": "Ky përdorues lejohet të kërkojë {limit} {type} çdo {days} ditë.", "components.RequestModal.QuotaDisplay.movie": "film", @@ -438,7 +429,6 @@ "components.ResetPassword.passwordreset": "Rivendos fjalëkalimin", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsSaved": "Cilësimet e njoftimit Pushbullet u ruajtën me sukses!", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "Duhet të jepni një URL të vlefshme", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "U dërgua njoftimi i testit LunaSea!", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL nuk duhet të përfundojë me një slesh", "components.Settings.Notifications.NotificationsPushbullet.pushbulletSettingsFailed": "Cilësimet e njoftimit Pushbullet nuk u ruajtën.", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Po dërgohet njoftimi i testit Pushbullet…", @@ -491,7 +481,6 @@ "components.Settings.tautulliApiKey": "Çelësi API", "components.Settings.tautulliSettings": "Cilësimet e Tautulli", "components.Settings.toastPlexRefresh": "Duke marrë listën e serverave nga Plex…", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL e Webhook", "components.Settings.notificationAgentSettingsDescription": "Konfiguro dhe aktivizo agjentët e njoftimit.", "components.Settings.plexlibrariesDescription": "Libraritë e Jellyseerr skanojnë për tituj. Vendos dhe ruaj cilësimet e lidhjes Plex, pastaj kliko në butonin më poshtë nëse nuk janë të listuara libraritë.", "components.Settings.plexsettingsDescription": "Konfiguro cilësimet për serverin tuaj Plex. Jellyseerr skanon libraritë tuaja Plex për të përcaktuar disponueshmërinë e përmbajtjes.", @@ -509,7 +498,6 @@ "components.IssueList.IssueItem.episodes": "{episodeCount, plural, one {Episod} other {Episode}}", "components.RequestModal.requestseasons4k": "Kërko {seasonCount} {seasonCount, plural, one {Sezon} other {Sezone}} në 4K", "components.RequestModal.requestseasons": "Kërko {seasonCount} {seasonCount, plural, one {Sezon} other {Sezone}}", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "URL e Njoftimit Webhook të bazuar në përdorues ose paisje", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "Duhet të zgjidhni të paktën një lloj njoftimi", "components.Settings.Notifications.NotificationsPushover.accessToken": "Token API i aplikacionit", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Regjistroni një aplikacion për ta përdorur me Jellyseerr", @@ -765,7 +753,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverUserKey": "Duhet të jepni një çelës të vlefshëm përdoruesi ose grupi", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Duhet të jepni një ID të vlefshme bisede", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Push", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Cilësimet e njoftimit në ueb nuk u ruajtën.", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Konfirmo fjalëkalimin", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Fjalëkalimi aktual", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Fjalëkalimi i ri", @@ -921,7 +908,6 @@ "components.Settings.address": "Adresa", "components.Settings.addsonarr": "Shto Serverin Sonarr", "components.Settings.cancelscan": "Anullo skanimin", - "components.Settings.copied": "Çelësi API u kopjua.", "components.Settings.currentlibrary": "Libraria aktuale: {name}", "components.Settings.default": "E paracaktuar", "components.Settings.default4k": "E Paracaktuar 4K", @@ -959,7 +945,6 @@ "components.TvDetails.firstAirDate": "Data e parë e transmetimit", "components.UserList.email": "Adresa email", "components.UserList.importedfromplex": "{userCount} {userCount, plural, one {përdorues} other {përdorues}} nga Plex u importuan me sukses!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Cilësimet e njoftimit në ueb u ruajtën me sukses!", "components.UserProfile.UserSettings.UserNotificationSettings.discordIdTip": "Numri i identifikimit me shumë shifra i lidhur me llogarinë tuaj të përdoruesit", "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "Duhet të jepni një çelës publik të vlefshëm PGP", "components.UserProfile.UserSettings.UserNotificationSettings.validationPushbulletAccessToken": "Duhet të japësh një Token hyrjeje", diff --git a/src/i18n/locale/sr.json b/src/i18n/locale/sr.json index 8bca478746..89599366f7 100644 --- a/src/i18n/locale/sr.json +++ b/src/i18n/locale/sr.json @@ -71,7 +71,6 @@ "components.Settings.default4k": "Podrazumevano 4K", "components.Settings.default": "Podrazumeno", "components.Settings.currentlibrary": "Trenutna biblioteka: {name}", - "components.Settings.copied": "Kopiran API ključ.", "components.Settings.cancelscan": "Otkaži skeniranje", "components.Settings.addsonarr": "Dodaj Sonarr server", "components.Settings.address": "Adresa", @@ -494,7 +493,6 @@ "i18n.notrequested": "Nije zahtevano", "components.Settings.Notifications.validationEmail": "Morate uneti validnu email adresu", "components.UserList.usercreatedfailedexisting": "Email adresa je već iskorišćena od strane drugog korisnika.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Šaljem LunaSea probno obaveštenje…", "components.CollectionDetails.requestcollection4k": "Zahtevaj kolekciju u 4K", "components.Login.signinheader": "Uloguj se za nastavak", "components.Login.signinwithoverseerr": "Iskoristi nalog od {applicationTitle}", diff --git a/src/i18n/locale/sv.json b/src/i18n/locale/sv.json index 31e4d96672..6cb7d0a793 100644 --- a/src/i18n/locale/sv.json +++ b/src/i18n/locale/sv.json @@ -31,7 +31,6 @@ "components.Settings.default4k": "Standard 4K", "components.Settings.default": "Standard", "components.Settings.currentlibrary": "Nuvarande bibliotek: {name}", - "components.Settings.copied": "API-nyckel kopierad till urklipp.", "components.Settings.cancelscan": "Avbryt skanning", "components.Settings.addsonarr": "Lägg till Sonarr-instans", "components.Settings.address": "Adress", @@ -131,7 +130,7 @@ "components.RequestBlock.seasons": "{seasonCount, plural, one {säsong} other {säsonger}}", "components.PersonDetails.ascharacter": "som {character}", "components.PersonDetails.appearsin": "Kan ses i", - "components.MovieDetails.studio": "{studioCount, plural, one {studio} other {studior}}", + "components.MovieDetails.studio": "{studioCount, plural, one {Studio} other {Studior}}", "components.MovieDetails.similar": "Liknande titlar", "components.MovieDetails.runtime": "{minutes} minuter", "components.MovieDetails.revenue": "Inkomster", @@ -152,7 +151,7 @@ "components.Discover.upcomingmovies": "Kommande filmer", "components.Discover.upcoming": "Kommande filmer", "components.Discover.trending": "Trendande", - "components.Discover.recentrequests": "Senaste förfrågningar", + "components.Discover.recentrequests": "Senaste förfrågningarna", "components.Discover.recentlyAdded": "Nyligen tillagda", "components.Discover.populartv": "Populära serier", "components.Discover.popularmovies": "Populära filmer", @@ -160,7 +159,7 @@ "components.TvDetails.TvCast.fullseriescast": "Rollista", "components.Setup.welcome": "Välkommen till Jellyseerr", "components.Setup.signinMessage": "Kom igång genom att logga in", - "components.RequestModal.requestseasons": "Begär {seasonCount} {seasonCount, plural, one {säsong} other {säsonger}}", + "components.RequestModal.requestseasons": "Begär {seasonCount} {seasonCount, plural, one {Säsong} other {Säsonger}}", "pages.returnHome": "Gå tillbaka till startsidan", "pages.oops": "Hoppsan", "i18n.unavailable": "Otillgänglig", @@ -194,7 +193,7 @@ "components.TvDetails.overviewunavailable": "Beskrivning saknas.", "components.TvDetails.overview": "Beskrivning", "components.TvDetails.originallanguage": "Originalspråk", - "components.TvDetails.network": "{networkCount, plural, one {nätverk} other {nätverk}}", + "components.TvDetails.network": "{networkCount, plural, one {Nätverk} other {Nätverk}}", "components.TvDetails.cast": "Roller", "i18n.close": "Stäng", "components.Settings.SettingsAbout.timezone": "Tidszon", @@ -225,9 +224,9 @@ "i18n.request": "Begär", "i18n.failed": "Misslyckades", "components.UserList.importedfromplex": "{userCount} Plex {userCount, plural, one {användare} other {användare}} importerades!", - "components.TvDetails.viewfullcrew": "Visa hela rollistan", + "components.TvDetails.viewfullcrew": "Visa hela teamet", "components.TvDetails.firstAirDate": "Första sändningsdatum", - "components.TvDetails.TvCrew.fullseriescrew": "Hela rollistan", + "components.TvDetails.TvCrew.fullseriescrew": "Hela teamet", "components.StatusBadge.status4k": "4K {status}", "components.Settings.SettingsAbout.documentation": "Dokumentation", "components.Settings.Notifications.validationChatIdRequired": "Du måste ange ett giltigt chatt-ID", @@ -279,10 +278,10 @@ "components.NotificationTypeSelector.mediaavailable": "Förfrågan tillgänglig", "components.NotificationTypeSelector.mediaapprovedDescription": "Skicka meddelanden när medieförfrågningar godkänns manuellt.", "components.NotificationTypeSelector.mediaapproved": "Förfrågan godkänd", - "components.MovieDetails.viewfullcrew": "Visa fullt filmteam", - "components.MovieDetails.MovieCrew.fullcrew": "Filmteam", + "components.MovieDetails.viewfullcrew": "Visa hela teamet", + "components.MovieDetails.MovieCrew.fullcrew": "Team", "components.UserList.userssaved": "Användarbehörigheter sparade!", - "components.UserList.bulkedit": "Mass-redigering", + "components.UserList.bulkedit": "Massredigering", "components.PermissionEdit.usersDescription": "Ge behörighet att hantera användare. Användare med denna behörighet kan inte ändra eller lägga till användare med adminrättigheter.", "components.PermissionEdit.users": "Hantera användare", "components.PermissionEdit.requestDescription": "Ge behörighet att skicka in förfrågningar för media som inte är 4K.", @@ -325,7 +324,7 @@ "components.UserList.createlocaluser": "Skapa lokal användare", "components.UserList.create": "Skapa", "components.UserList.autogeneratepassword": "Generera lösenord automatiskt", - "components.PersonDetails.crewmember": "Crew", + "components.PersonDetails.crewmember": "Teammedlem", "components.Login.validationemailrequired": "Du måste ange en giltig e-postadress", "components.Login.email": "E-postadress", "components.PermissionEdit.autoapproveSeriesDescription": "Ge automatiskt godkännande för serieförfrågningar som inte är 4K.", @@ -425,7 +424,7 @@ "components.Settings.serverRemote": "fjärr", "components.Settings.serverLocal": "lokal", "i18n.loading": "Laddar…", - "components.UserProfile.recentrequests": "Senaste förfrågningar", + "components.UserProfile.recentrequests": "Senaste förfrågningarna", "components.UserProfile.UserSettings.menuPermissions": "Behörigheter", "components.UserProfile.UserSettings.menuNotifications": "Meddelanden", "components.UserProfile.UserSettings.menuGeneralSettings": "Allmänt", @@ -506,7 +505,7 @@ "components.Settings.SettingsJobsCache.plex-full-scan": "Full biblioteksskanning för Plex", "components.Settings.SettingsJobsCache.jellyfin-full-scan": "Full Jellyfin-biblioteksskanning", "components.Settings.SettingsJobsCache.jellyfin-recently-added-scan": "Skanning av nyligen tillagda objekt i Jellyfin", - "components.Settings.SettingsJobsCache.download-sync-reset": "Återställ nedladdningssynkronisering", + "components.Settings.SettingsJobsCache.download-sync-reset": "Nollställ nedladdningssynkronisering", "components.Settings.SettingsJobsCache.download-sync": "Nedladdningssynkronisering", "components.Settings.SettingsAbout.preferredmethod": "Föredraget", "components.Settings.Notifications.validationUrl": "Du måste ange en giltig URL", @@ -554,7 +553,7 @@ "components.Discover.TvGenreSlider.tvgenres": "Seriegenrer", "components.RequestModal.AdvancedRequester.folder": "{path} ({space})", "components.TvDetails.episodeRuntimeMinutes": "{runtime} minuter", - "components.TvDetails.episodeRuntime": "Avsnittets speltid", + "components.TvDetails.episodeRuntime": "Avsnittslängd", "components.Settings.Notifications.pgpPrivateKeyTip": "Signera krypterade e-postmeddelanden med OpenPGP", "components.Settings.Notifications.pgpPrivateKey": "Privat PGP-nyckel", "components.Settings.Notifications.pgpPasswordTip": "Signera krypterade e-postmeddelanden med OpenPGP", @@ -587,7 +586,7 @@ "components.Settings.SettingsLogs.filterInfo": "Info", "components.Settings.SettingsLogs.filterError": "Fel", "components.Settings.SettingsLogs.filterDebug": "Felsök", - "components.Settings.SettingsJobsCache.jobsandcache": "Jobb & Cache", + "components.Settings.SettingsJobsCache.jobsandcache": "Jobb och cache", "components.Settings.SettingsAbout.about": "Om", "components.ResetPassword.passwordreset": "Återställning av lösenord", "components.Settings.SettingsLogs.logDetails": "Logginformation", @@ -716,27 +715,15 @@ "components.Settings.Notifications.NotificationsWebPush.webpushsettingssaved": "Webbpush-meddelandeinställningar har sparats!", "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "Webbpush-meddelandeinställningar kunde inte sparas.", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Aktivera Webbpush", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook-URL", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Du måste ange en giltig URL", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea-meddelandeinställningar har sparats!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea-meddelandeinställningar kunde inte sparas.", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Endast nödvändigt om du inte använder standard-profilen", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profilnamn", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Aktivera LunaSea", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "Skickar Pushbullet-testmeddelande…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet-testmeddelande kunde inte skickas.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea-testmeddelande skickat!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Skickar LunaSea-testmeddelande…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea-testmeddelande kunde inte skickas.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Webbpush-meddelandeinställningar har sparats!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Webbpush-meddelandeinställningar kunde inte sparas.", "components.Settings.noDefault4kServer": "En 4K {serverType}-instans måste markeras som standard för att användare ska kunna skicka in 4K {mediaType}-förfrågningar.", "components.Settings.is4k": "4K", "components.Settings.Notifications.toastTelegramTestSuccess": "Telegram-testmeddelande skickat!", "components.Settings.Notifications.toastTelegramTestSending": "Skickar Telegram-testmeddelande…", "components.Settings.Notifications.toastTelegramTestFailed": "Telegram-testmeddelande kunde inte skickas.", "components.Settings.Notifications.toastEmailTestSuccess": "E-posttestmeddelande skickat!", - "components.Settings.Notifications.toastEmailTestSending": "kickar e-posttestmeddelande…", + "components.Settings.Notifications.toastEmailTestSending": "Skickar e-posttestmeddelande…", "components.Settings.Notifications.toastEmailTestFailed": "E-posttestmeddelande kunde inte skickas.", "components.Settings.Notifications.toastDiscordTestSuccess": "Discord-testmeddelande skickat!", "components.Settings.Notifications.toastDiscordTestSending": "Skickar Discord-testmeddelande…", @@ -774,7 +761,6 @@ "components.Settings.Notifications.NotificationsPushover.userTokenTip": "Din användare eller gruppidentifierare (30 tecken)", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Registrera en applikation för användning med Jellyseerr", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Skapa en token från dina kontoinställningar", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Din användar- eller enhetsbaserade webhook-URL för meddelanden", "components.DownloadBlock.estimatedtime": "Beräknad {time}", "components.Settings.webAppUrlTip": "Alternativt skicka användare till den lokala webbappen istället för den \"hostade\" webbappen", "components.Settings.webAppUrl": "Webbapp-URL", @@ -789,7 +775,6 @@ "components.QuotaSelector.seasons": "{count, plural, one {säsong} other {säsonger}}", "components.QuotaSelector.movies": "{count, plural, one {film} other {filmer}}", "components.QuotaSelector.days": "{count, plural, one {dag} other {dagar}}", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Du måste välja minst en meddelandetyp", "components.Settings.Notifications.validationTypes": "Du måste välja minst en meddelandetyp", "components.Settings.Notifications.NotificationsWebhook.validationTypes": "Du måste välja minst en meddelandetyp", "components.Settings.Notifications.NotificationsSlack.validationTypes": "Du måste välja minst en meddelandetyp", @@ -848,7 +833,7 @@ "components.IssueDetails.reopenissueandcomment": "Återöppna med kommentar", "components.IssueDetails.season": "Säsong {seasonNumber}", "components.IssueDetails.toasteditdescriptionsuccess": "Ärendebeskrivning redigerad!", - "components.IssueList.IssueItem.seasons": "{seasonCount, plural, one {säsong} other {säsonger}}", + "components.IssueList.IssueItem.seasons": "{seasonCount, plural, one {Säsong} other {Säsonger}}", "components.IssueList.IssueItem.unknownissuetype": "Okänd", "components.IssueList.IssueItem.openeduserdate": "{date} av {user}", "components.IssueList.IssueItem.viewissue": "Visa ärende", @@ -943,7 +928,7 @@ "components.RequestModal.requestApproved": "Förfrågan för {title} godkänd!", "components.RequestModal.requestmovies": "Begär {count} {count, plural, one {film} other {filmer}}", "components.RequestModal.requestmovies4k": "Begär {count} {count, plural, one {film} other {filmer}} i 4K", - "components.RequestModal.requestseasons4k": "Begär {seasonCount} {seasonCount, plural, one {säsong} other {säsonger}} i 4K", + "components.RequestModal.requestseasons4k": "Begär {seasonCount} {seasonCount, plural, one {Säsong} other {Säsonger}} i 4K", "components.Settings.RadarrModal.inCinemas": "På bio", "components.Settings.RadarrModal.released": "Släppt", "components.Settings.RadarrModal.announced": "Tillkännagiven", @@ -1052,7 +1037,7 @@ "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncseriestip": "Begär automatiskt serier på din Plex bevakningslista", "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncmoviestip": "Begär automatiskt filmer på din Plex bevakningslista", "components.Settings.SettingsJobsCache.editJobScheduleCurrent": "Aktuell frekvens", - "components.PermissionEdit.viewrecentDescription": "Ge tillstånd till att visa listan över nyligen tillagd media.", + "components.PermissionEdit.viewrecentDescription": "Ge behörighet att visa listan över nyligen tillagd media.", "components.StatusBadge.managemedia": "Hantera {mediaType}", "components.StatusBadge.playonplex": "Spela upp på {mediaServerName}", "components.TitleCard.tvdbid": "TheTVDB-ID", @@ -1081,7 +1066,7 @@ "components.RequestModal.requestseriestitle": "Begär serie", "components.StatusBadge.openinarr": "Öppna i {arr}", "components.TvDetails.Season.somethingwentwrong": "Något gick fel när säsongsdata hämtades.", - "components.TvDetails.manageseries": "Hantera serier", + "components.TvDetails.manageseries": "Hantera serie", "components.TvDetails.rtaudiencescore": "Rotten Tomatoes Audience Score", "components.TvDetails.seasonnumber": "Säsong {seasonNumber}", "components.TvDetails.status4k": "4K {status}", @@ -1289,7 +1274,6 @@ "components.UserProfile.UserSettings.UserGeneralSettings.email": "E-post", "components.Login.back": "Gå tillbaka", "components.Login.hostname": "{mediaServerName}-URL", - "components.Login.validationHostnameRequired": "Du måste ange ett giltigt värdnamn eller en IP-adress", "components.Login.invalidurlerror": "Kunde inte ansluta till {mediaServerName} server.", "components.Login.port": "Port", "components.Login.servertype": "Typ av server", @@ -1408,7 +1392,6 @@ "components.Settings.SettingsMain.enableSpecialEpisodes": "Tillåt förfrågningar om specialavsnitt", "components.Settings.SettingsMain.streamingRegion": "Streamingregion", "components.Settings.SettingsMain.streamingRegionTip": "Visa streamingtjänster efter regional tillgänglighet", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Avancerade nätverksinställningar", "components.Settings.SettingsNetwork.csrfProtection": "Aktivera CSRF-skydd", "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "Aktivera INTE denna inställning om du inte vet vad du gör!", "components.Settings.SettingsNetwork.csrfProtectionTip": "Ställ in skrivskyddad åtkomst till externt API (kräver HTTPS)", diff --git a/src/i18n/locale/tr.json b/src/i18n/locale/tr.json index d5c0f69ea1..5fa5343087 100644 --- a/src/i18n/locale/tr.json +++ b/src/i18n/locale/tr.json @@ -554,16 +554,6 @@ "components.ResetPassword.gobacklogin": "Oturum Açma Sayfasına Dön", "components.ResetPassword.requestresetlinksuccessmessage": "Eğer ki girilen e-mail adresi gerçek bir kişiyle ilişkiliyse şifre sıfırlama linki gönderilecektir.", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL'nizin sonunda slash (eğik çizgi) olmamalıdır", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Aracıyı Etkinleştir", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Profil İsmi", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Eğer ki varsayılan profil kullanılmıyorsa gereklidir", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea bildirim ayarları kaydedilemedi.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea deneme bildirimi gönderilemedi.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "LunaSea deneme bildirimi gönderiliyor…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea deneme bildirimi gönderildi!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "En azından bir adet bildirim türü seçmelisiniz", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Geçerli bir URL girmelisiniz", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook URL'si", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Erişim Token'i", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Hesap Ayarlarınızdan bir token oluşturun", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Aracıyı Etkinleştir", @@ -575,9 +565,7 @@ "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "Bir erişim token'i sağlamalısınız", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "En azından bir adet bildirim türü seçmelisiniz", "components.Settings.Notifications.NotificationsPushover.accessToken": "Uygulama API'sinin Token'i", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea bildirim ayarları kaydedildi!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet deneme bildirimi gönderilemedi.", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "Kullanıcı ya da cihaz tabanlı webhook bildirimi URL'niz", "components.Settings.RadarrModal.released": "Yayınlandı", "components.Settings.RadarrModal.rootfolder": "Ana Klasör", "components.Settings.Notifications.NotificationsPushover.agentenabled": "Aracıyı Etkinleştir", @@ -864,7 +852,6 @@ "components.Settings.address": "Adres", "components.Settings.addsonarr": "Sonarr Sunucusu Ekle", "components.Settings.cancelscan": "Taramayı İptal Et", - "components.Settings.copied": "API Anahtarı panoya kopyalandı.", "components.Settings.currentlibrary": "Mevcut Kütüphane: {name}", "components.Settings.default": "Öntanımlı", "components.Settings.default4k": "Öntanımlı 4K", @@ -1179,8 +1166,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverUserKey": "Geçerli bir kullanıcı ya da grup kimliği sağlamalısınız", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Geçerli bir sohbet ID'si sağlamalısın", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Web Bildirimi", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Web bildirim ayarları kaydedilemedi.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Web bildirim ayarları kaydedildi!", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Şifreyi Doğrula", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Kullandığınız Şifre", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Yeni Şifre", @@ -1304,7 +1289,6 @@ "components.Login.invalidurlerror": "{mediaServerName} sunucusuna bağlanılamıyor.", "components.Login.port": "Port", "components.Login.urlBase": "URL Tabanı", - "components.Login.validationHostnameRequired": "Geçerli bir ana bilgisayar adı veya IP adresi sağlamalısınız", "components.Login.validationPortRequired": "Geçerli bir port numarası sağlamalısınız", "components.Login.validationUrlBaseLeadingSlash": "URL tabanının başında eğik çizgi olmalıdır", "components.Login.validationUrlBaseTrailingSlash": "URL tabanı eğik çizgiyle bitmemelidir", @@ -1432,7 +1416,6 @@ "components.Settings.OverrideRuleTile.tags": "Etiketler", "components.Settings.OverrideRuleTile.users": "Kullanıcılar", "components.Settings.SettingsMain.enableSpecialEpisodes": "Özel Bölüm Taleplerine İzin Ver", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "Gelişmiş Ağ Ayarları", "components.Settings.SettingsNetwork.csrfProtection": "CSRF Korumasını Etkinleştir", "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "Ne yaptığınızı bilmiyorsanız bu ayarı ETKİNLEŞTİRMEYİN!", "components.Settings.SettingsNetwork.csrfProtectionTip": "Harici API erişimini salt okunur olarak ayarlayın (HTTPS gerektirir)", diff --git a/src/i18n/locale/uk.json b/src/i18n/locale/uk.json index 396971a550..c7abc6c60e 100644 --- a/src/i18n/locale/uk.json +++ b/src/i18n/locale/uk.json @@ -427,18 +427,6 @@ "components.Settings.Notifications.NotificationsGotify.validationTypes": "Необхідно вибрати принаймні один тип сповіщення", "components.Settings.Notifications.NotificationsGotify.validationUrlRequired": "Ви повинні надати дійсну URL-адресу", "components.Settings.Notifications.NotificationsGotify.validationUrlTrailingSlash": "URL-адреса не має закінчуватися косою рискою", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "Активувати службу", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "Назва профілю", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "Потрібно лише в тому випадку, якщо не використовується профіль default", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "Не вдалося зберегти налаштування повідомлень LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "Налаштування повідомлень LunaSea успішно збережено!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "Не вдалося надіслати тестове повідомлення до LunaSea.", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "Надсилання тестового повідомлення в LunaSea…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "Тестове повідомлення надіслано до LunaSea!", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "Ви повинні вибрати хоча б один тип повідомлень", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "Ви повинні вказати дійсну URL-адресу", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "URL веб-перехоплювача", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "URL веб-перехоплювача для повідомлень на основі користувача або пристрою", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "Токен доступу", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "Створіть токен у налаштуваннях облікового запису", "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "Активувати службу", @@ -754,7 +742,6 @@ "components.Settings.addsonarr": "Додати сервер Sonarr", "components.Settings.advancedTooltip": "Неправильне налаштування цього параметра може призвести до несправності функціональності", "components.Settings.cancelscan": "Скасувати сканування", - "components.Settings.copied": "Ключ API скопійовано в буфер обміну.", "components.Settings.currentlibrary": "Поточна бібліотека: {name}", "components.Settings.default": "За замовчуванням", "components.Settings.default4k": "4К за замовчуванням", @@ -994,8 +981,6 @@ "components.UserProfile.UserSettings.UserNotificationSettings.validationPushoverUserKey": "Ви повинні надати дійсний ключ користувача або групи", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "Ви повинні надати дійсний ID чату", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "Веб-push", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "Не вдалося зберегти налаштування веб-повідомлень.", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "Налаштування веб-повідомлень успішно збережено!", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "Підтвердіть пароль", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "Поточний пароль", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "Новий пароль", @@ -1312,7 +1297,6 @@ "components.Login.validationUrlBaseTrailingSlash": "Базова URL-адреса не має закінчуватися косою рискою", "components.Login.validationservertyperequired": "Виберіть тип сервера", "components.Login.urlBase": "Базова URL-адреса", - "components.Login.validationHostnameRequired": "Ви повинні вказати дійсний домен або IP-адресу", "components.MovieDetails.watchlistDeleted": "{title} Видалено зі списку перегляду успішно!", "components.MovieDetails.watchlistError": "Щось пішло не так, повторіть спробу.", "components.Selector.ended": "Завершено", diff --git a/src/i18n/locale/zh_Hans.json b/src/i18n/locale/zh_Hans.json index 5b9dcee622..adf57ae442 100644 --- a/src/i18n/locale/zh_Hans.json +++ b/src/i18n/locale/zh_Hans.json @@ -1,6 +1,6 @@ { "components.UserList.validationpasswordminchars": "密码必须至少包含八个字符", - "components.UserList.validationEmail": "请输入有效的电子邮件地址", + "components.UserList.validationEmail": "需要提供电子邮件", "components.UserList.userssaved": "用户权限保存成功!", "components.UserList.users": "用户", "components.UserList.userlist": "用户清单", @@ -50,7 +50,7 @@ "components.TvDetails.originaltitle": "原始標題", "components.TvDetails.originallanguage": "原始语言", "components.TvDetails.nextAirDate": "下一次播出日期", - "components.TvDetails.network": "电视网", + "components.TvDetails.network": "{networkCount, plural, one {Network} other {Networks}}", "components.TvDetails.firstAirDate": "原始播出日期", "components.TvDetails.episodeRuntimeMinutes": "{runtime} 分钟", "components.TvDetails.episodeRuntime": "劇集片長", @@ -95,9 +95,9 @@ "components.Settings.scan": "媒体库同步", "components.Settings.radarrsettings": "Radarr 设置", "components.Settings.port": "端口", - "components.Settings.plexsettingsDescription": "关于 Plex 服务器的设置。Jellyseerr 将定时执行媒体库扫描。", + "components.Settings.plexsettingsDescription": "配置您的 Plex 服务器设置。Jellyseerr 将通过扫描 Plex 媒体库来确定内容可用性。", "components.Settings.plexsettings": "Plex 设置", - "components.Settings.plexlibrariesDescription": "Jellyseerr 将扫描的媒体库。", + "components.Settings.plexlibrariesDescription": "Jellyseerr 扫描影片的媒体库。如果未列出任何媒体库,请先设置并保存您的 Plex 连接配置,然后点击下方按钮。", "components.Settings.plexlibraries": "Plex 媒体库", "components.Settings.plex": "Plex", "components.Settings.notrunning": "未运行", @@ -117,7 +117,7 @@ "components.Settings.menuAbout": "关于 Jellyseerr", "components.Settings.mediaTypeSeries": "电视节目", "components.Settings.mediaTypeMovie": "电影", - "components.Settings.manualscanDescription": "在正常情況下,Jellyseerr 会每24小时扫描你的 Plex 媒体库。最新添加的媒体将更频繁扫描。设置新的 Plex 服务器时,我们建议你执行一次手动扫描!", + "components.Settings.manualscanDescription": "在正常情況下,Jellyseerr 会每24小时扫描一次你的 Plex 媒体库。Jellyseerr会更积极地检查你的Plex服务器最近添加的内容。如果这是你第一次配置Plex,我们建议你执行一次手动扫描!", "components.Settings.manualscan": "媒体库手动扫描", "components.Settings.librariesRemaining": "媒体库剩余数: {count}", "components.Settings.is4k": "4K", @@ -128,7 +128,6 @@ "components.Settings.default4k": "设置 4K 为默认分辨率", "components.Settings.default": "默认", "components.Settings.currentlibrary": "当前媒体库: {name}", - "components.Settings.copied": "应用程序密钥已复制到剪贴板。", "components.Settings.cancelscan": "取消扫描", "components.Settings.addsonarr": "添加 Sonarr 服务器", "components.Settings.address": "网址", @@ -262,7 +261,7 @@ "components.Discover.TvGenreSlider.tvgenres": "电视节目类型", "components.Discover.TvGenreList.seriesgenres": "电视节目类型", "components.Discover.StudioSlider.studios": "制作公司", - "components.Discover.NetworkSlider.networks": "电视网", + "components.Discover.NetworkSlider.networks": "流媒体平台", "components.Discover.MovieGenreSlider.moviegenres": "电影类型", "components.Discover.MovieGenreList.moviegenres": "电影类型", "components.Discover.DiscoverTvLanguage.languageSeries": "{language}电视节目", @@ -275,7 +274,7 @@ "components.CollectionDetails.requestcollection": "提交系列请求", "components.CollectionDetails.overview": "简介", "components.CollectionDetails.numberofmovies": "{count} 部电影", - "components.AppDataWarning.dockerVolumeMissingDescription": "必须使用繫結掛载(bind mount)指定某个宿主机器的资料夹跟容器內的 {appDataPath} 资料夹連通,才能保存 Jellyseerr 的配置和数据。", + "components.AppDataWarning.dockerVolumeMissingDescription": "{appDataPath} 卷挂载配置不正确。容器停止或重启时,所有数据将被清除。", "components.PersonDetails.ascharacter": "饰演 {character}", "pages.somethingwentwrong": "出了点问题", "pages.serviceunavailable": "服务器无法使用", @@ -359,12 +358,10 @@ "components.UserProfile.UserSettings.UserPasswordChange.password": "密码设置", "components.UserProfile.UserSettings.UserPasswordChange.nopermissionDescription": "你无权设置此用户的密码。", "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSetOwnAccount": "你的帐户目前没有设置密码。在下方配置密码,使你能够作为“本地用户”登录。", - "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "此用户帐户目前没有设置密码。配置下面的密码以使此帐户能够作为“本地用户”登录。", + "components.UserProfile.UserSettings.UserPasswordChange.noPasswordSet": "该用户账户当前未设置密码。请在下方配置密码,以启用“本地用户”登录功能。", "components.UserProfile.UserSettings.UserPasswordChange.newpassword": "新密码", "components.UserProfile.UserSettings.UserPasswordChange.currentpassword": "当前的密码", "components.UserProfile.UserSettings.UserPasswordChange.confirmpassword": "确认密码", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingssaved": "网络推送知设置保存成功!", - "components.UserProfile.UserSettings.UserNotificationSettings.webpushsettingsfailed": "网络推送知设置保存失败。", "components.UserProfile.UserSettings.UserNotificationSettings.webpush": "网络推送", "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramChatId": "请输入聊天室 ID", "components.UserProfile.UserSettings.UserNotificationSettings.validationPgpPublicKey": "请输入有效的 PGP 公钥", @@ -442,7 +439,7 @@ "components.Settings.SettingsUsers.newPlexLoginTip": "让还没导入的 Plex 用户登录", "components.Settings.SettingsUsers.newPlexLogin": "允许新的 Plex 登录", "components.Settings.SettingsUsers.movieRequestLimitLabel": "电影请求全局限制", - "components.Settings.SettingsUsers.localLoginTip": "让用户使用电子邮件地址和密码登录", + "components.Settings.SettingsUsers.localLoginTip": "允许用户使用电子邮件地址和密码登录", "components.Settings.SettingsUsers.localLogin": "允许本地登录", "components.Settings.SettingsUsers.defaultPermissionsTip": "授予给新用户的权限", "components.Settings.SettingsUsers.defaultPermissions": "默认权限", @@ -451,7 +448,7 @@ "components.Settings.SettingsLogs.resumeLogs": "恢复", "components.Settings.SettingsLogs.pauseLogs": "暫停", "components.Settings.SettingsLogs.message": "消息", - "components.Settings.SettingsLogs.logsDescription": "你也可以直接查看这些日志,方法是借助 stdout, 或者打开 {appDataPath}/logs/overseerr.log。", + "components.Settings.SettingsLogs.logsDescription": "您也可以通过stdout{appDataPath}/logs/ jellyserer .log直接查看这些日志。", "components.Settings.SettingsLogs.logs": "日志", "components.Settings.SettingsLogs.logDetails": "日志详細信息", "components.Settings.SettingsLogs.level": "等級", @@ -474,7 +471,7 @@ "components.Settings.SettingsJobsCache.jobtype": "作业类型", "components.Settings.SettingsJobsCache.jobstarted": "{jobname} 已开始运行。", "components.Settings.SettingsJobsCache.jobsandcache": "作业和缓存", - "components.Settings.SettingsJobsCache.jobsDescription": "Jellyseerr 将定时运行以下的维护任务。手动执行工作不会影响它正常的时间表。", + "components.Settings.SettingsJobsCache.jobsDescription": "Jellyseerr将某些维护任务作为定期计划的任务执行,但它们也可以在下面手动触发。手动运行任务不会改变它的时间表。", "components.Settings.SettingsJobsCache.jobs": "作业", "components.Settings.SettingsJobsCache.jobname": "作业名", "components.Settings.SettingsJobsCache.jobcancelled": "{jobname}已被取消。", @@ -490,7 +487,7 @@ "components.Settings.SettingsJobsCache.cachekeys": "键数", "components.Settings.SettingsJobsCache.cachehits": "击中数", "components.Settings.SettingsJobsCache.cacheflushed": "{cachename} 缓存已清除。", - "components.Settings.SettingsJobsCache.cacheDescription": "外部应用程序介面(external API)请求将存到缓存,以減少 API 呼叫次数。", + "components.Settings.SettingsJobsCache.cacheDescription": "Jellyseerr将请求缓存到外部API端点,以优化性能,避免进行不必要的API调用。", "components.Settings.SettingsJobsCache.cache": "缓存", "components.Settings.SettingsAbout.version": "软件版本", "components.Settings.SettingsAbout.uptodate": "最新", @@ -598,7 +595,7 @@ "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "网络推送测试通知已发送!", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "发送网络推送测试通知中…", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestFailed": "网络推送测试通知发送失败。", - "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "Jellyseerr 必须通過 HTTPS 投放才能使用网络推送通知。", + "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "为了接收web推送通知,Jellyseerr必须通过HTTPS提供服务。", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "启用通知", "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "创建一个 incoming webhook 集成", "components.Settings.Notifications.NotificationsSlack.webhookUrl": "网络钩子网址(URL)", @@ -621,7 +618,7 @@ "components.Settings.Notifications.NotificationsPushover.pushoversettingssaved": "Pushover 通知设置保存成功!", "components.Settings.Notifications.NotificationsPushover.pushoversettingsfailed": "Pushover 通知设置保存失败。", "components.Settings.Notifications.NotificationsPushover.agentenabled": "启用通知", - "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "建立一个 Jellyseerr 专用的应用程序", + "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "创建应用 并关联 Jellyseerr", "components.Settings.Notifications.NotificationsPushover.accessToken": "应用程序 API 令牌", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "请选择通知类型", "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "请输入 API 令牌", @@ -633,18 +630,6 @@ "components.Settings.Notifications.NotificationsPushbullet.agentEnabled": "启用通知", "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "从你的账户设定取得 API 令牌", "components.Settings.Notifications.NotificationsPushbullet.accessToken": "API 令牌", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "用户或设備通知的网络钩子网址", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "网络钩子网址(URL)", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "请输入有效的网址", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "请选择通知类型", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea 测试通知已发送!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "发送 LunaSea 测试通知中…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea 测试通知发送失败。", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea 通知设置保存成功!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea 通知设置保存失败。", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "不使用 default 默认设定档才必须输入", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "设定档名", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "启用通知", "components.Search.searchresults": "搜索結果", "components.Search.search": "搜索", "components.ResetPassword.validationpasswordrequired": "请输入密码", @@ -870,7 +855,7 @@ "components.Settings.SettingsAbout.appDataPath": "数据目录", "components.Settings.SettingsJobsCache.editJobScheduleSelectorHours": "每 {jobScheduleHours, plural, one {hour} other {{jobScheduleHours} hours}}", "components.Settings.tautulliSettings": "Tautulli 设置", - "components.Settings.tautulliSettingsDescription": "关于 Tautulli 服务器的设置。Jellyseerr 会从 Tautulli 获取 Plex 媒体的观看历史记录。", + "components.Settings.tautulliSettingsDescription": "可选配置您的 Tautulli 服务器设置。Jellyseerr 会从 Tautulli 获取您的 Plex 媒体观看历史数据。", "components.UserProfile.UserSettings.UserGeneralSettings.discordId": "Discord 用户ID", "components.UserProfile.UserSettings.UserNotificationSettings.pushbulletsettingsfailed": "Pushbullet 通知设置保存失败。", "components.UserProfile.UserSettings.UserGeneralSettings.discordIdTip": "您的Discord 用户 ID ", @@ -1019,7 +1004,7 @@ "components.RequestCard.tmdbid": "TMDB ID", "components.Settings.SettingsLogs.viewdetails": "查看详情", "components.Layout.UserDropdown.requests": "请求", - "components.Settings.restartrequiredTooltip": "必须重新启动 Jellyseerr 才能使更改的设置生效", + "components.Settings.restartrequiredTooltip": "需重启 Jellyseerr 服务才能使此设置生效", "components.TvDetails.manageseries": "管理电视节目", "components.UserProfile.UserSettings.UserGeneralSettings.plexwatchlistsyncseriestip": "自动请求您的 Plex 关注列表的媒体", "components.AirDateBadge.airedrelative": "{relativeTime}播出", @@ -1089,7 +1074,7 @@ "components.StatusBadge.seasonepisodenumber": "S{seasonNumber}E{episodeNumber}", "components.Discover.PlexWatchlistSlider.plexwatchlist": "您的 Plex 关注列表", "components.Discover.moviegenres": "电影类型", - "components.Discover.networks": "电视网", + "components.Discover.networks": "流媒体平台", "components.Discover.studios": "制作公司", "components.Discover.DiscoverMovieKeyword.keywordMovies": "{keywordTitle} 电影", "components.Settings.SettingsMain.apikey": "应用程序密钥", @@ -1138,7 +1123,7 @@ "components.Discover.DiscoverMovies.sortReleaseDateDesc": "上映日期递减", "components.Discover.DiscoverTv.sortPopularityDesc": "人气递减", "components.Discover.DiscoverTv.sortTitleDesc": "标题 (Z-A) 递减", - "components.Settings.SettingsMain.partialRequestsEnabled": "允许电视节目不完整请求", + "components.Settings.SettingsMain.partialRequestsEnabled": "允许部分剧集请求", "components.Discover.DiscoverMovies.sortTitleDesc": "标题 (Z-A) 递减", "components.Discover.DiscoverTv.sortTmdbRatingDesc": "TMDB 评分递减", "components.Discover.DiscoverMovies.sortTitleAsc": "标题 (A-Z) 递增", @@ -1162,22 +1147,22 @@ "components.Discover.updatefailed": "更新探索媒体设置时出了点问题。", "components.Settings.SettingsMain.originallanguageTip": "以原始语言筛选结果", "components.Settings.SettingsMain.originallanguage": "探索语言", - "components.Discover.tmdbnetwork": "TMDB 电视网", + "components.Discover.tmdbnetwork": "TMDB 平台", "components.Discover.tmdbsearch": "TMDB 搜索", "components.Discover.tmdbstudio": "TMDB 制作公司", - "components.Discover.CreateSlider.editfail": "编辑滑动框失败。", + "components.Discover.CreateSlider.editfail": "编辑滑块失败。", "components.Discover.CreateSlider.validationTitlerequired": "你必须提供滑动框的名称。", "components.Discover.DiscoverSliderEdit.deletesuccess": "成功删除滑动框。", "components.Discover.resettodefault": "重置为默认", "components.Discover.stopediting": "退出编辑", "components.Discover.resetwarning": "将所有滑动框重置为默认。这也将删除所有自定义滑动框!", - "components.Discover.CreateSlider.editSlider": "编辑滑动框", + "components.Discover.CreateSlider.editSlider": "编辑滑块", "components.Discover.CreateSlider.addSlider": "添加滑动框", - "components.Discover.CreateSlider.addcustomslider": "创建自定义滑动框", + "components.Discover.CreateSlider.addcustomslider": "创建自定义滑块", "components.Discover.DiscoverSliderEdit.deletefail": "删除滑动框失败。", "components.Discover.DiscoverSliderEdit.remove": "移除", - "components.Discover.CreateSlider.addfail": "创建新滑动框失败。", - "components.Discover.CreateSlider.addsuccess": "已创建新的滑动框并保存探索自定义设置。", + "components.Discover.CreateSlider.addfail": "创建新滑块失败。", + "components.Discover.CreateSlider.addsuccess": "已创建新滑块并保存探索页面的自定义设置。", "components.Discover.tmdbmoviegenre": "TMDB 电影类型", "components.Discover.tmdbtvgenre": "TMDB 电视节目类型", "components.Discover.tmdbtvkeyword": "TMDB 电视节目关键词", @@ -1196,10 +1181,10 @@ "components.Discover.customizediscover": "自定义探索", "components.Discover.createnewslider": "创建新的滑动框", "components.Discover.tmdbmoviekeyword": "TMDB 电影关键词", - "components.Discover.CreateSlider.editsuccess": "已编辑滑动框并保存探索自定义设置。", + "components.Discover.CreateSlider.editsuccess": "已编辑滑块并保存探索页面的自定义设置。", "components.Discover.CreateSlider.validationDatarequired": "你必须提供一个供搜索的内容。", "components.Discover.CreateSlider.providetmdbstudio": "提供 TMDB 制作公司 ID", - "components.Discover.CreateSlider.providetmdbnetwork": "提供一个 TMDB 电视网 ID", + "components.Discover.CreateSlider.providetmdbnetwork": "请提供 TMDB 网络 ID", "components.Discover.CreateSlider.slidernameplaceholder": "滑动框名称", "components.Discover.resetsuccess": "成功重置探索自定义设置。", "components.Settings.SettingsJobsCache.availability-sync": "同步媒体可用性", @@ -1249,10 +1234,10 @@ "components.Settings.syncing": "同步中", "components.Settings.timeout": "超时", "components.Setup.signin": "登录", - "components.Setup.signinWithJellyfin": "使用您的{mediaServerName}帐户", + "components.Setup.signinWithJellyfin": "输入您的 Jellyfin 详细信息", "components.TitleCard.addToWatchList": "添加到监视列表", "components.TitleCard.watchlistDeleted": "{title}从监视列表中删除成功!", - "components.TitleCard.watchlistError": "出了问题,再试一次。", + "components.TitleCard.watchlistError": "出现错误,请重试。", "components.TvDetails.play": "在 {mediaServerName} 播放", "components.TvDetails.play4k": "mediaServerName} 播放 4K", "components.UserList.importfrommediaserver": "导入{mediaServerName}用户", @@ -1274,12 +1259,12 @@ "components.Settings.SettingsJobsCache.jellyfin-recently-added-scan": "Jellyfin最近新增扫描", "components.Settings.SonarrModal.animeSeriesType": "动漫系列", "components.Settings.jellyfinSettings": "{mediaServerName}设置", - "components.Settings.jellyfinSettingsDescription": "可以为您的{mediaServerName}服务器配置内部和外部端点。在大多数情况下,外部URL与内部URL不同。如果你想重定向到不同的密码重置页面,也可以为{mediaServerName}登录设置自定义密码重置URL。", + "components.Settings.jellyfinSettingsDescription": "可以为您的{mediaServerName}服务器配置内部和外部端点。在大多数情况下,外部URL与内部URL是不同的。如果你想重定向到不同的密码重置页面,也可以为{mediaServerName}登录设置自定义密码重置URL。你也可以修改之前自动生成的Jellyfin API密钥。", "components.Settings.jellyfinsettingsDescription": "配置{mediaServerName}服务器的设置。{mediaServerName}扫描{mediaServerName}库以查看可用的内容。", "components.Settings.manualscanDescriptionJellyfin": "正常情况下,每24小时只会运行一次。Jellyseerr将更积极地检查您的{mediaServerName}服务器最近添加的内容。如果这是您第一次配置Jellyseerr,建议您手动进行一次完整的库扫描!", "components.Settings.save": "保存更改", "components.Setup.configuremediaserver": "配置媒体服务器", - "components.Setup.signinWithPlex": "使用您的 Plex 帐户", + "components.Setup.signinWithPlex": "输入您的 Plex 详细信息", "components.TitleCard.watchlistCancel": "{title}的监视列表已取消。", "components.TitleCard.watchlistSuccess": "{title}添加到监视列表成功!", "components.UserList.importfromJellyfin": "导入{mediaServerName}用户", @@ -1291,22 +1276,20 @@ "components.UserProfile.localWatchlist": "{username}的监视列表", "components.UserList.importedfromJellyfin": "{userCount} {mediaServerName} {userCount, plural, one {user} other {users}} 导入成功!", "components.Settings.SettingsNetwork.proxyBypassLocalAddresses": "代理绕过本地地址", - "components.MovieDetails.addtowatchlist": "添加到监视列表", + "components.MovieDetails.addtowatchlist": "加入监视列表", "components.MovieDetails.watchlistError": "出了点问题,请重试。", "components.PermissionEdit.manageblacklistDescription": "授予管理黑名单媒体的权限。", "components.Login.invalidurlerror": "无法连接到 {mediaServerName} 服务器。", "components.Login.enablessl": "使用 SSL", "components.PermissionEdit.manageblacklist": "管理黑名单", - "components.Login.validationUrlBaseTrailingSlash": "请删除结尾斜杠", + "components.Login.validationUrlBaseTrailingSlash": "基础 URL 末尾不得包含斜杠", "components.Login.noadminerror": "没有在服务器上找到管理员账户。", "components.Login.port": "端口", - "components.Login.validationHostnameRequired": "你必须提供有效的主机名或 IP 地址", - "components.Login.validationPortRequired": "请输入有效的端口", - "components.Login.validationUrlBaseLeadingSlash": "请添加前置斜杠", - "components.Login.validationUrlTrailingSlash": "请删除结尾斜杠", + "components.Login.validationPortRequired": "您必须提供一个有效的端口号", + "components.Login.validationUrlBaseLeadingSlash": "基础 URL 开头必须包含斜杠", + "components.Login.validationUrlTrailingSlash": "URL不能以斜杠结尾", "components.MovieDetails.removefromwatchlist": "从监视列表中移除", "components.Settings.SettingsNetwork.csrfProtection": "启用 CSRF 保护", - "components.Settings.SettingsNetwork.advancedNetworkSettings": "高级网络设置", "components.Settings.SettingsMain.discoverRegion": "探索地区", "components.Settings.SettingsMain.enableSpecialEpisodes": "允许特别剧集请求", "components.Settings.SettingsNetwork.proxyEnabled": "HTTP(S) 代理", @@ -1319,5 +1302,171 @@ "components.Settings.SettingsNetwork.validationProxyPort": "您必须提供有效端口", "components.Settings.SettingsUsers.loginMethods": "登录方式", "components.Settings.SettingsUsers.mediaServerLogin": "允许 {mediaServerName} 登录", - "components.Settings.SettingsNetwork.networksettings": "网络设置" + "components.Settings.SettingsNetwork.networksettings": "网络设置", + "component.BlacklistBlock.blacklistdate": "黑名单日期", + "components.PermissionEdit.viewblacklistedItemsDescription": "允许查看黑名单媒体。", + "components.Settings.Notifications.validationMessageThreadId": "线程/话题ID必须为正的整数", + "components.Settings.OverrideRuleModal.conditionsDescription": "指定应用参数更改前的条件。每个字段必须经过验证才能应用(和操作)规则。如果字段的任何属性(或操作)匹配,则认为该字段已验证。", + "components.Settings.OverrideRuleModal.genres": "类型", + "components.Settings.OverrideRuleModal.ruleCreated": "覆盖规则创建成功!", + "components.TvDetails.watchlistDeleted": "{title}从监视列表中删除成功!", + "components.UserProfile.UserSettings.LinkJellyfinModal.description": "输入您的{mediaServerName}凭据以将您的帐户与{applicationName}链接。", + "components.UserProfile.UserSettings.menuLinkedAccounts": "关联账户", + "components.Blacklist.blacklistNotFoundError": "{title}未被列入黑名单。", + "components.Blacklist.blacklistdate": "日期", + "components.DiscoverTvUpcoming.upcomingtv": "即将播出的电视剧", + "components.Blacklist.blacklistedby": "{date} 来自 {user}", + "components.Login.adminerror": "您必须使用管理员帐户登录。", + "components.Selector.canceled": "已取消", + "components.Settings.addrule": "新的覆盖规则", + "components.Setup.signinWithEmby": "输入您的Emby详细信息", + "components.TvDetails.addtowatchlist": "添加到监控列表", + "components.UserList.validationUsername": "你必须提供一个用户名", + "components.UserProfile.UserSettings.UserGeneralSettings.streamingRegion": "流媒体区域", + "components.UserProfile.UserSettings.UserNotificationSettings.telegramMessageThreadIdTip": "如果您的群聊启用了主题,您可以在这里指定线程/主题的ID", + "components.Discover.FilterSlideover.status": "状态", + "components.Login.back": "返回", + "components.RequestList.RequestItem.removearr": "从{arr}中删除", + "components.Layout.Sidebar.blacklist": "黑名单", + "components.Settings.OverrideRuleModal.settingsDescription": "指定当满足上述条件时将更改哪些设置。", + "components.PermissionEdit.viewblacklistedItems": "查看被列入黑名单的媒体。", + "components.RequestList.sortDirection": "切换排序方向", + "components.Settings.Notifications.webhookRoleIdTip": "要在webhook消息中提及的角色ID。留空以禁用提及", + "components.UserList.username": "用户名", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmail": "这个邮箱已经被使用了!", + "components.Settings.invalidurlerror": "无法连接到{mediaServerName}服务器。", + "components.Settings.scanbackground": "扫描将在后台运行。在此期间,您可以继续安装过程。", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorExists": "这个帐户已经链接到一个{applicationName}用户", + "i18n.blacklistSuccess": "{title} 被成功加入黑名单。", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccountsHint": "这些外部帐户与您的{applicationName}帐户相关联。", + "i18n.addToBlacklist": "添加到黑名单", + "components.Selector.returningSeries": "回归剧集", + "components.Blacklist.blacklistsettings": "黑名单设置", + "components.Blacklist.mediaName": "名称", + "components.Blacklist.mediaTmdbId": "tmdb Id", + "components.Blacklist.mediaType": "类型", + "component.BlacklistModal.blacklisting": "黑名单", + "components.Blacklist.blacklistSettingsDescription": "管理黑名单媒体。", + "component.BlacklistBlock.blacklistedby": "被列入黑名单", + "i18n.blacklist": "黑名单", + "components.Login.hostname": "{mediaServerName} URL", + "components.Login.loginwithapp": "使用{appName}登录", + "components.Login.orsigninwith": "或者登录", + "components.Login.servertype": "服务器类型", + "components.Login.validationservertyperequired": "请选择服务器类型", + "components.Login.urlBase": "基础 URL", + "components.MovieDetails.watchlistDeleted": "{title}从监视列表中删除成功!", + "components.MovieDetails.watchlistSuccess": "{title}添加到监视列表成功!", + "components.PermissionEdit.blacklistedItems": "黑名单媒体。", + "components.PermissionEdit.blacklistedItemsDescription": "添加黑名单媒体权限。", + "components.RequestList.RequestItem.profileName": "配置方案", + "components.Selector.ended": "已结束", + "components.Selector.inProduction": "在生产中", + "components.Selector.pilot": "试播节目", + "components.Selector.planned": "计划中", + "components.Selector.searchStatus": "选择状态…", + "components.Selector.searchUsers": "选择用户…", + "components.Settings.Notifications.messageThreadIdTip": "如果您的群聊启用了主题,您可以在这里指定线程/主题的ID", + "components.Settings.Notifications.messageThreadId": "主题/帖子 ID", + "components.Settings.Notifications.validationWebhookRoleId": "您必须提供一个有效的Discord角色ID", + "components.Settings.Notifications.webhookRoleId": "通知角色ID", + "components.Settings.OverrideRuleModal.conditions": "条件", + "components.Settings.OverrideRuleModal.create": "创建规则", + "components.Settings.OverrideRuleModal.createrule": "新覆盖规则", + "components.Settings.OverrideRuleModal.editrule": "编辑覆盖规则", + "components.Settings.OverrideRuleTile.tags": "标签", + "components.Settings.OverrideRuleModal.keywords": "关键字", + "components.Settings.OverrideRuleModal.languages": "语言", + "components.Settings.OverrideRuleModal.notagoptions": "没有标签。", + "components.Settings.OverrideRuleModal.qualityprofile": "质量概况", + "components.Settings.OverrideRuleModal.rootfolder": "根目录", + "components.Settings.OverrideRuleModal.ruleUpdated": "覆盖规则更新成功!", + "components.Settings.OverrideRuleModal.selectRootFolder": "选择根目录", + "components.Settings.OverrideRuleModal.selecttags": "选择标签", + "components.Settings.OverrideRuleModal.serviceDescription": "将此规则应用于所选服务。", + "components.Settings.OverrideRuleModal.settings": "设置", + "components.Settings.OverrideRuleModal.tags": "标签", + "components.Settings.OverrideRuleModal.users": "用户", + "components.Settings.OverrideRuleTile.conditions": "条件", + "components.Settings.OverrideRuleTile.keywords": "关键字", + "components.Settings.OverrideRuleTile.language": "语言", + "components.Settings.OverrideRuleTile.qualityprofile": "质量档案", + "components.Settings.OverrideRuleTile.rootfolder": "根目录", + "components.Settings.OverrideRuleTile.settings": "设置", + "components.Settings.OverrideRuleTile.users": "用户", + "components.Settings.OverrideRuleModal.selectService": "选择服务", + "components.Settings.OverrideRuleModal.service": "服务", + "components.Settings.OverrideRuleTile.genre": "类型", + "components.Settings.OverrideRuleModal.selectQualityProfile": "选择画质配置", + "components.Settings.SettingsJobsCache.usersavatars": "用户头像", + "components.Settings.SettingsJobsCache.plex-refresh-token": "Plex 刷新令牌", + "components.Settings.SettingsMain.discoverRegionTip": "根据区域可用性过滤内容", + "components.Settings.SettingsMain.streamingRegionTip": "按地区可用性显示流媒体网站", + "components.Settings.SettingsNetwork.csrfProtectionHoverTip": "不要启用这个设置,除非你明白你在做什么!", + "components.Settings.SettingsMain.streamingRegion": "流媒体区域", + "components.Settings.SettingsNetwork.csrfProtectionTip": "将外部API访问设置为只读(需要HTTPS)", + "components.Settings.SettingsNetwork.docs": "文档", + "components.Settings.SettingsNetwork.forceIpv4First": "强制IPv4优先解析", + "components.Settings.SettingsNetwork.forceIpv4FirstTip": "强制Jellyseerr首先解析IPv4地址,而不是IPv6地址", + "components.Settings.SettingsNetwork.network": "网络", + "components.Settings.SettingsNetwork.networkDisclaimer": "应该使用来自容器/系统的网络参数,而不是这些设置。有关更多信息,请参阅{docs}。", + "components.Settings.SettingsNetwork.networksettingsDescription": "为您的Jellyseerr实例配置网络设置。", + "components.Settings.SettingsNetwork.proxyBypassFilter": "忽略的代理地址", + "components.Settings.SettingsNetwork.proxyBypassFilterTip": "使用“,”和“*”作为分隔符。“*”作为子域的通配符", + "components.Settings.SettingsNetwork.toastSettingsFailure": "在保存设置时出错了。", + "components.Settings.SettingsNetwork.toastSettingsSuccess": "设置保存成功!", + "components.Settings.SettingsNetwork.trustProxyTip": "允许Jellyseerr在代理后正确地注册客户端IP地址", + "components.Settings.SettingsUsers.atLeastOneAuth": "必须选择至少一种身份验证方法。", + "components.Settings.SettingsUsers.loginMethodsTip": "配置用户登录方式。", + "components.Settings.SettingsUsers.mediaServerLoginTip": "允许用户使用他们的{mediaServerName}帐户登录", + "components.Settings.jellyfinForgotPasswordUrl": "忘记密码URL", + "components.Settings.apiKey": "API 密钥", + "components.Settings.jellyfinSyncFailedGenericError": "同步库时出错了", + "components.Settings.jellyfinSyncFailedNoLibrariesFound": "没有找到库", + "components.Settings.menuNetwork": "网络", + "components.Settings.overrideRules": "覆盖规则", + "components.Settings.overrideRulesDescription": "覆盖规则允许您指定在请求与规则匹配时将被替换的属性。", + "components.Settings.jellyfinSyncFailedAutomaticGroupedFolders": "不支持同时使用自定义认证和自动媒体库分组功能", + "components.Settings.tip": "提示", + "components.Setup.configemby": "配置Emby", + "components.Setup.configjellyfin": "配置Jellyfin", + "components.Setup.configplex": "配置Plex", + "components.Setup.librarieserror": "验证失败。请再次切换库以继续。", + "components.Setup.servertype": "选择服务器类型", + "components.Setup.subtitle": "首先选择您的媒体服务器", + "components.Setup.back": "返回", + "components.StatusBadge.seasonnumber": "第 {seasonNumber} 季", + "components.TvDetails.removefromwatchlist": "从监视列表中删除", + "components.TvDetails.watchlistError": "发生了一些错误。请再试一次。", + "components.TvDetails.watchlistSuccess": "{title}添加到监视列表成功!", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnauthorized": "无法使用您的凭据连接到{mediaServerName}", + "components.UserProfile.UserSettings.LinkJellyfinModal.errorUnknown": "发生未知错误", + "components.UserProfile.UserSettings.LinkJellyfinModal.password": "密码", + "components.UserProfile.UserSettings.LinkJellyfinModal.passwordRequired": "你必须提供一个密码", + "components.UserProfile.UserSettings.LinkJellyfinModal.save": "链接", + "components.UserProfile.UserSettings.LinkJellyfinModal.saving": "添加中…", + "components.UserProfile.UserSettings.LinkJellyfinModal.title": "链接{mediaServerName}帐户", + "components.UserProfile.UserSettings.LinkJellyfinModal.username": "用户名", + "components.UserProfile.UserSettings.LinkJellyfinModal.usernameRequired": "你必须提供一个用户名", + "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegion": "发现区域", + "components.UserProfile.UserSettings.UserGeneralSettings.discoverRegionTip": "根据区域可用性筛选内容", + "components.UserProfile.UserSettings.UserGeneralSettings.streamingRegionTip": "按地区可用性显示流媒体网站", + "components.UserProfile.UserSettings.UserGeneralSettings.toastSettingsFailureEmailEmpty": "该用户名已被其他用户使用,你必须设置一个邮箱", + "components.UserProfile.UserSettings.UserGeneralSettings.validationemailformat": "需要有效的邮箱", + "components.UserProfile.UserSettings.UserGeneralSettings.validationemailrequired": "需要邮箱", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.errorUnknown": "发生未知错误", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.linkedAccounts": "关联账户", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noLinkedAccounts": "您的账号没有绑定任何外部账号。", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.noPermissionDescription": "您没有权限修改此用户的关联帐户。", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.deleteFailed": "无法删除关联帐户。", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.plexErrorExists": "此帐户已关联到一个Plex用户", + "components.UserProfile.UserSettings.UserLinkedAccountsSettings.plexErrorUnauthorized": "无法使用您的凭证连接Plex", + "components.UserProfile.UserSettings.UserNotificationSettings.telegramMessageThreadId": "线程/主题 ID", + "components.UserProfile.UserSettings.UserNotificationSettings.validationTelegramMessageThreadId": "线程/主题ID必须是正的整数", + "i18n.blacklistDuplicateError": "{title}已被列入黑名单。", + "i18n.blacklistError": "出问题了。请再试一次。", + "i18n.removefromBlacklist": "移出黑名单", + "i18n.blacklisted": "已列入黑名单", + "i18n.removeFromBlacklistSuccess": "{title} 已成功从黑名单中移除。", + "i18n.specials": "特别篇" } diff --git a/src/i18n/locale/zh_Hant.json b/src/i18n/locale/zh_Hant.json index fc0de8f69a..9540a6bf47 100644 --- a/src/i18n/locale/zh_Hant.json +++ b/src/i18n/locale/zh_Hant.json @@ -364,7 +364,6 @@ "components.Settings.SettingsJobsCache.process": "程序", "components.Settings.SettingsAbout.preferredmethod": "首選", "i18n.advanced": "進階", - "components.Settings.copied": "應用程式密鑰已複製到剪貼板。", "components.Settings.serverpresetLoad": "請點右邊的按鈕", "components.Settings.toastPlexRefreshSuccess": "獲取 Plex 伺服器列表成功!", "components.Settings.toastPlexRefreshFailure": "獲取 Plex 伺服器列表失敗。", @@ -713,11 +712,6 @@ "components.Settings.Notifications.NotificationsWebPush.webpushsettingsfailed": "網路推送通知設定儲存失敗。", "components.UserProfile.UserSettings.UserGeneralSettings.applanguage": "顯示語言", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "啟用通知", - "components.Settings.Notifications.NotificationsLunaSea.settingsSaved": "LunaSea 通知設定儲存成功!", - "components.Settings.Notifications.NotificationsLunaSea.settingsFailed": "LunaSea 通知設定儲存失敗。", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrl": "Webhook 網址", - "components.Settings.Notifications.NotificationsLunaSea.validationWebhookUrl": "請輸入有效的網址", - "components.Settings.Notifications.NotificationsLunaSea.agentenabled": "啟用通知", "components.Settings.is4k": "4K", "components.Settings.Notifications.toastEmailTestSuccess": "電子郵件測試通知已發送!", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "網路推送測試通知已發送!", @@ -726,10 +720,7 @@ "components.Settings.Notifications.NotificationsSlack.toastSlackTestSuccess": "Slack 測試通知已發送!", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSuccess": "Pushover 測試通知已發送!", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSuccess": "Pushbullet 測試通知已發送!", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSuccess": "LunaSea 測試通知已發送!", "components.Settings.noDefault4kServer": "您必須指定一個 4K {serverType} 伺服器為預設,才能處理 4K 的{mediaType}請求。", - "components.Settings.Notifications.NotificationsLunaSea.profileNameTip": "不使用 default 預設設定檔才必須輸入", - "components.Settings.Notifications.NotificationsLunaSea.profileName": "設定檔名稱", "components.Settings.Notifications.toastTelegramTestSending": "發送 Telegram 測試通知中…", "components.Settings.Notifications.toastEmailTestSending": "發送電子郵件測試通知中…", "components.Settings.Notifications.toastDiscordTestSending": "發送 Discord 測試通知中…", @@ -738,7 +729,6 @@ "components.Settings.Notifications.NotificationsSlack.toastSlackTestSending": "發送 Slack 測試通知中…", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestSending": "發送 Pushover 測試通知中…", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestSending": "發送 Pushbullet 測試通知中…", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestSending": "發送 LunaSea 測試通知中…", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestFailed": "網路推送測試通知發送失敗。", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestFailed": "Webhook 測試通知發送失敗。", "components.Settings.Notifications.toastEmailTestFailed": "電子郵件測試通知發送失敗。", @@ -747,7 +737,6 @@ "components.Settings.Notifications.NotificationsSlack.toastSlackTestFailed": "Slack 測試通知發送失敗。", "components.Settings.Notifications.NotificationsPushover.toastPushoverTestFailed": "Pushover 測試通知發送失敗。", "components.Settings.Notifications.NotificationsPushbullet.toastPushbulletTestFailed": "Pushbullet 測試通知發送失敗。", - "components.Settings.Notifications.NotificationsLunaSea.toastLunaSeaTestFailed": "LunaSea 測試通知發送失敗。", "components.Settings.Notifications.NotificationsWebhook.toastWebhookTestSuccess": "Webhook 測試通知已發送!", "components.Settings.SettingsUsers.newPlexLoginTip": "讓還沒匯入的 Plex 使用者登入", "components.Settings.SettingsUsers.newPlexLogin": "允許新的 Plex 登入", @@ -767,7 +756,6 @@ "components.Settings.Notifications.NotificationsPushbullet.accessTokenTip": "從您的帳號設定取得 API 令牌", "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "建立一個 Jellyseerr 專用的應用程式", "components.Settings.Notifications.NotificationsSlack.webhookUrlTip": "創建一個「Incoming Webhook」整合", - "components.Settings.Notifications.NotificationsLunaSea.webhookUrlTip": "使用者或設備通知的 webhook 網址", "components.Settings.Notifications.webhookUrlTip": "在您的伺服器裡建立一個 webhook", "components.Settings.Notifications.botApiTip": "建立一個 Jellyseerr 專用的機器人", "components.Settings.Notifications.chatIdTip": "先與您的機器人建立一個聊天室以及把 @get_id_bot 也加到聊天室,然後在聊天室裡發出 /my_id 命令", @@ -789,7 +777,6 @@ "components.Settings.Notifications.NotificationsSlack.validationTypes": "請選擇通知類型", "components.Settings.Notifications.NotificationsPushover.validationTypes": "請選擇通知類型", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "請選擇通知類型", - "components.Settings.Notifications.NotificationsLunaSea.validationTypes": "請選擇通知類型", "components.NotificationTypeSelector.usermediarequestedDescription": "當其他使用者提出需要管理員批准的請求時取得通知。", "components.NotificationTypeSelector.usermediafailedDescription": "當 Radarr 或 Sonarr 處理請求失敗時取得通知。", "components.NotificationTypeSelector.usermediadeclinedDescription": "當您的請求被拒絕時取得通知。", From b10c57ce432cf45c6e97750938770ec69c663193 Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Mon, 29 Sep 2025 01:22:41 +0500 Subject: [PATCH 32/96] docs: update link to AI assistance policy in PR template (#1936) --- .github/PULL_REQUEST_TEMPLATE.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index 985ca5f6a6..831ea0a3e5 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -4,7 +4,7 @@ #### To-Dos -- [ ] Disclosed any use of AI (see our [policy](https://github.com/fallenbagel/jellyseerr/blob/docs-contributing/CONTRIBUTING.md#ai-assistance-notice)) +- [ ] Disclosed any use of AI (see our [policy](https://github.com/fallenbagel/jellyseerr/blob/develop/CONTRIBUTING.md#ai-assistance-notice)) - [ ] Successful build `pnpm build` - [ ] Translation keys `pnpm i18n:extract` - [ ] Database migration (if required) From 82c583974fcfac3c266004f362a12e283ad73dc6 Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Mon, 29 Sep 2025 05:40:01 +0500 Subject: [PATCH 33/96] docs(blog): implement blog (#1935) * docs(blog): implement blog This enables blog with a simple welcome to the blog post. * docs(blog): add authors page * chore(docusaurus): update docusaurus to v3.9.1 * docs(blog): add a description for each author * docs(blog): refactor the image url for each author * docs: update author name Co-authored-by: Gauthier --------- Co-authored-by: Gauthier --- .../2025-09-29-introducing-jellyseerr-blog.md | 24 + gen-docs/blog/authors.yml | 21 + gen-docs/docusaurus.config.ts | 19 +- gen-docs/package.json | 15 +- gen-docs/pnpm-lock.yaml | 8440 +++++++++-------- 5 files changed, 4794 insertions(+), 3725 deletions(-) create mode 100644 gen-docs/blog/2025-09-29-introducing-jellyseerr-blog.md create mode 100644 gen-docs/blog/authors.yml diff --git a/gen-docs/blog/2025-09-29-introducing-jellyseerr-blog.md b/gen-docs/blog/2025-09-29-introducing-jellyseerr-blog.md new file mode 100644 index 0000000000..33ae009352 --- /dev/null +++ b/gen-docs/blog/2025-09-29-introducing-jellyseerr-blog.md @@ -0,0 +1,24 @@ +--- +title: Welcome to the Jellyseerr Blog +description: The official Jellyseerr blog for release notes, technical updates, and community news. +slug: welcome +authors: [fallenbagel, gauthier-th] +tags: [announcement, jellyseerr, blog] +image: https://raw.githubusercontent.com/fallenbagel/jellyseerr/refs/heads/develop/gen-docs/static/img/logo.svg +hide_table_of_contents: false +--- + +We are pleased to introduce the official Jellyseerr blog. + +This space will serve as the central place for: + +- Release announcements +- Updates on new features and improvements +- Technical articles, such as details on our [**DNS caching package**](https://github.com/jellyseerr/dns-caching) and other enhancements +- Community-related news + + + +Our goal is to keep the community informed and provide deeper insights into the ongoing development of Jellyseerr. + +Thank you for being part of the Jellyseerr project. More updates will follow soon. diff --git a/gen-docs/blog/authors.yml b/gen-docs/blog/authors.yml new file mode 100644 index 0000000000..d0b229a87e --- /dev/null +++ b/gen-docs/blog/authors.yml @@ -0,0 +1,21 @@ +fallenbagel: + name: Fallenbagel + page: true + title: Developer & Maintainer of Jellyseerr + description: Core Maintainer & Developer of Jellyseerr | Full-Stack Software Engineer | MSc Software Engineering Candidate. + url: https://github.com/fallenbagel + image_url: https://github.com/fallenbagel.png + email: hello@fallenbagel.com + socials: + github: fallenbagel + +gauthier-th: + name: Gauthier + page: true + title: Co-Developer & Co-Maintainer of Jellyseerr + description: Co-Maintainer & Developer of Jellyseerr | PhD Student in AI at ICB, Dijon + url: https://gauthierth.fr + image_url: https://github.com/gauthier-th.png + email: mail@gauthierth.fr + socials: + github: gauthier-th diff --git a/gen-docs/docusaurus.config.ts b/gen-docs/docusaurus.config.ts index 637741b02e..db5be48407 100644 --- a/gen-docs/docusaurus.config.ts +++ b/gen-docs/docusaurus.config.ts @@ -34,7 +34,6 @@ const config: Config = { editUrl: 'https://github.com/fallenbagel/jellyseerr/edit/develop/docs/', }, - blog: false, pages: false, theme: { customCss: './src/css/custom.css', @@ -69,6 +68,11 @@ const config: Config = { src: 'img/logo.svg', }, items: [ + { + to: 'blog', + label: 'Blog', + position: 'right', + }, { href: 'https://github.com/fallenbagel/jellyseerr', label: 'GitHub', @@ -88,6 +92,19 @@ const config: Config = { }, ], }, + { + title: 'Project', + items: [ + { + label: 'Blog', + to: '/blog', + }, + { + label: 'GitHub', + href: 'https://github.com/fallenbagel/jellyseerr', + }, + ], + }, { title: 'Community', items: [ diff --git a/gen-docs/package.json b/gen-docs/package.json index 4be20686e2..d4506996fb 100644 --- a/gen-docs/package.json +++ b/gen-docs/package.json @@ -15,9 +15,9 @@ "typecheck": "tsc" }, "dependencies": { - "@docusaurus/core": "3.4.0", - "@docusaurus/preset-classic": "3.4.0", - "@easyops-cn/docusaurus-search-local": "^0.44.2", + "@docusaurus/core": "3.9.1", + "@docusaurus/preset-classic": "3.9.1", + "@easyops-cn/docusaurus-search-local": "^0.52.1", "@mdx-js/react": "^3.0.0", "clsx": "^2.0.0", "prism-react-renderer": "^2.3.0", @@ -26,14 +26,11 @@ "tailwindcss": "^3.4.4" }, "devDependencies": { - "@docusaurus/module-type-aliases": "3.4.0", - "@docusaurus/tsconfig": "3.4.0", - "@docusaurus/types": "3.4.0", + "@docusaurus/module-type-aliases": "3.9.1", + "@docusaurus/tsconfig": "3.9.1", + "@docusaurus/types": "3.9.1", "typescript": "~5.2.2" }, - "resolutions": { - "prismjs": "PrismJS/prism" - }, "browserslist": { "production": [ ">0.5%", diff --git a/gen-docs/pnpm-lock.yaml b/gen-docs/pnpm-lock.yaml index 8878f95e91..a038a91641 100644 --- a/gen-docs/pnpm-lock.yaml +++ b/gen-docs/pnpm-lock.yaml @@ -4,31 +4,28 @@ settings: autoInstallPeers: true excludeLinksFromLockfile: false -overrides: - prismjs: PrismJS/prism - importers: .: dependencies: '@docusaurus/core': - specifier: 3.4.0 - version: 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + specifier: 3.9.1 + version: 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) '@docusaurus/preset-classic': - specifier: 3.4.0 - version: 3.4.0(@algolia/client-search@4.23.3)(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.14.0)(typescript@5.2.2) + specifier: 3.9.1 + version: 3.9.1(@algolia/client-search@5.39.0)(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.17.3)(typescript@5.2.2) '@easyops-cn/docusaurus-search-local': - specifier: ^0.44.2 - version: 0.44.2(@docusaurus/theme-common@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + specifier: ^0.52.1 + version: 0.52.1(@docusaurus/theme-common@3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) '@mdx-js/react': specifier: ^3.0.0 - version: 3.0.1(@types/react@18.3.3)(react@18.3.1) + version: 3.1.1(@types/react@19.1.15)(react@18.3.1) clsx: specifier: ^2.0.0 version: 2.1.1 prism-react-renderer: specifier: ^2.3.0 - version: 2.3.1(react@18.3.1) + version: 2.4.1(react@18.3.1) react: specifier: ^18.0.0 version: 18.3.1 @@ -37,251 +34,260 @@ importers: version: 18.3.1(react@18.3.1) tailwindcss: specifier: ^3.4.4 - version: 3.4.4 + version: 3.4.17 devDependencies: '@docusaurus/module-type-aliases': - specifier: 3.4.0 - version: 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + specifier: 3.9.1 + version: 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) '@docusaurus/tsconfig': - specifier: 3.4.0 - version: 3.4.0 + specifier: 3.9.1 + version: 3.9.1 '@docusaurus/types': - specifier: 3.4.0 - version: 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + specifier: 3.9.1 + version: 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) typescript: specifier: ~5.2.2 version: 5.2.2 packages: - '@algolia/autocomplete-core@1.9.3': - resolution: {integrity: sha512-009HdfugtGCdC4JdXUbVJClA0q0zh24yyePn+KUGk3rP7j8FEe/m5Yo/z65gn6nP/cM39PxpzqKrL7A6fP6PPw==} + '@ai-sdk/gateway@1.0.30': + resolution: {integrity: sha512-QdrSUryr/CLcsCISokLHOImcHj1adGXk1yy4B3qipqLhcNc33Kj/O/3crI790Qp85oDx7sc4vm7R4raf9RA/kg==} + engines: {node: '>=18'} + peerDependencies: + zod: ^3.25.76 || ^4.1.8 - '@algolia/autocomplete-plugin-algolia-insights@1.9.3': - resolution: {integrity: sha512-a/yTUkcO/Vyy+JffmAnTWbr4/90cLzw+CC3bRbhnULr/EM0fGNvM13oQQ14f2moLMcVDyAx/leczLlAOovhSZg==} + '@ai-sdk/provider-utils@3.0.10': + resolution: {integrity: sha512-T1gZ76gEIwffep6MWI0QNy9jgoybUHE7TRaHB5k54K8mF91ciGFlbtCGxDYhMH3nCRergKwYFIDeFF0hJSIQHQ==} + engines: {node: '>=18'} peerDependencies: - search-insights: '>= 1 < 3' + zod: ^3.25.76 || ^4.1.8 - '@algolia/autocomplete-preset-algolia@1.9.3': - resolution: {integrity: sha512-d4qlt6YmrLMYy95n5TB52wtNDr6EgAIPH81dvvvW8UmuWRgxEtY0NJiPwl/h95JtG2vmRM804M0DSwMCNZlzRA==} + '@ai-sdk/provider@2.0.0': + resolution: {integrity: sha512-6o7Y2SeO9vFKB8lArHXehNuusnpddKPk7xqL7T2/b+OvXMRIXUO1rR4wcv1hAFUAT9avGZshty3Wlua/XA7TvA==} + engines: {node: '>=18'} + + '@ai-sdk/react@2.0.56': + resolution: {integrity: sha512-7glIc65IZYFx+GZIcvMFdp+lkJnpsgRJNGRhStF6naUXtCrhjC5SyyXFMwZk+GMk3ZK9Kb83zdnWqtO7LOXGuA==} + engines: {node: '>=18'} peerDependencies: - '@algolia/client-search': '>= 4.9.1 < 6' - algoliasearch: '>= 4.9.1 < 6' + react: ^18 || ^19 || ^19.0.0-rc + zod: ^3.25.76 || ^4.1.8 + peerDependenciesMeta: + zod: + optional: true + + '@algolia/abtesting@1.5.0': + resolution: {integrity: sha512-W/ohRkbKQsqDWALJg28X15KF7Tcyg53L1MfdOkLgvkcCcofdzGHSimHHeNG05ojjFw9HK8+VPhe/Vwq4MozIJg==} + engines: {node: '>= 14.0.0'} + + '@algolia/autocomplete-core@1.19.2': + resolution: {integrity: sha512-mKv7RyuAzXvwmq+0XRK8HqZXt9iZ5Kkm2huLjgn5JoCPtDy+oh9yxUMfDDaVCw0oyzZ1isdJBc7l9nuCyyR7Nw==} + + '@algolia/autocomplete-plugin-algolia-insights@1.19.2': + resolution: {integrity: sha512-TjxbcC/r4vwmnZaPwrHtkXNeqvlpdyR+oR9Wi2XyfORkiGkLTVhX2j+O9SaCCINbKoDfc+c2PB8NjfOnz7+oKg==} + peerDependencies: + search-insights: '>= 1 < 3' - '@algolia/autocomplete-shared@1.9.3': - resolution: {integrity: sha512-Wnm9E4Ye6Rl6sTTqjoymD+l8DjSTHsHboVRYrKgEt8Q7UHm9nYbqhN/i0fhUYA3OAEH7WA8x3jfpnmJm3rKvaQ==} + '@algolia/autocomplete-shared@1.19.2': + resolution: {integrity: sha512-jEazxZTVD2nLrC+wYlVHQgpBoBB5KPStrJxLzsIFl6Kqd1AlG9sIAGl39V5tECLpIQzB3Qa2T6ZPJ1ChkwMK/w==} peerDependencies: '@algolia/client-search': '>= 4.9.1 < 6' algoliasearch: '>= 4.9.1 < 6' - '@algolia/cache-browser-local-storage@4.23.3': - resolution: {integrity: sha512-vRHXYCpPlTDE7i6UOy2xE03zHF2C8MEFjPN2v7fRbqVpcOvAUQK81x3Kc21xyb5aSIpYCjWCZbYZuz8Glyzyyg==} + '@algolia/client-abtesting@5.39.0': + resolution: {integrity: sha512-Vf0ZVe+qo3sHDrCinouJqlg8VoxM4Qo/KxNIqMYybkuctutfnp3kIY9OmESplOQ/9NGBthU9EG+4d5fBibWK/A==} + engines: {node: '>= 14.0.0'} - '@algolia/cache-common@4.23.3': - resolution: {integrity: sha512-h9XcNI6lxYStaw32pHpB1TMm0RuxphF+Ik4o7tcQiodEdpKK+wKufY6QXtba7t3k8eseirEMVB83uFFF3Nu54A==} + '@algolia/client-analytics@5.39.0': + resolution: {integrity: sha512-V16ITZxYIwcv1arNce65JZmn94Ft6vKlBZ//gXw8AvIH32glJz1KcbaVAUr9p7PYlGZ/XVHP6LxDgrpNdtwgcA==} + engines: {node: '>= 14.0.0'} - '@algolia/cache-in-memory@4.23.3': - resolution: {integrity: sha512-yvpbuUXg/+0rbcagxNT7un0eo3czx2Uf0y4eiR4z4SD7SiptwYTpbuS0IHxcLHG3lq22ukx1T6Kjtk/rT+mqNg==} + '@algolia/client-common@5.39.0': + resolution: {integrity: sha512-UCJTuwySEQeiKPWV3wruhuI/wHbDYenHzgL9pYsvh6r/u5Z+g61ip1iwdAlFp02CnywzI9O7+AQPh2ManYyHmQ==} + engines: {node: '>= 14.0.0'} - '@algolia/client-account@4.23.3': - resolution: {integrity: sha512-hpa6S5d7iQmretHHF40QGq6hz0anWEHGlULcTIT9tbUssWUriN9AUXIFQ8Ei4w9azD0hc1rUok9/DeQQobhQMA==} + '@algolia/client-insights@5.39.0': + resolution: {integrity: sha512-s0ia8M/ZZR+iO2uLNTBrlQdEb6ZMAMcKMHckp5mcoglxrf8gHifL4LmdhGKdAxAn3UIagtqIP0RCnIymHUbm7A==} + engines: {node: '>= 14.0.0'} - '@algolia/client-analytics@4.23.3': - resolution: {integrity: sha512-LBsEARGS9cj8VkTAVEZphjxTjMVCci+zIIiRhpFun9jGDUlS1XmhCW7CTrnaWeIuCQS/2iPyRqSy1nXPjcBLRA==} + '@algolia/client-personalization@5.39.0': + resolution: {integrity: sha512-vZPIt7Lw+toNsHZUiPhNIc1Z3vUjDp7nzn6AMOaPC73gEuTq2iLPNvM06CSB6aHePo5eMeJIP5YEKBUQUA/PJA==} + engines: {node: '>= 14.0.0'} - '@algolia/client-common@4.23.3': - resolution: {integrity: sha512-l6EiPxdAlg8CYhroqS5ybfIczsGUIAC47slLPOMDeKSVXYG1n0qGiz4RjAHLw2aD0xzh2EXZ7aRguPfz7UKDKw==} + '@algolia/client-query-suggestions@5.39.0': + resolution: {integrity: sha512-jcPQr3iKTWNVli2NYHPv02aNLwixDjPCpOgMp9CZTvEiPI6Ec4jHX+oFr3LDZagOFY9e1xJhc/JrgMGGW1sHnw==} + engines: {node: '>= 14.0.0'} - '@algolia/client-personalization@4.23.3': - resolution: {integrity: sha512-3E3yF3Ocr1tB/xOZiuC3doHQBQ2zu2MPTYZ0d4lpfWads2WTKG7ZzmGnsHmm63RflvDeLK/UVx7j2b3QuwKQ2g==} - - '@algolia/client-search@4.23.3': - resolution: {integrity: sha512-P4VAKFHqU0wx9O+q29Q8YVuaowaZ5EM77rxfmGnkHUJggh28useXQdopokgwMeYw2XUht49WX5RcTQ40rZIabw==} + '@algolia/client-search@5.39.0': + resolution: {integrity: sha512-/IYpF10BpthGZEJQZMhMqV4AqWr5avcWfZm/SIKK1RvUDmzGqLoW/+xeJVX9C8ZnNkIC8hivbIQFaNaRw0BFZQ==} + engines: {node: '>= 14.0.0'} '@algolia/events@4.0.1': resolution: {integrity: sha512-FQzvOCgoFXAbf5Y6mYozw2aj5KCJoA3m4heImceldzPSMbdyS4atVjJzXKMsfX3wnZTFYwkkt8/z8UesLHlSBQ==} - '@algolia/logger-common@4.23.3': - resolution: {integrity: sha512-y9kBtmJwiZ9ZZ+1Ek66P0M68mHQzKRxkW5kAAXYN/rdzgDN0d2COsViEFufxJ0pb45K4FRcfC7+33YB4BLrZ+g==} - - '@algolia/logger-console@4.23.3': - resolution: {integrity: sha512-8xoiseoWDKuCVnWP8jHthgaeobDLolh00KJAdMe9XPrWPuf1by732jSpgy2BlsLTaT9m32pHI8CRfrOqQzHv3A==} + '@algolia/ingestion@1.39.0': + resolution: {integrity: sha512-IgSHKUiuecqLfBlXiuCSdRTdsO3/yvpmXrMFz8fAJ8M4QmDtHkOuD769dmybRYqsbYMHivw+lir4BgbRGMtOIQ==} + engines: {node: '>= 14.0.0'} - '@algolia/recommend@4.23.3': - resolution: {integrity: sha512-9fK4nXZF0bFkdcLBRDexsnGzVmu4TSYZqxdpgBW2tEyfuSSY54D4qSRkLmNkrrz4YFvdh2GM1gA8vSsnZPR73w==} + '@algolia/monitoring@1.39.0': + resolution: {integrity: sha512-8Xnd4+609SKC/hqVsuFc4evFBmvA2765/4NcH+Dpr756SKPbL1BY0X8kVxlmM3YBLNqnduSQxHxpDJUK58imCA==} + engines: {node: '>= 14.0.0'} - '@algolia/requester-browser-xhr@4.23.3': - resolution: {integrity: sha512-jDWGIQ96BhXbmONAQsasIpTYWslyjkiGu0Quydjlowe+ciqySpiDUrJHERIRfELE5+wFc7hc1Q5hqjGoV7yghw==} + '@algolia/recommend@5.39.0': + resolution: {integrity: sha512-D7Ye2Ss/5xqUkQUxKm/VqEJLt5kARd9IMmjdzlxaKhGgNlOemTay0lwBmOVFuJRp7UODjp5c9+K+B8g0ORObIw==} + engines: {node: '>= 14.0.0'} - '@algolia/requester-common@4.23.3': - resolution: {integrity: sha512-xloIdr/bedtYEGcXCiF2muajyvRhwop4cMZo+K2qzNht0CMzlRkm8YsDdj5IaBhshqfgmBb3rTg4sL4/PpvLYw==} + '@algolia/requester-browser-xhr@5.39.0': + resolution: {integrity: sha512-mgPte1ZJqpk9dkVs44J3wKAbHATvHZNlSpzhMdjMLIg/3qTycSZyDiomLiSlxE8CLsxyBAOJWnyKRHfom+Z1rg==} + engines: {node: '>= 14.0.0'} - '@algolia/requester-node-http@4.23.3': - resolution: {integrity: sha512-zgu++8Uj03IWDEJM3fuNl34s746JnZOWn1Uz5taV1dFyJhVM/kTNw9Ik7YJWiUNHJQXcaD8IXD1eCb0nq/aByA==} + '@algolia/requester-fetch@5.39.0': + resolution: {integrity: sha512-LIrCkrxu1WnO3ev1+w6NnZ12JZL/o+2H9w6oWnZAjQZIlA/Ym6M9QHkt+OQ/SwkuoiNkW3DAo+Pi4A2V9FPtqg==} + engines: {node: '>= 14.0.0'} - '@algolia/transporter@4.23.3': - resolution: {integrity: sha512-Wjl5gttqnf/gQKJA+dafnD0Y6Yw97yvfY8R9h0dQltX1GXTgNs1zWgvtWW0tHl1EgMdhAyw189uWiZMnL3QebQ==} + '@algolia/requester-node-http@5.39.0': + resolution: {integrity: sha512-6beG+egPwXmvhAg+m0STCj+ZssDcjrLzf4L05aKm2nGglMXSSPz0cH/rM+kVD9krNfldiMctURd4wjojW1fV0w==} + engines: {node: '>= 14.0.0'} '@alloc/quick-lru@5.2.0': resolution: {integrity: sha512-UrcABB+4bUrFABwbluTIBErXwvbsU/V7TZWfmbgJfbkwiBuziS9gxdODUyuiecfdGQ85jglMW6juS3+z5TsKLw==} engines: {node: '>=10'} - '@ampproject/remapping@2.3.0': - resolution: {integrity: sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==} - engines: {node: '>=6.0.0'} - - '@babel/code-frame@7.24.7': - resolution: {integrity: sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==} + '@babel/code-frame@7.27.1': + resolution: {integrity: sha512-cjQ7ZlQ0Mv3b47hABuTevyTuYN4i+loJKGeV9flcCgIK37cCXRh+L1bd3iBHlynerhQ7BhCkn2BPbQUL+rGqFg==} engines: {node: '>=6.9.0'} - '@babel/compat-data@7.24.7': - resolution: {integrity: sha512-qJzAIcv03PyaWqxRgO4mSU3lihncDT296vnyuE2O8uA4w3UHWI4S3hgeZd1L8W1Bft40w9JxJ2b412iDUFFRhw==} + '@babel/compat-data@7.28.4': + resolution: {integrity: sha512-YsmSKC29MJwf0gF8Rjjrg5LQCmyh+j/nD8/eP7f+BeoQTKYqs9RoWbjGOdy0+1Ekr68RJZMUOPVQaQisnIo4Rw==} engines: {node: '>=6.9.0'} - '@babel/core@7.24.7': - resolution: {integrity: sha512-nykK+LEK86ahTkX/3TgauT0ikKoNCfKHEaZYTUVupJdTLzGNvrblu4u6fa7DhZONAltdf8e662t/abY8idrd/g==} + '@babel/core@7.28.4': + resolution: {integrity: sha512-2BCOP7TN8M+gVDj7/ht3hsaO/B/n5oDbiAyyvnRlNOs+u1o+JWNYTQrmpuNp1/Wq2gcFrI01JAW+paEKDMx/CA==} engines: {node: '>=6.9.0'} - '@babel/generator@7.24.7': - resolution: {integrity: sha512-oipXieGC3i45Y1A41t4tAqpnEZWgB/lC6Ehh6+rOviR5XWpTtMmLN+fGjz9vOiNRt0p6RtO6DtD0pdU3vpqdSA==} + '@babel/generator@7.28.3': + resolution: {integrity: sha512-3lSpxGgvnmZznmBkCRnVREPUFJv2wrv9iAoFDvADJc0ypmdOxdUtcLeBgBJ6zE0PMeTKnxeQzyk0xTBq4Ep7zw==} engines: {node: '>=6.9.0'} - '@babel/helper-annotate-as-pure@7.24.7': - resolution: {integrity: sha512-BaDeOonYvhdKw+JoMVkAixAAJzG2jVPIwWoKBPdYuY9b452e2rPuI9QPYh3KpofZ3pW2akOmwZLOiOsHMiqRAg==} + '@babel/helper-annotate-as-pure@7.27.3': + resolution: {integrity: sha512-fXSwMQqitTGeHLBC08Eq5yXz2m37E4pJX1qAU1+2cNedz/ifv/bVXft90VeSav5nFO61EcNgwr0aJxbyPaWBPg==} engines: {node: '>=6.9.0'} - '@babel/helper-builder-binary-assignment-operator-visitor@7.24.7': - resolution: {integrity: sha512-xZeCVVdwb4MsDBkkyZ64tReWYrLRHlMN72vP7Bdm3OUOuyFZExhsHUUnuWnm2/XOlAJzR0LfPpB56WXZn0X/lA==} + '@babel/helper-compilation-targets@7.27.2': + resolution: {integrity: sha512-2+1thGUUWWjLTYTHZWK1n8Yga0ijBz1XAhUXcKy81rd5g6yh7hGqMp45v7cadSbEHc9G3OTv45SyneRN3ps4DQ==} engines: {node: '>=6.9.0'} - '@babel/helper-compilation-targets@7.24.7': - resolution: {integrity: sha512-ctSdRHBi20qWOfy27RUb4Fhp07KSJ3sXcuSvTrXrc4aG8NSYDo1ici3Vhg9bg69y5bj0Mr1lh0aeEgTvc12rMg==} - engines: {node: '>=6.9.0'} - - '@babel/helper-create-class-features-plugin@7.24.7': - resolution: {integrity: sha512-kTkaDl7c9vO80zeX1rJxnuRpEsD5tA81yh11X1gQo+PhSti3JS+7qeZo9U4RHobKRiFPKaGK3svUAeb8D0Q7eg==} + '@babel/helper-create-class-features-plugin@7.28.3': + resolution: {integrity: sha512-V9f6ZFIYSLNEbuGA/92uOvYsGCJNsuA8ESZ4ldc09bWk/j8H8TKiPw8Mk1eG6olpnO0ALHJmYfZvF4MEE4gajg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-create-regexp-features-plugin@7.24.7': - resolution: {integrity: sha512-03TCmXy2FtXJEZfbXDTSqq1fRJArk7lX9DOFC/47VthYcxyIOx+eXQmdo6DOQvrbpIix+KfXwvuXdFDZHxt+rA==} + '@babel/helper-create-regexp-features-plugin@7.27.1': + resolution: {integrity: sha512-uVDC72XVf8UbrH5qQTc18Agb8emwjTiZrQE11Nv3CuBEZmVvTwwE9CBUEvHku06gQCAyYf8Nv6ja1IN+6LMbxQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-define-polyfill-provider@0.6.2': - resolution: {integrity: sha512-LV76g+C502biUK6AyZ3LK10vDpDyCzZnhZFXkH1L75zHPj68+qc8Zfpx2th+gzwA2MzyK+1g/3EPl62yFnVttQ==} + '@babel/helper-define-polyfill-provider@0.6.5': + resolution: {integrity: sha512-uJnGFcPsWQK8fvjgGP5LZUZZsYGIoPeRjSF5PGwrelYgq7Q15/Ft9NGFp1zglwgIv//W0uG4BevRuSJRyylZPg==} peerDependencies: '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 - '@babel/helper-environment-visitor@7.24.7': - resolution: {integrity: sha512-DoiN84+4Gnd0ncbBOM9AZENV4a5ZiL39HYMyZJGZ/AZEykHYdJw0wW3kdcsh9/Kn+BRXHLkkklZ51ecPKmI1CQ==} - engines: {node: '>=6.9.0'} - - '@babel/helper-function-name@7.24.7': - resolution: {integrity: sha512-FyoJTsj/PEUWu1/TYRiXTIHc8lbw+TDYkZuoE43opPS5TrI7MyONBE1oNvfguEXAD9yhQRrVBnXdXzSLQl9XnA==} + '@babel/helper-globals@7.28.0': + resolution: {integrity: sha512-+W6cISkXFa1jXsDEdYA8HeevQT/FULhxzR99pxphltZcVaugps53THCeiWA8SguxxpSp3gKPiuYfSWopkLQ4hw==} engines: {node: '>=6.9.0'} - '@babel/helper-hoist-variables@7.24.7': - resolution: {integrity: sha512-MJJwhkoGy5c4ehfoRyrJ/owKeMl19U54h27YYftT0o2teQ3FJ3nQUf/I3LlJsX4l3qlw7WRXUmiyajvHXoTubQ==} + '@babel/helper-member-expression-to-functions@7.27.1': + resolution: {integrity: sha512-E5chM8eWjTp/aNoVpcbfM7mLxu9XGLWYise2eBKGQomAk/Mb4XoxyqXTZbuTohbsl8EKqdlMhnDI2CCLfcs9wA==} engines: {node: '>=6.9.0'} - '@babel/helper-member-expression-to-functions@7.24.7': - resolution: {integrity: sha512-LGeMaf5JN4hAT471eJdBs/GK1DoYIJ5GCtZN/EsL6KUiiDZOvO/eKE11AMZJa2zP4zk4qe9V2O/hxAmkRc8p6w==} + '@babel/helper-module-imports@7.27.1': + resolution: {integrity: sha512-0gSFWUPNXNopqtIPQvlD5WgXYI5GY2kP2cCvoT8kczjbfcfuIljTbcWrulD1CIPIX2gt1wghbDy08yE1p+/r3w==} engines: {node: '>=6.9.0'} - '@babel/helper-module-imports@7.24.7': - resolution: {integrity: sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==} - engines: {node: '>=6.9.0'} - - '@babel/helper-module-transforms@7.24.7': - resolution: {integrity: sha512-1fuJEwIrp+97rM4RWdO+qrRsZlAeL1lQJoPqtCYWv0NL115XM93hIH4CSRln2w52SqvmY5hqdtauB6QFCDiZNQ==} + '@babel/helper-module-transforms@7.28.3': + resolution: {integrity: sha512-gytXUbs8k2sXS9PnQptz5o0QnpLL51SwASIORY6XaBKF88nsOT0Zw9szLqlSGQDP/4TljBAD5y98p2U1fqkdsw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-optimise-call-expression@7.24.7': - resolution: {integrity: sha512-jKiTsW2xmWwxT1ixIdfXUZp+P5yURx2suzLZr5Hi64rURpDYdMW0pv+Uf17EYk2Rd428Lx4tLsnjGJzYKDM/6A==} + '@babel/helper-optimise-call-expression@7.27.1': + resolution: {integrity: sha512-URMGH08NzYFhubNSGJrpUEphGKQwMQYBySzat5cAByY1/YgIRkULnIy3tAMeszlL/so2HbeilYloUmSpd7GdVw==} engines: {node: '>=6.9.0'} - '@babel/helper-plugin-utils@7.24.7': - resolution: {integrity: sha512-Rq76wjt7yz9AAc1KnlRKNAi/dMSVWgDRx43FHoJEbcYU6xOWaE2dVPwcdTukJrjxS65GITyfbvEYHvkirZ6uEg==} + '@babel/helper-plugin-utils@7.27.1': + resolution: {integrity: sha512-1gn1Up5YXka3YYAHGKpbideQ5Yjf1tDa9qYcgysz+cNCXukyLl6DjPXhD3VRwSb8c0J9tA4b2+rHEZtc6R0tlw==} engines: {node: '>=6.9.0'} - '@babel/helper-remap-async-to-generator@7.24.7': - resolution: {integrity: sha512-9pKLcTlZ92hNZMQfGCHImUpDOlAgkkpqalWEeftW5FBya75k8Li2ilerxkM/uBEj01iBZXcCIB/bwvDYgWyibA==} + '@babel/helper-remap-async-to-generator@7.27.1': + resolution: {integrity: sha512-7fiA521aVw8lSPeI4ZOD3vRFkoqkJcS+z4hFo82bFSH/2tNd6eJ5qCVMS5OzDmZh/kaHQeBaeyxK6wljcPtveA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-replace-supers@7.24.7': - resolution: {integrity: sha512-qTAxxBM81VEyoAY0TtLrx1oAEJc09ZK67Q9ljQToqCnA+55eNwCORaxlKyu+rNfX86o8OXRUSNUnrtsAZXM9sg==} + '@babel/helper-replace-supers@7.27.1': + resolution: {integrity: sha512-7EHz6qDZc8RYS5ElPoShMheWvEgERonFCs7IAonWLLUTXW59DP14bCZt89/GKyreYn8g3S83m21FelHKbeDCKA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/helper-simple-access@7.24.7': - resolution: {integrity: sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==} - engines: {node: '>=6.9.0'} - - '@babel/helper-skip-transparent-expression-wrappers@7.24.7': - resolution: {integrity: sha512-IO+DLT3LQUElMbpzlatRASEyQtfhSE0+m465v++3jyyXeBTBUjtVZg28/gHeV5mrTJqvEKhKroBGAvhW+qPHiQ==} - engines: {node: '>=6.9.0'} - - '@babel/helper-split-export-declaration@7.24.7': - resolution: {integrity: sha512-oy5V7pD+UvfkEATUKvIjvIAH/xCzfsFVw7ygW2SI6NClZzquT+mwdTfgfdbUiceh6iQO0CHtCPsyze/MZ2YbAA==} - engines: {node: '>=6.9.0'} - - '@babel/helper-string-parser@7.24.7': - resolution: {integrity: sha512-7MbVt6xrwFQbunH2DNQsAP5sTGxfqQtErvBIvIMi6EQnbgUOuVYanvREcmFrOPhoXBrTtjhhP+lW+o5UfK+tDg==} + '@babel/helper-skip-transparent-expression-wrappers@7.27.1': + resolution: {integrity: sha512-Tub4ZKEXqbPjXgWLl2+3JpQAYBJ8+ikpQ2Ocj/q/r0LwE3UhENh7EUabyHjz2kCEsrRY83ew2DQdHluuiDQFzg==} engines: {node: '>=6.9.0'} - '@babel/helper-validator-identifier@7.24.7': - resolution: {integrity: sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==} + '@babel/helper-string-parser@7.27.1': + resolution: {integrity: sha512-qMlSxKbpRlAridDExk92nSobyDdpPijUq2DW6oDnUqd0iOGxmQjyqhMIihI9+zv4LPyZdRje2cavWPbCbWm3eA==} engines: {node: '>=6.9.0'} - '@babel/helper-validator-option@7.24.7': - resolution: {integrity: sha512-yy1/KvjhV/ZCL+SM7hBrvnZJ3ZuT9OuZgIJAGpPEToANvc3iM6iDvBnRjtElWibHU6n8/LPR/EjX9EtIEYO3pw==} + '@babel/helper-validator-identifier@7.27.1': + resolution: {integrity: sha512-D2hP9eA+Sqx1kBZgzxZh0y1trbuU+JoDkiEwqhQ36nodYqJwyEIhPSdMNd7lOm/4io72luTPWH20Yda0xOuUow==} engines: {node: '>=6.9.0'} - '@babel/helper-wrap-function@7.24.7': - resolution: {integrity: sha512-N9JIYk3TD+1vq/wn77YnJOqMtfWhNewNE+DJV4puD2X7Ew9J4JvrzrFDfTfyv5EgEXVy9/Wt8QiOErzEmv5Ifw==} + '@babel/helper-validator-option@7.27.1': + resolution: {integrity: sha512-YvjJow9FxbhFFKDSuFnVCe2WxXk1zWc22fFePVNEaWJEu8IrZVlda6N0uHwzZrUM1il7NC9Mlp4MaJYbYd9JSg==} engines: {node: '>=6.9.0'} - '@babel/helpers@7.24.7': - resolution: {integrity: sha512-NlmJJtvcw72yRJRcnCmGvSi+3jDEg8qFu3z0AFoymmzLx5ERVWyzd9kVXr7Th9/8yIJi2Zc6av4Tqz3wFs8QWg==} + '@babel/helper-wrap-function@7.28.3': + resolution: {integrity: sha512-zdf983tNfLZFletc0RRXYrHrucBEg95NIFMkn6K9dbeMYnsgHaSBGcQqdsCSStG2PYwRre0Qc2NNSCXbG+xc6g==} engines: {node: '>=6.9.0'} - '@babel/highlight@7.24.7': - resolution: {integrity: sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==} + '@babel/helpers@7.28.4': + resolution: {integrity: sha512-HFN59MmQXGHVyYadKLVumYsA9dBFun/ldYxipEjzA4196jpLZd8UjEEBLkbEkvfYreDqJhZxYAWFPtrfhNpj4w==} engines: {node: '>=6.9.0'} - '@babel/parser@7.24.7': - resolution: {integrity: sha512-9uUYRm6OqQrCqQdG1iCBwBPZgN8ciDBro2nIOFaiRz1/BCxaI7CNvQbDHvsArAC7Tw9Hda/B3U+6ui9u4HWXPw==} + '@babel/parser@7.28.4': + resolution: {integrity: sha512-yZbBqeM6TkpP9du/I2pUZnJsRMGGvOuIrhjzC1AwHwW+6he4mni6Bp/m8ijn0iOuZuPI2BfkCoSRunpyjnrQKg==} engines: {node: '>=6.0.0'} hasBin: true - '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.24.7': - resolution: {integrity: sha512-TiT1ss81W80eQsN+722OaeQMY/G4yTb4G9JrqeiDADs3N8lbPMGldWi9x8tyqCW5NLx1Jh2AvkE6r6QvEltMMQ==} + '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.27.1': + resolution: {integrity: sha512-QPG3C9cCVRQLxAVwmefEmwdTanECuUBMQZ/ym5kiw3XKCGA7qkuQLcjWWHcrD/GKbn/WmJwaezfuuAOcyKlRPA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@7.24.7': - resolution: {integrity: sha512-unaQgZ/iRu/By6tsjMZzpeBZjChYfLYry6HrEXPoz3KmfF0sVBQ1l8zKMQ4xRGLWVsjuvB8nQfjNP/DcfEOCsg==} + '@babel/plugin-bugfix-safari-class-field-initializer-scope@7.27.1': + resolution: {integrity: sha512-qNeq3bCKnGgLkEXUuFry6dPlGfCdQNZbn7yUAPCInwAJHMU7THJfrBSozkcWq5sNM6RcF3S8XyQL2A52KNR9IA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@7.24.7': - resolution: {integrity: sha512-+izXIbke1T33mY4MSNnrqhPXDz01WYhEf3yF5NbnUtkiNnm+XBZJl3kNfoK6NKmYlz/D07+l2GWVK/QfDkNCuQ==} + '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@7.27.1': + resolution: {integrity: sha512-g4L7OYun04N1WyqMNjldFwlfPCLVkgB54A/YCXICZYBsvJJE3kByKv9c9+R/nAfmIfjl2rKYLNyMHboYbZaWaA==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0 + + '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@7.27.1': + resolution: {integrity: sha512-oO02gcONcD5O1iTLi/6frMJBIwWEHceWGSGqrpCmEL8nogiS6J9PBlE48CaK20/Jx1LuRml9aDftLgdjXT8+Cw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.13.0 - '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@7.24.7': - resolution: {integrity: sha512-utA4HuR6F4Vvcr+o4DnjL8fCOlgRFGbeeBEGNg3ZTrLFw6VWG5XmUrvcQ0FjIYMU2ST4XcR2Wsp7t9qOAPnxMg==} + '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@7.28.3': + resolution: {integrity: sha512-b6YTX108evsvE4YgWyQ921ZAFFQm3Bn+CA3+ZXlNVnPhx+UfsVURoPjfGAPCjBgrqo30yX/C2nZGX96DxvR9Iw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 @@ -292,507 +298,725 @@ packages: peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-async-generators@7.8.4': - resolution: {integrity: sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==} - peerDependencies: - '@babel/core': ^7.0.0-0 - - '@babel/plugin-syntax-class-properties@7.12.13': - resolution: {integrity: sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==} + '@babel/plugin-syntax-dynamic-import@7.8.3': + resolution: {integrity: sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-class-static-block@7.14.5': - resolution: {integrity: sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==} + '@babel/plugin-syntax-import-assertions@7.27.1': + resolution: {integrity: sha512-UT/Jrhw57xg4ILHLFnzFpPDlMbcdEicaAtjPQpbj9wa8T4r5KVWCimHcL/460g8Ht0DMxDyjsLgiWSkVjnwPFg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-dynamic-import@7.8.3': - resolution: {integrity: sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==} + '@babel/plugin-syntax-import-attributes@7.27.1': + resolution: {integrity: sha512-oFT0FrKHgF53f4vOsZGi2Hh3I35PfSmVs4IBFLFj4dnafP+hIWDLg3VyKmUHfLoLHlyxY4C7DGtmHuJgn+IGww==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-export-namespace-from@7.8.3': - resolution: {integrity: sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==} + '@babel/plugin-syntax-jsx@7.27.1': + resolution: {integrity: sha512-y8YTNIeKoyhGd9O0Jiyzyyqk8gdjnumGTQPsz0xOZOQ2RmkVJeZ1vmmfIvFEKqucBG6axJGBZDE/7iI5suUI/w==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-import-assertions@7.24.7': - resolution: {integrity: sha512-Ec3NRUMoi8gskrkBe3fNmEQfxDvY8bgfQpz6jlk/41kX9eUjvpyqWU7PBP/pLAvMaSQjbMNKJmvX57jP+M6bPg==} + '@babel/plugin-syntax-typescript@7.27.1': + resolution: {integrity: sha512-xfYCBMxveHrRMnAWl1ZlPXOZjzkN82THFvLhQhFXFt81Z5HnN+EtUkZhv/zcKpmT3fzmWZB0ywiBrbC3vogbwQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-import-attributes@7.24.7': - resolution: {integrity: sha512-hbX+lKKeUMGihnK8nvKqmXBInriT3GVjzXKFriV3YC6APGxMbP8RZNFwy91+hocLXq90Mta+HshoB31802bb8A==} + '@babel/plugin-syntax-unicode-sets-regex@7.18.6': + resolution: {integrity: sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0 - '@babel/plugin-syntax-import-meta@7.10.4': - resolution: {integrity: sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==} + '@babel/plugin-transform-arrow-functions@7.27.1': + resolution: {integrity: sha512-8Z4TGic6xW70FKThA5HYEKKyBpOOsucTOD1DjU3fZxDg+K3zBJcXMFnt/4yQiZnf5+MiOMSXQ9PaEK/Ilh1DeA==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-json-strings@7.8.3': - resolution: {integrity: sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==} + '@babel/plugin-transform-async-generator-functions@7.28.0': + resolution: {integrity: sha512-BEOdvX4+M765icNPZeidyADIvQ1m1gmunXufXxvRESy/jNNyfovIqUyE7MVgGBjWktCoJlzvFA1To2O4ymIO3Q==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-jsx@7.24.7': - resolution: {integrity: sha512-6ddciUPe/mpMnOKv/U+RSd2vvVy+Yw/JfBB0ZHYjEZt9NLHmCUylNYlsbqCCS1Bffjlb0fCwC9Vqz+sBz6PsiQ==} + '@babel/plugin-transform-async-to-generator@7.27.1': + resolution: {integrity: sha512-NREkZsZVJS4xmTr8qzE5y8AfIPqsdQfRuUiLRTEzb7Qii8iFWCyDKaUV2c0rCuh4ljDZ98ALHP/PetiBV2nddA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-logical-assignment-operators@7.10.4': - resolution: {integrity: sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==} + '@babel/plugin-transform-block-scoped-functions@7.27.1': + resolution: {integrity: sha512-cnqkuOtZLapWYZUYM5rVIdv1nXYuFVIltZ6ZJ7nIj585QsjKM5dhL2Fu/lICXZ1OyIAFc7Qy+bvDAtTXqGrlhg==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-nullish-coalescing-operator@7.8.3': - resolution: {integrity: sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==} + '@babel/plugin-transform-block-scoping@7.28.4': + resolution: {integrity: sha512-1yxmvN0MJHOhPVmAsmoW5liWwoILobu/d/ShymZmj867bAdxGbehIrew1DuLpw2Ukv+qDSSPQdYW1dLNE7t11A==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-numeric-separator@7.10.4': - resolution: {integrity: sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==} + '@babel/plugin-transform-class-properties@7.27.1': + resolution: {integrity: sha512-D0VcalChDMtuRvJIu3U/fwWjf8ZMykz5iZsg77Nuj821vCKI3zCyRLwRdWbsuJ/uRwZhZ002QtCqIkwC/ZkvbA==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-object-rest-spread@7.8.3': - resolution: {integrity: sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==} + '@babel/plugin-transform-class-static-block@7.28.3': + resolution: {integrity: sha512-LtPXlBbRoc4Njl/oh1CeD/3jC+atytbnf/UqLoqTDcEYGUPj022+rvfkbDYieUrSj3CaV4yHDByPE+T2HwfsJg==} + engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.12.0 - '@babel/plugin-syntax-optional-catch-binding@7.8.3': - resolution: {integrity: sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==} + '@babel/plugin-transform-classes@7.28.4': + resolution: {integrity: sha512-cFOlhIYPBv/iBoc+KS3M6et2XPtbT2HiCRfBXWtfpc9OAyostldxIf9YAYB6ypURBBbx+Qv6nyrLzASfJe+hBA==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-optional-chaining@7.8.3': - resolution: {integrity: sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==} + '@babel/plugin-transform-computed-properties@7.27.1': + resolution: {integrity: sha512-lj9PGWvMTVksbWiDT2tW68zGS/cyo4AkZ/QTp0sQT0mjPopCmrSkzxeXkznjqBxzDI6TclZhOJbBmbBLjuOZUw==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-private-property-in-object@7.14.5': - resolution: {integrity: sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==} + '@babel/plugin-transform-destructuring@7.28.0': + resolution: {integrity: sha512-v1nrSMBiKcodhsyJ4Gf+Z0U/yawmJDBOTpEB3mcQY52r9RIyPneGyAS/yM6seP/8I+mWI3elOMtT5dB8GJVs+A==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-top-level-await@7.14.5': - resolution: {integrity: sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==} + '@babel/plugin-transform-dotall-regex@7.27.1': + resolution: {integrity: sha512-gEbkDVGRvjj7+T1ivxrfgygpT7GUd4vmODtYpbs0gZATdkX8/iSnOtZSxiZnsgm1YjTgjI6VKBGSJJevkrclzw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-typescript@7.24.7': - resolution: {integrity: sha512-c/+fVeJBB0FeKsFvwytYiUD+LBvhHjGSI0g446PRGdSVGZLRNArBUno2PETbAly3tpiNAQR5XaZ+JslxkotsbA==} + '@babel/plugin-transform-duplicate-keys@7.27.1': + resolution: {integrity: sha512-MTyJk98sHvSs+cvZ4nOauwTTG1JeonDjSGvGGUNHreGQns+Mpt6WX/dVzWBHgg+dYZhkC4X+zTDfkTU+Vy9y7Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-syntax-unicode-sets-regex@7.18.6': - resolution: {integrity: sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==} + '@babel/plugin-transform-duplicate-named-capturing-groups-regex@7.27.1': + resolution: {integrity: sha512-hkGcueTEzuhB30B3eJCbCYeCaaEQOmQR0AdvzpD4LoN0GXMWzzGSuRrxR2xTnCrvNbVwK9N6/jQ92GSLfiZWoQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 - '@babel/plugin-transform-arrow-functions@7.24.7': - resolution: {integrity: sha512-Dt9LQs6iEY++gXUwY03DNFat5C2NbO48jj+j/bSAz6b3HgPs39qcPiYt77fDObIcFwj3/C2ICX9YMwGflUoSHQ==} + '@babel/plugin-transform-dynamic-import@7.27.1': + resolution: {integrity: sha512-MHzkWQcEmjzzVW9j2q8LGjwGWpG2mjwaaB0BNQwst3FIjqsg8Ct/mIZlvSPJvfi9y2AC8mi/ktxbFVL9pZ1I4A==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-async-generator-functions@7.24.7': - resolution: {integrity: sha512-o+iF77e3u7ZS4AoAuJvapz9Fm001PuD2V3Lp6OSE4FYQke+cSewYtnek+THqGRWyQloRCyvWL1OkyfNEl9vr/g==} + '@babel/plugin-transform-explicit-resource-management@7.28.0': + resolution: {integrity: sha512-K8nhUcn3f6iB+P3gwCv/no7OdzOZQcKchW6N389V6PD8NUWKZHzndOd9sPDVbMoBsbmjMqlB4L9fm+fEFNVlwQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-async-to-generator@7.24.7': - resolution: {integrity: sha512-SQY01PcJfmQ+4Ash7NE+rpbLFbmqA2GPIgqzxfFTL4t1FKRq4zTms/7htKpoCUI9OcFYgzqfmCdH53s6/jn5fA==} + '@babel/plugin-transform-exponentiation-operator@7.27.1': + resolution: {integrity: sha512-uspvXnhHvGKf2r4VVtBpeFnuDWsJLQ6MF6lGJLC89jBR1uoVeqM416AZtTuhTezOfgHicpJQmoD5YUakO/YmXQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-block-scoped-functions@7.24.7': - resolution: {integrity: sha512-yO7RAz6EsVQDaBH18IDJcMB1HnrUn2FJ/Jslc/WtPPWcjhpUJXU/rjbwmluzp7v/ZzWcEhTMXELnnsz8djWDwQ==} + '@babel/plugin-transform-export-namespace-from@7.27.1': + resolution: {integrity: sha512-tQvHWSZ3/jH2xuq/vZDy0jNn+ZdXJeM8gHvX4lnJmsc3+50yPlWdZXIc5ay+umX+2/tJIqHqiEqcJvxlmIvRvQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-block-scoping@7.24.7': - resolution: {integrity: sha512-Nd5CvgMbWc+oWzBsuaMcbwjJWAcp5qzrbg69SZdHSP7AMY0AbWFqFO0WTFCA1jxhMCwodRwvRec8k0QUbZk7RQ==} + '@babel/plugin-transform-for-of@7.27.1': + resolution: {integrity: sha512-BfbWFFEJFQzLCQ5N8VocnCtA8J1CLkNTe2Ms2wocj75dd6VpiqS5Z5quTYcUoo4Yq+DN0rtikODccuv7RU81sw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-class-properties@7.24.7': - resolution: {integrity: sha512-vKbfawVYayKcSeSR5YYzzyXvsDFWU2mD8U5TFeXtbCPLFUqe7GyCgvO6XDHzje862ODrOwy6WCPmKeWHbCFJ4w==} + '@babel/plugin-transform-function-name@7.27.1': + resolution: {integrity: sha512-1bQeydJF9Nr1eBCMMbC+hdwmRlsv5XYOMu03YSWFwNs0HsAmtSxxF1fyuYPqemVldVyFmlCU7w8UE14LupUSZQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-class-static-block@7.24.7': - resolution: {integrity: sha512-HMXK3WbBPpZQufbMG4B46A90PkuuhN9vBCb5T8+VAHqvAqvcLi+2cKoukcpmUYkszLhScU3l1iudhrks3DggRQ==} + '@babel/plugin-transform-json-strings@7.27.1': + resolution: {integrity: sha512-6WVLVJiTjqcQauBhn1LkICsR2H+zm62I3h9faTDKt1qP4jn2o72tSvqMwtGFKGTpojce0gJs+76eZ2uCHRZh0Q==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.12.0 + '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-classes@7.24.7': - resolution: {integrity: sha512-CFbbBigp8ln4FU6Bpy6g7sE8B/WmCmzvivzUC6xDAdWVsjYTXijpuuGJmYkAaoWAzcItGKT3IOAbxRItZ5HTjw==} + '@babel/plugin-transform-literals@7.27.1': + resolution: {integrity: sha512-0HCFSepIpLTkLcsi86GG3mTUzxV5jpmbv97hTETW3yzrAij8aqlD36toB1D0daVFJM8NK6GvKO0gslVQmm+zZA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-computed-properties@7.24.7': - resolution: {integrity: sha512-25cS7v+707Gu6Ds2oY6tCkUwsJ9YIDbggd9+cu9jzzDgiNq7hR/8dkzxWfKWnTic26vsI3EsCXNd4iEB6e8esQ==} + '@babel/plugin-transform-logical-assignment-operators@7.27.1': + resolution: {integrity: sha512-SJvDs5dXxiae4FbSL1aBJlG4wvl594N6YEVVn9e3JGulwioy6z3oPjx/sQBO3Y4NwUu5HNix6KJ3wBZoewcdbw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-destructuring@7.24.7': - resolution: {integrity: sha512-19eJO/8kdCQ9zISOf+SEUJM/bAUIsvY3YDnXZTupUCQ8LgrWnsG/gFB9dvXqdXnRXMAM8fvt7b0CBKQHNGy1mw==} + '@babel/plugin-transform-member-expression-literals@7.27.1': + resolution: {integrity: sha512-hqoBX4dcZ1I33jCSWcXrP+1Ku7kdqXf1oeah7ooKOIiAdKQ+uqftgCFNOSzA5AMS2XIHEYeGFg4cKRCdpxzVOQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-dotall-regex@7.24.7': - resolution: {integrity: sha512-ZOA3W+1RRTSWvyqcMJDLqbchh7U4NRGqwRfFSVbOLS/ePIP4vHB5e8T8eXcuqyN1QkgKyj5wuW0lcS85v4CrSw==} + '@babel/plugin-transform-modules-amd@7.27.1': + resolution: {integrity: sha512-iCsytMg/N9/oFq6n+gFTvUYDZQOMK5kEdeYxmxt91fcJGycfxVP9CnrxoliM0oumFERba2i8ZtwRUCMhvP1LnA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-duplicate-keys@7.24.7': - resolution: {integrity: sha512-JdYfXyCRihAe46jUIliuL2/s0x0wObgwwiGxw/UbgJBr20gQBThrokO4nYKgWkD7uBaqM7+9x5TU7NkExZJyzw==} + '@babel/plugin-transform-modules-commonjs@7.27.1': + resolution: {integrity: sha512-OJguuwlTYlN0gBZFRPqwOGNWssZjfIUdS7HMYtN8c1KmwpwHFBwTeFZrg9XZa+DFTitWOW5iTAG7tyCUPsCCyw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-dynamic-import@7.24.7': - resolution: {integrity: sha512-sc3X26PhZQDb3JhORmakcbvkeInvxz+A8oda99lj7J60QRuPZvNAk9wQlTBS1ZynelDrDmTU4pw1tyc5d5ZMUg==} + '@babel/plugin-transform-modules-systemjs@7.27.1': + resolution: {integrity: sha512-w5N1XzsRbc0PQStASMksmUeqECuzKuTJer7kFagK8AXgpCMkeDMO5S+aaFb7A51ZYDF7XI34qsTX+fkHiIm5yA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-exponentiation-operator@7.24.7': - resolution: {integrity: sha512-Rqe/vSc9OYgDajNIK35u7ot+KeCoetqQYFXM4Epf7M7ez3lWlOjrDjrwMei6caCVhfdw+mIKD4cgdGNy5JQotQ==} + '@babel/plugin-transform-modules-umd@7.27.1': + resolution: {integrity: sha512-iQBE/xC5BV1OxJbp6WG7jq9IWiD+xxlZhLrdwpPkTX3ydmXdvoCpyfJN7acaIBZaOqTfr76pgzqBJflNbeRK+w==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-export-namespace-from@7.24.7': - resolution: {integrity: sha512-v0K9uNYsPL3oXZ/7F9NNIbAj2jv1whUEtyA6aujhekLs56R++JDQuzRcP2/z4WX5Vg/c5lE9uWZA0/iUoFhLTA==} + '@babel/plugin-transform-named-capturing-groups-regex@7.27.1': + resolution: {integrity: sha512-SstR5JYy8ddZvD6MhV0tM/j16Qds4mIpJTOd1Yu9J9pJjH93bxHECF7pgtc28XvkzTD6Pxcm/0Z73Hvk7kb3Ng==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0 - '@babel/plugin-transform-for-of@7.24.7': - resolution: {integrity: sha512-wo9ogrDG1ITTTBsy46oGiN1dS9A7MROBTcYsfS8DtsImMkHk9JXJ3EWQM6X2SUw4x80uGPlwj0o00Uoc6nEE3g==} + '@babel/plugin-transform-new-target@7.27.1': + resolution: {integrity: sha512-f6PiYeqXQ05lYq3TIfIDu/MtliKUbNwkGApPUvyo6+tc7uaR4cPjPe7DFPr15Uyycg2lZU6btZ575CuQoYh7MQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-function-name@7.24.7': - resolution: {integrity: sha512-U9FcnA821YoILngSmYkW6FjyQe2TyZD5pHt4EVIhmcTkrJw/3KqcrRSxuOo5tFZJi7TE19iDyI1u+weTI7bn2w==} + '@babel/plugin-transform-nullish-coalescing-operator@7.27.1': + resolution: {integrity: sha512-aGZh6xMo6q9vq1JGcw58lZ1Z0+i0xB2x0XaauNIUXd6O1xXc3RwoWEBlsTQrY4KQ9Jf0s5rgD6SiNkaUdJegTA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-json-strings@7.24.7': - resolution: {integrity: sha512-2yFnBGDvRuxAaE/f0vfBKvtnvvqU8tGpMHqMNpTN2oWMKIR3NqFkjaAgGwawhqK/pIN2T3XdjGPdaG0vDhOBGw==} + '@babel/plugin-transform-numeric-separator@7.27.1': + resolution: {integrity: sha512-fdPKAcujuvEChxDBJ5c+0BTaS6revLV7CJL08e4m3de8qJfNIuCc2nc7XJYOjBoTMJeqSmwXJ0ypE14RCjLwaw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-literals@7.24.7': - resolution: {integrity: sha512-vcwCbb4HDH+hWi8Pqenwnjy+UiklO4Kt1vfspcQYFhJdpthSnW8XvWGyDZWKNVrVbVViI/S7K9PDJZiUmP2fYQ==} + '@babel/plugin-transform-object-rest-spread@7.28.4': + resolution: {integrity: sha512-373KA2HQzKhQCYiRVIRr+3MjpCObqzDlyrM6u4I201wL8Mp2wHf7uB8GhDwis03k2ti8Zr65Zyyqs1xOxUF/Ew==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-logical-assignment-operators@7.24.7': - resolution: {integrity: sha512-4D2tpwlQ1odXmTEIFWy9ELJcZHqrStlzK/dAOWYyxX3zT0iXQB6banjgeOJQXzEc4S0E0a5A+hahxPaEFYftsw==} + '@babel/plugin-transform-object-super@7.27.1': + resolution: {integrity: sha512-SFy8S9plRPbIcxlJ8A6mT/CxFdJx/c04JEctz4jf8YZaVS2px34j7NXRrlGlHkN/M2gnpL37ZpGRGVFLd3l8Ng==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-member-expression-literals@7.24.7': - resolution: {integrity: sha512-T/hRC1uqrzXMKLQ6UCwMT85S3EvqaBXDGf0FaMf4446Qx9vKwlghvee0+uuZcDUCZU5RuNi4781UQ7R308zzBw==} + '@babel/plugin-transform-optional-catch-binding@7.27.1': + resolution: {integrity: sha512-txEAEKzYrHEX4xSZN4kJ+OfKXFVSWKB2ZxM9dpcE3wT7smwkNmXo5ORRlVzMVdJbD+Q8ILTgSD7959uj+3Dm3Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-modules-amd@7.24.7': - resolution: {integrity: sha512-9+pB1qxV3vs/8Hdmz/CulFB8w2tuu6EB94JZFsjdqxQokwGa9Unap7Bo2gGBGIvPmDIVvQrom7r5m/TCDMURhg==} + '@babel/plugin-transform-optional-chaining@7.27.1': + resolution: {integrity: sha512-BQmKPPIuc8EkZgNKsv0X4bPmOoayeu4F1YCwx2/CfmDSXDbp7GnzlUH+/ul5VGfRg1AoFPsrIThlEBj2xb4CAg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-modules-commonjs@7.24.7': - resolution: {integrity: sha512-iFI8GDxtevHJ/Z22J5xQpVqFLlMNstcLXh994xifFwxxGslr2ZXXLWgtBeLctOD63UFDArdvN6Tg8RFw+aEmjQ==} + '@babel/plugin-transform-parameters@7.27.7': + resolution: {integrity: sha512-qBkYTYCb76RRxUM6CcZA5KRu8K4SM8ajzVeUgVdMVO9NN9uI/GaVmBg/WKJJGnNokV9SY8FxNOVWGXzqzUidBg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-modules-systemjs@7.24.7': - resolution: {integrity: sha512-GYQE0tW7YoaN13qFh3O1NCY4MPkUiAH3fiF7UcV/I3ajmDKEdG3l+UOcbAm4zUE3gnvUU+Eni7XrVKo9eO9auw==} + '@babel/plugin-transform-private-methods@7.27.1': + resolution: {integrity: sha512-10FVt+X55AjRAYI9BrdISN9/AQWHqldOeZDUoLyif1Kn05a56xVBXb8ZouL8pZ9jem8QpXaOt8TS7RHUIS+GPA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-modules-umd@7.24.7': - resolution: {integrity: sha512-3aytQvqJ/h9z4g8AsKPLvD4Zqi2qT+L3j7XoFFu1XBlZWEl2/1kWnhmAbxpLgPrHSY0M6UA02jyTiwUVtiKR6A==} + '@babel/plugin-transform-private-property-in-object@7.27.1': + resolution: {integrity: sha512-5J+IhqTi1XPa0DXF83jYOaARrX+41gOewWbkPyjMNRDqgOCqdffGh8L3f/Ek5utaEBZExjSAzcyjmV9SSAWObQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-named-capturing-groups-regex@7.24.7': - resolution: {integrity: sha512-/jr7h/EWeJtk1U/uz2jlsCioHkZk1JJZVcc8oQsJ1dUlaJD83f4/6Zeh2aHt9BIFokHIsSeDfhUmju0+1GPd6g==} + '@babel/plugin-transform-property-literals@7.27.1': + resolution: {integrity: sha512-oThy3BCuCha8kDZ8ZkgOg2exvPYUlprMukKQXI1r1pJ47NCvxfkEy8vK+r/hT9nF0Aa4H1WUPZZjHTFtAhGfmQ==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0 + '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-new-target@7.24.7': - resolution: {integrity: sha512-RNKwfRIXg4Ls/8mMTza5oPF5RkOW8Wy/WgMAp1/F1yZ8mMbtwXW+HDoJiOsagWrAhI5f57Vncrmr9XeT4CVapA==} + '@babel/plugin-transform-react-constant-elements@7.27.1': + resolution: {integrity: sha512-edoidOjl/ZxvYo4lSBOQGDSyToYVkTAwyVoa2tkuYTSmjrB1+uAedoL5iROVLXkxH+vRgA7uP4tMg2pUJpZ3Ug==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-nullish-coalescing-operator@7.24.7': - resolution: {integrity: sha512-Ts7xQVk1OEocqzm8rHMXHlxvsfZ0cEF2yomUqpKENHWMF4zKk175Y4q8H5knJes6PgYad50uuRmt3UJuhBw8pQ==} + '@babel/plugin-transform-react-display-name@7.28.0': + resolution: {integrity: sha512-D6Eujc2zMxKjfa4Zxl4GHMsmhKKZ9VpcqIchJLvwTxad9zWIYulwYItBovpDOoNLISpcZSXoDJ5gaGbQUDqViA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-numeric-separator@7.24.7': - resolution: {integrity: sha512-e6q1TiVUzvH9KRvicuxdBTUj4AdKSRwzIyFFnfnezpCfP2/7Qmbb8qbU2j7GODbl4JMkblitCQjKYUaX/qkkwA==} + '@babel/plugin-transform-react-jsx-development@7.27.1': + resolution: {integrity: sha512-ykDdF5yI4f1WrAolLqeF3hmYU12j9ntLQl/AOG1HAS21jxyg1Q0/J/tpREuYLfatGdGmXp/3yS0ZA76kOlVq9Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-object-rest-spread@7.24.7': - resolution: {integrity: sha512-4QrHAr0aXQCEFni2q4DqKLD31n2DL+RxcwnNjDFkSG0eNQ/xCavnRkfCUjsyqGC2OviNJvZOF/mQqZBw7i2C5Q==} + '@babel/plugin-transform-react-jsx@7.27.1': + resolution: {integrity: sha512-2KH4LWGSrJIkVf5tSiBFYuXDAoWRq2MMwgivCf+93dd0GQi8RXLjKA/0EvRnVV5G0hrHczsquXuD01L8s6dmBw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-object-super@7.24.7': - resolution: {integrity: sha512-A/vVLwN6lBrMFmMDmPPz0jnE6ZGx7Jq7d6sT/Ev4H65RER6pZ+kczlf1DthF5N0qaPHBsI7UXiE8Zy66nmAovg==} + '@babel/plugin-transform-react-pure-annotations@7.27.1': + resolution: {integrity: sha512-JfuinvDOsD9FVMTHpzA/pBLisxpv1aSf+OIV8lgH3MuWrks19R27e6a6DipIg4aX1Zm9Wpb04p8wljfKrVSnPA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-optional-catch-binding@7.24.7': - resolution: {integrity: sha512-uLEndKqP5BfBbC/5jTwPxLh9kqPWWgzN/f8w6UwAIirAEqiIVJWWY312X72Eub09g5KF9+Zn7+hT7sDxmhRuKA==} + '@babel/plugin-transform-regenerator@7.28.4': + resolution: {integrity: sha512-+ZEdQlBoRg9m2NnzvEeLgtvBMO4tkFBw5SQIUgLICgTrumLoU7lr+Oghi6km2PFj+dbUt2u1oby2w3BDO9YQnA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-optional-chaining@7.24.7': - resolution: {integrity: sha512-tK+0N9yd4j+x/4hxF3F0e0fu/VdcxU18y5SevtyM/PCFlQvXbR0Zmlo2eBrKtVipGNFzpq56o8WsIIKcJFUCRQ==} + '@babel/plugin-transform-regexp-modifiers@7.27.1': + resolution: {integrity: sha512-TtEciroaiODtXvLZv4rmfMhkCv8jx3wgKpL68PuiPh2M4fvz5jhsA7697N1gMvkvr/JTF13DrFYyEbY9U7cVPA==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0 - '@babel/plugin-transform-parameters@7.24.7': - resolution: {integrity: sha512-yGWW5Rr+sQOhK0Ot8hjDJuxU3XLRQGflvT4lhlSY0DFvdb3TwKaY26CJzHtYllU0vT9j58hc37ndFPsqT1SrzA==} + '@babel/plugin-transform-reserved-words@7.27.1': + resolution: {integrity: sha512-V2ABPHIJX4kC7HegLkYoDpfg9PVmuWy/i6vUM5eGK22bx4YVFD3M5F0QQnWQoDs6AGsUWTVOopBiMFQgHaSkVw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-private-methods@7.24.7': - resolution: {integrity: sha512-COTCOkG2hn4JKGEKBADkA8WNb35TGkkRbI5iT845dB+NyqgO8Hn+ajPbSnIQznneJTa3d30scb6iz/DhH8GsJQ==} + '@babel/plugin-transform-runtime@7.28.3': + resolution: {integrity: sha512-Y6ab1kGqZ0u42Zv/4a7l0l72n9DKP/MKoKWaUSBylrhNZO2prYuqFOLbn5aW5SIFXwSH93yfjbgllL8lxuGKLg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-private-property-in-object@7.24.7': - resolution: {integrity: sha512-9z76mxwnwFxMyxZWEgdgECQglF2Q7cFLm0kMf8pGwt+GSJsY0cONKj/UuO4bOH0w/uAel3ekS4ra5CEAyJRmDA==} + '@babel/plugin-transform-shorthand-properties@7.27.1': + resolution: {integrity: sha512-N/wH1vcn4oYawbJ13Y/FxcQrWk63jhfNa7jef0ih7PHSIHX2LB7GWE1rkPrOnka9kwMxb6hMl19p7lidA+EHmQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-property-literals@7.24.7': - resolution: {integrity: sha512-EMi4MLQSHfd2nrCqQEWxFdha2gBCqU4ZcCng4WBGZ5CJL4bBRW0ptdqqDdeirGZcpALazVVNJqRmsO8/+oNCBA==} + '@babel/plugin-transform-spread@7.27.1': + resolution: {integrity: sha512-kpb3HUqaILBJcRFVhFUs6Trdd4mkrzcGXss+6/mxUd273PfbWqSDHRzMT2234gIg2QYfAjvXLSquP1xECSg09Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-react-constant-elements@7.24.7': - resolution: {integrity: sha512-7LidzZfUXyfZ8/buRW6qIIHBY8wAZ1OrY9c/wTr8YhZ6vMPo+Uc/CVFLYY1spZrEQlD4w5u8wjqk5NQ3OVqQKA==} + '@babel/plugin-transform-sticky-regex@7.27.1': + resolution: {integrity: sha512-lhInBO5bi/Kowe2/aLdBAawijx+q1pQzicSgnkB6dUPc1+RC8QmJHKf2OjvU+NZWitguJHEaEmbV6VWEouT58g==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-react-display-name@7.24.7': - resolution: {integrity: sha512-H/Snz9PFxKsS1JLI4dJLtnJgCJRoo0AUm3chP6NYr+9En1JMKloheEiLIhlp5MDVznWo+H3AAC1Mc8lmUEpsgg==} + '@babel/plugin-transform-template-literals@7.27.1': + resolution: {integrity: sha512-fBJKiV7F2DxZUkg5EtHKXQdbsbURW3DZKQUWphDum0uRP6eHGGa/He9mc0mypL680pb+e/lDIthRohlv8NCHkg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-react-jsx-development@7.24.7': - resolution: {integrity: sha512-QG9EnzoGn+Qar7rxuW+ZOsbWOt56FvvI93xInqsZDC5fsekx1AlIO4KIJ5M+D0p0SqSH156EpmZyXq630B8OlQ==} + '@babel/plugin-transform-typeof-symbol@7.27.1': + resolution: {integrity: sha512-RiSILC+nRJM7FY5srIyc4/fGIwUhyDuuBSdWn4y6yT6gm652DpCHZjIipgn6B7MQ1ITOUnAKWixEUjQRIBIcLw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-react-jsx@7.24.7': - resolution: {integrity: sha512-+Dj06GDZEFRYvclU6k4bme55GKBEWUmByM/eoKuqg4zTNQHiApWRhQph5fxQB2wAEFvRzL1tOEj1RJ19wJrhoA==} + '@babel/plugin-transform-typescript@7.28.0': + resolution: {integrity: sha512-4AEiDEBPIZvLQaWlc9liCavE0xRM0dNca41WtBeM3jgFptfUOSG9z0uteLhq6+3rq+WB6jIvUwKDTpXEHPJ2Vg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-react-pure-annotations@7.24.7': - resolution: {integrity: sha512-PLgBVk3fzbmEjBJ/u8kFzOqS9tUeDjiaWud/rRym/yjCo/M9cASPlnrd2ZmmZpQT40fOOrvR8jh+n8jikrOhNA==} + '@babel/plugin-transform-unicode-escapes@7.27.1': + resolution: {integrity: sha512-Ysg4v6AmF26k9vpfFuTZg8HRfVWzsh1kVfowA23y9j/Gu6dOuahdUVhkLqpObp3JIv27MLSii6noRnuKN8H0Mg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-regenerator@7.24.7': - resolution: {integrity: sha512-lq3fvXPdimDrlg6LWBoqj+r/DEWgONuwjuOuQCSYgRroXDH/IdM1C0IZf59fL5cHLpjEH/O6opIRBbqv7ELnuA==} + '@babel/plugin-transform-unicode-property-regex@7.27.1': + resolution: {integrity: sha512-uW20S39PnaTImxp39O5qFlHLS9LJEmANjMG7SxIhap8rCHqu0Ik+tLEPX5DKmHn6CsWQ7j3lix2tFOa5YtL12Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-reserved-words@7.24.7': - resolution: {integrity: sha512-0DUq0pHcPKbjFZCfTss/pGkYMfy3vFWydkUBd9r0GHpIyfs2eCDENvqadMycRS9wZCXR41wucAfJHJmwA0UmoQ==} + '@babel/plugin-transform-unicode-regex@7.27.1': + resolution: {integrity: sha512-xvINq24TRojDuyt6JGtHmkVkrfVV3FPT16uytxImLeBZqW3/H52yN+kM1MGuyPkIQxrzKwPHs5U/MP3qKyzkGw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-runtime@7.24.7': - resolution: {integrity: sha512-YqXjrk4C+a1kZjewqt+Mmu2UuV1s07y8kqcUf4qYLnoqemhR4gRQikhdAhSVJioMjVTu6Mo6pAbaypEA3jY6fw==} + '@babel/plugin-transform-unicode-sets-regex@7.27.1': + resolution: {integrity: sha512-EtkOujbc4cgvb0mlpQefi4NTPBzhSIevblFevACNLUspmrALgmEBdL/XfnyyITfd8fKBZrZys92zOWcik7j9Tw==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0 - '@babel/plugin-transform-shorthand-properties@7.24.7': - resolution: {integrity: sha512-KsDsevZMDsigzbA09+vacnLpmPH4aWjcZjXdyFKGzpplxhbeB4wYtury3vglQkg6KM/xEPKt73eCjPPf1PgXBA==} + '@babel/preset-env@7.28.3': + resolution: {integrity: sha512-ROiDcM+GbYVPYBOeCR6uBXKkQpBExLl8k9HO1ygXEyds39j+vCCsjmj7S8GOniZQlEs81QlkdJZe76IpLSiqpg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-spread@7.24.7': - resolution: {integrity: sha512-x96oO0I09dgMDxJaANcRyD4ellXFLLiWhuwDxKZX5g2rWP1bTPkBSwCYv96VDXVT1bD9aPj8tppr5ITIh8hBng==} - engines: {node: '>=6.9.0'} + '@babel/preset-modules@0.1.6-no-external-plugins': + resolution: {integrity: sha512-HrcgcIESLm9aIR842yhJ5RWan/gebQUJ6E/E5+rf0y9o6oj7w0Br+sWuL6kEQ/o/AdfvR1Je9jG18/gnpwjEyA==} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0-0 || ^8.0.0-0 <8.0.0 - '@babel/plugin-transform-sticky-regex@7.24.7': - resolution: {integrity: sha512-kHPSIJc9v24zEml5geKg9Mjx5ULpfncj0wRpYtxbvKyTtHCYDkVE3aHQ03FrpEo4gEe2vrJJS1Y9CJTaThA52g==} + '@babel/preset-react@7.27.1': + resolution: {integrity: sha512-oJHWh2gLhU9dW9HHr42q0cI0/iHHXTLGe39qvpAZZzagHy0MzYLCnCVV0symeRvzmjHyVU7mw2K06E6u/JwbhA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-template-literals@7.24.7': - resolution: {integrity: sha512-AfDTQmClklHCOLxtGoP7HkeMw56k1/bTQjwsfhL6pppo/M4TOBSq+jjBUBLmV/4oeFg4GWMavIl44ZeCtmmZTw==} + '@babel/preset-typescript@7.27.1': + resolution: {integrity: sha512-l7WfQfX0WK4M0v2RudjuQK4u99BS6yLHYEmdtVPP7lKV013zr9DygFuWNlnbvQ9LR+LS0Egz/XAvGx5U9MX0fQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-typeof-symbol@7.24.7': - resolution: {integrity: sha512-VtR8hDy7YLB7+Pet9IarXjg/zgCMSF+1mNS/EQEiEaUPoFXCVsHG64SIxcaaI2zJgRiv+YmgaQESUfWAdbjzgg==} + '@babel/runtime-corejs3@7.28.4': + resolution: {integrity: sha512-h7iEYiW4HebClDEhtvFObtPmIvrd1SSfpI9EhOeKk4CtIK/ngBWFpuhCzhdmRKtg71ylcue+9I6dv54XYO1epQ==} engines: {node: '>=6.9.0'} - peerDependencies: - '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-typescript@7.24.7': - resolution: {integrity: sha512-iLD3UNkgx2n/HrjBesVbYX6j0yqn/sJktvbtKKgcaLIQ4bTTQ8obAypc1VpyHPD2y4Phh9zHOaAt8e/L14wCpw==} + '@babel/runtime@7.28.4': + resolution: {integrity: sha512-Q/N6JNWvIvPnLDvjlE1OUBLPQHH6l3CltCEsHIujp45zQUSSh8K+gHnaEX45yAT1nyngnINhvWtzN+Nb9D8RAQ==} engines: {node: '>=6.9.0'} - peerDependencies: - '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-unicode-escapes@7.24.7': - resolution: {integrity: sha512-U3ap1gm5+4edc2Q/P+9VrBNhGkfnf+8ZqppY71Bo/pzZmXhhLdqgaUl6cuB07O1+AQJtCLfaOmswiNbSQ9ivhw==} + '@babel/template@7.27.2': + resolution: {integrity: sha512-LPDZ85aEJyYSd18/DkjNh4/y1ntkE5KwUHWTiqgRxruuZL2F1yuHligVHLvcHY2vMHXttKFpJn6LwfI7cw7ODw==} engines: {node: '>=6.9.0'} - peerDependencies: - '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-unicode-property-regex@7.24.7': - resolution: {integrity: sha512-uH2O4OV5M9FZYQrwc7NdVmMxQJOCCzFeYudlZSzUAHRFeOujQefa92E74TQDVskNHCzOXoigEuoyzHDhaEaK5w==} + '@babel/traverse@7.28.4': + resolution: {integrity: sha512-YEzuboP2qvQavAcjgQNVgsvHIDv6ZpwXvcvjmyySP2DIMuByS/6ioU5G9pYrWHM6T2YDfc7xga9iNzYOs12CFQ==} engines: {node: '>=6.9.0'} - peerDependencies: - '@babel/core': ^7.0.0-0 - '@babel/plugin-transform-unicode-regex@7.24.7': - resolution: {integrity: sha512-hlQ96MBZSAXUq7ltkjtu3FJCCSMx/j629ns3hA3pXnBXjanNP0LHi+JpPeA81zaWgVK1VGH95Xuy7u0RyQ8kMg==} + '@babel/types@7.28.4': + resolution: {integrity: sha512-bkFqkLhh3pMBUQQkpVgWDWq/lqzc2678eUyDlTBhRqhCHFguYYGM0Efga7tYk4TogG/3x0EEl66/OQ+WGbWB/Q==} engines: {node: '>=6.9.0'} + + '@colors/colors@1.5.0': + resolution: {integrity: sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==} + engines: {node: '>=0.1.90'} + + '@csstools/cascade-layer-name-parser@2.0.5': + resolution: {integrity: sha512-p1ko5eHgV+MgXFVa4STPKpvPxr6ReS8oS2jzTukjR74i5zJNyWO1ZM1m8YKBXnzDKWfBN1ztLYlHxbVemDD88A==} + engines: {node: '>=18'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@csstools/css-parser-algorithms': ^3.0.5 + '@csstools/css-tokenizer': ^3.0.4 - '@babel/plugin-transform-unicode-sets-regex@7.24.7': - resolution: {integrity: sha512-2G8aAvF4wy1w/AGZkemprdGMRg5o6zPNhbHVImRz3lss55TYCBd6xStN19rt8XJHq20sqV0JbyWjOWwQRwV/wg==} - engines: {node: '>=6.9.0'} + '@csstools/color-helpers@5.1.0': + resolution: {integrity: sha512-S11EXWJyy0Mz5SYvRmY8nJYTFFd1LCNV+7cXyAgQtOOuzb4EsgfqDufL+9esx72/eLhsRdGZwaldu/h+E4t4BA==} + engines: {node: '>=18'} + + '@csstools/css-calc@2.1.4': + resolution: {integrity: sha512-3N8oaj+0juUw/1H3YwmDDJXCgTB1gKU6Hc/bB502u9zR0q2vd786XJH9QfrKIEgFlZmhZiq6epXl4rHqhzsIgQ==} + engines: {node: '>=18'} peerDependencies: - '@babel/core': ^7.0.0 + '@csstools/css-parser-algorithms': ^3.0.5 + '@csstools/css-tokenizer': ^3.0.4 - '@babel/preset-env@7.24.7': - resolution: {integrity: sha512-1YZNsc+y6cTvWlDHidMBsQZrZfEFjRIo/BZCT906PMdzOyXtSLTgqGdrpcuTDCXyd11Am5uQULtDIcCfnTc8fQ==} - engines: {node: '>=6.9.0'} + '@csstools/css-color-parser@3.1.0': + resolution: {integrity: sha512-nbtKwh3a6xNVIp/VRuXV64yTKnb1IjTAEEh3irzS+HkKjAOYLTGNb9pmVNntZ8iVBHcWDA2Dof0QtPgFI1BaTA==} + engines: {node: '>=18'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@csstools/css-parser-algorithms': ^3.0.5 + '@csstools/css-tokenizer': ^3.0.4 - '@babel/preset-modules@0.1.6-no-external-plugins': - resolution: {integrity: sha512-HrcgcIESLm9aIR842yhJ5RWan/gebQUJ6E/E5+rf0y9o6oj7w0Br+sWuL6kEQ/o/AdfvR1Je9jG18/gnpwjEyA==} + '@csstools/css-parser-algorithms@3.0.5': + resolution: {integrity: sha512-DaDeUkXZKjdGhgYaHNJTV9pV7Y9B3b644jCLs9Upc3VeNGg6LWARAT6O+Q+/COo+2gg/bM5rhpMAtf70WqfBdQ==} + engines: {node: '>=18'} peerDependencies: - '@babel/core': ^7.0.0-0 || ^8.0.0-0 <8.0.0 + '@csstools/css-tokenizer': ^3.0.4 - '@babel/preset-react@7.24.7': - resolution: {integrity: sha512-AAH4lEkpmzFWrGVlHaxJB7RLH21uPQ9+He+eFLWHmF9IuFQVugz8eAsamaW0DXRrTfco5zj1wWtpdcXJUOfsag==} - engines: {node: '>=6.9.0'} + '@csstools/css-tokenizer@3.0.4': + resolution: {integrity: sha512-Vd/9EVDiu6PPJt9yAh6roZP6El1xHrdvIVGjyBsHR0RYwNHgL7FJPyIIW4fANJNG6FtyZfvlRPpFI4ZM/lubvw==} + engines: {node: '>=18'} + + '@csstools/media-query-list-parser@4.0.3': + resolution: {integrity: sha512-HAYH7d3TLRHDOUQK4mZKf9k9Ph/m8Akstg66ywKR4SFAigjs3yBiUeZtFxywiTm5moZMAp/5W/ZuFnNXXYLuuQ==} + engines: {node: '>=18'} peerDependencies: - '@babel/core': ^7.0.0-0 + '@csstools/css-parser-algorithms': ^3.0.5 + '@csstools/css-tokenizer': ^3.0.4 - '@babel/preset-typescript@7.24.7': - resolution: {integrity: sha512-SyXRe3OdWwIwalxDg5UtJnJQO+YPcTfwiIY2B0Xlddh9o7jpWLvv8X1RthIeDOxQ+O1ML5BLPCONToObyVQVuQ==} - engines: {node: '>=6.9.0'} + '@csstools/postcss-alpha-function@1.0.1': + resolution: {integrity: sha512-isfLLwksH3yHkFXfCI2Gcaqg7wGGHZZwunoJzEZk0yKYIokgre6hYVFibKL3SYAoR1kBXova8LB+JoO5vZzi9w==} + engines: {node: '>=18'} peerDependencies: - '@babel/core': ^7.0.0-0 + postcss: ^8.4 - '@babel/regjsgen@0.8.0': - resolution: {integrity: sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==} + '@csstools/postcss-cascade-layers@5.0.2': + resolution: {integrity: sha512-nWBE08nhO8uWl6kSAeCx4im7QfVko3zLrtgWZY4/bP87zrSPpSyN/3W3TDqz1jJuH+kbKOHXg5rJnK+ZVYcFFg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 - '@babel/runtime-corejs3@7.24.7': - resolution: {integrity: sha512-eytSX6JLBY6PVAeQa2bFlDx/7Mmln/gaEpsit5a3WEvjGfiIytEsgAwuIXCPM0xvw0v0cJn3ilq0/TvXrW0kgA==} - engines: {node: '>=6.9.0'} + '@csstools/postcss-color-function-display-p3-linear@1.0.1': + resolution: {integrity: sha512-E5qusdzhlmO1TztYzDIi8XPdPoYOjoTY6HBYBCYSj+Gn4gQRBlvjgPQXzfzuPQqt8EhkC/SzPKObg4Mbn8/xMg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 - '@babel/runtime@7.24.7': - resolution: {integrity: sha512-UwgBRMjJP+xv857DCngvqXI3Iq6J4v0wXmwc6sapg+zyhbwmQX67LUEFrkK5tbyJ30jGuG3ZvWpBiB9LCy1kWw==} - engines: {node: '>=6.9.0'} + '@csstools/postcss-color-function@4.0.12': + resolution: {integrity: sha512-yx3cljQKRaSBc2hfh8rMZFZzChaFgwmO2JfFgFr1vMcF3C/uyy5I4RFIBOIWGq1D+XbKCG789CGkG6zzkLpagA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 - '@babel/template@7.24.7': - resolution: {integrity: sha512-jYqfPrU9JTF0PmPy1tLYHW4Mp4KlgxJD9l2nP9fD6yT/ICi554DmrWBAEYpIelzjHf1msDP3PxJIRt/nFNfBig==} - engines: {node: '>=6.9.0'} + '@csstools/postcss-color-mix-function@3.0.12': + resolution: {integrity: sha512-4STERZfCP5Jcs13P1U5pTvI9SkgLgfMUMhdXW8IlJWkzOOOqhZIjcNhWtNJZes2nkBDsIKJ0CJtFtuaZ00moag==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 - '@babel/traverse@7.24.7': - resolution: {integrity: sha512-yb65Ed5S/QAcewNPh0nZczy9JdYXkkAbIsEo+P7BE7yO3txAY30Y/oPa3QkQ5It3xVG2kpKMg9MsdxZaO31uKA==} - engines: {node: '>=6.9.0'} + '@csstools/postcss-color-mix-variadic-function-arguments@1.0.2': + resolution: {integrity: sha512-rM67Gp9lRAkTo+X31DUqMEq+iK+EFqsidfecmhrteErxJZb6tUoJBVQca1Vn1GpDql1s1rD1pKcuYzMsg7Z1KQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 - '@babel/types@7.24.7': - resolution: {integrity: sha512-XEFXSlxiG5td2EJRe8vOmRbaXVgfcBlszKujvVmWIK/UpywWljQCfzAv3RQCGujWQ1RD4YYWEAqDXfuJiy8f5Q==} - engines: {node: '>=6.9.0'} + '@csstools/postcss-content-alt-text@2.0.8': + resolution: {integrity: sha512-9SfEW9QCxEpTlNMnpSqFaHyzsiRpZ5J5+KqCu1u5/eEJAWsMhzT40qf0FIbeeglEvrGRMdDzAxMIz3wqoGSb+Q==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 - '@colors/colors@1.5.0': - resolution: {integrity: sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==} - engines: {node: '>=0.1.90'} + '@csstools/postcss-contrast-color-function@2.0.12': + resolution: {integrity: sha512-YbwWckjK3qwKjeYz/CijgcS7WDUCtKTd8ShLztm3/i5dhh4NaqzsbYnhm4bjrpFpnLZ31jVcbK8YL77z3GBPzA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-exponential-functions@2.0.9': + resolution: {integrity: sha512-abg2W/PI3HXwS/CZshSa79kNWNZHdJPMBXeZNyPQFbbj8sKO3jXxOt/wF7juJVjyDTc6JrvaUZYFcSBZBhaxjw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-font-format-keywords@4.0.0': + resolution: {integrity: sha512-usBzw9aCRDvchpok6C+4TXC57btc4bJtmKQWOHQxOVKen1ZfVqBUuCZ/wuqdX5GHsD0NRSr9XTP+5ID1ZZQBXw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-gamut-mapping@2.0.11': + resolution: {integrity: sha512-fCpCUgZNE2piVJKC76zFsgVW1apF6dpYsqGyH8SIeCcM4pTEsRTWTLCaJIMKFEundsCKwY1rwfhtrio04RJ4Dw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-gradients-interpolation-method@5.0.12': + resolution: {integrity: sha512-jugzjwkUY0wtNrZlFeyXzimUL3hN4xMvoPnIXxoZqxDvjZRiSh+itgHcVUWzJ2VwD/VAMEgCLvtaJHX+4Vj3Ow==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-hwb-function@4.0.12': + resolution: {integrity: sha512-mL/+88Z53KrE4JdePYFJAQWFrcADEqsLprExCM04GDNgHIztwFzj0Mbhd/yxMBngq0NIlz58VVxjt5abNs1VhA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-ic-unit@4.0.4': + resolution: {integrity: sha512-yQ4VmossuOAql65sCPppVO1yfb7hDscf4GseF0VCA/DTDaBc0Wtf8MTqVPfjGYlT5+2buokG0Gp7y0atYZpwjg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-initial@2.0.1': + resolution: {integrity: sha512-L1wLVMSAZ4wovznquK0xmC7QSctzO4D0Is590bxpGqhqjboLXYA16dWZpfwImkdOgACdQ9PqXsuRroW6qPlEsg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-is-pseudo-class@5.0.3': + resolution: {integrity: sha512-jS/TY4SpG4gszAtIg7Qnf3AS2pjcUM5SzxpApOrlndMeGhIbaTzWBzzP/IApXoNWEW7OhcjkRT48jnAUIFXhAQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-light-dark-function@2.0.11': + resolution: {integrity: sha512-fNJcKXJdPM3Lyrbmgw2OBbaioU7yuKZtiXClf4sGdQttitijYlZMD5K7HrC/eF83VRWRrYq6OZ0Lx92leV2LFA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-logical-float-and-clear@3.0.0': + resolution: {integrity: sha512-SEmaHMszwakI2rqKRJgE+8rpotFfne1ZS6bZqBoQIicFyV+xT1UF42eORPxJkVJVrH9C0ctUgwMSn3BLOIZldQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-logical-overflow@2.0.0': + resolution: {integrity: sha512-spzR1MInxPuXKEX2csMamshR4LRaSZ3UXVaRGjeQxl70ySxOhMpP2252RAFsg8QyyBXBzuVOOdx1+bVO5bPIzA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-logical-overscroll-behavior@2.0.0': + resolution: {integrity: sha512-e/webMjoGOSYfqLunyzByZj5KKe5oyVg/YSbie99VEaSDE2kimFm0q1f6t/6Jo+VVCQ/jbe2Xy+uX+C4xzWs4w==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-logical-resize@3.0.0': + resolution: {integrity: sha512-DFbHQOFW/+I+MY4Ycd/QN6Dg4Hcbb50elIJCfnwkRTCX05G11SwViI5BbBlg9iHRl4ytB7pmY5ieAFk3ws7yyg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-logical-viewport-units@3.0.4': + resolution: {integrity: sha512-q+eHV1haXA4w9xBwZLKjVKAWn3W2CMqmpNpZUk5kRprvSiBEGMgrNH3/sJZ8UA3JgyHaOt3jwT9uFa4wLX4EqQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-media-minmax@2.0.9': + resolution: {integrity: sha512-af9Qw3uS3JhYLnCbqtZ9crTvvkR+0Se+bBqSr7ykAnl9yKhk6895z9rf+2F4dClIDJWxgn0iZZ1PSdkhrbs2ig==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-media-queries-aspect-ratio-number-values@3.0.5': + resolution: {integrity: sha512-zhAe31xaaXOY2Px8IYfoVTB3wglbJUVigGphFLj6exb7cjZRH9A6adyE22XfFK3P2PzwRk0VDeTJmaxpluyrDg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-nested-calc@4.0.0': + resolution: {integrity: sha512-jMYDdqrQQxE7k9+KjstC3NbsmC063n1FTPLCgCRS2/qHUbHM0mNy9pIn4QIiQGs9I/Bg98vMqw7mJXBxa0N88A==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-normalize-display-values@4.0.0': + resolution: {integrity: sha512-HlEoG0IDRoHXzXnkV4in47dzsxdsjdz6+j7MLjaACABX2NfvjFS6XVAnpaDyGesz9gK2SC7MbNwdCHusObKJ9Q==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-oklab-function@4.0.12': + resolution: {integrity: sha512-HhlSmnE1NKBhXsTnNGjxvhryKtO7tJd1w42DKOGFD6jSHtYOrsJTQDKPMwvOfrzUAk8t7GcpIfRyM7ssqHpFjg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-progressive-custom-properties@4.2.1': + resolution: {integrity: sha512-uPiiXf7IEKtUQXsxu6uWtOlRMXd2QWWy5fhxHDnPdXKCQckPP3E34ZgDoZ62r2iT+UOgWsSbM4NvHE5m3mAEdw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-random-function@2.0.1': + resolution: {integrity: sha512-q+FQaNiRBhnoSNo+GzqGOIBKoHQ43lYz0ICrV+UudfWnEF6ksS6DsBIJSISKQT2Bvu3g4k6r7t0zYrk5pDlo8w==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-relative-color-syntax@3.0.12': + resolution: {integrity: sha512-0RLIeONxu/mtxRtf3o41Lq2ghLimw0w9ByLWnnEVuy89exmEEq8bynveBxNW3nyHqLAFEeNtVEmC1QK9MZ8Huw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-scope-pseudo-class@4.0.1': + resolution: {integrity: sha512-IMi9FwtH6LMNuLea1bjVMQAsUhFxJnyLSgOp/cpv5hrzWmrUYU5fm0EguNDIIOHUqzXode8F/1qkC/tEo/qN8Q==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-sign-functions@1.1.4': + resolution: {integrity: sha512-P97h1XqRPcfcJndFdG95Gv/6ZzxUBBISem0IDqPZ7WMvc/wlO+yU0c5D/OCpZ5TJoTt63Ok3knGk64N+o6L2Pg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-stepped-value-functions@4.0.9': + resolution: {integrity: sha512-h9btycWrsex4dNLeQfyU3y3w40LMQooJWFMm/SK9lrKguHDcFl4VMkncKKoXi2z5rM9YGWbUQABI8BT2UydIcA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-text-decoration-shorthand@4.0.3': + resolution: {integrity: sha512-KSkGgZfx0kQjRIYnpsD7X2Om9BUXX/Kii77VBifQW9Ih929hK0KNjVngHDH0bFB9GmfWcR9vJYJJRvw/NQjkrA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-trigonometric-functions@4.0.9': + resolution: {integrity: sha512-Hnh5zJUdpNrJqK9v1/E3BbrQhaDTj5YiX7P61TOvUhoDHnUmsNNxcDAgkQ32RrcWx9GVUvfUNPcUkn8R3vIX6A==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/postcss-unset-value@4.0.0': + resolution: {integrity: sha512-cBz3tOCI5Fw6NIFEwU3RiwK6mn3nKegjpJuzCndoGq3BZPkUjnsq7uQmIeMNeMbMk7YD2MfKcgCpZwX5jyXqCA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + '@csstools/selector-resolve-nested@3.1.0': + resolution: {integrity: sha512-mf1LEW0tJLKfWyvn5KdDrhpxHyuxpbNwTIwOYLIvsTffeyOf85j5oIzfG0yosxDgx/sswlqBnESYUcQH0vgZ0g==} + engines: {node: '>=18'} + peerDependencies: + postcss-selector-parser: ^7.0.0 + + '@csstools/selector-specificity@5.0.0': + resolution: {integrity: sha512-PCqQV3c4CoVm3kdPhyeZ07VmBRdH2EpMFA/pd9OASpOEC3aXNGoqPDAZ80D0cLpMBxnmk0+yNhGsEx31hq7Gtw==} + engines: {node: '>=18'} + peerDependencies: + postcss-selector-parser: ^7.0.0 + + '@csstools/utilities@2.0.0': + resolution: {integrity: sha512-5VdOr0Z71u+Yp3ozOx8T11N703wIFGVRgOWbOZMKgglPJsWA54MRIoMNVMa7shUToIhx5J8vX4sOZgD2XiihiQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 '@discoveryjs/json-ext@0.5.7': resolution: {integrity: sha512-dBVuXR082gk3jsFp7Rd/JI4kytwGHecnCoTtXFb7DB6CNHp4rg5k1bhg0nWdLGLnOV71lmDzGQaLMy8iPLY0pw==} engines: {node: '>=10.0.0'} - '@docsearch/css@3.6.0': - resolution: {integrity: sha512-+sbxb71sWre+PwDK7X2T8+bhS6clcVMLwBPznX45Qu6opJcgRjAp7gYSDzVFp187J+feSj5dNBN1mJoi6ckkUQ==} + '@docsearch/css@4.1.0': + resolution: {integrity: sha512-nuNKGjHj/FQeWgE9t+i83QD/V67QiaAmGY7xS9TVCRUiCqSljOgIKlsLoQZKKVwEG8f+OWKdznzZkJxGZ7d06A==} - '@docsearch/react@3.6.0': - resolution: {integrity: sha512-HUFut4ztcVNmqy9gp/wxNbC7pTOHhgVVkHVGCACTuLhUKUhKAF9KYHJtMiLUJxEqiFLQiuri1fWF8zqwM/cu1w==} + '@docsearch/react@4.1.0': + resolution: {integrity: sha512-4GHI7TT3sJZ2Vs4Kjadv7vAkMrTsJqHvzvxO3JA7UT8iPRKaDottG5o5uNshPWhVVaBYPC35Ukf8bfCotGpjSg==} peerDependencies: - '@types/react': '>= 16.8.0 < 19.0.0' - react: '>= 16.8.0 < 19.0.0' - react-dom: '>= 16.8.0 < 19.0.0' + '@types/react': '>= 16.8.0 < 20.0.0' + react: '>= 16.8.0 < 20.0.0' + react-dom: '>= 16.8.0 < 20.0.0' search-insights: '>= 1 < 3' peerDependenciesMeta: '@types/react': @@ -804,178 +1028,195 @@ packages: search-insights: optional: true - '@docusaurus/core@3.4.0': - resolution: {integrity: sha512-g+0wwmN2UJsBqy2fQRQ6fhXruoEa62JDeEa5d8IdTJlMoaDaEDfHh7WjwGRn4opuTQWpjAwP/fbcgyHKlE+64w==} - engines: {node: '>=18.0'} + '@docusaurus/babel@3.9.1': + resolution: {integrity: sha512-/uoi3oG+wvbVWNBRfPrzrEslOSeLxrQEyWMywK51TLDFTANqIRivzkMusudh5bdDty8fXzCYUT+tg5t697jYqg==} + engines: {node: '>=20.0'} + + '@docusaurus/bundler@3.9.1': + resolution: {integrity: sha512-E1c9DgNmAz4NqbNtiJVp4UgjLtr8O01IgtXD/NDQ4PZaK8895cMiTOgb3k7mN0qX8A3lb8vqyrPJ842+yMpuUg==} + engines: {node: '>=20.0'} + peerDependencies: + '@docusaurus/faster': '*' + peerDependenciesMeta: + '@docusaurus/faster': + optional: true + + '@docusaurus/core@3.9.1': + resolution: {integrity: sha512-FWDk1LIGD5UR5Zmm9rCrXRoxZUgbwuP6FBA7rc50DVfzqDOMkeMe3NyJhOsA2dF0zBE3VbHEIMmTjKwTZJwbaA==} + engines: {node: '>=20.0'} hasBin: true peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + '@mdx-js/react': ^3.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/cssnano-preset@3.4.0': - resolution: {integrity: sha512-qwLFSz6v/pZHy/UP32IrprmH5ORce86BGtN0eBtG75PpzQJAzp9gefspox+s8IEOr0oZKuQ/nhzZ3xwyc3jYJQ==} - engines: {node: '>=18.0'} + '@docusaurus/cssnano-preset@3.9.1': + resolution: {integrity: sha512-2y7+s7RWQMqBg+9ejeKwvZs7Bdw/hHIVJIodwMXbs2kr+S48AhcmAfdOh6Cwm0unJb0hJUshN0ROwRoQMwl3xg==} + engines: {node: '>=20.0'} - '@docusaurus/logger@3.4.0': - resolution: {integrity: sha512-bZwkX+9SJ8lB9kVRkXw+xvHYSMGG4bpYHKGXeXFvyVc79NMeeBSGgzd4TQLHH+DYeOJoCdl8flrFJVxlZ0wo/Q==} - engines: {node: '>=18.0'} + '@docusaurus/logger@3.9.1': + resolution: {integrity: sha512-C9iFzXwHzwvGlisE4bZx+XQE0JIqlGAYAd5LzpR7fEDgjctu7yL8bE5U4nTNywXKHURDzMt4RJK8V6+stFHVkA==} + engines: {node: '>=20.0'} - '@docusaurus/mdx-loader@3.4.0': - resolution: {integrity: sha512-kSSbrrk4nTjf4d+wtBA9H+FGauf2gCax89kV8SUSJu3qaTdSIKdWERlngsiHaCFgZ7laTJ8a67UFf+xlFPtuTw==} - engines: {node: '>=18.0'} + '@docusaurus/mdx-loader@3.9.1': + resolution: {integrity: sha512-/1PY8lqry8jCt0qZddJSpc0U2sH6XC27kVJZfpA7o2TiQ3mdBQyH5AVbj/B2m682B1ounE+XjI0LdpOkAQLPoA==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/module-type-aliases@3.4.0': - resolution: {integrity: sha512-A1AyS8WF5Bkjnb8s+guTDuYmUiwJzNrtchebBHpc0gz0PyHJNMaybUlSrmJjHVcGrya0LKI4YcR3lBDQfXRYLw==} + '@docusaurus/module-type-aliases@3.9.1': + resolution: {integrity: sha512-YBce3GbJGGcMbJTyHcnEOMvdXqg41pa5HsrMCGA5Rm4z0h0tHS6YtEldj0mlfQRhCG7Y0VD66t2tb87Aom+11g==} peerDependencies: react: '*' react-dom: '*' - '@docusaurus/plugin-content-blog@3.4.0': - resolution: {integrity: sha512-vv6ZAj78ibR5Jh7XBUT4ndIjmlAxkijM3Sx5MAAzC1gyv0vupDQNhzuFg1USQmQVj3P5I6bquk12etPV3LJ+Xw==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-content-blog@3.9.1': + resolution: {integrity: sha512-vT6kIimpJLWvW9iuWzH4u7VpTdsGlmn4yfyhq0/Kb1h4kf9uVouGsTmrD7WgtYBUG1P+TSmQzUUQa+ALBSRTig==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + '@docusaurus/plugin-content-docs': '*' + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-content-docs@3.4.0': - resolution: {integrity: sha512-HkUCZffhBo7ocYheD9oZvMcDloRnGhBMOZRyVcAQRFmZPmNqSyISlXA1tQCIxW+r478fty97XXAGjNYzBjpCsg==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-content-docs@3.9.1': + resolution: {integrity: sha512-DyLk9BIA6I9gPIuia8XIL+XIEbNnExam6AHzRsfrEq4zJr7k/DsWW7oi4aJMepDnL7jMRhpVcdsCxdjb0/A9xg==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-content-pages@3.4.0': - resolution: {integrity: sha512-h2+VN/0JjpR8fIkDEAoadNjfR3oLzB+v1qSXbIAKjQ46JAHx3X22n9nqS+BWSQnTnp1AjkjSvZyJMekmcwxzxg==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-content-pages@3.9.1': + resolution: {integrity: sha512-/1wFzRnXYASI+Nv9ck9IVPIMw0O5BGQ8ZVhDzEwhkL+tl44ycvSnY6PIe6rW2HLxsw61Z3WFwAiU8+xMMtMZpg==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-debug@3.4.0': - resolution: {integrity: sha512-uV7FDUNXGyDSD3PwUaf5YijX91T5/H9SX4ErEcshzwgzWwBtK37nUWPU3ZLJfeTavX3fycTOqk9TglpOLaWkCg==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-css-cascade-layers@3.9.1': + resolution: {integrity: sha512-/QyW2gRCk/XE3ttCK/ERIgle8KJ024dBNKMu6U5SmpJvuT2il1n5jR/48Pp/9wEwut8WVml4imNm6X8JsL5A0Q==} + engines: {node: '>=20.0'} + + '@docusaurus/plugin-debug@3.9.1': + resolution: {integrity: sha512-qPeAuk0LccC251d7jg2MRhNI+o7niyqa924oEM/AxnZJvIpMa596aAxkRImiAqNN6+gtLE1Hkrz/RHUH2HDGsA==} + engines: {node: '>=20.0'} + peerDependencies: + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 + + '@docusaurus/plugin-google-analytics@3.9.1': + resolution: {integrity: sha512-k4Qq2HphqOrIU/CevGPdEO1yJnWUI8m0zOJsYt5NfMJwNsIn/gDD6gv/DKD+hxHndQT5pacsfBd4BWHZVNVroQ==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-google-analytics@3.4.0': - resolution: {integrity: sha512-mCArluxEGi3cmYHqsgpGGt3IyLCrFBxPsxNZ56Mpur0xSlInnIHoeLDH7FvVVcPJRPSQ9/MfRqLsainRw+BojA==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-google-gtag@3.9.1': + resolution: {integrity: sha512-n9BURBiQyJKI/Ecz35IUjXYwXcgNCSq7/eA07+ZYcDiSyH2p/EjPf8q/QcZG3CyEJPZ/SzGkDHePfcVPahY4Gg==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-google-gtag@3.4.0': - resolution: {integrity: sha512-Dsgg6PLAqzZw5wZ4QjUYc8Z2KqJqXxHxq3vIoyoBWiLEEfigIs7wHR+oiWUQy3Zk9MIk6JTYj7tMoQU0Jm3nqA==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-google-tag-manager@3.9.1': + resolution: {integrity: sha512-rZAQZ25ZuXaThBajxzLjXieTDUCMmBzfAA6ThElQ3o7Q+LEpOjCIrwGFau0KLY9HeG6x91+FwwsAM8zeApYDrg==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-google-tag-manager@3.4.0': - resolution: {integrity: sha512-O9tX1BTwxIhgXpOLpFDueYA9DWk69WCbDRrjYoMQtFHSkTyE7RhNgyjSPREUWJb9i+YUg3OrsvrBYRl64FCPCQ==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-sitemap@3.9.1': + resolution: {integrity: sha512-k/bf5cXDxAJUYTzqatgFJwmZsLUbIgl6S8AdZMKGG2Mv2wcOHt+EQNN9qPyWZ5/9cFj+Q8f8DN+KQheBMYLong==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/plugin-sitemap@3.4.0': - resolution: {integrity: sha512-+0VDvx9SmNrFNgwPoeoCha+tRoAjopwT0+pYO1xAbyLcewXSemq+eLxEa46Q1/aoOaJQ0qqHELuQM7iS2gp33Q==} - engines: {node: '>=18.0'} + '@docusaurus/plugin-svgr@3.9.1': + resolution: {integrity: sha512-TeZOXT2PSdTNR1OpDJMkYqFyX7MMhbd4t16hQByXksgZQCXNyw3Dio+KaDJ2Nj+LA4WkOvsk45bWgYG5MAaXSQ==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/preset-classic@3.4.0': - resolution: {integrity: sha512-Ohj6KB7siKqZaQhNJVMBBUzT3Nnp6eTKqO+FXO3qu/n1hJl3YLwVKTWBg28LF7MWrKu46UuYavwMRxud0VyqHg==} - engines: {node: '>=18.0'} + '@docusaurus/preset-classic@3.9.1': + resolution: {integrity: sha512-ZHga2xsxxsyd0dN1BpLj8S889Eu9eMBuj2suqxdw/vaaXu/FjJ8KEGbcaeo6nHPo8VQcBBnPEdkBtSDm2TfMNw==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 '@docusaurus/react-loadable@6.0.0': resolution: {integrity: sha512-YMMxTUQV/QFSnbgrP3tjDzLHRg7vsbMn8e9HAa8o/1iXoiomo48b7sk/kkmWEuWNDPJVlKSJRB6Y2fHqdJk+SQ==} peerDependencies: react: '*' - '@docusaurus/theme-classic@3.4.0': - resolution: {integrity: sha512-0IPtmxsBYv2adr1GnZRdMkEQt1YW6tpzrUPj02YxNpvJ5+ju4E13J5tB4nfdaen/tfR1hmpSPlTFPvTf4kwy8Q==} - engines: {node: '>=18.0'} + '@docusaurus/theme-classic@3.9.1': + resolution: {integrity: sha512-LrAIu/mQ04nG6s1cssC0TMmICD8twFIIn/hJ5Pd9uIPQvtKnyAKEn12RefopAul5KfMo9kixPaqogV5jIJr26w==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/theme-common@3.4.0': - resolution: {integrity: sha512-0A27alXuv7ZdCg28oPE8nH/Iz73/IUejVaCazqu9elS4ypjiLhK3KfzdSQBnL/g7YfHSlymZKdiOHEo8fJ0qMA==} - engines: {node: '>=18.0'} + '@docusaurus/theme-common@3.9.1': + resolution: {integrity: sha512-j9adi961F+6Ps9d0jcb5BokMcbjXAAJqKkV43eo8nh4YgmDj7KUNDX4EnOh/MjTQeO06oPY5cxp3yUXdW/8Ggw==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + '@docusaurus/plugin-content-docs': '*' + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/theme-search-algolia@3.4.0': - resolution: {integrity: sha512-aiHFx7OCw4Wck1z6IoShVdUWIjntC8FHCw9c5dR8r3q4Ynh+zkS8y2eFFunN/DL6RXPzpnvKCg3vhLQYJDmT9Q==} - engines: {node: '>=18.0'} + '@docusaurus/theme-search-algolia@3.9.1': + resolution: {integrity: sha512-WjM28bzlgfT6nHlEJemkwyGVpvGsZWPireV/w+wZ1Uo64xCZ8lNOb4xwQRukDaLSed3oPBN0gSnu06l5VuCXHg==} + engines: {node: '>=20.0'} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/theme-translations@3.4.0': - resolution: {integrity: sha512-zSxCSpmQCCdQU5Q4CnX/ID8CSUUI3fvmq4hU/GNP/XoAWtXo9SAVnM3TzpU8Gb//H3WCsT8mJcTfyOk3d9ftNg==} - engines: {node: '>=18.0'} + '@docusaurus/theme-translations@3.9.1': + resolution: {integrity: sha512-mUQd49BSGKTiM6vP9+JFgRJL28lMIN3PUvXjF3rzuOHMByUZUBNwCt26Z23GkKiSIOrRkjKoaBNTipR/MHdYSQ==} + engines: {node: '>=20.0'} - '@docusaurus/tsconfig@3.4.0': - resolution: {integrity: sha512-0qENiJ+TRaeTzcg4olrnh0BQ7eCxTgbYWBnWUeQDc84UYkt/T3pDNnm3SiQkqPb+YQ1qtYFlC0RriAElclo8Dg==} + '@docusaurus/tsconfig@3.9.1': + resolution: {integrity: sha512-stdzM1dNDgRO0OvxeznXlE3N1igUoeHPNJjiKqyffLizgpVgNXJBAWeG6fuoYiCH4udGUBqy2dyM+1+kG2/UPQ==} - '@docusaurus/types@3.4.0': - resolution: {integrity: sha512-4jcDO8kXi5Cf9TcyikB/yKmz14f2RZ2qTRerbHAsS+5InE9ZgSLBNLsewtFTcTOXSVcbU3FoGOzcNWAmU1TR0A==} + '@docusaurus/types@3.9.1': + resolution: {integrity: sha512-ElekJ29sk39s5LTEZMByY1c2oH9FMtw7KbWFU3BtuQ1TytfIK39HhUivDEJvm5KCLyEnnfUZlvSNDXeyk0vzAA==} peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 + react: ^18.0.0 || ^19.0.0 + react-dom: ^18.0.0 || ^19.0.0 - '@docusaurus/utils-common@3.4.0': - resolution: {integrity: sha512-NVx54Wr4rCEKsjOH5QEVvxIqVvm+9kh7q8aYTU5WzUU9/Hctd6aTrcZ3G0Id4zYJ+AeaG5K5qHA4CY5Kcm2iyQ==} - engines: {node: '>=18.0'} - peerDependencies: - '@docusaurus/types': '*' - peerDependenciesMeta: - '@docusaurus/types': - optional: true + '@docusaurus/utils-common@3.9.1': + resolution: {integrity: sha512-4M1u5Q8Zn2CYL2TJ864M51FV4YlxyGyfC3x+7CLuR6xsyTVNBNU4QMcPgsTHRS9J2+X6Lq7MyH6hiWXyi/sXUQ==} + engines: {node: '>=20.0'} - '@docusaurus/utils-validation@3.4.0': - resolution: {integrity: sha512-hYQ9fM+AXYVTWxJOT1EuNaRnrR2WGpRdLDQG07O8UOpsvCPWUVOeo26Rbm0JWY2sGLfzAb+tvJ62yF+8F+TV0g==} - engines: {node: '>=18.0'} + '@docusaurus/utils-validation@3.9.1': + resolution: {integrity: sha512-5bzab5si3E1udrlZuVGR17857Lfwe8iFPoy5AvMP9PXqDfoyIKT7gDQgAmxdRDMurgHaJlyhXEHHdzDKkOxxZQ==} + engines: {node: '>=20.0'} - '@docusaurus/utils@3.4.0': - resolution: {integrity: sha512-fRwnu3L3nnWaXOgs88BVBmG1yGjcQqZNHG+vInhEa2Sz2oQB+ZjbEMO5Rh9ePFpZ0YDiDUhpaVjwmS+AU2F14g==} - engines: {node: '>=18.0'} - peerDependencies: - '@docusaurus/types': '*' - peerDependenciesMeta: - '@docusaurus/types': - optional: true + '@docusaurus/utils@3.9.1': + resolution: {integrity: sha512-YAL4yhhWLl9DXuf5MVig260a6INz4MehrBGFU/CZu8yXmRiYEuQvRFWh9ZsjfAOyaG7za1MNmBVZ4VVAi/CiJA==} + engines: {node: '>=20.0'} '@easyops-cn/autocomplete.js@0.38.1': resolution: {integrity: sha512-drg76jS6syilOUmVNkyo1c7ZEBPcPuK+aJA7AksM5ZIIbV57DMHCywiCr+uHyv8BE5jUTU98j/H7gVrkHrWW3Q==} - '@easyops-cn/docusaurus-search-local@0.44.2': - resolution: {integrity: sha512-4tMBU54R1O6ITxkMGwOEifSHNkZLa2fb4ajGc8rd6TYZ0a8+jlu/u/5gYtw1s6sGGMRkwyG+QI6HD0bEnCRa1w==} + '@easyops-cn/docusaurus-search-local@0.52.1': + resolution: {integrity: sha512-pwfANjTLOQyAPc2Iz93WbG4OQM5C4COCWARbLAs79FIpIS38gHq3PrbDIX8f7oDhGQp1u6f8fr3K3u3+yZXZTA==} engines: {node: '>=12'} peerDependencies: '@docusaurus/theme-common': ^2 || ^3 - react: ^16.14.0 || ^17 || ^18 - react-dom: ^16.14.0 || 17 || ^18 + react: ^16.14.0 || ^17 || ^18 || ^19 + react-dom: ^16.14.0 || 17 || ^18 || ^19 - '@emnapi/core@1.2.0': - resolution: {integrity: sha512-E7Vgw78I93we4ZWdYCb4DGAwRROGkMIXk7/y87UmANR+J6qsWusmC3gLt0H+O0KOt5e6O38U8oJamgbudrES/w==} + '@emnapi/core@1.5.0': + resolution: {integrity: sha512-sbP8GzB1WDzacS8fgNPpHlp6C9VZe+SJP3F90W9rLemaQj2PzIuTEl1qDOYQf58YIpyjViI24y9aPWCjEzY2cg==} - '@emnapi/runtime@1.2.0': - resolution: {integrity: sha512-bV21/9LQmcQeCPEg3BDFtvwL6cwiTMksYNWQQ4KOxCZikEGalWtenoZ0wCiukJINlGCIi2KXx01g4FoH/LxpzQ==} + '@emnapi/runtime@1.5.0': + resolution: {integrity: sha512-97/BJ3iXHww3djw6hYIfErCZFee7qCtrneuLa20UXFCOTCfBM2cvQHjWJ2EG0s0MtdNwInarqCTz35i4wWXHsQ==} - '@emnapi/wasi-threads@1.0.1': - resolution: {integrity: sha512-iIBu7mwkq4UQGeMEM8bLwNK962nXdhodeScX4slfQnRhEMMzvYivHhutCIk8uojvmASXXPC2WNEjwxFWk72Oqw==} + '@emnapi/wasi-threads@1.1.0': + resolution: {integrity: sha512-WI0DdZ8xFSbgMjR1sFsKABJ/C5OnRrjT06JXbZKexJGrDuPTzZdDYfFlsgcCXCyf+suG5QU2e/y1Wo2V/OapLQ==} '@hapi/hoek@9.3.0': resolution: {integrity: sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==} @@ -995,127 +1236,161 @@ packages: resolution: {integrity: sha512-u3UPsIilWKOM3F9CXtrG8LEJmNxwoCQC/XVj4IKYXvvpx7QIi/Kg1LI5uDmDpKlac62NUtX7eLjRh+jVZcLOzw==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} - '@jridgewell/gen-mapping@0.3.5': - resolution: {integrity: sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==} - engines: {node: '>=6.0.0'} + '@jridgewell/gen-mapping@0.3.13': + resolution: {integrity: sha512-2kkt/7niJ6MgEPxF0bYdQ6etZaA+fQvDcLKckhy1yIQOzaoKjBBjSj63/aLVjYE3qhRt5dvM+uUyfCg6UKCBbA==} + + '@jridgewell/remapping@2.3.5': + resolution: {integrity: sha512-LI9u/+laYG4Ds1TDKSJW2YPrIlcVYOwi2fUC6xB43lueCjgxV4lffOCZCtYFiH6TNOX+tQKXx97T4IKHbhyHEQ==} '@jridgewell/resolve-uri@3.1.2': resolution: {integrity: sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==} engines: {node: '>=6.0.0'} - '@jridgewell/set-array@1.2.1': - resolution: {integrity: sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==} - engines: {node: '>=6.0.0'} + '@jridgewell/source-map@0.3.11': + resolution: {integrity: sha512-ZMp1V8ZFcPG5dIWnQLr3NSI1MiCU7UETdS/A0G8V/XWHvJv3ZsFqutJn1Y5RPmAPX6F3BiE397OqveU/9NCuIA==} + + '@jridgewell/sourcemap-codec@1.5.5': + resolution: {integrity: sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==} + + '@jridgewell/trace-mapping@0.3.31': + resolution: {integrity: sha512-zzNR+SdQSDJzc8joaeP8QQoCQr8NuYx2dIIytl1QeBEZHJ9uW6hebsrYgbz8hJwUQao3TWCMtmfV8Nu1twOLAw==} + + '@jsonjoy.com/base64@1.1.2': + resolution: {integrity: sha512-q6XAnWQDIMA3+FTiOYajoYqySkO+JSat0ytXGSuRdq9uXE7o92gzuQwQM14xaCRlBLGq3v5miDGC4vkVTn54xA==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' + + '@jsonjoy.com/buffers@1.0.0': + resolution: {integrity: sha512-NDigYR3PHqCnQLXYyoLbnEdzMMvzeiCWo1KOut7Q0CoIqg9tUAPKJ1iq/2nFhc5kZtexzutNY0LFjdwWL3Dw3Q==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' - '@jridgewell/source-map@0.3.6': - resolution: {integrity: sha512-1ZJTZebgqllO79ue2bm3rIGud/bOe0pP5BjSRCRxxYkEZS8STV7zN84UBbiYu7jy+eCKSnVIUgoWWE/tt+shMQ==} + '@jsonjoy.com/codegen@1.0.0': + resolution: {integrity: sha512-E8Oy+08cmCf0EK/NMxpaJZmOxPqM+6iSe2S4nlSBrPZOORoDJILxtbSUEDKQyTamm/BVAhIGllOBNU79/dwf0g==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' + + '@jsonjoy.com/json-pack@1.14.0': + resolution: {integrity: sha512-LpWbYgVnKzphN5S6uss4M25jJ/9+m6q6UJoeN6zTkK4xAGhKsiBRPVeF7OYMWonn5repMQbE5vieRXcMUrKDKw==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' - '@jridgewell/sourcemap-codec@1.4.15': - resolution: {integrity: sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==} + '@jsonjoy.com/json-pointer@1.0.2': + resolution: {integrity: sha512-Fsn6wM2zlDzY1U+v4Nc8bo3bVqgfNTGcn6dMgs6FjrEnt4ZCe60o6ByKRjOGlI2gow0aE/Q41QOigdTqkyK5fg==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' - '@jridgewell/trace-mapping@0.3.25': - resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==} + '@jsonjoy.com/util@1.9.0': + resolution: {integrity: sha512-pLuQo+VPRnN8hfPqUTLTHk126wuYdXVxE6aDmjSeV4NCAgyxWbiOIeNJVtID3h1Vzpoi9m4jXezf73I6LgabgQ==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' '@leichtgewicht/ip-codec@2.0.5': resolution: {integrity: sha512-Vo+PSpZG2/fmgmiNzYK9qWRh8h/CHrwD0mo1h1DzL4yzHNSfWYujGTYsWGreD000gcgmZ7K4Ys6Tx9TxtsKdDw==} - '@mdx-js/mdx@3.0.1': - resolution: {integrity: sha512-eIQ4QTrOWyL3LWEe/bu6Taqzq2HQvHcyTMaOrI95P2/LmJE7AsfPfgJGuFLPVqBUE1BC1rik3VIhU+s9u72arA==} + '@mdx-js/mdx@3.1.1': + resolution: {integrity: sha512-f6ZO2ifpwAQIpzGWaBQT2TXxPv6z3RBzQKpVftEWN78Vl/YweF1uwussDx8ECAXVtr3Rs89fKyG9YlzUs9DyGQ==} - '@mdx-js/react@3.0.1': - resolution: {integrity: sha512-9ZrPIU4MGf6et1m1ov3zKf+q9+deetI51zprKB1D/z3NOb+rUxxtEl3mCjW5wTGh6VhRdwPueh1oRzi6ezkA8A==} + '@mdx-js/react@3.1.1': + resolution: {integrity: sha512-f++rKLQgUVYDAtECQ6fn/is15GkEH9+nZPM3MS0RcxVqoTfawHvDlSCH7JbMhAM6uJ32v3eXLvLmLvjGu7PTQw==} peerDependencies: '@types/react': '>=16' react: '>=16' - '@napi-rs/wasm-runtime@0.2.4': - resolution: {integrity: sha512-9zESzOO5aDByvhIAsOy9TbpZ0Ur2AJbUI7UT73kcUTS2mxAMHOBaa1st/jAymNoCtvrit99kkzT1FZuXVcgfIQ==} + '@napi-rs/wasm-runtime@0.2.12': + resolution: {integrity: sha512-ZVWUcfwY4E/yPitQJl481FjFo3K22D6qF0DuFH6Y/nbnE11GY5uguDxZMGXPQ8WQ0128MXQD7TnfHyK4oWoIJQ==} - '@node-rs/jieba-android-arm-eabi@1.10.3': - resolution: {integrity: sha512-fuqVtaYlUKZg3cqagYFxj1DSa7ZHKXLle4iGH2kbQWg7Kw6cf7aCYBHIUZuH5sliK10M/CWccZ+SGRUwcSGfbg==} + '@node-rs/jieba-android-arm-eabi@1.10.4': + resolution: {integrity: sha512-MhyvW5N3Fwcp385d0rxbCWH42kqDBatQTyP8XbnYbju2+0BO/eTeCCLYj7Agws4pwxn2LtdldXRSKavT7WdzNA==} engines: {node: '>= 10'} cpu: [arm] os: [android] - '@node-rs/jieba-android-arm64@1.10.3': - resolution: {integrity: sha512-iuZZZq5yD9lT+AgaXpFe19gtAsIecUODRLLaBFbavjgjLk5cumv38ytWjS36s/eqptwI15MQfysSYOlWtMEG5g==} + '@node-rs/jieba-android-arm64@1.10.4': + resolution: {integrity: sha512-XyDwq5+rQ+Tk55A+FGi6PtJbzf974oqnpyCcCPzwU3QVXJCa2Rr4Lci+fx8oOpU4plT3GuD+chXMYLsXipMgJA==} engines: {node: '>= 10'} cpu: [arm64] os: [android] - '@node-rs/jieba-darwin-arm64@1.10.3': - resolution: {integrity: sha512-dwPhkav1tEARskwPz91UUXL2NXy4h0lJYTuJzpGgwXxm552zBM2JJ41kjah1364j+EOq5At3NQvf5r5rH89phQ==} + '@node-rs/jieba-darwin-arm64@1.10.4': + resolution: {integrity: sha512-G++RYEJ2jo0rxF9626KUy90wp06TRUjAsvY/BrIzEOX/ingQYV/HjwQzNPRR1P1o32a6/U8RGo7zEBhfdybL6w==} engines: {node: '>= 10'} cpu: [arm64] os: [darwin] - '@node-rs/jieba-darwin-x64@1.10.3': - resolution: {integrity: sha512-kjxvV6G1baQo/2I3mELv5qGv4Q0rhd5srwXhypSxMWZFtSpNwCDsLcIOR5bvMBci6QVFfZOs6WD6DKiWVz0SlA==} + '@node-rs/jieba-darwin-x64@1.10.4': + resolution: {integrity: sha512-MmDNeOb2TXIZCPyWCi2upQnZpPjAxw5ZGEj6R8kNsPXVFALHIKMa6ZZ15LCOkSTsKXVC17j2t4h+hSuyYb6qfQ==} engines: {node: '>= 10'} cpu: [x64] os: [darwin] - '@node-rs/jieba-freebsd-x64@1.10.3': - resolution: {integrity: sha512-QYTsn+zlWRil+MuBeLfTK5Md4GluOf2lHnFqjrOZW2oMgNOvxB3qoLV4TUf70S/E2XHeP6PUdjCKItX8C7GQPg==} + '@node-rs/jieba-freebsd-x64@1.10.4': + resolution: {integrity: sha512-/x7aVQ8nqUWhpXU92RZqd333cq639i/olNpd9Z5hdlyyV5/B65LLy+Je2B2bfs62PVVm5QXRpeBcZqaHelp/bg==} engines: {node: '>= 10'} cpu: [x64] os: [freebsd] - '@node-rs/jieba-linux-arm-gnueabihf@1.10.3': - resolution: {integrity: sha512-UFB43kDOvqmbRl99e3GPwaTuwJZaAvgLaMTvBkmxww4MpQH6G1k31RLzMW/S21uSQso2lj6W/Mm59gaJk2FiyA==} + '@node-rs/jieba-linux-arm-gnueabihf@1.10.4': + resolution: {integrity: sha512-crd2M35oJBRLkoESs0O6QO3BBbhpv+tqXuKsqhIG94B1d02RVxtRIvSDwO33QurxqSdvN9IeSnVpHbDGkuXm3g==} engines: {node: '>= 10'} cpu: [arm] os: [linux] - '@node-rs/jieba-linux-arm64-gnu@1.10.3': - resolution: {integrity: sha512-bu++yWi10wZtnS5uLcwxzxKmHVT77NgQMK8JiQr1TWCl3Y1Th7CnEHQtxfVB489edDK8l644h1/4zSTe5fRnOQ==} + '@node-rs/jieba-linux-arm64-gnu@1.10.4': + resolution: {integrity: sha512-omIzNX1psUzPcsdnUhGU6oHeOaTCuCjUgOA/v/DGkvWC1jLcnfXe4vdYbtXMh4XOCuIgS1UCcvZEc8vQLXFbXQ==} engines: {node: '>= 10'} cpu: [arm64] os: [linux] - '@node-rs/jieba-linux-arm64-musl@1.10.3': - resolution: {integrity: sha512-pJh+SzrK1HaKakhdFM+ew9vXwpZqMxy9u0U7J4GT+3GvOwnAZ+KjeaHebIfgOz7ZHvp/T4YBNf8oWW4zwj3AJw==} + '@node-rs/jieba-linux-arm64-musl@1.10.4': + resolution: {integrity: sha512-Y/tiJ1+HeS5nnmLbZOE+66LbsPOHZ/PUckAYVeLlQfpygLEpLYdlh0aPpS5uiaWMjAXYZYdFkpZHhxDmSLpwpw==} engines: {node: '>= 10'} cpu: [arm64] os: [linux] - '@node-rs/jieba-linux-x64-gnu@1.10.3': - resolution: {integrity: sha512-GF5cfvu/0wXO2fVX/XV3WYH/xEGWzMBvfqLhGiA1OA1xHIufnA1T7uU3ZXkyoNi5Bzf6dmxnwtE4CJL0nvhwjQ==} + '@node-rs/jieba-linux-x64-gnu@1.10.4': + resolution: {integrity: sha512-WZO8ykRJpWGE9MHuZpy1lu3nJluPoeB+fIJJn5CWZ9YTVhNDWoCF4i/7nxz1ntulINYGQ8VVuCU9LD86Mek97g==} engines: {node: '>= 10'} cpu: [x64] os: [linux] - '@node-rs/jieba-linux-x64-musl@1.10.3': - resolution: {integrity: sha512-h45HMVU/hgzQ0saXNsK9fKlGdah1i1cXZULpB5vQRlRL2ZIaGp+ULtWTogS7vkoo2K8s2l4tqakWMg9eUjIJ2A==} + '@node-rs/jieba-linux-x64-musl@1.10.4': + resolution: {integrity: sha512-uBBD4S1rGKcgCyAk6VCKatEVQb6EDD5I40v/DxODi5CuZVCANi9m5oee/MQbAoaX7RydA2f0OSCE9/tcwXEwUg==} engines: {node: '>= 10'} cpu: [x64] os: [linux] - '@node-rs/jieba-wasm32-wasi@1.10.3': - resolution: {integrity: sha512-vuoQ62vVoedNGcBmIi4UWdtNBOZG8B+vDYfjx3FD6rNg6g/RgwbVjYXbOVMOQwX06Ob9CfrutICXdUGHgoxzEQ==} + '@node-rs/jieba-wasm32-wasi@1.10.4': + resolution: {integrity: sha512-Y2umiKHjuIJy0uulNDz9SDYHdfq5Hmy7jY5nORO99B4pySKkcrMjpeVrmWXJLIsEKLJwcCXHxz8tjwU5/uhz0A==} engines: {node: '>=14.0.0'} cpu: [wasm32] - '@node-rs/jieba-win32-arm64-msvc@1.10.3': - resolution: {integrity: sha512-B8t4dh56TZnMLBoYWDkopf1ed37Ru/iU1qiIeBkbZWXGmNBChNZUOd//eaPOFjx8m9Sfc8bkj3FBRWt/kTAhmw==} + '@node-rs/jieba-win32-arm64-msvc@1.10.4': + resolution: {integrity: sha512-nwMtViFm4hjqhz1it/juQnxpXgqlGltCuWJ02bw70YUDMDlbyTy3grCJPpQQpueeETcALUnTxda8pZuVrLRcBA==} engines: {node: '>= 10'} cpu: [arm64] os: [win32] - '@node-rs/jieba-win32-ia32-msvc@1.10.3': - resolution: {integrity: sha512-SKuPGZJ5T+X4jOn1S8LklOSZ6HC7UBiw0hwi2z9uqX6WgElquLjGi/xfZ2gPqffeR/5K/PUu7aqYUUPL1XonVQ==} + '@node-rs/jieba-win32-ia32-msvc@1.10.4': + resolution: {integrity: sha512-DCAvLx7Z+W4z5oKS+7vUowAJr0uw9JBw8x1Y23Xs/xMA4Em+OOSiaF5/tCJqZUCJ8uC4QeImmgDFiBqGNwxlyA==} engines: {node: '>= 10'} cpu: [ia32] os: [win32] - '@node-rs/jieba-win32-x64-msvc@1.10.3': - resolution: {integrity: sha512-j9I4+a/tf2hsLu8Sr0NhcLBVNBBQctO2mzcjemMpRa1SlEeODyic9RIyP8Ljz3YTN6MYqKh1KA9iR1xvxjxYFg==} + '@node-rs/jieba-win32-x64-msvc@1.10.4': + resolution: {integrity: sha512-+sqemSfS1jjb+Tt7InNbNzrRh1Ua3vProVvC4BZRPg010/leCbGFFiQHpzcPRfpxAXZrzG5Y0YBTsPzN/I4yHQ==} engines: {node: '>= 10'} cpu: [x64] os: [win32] - '@node-rs/jieba@1.10.3': - resolution: {integrity: sha512-SG0CWHmhIveH6upJURgymDKLertEPYbOc5NSFIpbZWW1W2MpqgumVteQO+5YBlkmpR6jMNDPWNQyQwkB6HoeNg==} + '@node-rs/jieba@1.10.4': + resolution: {integrity: sha512-GvDgi8MnBiyWd6tksojej8anIx18244NmIOc1ovEw8WKNUejcccLfyu8vj66LWSuoZuKILVtNsOy4jvg3aoxIw==} engines: {node: '>= 10'} '@nodelib/fs.scandir@2.1.5': @@ -1130,6 +1405,10 @@ packages: resolution: {integrity: sha512-oGB+UxlgWcgQkgwo8GcEGwemoTFt3FIO9ababBmaGwXIoBKZ+GTy0pP185beGg7Llih/NSHSV2XAs1lnznocSg==} engines: {node: '>= 8'} + '@opentelemetry/api@1.9.0': + resolution: {integrity: sha512-3giAOQvZiH5F9bMlMiv8+GSPMeqg0dbaeo58/0SlA9sxSqZhnUtxzX9/2FzyhS9sWQf5S0GJE0AKBrFqjpeYcg==} + engines: {node: '>=8.0.0'} + '@pkgjs/parseargs@0.11.0': resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==} engines: {node: '>=14'} @@ -1142,12 +1421,12 @@ packages: resolution: {integrity: sha512-YcPQ8a0jwYU9bTdJDpXjMi7Brhkr1mXsXrUJvjqM2mQDgkRiz8jFaQGOdaLxgjtUfQgZhKy/O3cG/YwmgKaxLA==} engines: {node: '>=12.22.0'} - '@pnpm/npm-conf@2.2.2': - resolution: {integrity: sha512-UA91GwWPhFExt3IizW6bOeY/pQ0BkuNwKjk9iQW9KqxluGCrg4VenZ0/L+2Y0+ZOtme72EVvg6v0zo3AMQRCeA==} + '@pnpm/npm-conf@2.3.1': + resolution: {integrity: sha512-c83qWb22rNRuB0UaVCI0uRPNRr8Z0FWnEIvT47jiHAmOIUHbBOg5XvV7pM5x+rKn9HRpjxquDbXYSXr3fAKFcw==} engines: {node: '>=12'} - '@polka/url@1.0.0-next.25': - resolution: {integrity: sha512-j7P6Rgr3mmtdkeDGTe0E/aYyWEWVtc5yFXtHCRHs28/jptDEWfaVOc5T7cblqy1XKPPfCxJc/8DwQ5YgLOZOVQ==} + '@polka/url@1.0.0-next.29': + resolution: {integrity: sha512-wwQAWhWSuHaag8c4q/KN/vCoeOJYshAIvMQwD4GpSb3OiZklFfvAgmj0VCBBImRpuF/aFgIRzllXlVX93Jevww==} '@sideway/address@4.1.5': resolution: {integrity: sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==} @@ -1169,9 +1448,18 @@ packages: resolution: {integrity: sha512-TV7t8GKYaJWsn00tFDqBw8+Uqmr8A0fRU1tvTQhyZzGv0sJCGRQL3JGMI3ucuKo3XIZdUP+Lx7/gh2t3lewy7g==} engines: {node: '>=14.16'} + '@slorber/react-helmet-async@1.3.0': + resolution: {integrity: sha512-e9/OK8VhwUSc67diWI8Rb3I0YgI9/SBQtnhe9aEuK6MhZm7ntZZimXgwXnd8W96YTmSOb9M4d8LwhRZyhWr/1A==} + peerDependencies: + react: ^16.6.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 + react-dom: ^16.6.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 + '@slorber/remark-comment@1.0.0': resolution: {integrity: sha512-RCE24n7jsOj1M0UPvIQCHTe7fI0sFL4S2nwKVWwHyVr/wI/H8GosgsJGyhnsZoGFnD/P2hLf1mSbrrgSLN93NA==} + '@standard-schema/spec@1.0.0': + resolution: {integrity: sha512-m2bOd0f2RT9k8QJx1JN85cZYyH1RqFBdlwtkSlf4tBDYLCiiZnv1fIIwacK6cqwXavOydf0NPToMQgpKq+dVlA==} + '@svgr/babel-plugin-add-jsx-attribute@8.0.0': resolution: {integrity: sha512-b9MIk7yhdS1pMCZM8VeNfUlSKVRhsHZNMl5O9SfaX0l0t5wjdgu4IDzGB8bpnGBBOjGST3rRFVsaaEtI4W6f7g==} engines: {node: '>=14'} @@ -1258,14 +1546,11 @@ packages: resolution: {integrity: sha512-L7z9BgrNEcYyUYtF+HaEfiS5ebkh9jXqbszz7pC0hRBPaatV0XjSD3+eHrpqFemQfgwiFF0QPIarnIihIDn7OA==} engines: {node: '>=10.13.0'} - '@tybys/wasm-util@0.9.0': - resolution: {integrity: sha512-6+7nlbMVX/PVDCwaIQ8nTOPveOcFLSt8GcXdx8hD0bt39uWxYT88uXzqTd4fTvqta7oeUJqudepapKNt2DYJFw==} + '@tybys/wasm-util@0.10.1': + resolution: {integrity: sha512-9tTaPJLSiejZKx+Bmog4uSubteqTvFrVrURwkmHixBo0G4seD0zUxp98E1DzUBJxLQ3NPwXrGKDiVjwx/DpPsg==} - '@types/acorn@4.0.6': - resolution: {integrity: sha512-veQTnWP+1D/xbxVrPC3zHnCZRjSrKfhbMUlEA43iMZLu7EsnTtkJklIuwrCPbOi8YkvDQAiW05VQQFvvz9oieQ==} - - '@types/body-parser@1.19.5': - resolution: {integrity: sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg==} + '@types/body-parser@1.19.6': + resolution: {integrity: sha512-HLFeCYgz89uk22N5Qg3dvGvsv46B8GLvKKo1zKG4NybA8U2DiEO3w9lqGg29t/tfLRJpJ6iQxnVw4OnB7MoM9g==} '@types/bonjour@3.5.13': resolution: {integrity: sha512-z9fJ5Im06zvUL548KvYNecEVlA7cVDkGUi6kZusb04mpyEFKCIZJvloCcmpmLaIahDpOQGHaHmG6imtPMmPXGQ==} @@ -1282,20 +1567,20 @@ packages: '@types/eslint-scope@3.7.7': resolution: {integrity: sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==} - '@types/eslint@8.56.10': - resolution: {integrity: sha512-Shavhk87gCtY2fhXDctcfS3e6FdxWkCx1iUZ9eEUbh7rTqlZT0/IzOkCOVt0fCjcFuZ9FPYfuezTBImfHCDBGQ==} + '@types/eslint@9.6.1': + resolution: {integrity: sha512-FXx2pKgId/WyYo2jXw63kk7/+TY7u7AziEJxJAnSFzHlqTAS3Ync6SvgYAN/k4/PQpnnVuzoMuVnByKK2qp0ag==} '@types/estree-jsx@1.0.5': resolution: {integrity: sha512-52CcUVNFyfb1A2ALocQw/Dd1BQFNmSdkuC3BkZ6iqhdMfQz7JWOFRuJFloOzjk+6WijU56m9oKXFAXc7o3Towg==} - '@types/estree@1.0.5': - resolution: {integrity: sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==} + '@types/estree@1.0.8': + resolution: {integrity: sha512-dWHzHa2WqEXI/O1E9OjrocMTKJl2mSrEolh1Iomrv6U+JuNwaHXsXx9bLu5gG7BUWFIN0skIQJQ/L1rIex4X6w==} - '@types/express-serve-static-core@4.19.5': - resolution: {integrity: sha512-y6W03tvrACO72aijJ5uF02FRq5cgDR9lUxddQ8vyF+GvmjJQqbzDcJngEjURc+ZsG31VI3hODNZJ2URj86pzmg==} + '@types/express-serve-static-core@4.19.6': + resolution: {integrity: sha512-N4LZ2xG7DatVqhCZzOGb1Yi5lMbXSZcmdLDe9EzSndPV2HpWYWzRbaerl2n27irrm94EPpprqa8KpskPT085+A==} - '@types/express@4.17.21': - resolution: {integrity: sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ==} + '@types/express@4.17.23': + resolution: {integrity: sha512-Crp6WY9aTYP3qPi2wGDo9iUe/rceX01UMhnF1jmwDcKCFM6cx7YhGP/Mpr3y9AASpfHixIG0E6azCcL5OcDHsQ==} '@types/gtag.js@0.0.12': resolution: {integrity: sha512-YQV9bUsemkzG81Ea295/nF/5GijnD2Af7QhEofh7xu+kvCN6RdodgNwwGWXB5GMI3NoyvQo0odNctoH/qLMIpg==} @@ -1312,11 +1597,11 @@ packages: '@types/http-cache-semantics@4.0.4': resolution: {integrity: sha512-1m0bIFVc7eJWyve9S0RnuRgcQqF/Xd5QsUZAZeQFr1Q3/p9JWoQQEqmVy+DPTNpGXwhgIetAoYF8JSc33q29QA==} - '@types/http-errors@2.0.4': - resolution: {integrity: sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==} + '@types/http-errors@2.0.5': + resolution: {integrity: sha512-r8Tayk8HJnX0FztbZN7oVqGccWgw98T/0neJphO91KkmOzug1KkofZURD4UaD5uH8AqcFLfdPErnBod0u71/qg==} - '@types/http-proxy@1.17.14': - resolution: {integrity: sha512-SSrD0c1OQzlFX7pGu1eXxSEjemej64aaNPRhhVYUGqXh0BtldAAx37MG8btcumvpgKyZp1F5Gn3JkktdxiFv6w==} + '@types/http-proxy@1.17.16': + resolution: {integrity: sha512-sdWoUajOB1cd0A8cRRQ1cfyWNbmFKLAqBB89Y8x5iYyG/mkJHc0YUH8pdWBy2omi9qtCpiIgGjuwO0dQST2l5w==} '@types/istanbul-lib-coverage@2.0.6': resolution: {integrity: sha512-2QF/t/auWm0lsy8XtKVPG19v3sSOQlJe/YHZgfjb/KBBHOGSV+J2q/S671rcq9uTBrLAXmZpqJiaQbMT+zNU1w==} @@ -1339,29 +1624,23 @@ packages: '@types/mime@1.3.5': resolution: {integrity: sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w==} - '@types/ms@0.7.34': - resolution: {integrity: sha512-nG96G3Wp6acyAgJqGasjODb+acrI7KltPiRxzHPXnP3NgI28bpQDRv53olbqGXbfcgF5aiiHmO3xpwEpS5Ld9g==} + '@types/ms@2.1.0': + resolution: {integrity: sha512-GsCCIZDE/p3i96vtEqx+7dBUGXrc7zeSK3wwPHIaRThS+9OhWIXRqzs4d6k1SVU8g91DrNRWxWUGhp5KXQb2VA==} - '@types/node-forge@1.3.11': - resolution: {integrity: sha512-FQx220y22OKNTqaByeBGqHWYz4cl94tpcxeFdvBo3wjG6XPBuZ0BNgNZRV5J5TFmmcsJ4IzsLkmGRiQbnYsBEQ==} + '@types/node-forge@1.3.14': + resolution: {integrity: sha512-mhVF2BnD4BO+jtOp7z1CdzaK4mbuK0LLQYAvdOLqHTavxFNq4zA1EmYkpnFjP8HOUzedfQkRnp0E2ulSAYSzAw==} '@types/node@17.0.45': resolution: {integrity: sha512-w+tIMs3rq2afQdsPJlODhoUEKzFP1ayaoyl1CcnwtIlsVe7K7bA1NGm4s3PraqTLlXnbIN84zuBlxBWo1u9BLw==} - '@types/node@20.14.8': - resolution: {integrity: sha512-DO+2/jZinXfROG7j7WKFn/3C6nFwxy2lLpgLjEXJz+0XKphZlTLJ14mo8Vfg8X5BWN6XjyESXq+LcYdT7tR3bA==} - - '@types/parse-json@4.0.2': - resolution: {integrity: sha512-dISoDXWWQwUquiKsyZ4Ng+HX2KsPL7LyHKHQwgGFEA3IaKac4Obd+h2a/a6waisAoepJlBcx9paWqjA8/HVjCw==} + '@types/node@24.5.2': + resolution: {integrity: sha512-FYxk1I7wPv3K2XBaoyH2cTnocQEu8AOZ60hPbsyukMPLv5/5qr7V1i8PLHdl6Zf87I+xZXFvPCXYjiTFq+YSDQ==} - '@types/prismjs@1.26.4': - resolution: {integrity: sha512-rlAnzkW2sZOjbqZ743IHUhFcvzaGbqijwOu8QZnZCjfQzBqFE3s4lOTJEsxikImav9uzz/42I+O7YUs1mWgMlg==} + '@types/prismjs@1.26.5': + resolution: {integrity: sha512-AUZTa7hQ2KY5L7AmtSiqxlhWxb4ina0yd8hNbl4TWuqnv/pFP0nDMb3YrfSBf4hJVGLh2YEIBfKaBW/9UEl6IQ==} - '@types/prop-types@15.7.12': - resolution: {integrity: sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q==} - - '@types/qs@6.9.15': - resolution: {integrity: sha512-uXHQKES6DQKKCLh441Xv/dwxOq1TVS3JPUMlEqoEglvlhR6Mxnlew/Xq/LRVHpLyk7iK3zODe1qYHIMltO7XGg==} + '@types/qs@6.14.0': + resolution: {integrity: sha512-eOunJqu0K1923aExK6y8p6fsihYEn/BYuQ4g0CxAAgFc4b/ZLN4CrsRZ55srTdqoiLzU2B2evC+apEIxprEzkQ==} '@types/range-parser@1.2.7': resolution: {integrity: sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==} @@ -1375,89 +1654,89 @@ packages: '@types/react-router@5.1.20': resolution: {integrity: sha512-jGjmu/ZqS7FjSH6owMcD5qpq19+1RS9DeVRqfl1FeBMxTDQAGwlMWOcs52NDoXaNKyG3d1cYQFMs9rCrb88o9Q==} - '@types/react@18.3.3': - resolution: {integrity: sha512-hti/R0pS0q1/xx+TsI73XIqk26eBsISZ2R0wUijXIngRK9R/e7Xw/cXVxQK7R5JjW+SV4zGcn5hXjudkN/pLIw==} + '@types/react@19.1.15': + resolution: {integrity: sha512-+kLxJpaJzXybyDyFXYADyP1cznTO8HSuBpenGlnKOAkH4hyNINiywvXS/tGJhsrGGP/gM185RA3xpjY0Yg4erA==} - '@types/retry@0.12.0': - resolution: {integrity: sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==} + '@types/retry@0.12.2': + resolution: {integrity: sha512-XISRgDJ2Tc5q4TRqvgJtzsRkFYNJzZrhTdtMoGVBttwzzQJkPnS3WWTFc7kuDRoPtPakl+T+OfdEUjYJj7Jbow==} '@types/sax@1.2.7': resolution: {integrity: sha512-rO73L89PJxeYM3s3pPPjiPgVVcymqU490g0YO5n5By0k2Erzj6tay/4lr1CHAAU4JyOWd1rpQ8bCf6cZfHU96A==} - '@types/send@0.17.4': - resolution: {integrity: sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA==} + '@types/send@0.17.5': + resolution: {integrity: sha512-z6F2D3cOStZvuk2SaP6YrwkNO65iTZcwA2ZkSABegdkAh/lf+Aa/YQndZVfmEXT5vgAp6zv06VQ3ejSVjAny4w==} '@types/serve-index@1.9.4': resolution: {integrity: sha512-qLpGZ/c2fhSs5gnYsQxtDEq3Oy8SXPClIXkW5ghvAvsNuVSA8k+gCONcUCS/UjLEYvYps+e8uBtfgXgvhwfNug==} - '@types/serve-static@1.15.7': - resolution: {integrity: sha512-W8Ym+h8nhuRwaKPaDw34QUkwsGi6Rc4yYqvKFo5rm2FUEhCFbzVWrxXUxuKK8TASjWsysJY0nsmNCGhCOIsrOw==} + '@types/serve-static@1.15.8': + resolution: {integrity: sha512-roei0UY3LhpOJvjbIP6ZZFngyLKl5dskOtDhxY5THRSpO+ZI+nzJ+m5yUMzGrp89YRa7lvknKkMYjqQFGwA7Sg==} '@types/sockjs@0.3.36': resolution: {integrity: sha512-MK9V6NzAS1+Ud7JV9lJLFqW85VbC9dq3LmwZCuBe4wBDgKC0Kj/jd8Xl+nSviU+Qc3+m7umHHyHg//2KSa0a0Q==} - '@types/unist@2.0.10': - resolution: {integrity: sha512-IfYcSBWE3hLpBg8+X2SEa8LVkJdJEkT2Ese2aaLs3ptGdVtABxndrMaxuFlQ1qdFf9Q5rDvDpxI3WwgvKFAsQA==} + '@types/unist@2.0.11': + resolution: {integrity: sha512-CmBKiL6NNo/OqgmMn95Fk9Whlp2mtvIv+KNpQKN2F4SjvrEesubTRWGYSg+BnWZOnlCaSTU1sMpsBOzgbYhnsA==} - '@types/unist@3.0.2': - resolution: {integrity: sha512-dqId9J8K/vGi5Zr7oo212BGii5m3q5Hxlkwy3WpYuKPklmBEvsbMYYyLxAQpSffdLl/gdW0XUpKWFvYmyoWCoQ==} + '@types/unist@3.0.3': + resolution: {integrity: sha512-ko/gIFJRv177XgZsZcBwnqJN5x/Gien8qNOn0D5bQU/zAzVf9Zt3BlcUiLqhV9y4ARk0GbT3tnUiPNgnTXzc/Q==} - '@types/ws@8.5.10': - resolution: {integrity: sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A==} + '@types/ws@8.18.1': + resolution: {integrity: sha512-ThVF6DCVhA8kUGy+aazFQ4kXQ7E1Ty7A3ypFOe0IcJV8O/M511G99AW24irKrW56Wt44yG9+ij8FaqoBGkuBXg==} '@types/yargs-parser@21.0.3': resolution: {integrity: sha512-I4q9QU9MQv4oEOz4tAHJtNz1cwuLxn2F3xcc2iV5WdqLPpUnj30aUuxt1mAxYTG+oe8CZMV/+6rU4S4gRDzqtQ==} - '@types/yargs@17.0.32': - resolution: {integrity: sha512-xQ67Yc/laOG5uMfX/093MRlGGCIBzZMarVa+gfNKJxWAIgykYpVGkBdbqEzGDDfCrVUj6Hiff4mTZ5BA6TmAog==} + '@types/yargs@17.0.33': + resolution: {integrity: sha512-WpxBCKWPLr4xSsHgz511rFJAM+wS28w2zEO1QDNY5zM/S8ok70NNfztH0xwhqKyaK0OHCbN98LDAZuy1ctxDkA==} - '@ungap/structured-clone@1.2.0': - resolution: {integrity: sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==} + '@ungap/structured-clone@1.3.0': + resolution: {integrity: sha512-WmoN8qaIAo7WTYWbAZuG8PYEhn5fkz7dZrqTBZ7dtt//lL2Gwms1IcnQ5yHqjDfX8Ft5j4YzDM23f87zBfDe9g==} - '@webassemblyjs/ast@1.12.1': - resolution: {integrity: sha512-EKfMUOPRRUTy5UII4qJDGPpqfwjOmZ5jeGFwid9mnoqIFK+e0vqoi1qH56JpmZSzEL53jKnNzScdmftJyG5xWg==} + '@webassemblyjs/ast@1.14.1': + resolution: {integrity: sha512-nuBEDgQfm1ccRp/8bCQrx1frohyufl4JlbMMZ4P1wpeOfDhF6FQkxZJ1b/e+PLwr6X1Nhw6OLme5usuBWYBvuQ==} - '@webassemblyjs/floating-point-hex-parser@1.11.6': - resolution: {integrity: sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==} + '@webassemblyjs/floating-point-hex-parser@1.13.2': + resolution: {integrity: sha512-6oXyTOzbKxGH4steLbLNOu71Oj+C8Lg34n6CqRvqfS2O71BxY6ByfMDRhBytzknj9yGUPVJ1qIKhRlAwO1AovA==} - '@webassemblyjs/helper-api-error@1.11.6': - resolution: {integrity: sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==} + '@webassemblyjs/helper-api-error@1.13.2': + resolution: {integrity: sha512-U56GMYxy4ZQCbDZd6JuvvNV/WFildOjsaWD3Tzzvmw/mas3cXzRJPMjP83JqEsgSbyrmaGjBfDtV7KDXV9UzFQ==} - '@webassemblyjs/helper-buffer@1.12.1': - resolution: {integrity: sha512-nzJwQw99DNDKr9BVCOZcLuJJUlqkJh+kVzVl6Fmq/tI5ZtEyWT1KZMyOXltXLZJmDtvLCDgwsyrkohEtopTXCw==} + '@webassemblyjs/helper-buffer@1.14.1': + resolution: {integrity: sha512-jyH7wtcHiKssDtFPRB+iQdxlDf96m0E39yb0k5uJVhFGleZFoNw1c4aeIcVUPPbXUVJ94wwnMOAqUHyzoEPVMA==} - '@webassemblyjs/helper-numbers@1.11.6': - resolution: {integrity: sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==} + '@webassemblyjs/helper-numbers@1.13.2': + resolution: {integrity: sha512-FE8aCmS5Q6eQYcV3gI35O4J789wlQA+7JrqTTpJqn5emA4U2hvwJmvFRC0HODS+3Ye6WioDklgd6scJ3+PLnEA==} - '@webassemblyjs/helper-wasm-bytecode@1.11.6': - resolution: {integrity: sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==} + '@webassemblyjs/helper-wasm-bytecode@1.13.2': + resolution: {integrity: sha512-3QbLKy93F0EAIXLh0ogEVR6rOubA9AoZ+WRYhNbFyuB70j3dRdwH9g+qXhLAO0kiYGlg3TxDV+I4rQTr/YNXkA==} - '@webassemblyjs/helper-wasm-section@1.12.1': - resolution: {integrity: sha512-Jif4vfB6FJlUlSbgEMHUyk1j234GTNG9dBJ4XJdOySoj518Xj0oGsNi59cUQF4RRMS9ouBUxDDdyBVfPTypa5g==} + '@webassemblyjs/helper-wasm-section@1.14.1': + resolution: {integrity: sha512-ds5mXEqTJ6oxRoqjhWDU83OgzAYjwsCV8Lo/N+oRsNDmx/ZDpqalmrtgOMkHwxsG0iI//3BwWAErYRHtgn0dZw==} - '@webassemblyjs/ieee754@1.11.6': - resolution: {integrity: sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==} + '@webassemblyjs/ieee754@1.13.2': + resolution: {integrity: sha512-4LtOzh58S/5lX4ITKxnAK2USuNEvpdVV9AlgGQb8rJDHaLeHciwG4zlGr0j/SNWlr7x3vO1lDEsuePvtcDNCkw==} - '@webassemblyjs/leb128@1.11.6': - resolution: {integrity: sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==} + '@webassemblyjs/leb128@1.13.2': + resolution: {integrity: sha512-Lde1oNoIdzVzdkNEAWZ1dZ5orIbff80YPdHx20mrHwHrVNNTjNr8E3xz9BdpcGqRQbAEa+fkrCb+fRFTl/6sQw==} - '@webassemblyjs/utf8@1.11.6': - resolution: {integrity: sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==} + '@webassemblyjs/utf8@1.13.2': + resolution: {integrity: sha512-3NQWGjKTASY1xV5m7Hr0iPeXD9+RDobLll3T9d2AO+g3my8xy5peVyjSag4I50mR1bBSN/Ct12lo+R9tJk0NZQ==} - '@webassemblyjs/wasm-edit@1.12.1': - resolution: {integrity: sha512-1DuwbVvADvS5mGnXbE+c9NfA8QRcZ6iKquqjjmR10k6o+zzsRVesil54DKexiowcFCPdr/Q0qaMgB01+SQ1u6g==} + '@webassemblyjs/wasm-edit@1.14.1': + resolution: {integrity: sha512-RNJUIQH/J8iA/1NzlE4N7KtyZNHi3w7at7hDjvRNm5rcUXa00z1vRz3glZoULfJ5mpvYhLybmVcwcjGrC1pRrQ==} - '@webassemblyjs/wasm-gen@1.12.1': - resolution: {integrity: sha512-TDq4Ojh9fcohAw6OIMXqiIcTq5KUXTGRkVxbSo1hQnSy6lAM5GSdfwWeSxpAo0YzgsgF182E/U0mDNhuA0tW7w==} + '@webassemblyjs/wasm-gen@1.14.1': + resolution: {integrity: sha512-AmomSIjP8ZbfGQhumkNvgC33AY7qtMCXnN6bL2u2Js4gVCg8fp735aEiMSBbDR7UQIj90n4wKAFUSEd0QN2Ukg==} - '@webassemblyjs/wasm-opt@1.12.1': - resolution: {integrity: sha512-Jg99j/2gG2iaz3hijw857AVYekZe2SAskcqlWIZXjji5WStnOpVoat3gQfT/Q5tb2djnCjBtMocY/Su1GfxPBg==} + '@webassemblyjs/wasm-opt@1.14.1': + resolution: {integrity: sha512-PTcKLUNvBqnY2U6E5bdOQcSM+oVP/PmrDY9NzowJjislEjwP/C4an2303MCVS2Mg9d3AJpIGdUFIQQWbPds0Sw==} - '@webassemblyjs/wasm-parser@1.12.1': - resolution: {integrity: sha512-xikIi7c2FHXysxXe3COrVUPSheuBtpcfhbpFj4gmu7KRLYOzANztwUU0IbsqvMqzuNK2+glRGWCEqZo1WCLyAQ==} + '@webassemblyjs/wasm-parser@1.14.1': + resolution: {integrity: sha512-JLBl+KZ0R5qB7mCnud/yyX08jWFw5MsoalJ1pQ4EdFlgj9VdXKGuENGsiCIjegI1W7p91rUlcB/LB5yRJKNTcQ==} - '@webassemblyjs/wast-printer@1.12.1': - resolution: {integrity: sha512-+X4WAlOisVWQMikjbcvY2e0rwPsKQ9F688lksZhBcPycBBuii3O7m8FACbDMWDojpAqvjIncrG8J0XHKyQfVeA==} + '@webassemblyjs/wast-printer@1.14.1': + resolution: {integrity: sha512-kPSSXE6De1XOR820C90RIo2ogvZG+c3KiHzqUoO/F34Y2shGzesfqv7o57xrxovZJH/MetF5UjroJ/R/3isoiw==} '@xtuc/ieee754@1.2.0': resolution: {integrity: sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==} @@ -1469,22 +1748,23 @@ packages: resolution: {integrity: sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==} engines: {node: '>= 0.6'} - acorn-import-attributes@1.9.5: - resolution: {integrity: sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==} + acorn-import-phases@1.0.4: + resolution: {integrity: sha512-wKmbr/DDiIXzEOiWrTTUcDm24kQ2vGfZQvM2fwg2vXqR5uW6aapr7ObPtj1th32b9u90/Pf4AItvdTh42fBmVQ==} + engines: {node: '>=10.13.0'} peerDependencies: - acorn: ^8 + acorn: ^8.14.0 acorn-jsx@5.3.2: resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==} peerDependencies: acorn: ^6.0.0 || ^7.0.0 || ^8.0.0 - acorn-walk@8.3.3: - resolution: {integrity: sha512-MxXdReSRhGO7VlFe1bRG/oI7/mdLV9B9JJT0N8vZOhF7gFRR5l3M8W9G8JxmKV+JC5mGqJ0QvqfSOLsCPa4nUw==} + acorn-walk@8.3.4: + resolution: {integrity: sha512-ueEepnujpqee2o5aIYnvHU6C0A42MNdsIDeqy5BydrkuC5R1ZuUFnm27EeFJGoEHJQgn3uleRvmTXaJgfXbt4g==} engines: {node: '>=0.4.0'} - acorn@8.12.0: - resolution: {integrity: sha512-RTvkC4w+KNXrM39/lWCUaG0IbRkWdCv7W/IOW9oU6SawyxulvkQy5HQPVTKxEjczcUvapcrw3cFx/60VN/NRNw==} + acorn@8.15.0: + resolution: {integrity: sha512-NZyJarBfL7nWwIq+FDL6Zp/yHEhePMNnnJ0y3qfieCrmNvYct8uvtiV41UvlSe6apAfk0fY1FbWx+NwfmpvtTg==} engines: {node: '>=0.4.0'} hasBin: true @@ -1496,6 +1776,12 @@ packages: resolution: {integrity: sha512-4I7Td01quW/RpocfNayFdFVk1qSuoh0E7JrbRJ16nH01HhKFQ88INq9Sd+nd72zqRySlr9BmDA8xlEJ6vJMrYA==} engines: {node: '>=8'} + ai@5.0.56: + resolution: {integrity: sha512-Rl++Ogg6DxzFkVHAOJZzhqcqvqtBLGOP9mMxJOGr2EJWj5HH5zjqDcnRh6x5vBoca5kj/Gd0rvUZFMnyI+sRiw==} + engines: {node: '>=18'} + peerDependencies: + zod: ^3.25.76 || ^4.1.8 + ajv-formats@2.1.1: resolution: {integrity: sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==} peerDependencies: @@ -1517,20 +1803,25 @@ packages: ajv@6.12.6: resolution: {integrity: sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==} - ajv@8.16.0: - resolution: {integrity: sha512-F0twR8U1ZU67JIEtekUcLkXkoO5mMMmgGD8sK/xUFzJ805jxHQl92hImFAqqXMyMYjSPOyUPAwHYhB72g5sTXw==} + ajv@8.17.1: + resolution: {integrity: sha512-B/gBuNg5SiMTrPkC+A2+cW0RszwxYmn6VYxB/inlBStS5nx6xHIt/ehKRhIMhqusl7a8LjQoZnjCs5vhwxOQ1g==} - algoliasearch-helper@3.22.1: - resolution: {integrity: sha512-fSxJ4YreH4kOME9CnKazbAn2tK/rvBoV37ETd6nTt4j7QfkcnW+c+F22WfuE9Q/sRpvOMnUwU/BXAVEiwW7p/w==} + algoliasearch-helper@3.26.0: + resolution: {integrity: sha512-Rv2x3GXleQ3ygwhkhJubhhYGsICmShLAiqtUuJTUkr9uOCOXyF2E71LVT4XDnVffbknv8XgScP4U0Oxtgm+hIw==} peerDependencies: algoliasearch: '>= 3.1 < 6' - algoliasearch@4.23.3: - resolution: {integrity: sha512-Le/3YgNvjW9zxIQMRhUHuhiUjAlKY/zsdZpfq4dlLqg6mEm0nL6yk+7f2hDOtLpxsgE4jSzDmvHL7nXdBp5feg==} + algoliasearch@5.39.0: + resolution: {integrity: sha512-DzTfhUxzg9QBNGzU/0kZkxEV72TeA4MmPJ7RVfLnQwHNhhliPo7ynglEWJS791rNlLFoTyrKvkapwr/P3EXV9A==} + engines: {node: '>= 14.0.0'} ansi-align@3.0.1: resolution: {integrity: sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==} + ansi-escapes@4.3.2: + resolution: {integrity: sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==} + engines: {node: '>=8'} + ansi-html-community@0.0.8: resolution: {integrity: sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==} engines: {'0': node >= 0.8.0} @@ -1540,20 +1831,16 @@ packages: resolution: {integrity: sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==} engines: {node: '>=8'} - ansi-regex@6.0.1: - resolution: {integrity: sha512-n5M855fKb2SsfMIiFFoVrABHJC8QtHwVx+mHWP3QcEqBHYienj5dHSgjbxtC0WEZXYt4wcD6zrQElDPhFuZgfA==} + ansi-regex@6.2.2: + resolution: {integrity: sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==} engines: {node: '>=12'} - ansi-styles@3.2.1: - resolution: {integrity: sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==} - engines: {node: '>=4'} - ansi-styles@4.3.0: resolution: {integrity: sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==} engines: {node: '>=8'} - ansi-styles@6.2.1: - resolution: {integrity: sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==} + ansi-styles@6.2.3: + resolution: {integrity: sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==} engines: {node: '>=12'} any-promise@1.3.0: @@ -1579,23 +1866,19 @@ packages: resolution: {integrity: sha512-HGyxoOTYUyCM6stUe6EJgnd4EoewAI7zMdfqO+kGjnlZmBDz/cR5pf8r/cR4Wq60sL/p0IkcjUEEPwS3GFrIyw==} engines: {node: '>=8'} - astring@1.8.6: - resolution: {integrity: sha512-ISvCdHdlTDlH5IpxQJIex7BWBywFWgjJSVdwst+/iQCoEYnyOaQ95+X1JGshuBjGp6nxKUy1jMgE3zPqN7fQdg==} + astring@1.9.0: + resolution: {integrity: sha512-LElXdjswlqjWrPpJFg1Fx4wpkOCxj1TDHlSV4PlaRxHGWko024xICaa97ZkMfs6DRKlCguiAI+rbXv5GWwXIkg==} hasBin: true - at-least-node@1.0.0: - resolution: {integrity: sha512-+q/t7Ekv1EDY2l6Gda6LLiX14rU9TV20Wa3ofeQmwPFZbOMo9DXrLbOjFaaclkXKWidIaopwAObQDqwWtGUjqg==} - engines: {node: '>= 4.0.0'} - - autoprefixer@10.4.19: - resolution: {integrity: sha512-BaENR2+zBZ8xXhM4pUaKUxlVdxZ0EZhjvbopwnXmxRUfqDmwSpC2lAi/QXvx7NRdPCo1WKEcEF6mV64si1z4Ew==} + autoprefixer@10.4.21: + resolution: {integrity: sha512-O+A6LWV5LDHSJD3LjHYoNi4VLsj/Whi7k6zG12xTYaU4cQ8oxQGckXNX8cRHK5yOZ/ppVHe0ZBXGzSV9jXdVbQ==} engines: {node: ^10 || ^12 || >=14} hasBin: true peerDependencies: postcss: ^8.1.0 - babel-loader@9.1.3: - resolution: {integrity: sha512-xG3ST4DglodGf8qSwv0MdeWLhrDsw/32QMdTO5T1ZIp9gQur0HkCyFs7Awskr10JKXFXwpAhiCuYX5oGXnRGbw==} + babel-loader@9.2.1: + resolution: {integrity: sha512-fqe8naHt46e0yIdkjUZYqddSXfej3AHajX+CSO5X7oy0EmPc6o5Xh+RClNoHjnieWz9AW4kZxW9yyFMhVB1QLA==} engines: {node: '>= 14.15.0'} peerDependencies: '@babel/core': ^7.12.0 @@ -1604,18 +1887,18 @@ packages: babel-plugin-dynamic-import-node@2.3.3: resolution: {integrity: sha512-jZVI+s9Zg3IqA/kdi0i6UDCybUI3aSBLnglhYbSSjKlV7yF1F/5LWv8MakQmvYpnbJDS6fcBL2KzHSxNCMtWSQ==} - babel-plugin-polyfill-corejs2@0.4.11: - resolution: {integrity: sha512-sMEJ27L0gRHShOh5G54uAAPaiCOygY/5ratXuiyb2G46FmlSpc9eFCzYVyDiPxfNbwzA7mYahmjQc5q+CZQ09Q==} + babel-plugin-polyfill-corejs2@0.4.14: + resolution: {integrity: sha512-Co2Y9wX854ts6U8gAAPXfn0GmAyctHuK8n0Yhfjd6t30g7yvKjspvvOo9yG+z52PZRgFErt7Ka2pYnXCjLKEpg==} peerDependencies: '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 - babel-plugin-polyfill-corejs3@0.10.4: - resolution: {integrity: sha512-25J6I8NGfa5YkCDogHRID3fVCadIR8/pGl1/spvCkzb6lVn6SR3ojpx9nOn9iEBcUsjY24AmdKm5khcfKdylcg==} + babel-plugin-polyfill-corejs3@0.13.0: + resolution: {integrity: sha512-U+GNwMdSFgzVmfhNm8GJUX88AadB3uo9KpJqS3FaqNIPKgySuvMb+bHPsOmmuWyIcuqZj/pzt1RUIUZns4y2+A==} peerDependencies: '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 - babel-plugin-polyfill-regenerator@0.6.2: - resolution: {integrity: sha512-2R25rQZWP63nGwaAswvDazbPXfrM3HwVoBXK6HcqeKrSrL/JqcC/rDcf95l4r7LXLyxDXc8uQDa064GubtCABg==} + babel-plugin-polyfill-regenerator@0.6.5: + resolution: {integrity: sha512-ISqQ2frbiNU9vIJkzg7dlPpznPZ4jOiUQ1uSmB0fEHeowtN3COYRsXr/xexn64NpU13P06jc/L5TgiJXOgrbEg==} peerDependencies: '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 @@ -1625,6 +1908,10 @@ packages: balanced-match@1.0.2: resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==} + baseline-browser-mapping@2.8.9: + resolution: {integrity: sha512-hY/u2lxLrbecMEWSB0IpGzGyDyeoMFQhCvZd2jGFSE5I17Fh01sYUBPCJtkWERw7zrac9+cIghxm/ytJa2X8iA==} + hasBin: true + batch@0.6.1: resolution: {integrity: sha512-x+VAiMRL6UPkx+kudNvxTl6hB2XNNCG2r+7wixVfIYwu/2HKRXimwQyaumLjMveWvT2Hkd/cAJw+QBMfJ/EKVw==} @@ -1635,12 +1922,12 @@ packages: resolution: {integrity: sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==} engines: {node: '>=8'} - body-parser@1.20.2: - resolution: {integrity: sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==} + body-parser@1.20.3: + resolution: {integrity: sha512-7rAxByjUMqQ3/bHJy7D6OGXvx/MMc4IqBn/X0fcM1QUcAItpZrBEYhWGem+tzXH90c+G01ypMcYJBO9Y30203g==} engines: {node: '>= 0.8', npm: 1.2.8000 || >= 1.4.16} - bonjour-service@1.2.1: - resolution: {integrity: sha512-oSzCS2zV14bh2kji6vNe7vrpJYCHGvcZnlffFQ1MEoX/WOeQ/teD8SYWKR942OI3INjq8OMNJlbPK5LLLUxFDw==} + bonjour-service@1.3.0: + resolution: {integrity: sha512-3YuAUiSkWykd+2Azjgyxei8OWf8thdn8AITIog2M4UICzoqfjlqr64WIjEXZllf/W6vK1goqleSR6brGomxQqA==} boolbase@1.0.0: resolution: {integrity: sha512-JZOSA7Mo9sNGB8+UjSgzdLtokWAky1zbztM3WRLCbZ70/3cTANmQmOdR7y2g+J0e2WXywy1yS468tY+IruqEww==} @@ -1653,24 +1940,28 @@ packages: resolution: {integrity: sha512-2hCgjEmP8YLWQ130n2FerGv7rYpfBmnmp9Uy2Le1vge6X3gZIfSmEzP5QTDElFxcvVcXlEn8Aq6MU/PZygIOog==} engines: {node: '>=14.16'} - brace-expansion@1.1.11: - resolution: {integrity: sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==} + brace-expansion@1.1.12: + resolution: {integrity: sha512-9T9UjW3r0UW5c1Q7GTwllptXwhvYmEzFhzMfZ9H7FQWt+uZePjZPjBP/W1ZEyZ1twGWom5/56TF4lPcqjnDHcg==} - brace-expansion@2.0.1: - resolution: {integrity: sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==} + brace-expansion@2.0.2: + resolution: {integrity: sha512-Jt0vHyM+jmUBqojB7E1NIYadt0vI0Qxjxd2TErW94wDz+E2LAm5vKMXXwg6ZZBTHPuUlDgQHKXvjGBdfcF1ZDQ==} braces@3.0.3: resolution: {integrity: sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==} engines: {node: '>=8'} - browserslist@4.23.1: - resolution: {integrity: sha512-TUfofFo/KsK/bWZ9TWQ5O26tsWW4Uhmt8IYklbnUa70udB6P2wA7w7o4PY4muaEPBQaAX+CEnmmIA41NVHtPVw==} + browserslist@4.26.2: + resolution: {integrity: sha512-ECFzp6uFOSB+dcZ5BK/IBaGWssbSYBHvuMeMt3MMFyhI0Z8SqGgEkBLARgpRH3hutIgPVsALcMwbDrJqPxQ65A==} engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7} hasBin: true buffer-from@1.1.2: resolution: {integrity: sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ==} + bundle-name@4.1.0: + resolution: {integrity: sha512-tjwM5exMg6BGRI+kNmTntNsvdZS1X8BFYS6tnJ2hdH0kVxM6/eVZ2xy+FqStSWvYmtfFMDLIxurorHwDKfDz5Q==} + engines: {node: '>=18'} + bytes@3.0.0: resolution: {integrity: sha512-pMhOfFDPiv9t5jjIXkHosWmkSyQbvsgEVNkz0ERHbuLh2T/7j4Mqqpz523Fe8MVY89KC6Sh/QfS2sM+SjgFDcw==} engines: {node: '>= 0.8'} @@ -1687,8 +1978,16 @@ packages: resolution: {integrity: sha512-zkDT5WAF4hSSoUgyfg5tFIxz8XQK+25W/TLVojJTMKBaxevLBBtLxgqguAuVQB8PVW79FVjHcU+GJ9tVbDZ9mQ==} engines: {node: '>=14.16'} - call-bind@1.0.7: - resolution: {integrity: sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==} + call-bind-apply-helpers@1.0.2: + resolution: {integrity: sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==} + engines: {node: '>= 0.4'} + + call-bind@1.0.8: + resolution: {integrity: sha512-oKlSFMcMwpUg2ednkhQ454wfWiU/ul3CkJe/PEHcTKuiX6RpbehUiFMXu13HalGZxfUwCQzZG747YXBn1im9ww==} + engines: {node: '>= 0.4'} + + call-bound@1.0.4: + resolution: {integrity: sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==} engines: {node: '>= 0.4'} callsites@3.1.0: @@ -1713,22 +2012,18 @@ packages: caniuse-api@3.0.0: resolution: {integrity: sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==} - caniuse-lite@1.0.30001636: - resolution: {integrity: sha512-bMg2vmr8XBsbL6Lr0UHXy/21m84FTxDLWn2FSqMd5PrlbMxwJlQnC2YWYxVgp66PZE+BBNF2jYQUBKCo1FDeZg==} + caniuse-lite@1.0.30001745: + resolution: {integrity: sha512-ywt6i8FzvdgrrrGbr1jZVObnVv6adj+0if2/omv9cmR2oiZs30zL4DIyaptKcbOrBdOIc74QTMoJvSE2QHh5UQ==} ccount@2.0.1: resolution: {integrity: sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==} - chalk@2.4.2: - resolution: {integrity: sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==} - engines: {node: '>=4'} - chalk@4.1.2: resolution: {integrity: sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==} engines: {node: '>=10'} - chalk@5.3.0: - resolution: {integrity: sha512-dLitG79d+GV1Nb/VYcCDFivJeK1hiukt9QjRNVOsUtTy1rR1YJsmpGGTZ3qJos+uw7WmWF4wUwBd9jxjocFC2w==} + chalk@5.6.2: + resolution: {integrity: sha512-7NzBL0rN6fMUW+f7A6Io4h40qQlG+xGmtMxfbnH/K7TAtt8JQWVQK+6g0UXKMeVJoyV5EkkNsErQ8pVD3bLHbA==} engines: {node: ^12.17.0 || ^14.13 || >=16.0.0} char-regex@1.0.2: @@ -1754,6 +2049,10 @@ packages: resolution: {integrity: sha512-VqR8m68vM46BNnuZ5NtnGBKIE/DfN0cRIzg9n40EIq9NOv90ayxLBXA8fXC5gquFRGJSTRqBq25Jt2ECLR431Q==} engines: {node: '>= 6'} + cheerio@1.1.2: + resolution: {integrity: sha512-IkxPpb5rS/d1IiLbHMgfPuS0FgiWTtFIm/Nj+2woXDLTZ7fOT2eqzgYbdMlLweqlHbsZjxEChoVK+7iph7jyQg==} + engines: {node: '>=20.18.1'} + chokidar@3.6.0: resolution: {integrity: sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==} engines: {node: '>= 8.10.0'} @@ -1786,10 +2085,6 @@ packages: resolution: {integrity: sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==} engines: {node: '>=6'} - clsx@1.2.1: - resolution: {integrity: sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg==} - engines: {node: '>=6'} - clsx@2.1.1: resolution: {integrity: sha512-eYm0QWBtUrBWZWG0d386OGAw16Z995PiOVo2B7bjWSbHedGl5e0ZWaq65kOGgUSNesEIDkB9ISbTg/JK9dhCZA==} engines: {node: '>=6'} @@ -1797,16 +2092,10 @@ packages: collapse-white-space@2.1.0: resolution: {integrity: sha512-loKTxY1zCOuG4j9f6EPnuyyYkf58RnhhWTvRoZEokgB+WbdXehfjFviyOVYkqzEWz1Q5kRiZdBYS5SwxbQYwzw==} - color-convert@1.9.3: - resolution: {integrity: sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==} - color-convert@2.0.1: resolution: {integrity: sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==} engines: {node: '>=7.0.0'} - color-name@1.1.3: - resolution: {integrity: sha512-72fSenhMw2HZMTVHeCA9KCmpEIbzWiQsjN+BHcBbS9vr1mtt+vJjPdksIBNUmKAW8TFUDPJK5SUU3QhE9NEXDw==} - color-name@1.1.4: resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==} @@ -1820,6 +2109,9 @@ packages: resolution: {integrity: sha512-VcQB1ziGD0NXrhKxiwyNbCDmRzs/OShMs2GqW2DlU2A/Sd0nQxE1oWDAE5O0ygSx5mgQOn9eIFh7yKPgFRVkPQ==} engines: {node: '>=10'} + comlink@4.4.2: + resolution: {integrity: sha512-OxGdvBmJuNKSCMO4NTl1L47VRp6xn2wG4F/2hYzB6tiCb709otOxtEYCSvK80PtjODfXXZu8ds+Nw5kVCjqd2g==} + comma-separated-tokens@2.0.3: resolution: {integrity: sha512-Fu4hJdvzeylCfQPp9SGWidpzrMs7tTrlu6Vb8XGaRGck8QSNZJJp538Wrb60Lax4fPwR64ViY468OIUTbRlGZg==} @@ -1853,8 +2145,8 @@ packages: resolution: {integrity: sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==} engines: {node: '>= 0.6'} - compression@1.7.4: - resolution: {integrity: sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==} + compression@1.8.1: + resolution: {integrity: sha512-9mAqGPHLakhCLeNyxPkK4xVo746zQ/czLH1Ky+vkitMnWfWZps8r0qXuwhwizagCRttsL4lfG4pIOvaWLpAP0w==} engines: {node: '>= 0.8.0'} concat-map@0.0.1: @@ -1871,8 +2163,9 @@ packages: resolution: {integrity: sha512-U73+6lQFmfiNPrYbXqr6kZ1i1wiRqXnp2nhMsINseWXO8lDau0LGEffJ8kQi4EjLZympVgRdvqjAgiZ1tgzDDA==} engines: {node: '>=0.8'} - consola@2.15.3: - resolution: {integrity: sha512-9vAdYbHj6x2fLKC4+oPH0kFzY/orMZyG2Aj+kNylHxKGJ/Ed4dpNyAQYwJOdqO4zdM7XpVHmyejQDcQHrnuXbw==} + consola@3.4.2: + resolution: {integrity: sha512-5IKcdX0nnYavi6G7TtOhwkYzyjfJlatbjMjuLSfE2kYT5pMDOilZ4OvMhi637CcDICTmz3wARPoyhqyX1Y+XvA==} + engines: {node: ^14.18.0 || >=16.10.0} content-disposition@0.5.2: resolution: {integrity: sha512-kRGRZw3bLlFISDBgwTSA1TMBFN6J6GWDeubmDE3AF+3+yXL8hTWv8r5rkLbqYXY4RjPk/EzHnClI3zQf1cFmHA==} @@ -1892,36 +2185,28 @@ packages: cookie-signature@1.0.6: resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==} - cookie@0.6.0: - resolution: {integrity: sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==} + cookie@0.7.1: + resolution: {integrity: sha512-6DnInpx7SJ2AK3+CTUE/ZM0vWTUboZCegxhC2xiIydHR9jNuTAASBrfEpHhiGOZw/nX51bHt6YQl8jsGo4y/0w==} engines: {node: '>= 0.6'} - copy-text-to-clipboard@3.2.0: - resolution: {integrity: sha512-RnJFp1XR/LOBDckxTib5Qjr/PMfkatD0MUCQgdpqS8MdKiNUzBjAQBEN6oUy+jW7LI93BBG3DtMB2KOOKpGs2Q==} - engines: {node: '>=12'} - copy-webpack-plugin@11.0.0: resolution: {integrity: sha512-fX2MWpamkW0hZxMEg0+mYnA40LTosOSa5TqZ9GYIBzyJa9C3QUaMPSE2xAi/buNr8u89SfD9wHSQVBzrRa/SOQ==} engines: {node: '>= 14.15.0'} peerDependencies: webpack: ^5.1.0 - core-js-compat@3.37.1: - resolution: {integrity: sha512-9TNiImhKvQqSUkOvk/mMRZzOANTiEVC7WaBNhHcKM7x+/5E1l5NvsysR19zuDQScE8k+kfQXWRN3AtS/eOSHpg==} + core-js-compat@3.45.1: + resolution: {integrity: sha512-tqTt5T4PzsMIZ430XGviK4vzYSoeNJ6CXODi6c/voxOT6IZqBht5/EKaSNnYiEjjRYxjVz7DQIsOsY0XNi8PIA==} - core-js-pure@3.37.1: - resolution: {integrity: sha512-J/r5JTHSmzTxbiYYrzXg9w1VpqrYt+gexenBE9pugeyhwPZTAEJddyiReJWsLO6uNQ8xJZFbod6XC7KKwatCiA==} + core-js-pure@3.45.1: + resolution: {integrity: sha512-OHnWFKgTUshEU8MK+lOs1H8kC8GkTi9Z1tvNkxrCcw9wl3MJIO7q2ld77wjWn4/xuGrVu2X+nME1iIIPBSdyEQ==} - core-js@3.37.1: - resolution: {integrity: sha512-Xn6qmxrQZyB0FFY8E3bgRXei3lWDJHhvI+u0q9TKIYM49G8pAr0FgnnrFRAmsbptZL1yxRADVXn+x5AGsbBfyw==} + core-js@3.45.1: + resolution: {integrity: sha512-L4NPsJlCfZsPeXukyzHFlg/i7IIVwHSItR0wg0FLNqYClJ4MQYTYLbC7EkjKYRLZF2iof2MUgN0EGy7MdQFChg==} core-util-is@1.0.3: resolution: {integrity: sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==} - cosmiconfig@6.0.0: - resolution: {integrity: sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg==} - engines: {node: '>=8'} - cosmiconfig@8.3.6: resolution: {integrity: sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==} engines: {node: '>=14'} @@ -1931,20 +2216,32 @@ packages: typescript: optional: true - cross-spawn@7.0.3: - resolution: {integrity: sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==} + cross-spawn@7.0.6: + resolution: {integrity: sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==} engines: {node: '>= 8'} crypto-random-string@4.0.0: resolution: {integrity: sha512-x8dy3RnvYdlUcPOjkEHqozhiwzKNSq7GcPuXFbnyMOCHxX8V3OgIg/pYuabl2sbUPfIJaeAQB7PMOK8DFIdoRA==} engines: {node: '>=12'} - css-declaration-sorter@7.2.0: - resolution: {integrity: sha512-h70rUM+3PNFuaBDTLe8wF/cdWu+dOZmb7pJt8Z2sedYbAcQVQV/tEchueg3GWxwqS0cxtbxmaHEdkNACqcvsow==} + css-blank-pseudo@7.0.1: + resolution: {integrity: sha512-jf+twWGDf6LDoXDUode+nc7ZlrqfaNphrBIBrcmeP3D8yw1uPaix1gCC8LUQUGQ6CycuK2opkbFFWFuq/a94ag==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + css-declaration-sorter@7.3.0: + resolution: {integrity: sha512-LQF6N/3vkAMYF4xoHLJfG718HRJh34Z8BnNhd6bosOMIVjMlhuZK5++oZa3uYAgrI5+7x2o27gUqTR2U/KjUOQ==} engines: {node: ^14 || ^16 || >=18} peerDependencies: postcss: ^8.0.9 + css-has-pseudo@7.0.3: + resolution: {integrity: sha512-oG+vKuGyqe/xvEMoxAQrhi7uY16deJR3i7wwhBerVrGQKSqUC5GiOVxTpM9F9B9hw0J+eKeOWLH7E9gZ1Dr5rA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + css-loader@6.11.0: resolution: {integrity: sha512-CTJ+AEQJjq5NzLga5pE39qdiSV56F8ywCIsqNIRF0r7BDgWsN25aazToqAFg7ZrtA/U016xudB3ffgweORxX7g==} engines: {node: '>= 12.13.0'} @@ -1982,11 +2279,17 @@ packages: lightningcss: optional: true + css-prefers-color-scheme@10.0.0: + resolution: {integrity: sha512-VCtXZAWivRglTZditUfB4StnsWr6YVZ2PRtuxQLKTNRdtAf8tpzaVPE9zXIF3VaSc7O70iK/j1+NXxyQCqdPjQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + css-select@4.3.0: resolution: {integrity: sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==} - css-select@5.1.0: - resolution: {integrity: sha512-nwoRF1rvRRnnCqqY7updORDsuqKzqYJ28+oSMaJMMgOauh3fvwHqMS7EZpIPqK8GL+g9mKxF1vP/ZjSeNjEVHg==} + css-select@5.2.2: + resolution: {integrity: sha512-TizTzUddG/xYLA3NXodFM0fSbNizXjOKhqiQQwvhlspadZokn1KDy0NZFS0wuEubIYAV5/c1/lAr0TaaFXEXzw==} css-tree@2.2.1: resolution: {integrity: sha512-OA0mILzGc1kCOCSJerOeqDxDQ4HOh+G8NbOJFOTgOCzpw7fCBubk0fEyxp8AgOL/jvLgYA/uV0cMbe43ElF1JA==} @@ -1996,10 +2299,13 @@ packages: resolution: {integrity: sha512-6Fv1DV/TYw//QF5IzQdqsNDjx/wc8TrMBZsqjL9eW01tWb7R7k/mq+/VXfJCl7SoD5emsJop9cOByJZfs8hYIw==} engines: {node: ^10 || ^12.20.0 || ^14.13.0 || >=15.0.0} - css-what@6.1.0: - resolution: {integrity: sha512-HTUrgRJ7r4dsZKU6GjmpfRK1O76h97Z8MfS1G0FozR+oF2kG6Vfe8JE6zwrkbxigziPHinCJ+gCPjA9EaBDtRw==} + css-what@6.2.2: + resolution: {integrity: sha512-u/O3vwbptzhMs3L1fQE82ZSLHQQfto5gyZzwteVIEyeaY5Fc7R4dapF/BvRoSYFeqfBk4m0V1Vafq5Pjv25wvA==} engines: {node: '>= 6'} + cssdb@8.4.2: + resolution: {integrity: sha512-PzjkRkRUS+IHDJohtxkIczlxPPZqRo0nXplsYXOMBRPjcVRjj1W4DfvRgshUYTVuUigU7ptVYkFJQ7abUB0nyg==} + cssesc@3.0.0: resolution: {integrity: sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==} engines: {node: '>=4'} @@ -2047,8 +2353,8 @@ packages: supports-color: optional: true - debug@4.3.5: - resolution: {integrity: sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==} + debug@4.4.3: + resolution: {integrity: sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==} engines: {node: '>=6.0'} peerDependencies: supports-color: '*' @@ -2056,8 +2362,8 @@ packages: supports-color: optional: true - decode-named-character-reference@1.0.2: - resolution: {integrity: sha512-O8x12RzrUF8xyVcY0KJowWsmaJxQbmy0/EtnNtHRpsOcT7dFk5W598coHqBVpmWo1oQQfsCqfCmkZN5DJrZVdg==} + decode-named-character-reference@1.2.0: + resolution: {integrity: sha512-c6fcElNV6ShtZXmsgNgFFV5tVX2PaV4g+MOAkb8eXHvn6sryJBrZa9r0zV6+dtTyoCKxtDy5tyQ5ZwQuidtd+Q==} decompress-response@6.0.0: resolution: {integrity: sha512-aW35yZM6Bb/4oJlZncMH2LCoZtJXTRxES17vE3hoRiowU2kWHaJKFkSBDnDR+cm9J+9QhXmREyIfv0pji9ejCQ==} @@ -2071,9 +2377,13 @@ packages: resolution: {integrity: sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==} engines: {node: '>=0.10.0'} - default-gateway@6.0.3: - resolution: {integrity: sha512-fwSOJsbbNzZ/CUFpqFBqYfYNLj1NbMPm8MMCIzHjC83iSJRBEGmDUxU+WP661BaBQImeC2yHwXtz+P/O9o+XEg==} - engines: {node: '>= 10'} + default-browser-id@5.0.0: + resolution: {integrity: sha512-A6p/pu/6fyBcA1TRz/GqWYPViplrftcW2gZC9q79ngNCKAeR/X3gcEdXQHl4KNXV+3wgIJ1CPkJQ3IHM6lcsyA==} + engines: {node: '>=18'} + + default-browser@5.2.1: + resolution: {integrity: sha512-WY/3TUME0x3KPYdRRxEJJvXRHV4PyPoUsxtZa78lwItwRQRHhd2U9xOscaT/YTf8uCXIAjeJOFBVEh/7FtD8Xg==} + engines: {node: '>=18'} defer-to-connect@2.0.1: resolution: {integrity: sha512-4tvttepXG1VaYGrRibk5EwJd1t4udunSOVMdLSAL6mId1ix438oPwPZMALY41FCijukO1L0twNcGsdzS7dHgDg==} @@ -2087,14 +2397,14 @@ packages: resolution: {integrity: sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==} engines: {node: '>=8'} + define-lazy-prop@3.0.0: + resolution: {integrity: sha512-N+MeXYoqr3pOgn8xfyRPREN7gHakLYjhsHhWGT3fWAiL4IkAt0iDw14QiiEm2bE30c5XX5q0FtAA3CK5f9/BUg==} + engines: {node: '>=12'} + define-properties@1.2.1: resolution: {integrity: sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==} engines: {node: '>= 0.4'} - del@6.1.1: - resolution: {integrity: sha512-ua8BhapfP0JUJKC/zV9yHHDW/rDoDxP4Zhn3AkA6/xT6gY7jYXJiaeyBZznYVujhZZET+UgcbZiQ7sN3WqcImg==} - engines: {node: '>=10'} - depd@1.1.2: resolution: {integrity: sha512-7emPTl6Dpo6JRXOXjLRxck+FlLRX5847cLKEn00PLAgc3g2hTZZgr+e4c2v6QpSmLeFP3n5yUo7ft6avBK/5jQ==} engines: {node: '>= 0.6'} @@ -2114,11 +2424,6 @@ packages: detect-node@2.1.0: resolution: {integrity: sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==} - detect-port-alt@1.1.6: - resolution: {integrity: sha512-5tQykt+LqfJFBEYaDITx7S7cR7mJ/zQmLXZ2qt5w04ainYZw6tBf9dBunMjVeVOdYVRUzUOE4HkY5J7+uttb5Q==} - engines: {node: '>= 4.2.1'} - hasBin: true - detect-port@1.6.1: resolution: {integrity: sha512-CmnVc+Hek2egPx1PeTFVta2W78xy2K/9Rkf6cC4T59S50tVnzKj+tnx5mmx5lwvCkujZ4uRrpRSuV+IVs3f90Q==} engines: {node: '>= 4.0.0'} @@ -2164,8 +2469,8 @@ packages: domutils@2.8.0: resolution: {integrity: sha512-w96Cjofp72M5IIhpjgobBimYEfoPjx1Vx0BSX9P30WBdZW2WIKU0T1Bd0kz2eNZ9ikjKgHbEyKx8BB6H1L3h3A==} - domutils@3.1.0: - resolution: {integrity: sha512-H78uMmQtI2AhgDJjWeQmHwJJ2bLPD3GMmO7Zja/ZZh84wkm+4ut+IUnUdRa8uCGX88DiVx1j6FRe1XfxEgjEZA==} + domutils@3.2.2: + resolution: {integrity: sha512-6kZKyUajlDuqlHKVX1w7gyslj9MPIXzIFiz/rGu35uC1wMi+kMhQwGhl4lt9unC9Vb9INnY9Z3/ZA3+FhASLaw==} dot-case@3.0.4: resolution: {integrity: sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==} @@ -2174,6 +2479,10 @@ packages: resolution: {integrity: sha512-tE7ztYzXHIeyvc7N+hR3oi7FIbf/NIjVP9hmAt3yMXzrQ072/fpjGLx2GxNxGxUl5V73MEqYzioOMoVhGMJ5cA==} engines: {node: '>=10'} + dunder-proto@1.0.1: + resolution: {integrity: sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==} + engines: {node: '>= 0.4'} + duplexer@0.1.2: resolution: {integrity: sha512-jtD6YG370ZCIi/9GTaJKQxWTZD045+4R4hTk/x1UyoqadyJ9x9CgSi1RlVDQF8U2sxLLSnFkCaMihqljHIWgMg==} @@ -2183,8 +2492,8 @@ packages: ee-first@1.1.1: resolution: {integrity: sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==} - electron-to-chromium@1.4.810: - resolution: {integrity: sha512-Kaxhu4T7SJGpRQx99tq216gCq2nMxJo+uuT6uzz9l8TVN2stL7M06MIIXAtr9jsrLs2Glflgf2vMQRepxawOdQ==} + electron-to-chromium@1.5.227: + resolution: {integrity: sha512-ITxuoPfJu3lsNWUi2lBM2PaBPYgH3uqmxut5vmBxgYvyI4AlJ6P3Cai1O76mOrkJCBzq0IxWg/NtqOrpu/0gKA==} emoji-regex@8.0.0: resolution: {integrity: sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==} @@ -2199,15 +2508,22 @@ packages: resolution: {integrity: sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==} engines: {node: '>= 4'} - emoticon@4.0.1: - resolution: {integrity: sha512-dqx7eA9YaqyvYtUhJwT4rC1HIp82j5ybS1/vQ42ur+jBe17dJMwZE4+gvL1XadSFfxaPFFGt3Xsw+Y8akThDlw==} + emoticon@4.1.0: + resolution: {integrity: sha512-VWZfnxqwNcc51hIy/sbOdEem6D+cVtpPzEEtVAFdaas30+1dgkyaOQ4sQ6Bp0tOMqWO1v+HQfYaoodOkdhK6SQ==} encodeurl@1.0.2: resolution: {integrity: sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==} engines: {node: '>= 0.8'} - enhanced-resolve@5.17.0: - resolution: {integrity: sha512-dwDPwZL0dmye8Txp2gzFmA6sxALaSvdRDjPH0viLcKrtlOL3tw62nWWweVD1SdILDTJrbrL6tdWVN58Wo6U3eA==} + encodeurl@2.0.0: + resolution: {integrity: sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==} + engines: {node: '>= 0.8'} + + encoding-sniffer@0.2.1: + resolution: {integrity: sha512-5gvq20T6vfpekVtqrYQsSCFZ1wEg5+wW0/QaZMWkFr6BqD3NfKs0rLCx4rrVlSWJeZb5NBJgVLswK/w2MWU+Gw==} + + enhanced-resolve@5.18.3: + resolution: {integrity: sha512-d4lC8xfavMeBjzGr2vECC3fsGXziXZQyJxD868h2M/mBI3PwAuODxAkLkq5HYuvrPYcUtiLzsTo8U3PgX3Ocww==} engines: {node: '>=10.13.0'} entities@2.2.0: @@ -2217,22 +2533,36 @@ packages: resolution: {integrity: sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==} engines: {node: '>=0.12'} - error-ex@1.3.2: - resolution: {integrity: sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==} + entities@6.0.1: + resolution: {integrity: sha512-aN97NXWF6AWBTahfVOIrB/NShkzi5H7F9r1s9mD3cDj4Ko5f2qhhVoYMibXF7GlLveb/D2ioWay8lxI97Ven3g==} + engines: {node: '>=0.12'} + + error-ex@1.3.4: + resolution: {integrity: sha512-sqQamAnR14VgCr1A618A3sGrygcpK+HEbenA/HiEAkkUwcZIIB/tgWqHFxWgOyDh4nB4JCRimh79dR5Ywc9MDQ==} - es-define-property@1.0.0: - resolution: {integrity: sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==} + es-define-property@1.0.1: + resolution: {integrity: sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==} engines: {node: '>= 0.4'} es-errors@1.3.0: resolution: {integrity: sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==} engines: {node: '>= 0.4'} - es-module-lexer@1.5.3: - resolution: {integrity: sha512-i1gCgmR9dCl6Vil6UKPI/trA69s08g/syhiDK9TG0Nf1RJjjFI+AzoWW7sPufzkgYAn861skuCwJa0pIIHYxvg==} + es-module-lexer@1.7.0: + resolution: {integrity: sha512-jEQoCwk8hyb2AZziIOLhDqpm5+2ww5uIE6lkO/6jcOCusfk6LhMHpXXfBLXTZ7Ydyt0j4VoUQv6uGNYbdW+kBA==} + + es-object-atoms@1.1.1: + resolution: {integrity: sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==} + engines: {node: '>= 0.4'} + + esast-util-from-estree@2.0.0: + resolution: {integrity: sha512-4CyanoAudUSBAn5K13H4JhsMH6L9ZP7XbLVe/dKybkxMO7eDyLsT8UHl9TRNrU2Gr9nz+FovfSIjuXWJ81uVwQ==} + + esast-util-from-js@2.0.1: + resolution: {integrity: sha512-8Ja+rNJ0Lt56Pcf3TAmpBZjmx8ZcK5Ts4cAzIOjsjevg9oSXJnl6SUQ2EevU8tv3h6ZLWmoKL5H4fgWvdvfETw==} - escalade@3.1.2: - resolution: {integrity: sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==} + escalade@3.2.0: + resolution: {integrity: sha512-WUj2qlxaQtO4g6Pq5c29GTcWGDyd8itL8zTlipgECz3JesAiiOKotd8JU6otB3PACgG6xkJUyVhboMS+bje/jA==} engines: {node: '>=6'} escape-goat@4.0.0: @@ -2284,11 +2614,14 @@ packages: estree-util-is-identifier-name@3.0.0: resolution: {integrity: sha512-hFtqIDZTIUZ9BXLb8y4pYGyk6+wekIivNVTcmvk8NoOh+VeRn5y6cEHzbURrWbfp1fIqdVipilzj+lfaadNZmg==} + estree-util-scope@1.0.0: + resolution: {integrity: sha512-2CAASclonf+JFWBNJPndcOpA8EMJwa0Q8LUFJEKqXLW6+qBvbFZuF5gItbQOs/umBUkjviCSDCbBwU2cXbmrhQ==} + estree-util-to-js@2.0.0: resolution: {integrity: sha512-WDF+xj5rRWmD5tj6bIqRi6CkLIXbbNQUcxQHzGysQzvHmdYG2G7p/Tf0J0gpxGgkeMZNTIjT/AoSvC9Xehcgdg==} - estree-util-value-to-estree@3.1.2: - resolution: {integrity: sha512-S0gW2+XZkmsx00tU2uJ4L9hUT7IFabbml9pHh2WQqFmAbxit++YGZne0sKJbNwkj9Wvg9E4uqWl4nCIFQMmfag==} + estree-util-value-to-estree@3.4.0: + resolution: {integrity: sha512-Zlp+gxis+gCfK12d3Srl2PdX2ybsEA8ZYy6vQGVQTNNYLEGRQQ56XB64bjemN8kxIKXP1nC9ip4Z+ILy9LGzvQ==} estree-util-visit@2.0.0: resolution: {integrity: sha512-m5KgiH85xAhhW8Wta0vShLcUvOsh3LLPI2YVwcbio1l7E09NTLL1EyMZFM1OyWowoH0skScNbhOPl4kcBgzTww==} @@ -2319,12 +2652,16 @@ packages: resolution: {integrity: sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==} engines: {node: '>=0.8.x'} + eventsource-parser@3.0.6: + resolution: {integrity: sha512-Vo1ab+QXPzZ4tCa8SwIHJFaSzy4R6SHf7BY79rFBDf0idraZWAkYrDjDj8uWaSm3S2TK+hJ7/t1CEmZ7jXw+pg==} + engines: {node: '>=18.0.0'} + execa@5.1.1: resolution: {integrity: sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==} engines: {node: '>=10'} - express@4.19.2: - resolution: {integrity: sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==} + express@4.21.2: + resolution: {integrity: sha512-28HqgMZAmih1Czt9ny7qr6ek2qddF4FclbMzwhCREB6OFfH+rXAnuNCwo1/wFvrtbgsQDb4kSbX9de9lFbrXnA==} engines: {node: '>= 0.10.0'} extend-shallow@2.0.1: @@ -2337,18 +2674,18 @@ packages: fast-deep-equal@3.1.3: resolution: {integrity: sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==} - fast-glob@3.3.2: - resolution: {integrity: sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==} + fast-glob@3.3.3: + resolution: {integrity: sha512-7MptL8U0cqcFdzIzwOTHoilX9x5BrNqye7Z/LuC7kCMRio1EMSyqRK3BEAUD7sXRq4iT4AzTVuZdhgQ2TCvYLg==} engines: {node: '>=8.6.0'} fast-json-stable-stringify@2.1.0: resolution: {integrity: sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==} - fast-url-parser@1.1.3: - resolution: {integrity: sha512-5jOCVXADYNuRkKFzNJ0dCCewsZiYo0dz8QNYljkOpFC6r2U4OBmKtvm/Tsuh4w1YYdDqDb31a8TVhBJ2OJKdqQ==} + fast-uri@3.1.0: + resolution: {integrity: sha512-iPeeDKJSWf4IEOasVVrknXpaBV0IApz/gp7S2bb7Z4Lljbl2MGJRqInZiUrQwV16cpzw/D3S5j5Julj/gT52AA==} - fastq@1.17.1: - resolution: {integrity: sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==} + fastq@1.19.1: + resolution: {integrity: sha512-GwLTyxkCXjXbxqIhTsMI2Nui8huMPtnxg7krajPJAjnEG/iiOS7i+zCtWGZR9G0NBKbXKh6X9m9UIsYX/N6vvQ==} fault@2.0.1: resolution: {integrity: sha512-WtySTkS4OKev5JtpHXnib4Gxiurzh5NCGvWrFaZ34m6JehfTUhKZvn9njTfw48t6JumVQOmrKqpmGcdwxnhqBQ==} @@ -2361,36 +2698,28 @@ packages: resolution: {integrity: sha512-u5/sxGfiMfZNtJ3OvQpXcvotFpYkL0n9u9mM2vkui2nGo8b4wvDkJ8gAkYqbA8QpGyFCv3RK0Z+Iv+9veCS9bQ==} engines: {node: '>=0.4.0'} + figures@3.2.0: + resolution: {integrity: sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==} + engines: {node: '>=8'} + file-loader@6.2.0: resolution: {integrity: sha512-qo3glqyTa61Ytg4u73GultjHGjdRyig3tG6lPtyX/jOEJvHif9uB0/OCI2Kif6ctF3caQTW2G5gym21oAsI4pw==} engines: {node: '>= 10.13.0'} peerDependencies: webpack: ^4.0.0 || ^5.0.0 - filesize@8.0.7: - resolution: {integrity: sha512-pjmC+bkIF8XI7fWaH8KxHcZL3DPybs1roSKP4rKDvy20tAWwIObE4+JIseG2byfGKhud5ZnM4YSGKBz7Sh0ndQ==} - engines: {node: '>= 0.4.0'} - fill-range@7.1.1: resolution: {integrity: sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==} engines: {node: '>=8'} - finalhandler@1.2.0: - resolution: {integrity: sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==} + finalhandler@1.3.1: + resolution: {integrity: sha512-6BN9trH7bp3qvnrRyzsBz+g3lZxTNZTbVO2EV1CS0WIcDbawYVdYvGflME/9QP0h0pYlCDBCTjYa9nZzMDpyxQ==} engines: {node: '>= 0.8'} find-cache-dir@4.0.0: resolution: {integrity: sha512-9ZonPT4ZAK4a+1pUPVPZJapbi7O5qbbJPdYw/NOQWZZbVLdDTYM3A4R9z/DpAM08IDaFGsvPgiGZ82WEwUDWjg==} engines: {node: '>=14.16'} - find-up@3.0.0: - resolution: {integrity: sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==} - engines: {node: '>=6'} - - find-up@5.0.0: - resolution: {integrity: sha512-78/PXT1wlLLDgTzDs7sjq9hzz0vXD+zn+7wypEe4fXQxCmdmqfGsEPQxmiCSQI3ajFV91bVSsvNtrJRiW6nGng==} - engines: {node: '>=10'} - find-up@6.3.0: resolution: {integrity: sha512-v2ZsoEuVHYy8ZIlYqwPe/39Cy+cFDzp4dXPaxNvkEuouymu+2Jbz0PxpKarJHYJTmv2HWT3O382qY8l4jMWthw==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} @@ -2399,8 +2728,8 @@ packages: resolution: {integrity: sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==} hasBin: true - follow-redirects@1.15.6: - resolution: {integrity: sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==} + follow-redirects@1.15.11: + resolution: {integrity: sha512-deG2P0JfjrTxl50XGCDyfI97ZGVCxIpfKYmfyrQ54n5FO/0gfIES8C/Psl6kWVDolizcaaxZJnTS0QSMxvnsBQ==} engines: {node: '>=4.0'} peerDependencies: debug: '*' @@ -2408,24 +2737,10 @@ packages: debug: optional: true - foreground-child@3.2.1: - resolution: {integrity: sha512-PXUUyLqrR2XCWICfv6ukppP96sdFwWbNEnfEMt7jNsISjMsvaLNinAHNDYyvkyU+SZG2BTSbT5NjG+vZslfGTA==} + foreground-child@3.3.1: + resolution: {integrity: sha512-gIXjKqtFuWEgzFRJA9WCQeSJLZDjgJUOMCMzxtvFq/37KojM1BFGufqsCy0r4qSQmYLsZYMeyRqzIWOMup03sw==} engines: {node: '>=14'} - fork-ts-checker-webpack-plugin@6.5.3: - resolution: {integrity: sha512-SbH/l9ikmMWycd5puHJKTkZJKddF4iRLyW3DeZ08HTI7NGyLS38MXd/KGgeWumQO7YNQbW2u/NtPT2YowbPaGQ==} - engines: {node: '>=10', yarn: '>=1.0.0'} - peerDependencies: - eslint: '>= 6' - typescript: '>= 2.7' - vue-template-compiler: '*' - webpack: '>= 4' - peerDependenciesMeta: - eslint: - optional: true - vue-template-compiler: - optional: true - form-data-encoder@2.1.4: resolution: {integrity: sha512-yDYSgNMraqvnxiEXO4hi88+YZxaHC6QKzb5N84iRCTDeRO7ZALpir/lVmf/uXUhnwUr2O4HU8s/n6x+yNjQkHw==} engines: {node: '>= 14.17'} @@ -2449,20 +2764,10 @@ packages: resolution: {integrity: sha512-oRXApq54ETRj4eMiFzGnHWGy+zo5raudjuxN0b8H7s/RU2oW0Wvsx9O0ACRN/kRq9E8Vu/ReskGB5o3ji+FzHQ==} engines: {node: '>=12'} - fs-extra@11.2.0: - resolution: {integrity: sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==} + fs-extra@11.3.2: + resolution: {integrity: sha512-Xr9F6z6up6Ws+NjzMCZc6WXg2YFRlrLP9NQDO3VQrWrfiojdhS56TzueT88ze0uBdCTwEIhQ3ptnmKeWGFAe0A==} engines: {node: '>=14.14'} - fs-extra@9.1.0: - resolution: {integrity: sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==} - engines: {node: '>=10'} - - fs-monkey@1.0.6: - resolution: {integrity: sha512-b1FMfwetIKymC0eioW7mTywihSQE4oLzQn1dB6rZB5fx/3NpNEdAWeCSMB+60/AeT0TCXsxzAlcYVEFCTAksWg==} - - fs.realpath@1.0.0: - resolution: {integrity: sha512-OO0pH2lK6a0hZnAdau5ItzHPI6pUlvI7jMVnxUQRtw4owF2wk8lOSabtGDCTP4Ggrg2MbGnWO9X8K1t4+fGMDw==} - fsevents@2.3.3: resolution: {integrity: sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==} engines: {node: ^8.16.0 || ^10.6.0 || >=11.0.0} @@ -2475,13 +2780,17 @@ packages: resolution: {integrity: sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==} engines: {node: '>=6.9.0'} - get-intrinsic@1.2.4: - resolution: {integrity: sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==} + get-intrinsic@1.3.0: + resolution: {integrity: sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ==} engines: {node: '>= 0.4'} get-own-enumerable-property-symbols@3.0.2: resolution: {integrity: sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==} + get-proto@1.0.1: + resolution: {integrity: sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g==} + engines: {node: '>= 0.4'} + get-stream@6.0.1: resolution: {integrity: sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==} engines: {node: '>=10'} @@ -2497,34 +2806,23 @@ packages: resolution: {integrity: sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A==} engines: {node: '>=10.13.0'} + glob-to-regex.js@1.0.1: + resolution: {integrity: sha512-CG/iEvgQqfzoVsMUbxSJcwbG2JwyZ3naEqPkeltwl0BSS8Bp83k3xlGms+0QdWFUAwV+uvo80wNswKF6FWEkKg==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' + glob-to-regexp@0.4.1: resolution: {integrity: sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==} - glob@10.4.2: - resolution: {integrity: sha512-GwMlUF6PkPo3Gk21UxkCohOv0PLcIXVtKyLlpEI28R/cO/4eNOdmLk3CMW1wROV/WR/EsZOWAfBbBOqYvs88/w==} - engines: {node: '>=16 || 14 >=14.18'} + glob@10.4.5: + resolution: {integrity: sha512-7Bv8RF0k6xjo7d4A/PxYLbUCfb6c+Vpd2/mB2yRDlew7Jb5hEXiCD9ibfO7wpk8i4sevK6DFny9h7EYbM3/sHg==} hasBin: true - glob@7.2.3: - resolution: {integrity: sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==} - deprecated: Glob versions prior to v9 are no longer supported - global-dirs@3.0.1: resolution: {integrity: sha512-NBcGGFbBA9s1VzD41QXDG+3++t9Mn5t1FpLdhESY6oKY4gYTFpX4wO3sqGUa0Srjtbfj3szX0RnemmrVRUdULA==} engines: {node: '>=10'} - global-modules@2.0.0: - resolution: {integrity: sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A==} - engines: {node: '>=6'} - - global-prefix@3.0.0: - resolution: {integrity: sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==} - engines: {node: '>=6'} - - globals@11.12.0: - resolution: {integrity: sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==} - engines: {node: '>=4'} - globby@11.1.0: resolution: {integrity: sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==} engines: {node: '>=10'} @@ -2533,8 +2831,9 @@ packages: resolution: {integrity: sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - gopd@1.0.1: - resolution: {integrity: sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==} + gopd@1.2.0: + resolution: {integrity: sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==} + engines: {node: '>= 0.4'} got@12.6.1: resolution: {integrity: sha512-mThBblvlAF1d4O5oqyvN+ZxLAYwIJK7bpMxgYqPD9okW0C3qm5FFn7k811QrcuEBwaogR3ngOFoCfs6mRv7teQ==} @@ -2557,10 +2856,6 @@ packages: handle-thing@2.0.1: resolution: {integrity: sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==} - has-flag@3.0.0: - resolution: {integrity: sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==} - engines: {node: '>=4'} - has-flag@4.0.0: resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==} engines: {node: '>=8'} @@ -2568,12 +2863,8 @@ packages: has-property-descriptors@1.0.2: resolution: {integrity: sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==} - has-proto@1.0.3: - resolution: {integrity: sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==} - engines: {node: '>= 0.4'} - - has-symbols@1.0.3: - resolution: {integrity: sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==} + has-symbols@1.1.0: + resolution: {integrity: sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==} engines: {node: '>= 0.4'} has-yarn@3.0.0: @@ -2584,20 +2875,20 @@ packages: resolution: {integrity: sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==} engines: {node: '>= 0.4'} - hast-util-from-parse5@8.0.1: - resolution: {integrity: sha512-Er/Iixbc7IEa7r/XLtuG52zoqn/b3Xng/w6aZQ0xGVxzhw5xUFxcRqdPzP6yFi/4HBYRaifaI5fQ1RH8n0ZeOQ==} + hast-util-from-parse5@8.0.3: + resolution: {integrity: sha512-3kxEVkEKt0zvcZ3hCRYI8rqrgwtlIOFMWkbclACvjlDw8Li9S2hk/d51OI0nr/gIpdMHNepwgOKqZ/sy0Clpyg==} hast-util-parse-selector@4.0.0: resolution: {integrity: sha512-wkQCkSYoOGCRKERFWcxMVMOcYE2K1AaNLU8DXS9arxnLOUEWbOXKXiJUNzEpqZ3JOKpnha3jkFrumEjVliDe7A==} - hast-util-raw@9.0.4: - resolution: {integrity: sha512-LHE65TD2YiNsHD3YuXcKPHXPLuYh/gjp12mOfU8jxSrm1f/yJpsb0F/KKljS6U9LJoP0Ux+tCe8iJ2AsPzTdgA==} + hast-util-raw@9.1.0: + resolution: {integrity: sha512-Y8/SBAHkZGoNkpzqqfCldijcuUKh7/su31kEBp67cFY09Wy0mTRgtsLYsiIxMJxlu0f6AA5SUTbDR8K0rxnbUw==} - hast-util-to-estree@3.1.0: - resolution: {integrity: sha512-lfX5g6hqVh9kjS/B9E2gSkvHH4SZNiQFiqWS0x9fENzEl+8W12RqdRxX6d/Cwxi30tPQs3bIO+aolQJNp1bIyw==} + hast-util-to-estree@3.1.3: + resolution: {integrity: sha512-48+B/rJWAp0jamNbAAf9M7Uf//UVqAoMmgXhBdxTDJLGKY+LRnZ99qcG+Qjl5HfMpYNzS5v4EAwVEF34LeAj7w==} - hast-util-to-jsx-runtime@2.3.0: - resolution: {integrity: sha512-H/y0+IWPdsLLS738P8tDnrQ8Z+dj12zQQ6WC11TIM21C8WFVoIxcqWXf2H3hiTVZjF1AWqoimGwrTWecWrnmRQ==} + hast-util-to-jsx-runtime@2.3.6: + resolution: {integrity: sha512-zl6s8LwNyo1P9uw+XJGvZtdFF1GdAkOg8ujOw+4Pyb76874fLps4ueHXDhXWdk6YHQ6OgUtinliG7RsYvCbbBg==} hast-util-to-parse5@8.0.0: resolution: {integrity: sha512-3KKrV5ZVI8if87DVSi1vDeByYrkGzg4mEfeu4alwgmmIeARiBLKCZS2uw5Gb6nU9x9Yufyj3iudm6i7nl52PFw==} @@ -2605,8 +2896,8 @@ packages: hast-util-whitespace@3.0.0: resolution: {integrity: sha512-88JUN06ipLwsnv+dVn+OIYOvAuvBMy/Qoi6O7mQHxdPXpjy+Cd6xRkWwux7DKO+4sYILtLBRIKgsdpS2gQc7qw==} - hastscript@8.0.0: - resolution: {integrity: sha512-dMOtzCEd3ABUeSIISmrETiKuyydk1w0pa+gE/uormcTpSYuaNJPbX1NU3JLyscSLjwAQM8bWMhhIlnCqnRvDTw==} + hastscript@9.0.1: + resolution: {integrity: sha512-g7df9rMFX/SPi34tyGCyUBREQoKkapwdY/T04Qn9TDWfHhAYt4/I0gMVirzK5wEzeUqIjEB+LXC/ypb7Aqno5w==} he@1.2.0: resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} @@ -2621,9 +2912,6 @@ packages: hpack.js@2.1.6: resolution: {integrity: sha512-zJxVehUdMGIKsRaNt7apO2Gqp0BdqW5yaiGHXXmbpvxgBYVZnAql+BJb4RO5ad2MgpbZKn5G6nMnegrH1FcNYQ==} - html-entities@2.5.2: - resolution: {integrity: sha512-K//PSRMQk4FZ78Kyau+mZurHn3FH0Vwr+H36eE0rPbeYkRRi9YxceYPhuN60UwWorxyKHhqoAJl2OFKa4BVtaA==} - html-escaper@2.0.2: resolution: {integrity: sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==} @@ -2644,8 +2932,8 @@ packages: html-void-elements@3.0.0: resolution: {integrity: sha512-bEqo66MRXsUGxWHV5IP0PUiAWwoEjba4VCzg0LjFJBpchPaTfyfCKTG6bc5F8ucKec3q5y6qOdGyYTSBEvhCrg==} - html-webpack-plugin@5.6.0: - resolution: {integrity: sha512-iwaY4wzbe48AfKLZ/Cc8k0L+FKG6oSNRaZ8x5A/T/IVDGyXcbHncM9TdDa93wn0FsSm82FhTKW7f3vS61thXAw==} + html-webpack-plugin@5.6.4: + resolution: {integrity: sha512-V/PZeWsqhfpE27nKeX9EO2sbR+D17A+tLf6qU+ht66jdUsN0QLKJN27Z+1+gHrVMKgndBahes0PU6rRihDgHTw==} engines: {node: '>=10.13.0'} peerDependencies: '@rspack/core': 0.x || 1.x @@ -2656,14 +2944,17 @@ packages: webpack: optional: true + htmlparser2@10.0.0: + resolution: {integrity: sha512-TwAZM+zE5Tq3lrEHvOlvwgj1XLWQCtaaibSN11Q+gGBAS7Y1uZSWwXXRe4iF6OXnaq1riyQAPFOBtYc77Mxq0g==} + htmlparser2@6.1.0: resolution: {integrity: sha512-gyyPk6rgonLFEDGoeRgQNaEUvdJ4ktTmmUh/h2t7s+M8oPpIPxgNACWa+6ESR57kXstwqPiCut0V8NRpcwgU7A==} htmlparser2@8.0.2: resolution: {integrity: sha512-GYdjWKDkbRLkZ5geuHs5NY1puJ+PXwP7+fHPRz06Eirsb9ugf6d8kkXav6ADhcODhFFPMIXyxkxSuMf3D6NCFA==} - http-cache-semantics@4.1.1: - resolution: {integrity: sha512-er295DKPVsV82j5kw1Gjt+ADA/XYHsajl82cGNQG2eyoPkvgUhX+nDIyelzhIWbbsXP39EHcI6l5tYs2FYqYXQ==} + http-cache-semantics@4.2.0: + resolution: {integrity: sha512-dTxcvPXqPvXBQpq5dUr6mEMJX4oIEFv6bwom3FDwKRDsuIjjJGANqhBuoAn9c1RQJIdAKav33ED65E2ys+87QQ==} http-deceiver@1.2.7: resolution: {integrity: sha512-LmpOGxTfbpgtGVxJrj5k7asXHCgNZp5nLfp+hWc8QQRqtb7fUy6kRY3BO1h9ddF6yIPYUARgxGOwB42DnxIaNw==} @@ -2676,11 +2967,11 @@ packages: resolution: {integrity: sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==} engines: {node: '>= 0.8'} - http-parser-js@0.5.8: - resolution: {integrity: sha512-SGeBX54F94Wgu5RH3X5jsDtf4eHyRogWX1XGT3b4HuW3tQPM4AaBzoUji/4AAJNXCEOWZ5O0DgZmJw1947gD5Q==} + http-parser-js@0.5.10: + resolution: {integrity: sha512-Pysuw9XpUq5dVc/2SMHpuTY01RFl8fttgcyunjL7eEMhGM3cI4eOmiCycJDVCo/7O7ClfQD3SaI6ftDzqOXYMA==} - http-proxy-middleware@2.0.6: - resolution: {integrity: sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw==} + http-proxy-middleware@2.0.9: + resolution: {integrity: sha512-c1IyJYLYppU574+YI7R4QyX2ystMtVXZwIdzazUIPIJsHuWNd+mho2j+bKoHftndicGj9yh+xjd+l0yj7VeT1Q==} engines: {node: '>=12.0.0'} peerDependencies: '@types/express': ^4.17.13 @@ -2700,33 +2991,38 @@ packages: resolution: {integrity: sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==} engines: {node: '>=10.17.0'} + hyperdyperid@1.2.0: + resolution: {integrity: sha512-Y93lCzHYgGWdrJ66yIktxiaGULYc6oGiABxhcO5AufBeOyoIdZF7bIfLaOrbM0iGIOXQQgxxRrFEnb+Y6w1n4A==} + engines: {node: '>=10.18'} + iconv-lite@0.4.24: resolution: {integrity: sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==} engines: {node: '>=0.10.0'} + iconv-lite@0.6.3: + resolution: {integrity: sha512-4fCk79wshMdzMp2rH06qWrJE4iolqLhCUH+OiuIgU++RB0+94NlDL81atO7GX55uUKueo0txHNtvEyI6D7WdMw==} + engines: {node: '>=0.10.0'} + icss-utils@5.1.0: resolution: {integrity: sha512-soFhflCVWLfRNOPU3iv5Z9VUdT44xFRbzjLsEzSr5AQmgqPMTHdU3PMT1Cf1ssx8fLNJDA1juftYl+PUcv3MqA==} engines: {node: ^10 || ^12 || >= 14} peerDependencies: postcss: ^8.1.0 - ignore@5.3.1: - resolution: {integrity: sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==} + ignore@5.3.2: + resolution: {integrity: sha512-hsBTNUqQTDwkWtcdYI2i06Y/nUBEsNEDJKjWdigLvegy8kDuJAS8uRlpkkcQpyEXL0Z/pjDy5HBmMjRCJ2gq+g==} engines: {node: '>= 4'} - image-size@1.1.1: - resolution: {integrity: sha512-541xKlUw6jr/6gGuk92F+mYM5zaFAc5ahphvkqvNe2bQ6gVBkd6bfrmVJ2t4KDAfikAYZyIqTnktX3i6/aQDrQ==} + image-size@2.0.2: + resolution: {integrity: sha512-IRqXKlaXwgSMAMtpNzZa1ZAe8m+Sa1770Dhk8VkSsP9LS+iHD62Zd8FQKs8fbPiagBE7BzoFX23cxFnwshpV6w==} engines: {node: '>=16.x'} hasBin: true immediate@3.3.0: resolution: {integrity: sha512-HR7EVodfFUdQCTIeySw+WDRFJlPcLOJbXfwwZ7Oom6tjsvZ3bOkCDJHehQC3nxJrv7+f9XecwazynjU8e4Vw3Q==} - immer@9.0.21: - resolution: {integrity: sha512-bc4NBHqOqSfRW7POMkHd51LvClaeMXpm8dx0e8oE2GORbq5aRK7Bxl4FyzVLdGtLmvLKL7BTDBG5ACQm4HWjTA==} - - import-fresh@3.3.0: - resolution: {integrity: sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw==} + import-fresh@3.3.1: + resolution: {integrity: sha512-TR3KfrTZTYLPB6jUjfx6MF9WcWrHL9su5TObK4ZkYgBdWKPOFoSoQIdEuTuR82pmtxH2spWG9h6etwfr1pLBqQ==} engines: {node: '>=6'} import-lazy@4.0.0: @@ -2741,14 +3037,10 @@ packages: resolution: {integrity: sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==} engines: {node: '>=8'} - infima@0.2.0-alpha.43: - resolution: {integrity: sha512-2uw57LvUqW0rK/SWYnd/2rRfxNA5DDNOh33jxF7fy46VWoNhGxiUQyVZHbBMjQ33mQem0cjdDVwgWVAmlRfgyQ==} + infima@0.2.0-alpha.45: + resolution: {integrity: sha512-uyH0zfr1erU1OohLk0fT4Rrb94AOhguWNOcD9uGrSpRvNB+6gZXUoJX5J0NtvzBO10YZ9PgvA4NFgt+fYg8ojw==} engines: {node: '>=12'} - inflight@1.0.6: - resolution: {integrity: sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==} - deprecated: This module is not supported, and leaks memory. Do not use it. Check out lru-cache if you want a good and tested way to coalesce async requests by a key value, which is much more comprehensive and powerful. - inherits@2.0.3: resolution: {integrity: sha512-x00IRNXNy63jwGkJmzPigoySHbaqpNuzKbBOmzK+g2OdZpQ9w+sxCN+VSB3ja7IAge2OP2qpfxTjeNcyjmW1uw==} @@ -2762,15 +3054,8 @@ packages: resolution: {integrity: sha512-7PnF4oN3CvZF23ADhA5wRaYEQpJ8qygSkbtTXWBeXWXmEVRXK+1ITciHWwHhsjv1TmW0MgacIv6hEi5pX5NQdA==} engines: {node: '>=10'} - inline-style-parser@0.1.1: - resolution: {integrity: sha512-7NXolsK4CAS5+xvdj5OMMbI962hU/wvwoxk+LWR9Ek9bVtyuuYScDN6eS0rUm6TxApFpw7CX1o4uJzcd4AyD3Q==} - - inline-style-parser@0.2.3: - resolution: {integrity: sha512-qlD8YNDqyTKTyuITrDOffsl6Tdhv+UC4hcdAVuQsK4IMQ99nSgd1MIA/Q+jQYoh9r3hVUXhYh7urSRmXPkW04g==} - - interpret@1.4.0: - resolution: {integrity: sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA==} - engines: {node: '>= 0.10'} + inline-style-parser@0.2.4: + resolution: {integrity: sha512-0aO8FkhNZlj/ZIbNi7Lxxr12obT7cL1moPfE4tg1LkX7LlLfC6DeX4l2ZEud1ukP9jNQyNnfzQVqwbwmAATY4Q==} invariant@2.2.4: resolution: {integrity: sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==} @@ -2800,8 +3085,8 @@ packages: resolution: {integrity: sha512-ZYvCgrefwqoQ6yTyYUbQu64HsITZ3NfKX1lzaEYdkTDcfKzzCI/wthRRYKkdjHKFVgNiXKAKm65Zo1pk2as/QQ==} hasBin: true - is-core-module@2.14.0: - resolution: {integrity: sha512-a5dFJih5ZLYlRtDc0dZWP7RiKr6xIKzmn/oAYCDvdLThadVgyJwlaoQPmRtMSpz+rk0OGAgIu+TcM9HUF0fk1A==} + is-core-module@2.16.1: + resolution: {integrity: sha512-UfoeMA6fIJ8wTYFEUjelnaGI67v6+N7qXJEvQuIGa99l4xsCruSYOVSQ0uPANn4dAzm8lkYPaKLrrijLq7x23w==} engines: {node: '>= 0.4'} is-decimal@2.0.1: @@ -2812,6 +3097,11 @@ packages: engines: {node: '>=8'} hasBin: true + is-docker@3.0.0: + resolution: {integrity: sha512-eljcgEDlEns/7AXFosB5K/2nCM4P7FQPkGc/DWLy5rmFEWvZayGrik1d9/QIY5nJ4f9YsVvBkA6kJpHn9rISdQ==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + hasBin: true + is-extendable@0.1.1: resolution: {integrity: sha512-5BMULNob1vgFX6EjQw5izWDxrecWK9AM72rugNr0TFldMOi0fj6Jk+zeKIt0xGj4cEfQIJth4w3OKWOJ4f+AFw==} engines: {node: '>=0.10.0'} @@ -2831,12 +3121,21 @@ packages: is-hexadecimal@2.0.1: resolution: {integrity: sha512-DgZQp241c8oO6cA1SbTEWiXeoxV42vlcJxgH+B3hi1AiqqKruZR3ZGF8In3fj4+/y/7rHvlOZLZtgJ/4ttYGZg==} + is-inside-container@1.0.0: + resolution: {integrity: sha512-KIYLCCJghfHZxqjYBE7rEy0OBuTd5xCHS7tHVgvCLkx7StIoaxwNW3hCALgEUjFfeRk+MG/Qxmp/vtETEF3tRA==} + engines: {node: '>=14.16'} + hasBin: true + is-installed-globally@0.4.0: resolution: {integrity: sha512-iwGqO3J21aaSkC7jWnHP/difazwS7SFeIqxv6wEtLU8Y5KlzFTjyqcSIT0d8s4+dDhKytsk9PJZ2BkS5eZwQRQ==} engines: {node: '>=10'} - is-npm@6.0.0: - resolution: {integrity: sha512-JEjxbSmtPSt1c8XTkVrlujcXdKV1/tvuQ7GwKcAlyiVLeYFQ2VHat8xfrDJsIkhCdF/tZ7CiIR3sy141c6+gPQ==} + is-network-error@1.3.0: + resolution: {integrity: sha512-6oIwpsgRfnDiyEDLMay/GqCl3HoAtH5+RUKW29gYkL0QA+ipzpDLA16yQs7/RHCSu+BwgbJaOUqa4A99qNVQVw==} + engines: {node: '>=16'} + + is-npm@6.1.0: + resolution: {integrity: sha512-O2z4/kNgyjhQwVR1Wpkbfc19JIhggF97NZNCpWTnjH7kVcZMUrnut9XSN7txI7VdyIYk5ZatOq3zvSuWpU8hoA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} is-number@7.0.0: @@ -2851,10 +3150,6 @@ packages: resolution: {integrity: sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==} engines: {node: '>=8'} - is-path-cwd@2.2.0: - resolution: {integrity: sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==} - engines: {node: '>=6'} - is-path-inside@3.0.3: resolution: {integrity: sha512-Fd4gABb+ycGAmKou8eMftCupSir5lRxqf4aD/vd0cD2qc4HL07OjCeuHMr8Ro4CoMaeCKDB0/ECBOVWjTwUvPQ==} engines: {node: '>=8'} @@ -2871,17 +3166,10 @@ packages: resolution: {integrity: sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==} engines: {node: '>=0.10.0'} - is-reference@3.0.2: - resolution: {integrity: sha512-v3rht/LgVcsdZa3O2Nqs+NMowLOxeOm7Ay9+/ARQ2F+qEoANRcqrjAZKGN0v8ymUetZGgkp26LTnGT7H0Qo9Pg==} - is-regexp@1.0.0: resolution: {integrity: sha512-7zjFAPO4/gwyQAAgRRmqeEeyIICSdmCqa3tsVHMdBzaXXRiqopZL4Cyghg/XulGWrtABTpbnYYzzIRffLkP4oA==} engines: {node: '>=0.10.0'} - is-root@2.1.0: - resolution: {integrity: sha512-AGOriNp96vNBd3HtU+RzFEc75FfR5ymiYv8E553I71SCeXBiMsVDUtdio1OEFvrPyLIQ9tVR5RxXIFe5PUFjMg==} - engines: {node: '>=6'} - is-stream@2.0.1: resolution: {integrity: sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==} engines: {node: '>=8'} @@ -2893,6 +3181,10 @@ packages: resolution: {integrity: sha512-fKzAra0rGJUUBwGBgNkHZuToZcn+TtXHpeCgmkMJMMYx1sQDYaCSyjJBSCa2nH1DGm7s3n1oBnohoVTBaN7Lww==} engines: {node: '>=8'} + is-wsl@3.1.0: + resolution: {integrity: sha512-UcVfVfaK4Sc4m7X3dUSoHoozQGBEFeDC+zVo06t98xe8CzHSZZBekNXH+tu0NalHolcJ/QAGqS46Hef7QXBIMw==} + engines: {node: '>=16'} + is-yarn-global@0.4.1: resolution: {integrity: sha512-/kppl+R+LO5VmhYSEWARUFjodS25D68gvj8W7z0I7OWhUla5xWu8KL6CtB2V0R6yqhnRgbcaREMr4EEM6htLPQ==} engines: {node: '>=12'} @@ -2910,9 +3202,8 @@ packages: resolution: {integrity: sha512-WhB9zCku7EGTj/HQQRz5aUQEUeoQZH2bWcltRErOpymJ4boYE6wL9Tbr23krRPSZ+C5zqNSrSw+Cc7sZZ4b7vg==} engines: {node: '>=0.10.0'} - jackspeak@3.4.0: - resolution: {integrity: sha512-JVYhQnN59LVPFCEcVa2C3CrEKYacvjRfqIQl+h8oi91aLYQVWRYbxjPcv1bUiUy/kLmQaANrYfNMCO3kuEDHfw==} - engines: {node: '>=14'} + jackspeak@3.4.3: + resolution: {integrity: sha512-OGlZQpz2yfahA/Rd1Y8Cd9SIEsqvXkLVoSw/cgwhnhFMDbsQFeZYoJJ7bIZBS9BcamUW96asq/npPWugM+RQBw==} jest-util@29.7.0: resolution: {integrity: sha512-z6EbKajIpqGKU56y5KBUgy1dt1ihhQJgWzUlZHArA/+X2ad7Cb5iF+AK1EWVL/Bo7Rz9uurpqw6SiBCefUbCGA==} @@ -2926,8 +3217,8 @@ packages: resolution: {integrity: sha512-eIz2msL/EzL9UFTFFx7jBTkeZfku0yUAyZZZmJ93H2TYEiroIx2PQjEXcwYtYl8zXCxb+PAmA2hLIt/6ZEkPHw==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} - jiti@1.21.6: - resolution: {integrity: sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==} + jiti@1.21.7: + resolution: {integrity: sha512-/imKNG4EbWNrVjoNC/1H5/9GFy+tqjGBHCaSsN+P2RnPqjsLmv6UD3Ej+Kj8nBWaRAwyk7kK5ZUc+OEatnTR3A==} hasBin: true joi@17.13.3: @@ -2944,13 +3235,9 @@ packages: resolution: {integrity: sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==} hasBin: true - jsesc@0.5.0: - resolution: {integrity: sha512-uZz5UnB7u4T9LvwmFqXii7pZSouaRPorGs5who1Ip7VO0wxanFvBL7GkM6dTHlgX+jhBApRetaWpnDabOeTcnA==} - hasBin: true - - jsesc@2.5.2: - resolution: {integrity: sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==} - engines: {node: '>=4'} + jsesc@3.1.0: + resolution: {integrity: sha512-/sM3dO2FOzXjKQhJuo0Q173wf2KOo8t4I8vHy6lF9poUp7bKT0/NHE8fPX23PwfhnykfqnC2xRxOnVw5XuGIaA==} + engines: {node: '>=6'} hasBin: true json-buffer@3.0.1: @@ -2965,13 +3252,16 @@ packages: json-schema-traverse@1.0.0: resolution: {integrity: sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==} + json-schema@0.4.0: + resolution: {integrity: sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==} + json5@2.2.3: resolution: {integrity: sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg==} engines: {node: '>=6'} hasBin: true - jsonfile@6.1.0: - resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==} + jsonfile@6.2.0: + resolution: {integrity: sha512-FGuPw30AdOIUTRMC2OMRtQV+jkVj2cfPqSeWXv1NEAJ1qZ5zb1X6z1mFhbfOB/iy3ssJCD+3KuZ8r8C3uVFlAg==} keyv@4.5.4: resolution: {integrity: sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==} @@ -2991,19 +3281,15 @@ packages: resolution: {integrity: sha512-KvNT4XqAMzdcL6ka6Tl3i2lYeFDgXNCuIX+xNx6ZMVR1dFq+idXd9FLKNMOIx0t9mJ9/HudyX4oZWXZQ0UJHeg==} engines: {node: '>=14.16'} - launch-editor@2.8.0: - resolution: {integrity: sha512-vJranOAJrI/llyWGRQqiDM+adrw+k83fvmmx3+nV47g3+36xM15jE+zyZ6Ffel02+xSvuM0b2GDRosXZkbb6wA==} + launch-editor@2.11.1: + resolution: {integrity: sha512-SEET7oNfgSaB6Ym0jufAdCeo3meJVeCaaDyzRygy0xsp2BFKCprcfHljTq4QkzTLUxEKkFK6OK4811YM2oSrRg==} leven@3.1.0: resolution: {integrity: sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==} engines: {node: '>=6'} - lilconfig@2.1.0: - resolution: {integrity: sha512-utWOt/GHzuUxnLKxB6dk81RoOeoNeHgbrXiuGk4yyF5qlRz+iIVWu56E2fqGHFrXz0QNUhLB/8nKqvRH66JKGQ==} - engines: {node: '>=10'} - - lilconfig@3.1.2: - resolution: {integrity: sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow==} + lilconfig@3.1.3: + resolution: {integrity: sha512-/vlFKAoH5Cgt3Ie+JLhRbwOsCQePABiU3tJ1egGvyQ+33R/vcwM2Zl2QR/LzjsBeItPt3oSVXapn+m4nQDvpzw==} engines: {node: '>=14'} lines-and-columns@1.2.4: @@ -3017,18 +3303,6 @@ packages: resolution: {integrity: sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==} engines: {node: '>=8.9.0'} - loader-utils@3.3.1: - resolution: {integrity: sha512-FMJTLMXfCLMLfJxcX9PFqX5qD88Z5MRGaZCVzfuqeZSPsyiBzs+pahDQjbIWz2QIzPZz0NX9Zy4FX3lmK6YHIg==} - engines: {node: '>= 12.13.0'} - - locate-path@3.0.0: - resolution: {integrity: sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==} - engines: {node: '>=6'} - - locate-path@6.0.0: - resolution: {integrity: sha512-iPZK6eYjbxRu3uB4/WZ3EsEIMJFMqAoopl3R+zuq0UjcAm/MO6KCweDgPfP3elTztoKP3KtnVHxTn2NHBSDVUw==} - engines: {node: '>=10'} - locate-path@7.2.0: resolution: {integrity: sha512-gvVijfZvn7R+2qyPX8mAuKcFGDf6Nc61GdvGafQsHL0sBIxfKzA+usWn4GFC/bk+QdwPUD4kWFJLhElipq+0VA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} @@ -3059,9 +3333,8 @@ packages: resolution: {integrity: sha512-ozCC6gdQ+glXOQsveKD0YsDy8DSQFjDTz4zyzEHNV5+JP5D62LmfDZ6o1cycFx9ouG940M5dE8C8CTewdj2YWQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - lru-cache@10.3.0: - resolution: {integrity: sha512-CQl19J/g+Hbjbv4Y3mFNNXFEL/5t/KCg8POCuUqd4rMKjGG+j1ybER83hxV58zL+dFI1PTkt3GNFSHRt+d8qEQ==} - engines: {node: 14 || >=16.14} + lru-cache@10.4.3: + resolution: {integrity: sha512-JNAzZcXrCt42VGLuYz0zfAzDfAvJWW6AfYlDBQyDV5DClI2m5sAmK+OIO7s59XfsRsWHp02jAJrRadPRGTt6SQ==} lru-cache@5.1.1: resolution: {integrity: sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==} @@ -3079,26 +3352,38 @@ packages: resolution: {integrity: sha512-o5vL7aDWatOTX8LzaS1WMoaoxIiLRQJuIKKe2wAw6IeULDHaqbiqiggmx+pKvZDb1Sj+pE46Sn1T7lCqfFtg1Q==} engines: {node: '>=16'} - markdown-table@3.0.3: - resolution: {integrity: sha512-Z1NL3Tb1M9wH4XESsCDEksWoKTdlUafKc4pt0GRwjUyXaCFZ+dc3g2erqB6zm3szA2IUSi7VnPI+o/9jnxh9hw==} + markdown-table@2.0.0: + resolution: {integrity: sha512-Ezda85ToJUBhM6WGaG6veasyym+Tbs3cMAw/ZhOPqXiYsr0jgocBV3j3nx+4lk47plLlIqjwuTm/ywVI+zjJ/A==} + + markdown-table@3.0.4: + resolution: {integrity: sha512-wiYz4+JrLyb/DqW2hkFJxP7Vd7JuTDm77fvbM8VfEQdmSMqcImWeeRbHwZjBjIFki/VaMK2BhFi7oUUZeM5bqw==} + + marked@16.3.0: + resolution: {integrity: sha512-K3UxuKu6l6bmA5FUwYho8CfJBlsUWAooKtdGgMcERSpF7gcBUrCGsLH7wDaaNOzwq18JzSUDyoEb/YsrqMac3w==} + engines: {node: '>= 20'} + hasBin: true + + math-intrinsics@1.1.0: + resolution: {integrity: sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==} + engines: {node: '>= 0.4'} - mdast-util-directive@3.0.0: - resolution: {integrity: sha512-JUpYOqKI4mM3sZcNxmF/ox04XYFFkNwr0CFlrQIkCwbvH0xzMCqkMqAde9wRd80VAhaUrwFwKm2nxretdT1h7Q==} + mdast-util-directive@3.1.0: + resolution: {integrity: sha512-I3fNFt+DHmpWCYAT7quoM6lHf9wuqtI+oCOfvILnoicNIqjh5E3dEJWiXuYME2gNe8vl1iMQwyUHa7bgFmak6Q==} - mdast-util-find-and-replace@3.0.1: - resolution: {integrity: sha512-SG21kZHGC3XRTSUhtofZkBzZTJNM5ecCi0SK2IMKmSXR8vO3peL+kb1O0z7Zl83jKtutG4k5Wv/W7V3/YHvzPA==} + mdast-util-find-and-replace@3.0.2: + resolution: {integrity: sha512-Tmd1Vg/m3Xz43afeNxDIhWRtFZgM2VLyaf4vSTYwudTyeuTneoL3qtWMA5jeLyz/O1vDJmmV4QuScFCA2tBPwg==} - mdast-util-from-markdown@2.0.1: - resolution: {integrity: sha512-aJEUyzZ6TzlsX2s5B4Of7lN7EQtAxvtradMMglCQDyaTFgse6CmtmdJ15ElnVRlCg1vpNyVtbem0PWzlNieZsA==} + mdast-util-from-markdown@2.0.2: + resolution: {integrity: sha512-uZhTV/8NBuw0WHkPTrCqDOl0zVe1BIng5ZtHoDk49ME1qqcjYmmLmOf0gELgcRMxN4w2iuIeVso5/6QymSrgmA==} mdast-util-frontmatter@2.0.1: resolution: {integrity: sha512-LRqI9+wdgC25P0URIJY9vwocIzCcksduHQ9OF2joxQoyTNVduwLAFUzjoopuRJbJAReaKrNQKAZKL3uCMugWJA==} - mdast-util-gfm-autolink-literal@2.0.0: - resolution: {integrity: sha512-FyzMsduZZHSc3i0Px3PQcBT4WJY/X/RCtEJKuybiC6sjPqLv7h1yqAkmILZtuxMSsUyaLUWNp71+vQH2zqp5cg==} + mdast-util-gfm-autolink-literal@2.0.1: + resolution: {integrity: sha512-5HVP2MKaP6L+G6YaxPNjuL0BPrq9orG3TsrZ9YXbA3vDw/ACI4MEsnoDpn6ZNm7GnZgtAcONJyPhOP8tNJQavQ==} - mdast-util-gfm-footnote@2.0.0: - resolution: {integrity: sha512-5jOT2boTSVkMnQ7LTrd6n/18kqwjmuYqo7JUPe+tRCY6O7dAuTFMtTPauYYrMPpox9hlN0uOx/FL8XvEfG9/mQ==} + mdast-util-gfm-footnote@2.1.0: + resolution: {integrity: sha512-sqpDWlsHn7Ac9GNZQMeUzPQSMzR6Wv0WKRNvQRg0KqHh02fpTz69Qc1QSseNX29bhz1ROIyNyxExfawVKTm1GQ==} mdast-util-gfm-strikethrough@2.0.0: resolution: {integrity: sha512-mKKb915TF+OC5ptj5bJ7WFRPdYtuHv0yTRxK2tJvi+BDqbkiG7h7u/9SI89nRAYcmap2xHQL9D+QG/6wSrTtXg==} @@ -3109,14 +3394,14 @@ packages: mdast-util-gfm-task-list-item@2.0.0: resolution: {integrity: sha512-IrtvNvjxC1o06taBAVJznEnkiHxLFTzgonUdy8hzFVeDun0uTjxxrRGVaNFqkU1wJR3RBPEfsxmU6jDWPofrTQ==} - mdast-util-gfm@3.0.0: - resolution: {integrity: sha512-dgQEX5Amaq+DuUqf26jJqSK9qgixgd6rYDHAv4aTBuA92cTknZlKpPfa86Z/s8Dj8xsAQpFfBmPUHWJBWqS4Bw==} + mdast-util-gfm@3.1.0: + resolution: {integrity: sha512-0ulfdQOM3ysHhCJ1p06l0b0VKlhU0wuQs3thxZQagjcjPrlFRqY215uZGHHJan9GEAXd9MbfPjFJz+qMkVR6zQ==} - mdast-util-mdx-expression@2.0.0: - resolution: {integrity: sha512-fGCu8eWdKUKNu5mohVGkhBXCXGnOTLuFqOvGMvdikr+J1w7lDJgxThOKpwRWzzbyXAU2hhSwsmssOY4yTokluw==} + mdast-util-mdx-expression@2.0.1: + resolution: {integrity: sha512-J6f+9hUp+ldTZqKRSg7Vw5V6MqjATc+3E4gf3CFNcuZNWD8XdyI6zQ8GqH7f8169MM6P7hMBRDVGnn7oHB9kXQ==} - mdast-util-mdx-jsx@3.1.2: - resolution: {integrity: sha512-eKMQDeywY2wlHc97k5eD8VC+9ASMjN8ItEZQNGwJ6E0XWKiW/Z0V5/H8pvoXUf+y+Mj0VIgeRRbujBmFn4FTyA==} + mdast-util-mdx-jsx@3.2.0: + resolution: {integrity: sha512-lj/z8v0r6ZtsN/cGNNtemmmfoLAFZnjMbNyLzBafjzikOM+glrjNHPlf6lQDOTccj9n5b0PPihEBbhneMyGs1Q==} mdast-util-mdx@3.0.0: resolution: {integrity: sha512-JfbYLAW7XnYTTbUsmpu0kdBUVe+yKVJZBItEjwyYJiDJuZ9w4eeaqks4HQO+R7objWgS2ymV60GYpI14Ug554w==} @@ -3130,8 +3415,8 @@ packages: mdast-util-to-hast@13.2.0: resolution: {integrity: sha512-QGYKEuUsYT9ykKBCMOEDLsU5JRObWQusAolFMeko/tYPufNkRffBAQjIE+99jbA87xv6FgmjLtwjh9wBWajwAA==} - mdast-util-to-markdown@2.1.0: - resolution: {integrity: sha512-SR2VnIEdVNCJbP6y7kVTJgPLifdr8WEU440fQec7qHoHOUz/oJ2jmNRqdDQ3rbiStOXb2mCDGTuwsK5OPUgYlQ==} + mdast-util-to-markdown@2.1.2: + resolution: {integrity: sha512-xj68wMTvGXVOKonmog6LwyJKrYXZPvlwabaryTjLh9LuvovB/KAH+kvi8Gjj+7rJjsFi23nkUxRQv1KqSroMqA==} mdast-util-to-string@4.0.0: resolution: {integrity: sha512-0H44vDimn51F0YwvxSJSm0eCDOJTRlmN0R1yBh4HLj9wiV1Dn0QoXGbvFAWj2hSItVTlCmBF1hqKlIyUBVFLPg==} @@ -3146,12 +3431,11 @@ packages: resolution: {integrity: sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==} engines: {node: '>= 0.6'} - memfs@3.5.3: - resolution: {integrity: sha512-UERzLsxzllchadvbPs5aolHh65ISpKpM+ccLbOJ8/vvpBKmAWf+la7dXFy7Mr0ySHbdHrFv5kGFCUHHe6GFEmw==} - engines: {node: '>= 4.0.0'} + memfs@4.47.0: + resolution: {integrity: sha512-Xey8IZA57tfotV/TN4d6BmccQuhFP+CqRiI7TTNdipZdZBzF2WnzUcH//Cudw6X4zJiUbo/LTuU/HPA/iC/pNg==} - merge-descriptors@1.0.1: - resolution: {integrity: sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==} + merge-descriptors@1.0.3: + resolution: {integrity: sha512-gaNvAS7TZ897/rVaZ0nMtAyxNyi/pdbjbAwUpFQpN70GqnVfOiXpeUUMKRBmzXaSQ8DdTX4/0ms62r2K+hE6mQ==} merge-stream@2.0.0: resolution: {integrity: sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==} @@ -3164,41 +3448,41 @@ packages: resolution: {integrity: sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==} engines: {node: '>= 0.6'} - micromark-core-commonmark@2.0.1: - resolution: {integrity: sha512-CUQyKr1e///ZODyD1U3xit6zXwy1a8q2a1S1HKtIlmgvurrEpaw/Y9y6KSIbF8P59cn/NjzHyO+Q2fAyYLQrAA==} + micromark-core-commonmark@2.0.3: + resolution: {integrity: sha512-RDBrHEMSxVFLg6xvnXmb1Ayr2WzLAWjeSATAoxwKYJV94TeNavgoIdA0a9ytzDSVzBy2YKFK+emCPOEibLeCrg==} - micromark-extension-directive@3.0.0: - resolution: {integrity: sha512-61OI07qpQrERc+0wEysLHMvoiO3s2R56x5u7glHq2Yqq6EHbH4dW25G9GfDdGCDYqA21KE6DWgNSzxSwHc2hSg==} + micromark-extension-directive@3.0.2: + resolution: {integrity: sha512-wjcXHgk+PPdmvR58Le9d7zQYWy+vKEU9Se44p2CrCDPiLr2FMyiT4Fyb5UFKFC66wGB3kPlgD7q3TnoqPS7SZA==} micromark-extension-frontmatter@2.0.0: resolution: {integrity: sha512-C4AkuM3dA58cgZha7zVnuVxBhDsbttIMiytjgsM2XbHAB2faRVaHRle40558FBN+DJcrLNCoqG5mlrpdU4cRtg==} - micromark-extension-gfm-autolink-literal@2.0.0: - resolution: {integrity: sha512-rTHfnpt/Q7dEAK1Y5ii0W8bhfJlVJFnJMHIPisfPK3gpVNuOP0VnRl96+YJ3RYWV/P4gFeQoGKNlT3RhuvpqAg==} + micromark-extension-gfm-autolink-literal@2.1.0: + resolution: {integrity: sha512-oOg7knzhicgQ3t4QCjCWgTmfNhvQbDDnJeVu9v81r7NltNCVmhPy1fJRX27pISafdjL+SVc4d3l48Gb6pbRypw==} - micromark-extension-gfm-footnote@2.0.0: - resolution: {integrity: sha512-6Rzu0CYRKDv3BfLAUnZsSlzx3ak6HAoI85KTiijuKIz5UxZxbUI+pD6oHgw+6UtQuiRwnGRhzMmPRv4smcz0fg==} + micromark-extension-gfm-footnote@2.1.0: + resolution: {integrity: sha512-/yPhxI1ntnDNsiHtzLKYnE3vf9JZ6cAisqVDauhp4CEHxlb4uoOTxOCJ+9s51bIB8U1N1FJ1RXOKTIlD5B/gqw==} - micromark-extension-gfm-strikethrough@2.0.0: - resolution: {integrity: sha512-c3BR1ClMp5fxxmwP6AoOY2fXO9U8uFMKs4ADD66ahLTNcwzSCyRVU4k7LPV5Nxo/VJiR4TdzxRQY2v3qIUceCw==} + micromark-extension-gfm-strikethrough@2.1.0: + resolution: {integrity: sha512-ADVjpOOkjz1hhkZLlBiYA9cR2Anf8F4HqZUO6e5eDcPQd0Txw5fxLzzxnEkSkfnD0wziSGiv7sYhk/ktvbf1uw==} - micromark-extension-gfm-table@2.0.0: - resolution: {integrity: sha512-PoHlhypg1ItIucOaHmKE8fbin3vTLpDOUg8KAr8gRCF1MOZI9Nquq2i/44wFvviM4WuxJzc3demT8Y3dkfvYrw==} + micromark-extension-gfm-table@2.1.1: + resolution: {integrity: sha512-t2OU/dXXioARrC6yWfJ4hqB7rct14e8f7m0cbI5hUmDyyIlwv5vEtooptH8INkbLzOatzKuVbQmAYcbWoyz6Dg==} micromark-extension-gfm-tagfilter@2.0.0: resolution: {integrity: sha512-xHlTOmuCSotIA8TW1mDIM6X2O1SiX5P9IuDtqGonFhEK0qgRI4yeC6vMxEV2dgyr2TiD+2PQ10o+cOhdVAcwfg==} - micromark-extension-gfm-task-list-item@2.0.1: - resolution: {integrity: sha512-cY5PzGcnULaN5O7T+cOzfMoHjBW7j+T9D2sucA5d/KbsBTPcYdebm9zUd9zzdgJGCwahV+/W78Z3nbulBYVbTw==} + micromark-extension-gfm-task-list-item@2.1.0: + resolution: {integrity: sha512-qIBZhqxqI6fjLDYFTBIa4eivDMnP+OZqsNwmQ3xNLE4Cxwc+zfQEfbs6tzAo2Hjq+bh6q5F+Z8/cksrLFYWQQw==} micromark-extension-gfm@3.0.0: resolution: {integrity: sha512-vsKArQsicm7t0z2GugkCKtZehqUm31oeGBV/KVSorWSy8ZlNAv7ytjFhvaryUiCUJYqs+NoE6AFhpQvBTM6Q4w==} - micromark-extension-mdx-expression@3.0.0: - resolution: {integrity: sha512-sI0nwhUDz97xyzqJAbHQhp5TfaxEvZZZ2JDqUo+7NvyIYG6BZ5CPPqj2ogUoPJlmXHBnyZUzISg9+oUmU6tUjQ==} + micromark-extension-mdx-expression@3.0.1: + resolution: {integrity: sha512-dD/ADLJ1AeMvSAKBwO22zG22N4ybhe7kFIZ3LsDI0GlsNr2A3KYxb0LdC1u5rj4Nw+CHKY0RVdnHX8vj8ejm4Q==} - micromark-extension-mdx-jsx@3.0.0: - resolution: {integrity: sha512-uvhhss8OGuzR4/N17L1JwvmJIpPhAd8oByMawEKx6NVdBCbesjH4t+vjEp3ZXft9DwvlKSD07fCeI44/N0Vf2w==} + micromark-extension-mdx-jsx@3.0.2: + resolution: {integrity: sha512-e5+q1DjMh62LZAJOnDraSSbDMvGJ8x3cbjygy2qFEi7HCeUT4BDKCvMozPozcD6WmOt6sVvYDNBKhFSz3kjOVQ==} micromark-extension-mdx-md@2.0.0: resolution: {integrity: sha512-EpAiszsB3blw4Rpba7xTOUptcFeBFi+6PY8VnJ2hhimH+vCQDirWgsMpz7w1XcZE7LVrSAUGb9VJpG9ghlYvYQ==} @@ -3209,86 +3493,86 @@ packages: micromark-extension-mdxjs@3.0.0: resolution: {integrity: sha512-A873fJfhnJ2siZyUrJ31l34Uqwy4xIFmvPY1oj+Ean5PHcPBYzEsvqvWGaWcfEIr11O5Dlw3p2y0tZWpKHDejQ==} - micromark-factory-destination@2.0.0: - resolution: {integrity: sha512-j9DGrQLm/Uhl2tCzcbLhy5kXsgkHUrjJHg4fFAeoMRwJmJerT9aw4FEhIbZStWN8A3qMwOp1uzHr4UL8AInxtA==} + micromark-factory-destination@2.0.1: + resolution: {integrity: sha512-Xe6rDdJlkmbFRExpTOmRj9N3MaWmbAgdpSrBQvCFqhezUn4AHqJHbaEnfbVYYiexVSs//tqOdY/DxhjdCiJnIA==} - micromark-factory-label@2.0.0: - resolution: {integrity: sha512-RR3i96ohZGde//4WSe/dJsxOX6vxIg9TimLAS3i4EhBAFx8Sm5SmqVfR8E87DPSR31nEAjZfbt91OMZWcNgdZw==} + micromark-factory-label@2.0.1: + resolution: {integrity: sha512-VFMekyQExqIW7xIChcXn4ok29YE3rnuyveW3wZQWWqF4Nv9Wk5rgJ99KzPvHjkmPXF93FXIbBp6YdW3t71/7Vg==} - micromark-factory-mdx-expression@2.0.1: - resolution: {integrity: sha512-F0ccWIUHRLRrYp5TC9ZYXmZo+p2AM13ggbsW4T0b5CRKP8KHVRB8t4pwtBgTxtjRmwrK0Irwm7vs2JOZabHZfg==} + micromark-factory-mdx-expression@2.0.3: + resolution: {integrity: sha512-kQnEtA3vzucU2BkrIa8/VaSAsP+EJ3CKOvhMuJgOEGg9KDC6OAY6nSnNDVRiVNRqj7Y4SlSzcStaH/5jge8JdQ==} micromark-factory-space@1.1.0: resolution: {integrity: sha512-cRzEj7c0OL4Mw2v6nwzttyOZe8XY/Z8G0rzmWQZTBi/jjwyw/U4uqKtUORXQrR5bAZZnbTI/feRV/R7hc4jQYQ==} - micromark-factory-space@2.0.0: - resolution: {integrity: sha512-TKr+LIDX2pkBJXFLzpyPyljzYK3MtmllMUMODTQJIUfDGncESaqB90db9IAUcz4AZAJFdd8U9zOp9ty1458rxg==} + micromark-factory-space@2.0.1: + resolution: {integrity: sha512-zRkxjtBxxLd2Sc0d+fbnEunsTj46SWXgXciZmHq0kDYGnck/ZSGj9/wULTV95uoeYiK5hRXP2mJ98Uo4cq/LQg==} - micromark-factory-title@2.0.0: - resolution: {integrity: sha512-jY8CSxmpWLOxS+t8W+FG3Xigc0RDQA9bKMY/EwILvsesiRniiVMejYTE4wumNc2f4UbAa4WsHqe3J1QS1sli+A==} + micromark-factory-title@2.0.1: + resolution: {integrity: sha512-5bZ+3CjhAd9eChYTHsjy6TGxpOFSKgKKJPJxr293jTbfry2KDoWkhBb6TcPVB4NmzaPhMs1Frm9AZH7OD4Cjzw==} - micromark-factory-whitespace@2.0.0: - resolution: {integrity: sha512-28kbwaBjc5yAI1XadbdPYHX/eDnqaUFVikLwrO7FDnKG7lpgxnvk/XGRhX/PN0mOZ+dBSZ+LgunHS+6tYQAzhA==} + micromark-factory-whitespace@2.0.1: + resolution: {integrity: sha512-Ob0nuZ3PKt/n0hORHyvoD9uZhr+Za8sFoP+OnMcnWK5lngSzALgQYKMr9RJVOWLqQYuyn6ulqGWSXdwf6F80lQ==} micromark-util-character@1.2.0: resolution: {integrity: sha512-lXraTwcX3yH/vMDaFWCQJP1uIszLVebzUa3ZHdrgxr7KEU/9mL4mVgCpGbyhvNLNlauROiNUq7WN5u7ndbY6xg==} - micromark-util-character@2.1.0: - resolution: {integrity: sha512-KvOVV+X1yLBfs9dCBSopq/+G1PcgT3lAK07mC4BzXi5E7ahzMAF8oIupDDJ6mievI6F+lAATkbQQlQixJfT3aQ==} + micromark-util-character@2.1.1: + resolution: {integrity: sha512-wv8tdUTJ3thSFFFJKtpYKOYiGP2+v96Hvk4Tu8KpCAsTMs6yi+nVmGh1syvSCsaxz45J6Jbw+9DD6g97+NV67Q==} - micromark-util-chunked@2.0.0: - resolution: {integrity: sha512-anK8SWmNphkXdaKgz5hJvGa7l00qmcaUQoMYsBwDlSKFKjc6gjGXPDw3FNL3Nbwq5L8gE+RCbGqTw49FK5Qyvg==} + micromark-util-chunked@2.0.1: + resolution: {integrity: sha512-QUNFEOPELfmvv+4xiNg2sRYeS/P84pTW0TCgP5zc9FpXetHY0ab7SxKyAQCNCc1eK0459uoLI1y5oO5Vc1dbhA==} - micromark-util-classify-character@2.0.0: - resolution: {integrity: sha512-S0ze2R9GH+fu41FA7pbSqNWObo/kzwf8rN/+IGlW/4tC6oACOs8B++bh+i9bVyNnwCcuksbFwsBme5OCKXCwIw==} + micromark-util-classify-character@2.0.1: + resolution: {integrity: sha512-K0kHzM6afW/MbeWYWLjoHQv1sgg2Q9EccHEDzSkxiP/EaagNzCm7T/WMKZ3rjMbvIpvBiZgwR3dKMygtA4mG1Q==} - micromark-util-combine-extensions@2.0.0: - resolution: {integrity: sha512-vZZio48k7ON0fVS3CUgFatWHoKbbLTK/rT7pzpJ4Bjp5JjkZeasRfrS9wsBdDJK2cJLHMckXZdzPSSr1B8a4oQ==} + micromark-util-combine-extensions@2.0.1: + resolution: {integrity: sha512-OnAnH8Ujmy59JcyZw8JSbK9cGpdVY44NKgSM7E9Eh7DiLS2E9RNQf0dONaGDzEG9yjEl5hcqeIsj4hfRkLH/Bg==} - micromark-util-decode-numeric-character-reference@2.0.1: - resolution: {integrity: sha512-bmkNc7z8Wn6kgjZmVHOX3SowGmVdhYS7yBpMnuMnPzDq/6xwVA604DuOXMZTO1lvq01g+Adfa0pE2UKGlxL1XQ==} + micromark-util-decode-numeric-character-reference@2.0.2: + resolution: {integrity: sha512-ccUbYk6CwVdkmCQMyr64dXz42EfHGkPQlBj5p7YVGzq8I7CtjXZJrubAYezf7Rp+bjPseiROqe7G6foFd+lEuw==} - micromark-util-decode-string@2.0.0: - resolution: {integrity: sha512-r4Sc6leeUTn3P6gk20aFMj2ntPwn6qpDZqWvYmAG6NgvFTIlj4WtrAudLi65qYoaGdXYViXYw2pkmn7QnIFasA==} + micromark-util-decode-string@2.0.1: + resolution: {integrity: sha512-nDV/77Fj6eH1ynwscYTOsbK7rR//Uj0bZXBwJZRfaLEJ1iGBR6kIfNmlNqaqJf649EP0F3NWNdeJi03elllNUQ==} - micromark-util-encode@2.0.0: - resolution: {integrity: sha512-pS+ROfCXAGLWCOc8egcBvT0kf27GoWMqtdarNfDcjb6YLuV5cM3ioG45Ys2qOVqeqSbjaKg72vU+Wby3eddPsA==} + micromark-util-encode@2.0.1: + resolution: {integrity: sha512-c3cVx2y4KqUnwopcO9b/SCdo2O67LwJJ/UyqGfbigahfegL9myoEFoDYZgkT7f36T0bLrM9hZTAaAyH+PCAXjw==} - micromark-util-events-to-acorn@2.0.2: - resolution: {integrity: sha512-Fk+xmBrOv9QZnEDguL9OI9/NQQp6Hz4FuQ4YmCb/5V7+9eAh1s6AYSvL20kHkD67YIg7EpE54TiSlcsf3vyZgA==} + micromark-util-events-to-acorn@2.0.3: + resolution: {integrity: sha512-jmsiEIiZ1n7X1Rr5k8wVExBQCg5jy4UXVADItHmNk1zkwEVhBuIUKRu3fqv+hs4nxLISi2DQGlqIOGiFxgbfHg==} - micromark-util-html-tag-name@2.0.0: - resolution: {integrity: sha512-xNn4Pqkj2puRhKdKTm8t1YHC/BAjx6CEwRFXntTaRf/x16aqka6ouVoutm+QdkISTlT7e2zU7U4ZdlDLJd2Mcw==} + micromark-util-html-tag-name@2.0.1: + resolution: {integrity: sha512-2cNEiYDhCWKI+Gs9T0Tiysk136SnR13hhO8yW6BGNyhOC4qYFnwF1nKfD3HFAIXA5c45RrIG1ub11GiXeYd1xA==} - micromark-util-normalize-identifier@2.0.0: - resolution: {integrity: sha512-2xhYT0sfo85FMrUPtHcPo2rrp1lwbDEEzpx7jiH2xXJLqBuy4H0GgXk5ToU8IEwoROtXuL8ND0ttVa4rNqYK3w==} + micromark-util-normalize-identifier@2.0.1: + resolution: {integrity: sha512-sxPqmo70LyARJs0w2UclACPUUEqltCkJ6PhKdMIDuJ3gSf/Q+/GIe3WKl0Ijb/GyH9lOpUkRAO2wp0GVkLvS9Q==} - micromark-util-resolve-all@2.0.0: - resolution: {integrity: sha512-6KU6qO7DZ7GJkaCgwBNtplXCvGkJToU86ybBAUdavvgsCiG8lSSvYxr9MhwmQ+udpzywHsl4RpGJsYWG1pDOcA==} + micromark-util-resolve-all@2.0.1: + resolution: {integrity: sha512-VdQyxFWFT2/FGJgwQnJYbe1jjQoNTS4RjglmSjTUlpUMa95Htx9NHeYW4rGDJzbjvCsl9eLjMQwGeElsqmzcHg==} - micromark-util-sanitize-uri@2.0.0: - resolution: {integrity: sha512-WhYv5UEcZrbAtlsnPuChHUAsu/iBPOVaEVsntLBIdpibO0ddy8OzavZz3iL2xVvBZOpolujSliP65Kq0/7KIYw==} + micromark-util-sanitize-uri@2.0.1: + resolution: {integrity: sha512-9N9IomZ/YuGGZZmQec1MbgxtlgougxTodVwDzzEouPKo3qFWvymFHWcnDi2vzV1ff6kas9ucW+o3yzJK9YB1AQ==} - micromark-util-subtokenize@2.0.1: - resolution: {integrity: sha512-jZNtiFl/1aY73yS3UGQkutD0UbhTt68qnRpw2Pifmz5wV9h8gOVsN70v+Lq/f1rKaU/W8pxRe8y8Q9FX1AOe1Q==} + micromark-util-subtokenize@2.1.0: + resolution: {integrity: sha512-XQLu552iSctvnEcgXw6+Sx75GflAPNED1qx7eBJ+wydBb2KCbRZe+NwvIEEMM83uml1+2WSXpBAcp9IUCgCYWA==} micromark-util-symbol@1.1.0: resolution: {integrity: sha512-uEjpEYY6KMs1g7QfJ2eX1SQEV+ZT4rUD3UcF6l57acZvLNK7PBZL+ty82Z1qhK1/yXIY4bdx04FKMgR0g4IAag==} - micromark-util-symbol@2.0.0: - resolution: {integrity: sha512-8JZt9ElZ5kyTnO94muPxIGS8oyElRJaiJO8EzV6ZSyGQ1Is8xwl4Q45qU5UOg+bGH4AikWziz0iN4sFLWs8PGw==} + micromark-util-symbol@2.0.1: + resolution: {integrity: sha512-vs5t8Apaud9N28kgCrRUdEed4UJ+wWNvicHLPxCa9ENlYuAY31M0ETy5y1vA33YoNPDFTghEbnh6efaE8h4x0Q==} micromark-util-types@1.1.0: resolution: {integrity: sha512-ukRBgie8TIAcacscVHSiddHjO4k/q3pnedmzMQ4iwDcK0FtFCohKOlFbaOL/mPgfnPsL3C1ZyxJa4sbWrBl3jg==} - micromark-util-types@2.0.0: - resolution: {integrity: sha512-oNh6S2WMHWRZrmutsRmDDfkzKtxF+bc2VxLC9dvtrDIRFln627VsFP6fLMgTryGDljgLPjkrzQSDcPrjPyDJ5w==} + micromark-util-types@2.0.2: + resolution: {integrity: sha512-Yw0ECSpJoViF1qTU4DC6NwtC4aWGt1EkzaQB8KPPyCRR8z9TWeV0HbEFGTO+ZY1wB22zmxnJqhPyTpOVCpeHTA==} - micromark@4.0.0: - resolution: {integrity: sha512-o/sd0nMof8kYff+TqcDx3VSrgBTcZpSvYcAHIfHhv5VAuNmisCxjhx6YmxS8PFEpb9z5WKWKPdzf0jM23ro3RQ==} + micromark@4.0.2: + resolution: {integrity: sha512-zpe98Q6kvavpCr1NPVSCMebCKfD7CA2NqZ+rykeNhONIJBpc1tFKt9hucLGwha3jNTNI8lHpctWJWoimVF4PfA==} - micromatch@4.0.7: - resolution: {integrity: sha512-LPP/3KorzCwBxfeUuZmaR6bG2kdeHSbe0P2tY3FLRU4vYrjYz5hI4QZwV0njUx3jeuKe67YukQ1LSPZBKDqO/Q==} + micromatch@4.0.8: + resolution: {integrity: sha512-PXwfBhYu0hBCPw8Dn0E+WDYb7af3dSLVWKi3HGv84IdF4TyFoC0ysxFd0Goxw7nSv4T/PzEJQxsYsEiFCKo2BA==} engines: {node: '>=8.6'} mime-db@1.33.0: @@ -3299,6 +3583,10 @@ packages: resolution: {integrity: sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==} engines: {node: '>= 0.6'} + mime-db@1.54.0: + resolution: {integrity: sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==} + engines: {node: '>= 0.6'} + mime-types@2.1.18: resolution: {integrity: sha512-lc/aahn+t4/SWV/qcmumYjymLsWfN3ELhpmVuUFjgsORruuZPVSwAQryq+HHGvO/SI2KVX26bx+En+zhM8g8hQ==} engines: {node: '>= 0.6'} @@ -3307,6 +3595,10 @@ packages: resolution: {integrity: sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==} engines: {node: '>= 0.6'} + mime-types@3.0.1: + resolution: {integrity: sha512-xRc4oEhT6eaBpU1XF7AjpOFD+xQmXNB5OVKwp4tqCuBpHLS/ZbBDrc07mYTDqVMg6PfxUjjNp85O6Cd2Z/5HWA==} + engines: {node: '>= 0.6'} + mime@1.6.0: resolution: {integrity: sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==} engines: {node: '>=4'} @@ -3324,8 +3616,8 @@ packages: resolution: {integrity: sha512-e5ISH9xMYU0DzrT+jl8q2ze9D6eWBto+I8CNpe+VI+K2J/F/k3PdkdTdz4wvGVH4NTpo+NRYTVIuMQEMMcsLqg==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - mini-css-extract-plugin@2.9.0: - resolution: {integrity: sha512-Zs1YsZVfemekSZG+44vBsYTLQORkPMwnlv+aehcxK/NLKC+EGhDB39/YePYYqx/sTk6NnYpuqikhSn7+JIevTA==} + mini-css-extract-plugin@2.9.4: + resolution: {integrity: sha512-ZWYT7ln73Hptxqxk2DxPU9MmapXRhxkJD6tkSR04dnQxm8BGu2hzgKLugK5yySD97u/8yy7Ma7E76k9ZdvtjkQ==} engines: {node: '>= 12.13.0'} peerDependencies: webpack: ^5.0.0 @@ -3347,16 +3639,13 @@ packages: resolution: {integrity: sha512-qOOzS1cBTWYF4BH8fVePDBOO9iptMnGUEZwNc/cMWnTV2nVLZ7VoNWEPHkYczZA0pdoA7dl6e7FL659nX9S2aw==} engines: {node: '>=16 || 14 >=14.17'} - mrmime@2.0.0: - resolution: {integrity: sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==} + mrmime@2.0.1: + resolution: {integrity: sha512-Y3wQdFg2Va6etvQ5I82yUhGdsKrcYox6p7FfL1LbK2J4V01F9TGlepTIhnK24t7koZibmg82KGglhA1XK5IsLQ==} engines: {node: '>=10'} ms@2.0.0: resolution: {integrity: sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==} - ms@2.1.2: - resolution: {integrity: sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==} - ms@2.1.3: resolution: {integrity: sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==} @@ -3367,8 +3656,8 @@ packages: mz@2.7.0: resolution: {integrity: sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==} - nanoid@3.3.7: - resolution: {integrity: sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==} + nanoid@3.3.11: + resolution: {integrity: sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w==} engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} hasBin: true @@ -3376,22 +3665,26 @@ packages: resolution: {integrity: sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==} engines: {node: '>= 0.6'} + negotiator@0.6.4: + resolution: {integrity: sha512-myRT3DiWPHqho5PrJaIRyaMv2kgYf0mUVgBNOYMuCH5Ki1yEiQaf/ZJuQ62nvpc44wL5WDbTX7yGJi1Neevw8w==} + engines: {node: '>= 0.6'} + neo-async@2.6.2: resolution: {integrity: sha512-Yd3UES5mWCSqR+qNT93S3UoYUkqAZ9lLg8a7g9rimsWmYGK8cVToA4/sF3RrshdyV3sAGMXVUmpMYOw+dLpOuw==} no-case@3.0.4: resolution: {integrity: sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==} - node-emoji@2.1.3: - resolution: {integrity: sha512-E2WEOVsgs7O16zsURJ/eH8BqhF029wGpEOnv7Urwdo2wmQanOACwJQh0devF9D9RhoZru0+9JXIS0dBXIAz+lA==} + node-emoji@2.2.0: + resolution: {integrity: sha512-Z3lTE9pLaJF47NyMhd4ww1yFTAP8YhYI8SleJiHzM46Fgpm5cnNzSl9XfzFNqbaz+VlJrIj3fXQ4DeN1Rjm6cw==} engines: {node: '>=18'} node-forge@1.3.1: resolution: {integrity: sha512-dPEtOeMvF9VMcYV/1Wb8CPoVAXtp6MKMlcbAt4ddqmGqUJ6fQZFXkNZNkNlfevtNkGtaSoXf/vNNNSvgrdXwtA==} engines: {node: '>= 6.13.0'} - node-releases@2.0.14: - resolution: {integrity: sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==} + node-releases@2.0.21: + resolution: {integrity: sha512-5b0pgg78U3hwXkCM8Z9b2FJdPZlr9Psr9V2gQPESdGHqbntyFJKFW4r5TeWGFzafGY3hzs1JC62VEQMbl1JFkw==} normalize-path@3.0.0: resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==} @@ -3401,8 +3694,8 @@ packages: resolution: {integrity: sha512-bdok/XvKII3nUpklnV6P2hxtMNrCboOjAcyBuQnWEhO665FwrSNRxU+AqpsyvO6LgGYPspN+lu5CLtw4jPRKNA==} engines: {node: '>=0.10.0'} - normalize-url@8.0.1: - resolution: {integrity: sha512-IO9QvjUMWxPQQhs60oOu10CRkWCiZzSUkzbXGGV9pviYl1fXYcvkzQ5jV9z8Y6un8ARoVRl4EtC6v6jNqbaJ/w==} + normalize-url@8.1.0: + resolution: {integrity: sha512-X06Mfd/5aKsRHc0O0J5CUedwnPmnDtLF2+nq+KN9KSDlJHkPuh0JUviWjEWMe0SW/9TDdSLVPuk7L5gGTIA1/w==} engines: {node: '>=14.16'} npm-run-path@4.0.1: @@ -3415,6 +3708,12 @@ packages: nth-check@2.1.1: resolution: {integrity: sha512-lqjrjmaOoAnWfMmBPL+XNnynZh2+swxiX3WUE0s4yEHI6m+AwrK2UZOimIRl3X/4QctVqS8AiZjFqyOGrMXb/w==} + null-loader@4.0.1: + resolution: {integrity: sha512-pxqVbi4U6N26lq+LmgIbB5XATP0VdZKOG25DhHi8btMmJJefGArFyDg1yc4U3hWCJbMqSrw0qyrz1UQX+qYXqg==} + engines: {node: '>= 10.13.0'} + peerDependencies: + webpack: ^4.0.0 || ^5.0.0 + object-assign@4.1.1: resolution: {integrity: sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==} engines: {node: '>=0.10.0'} @@ -3423,16 +3722,16 @@ packages: resolution: {integrity: sha512-RSn9F68PjH9HqtltsSnqYC1XXoWe9Bju5+213R98cNGttag9q9yAOTzdbsqvIa7aNm5WffBZFpWYr2aWrklWAw==} engines: {node: '>= 6'} - object-inspect@1.13.2: - resolution: {integrity: sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==} + object-inspect@1.13.4: + resolution: {integrity: sha512-W67iLl4J2EXEGTbfeHCffrjDfitvLANg0UlX3wFUUSTx92KXRFegMHUVgSqE+wvhAbi4WqjGg9czysTV2Epbew==} engines: {node: '>= 0.4'} object-keys@1.1.1: resolution: {integrity: sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==} engines: {node: '>= 0.4'} - object.assign@4.1.5: - resolution: {integrity: sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==} + object.assign@4.1.7: + resolution: {integrity: sha512-nK28WOo+QIjBkDduTINE4JkF/UJJKyf2EJxvJKfblDpyg0Q+pkOHNTL0Qwy6NP6FhE/EnzV73BxxqcJaXY9anw==} engines: {node: '>= 0.4'} obuf@1.1.2: @@ -3442,17 +3741,18 @@ packages: resolution: {integrity: sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==} engines: {node: '>= 0.8'} - on-headers@1.0.2: - resolution: {integrity: sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==} + on-headers@1.1.0: + resolution: {integrity: sha512-737ZY3yNnXy37FHkQxPzt4UZ2UWPWiCZWLvFZ4fu5cueciegX0zGPnrlY6bwRg4FdQOe9YU8MkmJwGhoMybl8A==} engines: {node: '>= 0.8'} - once@1.4.0: - resolution: {integrity: sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==} - onetime@5.1.2: resolution: {integrity: sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==} engines: {node: '>=6'} + open@10.2.0: + resolution: {integrity: sha512-YgBpdJHPyQ2UE5x+hlSXcnejzAvD0b22U2OuAP+8OnlJT+PjWPxtgmGqKKc+RgTM63U9gN0YzrYc71R2WT/hTA==} + engines: {node: '>=18'} + open@8.4.2: resolution: {integrity: sha512-7x81NCL719oNbsq/3mh+hVrAWmFuEYUqrq/Iw3kUzH8ReypT9QQ0BLoJS7/G9k6N81XjW4qHWtjWwe/9eLy1EQ==} engines: {node: '>=12'} @@ -3465,26 +3765,14 @@ packages: resolution: {integrity: sha512-mlVgR3PGuzlo0MmTdk4cXqXWlwQDLnONTAg6sm62XkMJEiRxN3GL3SffkYvqwonbkJBcrI7Uvv5Zh9yjvn2iUw==} engines: {node: '>=12.20'} - p-limit@2.3.0: - resolution: {integrity: sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==} - engines: {node: '>=6'} - - p-limit@3.1.0: - resolution: {integrity: sha512-TYOanM3wGwNGsZN2cVTYPArw454xnXj5qmWF1bEoAc4+cU/ol7GVh7odevjp1FNHduHc3KZMcFduxU5Xc6uJRQ==} - engines: {node: '>=10'} + p-finally@1.0.0: + resolution: {integrity: sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==} + engines: {node: '>=4'} p-limit@4.0.0: resolution: {integrity: sha512-5b0R4txpzjPWVw/cXXUResoD4hb6U/x9BH08L7nw+GN1sezDzPdxeRvpc9c433fZhBan/wusjbCsqwqm4EIBIQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - p-locate@3.0.0: - resolution: {integrity: sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==} - engines: {node: '>=6'} - - p-locate@5.0.0: - resolution: {integrity: sha512-LaNjtRWUBY++zB5nE/NwcaoMylSPk+S+ZHNB1TzdbMJMny6dynpAGt7X/tl/QYq3TIeE6nxHppbo2LGymrG5Pw==} - engines: {node: '>=10'} - p-locate@6.0.0: resolution: {integrity: sha512-wPrq66Llhl7/4AGC6I+cqxT07LhXvWL08LNXz1fENOw0Ap4sRZZ/gZpTTJ5jpurzzzfS2W/Ge9BY3LgLjCShcw==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} @@ -3493,16 +3781,20 @@ packages: resolution: {integrity: sha512-/bjOqmgETBYB5BoEeGVea8dmvHb2m9GLy1E9W43yeyfP6QQCZGFNa+XRceJEuDB6zqr+gKpIAmlLebMpykw/MQ==} engines: {node: '>=10'} - p-retry@4.6.2: - resolution: {integrity: sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==} + p-queue@6.6.2: + resolution: {integrity: sha512-RwFpb72c/BhQLEXIZ5K2e+AhgNVmIejGlTgiB9MzZ0e93GRvqZ7uSi0dvRF7/XIXDeNkra2fNHBxTyPDGySpjQ==} engines: {node: '>=8'} - p-try@2.2.0: - resolution: {integrity: sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==} - engines: {node: '>=6'} + p-retry@6.2.1: + resolution: {integrity: sha512-hEt02O4hUct5wtwg4H4KcWgDdm+l1bOaEy/hWzd8xtXB9BqxTWBBhb+2ImAtH4Cv4rPjV76xN3Zumqk3k3AhhQ==} + engines: {node: '>=16.17'} + + p-timeout@3.2.0: + resolution: {integrity: sha512-rhIwUycgwwKcP9yTOOFK/AKsAopjjCakVqLHePO3CC6Mir1Z99xT+R63jZxAT5lFZLa2inS5h+ZS2GvR99/FBg==} + engines: {node: '>=8'} - package-json-from-dist@1.0.0: - resolution: {integrity: sha512-dATvCeZN/8wQsGywez1mzHtTlP22H8OEfPrVMLNr4/eGa+ijtLn/6M5f0dY8UKNrC2O9UCU6SSoG3qRKnt7STw==} + package-json-from-dist@1.0.1: + resolution: {integrity: sha512-UEZIS3/by4OC8vL3P2dTXRETpebLI2NiI5vIrjaD/5UtrkFX/tNbwjTSRAGC/+7CAo2pIcBaRgWmcBBHcsaCIw==} package-json@8.1.1: resolution: {integrity: sha512-cbH9IAIJHNj9uXi196JVsRlt7cHKak6u/e6AkL/bkRelZ7rlL3X1YKxsZwa36xipOEKAsdtmaG6aAJoM1fx2zA==} @@ -3515,8 +3807,8 @@ packages: resolution: {integrity: sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==} engines: {node: '>=6'} - parse-entities@4.0.1: - resolution: {integrity: sha512-SWzvYcSJh4d/SGLIOQfZ/CoNv6BTlI6YEQ7Nj82oDVnRpwe/Z/F1EMx42x3JAOwGBlCjeCH0BRJQbQ/opHL17w==} + parse-entities@4.0.2: + resolution: {integrity: sha512-GG2AQYWoLgL877gQIKeRPGO1xF9+eG1ujIb5soS5gPvLQ1y2o8FL90w2QWNdf9I361Mpp7726c+lj3U0qK1uGw==} parse-json@5.2.0: resolution: {integrity: sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==} @@ -3525,11 +3817,14 @@ packages: parse-numeric-range@1.3.0: resolution: {integrity: sha512-twN+njEipszzlMJd4ONUYgSfZPDxgHhT9Ahed5uTigpQn90FggW4SA/AIPq/6a149fTbE9qBEcSwE3FAEp6wQQ==} - parse5-htmlparser2-tree-adapter@7.0.0: - resolution: {integrity: sha512-B77tOZrqqfUfnVcOrUvfdLbz4pu4RopLD/4vmu3HUPswwTA8OH0EMW9BlWR2B0RCoiZRAHEUu7IxeP1Pd1UU+g==} + parse5-htmlparser2-tree-adapter@7.1.0: + resolution: {integrity: sha512-ruw5xyKs6lrpo9x9rCZqZZnIUntICjQAd0Wsmp396Ul9lN/h+ifgVV1x1gZHi8euej6wTfpqX8j+BFQxF0NS/g==} - parse5@7.1.2: - resolution: {integrity: sha512-Czj1WaSVpaoj0wbhMzLmWD69anp2WH7FXMB9n1Sy8/ZFF9jolSQVMu1Ij5WIyGmcBmhk7EOndpO4mIpihVqAXw==} + parse5-parser-stream@7.1.2: + resolution: {integrity: sha512-JyeQc9iwFLn5TbvvqACIF/VXG6abODeB3Fwmv/TGdLk2LfbWkaySGY72at4+Ty7EkPZj854u4CrICqNk2qIbow==} + + parse5@7.3.0: + resolution: {integrity: sha512-IInvU7fabl34qmi9gY8XOVxhYyMyuH2xUNpb2q8/Y+7552KlejkRvqvD19nMoUW/uQGGbqNpA6Tufu5FL5BZgw==} parseurl@1.3.3: resolution: {integrity: sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==} @@ -3538,22 +3833,10 @@ packages: pascal-case@3.1.2: resolution: {integrity: sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==} - path-exists@3.0.0: - resolution: {integrity: sha512-bpC7GYwiDYQ4wYLe+FA8lhRjhQCMcQGuSgGGqDkg/QerRWw9CmGRT0iSOVRSZJ29NMLZgIzqaljJ63oaL4NIJQ==} - engines: {node: '>=4'} - - path-exists@4.0.0: - resolution: {integrity: sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==} - engines: {node: '>=8'} - path-exists@5.0.0: resolution: {integrity: sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - path-is-absolute@1.0.1: - resolution: {integrity: sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==} - engines: {node: '>=0.10.0'} - path-is-inside@1.0.2: resolution: {integrity: sha512-DUWJr3+ULp4zXmol/SZkFf3JGsS9/SIv+Y3Rt93/UjPpDpklB5f1er4O3POIbUuUJ3FXgqte2Q7SrU6zAqwk8w==} @@ -3568,24 +3851,21 @@ packages: resolution: {integrity: sha512-Xa4Nw17FS9ApQFJ9umLiJS4orGjm7ZzwUrwamcGQuHSzDyth9boKDaycYdDcZDuqYATXw4HFXgaqWTctW/v1HA==} engines: {node: '>=16 || 14 >=14.18'} - path-to-regexp@0.1.7: - resolution: {integrity: sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==} + path-to-regexp@0.1.12: + resolution: {integrity: sha512-RA1GjUVMnvYFxuqovrEqZoxxW5NUZqbwKtYz/Tt7nXerk0LbLblQmrsgdeOxV5SFHf0UDggjS/bSeOZwt1pmEQ==} - path-to-regexp@1.8.0: - resolution: {integrity: sha512-n43JRhlUKUAlibEJhPeir1ncUID16QnEjNpwzNdO3Lm4ywrBpBZ5oLD0I6br9evr1Y9JTqwRtAh7JLoOzAQdVA==} + path-to-regexp@1.9.0: + resolution: {integrity: sha512-xIp7/apCFJuUHdDLWe8O1HIkb0kQrOMb/0u6FXQjemHn/ii5LrIzU6bdECnsiTF/GjZkMEKg1xdiZwNqDYlZ6g==} - path-to-regexp@2.2.1: - resolution: {integrity: sha512-gu9bD6Ta5bwGrrU8muHzVOBFFREpp2iRkVfhBJahwJ6p6Xw20SjT0MxLnwkjOibQmGSYhiUnf2FLe7k+jcFmGQ==} + path-to-regexp@3.3.0: + resolution: {integrity: sha512-qyCH421YQPS2WFDxDjftfc1ZR5WKQzVzqsp4n9M2kQhVOo/ByahFoUNJfl58kOcEGfQ//7weFTDhm+ss8Ecxgw==} path-type@4.0.0: resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==} engines: {node: '>=8'} - periscopic@3.1.0: - resolution: {integrity: sha512-vKiQ8RRtkl9P+r/+oefh25C3fhybptkHKCZSPlcXiJux2tJF55GnEj3BVn4A5gKfq9NWWXXrxkHBwVPUfH0opw==} - - picocolors@1.0.1: - resolution: {integrity: sha512-anP1Z8qwhkbmu7MFP5iTt+wQKXgwzf7zTyGlcdzabySa9vd0Xt392U0rVmz9poOaBj0uHJKyyo9/upk0HrEQew==} + picocolors@1.1.1: + resolution: {integrity: sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==} picomatch@2.3.1: resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==} @@ -3595,17 +3875,19 @@ packages: resolution: {integrity: sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==} engines: {node: '>=0.10.0'} - pirates@4.0.6: - resolution: {integrity: sha512-saLsH7WeYYPiD25LDuLRRY/i+6HaPYr6G1OUlN39otzkSTxKnubR9RTxS3/Kk50s1g2JTgFwWQDQyplC5/SHZg==} + pirates@4.0.7: + resolution: {integrity: sha512-TfySrs/5nm8fQJDcBDuUng3VOUKsd7S+zqvbOTiGXHfxX4wK31ard+hoNuvkicM/2YFzlpDgABOevKSsB4G/FA==} engines: {node: '>= 6'} pkg-dir@7.0.0: resolution: {integrity: sha512-Ie9z/WINcxxLp27BKOCHGde4ITq9UklYKDzVo1nhk5sqGEXU3FpkwP5GM2voTGJkGd9B3Otl+Q4uwSOeSUtOBA==} engines: {node: '>=14.16'} - pkg-up@3.1.0: - resolution: {integrity: sha512-nDywThFk1i4BQK4twPQ6TA4RT8bDY96yeuCVBWL3ePARCiEKDRSrNGbFIgUJpLp+XeIR65v8ra7WuJOFUBtkMA==} - engines: {node: '>=8'} + postcss-attribute-case-insensitive@7.0.1: + resolution: {integrity: sha512-Uai+SupNSqzlschRyNx3kbCTWgY/2hcwtHEI/ej2LJWc9JJ77qKgGptd8DHwY1mXtZ7Aoh4z4yxfwMBue9eNgw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 postcss-calc@9.0.1: resolution: {integrity: sha512-TipgjGyzP5QzEhsOZUaIkeO5mKeMFpebWzRogWG/ysonUlnHcq5aJe0jOjpfzUU8PeSaBQnrE8ehR0QA5vs8PQ==} @@ -3613,6 +3895,30 @@ packages: peerDependencies: postcss: ^8.2.2 + postcss-clamp@4.1.0: + resolution: {integrity: sha512-ry4b1Llo/9zz+PKC+030KUnPITTJAHeOwjfAyyB60eT0AorGLdzp52s31OsPRHRf8NchkgFoG2y6fCfn1IV1Ow==} + engines: {node: '>=7.6.0'} + peerDependencies: + postcss: ^8.4.6 + + postcss-color-functional-notation@7.0.12: + resolution: {integrity: sha512-TLCW9fN5kvO/u38/uesdpbx3e8AkTYhMvDZYa9JpmImWuTE99bDQ7GU7hdOADIZsiI9/zuxfAJxny/khknp1Zw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-color-hex-alpha@10.0.0: + resolution: {integrity: sha512-1kervM2cnlgPs2a8Vt/Qbe5cQ++N7rkYo/2rz2BkqJZIHQwaVuJgQH38REHrAi4uM0b1fqxMkWYmese94iMp3w==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-color-rebeccapurple@10.0.0: + resolution: {integrity: sha512-JFta737jSP+hdAIEhk1Vs0q0YF5P8fFcj+09pweS8ktuGuZ8pPlykHsk6mPxZ8awDl4TrcxUqJo9l1IhVr/OjQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-colormin@6.1.0: resolution: {integrity: sha512-x9yX7DOxeMAR+BgGVnNSAxmAj98NX/YxEMNFP+SDCEeNLb2r3i6Hh1ksMsnW8Ub5SLCpbescQqn9YEbE9554Sw==} engines: {node: ^14 || ^16 || >=18.0} @@ -3625,6 +3931,30 @@ packages: peerDependencies: postcss: ^8.4.31 + postcss-custom-media@11.0.6: + resolution: {integrity: sha512-C4lD4b7mUIw+RZhtY7qUbf4eADmb7Ey8BFA2px9jUbwg7pjTZDl4KY4bvlUV+/vXQvzQRfiGEVJyAbtOsCMInw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-custom-properties@14.0.6: + resolution: {integrity: sha512-fTYSp3xuk4BUeVhxCSJdIPhDLpJfNakZKoiTDx7yRGCdlZrSJR7mWKVOBS4sBF+5poPQFMj2YdXx1VHItBGihQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-custom-selectors@8.0.5: + resolution: {integrity: sha512-9PGmckHQswiB2usSO6XMSswO2yFWVoCAuih1yl9FVcwkscLjRKjwsjM3t+NIWpSU2Jx3eOiK2+t4vVTQaoCHHg==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-dir-pseudo-class@9.0.1: + resolution: {integrity: sha512-tRBEK0MHYvcMUrAuYMEOa0zg9APqirBcgzi6P21OhxtJyJADo/SWBwY1CAwEohQ/6HDaa9jCjLRG7K3PVQYHEA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-discard-comments@6.0.2: resolution: {integrity: sha512-65w/uIqhSBBfQmYnG92FO1mWZjJ4GL5b8atm5Yw2UgrwD7HiNiSSNwJor1eCFGzUgYnN/iIknhNRVqjrrpuglw==} engines: {node: ^14 || ^16 || >=18.0} @@ -3655,18 +3985,59 @@ packages: peerDependencies: postcss: ^8.4.31 + postcss-double-position-gradients@6.0.4: + resolution: {integrity: sha512-m6IKmxo7FxSP5nF2l63QbCC3r+bWpFUWmZXZf096WxG0m7Vl1Q1+ruFOhpdDRmKrRS+S3Jtk+TVk/7z0+BVK6g==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-focus-visible@10.0.1: + resolution: {integrity: sha512-U58wyjS/I1GZgjRok33aE8juW9qQgQUNwTSdxQGuShHzwuYdcklnvK/+qOWX1Q9kr7ysbraQ6ht6r+udansalA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-focus-within@9.0.1: + resolution: {integrity: sha512-fzNUyS1yOYa7mOjpci/bR+u+ESvdar6hk8XNK/TRR0fiGTp2QT5N+ducP0n3rfH/m9I7H/EQU6lsa2BrgxkEjw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-font-variant@5.0.0: + resolution: {integrity: sha512-1fmkBaCALD72CK2a9i468mA/+tr9/1cBxRRMXOUaZqO43oWPR5imcyPjXwuv7PXbCid4ndlP5zWhidQVVa3hmA==} + peerDependencies: + postcss: ^8.1.0 + + postcss-gap-properties@6.0.0: + resolution: {integrity: sha512-Om0WPjEwiM9Ru+VhfEDPZJAKWUd0mV1HmNXqp2C29z80aQ2uP9UVhLc7e3aYMIor/S5cVhoPgYQ7RtfeZpYTRw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-image-set-function@7.0.0: + resolution: {integrity: sha512-QL7W7QNlZuzOwBTeXEmbVckNt1FSmhQtbMRvGGqqU4Nf4xk6KUEQhAoWuMzwbSv5jxiRiSZ5Tv7eiDB9U87znA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-import@15.1.0: resolution: {integrity: sha512-hpr+J05B2FVYUAXHeK1YyI267J/dDDhMU6B6civm8hSY1jYJnBXxzKDKDswzJmtLHryrjhnDjqqp/49t8FALew==} engines: {node: '>=14.0.0'} peerDependencies: postcss: ^8.0.0 - postcss-js@4.0.1: - resolution: {integrity: sha512-dDLF8pEO191hJMtlHFPRa8xsizHaM82MLfNkUHdUtVEV3tgTp5oj+8qbEqYM57SLfc74KSbw//4SeJma2LRVIw==} + postcss-js@4.1.0: + resolution: {integrity: sha512-oIAOTqgIo7q2EOwbhb8UalYePMvYoIeRY2YKntdpFQXNosSu3vLrniGgmH9OKs/qAkfoj5oB3le/7mINW1LCfw==} engines: {node: ^12 || ^14 || >= 16} peerDependencies: postcss: ^8.4.21 + postcss-lab-function@7.0.12: + resolution: {integrity: sha512-tUcyRk1ZTPec3OuKFsqtRzW2Go5lehW29XA21lZ65XmzQkz43VY2tyWEC202F7W3mILOjw0voOiuxRGTsN+J9w==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-load-config@4.0.2: resolution: {integrity: sha512-bSVhyJGL00wMVoPUzAVAnbEoWyqRxkjv64tUl427SKnPrENtq6hJwUojroMz2VB+Q1edmi4IfrAPpami5VVgMQ==} engines: {node: '>= 14'} @@ -3686,6 +4057,12 @@ packages: postcss: ^7.0.0 || ^8.0.1 webpack: ^5.0.0 + postcss-logical@8.1.0: + resolution: {integrity: sha512-pL1hXFQ2fEXNKiNiAgtfA005T9FBxky5zkX6s4GZM2D8RkVgRqz3f4g1JUoq925zXv495qk8UNldDwh8uGEDoA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-merge-idents@6.0.3: resolution: {integrity: sha512-1oIoAsODUs6IHQZkLQGO15uGEbK3EAl5wi9SS8hs45VgsxQfMnxvt+L+zIr7ifZFIH14cfAeVe2uCTa+SPRa3g==} engines: {node: ^14 || ^16 || >=18.0} @@ -3734,14 +4111,14 @@ packages: peerDependencies: postcss: ^8.1.0 - postcss-modules-local-by-default@4.0.5: - resolution: {integrity: sha512-6MieY7sIfTK0hYfafw1OMEG+2bg8Q1ocHCpoWLqOKj3JXlKu4G7btkmM/B7lFubYkYWmRSPLZi5chid63ZaZYw==} + postcss-modules-local-by-default@4.2.0: + resolution: {integrity: sha512-5kcJm/zk+GJDSfw+V/42fJ5fhjL5YbFDl8nVdXkJPLLW+Vf9mTD5Xe0wqIaDnLuL2U6cDNpTr+UQ+v2HWIBhzw==} engines: {node: ^10 || ^12 || >= 14} peerDependencies: postcss: ^8.1.0 - postcss-modules-scope@3.2.0: - resolution: {integrity: sha512-oq+g1ssrsZOsx9M96c5w8laRmvEu9C3adDSjI8oTcbfkrTE8hx/zfyobUoWIxaKPO8bt6S62kxpw5GqypEw1QQ==} + postcss-modules-scope@3.2.1: + resolution: {integrity: sha512-m9jZstCVaqGjTAuny8MdgE88scJnCiQSlSrOWcTQgM2t32UBe+MUmFSO5t7VMSfAf/FJKImAxBav8ooCHJXCJA==} engines: {node: ^10 || ^12 || >= 14} peerDependencies: postcss: ^8.1.0 @@ -3752,12 +4129,18 @@ packages: peerDependencies: postcss: ^8.1.0 - postcss-nested@6.0.1: - resolution: {integrity: sha512-mEp4xPMi5bSWiMbsgoPfcP74lsWLHkQbZc3sY+jWYd65CUwXrUaTp0fmNpa01ZcETKlIgUdFN/MpS2xZtqL9dQ==} + postcss-nested@6.2.0: + resolution: {integrity: sha512-HQbt28KulC5AJzG+cZtj9kvKB93CFCdLvog1WFLf1D+xmMvPGlBstkpTEZfK5+AN9hfJocyBFCNiqyS48bpgzQ==} engines: {node: '>=12.0'} peerDependencies: postcss: ^8.2.14 + postcss-nesting@13.0.2: + resolution: {integrity: sha512-1YCI290TX+VP0U/K/aFxzHzQWHWURL+CtHMSbex1lCdpXD1SoR2sYuxDu5aNI9lPoXpKTCggFZiDJbwylU0LEQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-normalize-charset@6.0.2: resolution: {integrity: sha512-a8N9czmdnrjPHa3DeFlwqst5eaL5W8jYu3EBbTTkI5FHkfMhFZh1EGbku6jhHhIzTA6tquI2P42NtZ59M/H/kQ==} engines: {node: ^14 || ^16 || >=18.0} @@ -3812,12 +4195,47 @@ packages: peerDependencies: postcss: ^8.4.31 + postcss-opacity-percentage@3.0.0: + resolution: {integrity: sha512-K6HGVzyxUxd/VgZdX04DCtdwWJ4NGLG212US4/LA1TLAbHgmAsTWVR86o+gGIbFtnTkfOpb9sCRBx8K7HO66qQ==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-ordered-values@6.0.2: resolution: {integrity: sha512-VRZSOB+JU32RsEAQrO94QPkClGPKJEL/Z9PCBImXMhIeK5KAYo6slP/hBYlLgrCjFxyqvn5VC81tycFEDBLG1Q==} engines: {node: ^14 || ^16 || >=18.0} peerDependencies: postcss: ^8.4.31 + postcss-overflow-shorthand@6.0.0: + resolution: {integrity: sha512-BdDl/AbVkDjoTofzDQnwDdm/Ym6oS9KgmO7Gr+LHYjNWJ6ExORe4+3pcLQsLA9gIROMkiGVjjwZNoL/mpXHd5Q==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-page-break@3.0.4: + resolution: {integrity: sha512-1JGu8oCjVXLa9q9rFTo4MbeeA5FMe00/9C7lN4va606Rdb+HkxXtXsmEDrIraQ11fGz/WvKWa8gMuCKkrXpTsQ==} + peerDependencies: + postcss: ^8 + + postcss-place@10.0.0: + resolution: {integrity: sha512-5EBrMzat2pPAxQNWYavwAfoKfYcTADJ8AXGVPcUZ2UkNloUTWzJQExgrzrDkh3EKzmAx1evfTAzF9I8NGcc+qw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-preset-env@10.4.0: + resolution: {integrity: sha512-2kqpOthQ6JhxqQq1FSAAZGe9COQv75Aw8WbsOvQVNJ2nSevc9Yx/IKZGuZ7XJ+iOTtVon7LfO7ELRzg8AZ+sdw==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-pseudo-class-any-link@10.0.1: + resolution: {integrity: sha512-3el9rXlBOqTFaMFkWDOkHUTQekFIYnaQY55Rsp8As8QQkpiSgIYEcF/6Ond93oHiDsGb4kad8zjt+NPlOC1H0Q==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + postcss-reduce-idents@6.0.3: resolution: {integrity: sha512-G3yCqZDpsNPoQgbDUy3T0E6hqOQ5xigUtBQyrmq3tn2GxlyiL0yyl7H+T8ulQR6kOcHJ9t7/9H4/R2tv8tJbMA==} engines: {node: ^14 || ^16 || >=18.0} @@ -3836,8 +4254,23 @@ packages: peerDependencies: postcss: ^8.4.31 - postcss-selector-parser@6.1.0: - resolution: {integrity: sha512-UMz42UD0UY0EApS0ZL9o1XnLhSTtvvvLe5Dc2H2O56fvRZi+KulDyf5ctDhhtYJBGKStV2FL1fy6253cmLgqVQ==} + postcss-replace-overflow-wrap@4.0.0: + resolution: {integrity: sha512-KmF7SBPphT4gPPcKZc7aDkweHiKEEO8cla/GjcBK+ckKxiZslIu3C4GCRW3DNfL0o7yW7kMQu9xlZ1kXRXLXtw==} + peerDependencies: + postcss: ^8.0.3 + + postcss-selector-not@8.0.1: + resolution: {integrity: sha512-kmVy/5PYVb2UOhy0+LqUYAhKj7DUGDpSWa5LZqlkWJaaAV+dxxsOG3+St0yNLu6vsKD7Dmqx+nWQt0iil89+WA==} + engines: {node: '>=18'} + peerDependencies: + postcss: ^8.4 + + postcss-selector-parser@6.1.2: + resolution: {integrity: sha512-Q8qQfPiZ+THO/3ZrOrO0cJJKfpYCagtMUkXbnEfmgUjwXg6z/WBeOyS9APBBPCTSiDV+s4SwQGu8yFsiMRIudg==} + engines: {node: '>=4'} + + postcss-selector-parser@7.1.0: + resolution: {integrity: sha512-8sLjZwK0R+JlxlYcTuVnyT2v+htpdrjDOKuMcOVdYjt52Lh8hWRYpxBPoKx/Zg+bcjc3wx6fmQevMmUztS/ccA==} engines: {node: '>=4'} postcss-sort-media-queries@5.2.0: @@ -3867,8 +4300,8 @@ packages: peerDependencies: postcss: ^8.4.31 - postcss@8.4.38: - resolution: {integrity: sha512-Wglpdk03BSfXkHoQa3b/oulrotAkwrlLDRSOb9D0bN86FdRyE9lppSp33aHNPgBa0JKCoB+drFLZkQoRRYae5A==} + postcss@8.5.6: + resolution: {integrity: sha512-3Ybi1tAuwAP9s0r1UQ2J4n5Y0G05bJkpUIO0/bI9MhwmD70S5aTWbXGBwxHrelT+XM1k6dM0pk+SwNkpTRN7Pg==} engines: {node: ^10 || ^12 || >=14} pretty-error@4.0.0: @@ -3878,14 +4311,13 @@ packages: resolution: {integrity: sha512-28iF6xPQrP8Oa6uxE6a1biz+lWeTOAPKggvjB8HAs6nVMKZwf5bG++632Dx614hIWgUPkgivRfG+a8uAXGTIbA==} engines: {node: '>=4'} - prism-react-renderer@2.3.1: - resolution: {integrity: sha512-Rdf+HzBLR7KYjzpJ1rSoxT9ioO85nZngQEoFIhL07XhtJHlCU3SOz0GJ6+qvMyQe0Se+BV3qpe6Yd/NmQF5Juw==} + prism-react-renderer@2.4.1: + resolution: {integrity: sha512-ey8Ls/+Di31eqzUxC46h8MksNuGx/n0AAC8uKpwFau4RPDYLuE3EXTp8N8G2vX2N7UC/+IXeNUnlWBGGcAG+Ig==} peerDependencies: react: '>=16.0.0' - prismjs@https://codeload.github.com/PrismJS/prism/tar.gz/59e5a3471377057de1f401ba38337aca27b80e03: - resolution: {tarball: https://codeload.github.com/PrismJS/prism/tar.gz/59e5a3471377057de1f401ba38337aca27b80e03} - version: 1.29.0 + prismjs@1.30.0: + resolution: {integrity: sha512-DEvV2ZF2r2/63V+tK8hQvrR2ZGn10srHbXviTlcv7Kpzw8jWiNTqbVgjO3IY8RxrrOUF8VPMQQFysYYYv0YZxw==} engines: {node: '>=6'} process-nextick-args@2.0.1: @@ -3901,6 +4333,9 @@ packages: property-information@6.5.0: resolution: {integrity: sha512-PgTgs/BlvHxOu8QuEN7wi5A0OmXaBcHpmCSTehcs6Uuu9IkDIEo13Hy7n898RHfrQ49vKCoGeWZSaAK01nwVig==} + property-information@7.1.0: + resolution: {integrity: sha512-TwEZ+X+yCJmYfL7TPUOcvBZ4QfoT5YenQiJuX//0th53DE6w0xxLEtfK3iyryQFddXuvkIk51EEgrJQ0WJkOmQ==} + proto-list@1.2.4: resolution: {integrity: sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==} @@ -3908,27 +4343,21 @@ packages: resolution: {integrity: sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==} engines: {node: '>= 0.10'} - punycode@1.4.1: - resolution: {integrity: sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ==} - punycode@2.3.1: resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==} engines: {node: '>=6'} - pupa@3.1.0: - resolution: {integrity: sha512-FLpr4flz5xZTSJxSeaheeMKN/EDzMdK7b8PTOC6a5PYFKTucWbdqjgqaEyH0shFiSJrVB1+Qqi4Tk19ccU6Aug==} + pupa@3.3.0: + resolution: {integrity: sha512-LjgDO2zPtoXP2wJpDjZrGdojii1uqO0cnwKoIoUzkfS98HDmbeiGmYiXo3lXeFlq2xvne1QFQhwYXSUCLKtEuA==} engines: {node: '>=12.20'} - qs@6.11.0: - resolution: {integrity: sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==} + qs@6.13.0: + resolution: {integrity: sha512-+38qI9SOr8tfZ4QmJNplMUxqjbe7LKvvZgWdExBOmd+egZTtjLB67Gu0HRX3u/XOq7UU2Nx6nsjvS16Z9uwfpg==} engines: {node: '>=0.6'} queue-microtask@1.2.3: resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==} - queue@6.0.2: - resolution: {integrity: sha512-iHZWu+q3IdFZFX36ro/lKBkSvfkztY5Y7HMiPlOUjhupPcG2JMfst2KKEpu5XndviX/3UhFbRngUPNKtgvtZiA==} - quick-lru@5.1.1: resolution: {integrity: sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==} engines: {node: '>=10'} @@ -3952,46 +4381,22 @@ packages: resolution: {integrity: sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==} hasBin: true - react-dev-utils@12.0.1: - resolution: {integrity: sha512-84Ivxmr17KjUupyqzFode6xKhjwuEJDROWKJy/BthkL7Wn6NJ8h4WE6k/exAv6ImS+0oZLRRW5j/aINMHyeGeQ==} - engines: {node: '>=14'} - peerDependencies: - typescript: '>=2.7' - webpack: '>=4' - peerDependenciesMeta: - typescript: - optional: true - react-dom@18.3.1: resolution: {integrity: sha512-5m4nQKp+rZRb09LNH59GM4BxTh9251/ylbKIbpe7TpGxfJ+9kv6BLkLBXIjjspbgbnIBNqlI23tRnTWT0snUIw==} peerDependencies: react: ^18.3.1 - react-error-overlay@6.0.11: - resolution: {integrity: sha512-/6UZ2qgEyH2aqzYZgQPxEnz33NJ2gNsnHA2o5+o4wW9bLM/JYQitNP9xPhsXwC08hMMovfGe/8retsdDsczPRg==} - react-fast-compare@3.2.2: resolution: {integrity: sha512-nsO+KSNgo1SbJqJEYRE9ERzo7YtYbou/OqjSQKxV7jcKox7+usiUVZOAC+XnDOABXggQTno0Y1CpVnuWEc1boQ==} - react-helmet-async@1.3.0: - resolution: {integrity: sha512-9jZ57/dAn9t3q6hneQS0wukqC2ENOBgMNVEhb/ZG9ZSxUetzVIw4iAmEU38IaVg3QGYauQPhSeUTuIUtFglWpg==} - peerDependencies: - react: ^16.6.0 || ^17.0.0 || ^18.0.0 - react-dom: ^16.6.0 || ^17.0.0 || ^18.0.0 - - react-helmet-async@2.0.5: - resolution: {integrity: sha512-rYUYHeus+i27MvFE+Jaa4WsyBKGkL6qVgbJvSBoX8mbsWoABJXdEO0bZyi0F6i+4f0NuIb8AvqPMj3iXFHkMwg==} - peerDependencies: - react: ^16.6.0 || ^17.0.0 || ^18.0.0 - react-is@16.13.1: resolution: {integrity: sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==} - react-json-view-lite@1.4.0: - resolution: {integrity: sha512-wh6F6uJyYAmQ4fK0e8dSQMEWuvTs2Wr3el3sLD9bambX1+pSWUVXIz1RFaoy3TI1mZ0FqdpKq9YgbgTTgyrmXA==} - engines: {node: '>=14'} + react-json-view-lite@2.5.0: + resolution: {integrity: sha512-tk7o7QG9oYyELWHL8xiMQ8x4WzjCzbWNyig3uexmkLb54r8jO0yH3WCWx8UZS0c49eSA4QUmG5caiRJ8fAn58g==} + engines: {node: '>=18'} peerDependencies: - react: ^16.13.1 || ^17.0.0 || ^18.0.0 + react: ^18.0.0 || ^19.0.0 react-loadable-ssr-addon-v5-slorber@1.0.1: resolution: {integrity: sha512-lq3Lyw1lGku8zUEJPDxsNm1AfYHBrO9Y1+olAYwpUJ2IGFBskM0DMKok97A6LWUpHm+o7IvQBOWu9MLenp9Z+A==} @@ -4034,55 +4439,58 @@ packages: resolution: {integrity: sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==} engines: {node: '>=8.10.0'} - reading-time@1.5.0: - resolution: {integrity: sha512-onYyVhBNr4CmAxFsKS7bz+uTLRakypIe4R+5A824vBSkQy/hB3fZepoVEf8OVAxzLvK+H/jm9TzpI3ETSm64Kg==} + recma-build-jsx@1.0.0: + resolution: {integrity: sha512-8GtdyqaBcDfva+GUKDr3nev3VpKAhup1+RvkMvUxURHpW7QyIvk9F5wz7Vzo06CEMSilw6uArgRqhpiUcWp8ew==} - rechoir@0.6.2: - resolution: {integrity: sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw==} - engines: {node: '>= 0.10'} + recma-jsx@1.0.1: + resolution: {integrity: sha512-huSIy7VU2Z5OLv6oFLosQGGDqPqdO1iq6bWNAdhzMxSJP7RAso4fCZ1cKu8j9YHCZf3TPrq4dw3okhrylgcd7w==} + peerDependencies: + acorn: ^6.0.0 || ^7.0.0 || ^8.0.0 - recursive-readdir@2.2.3: - resolution: {integrity: sha512-8HrF5ZsXk5FAH9dgsx3BlUer73nIhuj+9OrQwEbLTPOBzGkL1lsFCR01am+v+0m2Cmbs1nP12hLDl5FA7EszKA==} - engines: {node: '>=6.0.0'} + recma-parse@1.0.0: + resolution: {integrity: sha512-OYLsIGBB5Y5wjnSnQW6t3Xg7q3fQ7FWbw/vcXtORTnyaSFscOtABg+7Pnz6YZ6c27fG1/aN8CjfwoUEUIdwqWQ==} + + recma-stringify@1.0.0: + resolution: {integrity: sha512-cjwII1MdIIVloKvC9ErQ+OgAtwHBmcZ0Bg4ciz78FtbT8In39aAYbaA7zvxQ61xVMSPE8WxhLwLbhif4Js2C+g==} - regenerate-unicode-properties@10.1.1: - resolution: {integrity: sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==} + regenerate-unicode-properties@10.2.2: + resolution: {integrity: sha512-m03P+zhBeQd1RGnYxrGyDAPpWX/epKirLrp8e3qevZdVkKtnCrjjWczIbYc8+xd6vcTStVlqfycTx1KR4LOr0g==} engines: {node: '>=4'} regenerate@1.4.2: resolution: {integrity: sha512-zrceR/XhGYU/d/opr2EKO7aRHUeiBI8qjtfHqADTwZd6Szfy16la6kqD0MIUs5z5hx6AaKa+PixpPrR289+I0A==} - regenerator-runtime@0.14.1: - resolution: {integrity: sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==} - - regenerator-transform@0.15.2: - resolution: {integrity: sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg==} - - regexpu-core@5.3.2: - resolution: {integrity: sha512-RAM5FlZz+Lhmo7db9L298p2vHP5ZywrVXmVXpmAD9GuL5MPH6t9ROw1iA/wfHkQ76Qe7AaPF0nGuim96/IrQMQ==} + regexpu-core@6.4.0: + resolution: {integrity: sha512-0ghuzq67LI9bLXpOX/ISfve/Mq33a4aFRzoQYhnnok1JOFpmE/A2TBGkNVenOGEeSBCjIiWcc6MVOG5HEQv0sA==} engines: {node: '>=4'} - registry-auth-token@5.0.2: - resolution: {integrity: sha512-o/3ikDxtXaA59BmZuZrJZDJv8NMDGSj+6j6XaeBmHw8eY1i1qd9+6H+LjVvQXx3HN6aRCGa1cUdJ9RaJZUugnQ==} + registry-auth-token@5.1.0: + resolution: {integrity: sha512-GdekYuwLXLxMuFTwAPg5UKGLW/UXzQrZvH/Zj791BQif5T05T0RsaLfHc9q3ZOKi7n+BoprPD9mJ0O0k4xzUlw==} engines: {node: '>=14'} registry-url@6.0.1: resolution: {integrity: sha512-+crtS5QjFRqFCoQmvGduwYWEBng99ZvmFvF+cUJkGYF1L1BfU8C6Zp9T7f5vPAwyLkUExpvK+ANVZmGU49qi4Q==} engines: {node: '>=12'} - regjsparser@0.9.1: - resolution: {integrity: sha512-dQUtn90WanSNl+7mQKcXAgZxvUe7Z0SqXlgzv0za4LwiUhyzBC58yQO3liFoUgu8GiJVInAhJjkj1N0EtQ5nkQ==} + regjsgen@0.8.0: + resolution: {integrity: sha512-RvwtGe3d7LvWiDQXeQw8p5asZUmfU1G/l6WbUXeHta7Y2PEIvBTwH6E2EfmYUK8pxcxEdEmaomqyp0vZZ7C+3Q==} + + regjsparser@0.13.0: + resolution: {integrity: sha512-NZQZdC5wOE/H3UT28fVGL+ikOZcEzfMGk/c3iN9UGxzWHMa1op7274oyiUVrAG4B2EuFhus8SvkaYnhvW92p9Q==} hasBin: true rehype-raw@7.0.0: resolution: {integrity: sha512-/aE8hCfKlQeA8LmyeyQvQF3eBiLRGNlfBJEvWH7ivp9sBqs7TNqBL5X3v157rM4IFETqDnIOO+z5M/biZbo9Ww==} + rehype-recma@1.0.0: + resolution: {integrity: sha512-lqA4rGUf1JmacCNWWZx0Wv1dHqMwxzsDWYMTowuplHF3xH0N/MmrZ/G3BDZnzAkRmxDadujCjaKM2hqYdCBOGw==} + relateurl@0.2.7: resolution: {integrity: sha512-G08Dxvm4iDN3MLM0EsP62EDV9IuhXPR6blNz6Utcp7zyV3tr4HVNINt6MpaRWbxoOHT3Q7YN2P+jaHX8vUbgog==} engines: {node: '>= 0.10'} - remark-directive@3.0.0: - resolution: {integrity: sha512-l1UyWJ6Eg1VPU7Hm/9tt0zKtReJQNOA4+iDMAxTyZNWnJnFlbS/7zhiel/rogTLQ2vMYwDzSJa4BiVNqGlqIMA==} + remark-directive@3.0.1: + resolution: {integrity: sha512-gwglrEQEZcZYgVyG1tQuA+h58EZfq5CSULw7J90AFuCTyib1thgHPoqQ+h9iFvU6R+vnZ5oNFQR5QKgGpk741A==} remark-emoji@4.0.1: resolution: {integrity: sha512-fHdvsTR1dHkWKev9eNyhTo4EFwbUvJ8ka9SgeWkMPYFX4WoI7ViVBms3PjlQYgw5TLvNQso3GUB/b/8t3yo+dg==} @@ -4091,17 +4499,17 @@ packages: remark-frontmatter@5.0.0: resolution: {integrity: sha512-XTFYvNASMe5iPN0719nPrdItC9aU0ssC4v14mH1BCi1u0n1gAocqcujWUrByftZTbLhRtiKRyjYTSIOcr69UVQ==} - remark-gfm@4.0.0: - resolution: {integrity: sha512-U92vJgBPkbw4Zfu/IiW2oTZLSL3Zpv+uI7My2eq8JxKgqraFdU8YUGicEJCEgSbeaG+QDFqIcwwfMTOEelPxuA==} + remark-gfm@4.0.1: + resolution: {integrity: sha512-1quofZ2RQ9EWdeN34S79+KExV1764+wCUGop5CPL1WGdD0ocPpu91lzPGbwWMECpEpd42kJGQwzRfyov9j4yNg==} - remark-mdx@3.0.1: - resolution: {integrity: sha512-3Pz3yPQ5Rht2pM5R+0J2MrGoBSrzf+tJG94N+t/ilfdh8YLyyKYtidAYwTveB20BoHAcwIopOUqhcmh2F7hGYA==} + remark-mdx@3.1.1: + resolution: {integrity: sha512-Pjj2IYlUY3+D8x00UJsIOg5BEvfMyeI+2uLPn9VO9Wg4MEtN/VTIq2NEJQfde9PnX15KgtHyl9S0BcTnWrIuWg==} remark-parse@11.0.0: resolution: {integrity: sha512-FCxlKLNGknS5ba/1lmpYijMUzX2esxW5xQqjWxw2eHFfS2MSdaHVINFmhjo+qN1WhZhNimq0dZATN9pH0IDrpA==} - remark-rehype@11.1.0: - resolution: {integrity: sha512-z3tJrAs2kIs1AqIIy6pzHmAHlF1hWQ+OdY4/hv+Wxe35EhyLKcajL33iUEn3ScxtFox9nUvRufR/Zre8Q08H/g==} + remark-rehype@11.1.2: + resolution: {integrity: sha512-Dh7l57ianaEoIpzbp0PC9UKAdCSVklD8E5Rpw7ETfbTl3FqcOOgq5q2LVDhgGCkaBv7p24JXikPdvhhmHvKMsw==} remark-stringify@11.0.0: resolution: {integrity: sha512-1OSmLd3awB/t8qdoEOMazZkNsfVTeY4fTsgzcQFdXNq8ToTN4ZGwrMnlda4K6smTFKD+GRV6O48i6Z4iKgPPpw==} @@ -4109,6 +4517,10 @@ packages: renderkid@3.0.0: resolution: {integrity: sha512-q/7VIQA8lmM1hF+jn+sFSPWGlMkSAeNYcPLmDQx2zzuiDfaLrOmumR8iaUKlenFgh0XRPIUeSPlH3A+AW3Z5pg==} + repeat-string@1.6.1: + resolution: {integrity: sha512-PV0dzCYDNfRi1jCDbJzpW7jNNDRuCOG/jI5ctQcGKt/clZD+YcPS3yIlWuTJMmESC8aevCFmWJy5wjAFgNqN6w==} + engines: {node: '>=0.10'} + require-from-string@2.0.2: resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==} engines: {node: '>=0.10.0'} @@ -4129,8 +4541,9 @@ packages: resolve-pathname@3.0.0: resolution: {integrity: sha512-C7rARubxI8bXFNB/hqcp/4iUeIXJhJZvFPFPiSPRnhU5UPxzMFIl+2E6yY6c4k9giDJAhtV+enfA+G89N6Csng==} - resolve@1.22.8: - resolution: {integrity: sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==} + resolve@1.22.10: + resolution: {integrity: sha512-NPRy+/ncIMeDlTAsuqwKIiferiawhefFJtkNSW0qZJEqMEb+qBt/77B/jGeeek+F0uOeN05CDa6HXbbIgtVX4w==} + engines: {node: '>= 0.4'} hasBin: true responselike@3.0.0: @@ -4141,23 +4554,19 @@ packages: resolution: {integrity: sha512-XQBQ3I8W1Cge0Seh+6gjj03LbmRFWuoszgK9ooCpwYIrhhoO80pfq4cUkU5DkknwfOfFteRwlZ56PYOGYyFWdg==} engines: {node: '>= 4'} - reusify@1.0.4: - resolution: {integrity: sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==} + reusify@1.1.0: + resolution: {integrity: sha512-g6QUff04oZpHs0eG5p83rFLhHeV00ug/Yf9nZM6fLeUrPguBTkTQOdpAWWspMh55TZfVQDPaN3NQJfbVRAxdIw==} engines: {iojs: '>=1.0.0', node: '>=0.10.0'} - rimraf@3.0.2: - resolution: {integrity: sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==} - deprecated: Rimraf versions prior to v4 are no longer supported - hasBin: true - - rtl-detect@1.1.2: - resolution: {integrity: sha512-PGMBq03+TTG/p/cRB7HCLKJ1MgDIi07+QU1faSjiYRfmY5UsAttV9Hs08jDAHVwcOwmVLcSJkpwyfXszVjWfIQ==} - - rtlcss@4.1.1: - resolution: {integrity: sha512-/oVHgBtnPNcggP2aVXQjSy6N1mMAfHg4GSag0QtZBlD5bdDgAHwr4pydqJGd+SUCu9260+Pjqbjwtvu7EMH1KQ==} + rtlcss@4.3.0: + resolution: {integrity: sha512-FI+pHEn7Wc4NqKXMXFM+VAYKEj/mRIcW4h24YVwVtyjI+EqGrLc2Hx/Ny0lrZ21cBWU2goLy36eqMcNj3AQJig==} engines: {node: '>=12.0.0'} hasBin: true + run-applescript@7.1.0: + resolution: {integrity: sha512-DPe5pVFaAsinSaV6QjQ6gdiedWDcRCbUuiQfQa2wmWV7+xC9bGulGI8+TdRmoFkAPaBXk8CrAbnlY2ISniJ47Q==} + engines: {node: '>=18'} + run-parallel@1.2.0: resolution: {integrity: sha512-5l4VyZR86LZ/lDxZTR6jqL8AFE2S0IFLMP26AbjsLVADxHdhB/c0GUsH+y39UfCi3dzz8OlQuPmnaJOMoDHQBA==} @@ -4176,20 +4585,19 @@ packages: scheduler@0.23.2: resolution: {integrity: sha512-UOShsPwz7NrMUqhR6t0hWjFduvOzbtv7toDH1/hIrfRNIDBnnBWd0CwJTGvTpngVlmwGCdP9/Zl/tVrDqcuYzQ==} - schema-utils@2.7.0: - resolution: {integrity: sha512-0ilKFI6QQF5nxDZLFn2dMjvc4hjg/Wkg7rHd3jK6/A4a1Hl9VFdQWvgB1UMGoU94pad1P/8N7fMcEnLnSiju8A==} - engines: {node: '>= 8.9.0'} + schema-dts@1.1.5: + resolution: {integrity: sha512-RJr9EaCmsLzBX2NDiO5Z3ux2BVosNZN5jo0gWgsyKvxKIUL5R3swNvoorulAeL9kLB0iTSX7V6aokhla2m7xbg==} schema-utils@3.3.0: resolution: {integrity: sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==} engines: {node: '>= 10.13.0'} - schema-utils@4.2.0: - resolution: {integrity: sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==} - engines: {node: '>= 12.13.0'} + schema-utils@4.3.2: + resolution: {integrity: sha512-Gn/JaSk/Mt9gYubxTtSn/QCV4em9mpAPiR1rqy/Ocu19u/G9J5WWdNoUT4SiV6mFC3y6cxyFcFwdzPM3FgxGAQ==} + engines: {node: '>= 10.13.0'} - search-insights@2.14.0: - resolution: {integrity: sha512-OLN6MsPMCghDOqlCtsIsYgtsC0pnwVTyT9Mu6A3ewOj1DxvzZF6COrn2g86E/c05xbktB0XN04m/t1Z+n+fTGw==} + search-insights@2.17.3: + resolution: {integrity: sha512-RQPdCYTa8A68uM2jwxoY842xDhvx3E5LFL1LxvxCNMev4o5mLuokczhzjAgGwUZBAmOKZknArSxLKmXtIi2AxQ==} section-matter@1.0.0: resolution: {integrity: sha512-vfD3pmTzGpufjScBh50YHKzEu2lxBWhVEHsNGoEXmCmn2hKGfeNLYMzCJpe8cD7gqX7TJluOVpBkAequ6dgMmA==} @@ -4210,27 +4618,27 @@ packages: resolution: {integrity: sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==} hasBin: true - semver@7.6.2: - resolution: {integrity: sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==} + semver@7.7.2: + resolution: {integrity: sha512-RF0Fw+rO5AMf9MAyaRXI4AV0Ulj5lMHqVxxdSgiVbixSCXoEmmX/jk0CuJw4+3SqroYO9VoUh+HcuJivvtJemA==} engines: {node: '>=10'} hasBin: true - send@0.18.0: - resolution: {integrity: sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==} + send@0.19.0: + resolution: {integrity: sha512-dW41u5VfLXu8SJh5bwRmyYUbAoSB3c9uQh6L8h/KtsFREPWpbX1lrljJo186Jc4nmci/sGUZ9a0a0J2zgfq2hw==} engines: {node: '>= 0.8.0'} serialize-javascript@6.0.2: resolution: {integrity: sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==} - serve-handler@6.1.5: - resolution: {integrity: sha512-ijPFle6Hwe8zfmBxJdE+5fta53fdIY0lHISJvuikXB3VYFafRjMRpOffSPvCYsbKyBA7pvy9oYr/BT1O3EArlg==} + serve-handler@6.1.6: + resolution: {integrity: sha512-x5RL9Y2p5+Sh3D38Fh9i/iQ5ZK+e4xuXRd/pGbM4D13tgo/MGwbttUk8emytcr1YYzBYs+apnUngBDFYfpjPuQ==} serve-index@1.9.1: resolution: {integrity: sha512-pXHfKNP4qujrtteMrSBb0rc8HJ9Ms/GrXwcUtUtD5s4ewDJI8bT3Cz2zTVRMKtri49pLx2e0Ya8ziP5Ya2pZZw==} engines: {node: '>= 0.8.0'} - serve-static@1.15.0: - resolution: {integrity: sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==} + serve-static@1.16.2: + resolution: {integrity: sha512-VqpjJZKadQB/PEbEwvFdO43Ax5dFBZ2UECszz8bQ7pi7wt//PWe1P6MN7eCnjsatYtBT6EuiClbjSWP2WrIoTw==} engines: {node: '>= 0.8.0'} set-function-length@1.2.2: @@ -4258,16 +4666,24 @@ packages: resolution: {integrity: sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==} engines: {node: '>=8'} - shell-quote@1.8.1: - resolution: {integrity: sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==} + shell-quote@1.8.3: + resolution: {integrity: sha512-ObmnIF4hXNg1BqhnHmgbDETF8dLPCggZWBjkQfhZpbszZnYur5DUljTcCHii5LC3J5E0yeO/1LIMyH+UvHQgyw==} + engines: {node: '>= 0.4'} + + side-channel-list@1.0.0: + resolution: {integrity: sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==} + engines: {node: '>= 0.4'} - shelljs@0.8.5: - resolution: {integrity: sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==} - engines: {node: '>=4'} - hasBin: true + side-channel-map@1.0.1: + resolution: {integrity: sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==} + engines: {node: '>= 0.4'} + + side-channel-weakmap@1.0.2: + resolution: {integrity: sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==} + engines: {node: '>= 0.4'} - side-channel@1.0.6: - resolution: {integrity: sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==} + side-channel@1.1.0: + resolution: {integrity: sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==} engines: {node: '>= 0.4'} signal-exit@3.0.7: @@ -4311,8 +4727,8 @@ packages: resolution: {integrity: sha512-0xtkGhWCC9MGt/EzgnvbbbKhqWjl1+/rncmhTh5qCpbYguXh6S/qwePfv/JQ8jePXXmqingylxoC49pCkSPIbA==} engines: {node: '>= 6.3.0'} - source-map-js@1.2.0: - resolution: {integrity: sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==} + source-map-js@1.2.1: + resolution: {integrity: sha512-UXWMKhLOwVKb728IUtQPXxfYU+usdybtUrK/8uGE8CQMvrhOpwvzDBwj0QhSL7MQc7vIsISBG8VQ8+IDQxpfQA==} engines: {node: '>=0.10.0'} source-map-support@0.5.21: @@ -4322,9 +4738,9 @@ packages: resolution: {integrity: sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==} engines: {node: '>=0.10.0'} - source-map@0.7.4: - resolution: {integrity: sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==} - engines: {node: '>= 8'} + source-map@0.7.6: + resolution: {integrity: sha512-i5uvt8C3ikiWeNZSVZNWcfZPItFQOsYTUAOkcUPGd8DqDy1uOUikjt5dG+uRlwyvR108Fb9DOd4GvXfT0N2/uQ==} + engines: {node: '>= 12'} space-separated-tokens@2.0.2: resolution: {integrity: sha512-PEGlAwrG8yXGXRjW32fGbg66JAlOAwbObuqVoJpv/mRgoWDQfgH1wDPvtzWyUSNAXBGSk8h755YDbbcEy3SH2Q==} @@ -4351,8 +4767,8 @@ packages: resolution: {integrity: sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==} engines: {node: '>= 0.8'} - std-env@3.7.0: - resolution: {integrity: sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==} + std-env@3.9.0: + resolution: {integrity: sha512-UGvjygr6F6tpH7o2qyqR6QYpwraIjKSdtzyBdyytFOHmPZY917kwdwLG0RbOjWOnKmnm3PeHjaoLLMie7kPLQw==} string-width@4.2.3: resolution: {integrity: sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==} @@ -4379,8 +4795,8 @@ packages: resolution: {integrity: sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==} engines: {node: '>=8'} - strip-ansi@7.1.0: - resolution: {integrity: sha512-iq6eVVI64nQQTRYq2KtEg2d2uU7LElhTJwsH4YzIHZshxlgZms/wIc4VoDQTlG/IvVIrBKG06CrZnp0qv7hkcQ==} + strip-ansi@7.1.2: + resolution: {integrity: sha512-gmBGslpoQJtgnMAvOVqGZpEz9dyoKTCzy2nfz/n8aIFhN/jCE/rCmcxabB6jOOHV+0WNnylOxaxBQPSvcWklhA==} engines: {node: '>=12'} strip-bom-string@1.0.0: @@ -4399,11 +4815,11 @@ packages: resolution: {integrity: sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig==} engines: {node: '>=8'} - style-to-object@0.4.4: - resolution: {integrity: sha512-HYNoHZa2GorYNyqiCaBgsxvcJIn7OHq6inEga+E6Ke3m5JkoqpQbnFssk4jwe+K7AhGa2fcha4wSOf1Kn01dMg==} + style-to-js@1.1.17: + resolution: {integrity: sha512-xQcBGDxJb6jjFCTzvQtfiPn6YvvP2O8U1MDIPNfJQlWMYfktPy+iGsHE7cssjs7y84d9fQaK4UF3RIJaAHSoYA==} - style-to-object@1.0.6: - resolution: {integrity: sha512-khxq+Qm3xEyZfKd/y9L3oIWQimxuc4STrQKtQn8aSDRHb8mFgpukgX1hdzfrMEW6JCjyJ8p89x+IUMVnCBI1PA==} + style-to-object@1.0.9: + resolution: {integrity: sha512-G4qppLgKu/k6FwRpHiGiKPaPTFcG3g4wNVX/Qsfu+RqQM30E7Tyu/TEgxcL9PNLF5pdRLwQdE3YKKf+KF2Dzlw==} stylehacks@6.1.1: resolution: {integrity: sha512-gSTTEQ670cJNoaeIp9KX6lZmm8LJ3jPB5yJmX8Zq/wQxOsAFXV3qjWzHas3YYk1qesuVIyYWWUpZ0vSE/dTSGg==} @@ -4416,10 +4832,6 @@ packages: engines: {node: '>=16 || 14 >=14.17'} hasBin: true - supports-color@5.5.0: - resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} - engines: {node: '>=4'} - supports-color@7.2.0: resolution: {integrity: sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==} engines: {node: '>=8'} @@ -4440,21 +4852,22 @@ packages: engines: {node: '>=14.0.0'} hasBin: true - tailwindcss@3.4.4: - resolution: {integrity: sha512-ZoyXOdJjISB7/BcLTR6SEsLgKtDStYyYZVLsUtWChO4Ps20CBad7lfJKVDiejocV4ME1hLmyY0WJE3hSDcmQ2A==} + swr@2.3.6: + resolution: {integrity: sha512-wfHRmHWk/isGNMwlLGlZX5Gzz/uTgo0o2IRuTMcf4CPuPFJZlq0rDaKUx+ozB5nBOReNV1kiOyzMfj+MBMikLw==} + peerDependencies: + react: ^16.11.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 + + tailwindcss@3.4.17: + resolution: {integrity: sha512-w33E2aCvSDP0tW9RZuNXadXlkHXqFzSkQew/aIa2i/Sj8fThxwovwlXHSPXTbAHwEIhBFXAedUhP2tueAKP8Og==} engines: {node: '>=14.0.0'} hasBin: true - tapable@1.1.3: - resolution: {integrity: sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==} - engines: {node: '>=6'} - - tapable@2.2.1: - resolution: {integrity: sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==} + tapable@2.2.3: + resolution: {integrity: sha512-ZL6DDuAlRlLGghwcfmSn9sK3Hr6ArtyudlSAiCqQ6IfE+b+HHbydbYDIG15IfS5do+7XQQBdBiubF/cV2dnDzg==} engines: {node: '>=6'} - terser-webpack-plugin@5.3.10: - resolution: {integrity: sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==} + terser-webpack-plugin@5.3.14: + resolution: {integrity: sha512-vkZjpUjb6OMS7dhV+tILUW6BhpDR7P2L/aQSAv+Uwk+m8KATX9EccViHTJR2qDtACKPIYndLGCyl3FMo+r2LMw==} engines: {node: '>= 10.13.0'} peerDependencies: '@swc/core': '*' @@ -4469,14 +4882,11 @@ packages: uglify-js: optional: true - terser@5.31.1: - resolution: {integrity: sha512-37upzU1+viGvuFtBo9NPufCb9dwM0+l9hMxYyWfBA+fbwrPqNJAhbZ6W47bBFnZHKHTUBnMvi87434qq+qnxOg==} + terser@5.44.0: + resolution: {integrity: sha512-nIVck8DK+GM/0Frwd+nIhZ84pR/BX7rmXMfYwyg+Sri5oGVE99/E3KvXqpC2xHFxyqXyGHTKBSioxxplrO4I4w==} engines: {node: '>=10'} hasBin: true - text-table@0.2.0: - resolution: {integrity: sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==} - thenify-all@1.6.0: resolution: {integrity: sha512-RNxQH/qI8/t3thXJDwcstUO4zeqo64+Uy/+sNVRBx4Xn2OX+OZ9oP+iJnNFqplFra2ZUVeKCSa2oVWi3T4uVmA==} engines: {node: '>=0.8'} @@ -4484,6 +4894,16 @@ packages: thenify@3.3.1: resolution: {integrity: sha512-RVZSIV5IG10Hk3enotrhvz0T9em6cyHBLkH/YAZuKqd8hRkKhSfCGIcP2KUY0EPxndzANBmNllzWPwak+bheSw==} + thingies@2.5.0: + resolution: {integrity: sha512-s+2Bwztg6PhWUD7XMfeYm5qliDdSiZm7M7n8KjTkIsm3l/2lgVRc2/Gx/v+ZX8lT4FMA+i8aQvhcWylldc+ZNw==} + engines: {node: '>=10.18'} + peerDependencies: + tslib: ^2 + + throttleit@2.1.0: + resolution: {integrity: sha512-nt6AMGKW1p/70DF/hGBdJB57B8Tspmbp5gfJ8ilhLnt7kkr2ye7hzD6NVG8GGErk2HWF34igrL2CXmNIkzKqKw==} + engines: {node: '>=18'} + thunky@1.1.0: resolution: {integrity: sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==} @@ -4493,9 +4913,9 @@ packages: tiny-warning@1.0.3: resolution: {integrity: sha512-lBN9zLN/oAf68o3zNXYrdCt1kP8WsiGW8Oo2ka41b2IM5JL/S1CTyX1rW0mb/zSuJun0ZUrDxx4sqvYS2FWzPA==} - to-fast-properties@2.0.0: - resolution: {integrity: sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==} - engines: {node: '>=4'} + tinypool@1.1.1: + resolution: {integrity: sha512-Zba82s87IFq9A9XmjiX5uZA/ARWDrB03OHlq+Vw1fSdt0I+4/Kutwy8BP4Y/y/aORMo61FQ0vIb5j44vSo5Pkg==} + engines: {node: ^18.0.0 || >=20.0.0} to-regex-range@5.0.1: resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==} @@ -4509,6 +4929,12 @@ packages: resolution: {integrity: sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ==} engines: {node: '>=6'} + tree-dump@1.1.0: + resolution: {integrity: sha512-rMuvhU4MCDbcbnleZTFezWsaZXRFemSqAM+7jPnzUl1fo9w3YEKOxAeui0fz3OI4EU4hf23iyA7uQRVko+UaBA==} + engines: {node: '>=10.0'} + peerDependencies: + tslib: '2' + trim-lines@3.0.1: resolution: {integrity: sha512-kRj8B+YHZCc9kQYdWfJB2/oUl9rA99qbowYYBtr4ui4mZyAQ2JpvVBd/6U2YloATfqBhBTSMhTpgBHtU0Mf3Rg==} @@ -4518,8 +4944,12 @@ packages: ts-interface-checker@0.1.13: resolution: {integrity: sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==} - tslib@2.6.3: - resolution: {integrity: sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==} + tslib@2.8.1: + resolution: {integrity: sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==} + + type-fest@0.21.3: + resolution: {integrity: sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==} + engines: {node: '>=10'} type-fest@1.4.0: resolution: {integrity: sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA==} @@ -4541,11 +4971,15 @@ packages: engines: {node: '>=14.17'} hasBin: true - undici-types@5.26.5: - resolution: {integrity: sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==} + undici-types@7.12.0: + resolution: {integrity: sha512-goOacqME2GYyOZZfb5Lgtu+1IDmAlAEu5xnD3+xTzS10hT0vzpf0SPjkXwAw9Jm+4n/mQGDP3LO8CPbYROeBfQ==} + + undici@7.16.0: + resolution: {integrity: sha512-QEg3HPMll0o3t2ourKwOeUAZ159Kn9mx5pnzHRQO8+Wixmh88YdZRiIwat0iNzNNXn0yoEtXJqFpyW7eM8BV7g==} + engines: {node: '>=20.18.1'} - unicode-canonical-property-names-ecmascript@2.0.0: - resolution: {integrity: sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==} + unicode-canonical-property-names-ecmascript@2.0.1: + resolution: {integrity: sha512-dA8WbNeb2a6oQzAQ55YlT5vQAWGV9WXOsi3SskE3bcCdM0P4SDd+24zS/OCacdRq5BkdsRj9q3Pg6YyQoxIGqg==} engines: {node: '>=4'} unicode-emoji-modifier-base@1.0.0: @@ -4556,12 +4990,12 @@ packages: resolution: {integrity: sha512-5kaZCrbp5mmbz5ulBkDkbY0SsPOjKqVS35VpL9ulMPfSl0J0Xsm+9Evphv9CoIZFwre7aJoa94AY6seMKGVN5Q==} engines: {node: '>=4'} - unicode-match-property-value-ecmascript@2.1.0: - resolution: {integrity: sha512-qxkjQt6qjg/mYscYMC0XKRn3Rh0wFPlfxB0xkt9CfyTvpX1Ra0+rAmdX2QyAobptSEvuy4RtpPRui6XkV+8wjA==} + unicode-match-property-value-ecmascript@2.2.1: + resolution: {integrity: sha512-JQ84qTuMg4nVkx8ga4A16a1epI9H6uTXAknqxkGF/aFfRLw1xC/Bp24HNLaZhHSkWd3+84t8iXnp1J0kYcZHhg==} engines: {node: '>=4'} - unicode-property-aliases-ecmascript@2.1.0: - resolution: {integrity: sha512-6t3foTQI9qne+OZoVQB/8x8rk2k1eVy1gRXhV3oFQ5T6R1dqQ1xtin3XqSlx3+ATBkliTaR/hHyJBm+LVPNM8w==} + unicode-property-aliases-ecmascript@2.2.0: + resolution: {integrity: sha512-hpbDzxUY9BFwX+UeBnxv3Sh1q7HFxj48DTmXchNgRa46lO8uj3/1iEn3MiNUYTg1g9ctIqXCCERn8gYZhHC5lQ==} engines: {node: '>=4'} unified@11.0.5: @@ -4580,9 +5014,6 @@ packages: unist-util-position@5.0.0: resolution: {integrity: sha512-fucsC7HjXvkB5R3kTCO7kUjRdrS0BJt3M/FPxmHMBOm8JQi2BsHAHFsy27E0EolP8rp0NzXsJ+jNPyDWvOJZPA==} - unist-util-remove-position@5.0.0: - resolution: {integrity: sha512-Hp5Kh3wLxv0PHj9m2yZhhLt58KzPtEYKQQ4yxfYFEO7EvHwzyDYnduhHnY1mDxoqr7VUwVuHXk9RXKIiYS1N8Q==} - unist-util-stringify-position@4.0.0: resolution: {integrity: sha512-0ASV06AAoKCDkS2+xw5RXJywruurpbC4JZSm7nr7MOt1ojAzvyyaO+UxZf18j8FCF6kmzCZKcAgN/yu2gm2XgQ==} @@ -4600,8 +5031,8 @@ packages: resolution: {integrity: sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==} engines: {node: '>= 0.8'} - update-browserslist-db@1.0.16: - resolution: {integrity: sha512-KVbTxlBYlckhF5wgfyZXTWnMn7MMZjMu9XG8bPlliUOP9ThaF4QnhP8qrjrH7DRzHfSk0oQv1wToW+iA5GajEQ==} + update-browserslist-db@1.1.3: + resolution: {integrity: sha512-UxhIZQ+QInVdunkDAaiazvvT/+fXL5Osr0JZlJulepYu6Jd7qJtDZjlur0emRlT71EN3ScPoE7gvsuIKKNavKw==} hasBin: true peerDependencies: browserslist: '>= 4.21.0' @@ -4623,6 +5054,11 @@ packages: file-loader: optional: true + use-sync-external-store@1.5.0: + resolution: {integrity: sha512-Rb46I4cGGVBmjamjphe8L/UnvJD+uPPtTkNvX5mZgqdbavhI4EbgIWJiIHXJ8bc/i9EQGPRh4DwEURJ552Do0A==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 || ^18.0.0 || ^19.0.0 + util-deprecate@1.0.2: resolution: {integrity: sha512-EPD5q1uXyFxJpCrLnCc1nHnq3gOa6DZBocAIiI2TaSCA7VCJ1UJDMagCzIkXNsUYfD1daK//LTEQ8xiIbrHtcw==} @@ -4648,17 +5084,17 @@ packages: resolution: {integrity: sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==} engines: {node: '>= 0.8'} - vfile-location@5.0.2: - resolution: {integrity: sha512-NXPYyxyBSH7zB5U6+3uDdd6Nybz6o6/od9rk8bp9H8GR3L+cm/fC0uUTbqBmUTnMCUDslAGBOIKNfvvb+gGlDg==} + vfile-location@5.0.3: + resolution: {integrity: sha512-5yXvWDEgqeiYiBe1lbxYF7UMAIm/IcopxMHrMQDq3nvKcjPKIhZklUKL+AE7J7uApI4kwe2snsK+eI6UTj9EHg==} - vfile-message@4.0.2: - resolution: {integrity: sha512-jRDZ1IMLttGj41KcZvlrYAaI3CfqpLpfpf+Mfig13viT6NKvRzWZ+lXz0Y5D60w6uJIBAOGq9mSHf0gktF0duw==} + vfile-message@4.0.3: + resolution: {integrity: sha512-QTHzsGd1EhbZs4AsQ20JX1rC3cOlt/IWJruk893DfLRr57lcnOeMaWG4K0JrRta4mIJZKth2Au3mM3u03/JWKw==} - vfile@6.0.1: - resolution: {integrity: sha512-1bYqc7pt6NIADBJ98UiG0Bn/CHIVOoZ/IyEkqIruLg0mE1BKzkOXY2D6CSqQIcKqgadppE5lrxgWXJmXd7zZJw==} + vfile@6.0.3: + resolution: {integrity: sha512-KzIbH/9tXat2u30jf+smMwFCsno4wHVdNmzFyL+T/L3UGqqk6JKfVqOFOZEpZSHADH1k40ab6NUIXZq422ov3Q==} - watchpack@2.4.1: - resolution: {integrity: sha512-8wrBCMtVhqcXP2Sup1ctSkga6uc2Bx0IIvKyT7yTFier5AXHooSI+QyQQAtTb7+E0IUCCKyTFmXqdqgum2XWGg==} + watchpack@2.4.4: + resolution: {integrity: sha512-c5EGNOiyxxV5qmTtAB7rbiXxi1ooX1pQKMLX/MIabJjRA0SJBQOjKF+KSVfHkr9U1cADPon0mRiVe/riyaiDUA==} engines: {node: '>=10.13.0'} wbuf@1.7.3: @@ -4672,18 +5108,21 @@ packages: engines: {node: '>= 10.13.0'} hasBin: true - webpack-dev-middleware@5.3.4: - resolution: {integrity: sha512-BVdTqhhs+0IfoeAf7EoH5WE+exCmqGerHfDM0IL096Px60Tq2Mn9MAbnaGUe6HiMa41KMCYF19gyzZmBcq/o4Q==} - engines: {node: '>= 12.13.0'} + webpack-dev-middleware@7.4.5: + resolution: {integrity: sha512-uxQ6YqGdE4hgDKNf7hUiPXOdtkXvBJXrfEGYSx7P7LC8hnUYGK70X6xQXUvXeNyBDDcsiQXpG2m3G9vxowaEuA==} + engines: {node: '>= 18.12.0'} peerDependencies: - webpack: ^4.0.0 || ^5.0.0 + webpack: ^5.0.0 + peerDependenciesMeta: + webpack: + optional: true - webpack-dev-server@4.15.2: - resolution: {integrity: sha512-0XavAZbNJ5sDrCbkpWL8mia0o5WPOd2YGtxrEiZkBK9FjLppIUK2TgxK6qGD2P3hUXTJNNPVibrerKcx5WkR1g==} - engines: {node: '>= 12.13.0'} + webpack-dev-server@5.2.2: + resolution: {integrity: sha512-QcQ72gh8a+7JO63TAx/6XZf/CWhgMzu5m0QirvPfGvptOusAxG12w2+aua1Jkjr7hzaWDnJ2n6JFeexMHI+Zjg==} + engines: {node: '>= 18.12.0'} hasBin: true peerDependencies: - webpack: ^4.37.0 || ^5.0.0 + webpack: ^5.0.0 webpack-cli: '*' peerDependenciesMeta: webpack: @@ -4695,12 +5134,16 @@ packages: resolution: {integrity: sha512-+4zXKdx7UnO+1jaN4l2lHVD+mFvnlZQP/6ljaJVb4SZiwIKeUnrT5l0gkT8z+n4hKpC+jpOv6O9R+gLtag7pSA==} engines: {node: '>=10.0.0'} - webpack-sources@3.2.3: - resolution: {integrity: sha512-/DyMEOrDgLKKIG0fmvtz+4dUX/3Ghozwgm6iPp8KRhvn+eQf9+Q7GWxVNMk3+uCPWfdXYC4ExGBckIXdFEfH1w==} + webpack-merge@6.0.1: + resolution: {integrity: sha512-hXXvrjtx2PLYx4qruKl+kyRSLc52V+cCvMxRjmKwoA+CBbbF5GfIBtR6kCvl0fYGqTUPKB+1ktVmTHqMOzgCBg==} + engines: {node: '>=18.0.0'} + + webpack-sources@3.3.3: + resolution: {integrity: sha512-yd1RBzSGanHkitROoPFd6qsrxt+oFhg/129YzheDGqeustzX0vTZJZsSsQjVQC4yzBQ56K55XU8gaNCtIzOnTg==} engines: {node: '>=10.13.0'} - webpack@5.92.1: - resolution: {integrity: sha512-JECQ7IwJb+7fgUFBlrJzbyu3GEuNBcdqr1LD7IbSzwkSmIevTm8PF+wej3Oxuz/JFBUZ6O1o43zsPkwm1C4TmA==} + webpack@5.101.3: + resolution: {integrity: sha512-7b0dTKR3Ed//AD/6kkx/o7duS8H3f1a4w3BYpIriX4BzIhjkn4teo05cptsxvLesHFKK5KObnadmCHBwGc+51A==} engines: {node: '>=10.13.0'} hasBin: true peerDependencies: @@ -4709,9 +5152,9 @@ packages: webpack-cli: optional: true - webpackbar@5.0.2: - resolution: {integrity: sha512-BmFJo7veBDgQzfWXl/wwYXr/VFus0614qZ8i9znqcl9fnEdiVkdbi0TedLQ6xAK92HZHDJ0QmyQ0fmuZPAgCYQ==} - engines: {node: '>=12'} + webpackbar@6.0.1: + resolution: {integrity: sha512-TnErZpmuKdwWBdMoexjio3KKX6ZtoKHRVvLIU0A47R0VVBDtx3ZyOJDktgYixhoJokZTYTt1Z37OkO9pnGJa9Q==} + engines: {node: '>=14.21.3'} peerDependencies: webpack: 3 || 4 || 5 @@ -4723,9 +5166,13 @@ packages: resolution: {integrity: sha512-OqedPIGOfsDlo31UNwYbCFMSaO9m9G/0faIHj5/dZFDMFqPTcx6UwqyOy3COEaEOg/9VsGIpdqn62W5KhoKSpg==} engines: {node: '>=0.8.0'} - which@1.3.1: - resolution: {integrity: sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==} - hasBin: true + whatwg-encoding@3.1.1: + resolution: {integrity: sha512-6qN4hJdMwfYBtE3YBTTHhoeuUrDBPZmbQaxWAqSALV/MeEnR5z1xd8UKud2RAkFoPkmB+hli1TZSnyi84xz1vQ==} + engines: {node: '>=18'} + + whatwg-mimetype@4.0.0: + resolution: {integrity: sha512-QaKxh0eNIi2mE9p2vEdzfagOKHCcj1pJ56EEHGQOVxp8r9/iszLUUV7v89x9O1p/T+NlTM5W7jW6+cz4Fq1YVg==} + engines: {node: '>=18'} which@2.0.2: resolution: {integrity: sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==} @@ -4747,9 +5194,6 @@ packages: resolution: {integrity: sha512-si7QWI6zUMq56bESFvagtmzMdGOtoxfR+Sez11Mobfc7tm+VkUckk9bW2UeffTGVUbOksxmSw0AA2gs8g71NCQ==} engines: {node: '>=12'} - wrappy@1.0.2: - resolution: {integrity: sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==} - write-file-atomic@3.0.3: resolution: {integrity: sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q==} @@ -4765,8 +5209,8 @@ packages: utf-8-validate: optional: true - ws@8.17.1: - resolution: {integrity: sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==} + ws@8.18.3: + resolution: {integrity: sha512-PEIGCY5tSlUt50cqyMXfCzX+oOPqN0vuGqWzbcJ2xvnkzkq46oOpz7dQaTDBdfICb4N14+GARUDw2XV2N4tvzg==} engines: {node: '>=10.0.0'} peerDependencies: bufferutil: ^4.0.1 @@ -4777,6 +5221,10 @@ packages: utf-8-validate: optional: true + wsl-utils@0.1.0: + resolution: {integrity: sha512-h3Fbisa2nKGPxCpm89Hk33lBLsnaGBvctQopaBSOW/uIs6FTe1ATyAnKFJrzVs9vpGdsTe73WF3V4lIsk4Gacw==} + engines: {node: '>=18'} + xdg-basedir@5.1.0: resolution: {integrity: sha512-GCPAHLvrIH13+c0SuacwvRYj2SxJXQ4kaVTT5xgL3kPrz56XxkF21IGhjSE1+W0aw7gpBWRGXLCPnPby6lSpmQ==} engines: {node: '>=12'} @@ -4788,1098 +5236,1341 @@ packages: yallist@3.1.1: resolution: {integrity: sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==} - yaml@1.10.2: - resolution: {integrity: sha512-r3vXyErRCYJ7wg28yvBY5VSoAF8ZvlcW9/BwUzEtUsjvX/DKs24dIkuwjtuprwJJHsbyUbLApepYTR1BN4uHrg==} - engines: {node: '>= 6'} - - yaml@2.4.5: - resolution: {integrity: sha512-aBx2bnqDzVOyNKfsysjA2ms5ZlnjSAW2eG3/L5G/CSujfjLJTJsEw1bGw8kCf04KodQWk1pxlGnZ56CRxiawmg==} - engines: {node: '>= 14'} + yaml@2.8.1: + resolution: {integrity: sha512-lcYcMxX2PO9XMGvAJkJ3OsNMw+/7FKes7/hgerGUYWIoWu5j/+YQqcZr5JnPZWzOsEBgMbSbiSTn/dv/69Mkpw==} + engines: {node: '>= 14.6'} hasBin: true - yocto-queue@0.1.0: - resolution: {integrity: sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==} - engines: {node: '>=10'} - - yocto-queue@1.0.0: - resolution: {integrity: sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g==} + yocto-queue@1.2.1: + resolution: {integrity: sha512-AyeEbWOu/TAXdxlV9wmGcR0+yh2j3vYPGOECcIj2S7MkrLyC7ne+oye2BKTItt0ii2PHk4cDy+95+LshzbXnGg==} engines: {node: '>=12.20'} + zod@4.1.11: + resolution: {integrity: sha512-WPsqwxITS2tzx1bzhIKsEs19ABD5vmCVa4xBo2tq/SrV4RNZtfws1EnCWQXM6yh8bD08a1idvkB5MZSBiZsjwg==} + zwitch@2.0.4: resolution: {integrity: sha512-bXE4cR/kVZhKZX/RjPEflHaKVhUVl85noU3v6b8apfQEc1x4A+zBxjZ4lN8LqGd6WZ3dl98pY4o717VFmoPp+A==} snapshots: - '@algolia/autocomplete-core@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.14.0)': + '@ai-sdk/gateway@1.0.30(zod@4.1.11)': + dependencies: + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.10(zod@4.1.11) + zod: 4.1.11 + + '@ai-sdk/provider-utils@3.0.10(zod@4.1.11)': + dependencies: + '@ai-sdk/provider': 2.0.0 + '@standard-schema/spec': 1.0.0 + eventsource-parser: 3.0.6 + zod: 4.1.11 + + '@ai-sdk/provider@2.0.0': + dependencies: + json-schema: 0.4.0 + + '@ai-sdk/react@2.0.56(react@18.3.1)(zod@4.1.11)': + dependencies: + '@ai-sdk/provider-utils': 3.0.10(zod@4.1.11) + ai: 5.0.56(zod@4.1.11) + react: 18.3.1 + swr: 2.3.6(react@18.3.1) + throttleit: 2.1.0 + optionalDependencies: + zod: 4.1.11 + + '@algolia/abtesting@1.5.0': + dependencies: + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 + + '@algolia/autocomplete-core@1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0)(search-insights@2.17.3)': dependencies: - '@algolia/autocomplete-plugin-algolia-insights': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.14.0) - '@algolia/autocomplete-shared': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3) + '@algolia/autocomplete-plugin-algolia-insights': 1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0)(search-insights@2.17.3) + '@algolia/autocomplete-shared': 1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0) transitivePeerDependencies: - '@algolia/client-search' - algoliasearch - search-insights - '@algolia/autocomplete-plugin-algolia-insights@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.14.0)': + '@algolia/autocomplete-plugin-algolia-insights@1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0)(search-insights@2.17.3)': dependencies: - '@algolia/autocomplete-shared': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3) - search-insights: 2.14.0 + '@algolia/autocomplete-shared': 1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0) + search-insights: 2.17.3 transitivePeerDependencies: - '@algolia/client-search' - algoliasearch - '@algolia/autocomplete-preset-algolia@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)': + '@algolia/autocomplete-shared@1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0)': dependencies: - '@algolia/autocomplete-shared': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3) - '@algolia/client-search': 4.23.3 - algoliasearch: 4.23.3 + '@algolia/client-search': 5.39.0 + algoliasearch: 5.39.0 - '@algolia/autocomplete-shared@1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)': + '@algolia/client-abtesting@5.39.0': dependencies: - '@algolia/client-search': 4.23.3 - algoliasearch: 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/cache-browser-local-storage@4.23.3': + '@algolia/client-analytics@5.39.0': dependencies: - '@algolia/cache-common': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/cache-common@4.23.3': {} - - '@algolia/cache-in-memory@4.23.3': - dependencies: - '@algolia/cache-common': 4.23.3 - - '@algolia/client-account@4.23.3': - dependencies: - '@algolia/client-common': 4.23.3 - '@algolia/client-search': 4.23.3 - '@algolia/transporter': 4.23.3 + '@algolia/client-common@5.39.0': {} - '@algolia/client-analytics@4.23.3': + '@algolia/client-insights@5.39.0': dependencies: - '@algolia/client-common': 4.23.3 - '@algolia/client-search': 4.23.3 - '@algolia/requester-common': 4.23.3 - '@algolia/transporter': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/client-common@4.23.3': + '@algolia/client-personalization@5.39.0': dependencies: - '@algolia/requester-common': 4.23.3 - '@algolia/transporter': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/client-personalization@4.23.3': + '@algolia/client-query-suggestions@5.39.0': dependencies: - '@algolia/client-common': 4.23.3 - '@algolia/requester-common': 4.23.3 - '@algolia/transporter': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/client-search@4.23.3': + '@algolia/client-search@5.39.0': dependencies: - '@algolia/client-common': 4.23.3 - '@algolia/requester-common': 4.23.3 - '@algolia/transporter': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 '@algolia/events@4.0.1': {} - '@algolia/logger-common@4.23.3': {} - - '@algolia/logger-console@4.23.3': - dependencies: - '@algolia/logger-common': 4.23.3 - - '@algolia/recommend@4.23.3': + '@algolia/ingestion@1.39.0': dependencies: - '@algolia/cache-browser-local-storage': 4.23.3 - '@algolia/cache-common': 4.23.3 - '@algolia/cache-in-memory': 4.23.3 - '@algolia/client-common': 4.23.3 - '@algolia/client-search': 4.23.3 - '@algolia/logger-common': 4.23.3 - '@algolia/logger-console': 4.23.3 - '@algolia/requester-browser-xhr': 4.23.3 - '@algolia/requester-common': 4.23.3 - '@algolia/requester-node-http': 4.23.3 - '@algolia/transporter': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/requester-browser-xhr@4.23.3': + '@algolia/monitoring@1.39.0': dependencies: - '@algolia/requester-common': 4.23.3 - - '@algolia/requester-common@4.23.3': {} + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/requester-node-http@4.23.3': + '@algolia/recommend@5.39.0': dependencies: - '@algolia/requester-common': 4.23.3 + '@algolia/client-common': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 - '@algolia/transporter@4.23.3': + '@algolia/requester-browser-xhr@5.39.0': dependencies: - '@algolia/cache-common': 4.23.3 - '@algolia/logger-common': 4.23.3 - '@algolia/requester-common': 4.23.3 + '@algolia/client-common': 5.39.0 - '@alloc/quick-lru@5.2.0': {} - - '@ampproject/remapping@2.3.0': + '@algolia/requester-fetch@5.39.0': dependencies: - '@jridgewell/gen-mapping': 0.3.5 - '@jridgewell/trace-mapping': 0.3.25 + '@algolia/client-common': 5.39.0 - '@babel/code-frame@7.24.7': + '@algolia/requester-node-http@5.39.0': dependencies: - '@babel/highlight': 7.24.7 - picocolors: 1.0.1 + '@algolia/client-common': 5.39.0 - '@babel/compat-data@7.24.7': {} + '@alloc/quick-lru@5.2.0': {} - '@babel/core@7.24.7': + '@babel/code-frame@7.27.1': dependencies: - '@ampproject/remapping': 2.3.0 - '@babel/code-frame': 7.24.7 - '@babel/generator': 7.24.7 - '@babel/helper-compilation-targets': 7.24.7 - '@babel/helper-module-transforms': 7.24.7(@babel/core@7.24.7) - '@babel/helpers': 7.24.7 - '@babel/parser': 7.24.7 - '@babel/template': 7.24.7 - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 + '@babel/helper-validator-identifier': 7.27.1 + js-tokens: 4.0.0 + picocolors: 1.1.1 + + '@babel/compat-data@7.28.4': {} + + '@babel/core@7.28.4': + dependencies: + '@babel/code-frame': 7.27.1 + '@babel/generator': 7.28.3 + '@babel/helper-compilation-targets': 7.27.2 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) + '@babel/helpers': 7.28.4 + '@babel/parser': 7.28.4 + '@babel/template': 7.27.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 + '@jridgewell/remapping': 2.3.5 convert-source-map: 2.0.0 - debug: 4.3.5 + debug: 4.4.3 gensync: 1.0.0-beta.2 json5: 2.2.3 semver: 6.3.1 transitivePeerDependencies: - supports-color - '@babel/generator@7.24.7': + '@babel/generator@7.28.3': dependencies: - '@babel/types': 7.24.7 - '@jridgewell/gen-mapping': 0.3.5 - '@jridgewell/trace-mapping': 0.3.25 - jsesc: 2.5.2 + '@babel/parser': 7.28.4 + '@babel/types': 7.28.4 + '@jridgewell/gen-mapping': 0.3.13 + '@jridgewell/trace-mapping': 0.3.31 + jsesc: 3.1.0 - '@babel/helper-annotate-as-pure@7.24.7': + '@babel/helper-annotate-as-pure@7.27.3': dependencies: - '@babel/types': 7.24.7 + '@babel/types': 7.28.4 - '@babel/helper-builder-binary-assignment-operator-visitor@7.24.7': + '@babel/helper-compilation-targets@7.27.2': dependencies: - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 - transitivePeerDependencies: - - supports-color - - '@babel/helper-compilation-targets@7.24.7': - dependencies: - '@babel/compat-data': 7.24.7 - '@babel/helper-validator-option': 7.24.7 - browserslist: 4.23.1 + '@babel/compat-data': 7.28.4 + '@babel/helper-validator-option': 7.27.1 + browserslist: 4.26.2 lru-cache: 5.1.1 semver: 6.3.1 - '@babel/helper-create-class-features-plugin@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-function-name': 7.24.7 - '@babel/helper-member-expression-to-functions': 7.24.7 - '@babel/helper-optimise-call-expression': 7.24.7 - '@babel/helper-replace-supers': 7.24.7(@babel/core@7.24.7) - '@babel/helper-skip-transparent-expression-wrappers': 7.24.7 - '@babel/helper-split-export-declaration': 7.24.7 + '@babel/helper-create-class-features-plugin@7.28.3(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-member-expression-to-functions': 7.27.1 + '@babel/helper-optimise-call-expression': 7.27.1 + '@babel/helper-replace-supers': 7.27.1(@babel/core@7.28.4) + '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 + '@babel/traverse': 7.28.4 semver: 6.3.1 transitivePeerDependencies: - supports-color - '@babel/helper-create-regexp-features-plugin@7.24.7(@babel/core@7.24.7)': + '@babel/helper-create-regexp-features-plugin@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - regexpu-core: 5.3.2 + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + regexpu-core: 6.4.0 semver: 6.3.1 - '@babel/helper-define-polyfill-provider@0.6.2(@babel/core@7.24.7)': + '@babel/helper-define-polyfill-provider@0.6.5(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-compilation-targets': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - debug: 4.3.5 + '@babel/core': 7.28.4 + '@babel/helper-compilation-targets': 7.27.2 + '@babel/helper-plugin-utils': 7.27.1 + debug: 4.4.3 lodash.debounce: 4.0.8 - resolve: 1.22.8 + resolve: 1.22.10 transitivePeerDependencies: - supports-color - '@babel/helper-environment-visitor@7.24.7': - dependencies: - '@babel/types': 7.24.7 + '@babel/helper-globals@7.28.0': {} - '@babel/helper-function-name@7.24.7': + '@babel/helper-member-expression-to-functions@7.27.1': dependencies: - '@babel/template': 7.24.7 - '@babel/types': 7.24.7 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 + transitivePeerDependencies: + - supports-color - '@babel/helper-hoist-variables@7.24.7': + '@babel/helper-module-imports@7.27.1': dependencies: - '@babel/types': 7.24.7 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 + transitivePeerDependencies: + - supports-color - '@babel/helper-member-expression-to-functions@7.24.7': + '@babel/helper-module-transforms@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-imports': 7.27.1 + '@babel/helper-validator-identifier': 7.27.1 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-module-imports@7.24.7': + '@babel/helper-optimise-call-expression@7.27.1': + dependencies: + '@babel/types': 7.28.4 + + '@babel/helper-plugin-utils@7.27.1': {} + + '@babel/helper-remap-async-to-generator@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-wrap-function': 7.28.3 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-module-transforms@7.24.7(@babel/core@7.24.7)': + '@babel/helper-replace-supers@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-module-imports': 7.24.7 - '@babel/helper-simple-access': 7.24.7 - '@babel/helper-split-export-declaration': 7.24.7 - '@babel/helper-validator-identifier': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-member-expression-to-functions': 7.27.1 + '@babel/helper-optimise-call-expression': 7.27.1 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-optimise-call-expression@7.24.7': + '@babel/helper-skip-transparent-expression-wrappers@7.27.1': dependencies: - '@babel/types': 7.24.7 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 + transitivePeerDependencies: + - supports-color + + '@babel/helper-string-parser@7.27.1': {} - '@babel/helper-plugin-utils@7.24.7': {} + '@babel/helper-validator-identifier@7.27.1': {} - '@babel/helper-remap-async-to-generator@7.24.7(@babel/core@7.24.7)': + '@babel/helper-validator-option@7.27.1': {} + + '@babel/helper-wrap-function@7.28.3': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-wrap-function': 7.24.7 + '@babel/template': 7.27.2 + '@babel/traverse': 7.28.4 + '@babel/types': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-replace-supers@7.24.7(@babel/core@7.24.7)': + '@babel/helpers@7.28.4': + dependencies: + '@babel/template': 7.27.2 + '@babel/types': 7.28.4 + + '@babel/parser@7.28.4': + dependencies: + '@babel/types': 7.28.4 + + '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-member-expression-to-functions': 7.24.7 - '@babel/helper-optimise-call-expression': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-simple-access@7.24.7': + '@babel/plugin-bugfix-safari-class-field-initializer-scope@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 + '@babel/plugin-transform-optional-chaining': 7.27.1(@babel/core@7.28.4) transitivePeerDependencies: - supports-color - '@babel/helper-skip-transparent-expression-wrappers@7.24.7': + '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helper-split-export-declaration@7.24.7': + '@babel/plugin-proposal-private-property-in-object@7.21.0-placeholder-for-preset-env.2(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + + '@babel/plugin-syntax-dynamic-import@7.8.3(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-syntax-import-assertions@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-syntax-import-attributes@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-syntax-jsx@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/helper-string-parser@7.24.7': {} + '@babel/plugin-syntax-typescript@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/helper-validator-identifier@7.24.7': {} + '@babel/plugin-syntax-unicode-sets-regex@7.18.6(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 - '@babel/helper-validator-option@7.24.7': {} + '@babel/plugin-transform-arrow-functions@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/helper-wrap-function@7.24.7': + '@babel/plugin-transform-async-generator-functions@7.28.0(@babel/core@7.28.4)': dependencies: - '@babel/helper-function-name': 7.24.7 - '@babel/template': 7.24.7 - '@babel/traverse': 7.24.7 - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-remap-async-to-generator': 7.27.1(@babel/core@7.28.4) + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/helpers@7.24.7': + '@babel/plugin-transform-async-to-generator@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/template': 7.24.7 - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-imports': 7.27.1 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-remap-async-to-generator': 7.27.1(@babel/core@7.28.4) + transitivePeerDependencies: + - supports-color - '@babel/highlight@7.24.7': + '@babel/plugin-transform-block-scoped-functions@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/helper-validator-identifier': 7.24.7 - chalk: 2.4.2 - js-tokens: 4.0.0 - picocolors: 1.0.1 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/parser@7.24.7': + '@babel/plugin-transform-block-scoping@7.28.4(@babel/core@7.28.4)': dependencies: - '@babel/types': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-bugfix-firefox-class-in-computed-class-key@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-class-properties@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-class-static-block@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-classes@7.28.4(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-skip-transparent-expression-wrappers': 7.24.7 - '@babel/plugin-transform-optional-chaining': 7.24.7(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-compilation-targets': 7.27.2 + '@babel/helper-globals': 7.28.0 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-replace-supers': 7.27.1(@babel/core@7.28.4) + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-computed-properties@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/template': 7.27.2 - '@babel/plugin-proposal-private-property-in-object@7.21.0-placeholder-for-preset-env.2(@babel/core@7.24.7)': + '@babel/plugin-transform-destructuring@7.28.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/traverse': 7.28.4 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-async-generators@7.8.4(@babel/core@7.24.7)': + '@babel/plugin-transform-dotall-regex@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-class-properties@7.12.13(@babel/core@7.24.7)': + '@babel/plugin-transform-duplicate-keys@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-class-static-block@7.14.5(@babel/core@7.24.7)': + '@babel/plugin-transform-duplicate-named-capturing-groups-regex@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-dynamic-import@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-dynamic-import@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-export-namespace-from@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-explicit-resource-management@7.28.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/plugin-transform-destructuring': 7.28.0(@babel/core@7.28.4) + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-import-assertions@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-exponentiation-operator@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-import-attributes@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-export-namespace-from@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-import-meta@7.10.4(@babel/core@7.24.7)': + '@babel/plugin-transform-for-of@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-json-strings@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-function-name@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-compilation-targets': 7.27.2 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/traverse': 7.28.4 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-jsx@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-json-strings@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-logical-assignment-operators@7.10.4(@babel/core@7.24.7)': + '@babel/plugin-transform-literals@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-nullish-coalescing-operator@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-logical-assignment-operators@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-numeric-separator@7.10.4(@babel/core@7.24.7)': + '@babel/plugin-transform-member-expression-literals@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-object-rest-spread@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-modules-amd@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-optional-catch-binding@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-modules-commonjs@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-optional-chaining@7.8.3(@babel/core@7.24.7)': + '@babel/plugin-transform-modules-systemjs@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-validator-identifier': 7.27.1 + '@babel/traverse': 7.28.4 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-private-property-in-object@7.14.5(@babel/core@7.24.7)': + '@babel/plugin-transform-modules-umd@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-transforms': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-syntax-top-level-await@7.14.5(@babel/core@7.24.7)': + '@babel/plugin-transform-named-capturing-groups-regex@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-typescript@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-new-target@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-syntax-unicode-sets-regex@7.18.6(@babel/core@7.24.7)': + '@babel/plugin-transform-nullish-coalescing-operator@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-regexp-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-arrow-functions@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-numeric-separator@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-async-generator-functions@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-object-rest-spread@7.28.4(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-remap-async-to-generator': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-syntax-async-generators': 7.8.4(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-compilation-targets': 7.27.2 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/plugin-transform-destructuring': 7.28.0(@babel/core@7.28.4) + '@babel/plugin-transform-parameters': 7.27.7(@babel/core@7.28.4) + '@babel/traverse': 7.28.4 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-async-to-generator@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-object-super@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-module-imports': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-remap-async-to-generator': 7.24.7(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-replace-supers': 7.27.1(@babel/core@7.28.4) transitivePeerDependencies: - supports-color - '@babel/plugin-transform-block-scoped-functions@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-optional-catch-binding@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-optional-chaining@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-transform-block-scoping@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-parameters@7.27.7(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-class-properties@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-private-methods@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-class-static-block@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-private-property-in-object@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-class-static-block': 7.14.5(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-classes@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-compilation-targets': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-function-name': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-replace-supers': 7.24.7(@babel/core@7.24.7) - '@babel/helper-split-export-declaration': 7.24.7 - globals: 11.12.0 + '@babel/plugin-transform-property-literals@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-react-constant-elements@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-react-display-name@7.28.0(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-react-jsx-development@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/plugin-transform-react-jsx': 7.27.1(@babel/core@7.28.4) transitivePeerDependencies: - supports-color - '@babel/plugin-transform-computed-properties@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-react-jsx@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/template': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-module-imports': 7.27.1 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/plugin-syntax-jsx': 7.27.1(@babel/core@7.28.4) + '@babel/types': 7.28.4 + transitivePeerDependencies: + - supports-color - '@babel/plugin-transform-destructuring@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-react-pure-annotations@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-dotall-regex@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-regenerator@7.28.4(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-regexp-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-duplicate-keys@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-regexp-modifiers@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-dynamic-import@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-reserved-words@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-exponentiation-operator@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-runtime@7.28.3(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-builder-binary-assignment-operator-visitor': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-module-imports': 7.27.1 + '@babel/helper-plugin-utils': 7.27.1 + babel-plugin-polyfill-corejs2: 0.4.14(@babel/core@7.28.4) + babel-plugin-polyfill-corejs3: 0.13.0(@babel/core@7.28.4) + babel-plugin-polyfill-regenerator: 0.6.5(@babel/core@7.28.4) + semver: 6.3.1 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-export-namespace-from@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-shorthand-properties@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-export-namespace-from': 7.8.3(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-for-of@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-spread@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-skip-transparent-expression-wrappers': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-function-name@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-sticky-regex@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-compilation-targets': 7.24.7 - '@babel/helper-function-name': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-json-strings@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-template-literals@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-json-strings': 7.8.3(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-literals@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-typeof-symbol@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 - '@babel/plugin-transform-logical-assignment-operators@7.24.7(@babel/core@7.24.7)': + '@babel/plugin-transform-typescript@7.28.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-logical-assignment-operators': 7.10.4(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-annotate-as-pure': 7.27.3 + '@babel/helper-create-class-features-plugin': 7.28.3(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-skip-transparent-expression-wrappers': 7.27.1 + '@babel/plugin-syntax-typescript': 7.27.1(@babel/core@7.28.4) + transitivePeerDependencies: + - supports-color + + '@babel/plugin-transform-unicode-escapes@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-unicode-property-regex@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-unicode-regex@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/plugin-transform-unicode-sets-regex@7.27.1(@babel/core@7.28.4)': + dependencies: + '@babel/core': 7.28.4 + '@babel/helper-create-regexp-features-plugin': 7.27.1(@babel/core@7.28.4) + '@babel/helper-plugin-utils': 7.27.1 + + '@babel/preset-env@7.28.3(@babel/core@7.28.4)': + dependencies: + '@babel/compat-data': 7.28.4 + '@babel/core': 7.28.4 + '@babel/helper-compilation-targets': 7.27.2 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-validator-option': 7.27.1 + '@babel/plugin-bugfix-firefox-class-in-computed-class-key': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-bugfix-safari-class-field-initializer-scope': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly': 7.28.3(@babel/core@7.28.4) + '@babel/plugin-proposal-private-property-in-object': 7.21.0-placeholder-for-preset-env.2(@babel/core@7.28.4) + '@babel/plugin-syntax-import-assertions': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-syntax-import-attributes': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-syntax-unicode-sets-regex': 7.18.6(@babel/core@7.28.4) + '@babel/plugin-transform-arrow-functions': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-async-generator-functions': 7.28.0(@babel/core@7.28.4) + '@babel/plugin-transform-async-to-generator': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-block-scoped-functions': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-block-scoping': 7.28.4(@babel/core@7.28.4) + '@babel/plugin-transform-class-properties': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-class-static-block': 7.28.3(@babel/core@7.28.4) + '@babel/plugin-transform-classes': 7.28.4(@babel/core@7.28.4) + '@babel/plugin-transform-computed-properties': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-destructuring': 7.28.0(@babel/core@7.28.4) + '@babel/plugin-transform-dotall-regex': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-duplicate-keys': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-duplicate-named-capturing-groups-regex': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-dynamic-import': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-explicit-resource-management': 7.28.0(@babel/core@7.28.4) + '@babel/plugin-transform-exponentiation-operator': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-export-namespace-from': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-for-of': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-function-name': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-json-strings': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-literals': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-logical-assignment-operators': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-member-expression-literals': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-modules-amd': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-modules-commonjs': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-modules-systemjs': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-modules-umd': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-named-capturing-groups-regex': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-new-target': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-nullish-coalescing-operator': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-numeric-separator': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-object-rest-spread': 7.28.4(@babel/core@7.28.4) + '@babel/plugin-transform-object-super': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-optional-catch-binding': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-optional-chaining': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-parameters': 7.27.7(@babel/core@7.28.4) + '@babel/plugin-transform-private-methods': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-private-property-in-object': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-property-literals': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-regenerator': 7.28.4(@babel/core@7.28.4) + '@babel/plugin-transform-regexp-modifiers': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-reserved-words': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-shorthand-properties': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-spread': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-sticky-regex': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-template-literals': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-typeof-symbol': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-unicode-escapes': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-unicode-property-regex': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-unicode-regex': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-unicode-sets-regex': 7.27.1(@babel/core@7.28.4) + '@babel/preset-modules': 0.1.6-no-external-plugins(@babel/core@7.28.4) + babel-plugin-polyfill-corejs2: 0.4.14(@babel/core@7.28.4) + babel-plugin-polyfill-corejs3: 0.13.0(@babel/core@7.28.4) + babel-plugin-polyfill-regenerator: 0.6.5(@babel/core@7.28.4) + core-js-compat: 3.45.1 + semver: 6.3.1 + transitivePeerDependencies: + - supports-color - '@babel/plugin-transform-member-expression-literals@7.24.7(@babel/core@7.24.7)': + '@babel/preset-modules@0.1.6-no-external-plugins(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/types': 7.28.4 + esutils: 2.0.3 - '@babel/plugin-transform-modules-amd@7.24.7(@babel/core@7.24.7)': + '@babel/preset-react@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-module-transforms': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-validator-option': 7.27.1 + '@babel/plugin-transform-react-display-name': 7.28.0(@babel/core@7.28.4) + '@babel/plugin-transform-react-jsx': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-react-jsx-development': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-react-pure-annotations': 7.27.1(@babel/core@7.28.4) transitivePeerDependencies: - supports-color - '@babel/plugin-transform-modules-commonjs@7.24.7(@babel/core@7.24.7)': + '@babel/preset-typescript@7.27.1(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-module-transforms': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-simple-access': 7.24.7 + '@babel/core': 7.28.4 + '@babel/helper-plugin-utils': 7.27.1 + '@babel/helper-validator-option': 7.27.1 + '@babel/plugin-syntax-jsx': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-modules-commonjs': 7.27.1(@babel/core@7.28.4) + '@babel/plugin-transform-typescript': 7.28.0(@babel/core@7.28.4) transitivePeerDependencies: - supports-color - '@babel/plugin-transform-modules-systemjs@7.24.7(@babel/core@7.24.7)': + '@babel/runtime-corejs3@7.28.4': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-hoist-variables': 7.24.7 - '@babel/helper-module-transforms': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-validator-identifier': 7.24.7 - transitivePeerDependencies: - - supports-color + core-js-pure: 3.45.1 + + '@babel/runtime@7.28.4': {} + + '@babel/template@7.27.2': + dependencies: + '@babel/code-frame': 7.27.1 + '@babel/parser': 7.28.4 + '@babel/types': 7.28.4 - '@babel/plugin-transform-modules-umd@7.24.7(@babel/core@7.24.7)': + '@babel/traverse@7.28.4': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-module-transforms': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 + '@babel/code-frame': 7.27.1 + '@babel/generator': 7.28.3 + '@babel/helper-globals': 7.28.0 + '@babel/parser': 7.28.4 + '@babel/template': 7.27.2 + '@babel/types': 7.28.4 + debug: 4.4.3 transitivePeerDependencies: - supports-color - '@babel/plugin-transform-named-capturing-groups-regex@7.24.7(@babel/core@7.24.7)': + '@babel/types@7.28.4': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-regexp-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 + '@babel/helper-string-parser': 7.27.1 + '@babel/helper-validator-identifier': 7.27.1 + + '@colors/colors@1.5.0': + optional: true - '@babel/plugin-transform-new-target@7.24.7(@babel/core@7.24.7)': + '@csstools/cascade-layer-name-parser@2.0.5(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 - '@babel/plugin-transform-nullish-coalescing-operator@7.24.7(@babel/core@7.24.7)': + '@csstools/color-helpers@5.1.0': {} + + '@csstools/css-calc@2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.24.7) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 - '@babel/plugin-transform-numeric-separator@7.24.7(@babel/core@7.24.7)': + '@csstools/css-color-parser@3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-numeric-separator': 7.10.4(@babel/core@7.24.7) + '@csstools/color-helpers': 5.1.0 + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 - '@babel/plugin-transform-object-rest-spread@7.24.7(@babel/core@7.24.7)': + '@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-compilation-targets': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-object-rest-spread': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-transform-parameters': 7.24.7(@babel/core@7.24.7) + '@csstools/css-tokenizer': 3.0.4 + + '@csstools/css-tokenizer@3.0.4': {} - '@babel/plugin-transform-object-super@7.24.7(@babel/core@7.24.7)': + '@csstools/media-query-list-parser@4.0.3(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-replace-supers': 7.24.7(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 - '@babel/plugin-transform-optional-catch-binding@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-alpha-function@1.0.1(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-optional-catch-binding': 7.8.3(@babel/core@7.24.7) + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-optional-chaining@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-cascade-layers@5.0.2(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-skip-transparent-expression-wrappers': 7.24.7 - '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + '@csstools/selector-specificity': 5.0.0(postcss-selector-parser@7.1.0) + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 - '@babel/plugin-transform-parameters@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-color-function-display-p3-linear@1.0.1(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-private-methods@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-color-function@4.0.12(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - transitivePeerDependencies: - - supports-color + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-private-property-in-object@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-color-mix-function@3.0.12(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-private-property-in-object': 7.14.5(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-property-literals@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-color-mix-variadic-function-arguments@1.0.2(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-react-constant-elements@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-content-alt-text@2.0.8(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-react-display-name@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-contrast-color-function@2.0.12(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-react-jsx-development@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-exponential-functions@2.0.9(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/plugin-transform-react-jsx': 7.24.7(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 - '@babel/plugin-transform-react-jsx@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-font-format-keywords@4.0.0(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-module-imports': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-jsx': 7.24.7(@babel/core@7.24.7) - '@babel/types': 7.24.7 - transitivePeerDependencies: - - supports-color + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - '@babel/plugin-transform-react-pure-annotations@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-gamut-mapping@2.0.11(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 - '@babel/plugin-transform-regenerator@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-gradients-interpolation-method@5.0.12(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - regenerator-transform: 0.15.2 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-reserved-words@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-hwb-function@4.0.12(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-runtime@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-ic-unit@4.0.4(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-module-imports': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - babel-plugin-polyfill-corejs2: 0.4.11(@babel/core@7.24.7) - babel-plugin-polyfill-corejs3: 0.10.4(@babel/core@7.24.7) - babel-plugin-polyfill-regenerator: 0.6.2(@babel/core@7.24.7) - semver: 6.3.1 - transitivePeerDependencies: - - supports-color + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - '@babel/plugin-transform-shorthand-properties@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-initial@2.0.1(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + postcss: 8.5.6 - '@babel/plugin-transform-spread@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-is-pseudo-class@5.0.3(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-skip-transparent-expression-wrappers': 7.24.7 - transitivePeerDependencies: - - supports-color + '@csstools/selector-specificity': 5.0.0(postcss-selector-parser@7.1.0) + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 - '@babel/plugin-transform-sticky-regex@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-light-dark-function@2.0.11(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/plugin-transform-template-literals@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-logical-float-and-clear@3.0.0(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + postcss: 8.5.6 - '@babel/plugin-transform-typeof-symbol@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-logical-overflow@2.0.0(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 + postcss: 8.5.6 - '@babel/plugin-transform-typescript@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-logical-overscroll-behavior@2.0.0(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-annotate-as-pure': 7.24.7 - '@babel/helper-create-class-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - '@babel/plugin-syntax-typescript': 7.24.7(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + postcss: 8.5.6 - '@babel/plugin-transform-unicode-escapes@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - - '@babel/plugin-transform-unicode-property-regex@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-regexp-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - - '@babel/plugin-transform-unicode-regex@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-regexp-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - - '@babel/plugin-transform-unicode-sets-regex@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/core': 7.24.7 - '@babel/helper-create-regexp-features-plugin': 7.24.7(@babel/core@7.24.7) - '@babel/helper-plugin-utils': 7.24.7 - - '@babel/preset-env@7.24.7(@babel/core@7.24.7)': - dependencies: - '@babel/compat-data': 7.24.7 - '@babel/core': 7.24.7 - '@babel/helper-compilation-targets': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-validator-option': 7.24.7 - '@babel/plugin-bugfix-firefox-class-in-computed-class-key': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-proposal-private-property-in-object': 7.21.0-placeholder-for-preset-env.2(@babel/core@7.24.7) - '@babel/plugin-syntax-async-generators': 7.8.4(@babel/core@7.24.7) - '@babel/plugin-syntax-class-properties': 7.12.13(@babel/core@7.24.7) - '@babel/plugin-syntax-class-static-block': 7.14.5(@babel/core@7.24.7) - '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-export-namespace-from': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-import-assertions': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-syntax-import-attributes': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-syntax-import-meta': 7.10.4(@babel/core@7.24.7) - '@babel/plugin-syntax-json-strings': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-logical-assignment-operators': 7.10.4(@babel/core@7.24.7) - '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-numeric-separator': 7.10.4(@babel/core@7.24.7) - '@babel/plugin-syntax-object-rest-spread': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-optional-catch-binding': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-syntax-private-property-in-object': 7.14.5(@babel/core@7.24.7) - '@babel/plugin-syntax-top-level-await': 7.14.5(@babel/core@7.24.7) - '@babel/plugin-syntax-unicode-sets-regex': 7.18.6(@babel/core@7.24.7) - '@babel/plugin-transform-arrow-functions': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-async-generator-functions': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-async-to-generator': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-block-scoped-functions': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-block-scoping': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-class-properties': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-class-static-block': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-classes': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-computed-properties': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-destructuring': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-dotall-regex': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-duplicate-keys': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-dynamic-import': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-exponentiation-operator': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-export-namespace-from': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-for-of': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-function-name': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-json-strings': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-literals': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-logical-assignment-operators': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-member-expression-literals': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-modules-amd': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-modules-commonjs': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-modules-systemjs': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-modules-umd': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-named-capturing-groups-regex': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-new-target': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-nullish-coalescing-operator': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-numeric-separator': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-object-rest-spread': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-object-super': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-optional-catch-binding': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-optional-chaining': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-parameters': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-private-methods': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-private-property-in-object': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-property-literals': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-regenerator': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-reserved-words': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-shorthand-properties': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-spread': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-sticky-regex': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-template-literals': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-typeof-symbol': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-unicode-escapes': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-unicode-property-regex': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-unicode-regex': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-unicode-sets-regex': 7.24.7(@babel/core@7.24.7) - '@babel/preset-modules': 0.1.6-no-external-plugins(@babel/core@7.24.7) - babel-plugin-polyfill-corejs2: 0.4.11(@babel/core@7.24.7) - babel-plugin-polyfill-corejs3: 0.10.4(@babel/core@7.24.7) - babel-plugin-polyfill-regenerator: 0.6.2(@babel/core@7.24.7) - core-js-compat: 3.37.1 - semver: 6.3.1 - transitivePeerDependencies: - - supports-color + '@csstools/postcss-logical-resize@3.0.0(postcss@8.5.6)': + dependencies: + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - '@babel/preset-modules@0.1.6-no-external-plugins(@babel/core@7.24.7)': + '@csstools/postcss-logical-viewport-units@3.0.4(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/types': 7.24.7 - esutils: 2.0.3 + '@csstools/css-tokenizer': 3.0.4 + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/preset-react@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-media-minmax@2.0.9(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-validator-option': 7.24.7 - '@babel/plugin-transform-react-display-name': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-react-jsx': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-react-jsx-development': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-react-pure-annotations': 7.24.7(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/media-query-list-parser': 4.0.3(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + postcss: 8.5.6 - '@babel/preset-typescript@7.24.7(@babel/core@7.24.7)': + '@csstools/postcss-media-queries-aspect-ratio-number-values@3.0.5(postcss@8.5.6)': dependencies: - '@babel/core': 7.24.7 - '@babel/helper-plugin-utils': 7.24.7 - '@babel/helper-validator-option': 7.24.7 - '@babel/plugin-syntax-jsx': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-modules-commonjs': 7.24.7(@babel/core@7.24.7) - '@babel/plugin-transform-typescript': 7.24.7(@babel/core@7.24.7) - transitivePeerDependencies: - - supports-color + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/media-query-list-parser': 4.0.3(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + postcss: 8.5.6 - '@babel/regjsgen@0.8.0': {} + '@csstools/postcss-nested-calc@4.0.0(postcss@8.5.6)': + dependencies: + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - '@babel/runtime-corejs3@7.24.7': + '@csstools/postcss-normalize-display-values@4.0.0(postcss@8.5.6)': dependencies: - core-js-pure: 3.37.1 - regenerator-runtime: 0.14.1 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - '@babel/runtime@7.24.7': + '@csstools/postcss-oklab-function@4.0.12(postcss@8.5.6)': dependencies: - regenerator-runtime: 0.14.1 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - '@babel/template@7.24.7': + '@csstools/postcss-progressive-custom-properties@4.2.1(postcss@8.5.6)': dependencies: - '@babel/code-frame': 7.24.7 - '@babel/parser': 7.24.7 - '@babel/types': 7.24.7 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - '@babel/traverse@7.24.7': + '@csstools/postcss-random-function@2.0.1(postcss@8.5.6)': dependencies: - '@babel/code-frame': 7.24.7 - '@babel/generator': 7.24.7 - '@babel/helper-environment-visitor': 7.24.7 - '@babel/helper-function-name': 7.24.7 - '@babel/helper-hoist-variables': 7.24.7 - '@babel/helper-split-export-declaration': 7.24.7 - '@babel/parser': 7.24.7 - '@babel/types': 7.24.7 - debug: 4.3.5 - globals: 11.12.0 - transitivePeerDependencies: - - supports-color + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 + + '@csstools/postcss-relative-color-syntax@3.0.12(postcss@8.5.6)': + dependencies: + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 + + '@csstools/postcss-scope-pseudo-class@4.0.1(postcss@8.5.6)': + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + '@csstools/postcss-sign-functions@1.1.4(postcss@8.5.6)': + dependencies: + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 + + '@csstools/postcss-stepped-value-functions@4.0.9(postcss@8.5.6)': + dependencies: + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 + + '@csstools/postcss-text-decoration-shorthand@4.0.3(postcss@8.5.6)': + dependencies: + '@csstools/color-helpers': 5.1.0 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + + '@csstools/postcss-trigonometric-functions@4.0.9(postcss@8.5.6)': + dependencies: + '@csstools/css-calc': 2.1.4(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 + + '@csstools/postcss-unset-value@4.0.0(postcss@8.5.6)': + dependencies: + postcss: 8.5.6 + + '@csstools/selector-resolve-nested@3.1.0(postcss-selector-parser@7.1.0)': + dependencies: + postcss-selector-parser: 7.1.0 - '@babel/types@7.24.7': + '@csstools/selector-specificity@5.0.0(postcss-selector-parser@7.1.0)': dependencies: - '@babel/helper-string-parser': 7.24.7 - '@babel/helper-validator-identifier': 7.24.7 - to-fast-properties: 2.0.0 + postcss-selector-parser: 7.1.0 - '@colors/colors@1.5.0': - optional: true + '@csstools/utilities@2.0.0(postcss@8.5.6)': + dependencies: + postcss: 8.5.6 '@discoveryjs/json-ext@0.5.7': {} - '@docsearch/css@3.6.0': {} + '@docsearch/css@4.1.0': {} - '@docsearch/react@3.6.0(@algolia/client-search@4.23.3)(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.14.0)': + '@docsearch/react@4.1.0(@algolia/client-search@5.39.0)(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.17.3)': dependencies: - '@algolia/autocomplete-core': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3)(search-insights@2.14.0) - '@algolia/autocomplete-preset-algolia': 1.9.3(@algolia/client-search@4.23.3)(algoliasearch@4.23.3) - '@docsearch/css': 3.6.0 - algoliasearch: 4.23.3 + '@ai-sdk/react': 2.0.56(react@18.3.1)(zod@4.1.11) + '@algolia/autocomplete-core': 1.19.2(@algolia/client-search@5.39.0)(algoliasearch@5.39.0)(search-insights@2.17.3) + '@docsearch/css': 4.1.0 + ai: 5.0.56(zod@4.1.11) + algoliasearch: 5.39.0 + marked: 16.3.0 + zod: 4.1.11 optionalDependencies: - '@types/react': 18.3.3 + '@types/react': 19.1.15 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - search-insights: 2.14.0 + search-insights: 2.17.3 transitivePeerDependencies: - '@algolia/client-search' - '@docusaurus/core@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': - dependencies: - '@babel/core': 7.24.7 - '@babel/generator': 7.24.7 - '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.24.7) - '@babel/plugin-transform-runtime': 7.24.7(@babel/core@7.24.7) - '@babel/preset-env': 7.24.7(@babel/core@7.24.7) - '@babel/preset-react': 7.24.7(@babel/core@7.24.7) - '@babel/preset-typescript': 7.24.7(@babel/core@7.24.7) - '@babel/runtime': 7.24.7 - '@babel/runtime-corejs3': 7.24.7 - '@babel/traverse': 7.24.7 - '@docusaurus/cssnano-preset': 3.4.0 - '@docusaurus/logger': 3.4.0 - '@docusaurus/mdx-loader': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - autoprefixer: 10.4.19(postcss@8.4.38) - babel-loader: 9.1.3(@babel/core@7.24.7)(webpack@5.92.1) + '@docusaurus/babel@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': + dependencies: + '@babel/core': 7.28.4 + '@babel/generator': 7.28.3 + '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.28.4) + '@babel/plugin-transform-runtime': 7.28.3(@babel/core@7.28.4) + '@babel/preset-env': 7.28.3(@babel/core@7.28.4) + '@babel/preset-react': 7.27.1(@babel/core@7.28.4) + '@babel/preset-typescript': 7.27.1(@babel/core@7.28.4) + '@babel/runtime': 7.28.4 + '@babel/runtime-corejs3': 7.28.4 + '@babel/traverse': 7.28.4 + '@docusaurus/logger': 3.9.1 + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) babel-plugin-dynamic-import-node: 2.3.3 + fs-extra: 11.3.2 + tslib: 2.8.1 + transitivePeerDependencies: + - '@swc/core' + - esbuild + - react + - react-dom + - supports-color + - uglify-js + - webpack-cli + + '@docusaurus/bundler@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@babel/core': 7.28.4 + '@docusaurus/babel': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/cssnano-preset': 3.9.1 + '@docusaurus/logger': 3.9.1 + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + babel-loader: 9.2.1(@babel/core@7.28.4)(webpack@5.101.3) + clean-css: 5.3.3 + copy-webpack-plugin: 11.0.0(webpack@5.101.3) + css-loader: 6.11.0(webpack@5.101.3) + css-minimizer-webpack-plugin: 5.0.1(clean-css@5.3.3)(webpack@5.101.3) + cssnano: 6.1.2(postcss@8.5.6) + file-loader: 6.2.0(webpack@5.101.3) + html-minifier-terser: 7.2.0 + mini-css-extract-plugin: 2.9.4(webpack@5.101.3) + null-loader: 4.0.1(webpack@5.101.3) + postcss: 8.5.6 + postcss-loader: 7.3.4(postcss@8.5.6)(typescript@5.2.2)(webpack@5.101.3) + postcss-preset-env: 10.4.0(postcss@8.5.6) + terser-webpack-plugin: 5.3.14(webpack@5.101.3) + tslib: 2.8.1 + url-loader: 4.1.1(file-loader@6.2.0(webpack@5.101.3))(webpack@5.101.3) + webpack: 5.101.3 + webpackbar: 6.0.1(webpack@5.101.3) + transitivePeerDependencies: + - '@parcel/css' + - '@rspack/core' + - '@swc/core' + - '@swc/css' + - csso + - esbuild + - lightningcss + - react + - react-dom + - supports-color + - typescript + - uglify-js + - webpack-cli + + '@docusaurus/core@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@docusaurus/babel': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/bundler': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/mdx-loader': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@mdx-js/react': 3.1.1(@types/react@19.1.15)(react@18.3.1) boxen: 6.2.1 chalk: 4.1.2 chokidar: 3.6.0 - clean-css: 5.3.3 cli-table3: 0.6.5 combine-promises: 1.2.0 commander: 5.1.0 - copy-webpack-plugin: 11.0.0(webpack@5.92.1) - core-js: 3.37.1 - css-loader: 6.11.0(webpack@5.92.1) - css-minimizer-webpack-plugin: 5.0.1(clean-css@5.3.3)(webpack@5.92.1) - cssnano: 6.1.2(postcss@8.4.38) - del: 6.1.1 + core-js: 3.45.1 detect-port: 1.6.1 escape-html: 1.0.3 eta: 2.2.0 eval: 0.1.8 - file-loader: 6.2.0(webpack@5.92.1) - fs-extra: 11.2.0 - html-minifier-terser: 7.2.0 + execa: 5.1.1 + fs-extra: 11.3.2 html-tags: 3.3.1 - html-webpack-plugin: 5.6.0(webpack@5.92.1) + html-webpack-plugin: 5.6.4(webpack@5.101.3) leven: 3.1.0 lodash: 4.17.21 - mini-css-extract-plugin: 2.9.0(webpack@5.92.1) + open: 8.4.2 p-map: 4.0.0 - postcss: 8.4.38 - postcss-loader: 7.3.4(postcss@8.4.38)(typescript@5.2.2)(webpack@5.92.1) prompts: 2.4.2 react: 18.3.1 - react-dev-utils: 12.0.1(typescript@5.2.2)(webpack@5.92.1) react-dom: 18.3.1(react@18.3.1) - react-helmet-async: 1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + react-helmet-async: '@slorber/react-helmet-async@1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)' react-loadable: '@docusaurus/react-loadable@6.0.0(react@18.3.1)' - react-loadable-ssr-addon-v5-slorber: 1.0.1(@docusaurus/react-loadable@6.0.0(react@18.3.1))(webpack@5.92.1) + react-loadable-ssr-addon-v5-slorber: 1.0.1(@docusaurus/react-loadable@6.0.0(react@18.3.1))(webpack@5.101.3) react-router: 5.3.4(react@18.3.1) react-router-config: 5.1.1(react-router@5.3.4(react@18.3.1))(react@18.3.1) react-router-dom: 5.3.4(react@18.3.1) - rtl-detect: 1.1.2 - semver: 7.6.2 - serve-handler: 6.1.5 - shelljs: 0.8.5 - terser-webpack-plugin: 5.3.10(webpack@5.92.1) - tslib: 2.6.3 + semver: 7.7.2 + serve-handler: 6.1.6 + tinypool: 1.1.1 + tslib: 2.8.1 update-notifier: 6.0.2 - url-loader: 4.1.1(file-loader@6.2.0(webpack@5.92.1))(webpack@5.92.1) - webpack: 5.92.1 + webpack: 5.101.3 webpack-bundle-analyzer: 4.10.2 - webpack-dev-server: 4.15.2(debug@4.3.5)(webpack@5.92.1) - webpack-merge: 5.10.0 - webpackbar: 5.0.2(webpack@5.92.1) + webpack-dev-server: 5.2.2(debug@4.4.3)(webpack@5.101.3) + webpack-merge: 6.0.1 transitivePeerDependencies: - - '@docusaurus/types' + - '@docusaurus/faster' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -5888,74 +6579,70 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/cssnano-preset@3.4.0': + '@docusaurus/cssnano-preset@3.9.1': dependencies: - cssnano-preset-advanced: 6.1.2(postcss@8.4.38) - postcss: 8.4.38 - postcss-sort-media-queries: 5.2.0(postcss@8.4.38) - tslib: 2.6.3 + cssnano-preset-advanced: 6.1.2(postcss@8.5.6) + postcss: 8.5.6 + postcss-sort-media-queries: 5.2.0(postcss@8.5.6) + tslib: 2.8.1 - '@docusaurus/logger@3.4.0': + '@docusaurus/logger@3.9.1': dependencies: chalk: 4.1.2 - tslib: 2.6.3 + tslib: 2.8.1 - '@docusaurus/mdx-loader@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/mdx-loader@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - '@docusaurus/logger': 3.4.0 - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@mdx-js/mdx': 3.0.1 + '@docusaurus/logger': 3.9.1 + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@mdx-js/mdx': 3.1.1 '@slorber/remark-comment': 1.0.0 escape-html: 1.0.3 - estree-util-value-to-estree: 3.1.2 - file-loader: 6.2.0(webpack@5.92.1) - fs-extra: 11.2.0 - image-size: 1.1.1 + estree-util-value-to-estree: 3.4.0 + file-loader: 6.2.0(webpack@5.101.3) + fs-extra: 11.3.2 + image-size: 2.0.2 mdast-util-mdx: 3.0.0 mdast-util-to-string: 4.0.0 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) rehype-raw: 7.0.0 - remark-directive: 3.0.0 + remark-directive: 3.0.1 remark-emoji: 4.0.1 remark-frontmatter: 5.0.0 - remark-gfm: 4.0.0 + remark-gfm: 4.0.1 stringify-object: 3.3.0 - tslib: 2.6.3 + tslib: 2.8.1 unified: 11.0.5 unist-util-visit: 5.0.0 - url-loader: 4.1.1(file-loader@6.2.0(webpack@5.92.1))(webpack@5.92.1) - vfile: 6.0.1 - webpack: 5.92.1 + url-loader: 4.1.1(file-loader@6.2.0(webpack@5.101.3))(webpack@5.101.3) + vfile: 6.0.3 + webpack: 5.101.3 transitivePeerDependencies: - - '@docusaurus/types' - '@swc/core' - esbuild - supports-color - - typescript - uglify-js - webpack-cli - '@docusaurus/module-type-aliases@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': + '@docusaurus/module-type-aliases@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) '@types/history': 4.7.11 - '@types/react': 18.3.3 + '@types/react': 19.1.15 '@types/react-router-config': 5.0.11 '@types/react-router-dom': 5.3.3 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - react-helmet-async: 2.0.5(react@18.3.1) + react-helmet-async: '@slorber/react-helmet-async@1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)' react-loadable: '@docusaurus/react-loadable@6.0.0(react@18.3.1)' transitivePeerDependencies: - '@swc/core' @@ -5964,28 +6651,32 @@ snapshots: - uglify-js - webpack-cli - '@docusaurus/plugin-content-blog@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': - dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/logger': 3.4.0 - '@docusaurus/mdx-loader': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) + '@docusaurus/plugin-content-blog@3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/mdx-loader': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/plugin-content-docs': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/theme-common': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) cheerio: 1.0.0-rc.12 feed: 4.2.2 - fs-extra: 11.2.0 + fs-extra: 11.3.2 lodash: 4.17.21 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - reading-time: 1.5.0 + schema-dts: 1.1.5 srcset: 4.0.0 - tslib: 2.6.3 + tslib: 2.8.1 unist-util-visit: 5.0.0 utility-types: 3.11.0 - webpack: 5.92.1 + webpack: 5.101.3 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -5994,36 +6685,38 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-content-docs@3.4.0(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': - dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/logger': 3.4.0 - '@docusaurus/mdx-loader': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/module-type-aliases': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) + '@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/mdx-loader': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/module-type-aliases': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/theme-common': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) '@types/react-router-config': 5.0.11 combine-promises: 1.2.0 - fs-extra: 11.2.0 + fs-extra: 11.3.2 js-yaml: 4.1.0 lodash: 4.17.21 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + schema-dts: 1.1.5 + tslib: 2.8.1 utility-types: 3.11.0 - webpack: 5.92.1 + webpack: 5.101.3 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6032,28 +6725,53 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-content-pages@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/plugin-content-pages@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/mdx-loader': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - fs-extra: 11.2.0 + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/mdx-loader': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + fs-extra: 11.3.2 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 - webpack: 5.92.1 + tslib: 2.8.1 + webpack: 5.101.3 + transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' + - '@parcel/css' + - '@rspack/core' + - '@swc/core' + - '@swc/css' + - bufferutil + - csso + - debug + - esbuild + - lightningcss + - supports-color + - typescript + - uglify-js + - utf-8-validate + - webpack-cli + + '@docusaurus/plugin-css-cascade-layers@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + tslib: 2.8.1 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6062,26 +6780,28 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss + - react + - react-dom - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-debug@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/plugin-debug@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - fs-extra: 11.2.0 + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + fs-extra: 11.3.2 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - react-json-view-lite: 1.4.0(react@18.3.1) - tslib: 2.6.3 + react-json-view-lite: 2.5.0(react@18.3.1) + tslib: 2.8.1 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6090,24 +6810,24 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-google-analytics@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/plugin-google-analytics@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + tslib: 2.8.1 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6116,25 +6836,25 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-google-gtag@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/plugin-google-gtag@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) '@types/gtag.js': 0.0.12 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + tslib: 2.8.1 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6143,24 +6863,24 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-google-tag-manager@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/plugin-google-tag-manager@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + tslib: 2.8.1 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6169,29 +6889,59 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/plugin-sitemap@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/plugin-sitemap@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/logger': 3.4.0 - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - fs-extra: 11.2.0 + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + fs-extra: 11.3.2 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) sitemap: 7.1.2 - tslib: 2.6.3 + tslib: 2.8.1 + transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' + - '@parcel/css' + - '@rspack/core' + - '@swc/core' + - '@swc/css' + - bufferutil + - csso + - debug + - esbuild + - lightningcss + - supports-color + - typescript + - uglify-js + - utf-8-validate + - webpack-cli + + '@docusaurus/plugin-svgr@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@svgr/core': 8.1.0(typescript@5.2.2) + '@svgr/webpack': 8.1.0(typescript@5.2.2) + react: 18.3.1 + react-dom: 18.3.1(react@18.3.1) + tslib: 2.8.1 + webpack: 5.101.3 transitivePeerDependencies: + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6200,34 +6950,36 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/preset-classic@3.4.0(@algolia/client-search@4.23.3)(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.14.0)(typescript@5.2.2)': - dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-blog': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-docs': 3.4.0(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-pages': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-debug': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-google-analytics': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-google-gtag': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-google-tag-manager': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-sitemap': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-classic': 3.4.0(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-search-algolia': 3.4.0(@algolia/client-search@4.23.3)(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.14.0)(typescript@5.2.2) - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/preset-classic@3.9.1(@algolia/client-search@5.39.0)(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.17.3)(typescript@5.2.2)': + dependencies: + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-content-blog': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-content-docs': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-content-pages': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-css-cascade-layers': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-debug': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-google-analytics': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-google-gtag': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-google-tag-manager': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-sitemap': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-svgr': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/theme-classic': 3.9.1(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/theme-common': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/theme-search-algolia': 3.9.1(@algolia/client-search@5.39.0)(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.17.3)(typescript@5.2.2) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) react: 18.3.1 react-dom: 18.3.1(react@18.3.1) transitivePeerDependencies: - '@algolia/client-search' + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6237,51 +6989,50 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - search-insights - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli '@docusaurus/react-loadable@6.0.0(react@18.3.1)': dependencies: - '@types/react': 18.3.3 + '@types/react': 19.1.15 react: 18.3.1 - '@docusaurus/theme-classic@3.4.0(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': - dependencies: - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/mdx-loader': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/module-type-aliases': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/plugin-content-blog': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-docs': 3.4.0(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-pages': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-translations': 3.4.0 - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@mdx-js/react': 3.0.1(@types/react@18.3.3)(react@18.3.1) + '@docusaurus/theme-classic@3.9.1(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + dependencies: + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/mdx-loader': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/module-type-aliases': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/plugin-content-blog': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-content-docs': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/plugin-content-pages': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/theme-common': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/theme-translations': 3.9.1 + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@mdx-js/react': 3.1.1(@types/react@19.1.15)(react@18.3.1) clsx: 2.1.1 - copy-text-to-clipboard: 3.2.0 - infima: 0.2.0-alpha.43 + infima: 0.2.0-alpha.45 lodash: 4.17.21 nprogress: 0.2.0 - postcss: 8.4.38 - prism-react-renderer: 2.3.1(react@18.3.1) - prismjs: https://codeload.github.com/PrismJS/prism/tar.gz/59e5a3471377057de1f401ba38337aca27b80e03 + postcss: 8.5.6 + prism-react-renderer: 2.4.1(react@18.3.1) + prismjs: 1.30.0 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) react-router-dom: 5.3.4(react@18.3.1) - rtlcss: 4.1.1 - tslib: 2.6.3 + rtlcss: 4.3.0 + tslib: 2.8.1 utility-types: 3.11.0 transitivePeerDependencies: + - '@docusaurus/faster' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6291,76 +7042,61 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/theme-common@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@docusaurus/theme-common@3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - '@docusaurus/mdx-loader': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/module-type-aliases': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) - '@docusaurus/plugin-content-blog': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-docs': 3.4.0(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/plugin-content-pages': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) + '@docusaurus/mdx-loader': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/module-type-aliases': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/plugin-content-docs': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) '@types/history': 4.7.11 - '@types/react': 18.3.3 + '@types/react': 19.1.15 '@types/react-router-config': 5.0.11 clsx: 2.1.1 parse-numeric-range: 1.3.0 - prism-react-renderer: 2.3.1(react@18.3.1) + prism-react-renderer: 2.4.1(react@18.3.1) react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + tslib: 2.8.1 utility-types: 3.11.0 transitivePeerDependencies: - - '@docusaurus/types' - - '@parcel/css' - - '@rspack/core' - '@swc/core' - - '@swc/css' - - bufferutil - - csso - - debug - esbuild - - eslint - - lightningcss - supports-color - - typescript - uglify-js - - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/theme-search-algolia@3.4.0(@algolia/client-search@4.23.3)(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.14.0)(typescript@5.2.2)': - dependencies: - '@docsearch/react': 3.6.0(@algolia/client-search@4.23.3)(@types/react@18.3.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.14.0) - '@docusaurus/core': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/logger': 3.4.0 - '@docusaurus/plugin-content-docs': 3.4.0(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-translations': 3.4.0 - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - algoliasearch: 4.23.3 - algoliasearch-helper: 3.22.1(algoliasearch@4.23.3) + '@docusaurus/theme-search-algolia@3.9.1(@algolia/client-search@5.39.0)(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.17.3)(typescript@5.2.2)': + dependencies: + '@docsearch/react': 4.1.0(@algolia/client-search@5.39.0)(@types/react@19.1.15)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(search-insights@2.17.3) + '@docusaurus/core': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/plugin-content-docs': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/theme-common': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/theme-translations': 3.9.1 + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + algoliasearch: 5.39.0 + algoliasearch-helper: 3.26.0(algoliasearch@5.39.0) clsx: 2.1.1 eta: 2.2.0 - fs-extra: 11.2.0 + fs-extra: 11.3.2 lodash: 4.17.21 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + tslib: 2.8.1 utility-types: 3.11.0 transitivePeerDependencies: - '@algolia/client-search' - - '@docusaurus/types' + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6370,35 +7106,34 @@ snapshots: - csso - debug - esbuild - - eslint - lightningcss - search-insights - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@docusaurus/theme-translations@3.4.0': + '@docusaurus/theme-translations@3.9.1': dependencies: - fs-extra: 11.2.0 - tslib: 2.6.3 + fs-extra: 11.3.2 + tslib: 2.8.1 - '@docusaurus/tsconfig@3.4.0': {} + '@docusaurus/tsconfig@3.9.1': {} - '@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': + '@docusaurus/types@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - '@mdx-js/mdx': 3.0.1 + '@mdx-js/mdx': 3.1.1 '@types/history': 4.7.11 - '@types/react': 18.3.3 + '@types/mdast': 4.0.4 + '@types/react': 19.1.15 commander: 5.1.0 joi: 17.13.3 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - react-helmet-async: 1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + react-helmet-async: '@slorber/react-helmet-async@1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)' utility-types: 3.11.0 - webpack: 5.92.1 + webpack: 5.101.3 webpack-merge: 5.10.0 transitivePeerDependencies: - '@swc/core' @@ -6407,60 +7142,67 @@ snapshots: - uglify-js - webpack-cli - '@docusaurus/utils-common@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))': + '@docusaurus/utils-common@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - tslib: 2.6.3 - optionalDependencies: - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + tslib: 2.8.1 + transitivePeerDependencies: + - '@swc/core' + - esbuild + - react + - react-dom + - supports-color + - uglify-js + - webpack-cli - '@docusaurus/utils-validation@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2)': + '@docusaurus/utils-validation@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - '@docusaurus/logger': 3.4.0 - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - fs-extra: 11.2.0 + '@docusaurus/logger': 3.9.1 + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + fs-extra: 11.3.2 joi: 17.13.3 js-yaml: 4.1.0 lodash: 4.17.21 - tslib: 2.6.3 + tslib: 2.8.1 transitivePeerDependencies: - - '@docusaurus/types' - '@swc/core' - esbuild + - react + - react-dom - supports-color - - typescript - uglify-js - webpack-cli - '@docusaurus/utils@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2)': + '@docusaurus/utils@3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': dependencies: - '@docusaurus/logger': 3.4.0 - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@svgr/webpack': 8.1.0(typescript@5.2.2) + '@docusaurus/logger': 3.9.1 + '@docusaurus/types': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) escape-string-regexp: 4.0.0 - file-loader: 6.2.0(webpack@5.92.1) - fs-extra: 11.2.0 + execa: 5.1.1 + file-loader: 6.2.0(webpack@5.101.3) + fs-extra: 11.3.2 github-slugger: 1.5.0 globby: 11.1.0 gray-matter: 4.0.3 - jiti: 1.21.6 + jiti: 1.21.7 js-yaml: 4.1.0 lodash: 4.17.21 - micromatch: 4.0.7 + micromatch: 4.0.8 + p-queue: 6.6.2 prompts: 2.4.2 resolve-pathname: 3.0.0 - shelljs: 0.8.5 - tslib: 2.6.3 - url-loader: 4.1.1(file-loader@6.2.0(webpack@5.92.1))(webpack@5.92.1) + tslib: 2.8.1 + url-loader: 4.1.1(file-loader@6.2.0(webpack@5.101.3))(webpack@5.101.3) utility-types: 3.11.0 - webpack: 5.92.1 - optionalDependencies: - '@docusaurus/types': 3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + webpack: 5.101.3 transitivePeerDependencies: - '@swc/core' - esbuild + - react + - react-dom - supports-color - - typescript - uglify-js - webpack-cli @@ -6469,19 +7211,20 @@ snapshots: cssesc: 3.0.0 immediate: 3.3.0 - '@easyops-cn/docusaurus-search-local@0.44.2(@docusaurus/theme-common@3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': + '@easyops-cn/docusaurus-search-local@0.52.1(@docusaurus/theme-common@3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2)': dependencies: - '@docusaurus/plugin-content-docs': 3.4.0(debug@4.3.5)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) - '@docusaurus/theme-translations': 3.4.0 - '@docusaurus/utils': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) - '@docusaurus/utils-common': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)) - '@docusaurus/utils-validation': 3.4.0(@docusaurus/types@3.4.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1))(typescript@5.2.2) + '@docusaurus/plugin-content-docs': 3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(debug@4.4.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2) + '@docusaurus/theme-common': 3.9.1(@docusaurus/plugin-content-docs@3.9.1(@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1))(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(typescript@5.2.2))(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/theme-translations': 3.9.1 + '@docusaurus/utils': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-common': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) + '@docusaurus/utils-validation': 3.9.1(react-dom@18.3.1(react@18.3.1))(react@18.3.1) '@easyops-cn/autocomplete.js': 0.38.1 - '@node-rs/jieba': 1.10.3 - cheerio: 1.0.0-rc.12 - clsx: 1.2.1 - debug: 4.3.5 + '@node-rs/jieba': 1.10.4 + cheerio: 1.1.2 + clsx: 2.1.1 + comlink: 4.4.2 + debug: 4.4.3 fs-extra: 10.1.0 klaw-sync: 6.0.0 lunr: 2.3.9 @@ -6489,9 +7232,10 @@ snapshots: mark.js: 8.11.1 react: 18.3.1 react-dom: 18.3.1(react@18.3.1) - tslib: 2.6.3 + tslib: 2.8.1 transitivePeerDependencies: - - '@docusaurus/types' + - '@docusaurus/faster' + - '@mdx-js/react' - '@parcel/css' - '@rspack/core' - '@swc/core' @@ -6499,29 +7243,27 @@ snapshots: - bufferutil - csso - esbuild - - eslint - lightningcss - supports-color - typescript - uglify-js - utf-8-validate - - vue-template-compiler - webpack-cli - '@emnapi/core@1.2.0': + '@emnapi/core@1.5.0': dependencies: - '@emnapi/wasi-threads': 1.0.1 - tslib: 2.6.3 + '@emnapi/wasi-threads': 1.1.0 + tslib: 2.8.1 optional: true - '@emnapi/runtime@1.2.0': + '@emnapi/runtime@1.5.0': dependencies: - tslib: 2.6.3 + tslib: 2.8.1 optional: true - '@emnapi/wasi-threads@1.0.1': + '@emnapi/wasi-threads@1.1.0': dependencies: - tslib: 2.6.3 + tslib: 2.8.1 optional: true '@hapi/hoek@9.3.0': {} @@ -6534,7 +7276,7 @@ snapshots: dependencies: string-width: 5.1.2 string-width-cjs: string-width@4.2.3 - strip-ansi: 7.1.0 + strip-ansi: 7.1.2 strip-ansi-cjs: strip-ansi@6.0.1 wrap-ansi: 8.1.0 wrap-ansi-cjs: wrap-ansi@7.0.0 @@ -6548,135 +7290,174 @@ snapshots: '@jest/schemas': 29.6.3 '@types/istanbul-lib-coverage': 2.0.6 '@types/istanbul-reports': 3.0.4 - '@types/node': 20.14.8 - '@types/yargs': 17.0.32 + '@types/node': 24.5.2 + '@types/yargs': 17.0.33 chalk: 4.1.2 - '@jridgewell/gen-mapping@0.3.5': + '@jridgewell/gen-mapping@0.3.13': dependencies: - '@jridgewell/set-array': 1.2.1 - '@jridgewell/sourcemap-codec': 1.4.15 - '@jridgewell/trace-mapping': 0.3.25 + '@jridgewell/sourcemap-codec': 1.5.5 + '@jridgewell/trace-mapping': 0.3.31 - '@jridgewell/resolve-uri@3.1.2': {} + '@jridgewell/remapping@2.3.5': + dependencies: + '@jridgewell/gen-mapping': 0.3.13 + '@jridgewell/trace-mapping': 0.3.31 - '@jridgewell/set-array@1.2.1': {} + '@jridgewell/resolve-uri@3.1.2': {} - '@jridgewell/source-map@0.3.6': + '@jridgewell/source-map@0.3.11': dependencies: - '@jridgewell/gen-mapping': 0.3.5 - '@jridgewell/trace-mapping': 0.3.25 + '@jridgewell/gen-mapping': 0.3.13 + '@jridgewell/trace-mapping': 0.3.31 - '@jridgewell/sourcemap-codec@1.4.15': {} + '@jridgewell/sourcemap-codec@1.5.5': {} - '@jridgewell/trace-mapping@0.3.25': + '@jridgewell/trace-mapping@0.3.31': dependencies: '@jridgewell/resolve-uri': 3.1.2 - '@jridgewell/sourcemap-codec': 1.4.15 + '@jridgewell/sourcemap-codec': 1.5.5 + + '@jsonjoy.com/base64@1.1.2(tslib@2.8.1)': + dependencies: + tslib: 2.8.1 + + '@jsonjoy.com/buffers@1.0.0(tslib@2.8.1)': + dependencies: + tslib: 2.8.1 + + '@jsonjoy.com/codegen@1.0.0(tslib@2.8.1)': + dependencies: + tslib: 2.8.1 + + '@jsonjoy.com/json-pack@1.14.0(tslib@2.8.1)': + dependencies: + '@jsonjoy.com/base64': 1.1.2(tslib@2.8.1) + '@jsonjoy.com/buffers': 1.0.0(tslib@2.8.1) + '@jsonjoy.com/codegen': 1.0.0(tslib@2.8.1) + '@jsonjoy.com/json-pointer': 1.0.2(tslib@2.8.1) + '@jsonjoy.com/util': 1.9.0(tslib@2.8.1) + hyperdyperid: 1.2.0 + thingies: 2.5.0(tslib@2.8.1) + tslib: 2.8.1 + + '@jsonjoy.com/json-pointer@1.0.2(tslib@2.8.1)': + dependencies: + '@jsonjoy.com/codegen': 1.0.0(tslib@2.8.1) + '@jsonjoy.com/util': 1.9.0(tslib@2.8.1) + tslib: 2.8.1 + + '@jsonjoy.com/util@1.9.0(tslib@2.8.1)': + dependencies: + '@jsonjoy.com/buffers': 1.0.0(tslib@2.8.1) + '@jsonjoy.com/codegen': 1.0.0(tslib@2.8.1) + tslib: 2.8.1 '@leichtgewicht/ip-codec@2.0.5': {} - '@mdx-js/mdx@3.0.1': + '@mdx-js/mdx@3.1.1': dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 '@types/estree-jsx': 1.0.5 '@types/hast': 3.0.4 '@types/mdx': 2.0.13 + acorn: 8.15.0 collapse-white-space: 2.1.0 devlop: 1.1.0 - estree-util-build-jsx: 3.0.1 estree-util-is-identifier-name: 3.0.0 - estree-util-to-js: 2.0.0 + estree-util-scope: 1.0.0 estree-walker: 3.0.3 - hast-util-to-estree: 3.1.0 - hast-util-to-jsx-runtime: 2.3.0 + hast-util-to-jsx-runtime: 2.3.6 markdown-extensions: 2.0.0 - periscopic: 3.1.0 - remark-mdx: 3.0.1 + recma-build-jsx: 1.0.0 + recma-jsx: 1.0.1(acorn@8.15.0) + recma-stringify: 1.0.0 + rehype-recma: 1.0.0 + remark-mdx: 3.1.1 remark-parse: 11.0.0 - remark-rehype: 11.1.0 - source-map: 0.7.4 + remark-rehype: 11.1.2 + source-map: 0.7.6 unified: 11.0.5 unist-util-position-from-estree: 2.0.0 unist-util-stringify-position: 4.0.0 unist-util-visit: 5.0.0 - vfile: 6.0.1 + vfile: 6.0.3 transitivePeerDependencies: - supports-color - '@mdx-js/react@3.0.1(@types/react@18.3.3)(react@18.3.1)': + '@mdx-js/react@3.1.1(@types/react@19.1.15)(react@18.3.1)': dependencies: '@types/mdx': 2.0.13 - '@types/react': 18.3.3 + '@types/react': 19.1.15 react: 18.3.1 - '@napi-rs/wasm-runtime@0.2.4': + '@napi-rs/wasm-runtime@0.2.12': dependencies: - '@emnapi/core': 1.2.0 - '@emnapi/runtime': 1.2.0 - '@tybys/wasm-util': 0.9.0 + '@emnapi/core': 1.5.0 + '@emnapi/runtime': 1.5.0 + '@tybys/wasm-util': 0.10.1 optional: true - '@node-rs/jieba-android-arm-eabi@1.10.3': + '@node-rs/jieba-android-arm-eabi@1.10.4': optional: true - '@node-rs/jieba-android-arm64@1.10.3': + '@node-rs/jieba-android-arm64@1.10.4': optional: true - '@node-rs/jieba-darwin-arm64@1.10.3': + '@node-rs/jieba-darwin-arm64@1.10.4': optional: true - '@node-rs/jieba-darwin-x64@1.10.3': + '@node-rs/jieba-darwin-x64@1.10.4': optional: true - '@node-rs/jieba-freebsd-x64@1.10.3': + '@node-rs/jieba-freebsd-x64@1.10.4': optional: true - '@node-rs/jieba-linux-arm-gnueabihf@1.10.3': + '@node-rs/jieba-linux-arm-gnueabihf@1.10.4': optional: true - '@node-rs/jieba-linux-arm64-gnu@1.10.3': + '@node-rs/jieba-linux-arm64-gnu@1.10.4': optional: true - '@node-rs/jieba-linux-arm64-musl@1.10.3': + '@node-rs/jieba-linux-arm64-musl@1.10.4': optional: true - '@node-rs/jieba-linux-x64-gnu@1.10.3': + '@node-rs/jieba-linux-x64-gnu@1.10.4': optional: true - '@node-rs/jieba-linux-x64-musl@1.10.3': + '@node-rs/jieba-linux-x64-musl@1.10.4': optional: true - '@node-rs/jieba-wasm32-wasi@1.10.3': + '@node-rs/jieba-wasm32-wasi@1.10.4': dependencies: - '@napi-rs/wasm-runtime': 0.2.4 + '@napi-rs/wasm-runtime': 0.2.12 optional: true - '@node-rs/jieba-win32-arm64-msvc@1.10.3': + '@node-rs/jieba-win32-arm64-msvc@1.10.4': optional: true - '@node-rs/jieba-win32-ia32-msvc@1.10.3': + '@node-rs/jieba-win32-ia32-msvc@1.10.4': optional: true - '@node-rs/jieba-win32-x64-msvc@1.10.3': + '@node-rs/jieba-win32-x64-msvc@1.10.4': optional: true - '@node-rs/jieba@1.10.3': + '@node-rs/jieba@1.10.4': optionalDependencies: - '@node-rs/jieba-android-arm-eabi': 1.10.3 - '@node-rs/jieba-android-arm64': 1.10.3 - '@node-rs/jieba-darwin-arm64': 1.10.3 - '@node-rs/jieba-darwin-x64': 1.10.3 - '@node-rs/jieba-freebsd-x64': 1.10.3 - '@node-rs/jieba-linux-arm-gnueabihf': 1.10.3 - '@node-rs/jieba-linux-arm64-gnu': 1.10.3 - '@node-rs/jieba-linux-arm64-musl': 1.10.3 - '@node-rs/jieba-linux-x64-gnu': 1.10.3 - '@node-rs/jieba-linux-x64-musl': 1.10.3 - '@node-rs/jieba-wasm32-wasi': 1.10.3 - '@node-rs/jieba-win32-arm64-msvc': 1.10.3 - '@node-rs/jieba-win32-ia32-msvc': 1.10.3 - '@node-rs/jieba-win32-x64-msvc': 1.10.3 + '@node-rs/jieba-android-arm-eabi': 1.10.4 + '@node-rs/jieba-android-arm64': 1.10.4 + '@node-rs/jieba-darwin-arm64': 1.10.4 + '@node-rs/jieba-darwin-x64': 1.10.4 + '@node-rs/jieba-freebsd-x64': 1.10.4 + '@node-rs/jieba-linux-arm-gnueabihf': 1.10.4 + '@node-rs/jieba-linux-arm64-gnu': 1.10.4 + '@node-rs/jieba-linux-arm64-musl': 1.10.4 + '@node-rs/jieba-linux-x64-gnu': 1.10.4 + '@node-rs/jieba-linux-x64-musl': 1.10.4 + '@node-rs/jieba-wasm32-wasi': 1.10.4 + '@node-rs/jieba-win32-arm64-msvc': 1.10.4 + '@node-rs/jieba-win32-ia32-msvc': 1.10.4 + '@node-rs/jieba-win32-x64-msvc': 1.10.4 '@nodelib/fs.scandir@2.1.5': dependencies: @@ -6688,7 +7469,9 @@ snapshots: '@nodelib/fs.walk@1.2.8': dependencies: '@nodelib/fs.scandir': 2.1.5 - fastq: 1.17.1 + fastq: 1.19.1 + + '@opentelemetry/api@1.9.0': {} '@pkgjs/parseargs@0.11.0': optional: true @@ -6699,13 +7482,13 @@ snapshots: dependencies: graceful-fs: 4.2.10 - '@pnpm/npm-conf@2.2.2': + '@pnpm/npm-conf@2.3.1': dependencies: '@pnpm/config.env-replace': 1.1.0 '@pnpm/network.ca-file': 1.0.2 config-chain: 1.1.13 - '@polka/url@1.0.0-next.25': {} + '@polka/url@1.0.0-next.29': {} '@sideway/address@4.1.5': dependencies: @@ -6721,60 +7504,72 @@ snapshots: '@sindresorhus/is@5.6.0': {} + '@slorber/react-helmet-async@1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1)': + dependencies: + '@babel/runtime': 7.28.4 + invariant: 2.2.4 + prop-types: 15.8.1 + react: 18.3.1 + react-dom: 18.3.1(react@18.3.1) + react-fast-compare: 3.2.2 + shallowequal: 1.1.0 + '@slorber/remark-comment@1.0.0': dependencies: micromark-factory-space: 1.1.0 micromark-util-character: 1.2.0 micromark-util-symbol: 1.1.0 - '@svgr/babel-plugin-add-jsx-attribute@8.0.0(@babel/core@7.24.7)': + '@standard-schema/spec@1.0.0': {} + + '@svgr/babel-plugin-add-jsx-attribute@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-remove-jsx-attribute@8.0.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-remove-jsx-attribute@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-remove-jsx-empty-expression@8.0.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-remove-jsx-empty-expression@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-replace-jsx-attribute-value@8.0.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-replace-jsx-attribute-value@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-svg-dynamic-title@8.0.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-svg-dynamic-title@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-svg-em-dimensions@8.0.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-svg-em-dimensions@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-transform-react-native-svg@8.1.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-transform-react-native-svg@8.1.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-plugin-transform-svg-component@8.0.0(@babel/core@7.24.7)': + '@svgr/babel-plugin-transform-svg-component@8.0.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 - '@svgr/babel-preset@8.1.0(@babel/core@7.24.7)': + '@svgr/babel-preset@8.1.0(@babel/core@7.28.4)': dependencies: - '@babel/core': 7.24.7 - '@svgr/babel-plugin-add-jsx-attribute': 8.0.0(@babel/core@7.24.7) - '@svgr/babel-plugin-remove-jsx-attribute': 8.0.0(@babel/core@7.24.7) - '@svgr/babel-plugin-remove-jsx-empty-expression': 8.0.0(@babel/core@7.24.7) - '@svgr/babel-plugin-replace-jsx-attribute-value': 8.0.0(@babel/core@7.24.7) - '@svgr/babel-plugin-svg-dynamic-title': 8.0.0(@babel/core@7.24.7) - '@svgr/babel-plugin-svg-em-dimensions': 8.0.0(@babel/core@7.24.7) - '@svgr/babel-plugin-transform-react-native-svg': 8.1.0(@babel/core@7.24.7) - '@svgr/babel-plugin-transform-svg-component': 8.0.0(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@svgr/babel-plugin-add-jsx-attribute': 8.0.0(@babel/core@7.28.4) + '@svgr/babel-plugin-remove-jsx-attribute': 8.0.0(@babel/core@7.28.4) + '@svgr/babel-plugin-remove-jsx-empty-expression': 8.0.0(@babel/core@7.28.4) + '@svgr/babel-plugin-replace-jsx-attribute-value': 8.0.0(@babel/core@7.28.4) + '@svgr/babel-plugin-svg-dynamic-title': 8.0.0(@babel/core@7.28.4) + '@svgr/babel-plugin-svg-em-dimensions': 8.0.0(@babel/core@7.28.4) + '@svgr/babel-plugin-transform-react-native-svg': 8.1.0(@babel/core@7.28.4) + '@svgr/babel-plugin-transform-svg-component': 8.0.0(@babel/core@7.28.4) '@svgr/core@8.1.0(typescript@5.2.2)': dependencies: - '@babel/core': 7.24.7 - '@svgr/babel-preset': 8.1.0(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@svgr/babel-preset': 8.1.0(@babel/core@7.28.4) camelcase: 6.3.0 cosmiconfig: 8.3.6(typescript@5.2.2) snake-case: 3.0.4 @@ -6784,13 +7579,13 @@ snapshots: '@svgr/hast-util-to-babel-ast@8.0.0': dependencies: - '@babel/types': 7.24.7 + '@babel/types': 7.28.4 entities: 4.5.0 '@svgr/plugin-jsx@8.1.0(@svgr/core@8.1.0(typescript@5.2.2))': dependencies: - '@babel/core': 7.24.7 - '@svgr/babel-preset': 8.1.0(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@svgr/babel-preset': 8.1.0(@babel/core@7.28.4) '@svgr/core': 8.1.0(typescript@5.2.2) '@svgr/hast-util-to-babel-ast': 8.0.0 svg-parser: 2.0.4 @@ -6808,11 +7603,11 @@ snapshots: '@svgr/webpack@8.1.0(typescript@5.2.2)': dependencies: - '@babel/core': 7.24.7 - '@babel/plugin-transform-react-constant-elements': 7.24.7(@babel/core@7.24.7) - '@babel/preset-env': 7.24.7(@babel/core@7.24.7) - '@babel/preset-react': 7.24.7(@babel/core@7.24.7) - '@babel/preset-typescript': 7.24.7(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/plugin-transform-react-constant-elements': 7.27.1(@babel/core@7.28.4) + '@babel/preset-env': 7.28.3(@babel/core@7.28.4) + '@babel/preset-react': 7.27.1(@babel/core@7.28.4) + '@babel/preset-typescript': 7.27.1(@babel/core@7.28.4) '@svgr/core': 8.1.0(typescript@5.2.2) '@svgr/plugin-jsx': 8.1.0(@svgr/core@8.1.0(typescript@5.2.2)) '@svgr/plugin-svgo': 8.1.0(@svgr/core@8.1.0(typescript@5.2.2))(typescript@5.2.2) @@ -6826,72 +7621,68 @@ snapshots: '@trysound/sax@0.2.0': {} - '@tybys/wasm-util@0.9.0': + '@tybys/wasm-util@0.10.1': dependencies: - tslib: 2.6.3 + tslib: 2.8.1 optional: true - '@types/acorn@4.0.6': - dependencies: - '@types/estree': 1.0.5 - - '@types/body-parser@1.19.5': + '@types/body-parser@1.19.6': dependencies: '@types/connect': 3.4.38 - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/bonjour@3.5.13': dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/connect-history-api-fallback@1.5.4': dependencies: - '@types/express-serve-static-core': 4.19.5 - '@types/node': 20.14.8 + '@types/express-serve-static-core': 4.19.6 + '@types/node': 24.5.2 '@types/connect@3.4.38': dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/debug@4.1.12': dependencies: - '@types/ms': 0.7.34 + '@types/ms': 2.1.0 '@types/eslint-scope@3.7.7': dependencies: - '@types/eslint': 8.56.10 - '@types/estree': 1.0.5 + '@types/eslint': 9.6.1 + '@types/estree': 1.0.8 - '@types/eslint@8.56.10': + '@types/eslint@9.6.1': dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 '@types/json-schema': 7.0.15 '@types/estree-jsx@1.0.5': dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 - '@types/estree@1.0.5': {} + '@types/estree@1.0.8': {} - '@types/express-serve-static-core@4.19.5': + '@types/express-serve-static-core@4.19.6': dependencies: - '@types/node': 20.14.8 - '@types/qs': 6.9.15 + '@types/node': 24.5.2 + '@types/qs': 6.14.0 '@types/range-parser': 1.2.7 - '@types/send': 0.17.4 + '@types/send': 0.17.5 - '@types/express@4.17.21': + '@types/express@4.17.23': dependencies: - '@types/body-parser': 1.19.5 - '@types/express-serve-static-core': 4.19.5 - '@types/qs': 6.9.15 - '@types/serve-static': 1.15.7 + '@types/body-parser': 1.19.6 + '@types/express-serve-static-core': 4.19.6 + '@types/qs': 6.14.0 + '@types/serve-static': 1.15.8 '@types/gtag.js@0.0.12': {} '@types/hast@3.0.4': dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 '@types/history@4.7.11': {} @@ -6899,11 +7690,11 @@ snapshots: '@types/http-cache-semantics@4.0.4': {} - '@types/http-errors@2.0.4': {} + '@types/http-errors@2.0.5': {} - '@types/http-proxy@1.17.14': + '@types/http-proxy@1.17.16': dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/istanbul-lib-coverage@2.0.6': {} @@ -6919,171 +7710,166 @@ snapshots: '@types/mdast@4.0.4': dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 '@types/mdx@2.0.13': {} '@types/mime@1.3.5': {} - '@types/ms@0.7.34': {} + '@types/ms@2.1.0': {} - '@types/node-forge@1.3.11': + '@types/node-forge@1.3.14': dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/node@17.0.45': {} - '@types/node@20.14.8': + '@types/node@24.5.2': dependencies: - undici-types: 5.26.5 - - '@types/parse-json@4.0.2': {} - - '@types/prismjs@1.26.4': {} + undici-types: 7.12.0 - '@types/prop-types@15.7.12': {} + '@types/prismjs@1.26.5': {} - '@types/qs@6.9.15': {} + '@types/qs@6.14.0': {} '@types/range-parser@1.2.7': {} '@types/react-router-config@5.0.11': dependencies: '@types/history': 4.7.11 - '@types/react': 18.3.3 + '@types/react': 19.1.15 '@types/react-router': 5.1.20 '@types/react-router-dom@5.3.3': dependencies: '@types/history': 4.7.11 - '@types/react': 18.3.3 + '@types/react': 19.1.15 '@types/react-router': 5.1.20 '@types/react-router@5.1.20': dependencies: '@types/history': 4.7.11 - '@types/react': 18.3.3 + '@types/react': 19.1.15 - '@types/react@18.3.3': + '@types/react@19.1.15': dependencies: - '@types/prop-types': 15.7.12 csstype: 3.1.3 - '@types/retry@0.12.0': {} + '@types/retry@0.12.2': {} '@types/sax@1.2.7': dependencies: '@types/node': 17.0.45 - '@types/send@0.17.4': + '@types/send@0.17.5': dependencies: '@types/mime': 1.3.5 - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/serve-index@1.9.4': dependencies: - '@types/express': 4.17.21 + '@types/express': 4.17.23 - '@types/serve-static@1.15.7': + '@types/serve-static@1.15.8': dependencies: - '@types/http-errors': 2.0.4 - '@types/node': 20.14.8 - '@types/send': 0.17.4 + '@types/http-errors': 2.0.5 + '@types/node': 24.5.2 + '@types/send': 0.17.5 '@types/sockjs@0.3.36': dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 - '@types/unist@2.0.10': {} + '@types/unist@2.0.11': {} - '@types/unist@3.0.2': {} + '@types/unist@3.0.3': {} - '@types/ws@8.5.10': + '@types/ws@8.18.1': dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 '@types/yargs-parser@21.0.3': {} - '@types/yargs@17.0.32': + '@types/yargs@17.0.33': dependencies: '@types/yargs-parser': 21.0.3 - '@ungap/structured-clone@1.2.0': {} + '@ungap/structured-clone@1.3.0': {} - '@webassemblyjs/ast@1.12.1': + '@webassemblyjs/ast@1.14.1': dependencies: - '@webassemblyjs/helper-numbers': 1.11.6 - '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/helper-numbers': 1.13.2 + '@webassemblyjs/helper-wasm-bytecode': 1.13.2 - '@webassemblyjs/floating-point-hex-parser@1.11.6': {} + '@webassemblyjs/floating-point-hex-parser@1.13.2': {} - '@webassemblyjs/helper-api-error@1.11.6': {} + '@webassemblyjs/helper-api-error@1.13.2': {} - '@webassemblyjs/helper-buffer@1.12.1': {} + '@webassemblyjs/helper-buffer@1.14.1': {} - '@webassemblyjs/helper-numbers@1.11.6': + '@webassemblyjs/helper-numbers@1.13.2': dependencies: - '@webassemblyjs/floating-point-hex-parser': 1.11.6 - '@webassemblyjs/helper-api-error': 1.11.6 + '@webassemblyjs/floating-point-hex-parser': 1.13.2 + '@webassemblyjs/helper-api-error': 1.13.2 '@xtuc/long': 4.2.2 - '@webassemblyjs/helper-wasm-bytecode@1.11.6': {} + '@webassemblyjs/helper-wasm-bytecode@1.13.2': {} - '@webassemblyjs/helper-wasm-section@1.12.1': + '@webassemblyjs/helper-wasm-section@1.14.1': dependencies: - '@webassemblyjs/ast': 1.12.1 - '@webassemblyjs/helper-buffer': 1.12.1 - '@webassemblyjs/helper-wasm-bytecode': 1.11.6 - '@webassemblyjs/wasm-gen': 1.12.1 + '@webassemblyjs/ast': 1.14.1 + '@webassemblyjs/helper-buffer': 1.14.1 + '@webassemblyjs/helper-wasm-bytecode': 1.13.2 + '@webassemblyjs/wasm-gen': 1.14.1 - '@webassemblyjs/ieee754@1.11.6': + '@webassemblyjs/ieee754@1.13.2': dependencies: '@xtuc/ieee754': 1.2.0 - '@webassemblyjs/leb128@1.11.6': + '@webassemblyjs/leb128@1.13.2': dependencies: '@xtuc/long': 4.2.2 - '@webassemblyjs/utf8@1.11.6': {} + '@webassemblyjs/utf8@1.13.2': {} - '@webassemblyjs/wasm-edit@1.12.1': + '@webassemblyjs/wasm-edit@1.14.1': dependencies: - '@webassemblyjs/ast': 1.12.1 - '@webassemblyjs/helper-buffer': 1.12.1 - '@webassemblyjs/helper-wasm-bytecode': 1.11.6 - '@webassemblyjs/helper-wasm-section': 1.12.1 - '@webassemblyjs/wasm-gen': 1.12.1 - '@webassemblyjs/wasm-opt': 1.12.1 - '@webassemblyjs/wasm-parser': 1.12.1 - '@webassemblyjs/wast-printer': 1.12.1 + '@webassemblyjs/ast': 1.14.1 + '@webassemblyjs/helper-buffer': 1.14.1 + '@webassemblyjs/helper-wasm-bytecode': 1.13.2 + '@webassemblyjs/helper-wasm-section': 1.14.1 + '@webassemblyjs/wasm-gen': 1.14.1 + '@webassemblyjs/wasm-opt': 1.14.1 + '@webassemblyjs/wasm-parser': 1.14.1 + '@webassemblyjs/wast-printer': 1.14.1 - '@webassemblyjs/wasm-gen@1.12.1': + '@webassemblyjs/wasm-gen@1.14.1': dependencies: - '@webassemblyjs/ast': 1.12.1 - '@webassemblyjs/helper-wasm-bytecode': 1.11.6 - '@webassemblyjs/ieee754': 1.11.6 - '@webassemblyjs/leb128': 1.11.6 - '@webassemblyjs/utf8': 1.11.6 + '@webassemblyjs/ast': 1.14.1 + '@webassemblyjs/helper-wasm-bytecode': 1.13.2 + '@webassemblyjs/ieee754': 1.13.2 + '@webassemblyjs/leb128': 1.13.2 + '@webassemblyjs/utf8': 1.13.2 - '@webassemblyjs/wasm-opt@1.12.1': + '@webassemblyjs/wasm-opt@1.14.1': dependencies: - '@webassemblyjs/ast': 1.12.1 - '@webassemblyjs/helper-buffer': 1.12.1 - '@webassemblyjs/wasm-gen': 1.12.1 - '@webassemblyjs/wasm-parser': 1.12.1 + '@webassemblyjs/ast': 1.14.1 + '@webassemblyjs/helper-buffer': 1.14.1 + '@webassemblyjs/wasm-gen': 1.14.1 + '@webassemblyjs/wasm-parser': 1.14.1 - '@webassemblyjs/wasm-parser@1.12.1': + '@webassemblyjs/wasm-parser@1.14.1': dependencies: - '@webassemblyjs/ast': 1.12.1 - '@webassemblyjs/helper-api-error': 1.11.6 - '@webassemblyjs/helper-wasm-bytecode': 1.11.6 - '@webassemblyjs/ieee754': 1.11.6 - '@webassemblyjs/leb128': 1.11.6 - '@webassemblyjs/utf8': 1.11.6 + '@webassemblyjs/ast': 1.14.1 + '@webassemblyjs/helper-api-error': 1.13.2 + '@webassemblyjs/helper-wasm-bytecode': 1.13.2 + '@webassemblyjs/ieee754': 1.13.2 + '@webassemblyjs/leb128': 1.13.2 + '@webassemblyjs/utf8': 1.13.2 - '@webassemblyjs/wast-printer@1.12.1': + '@webassemblyjs/wast-printer@1.14.1': dependencies: - '@webassemblyjs/ast': 1.12.1 + '@webassemblyjs/ast': 1.14.1 '@xtuc/long': 4.2.2 '@xtuc/ieee754@1.2.0': {} @@ -7095,19 +7881,19 @@ snapshots: mime-types: 2.1.35 negotiator: 0.6.3 - acorn-import-attributes@1.9.5(acorn@8.12.0): + acorn-import-phases@1.0.4(acorn@8.15.0): dependencies: - acorn: 8.12.0 + acorn: 8.15.0 - acorn-jsx@5.3.2(acorn@8.12.0): + acorn-jsx@5.3.2(acorn@8.15.0): dependencies: - acorn: 8.12.0 + acorn: 8.15.0 - acorn-walk@8.3.3: + acorn-walk@8.3.4: dependencies: - acorn: 8.12.0 + acorn: 8.15.0 - acorn@8.12.0: {} + acorn@8.15.0: {} address@1.2.2: {} @@ -7116,17 +7902,25 @@ snapshots: clean-stack: 2.2.0 indent-string: 4.0.0 - ajv-formats@2.1.1(ajv@8.16.0): + ai@5.0.56(zod@4.1.11): + dependencies: + '@ai-sdk/gateway': 1.0.30(zod@4.1.11) + '@ai-sdk/provider': 2.0.0 + '@ai-sdk/provider-utils': 3.0.10(zod@4.1.11) + '@opentelemetry/api': 1.9.0 + zod: 4.1.11 + + ajv-formats@2.1.1(ajv@8.17.1): optionalDependencies: - ajv: 8.16.0 + ajv: 8.17.1 ajv-keywords@3.5.2(ajv@6.12.6): dependencies: ajv: 6.12.6 - ajv-keywords@5.1.0(ajv@8.16.0): + ajv-keywords@5.1.0(ajv@8.17.1): dependencies: - ajv: 8.16.0 + ajv: 8.17.1 fast-deep-equal: 3.1.3 ajv@6.12.6: @@ -7136,55 +7930,54 @@ snapshots: json-schema-traverse: 0.4.1 uri-js: 4.4.1 - ajv@8.16.0: + ajv@8.17.1: dependencies: fast-deep-equal: 3.1.3 + fast-uri: 3.1.0 json-schema-traverse: 1.0.0 require-from-string: 2.0.2 - uri-js: 4.4.1 - algoliasearch-helper@3.22.1(algoliasearch@4.23.3): + algoliasearch-helper@3.26.0(algoliasearch@5.39.0): dependencies: '@algolia/events': 4.0.1 - algoliasearch: 4.23.3 - - algoliasearch@4.23.3: - dependencies: - '@algolia/cache-browser-local-storage': 4.23.3 - '@algolia/cache-common': 4.23.3 - '@algolia/cache-in-memory': 4.23.3 - '@algolia/client-account': 4.23.3 - '@algolia/client-analytics': 4.23.3 - '@algolia/client-common': 4.23.3 - '@algolia/client-personalization': 4.23.3 - '@algolia/client-search': 4.23.3 - '@algolia/logger-common': 4.23.3 - '@algolia/logger-console': 4.23.3 - '@algolia/recommend': 4.23.3 - '@algolia/requester-browser-xhr': 4.23.3 - '@algolia/requester-common': 4.23.3 - '@algolia/requester-node-http': 4.23.3 - '@algolia/transporter': 4.23.3 + algoliasearch: 5.39.0 + + algoliasearch@5.39.0: + dependencies: + '@algolia/abtesting': 1.5.0 + '@algolia/client-abtesting': 5.39.0 + '@algolia/client-analytics': 5.39.0 + '@algolia/client-common': 5.39.0 + '@algolia/client-insights': 5.39.0 + '@algolia/client-personalization': 5.39.0 + '@algolia/client-query-suggestions': 5.39.0 + '@algolia/client-search': 5.39.0 + '@algolia/ingestion': 1.39.0 + '@algolia/monitoring': 1.39.0 + '@algolia/recommend': 5.39.0 + '@algolia/requester-browser-xhr': 5.39.0 + '@algolia/requester-fetch': 5.39.0 + '@algolia/requester-node-http': 5.39.0 ansi-align@3.0.1: dependencies: string-width: 4.2.3 + ansi-escapes@4.3.2: + dependencies: + type-fest: 0.21.3 + ansi-html-community@0.0.8: {} ansi-regex@5.0.1: {} - ansi-regex@6.0.1: {} - - ansi-styles@3.2.1: - dependencies: - color-convert: 1.9.3 + ansi-regex@6.2.2: {} ansi-styles@4.3.0: dependencies: color-convert: 2.0.1 - ansi-styles@6.2.1: {} + ansi-styles@6.2.3: {} any-promise@1.3.0: {} @@ -7205,52 +7998,50 @@ snapshots: array-union@2.1.0: {} - astring@1.8.6: {} - - at-least-node@1.0.0: {} + astring@1.9.0: {} - autoprefixer@10.4.19(postcss@8.4.38): + autoprefixer@10.4.21(postcss@8.5.6): dependencies: - browserslist: 4.23.1 - caniuse-lite: 1.0.30001636 + browserslist: 4.26.2 + caniuse-lite: 1.0.30001745 fraction.js: 4.3.7 normalize-range: 0.1.2 - picocolors: 1.0.1 - postcss: 8.4.38 + picocolors: 1.1.1 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - babel-loader@9.1.3(@babel/core@7.24.7)(webpack@5.92.1): + babel-loader@9.2.1(@babel/core@7.28.4)(webpack@5.101.3): dependencies: - '@babel/core': 7.24.7 + '@babel/core': 7.28.4 find-cache-dir: 4.0.0 - schema-utils: 4.2.0 - webpack: 5.92.1 + schema-utils: 4.3.2 + webpack: 5.101.3 babel-plugin-dynamic-import-node@2.3.3: dependencies: - object.assign: 4.1.5 + object.assign: 4.1.7 - babel-plugin-polyfill-corejs2@0.4.11(@babel/core@7.24.7): + babel-plugin-polyfill-corejs2@0.4.14(@babel/core@7.28.4): dependencies: - '@babel/compat-data': 7.24.7 - '@babel/core': 7.24.7 - '@babel/helper-define-polyfill-provider': 0.6.2(@babel/core@7.24.7) + '@babel/compat-data': 7.28.4 + '@babel/core': 7.28.4 + '@babel/helper-define-polyfill-provider': 0.6.5(@babel/core@7.28.4) semver: 6.3.1 transitivePeerDependencies: - supports-color - babel-plugin-polyfill-corejs3@0.10.4(@babel/core@7.24.7): + babel-plugin-polyfill-corejs3@0.13.0(@babel/core@7.28.4): dependencies: - '@babel/core': 7.24.7 - '@babel/helper-define-polyfill-provider': 0.6.2(@babel/core@7.24.7) - core-js-compat: 3.37.1 + '@babel/core': 7.28.4 + '@babel/helper-define-polyfill-provider': 0.6.5(@babel/core@7.28.4) + core-js-compat: 3.45.1 transitivePeerDependencies: - supports-color - babel-plugin-polyfill-regenerator@0.6.2(@babel/core@7.24.7): + babel-plugin-polyfill-regenerator@0.6.5(@babel/core@7.28.4): dependencies: - '@babel/core': 7.24.7 - '@babel/helper-define-polyfill-provider': 0.6.2(@babel/core@7.24.7) + '@babel/core': 7.28.4 + '@babel/helper-define-polyfill-provider': 0.6.5(@babel/core@7.28.4) transitivePeerDependencies: - supports-color @@ -7258,13 +8049,15 @@ snapshots: balanced-match@1.0.2: {} + baseline-browser-mapping@2.8.9: {} + batch@0.6.1: {} big.js@5.2.2: {} binary-extensions@2.3.0: {} - body-parser@1.20.2: + body-parser@1.20.3: dependencies: bytes: 3.1.2 content-type: 1.0.5 @@ -7274,14 +8067,14 @@ snapshots: http-errors: 2.0.0 iconv-lite: 0.4.24 on-finished: 2.4.1 - qs: 6.11.0 + qs: 6.13.0 raw-body: 2.5.2 type-is: 1.6.18 unpipe: 1.0.0 transitivePeerDependencies: - supports-color - bonjour-service@1.2.1: + bonjour-service@1.3.0: dependencies: fast-deep-equal: 3.1.3 multicast-dns: 7.2.5 @@ -7303,19 +8096,19 @@ snapshots: dependencies: ansi-align: 3.0.1 camelcase: 7.0.1 - chalk: 5.3.0 + chalk: 5.6.2 cli-boxes: 3.0.0 string-width: 5.1.2 type-fest: 2.19.0 widest-line: 4.0.1 wrap-ansi: 8.1.0 - brace-expansion@1.1.11: + brace-expansion@1.1.12: dependencies: balanced-match: 1.0.2 concat-map: 0.0.1 - brace-expansion@2.0.1: + brace-expansion@2.0.2: dependencies: balanced-match: 1.0.2 @@ -7323,15 +8116,20 @@ snapshots: dependencies: fill-range: 7.1.1 - browserslist@4.23.1: + browserslist@4.26.2: dependencies: - caniuse-lite: 1.0.30001636 - electron-to-chromium: 1.4.810 - node-releases: 2.0.14 - update-browserslist-db: 1.0.16(browserslist@4.23.1) + baseline-browser-mapping: 2.8.9 + caniuse-lite: 1.0.30001745 + electron-to-chromium: 1.5.227 + node-releases: 2.0.21 + update-browserslist-db: 1.1.3(browserslist@4.26.2) buffer-from@1.1.2: {} + bundle-name@4.1.0: + dependencies: + run-applescript: 7.1.0 + bytes@3.0.0: {} bytes@3.1.2: {} @@ -7342,26 +8140,35 @@ snapshots: dependencies: '@types/http-cache-semantics': 4.0.4 get-stream: 6.0.1 - http-cache-semantics: 4.1.1 + http-cache-semantics: 4.2.0 keyv: 4.5.4 mimic-response: 4.0.0 - normalize-url: 8.0.1 + normalize-url: 8.1.0 responselike: 3.0.0 - call-bind@1.0.7: + call-bind-apply-helpers@1.0.2: dependencies: - es-define-property: 1.0.0 es-errors: 1.3.0 function-bind: 1.1.2 - get-intrinsic: 1.2.4 + + call-bind@1.0.8: + dependencies: + call-bind-apply-helpers: 1.0.2 + es-define-property: 1.0.1 + get-intrinsic: 1.3.0 set-function-length: 1.2.2 + call-bound@1.0.4: + dependencies: + call-bind-apply-helpers: 1.0.2 + get-intrinsic: 1.3.0 + callsites@3.1.0: {} camel-case@4.1.2: dependencies: pascal-case: 3.1.2 - tslib: 2.6.3 + tslib: 2.8.1 camelcase-css@2.0.1: {} @@ -7371,27 +8178,21 @@ snapshots: caniuse-api@3.0.0: dependencies: - browserslist: 4.23.1 - caniuse-lite: 1.0.30001636 + browserslist: 4.26.2 + caniuse-lite: 1.0.30001745 lodash.memoize: 4.1.2 lodash.uniq: 4.5.0 - caniuse-lite@1.0.30001636: {} + caniuse-lite@1.0.30001745: {} ccount@2.0.1: {} - chalk@2.4.2: - dependencies: - ansi-styles: 3.2.1 - escape-string-regexp: 1.0.5 - supports-color: 5.5.0 - chalk@4.1.2: dependencies: ansi-styles: 4.3.0 supports-color: 7.2.0 - chalk@5.3.0: {} + chalk@5.6.2: {} char-regex@1.0.2: {} @@ -7406,21 +8207,35 @@ snapshots: cheerio-select@2.1.0: dependencies: boolbase: 1.0.0 - css-select: 5.1.0 - css-what: 6.1.0 + css-select: 5.2.2 + css-what: 6.2.2 domelementtype: 2.3.0 domhandler: 5.0.3 - domutils: 3.1.0 + domutils: 3.2.2 cheerio@1.0.0-rc.12: dependencies: cheerio-select: 2.1.0 dom-serializer: 2.0.0 domhandler: 5.0.3 - domutils: 3.1.0 + domutils: 3.2.2 htmlparser2: 8.0.2 - parse5: 7.1.2 - parse5-htmlparser2-tree-adapter: 7.0.0 + parse5: 7.3.0 + parse5-htmlparser2-tree-adapter: 7.1.0 + + cheerio@1.1.2: + dependencies: + cheerio-select: 2.1.0 + dom-serializer: 2.0.0 + domhandler: 5.0.3 + domutils: 3.2.2 + encoding-sniffer: 0.2.1 + htmlparser2: 10.0.0 + parse5: 7.3.0 + parse5-htmlparser2-tree-adapter: 7.1.0 + parse5-parser-stream: 7.1.2 + undici: 7.16.0 + whatwg-mimetype: 4.0.0 chokidar@3.6.0: dependencies: @@ -7458,22 +8273,14 @@ snapshots: kind-of: 6.0.3 shallow-clone: 3.0.1 - clsx@1.2.1: {} - clsx@2.1.1: {} collapse-white-space@2.1.0: {} - color-convert@1.9.3: - dependencies: - color-name: 1.1.3 - color-convert@2.0.1: dependencies: color-name: 1.1.4 - color-name@1.1.3: {} - color-name@1.1.4: {} colord@2.9.3: {} @@ -7482,6 +8289,8 @@ snapshots: combine-promises@1.2.0: {} + comlink@4.4.2: {} + comma-separated-tokens@2.0.3: {} commander@10.0.1: {} @@ -7500,16 +8309,16 @@ snapshots: compressible@2.0.18: dependencies: - mime-db: 1.52.0 + mime-db: 1.54.0 - compression@1.7.4: + compression@1.8.1: dependencies: - accepts: 1.3.8 - bytes: 3.0.0 + bytes: 3.1.2 compressible: 2.0.18 debug: 2.6.9 - on-headers: 1.0.2 - safe-buffer: 5.1.2 + negotiator: 0.6.4 + on-headers: 1.1.0 + safe-buffer: 5.2.1 vary: 1.1.2 transitivePeerDependencies: - supports-color @@ -7531,7 +8340,7 @@ snapshots: connect-history-api-fallback@2.0.0: {} - consola@2.15.3: {} + consola@3.4.2: {} content-disposition@0.5.2: {} @@ -7545,48 +8354,38 @@ snapshots: cookie-signature@1.0.6: {} - cookie@0.6.0: {} + cookie@0.7.1: {} - copy-text-to-clipboard@3.2.0: {} - - copy-webpack-plugin@11.0.0(webpack@5.92.1): + copy-webpack-plugin@11.0.0(webpack@5.101.3): dependencies: - fast-glob: 3.3.2 + fast-glob: 3.3.3 glob-parent: 6.0.2 globby: 13.2.2 normalize-path: 3.0.0 - schema-utils: 4.2.0 + schema-utils: 4.3.2 serialize-javascript: 6.0.2 - webpack: 5.92.1 + webpack: 5.101.3 - core-js-compat@3.37.1: + core-js-compat@3.45.1: dependencies: - browserslist: 4.23.1 + browserslist: 4.26.2 - core-js-pure@3.37.1: {} + core-js-pure@3.45.1: {} - core-js@3.37.1: {} + core-js@3.45.1: {} core-util-is@1.0.3: {} - cosmiconfig@6.0.0: - dependencies: - '@types/parse-json': 4.0.2 - import-fresh: 3.3.0 - parse-json: 5.2.0 - path-type: 4.0.0 - yaml: 1.10.2 - cosmiconfig@8.3.6(typescript@5.2.2): dependencies: - import-fresh: 3.3.0 + import-fresh: 3.3.1 js-yaml: 4.1.0 parse-json: 5.2.0 path-type: 4.0.0 optionalDependencies: typescript: 5.2.2 - cross-spawn@7.0.3: + cross-spawn@7.0.6: dependencies: path-key: 3.1.1 shebang-command: 2.0.0 @@ -7596,119 +8395,137 @@ snapshots: dependencies: type-fest: 1.4.0 - css-declaration-sorter@7.2.0(postcss@8.4.38): + css-blank-pseudo@7.0.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + css-declaration-sorter@7.3.0(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + css-has-pseudo@7.0.3(postcss@8.5.6): dependencies: - postcss: 8.4.38 + '@csstools/selector-specificity': 5.0.0(postcss-selector-parser@7.1.0) + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + postcss-value-parser: 4.2.0 - css-loader@6.11.0(webpack@5.92.1): + css-loader@6.11.0(webpack@5.101.3): dependencies: - icss-utils: 5.1.0(postcss@8.4.38) - postcss: 8.4.38 - postcss-modules-extract-imports: 3.1.0(postcss@8.4.38) - postcss-modules-local-by-default: 4.0.5(postcss@8.4.38) - postcss-modules-scope: 3.2.0(postcss@8.4.38) - postcss-modules-values: 4.0.0(postcss@8.4.38) + icss-utils: 5.1.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-modules-extract-imports: 3.1.0(postcss@8.5.6) + postcss-modules-local-by-default: 4.2.0(postcss@8.5.6) + postcss-modules-scope: 3.2.1(postcss@8.5.6) + postcss-modules-values: 4.0.0(postcss@8.5.6) postcss-value-parser: 4.2.0 - semver: 7.6.2 + semver: 7.7.2 optionalDependencies: - webpack: 5.92.1 + webpack: 5.101.3 - css-minimizer-webpack-plugin@5.0.1(clean-css@5.3.3)(webpack@5.92.1): + css-minimizer-webpack-plugin@5.0.1(clean-css@5.3.3)(webpack@5.101.3): dependencies: - '@jridgewell/trace-mapping': 0.3.25 - cssnano: 6.1.2(postcss@8.4.38) + '@jridgewell/trace-mapping': 0.3.31 + cssnano: 6.1.2(postcss@8.5.6) jest-worker: 29.7.0 - postcss: 8.4.38 - schema-utils: 4.2.0 + postcss: 8.5.6 + schema-utils: 4.3.2 serialize-javascript: 6.0.2 - webpack: 5.92.1 + webpack: 5.101.3 optionalDependencies: clean-css: 5.3.3 + css-prefers-color-scheme@10.0.0(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + css-select@4.3.0: dependencies: boolbase: 1.0.0 - css-what: 6.1.0 + css-what: 6.2.2 domhandler: 4.3.1 domutils: 2.8.0 nth-check: 2.1.1 - css-select@5.1.0: + css-select@5.2.2: dependencies: boolbase: 1.0.0 - css-what: 6.1.0 + css-what: 6.2.2 domhandler: 5.0.3 - domutils: 3.1.0 + domutils: 3.2.2 nth-check: 2.1.1 css-tree@2.2.1: dependencies: mdn-data: 2.0.28 - source-map-js: 1.2.0 + source-map-js: 1.2.1 css-tree@2.3.1: dependencies: mdn-data: 2.0.30 - source-map-js: 1.2.0 + source-map-js: 1.2.1 - css-what@6.1.0: {} + css-what@6.2.2: {} + + cssdb@8.4.2: {} cssesc@3.0.0: {} - cssnano-preset-advanced@6.1.2(postcss@8.4.38): - dependencies: - autoprefixer: 10.4.19(postcss@8.4.38) - browserslist: 4.23.1 - cssnano-preset-default: 6.1.2(postcss@8.4.38) - postcss: 8.4.38 - postcss-discard-unused: 6.0.5(postcss@8.4.38) - postcss-merge-idents: 6.0.3(postcss@8.4.38) - postcss-reduce-idents: 6.0.3(postcss@8.4.38) - postcss-zindex: 6.0.2(postcss@8.4.38) - - cssnano-preset-default@6.1.2(postcss@8.4.38): - dependencies: - browserslist: 4.23.1 - css-declaration-sorter: 7.2.0(postcss@8.4.38) - cssnano-utils: 4.0.2(postcss@8.4.38) - postcss: 8.4.38 - postcss-calc: 9.0.1(postcss@8.4.38) - postcss-colormin: 6.1.0(postcss@8.4.38) - postcss-convert-values: 6.1.0(postcss@8.4.38) - postcss-discard-comments: 6.0.2(postcss@8.4.38) - postcss-discard-duplicates: 6.0.3(postcss@8.4.38) - postcss-discard-empty: 6.0.3(postcss@8.4.38) - postcss-discard-overridden: 6.0.2(postcss@8.4.38) - postcss-merge-longhand: 6.0.5(postcss@8.4.38) - postcss-merge-rules: 6.1.1(postcss@8.4.38) - postcss-minify-font-values: 6.1.0(postcss@8.4.38) - postcss-minify-gradients: 6.0.3(postcss@8.4.38) - postcss-minify-params: 6.1.0(postcss@8.4.38) - postcss-minify-selectors: 6.0.4(postcss@8.4.38) - postcss-normalize-charset: 6.0.2(postcss@8.4.38) - postcss-normalize-display-values: 6.0.2(postcss@8.4.38) - postcss-normalize-positions: 6.0.2(postcss@8.4.38) - postcss-normalize-repeat-style: 6.0.2(postcss@8.4.38) - postcss-normalize-string: 6.0.2(postcss@8.4.38) - postcss-normalize-timing-functions: 6.0.2(postcss@8.4.38) - postcss-normalize-unicode: 6.1.0(postcss@8.4.38) - postcss-normalize-url: 6.0.2(postcss@8.4.38) - postcss-normalize-whitespace: 6.0.2(postcss@8.4.38) - postcss-ordered-values: 6.0.2(postcss@8.4.38) - postcss-reduce-initial: 6.1.0(postcss@8.4.38) - postcss-reduce-transforms: 6.0.2(postcss@8.4.38) - postcss-svgo: 6.0.3(postcss@8.4.38) - postcss-unique-selectors: 6.0.4(postcss@8.4.38) - - cssnano-utils@4.0.2(postcss@8.4.38): - dependencies: - postcss: 8.4.38 - - cssnano@6.1.2(postcss@8.4.38): - dependencies: - cssnano-preset-default: 6.1.2(postcss@8.4.38) - lilconfig: 3.1.2 - postcss: 8.4.38 + cssnano-preset-advanced@6.1.2(postcss@8.5.6): + dependencies: + autoprefixer: 10.4.21(postcss@8.5.6) + browserslist: 4.26.2 + cssnano-preset-default: 6.1.2(postcss@8.5.6) + postcss: 8.5.6 + postcss-discard-unused: 6.0.5(postcss@8.5.6) + postcss-merge-idents: 6.0.3(postcss@8.5.6) + postcss-reduce-idents: 6.0.3(postcss@8.5.6) + postcss-zindex: 6.0.2(postcss@8.5.6) + + cssnano-preset-default@6.1.2(postcss@8.5.6): + dependencies: + browserslist: 4.26.2 + css-declaration-sorter: 7.3.0(postcss@8.5.6) + cssnano-utils: 4.0.2(postcss@8.5.6) + postcss: 8.5.6 + postcss-calc: 9.0.1(postcss@8.5.6) + postcss-colormin: 6.1.0(postcss@8.5.6) + postcss-convert-values: 6.1.0(postcss@8.5.6) + postcss-discard-comments: 6.0.2(postcss@8.5.6) + postcss-discard-duplicates: 6.0.3(postcss@8.5.6) + postcss-discard-empty: 6.0.3(postcss@8.5.6) + postcss-discard-overridden: 6.0.2(postcss@8.5.6) + postcss-merge-longhand: 6.0.5(postcss@8.5.6) + postcss-merge-rules: 6.1.1(postcss@8.5.6) + postcss-minify-font-values: 6.1.0(postcss@8.5.6) + postcss-minify-gradients: 6.0.3(postcss@8.5.6) + postcss-minify-params: 6.1.0(postcss@8.5.6) + postcss-minify-selectors: 6.0.4(postcss@8.5.6) + postcss-normalize-charset: 6.0.2(postcss@8.5.6) + postcss-normalize-display-values: 6.0.2(postcss@8.5.6) + postcss-normalize-positions: 6.0.2(postcss@8.5.6) + postcss-normalize-repeat-style: 6.0.2(postcss@8.5.6) + postcss-normalize-string: 6.0.2(postcss@8.5.6) + postcss-normalize-timing-functions: 6.0.2(postcss@8.5.6) + postcss-normalize-unicode: 6.1.0(postcss@8.5.6) + postcss-normalize-url: 6.0.2(postcss@8.5.6) + postcss-normalize-whitespace: 6.0.2(postcss@8.5.6) + postcss-ordered-values: 6.0.2(postcss@8.5.6) + postcss-reduce-initial: 6.1.0(postcss@8.5.6) + postcss-reduce-transforms: 6.0.2(postcss@8.5.6) + postcss-svgo: 6.0.3(postcss@8.5.6) + postcss-unique-selectors: 6.0.4(postcss@8.5.6) + + cssnano-utils@4.0.2(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + cssnano@6.1.2(postcss@8.5.6): + dependencies: + cssnano-preset-default: 6.1.2(postcss@8.5.6) + lilconfig: 3.1.3 + postcss: 8.5.6 csso@5.0.5: dependencies: @@ -7722,11 +8539,11 @@ snapshots: dependencies: ms: 2.0.0 - debug@4.3.5: + debug@4.4.3: dependencies: - ms: 2.1.2 + ms: 2.1.3 - decode-named-character-reference@1.0.2: + decode-named-character-reference@1.2.0: dependencies: character-entities: 2.0.2 @@ -7738,37 +8555,31 @@ snapshots: deepmerge@4.3.1: {} - default-gateway@6.0.3: + default-browser-id@5.0.0: {} + + default-browser@5.2.1: dependencies: - execa: 5.1.1 + bundle-name: 4.1.0 + default-browser-id: 5.0.0 defer-to-connect@2.0.1: {} define-data-property@1.1.4: dependencies: - es-define-property: 1.0.0 + es-define-property: 1.0.1 es-errors: 1.3.0 - gopd: 1.0.1 + gopd: 1.2.0 define-lazy-prop@2.0.0: {} + define-lazy-prop@3.0.0: {} + define-properties@1.2.1: dependencies: define-data-property: 1.1.4 has-property-descriptors: 1.0.2 object-keys: 1.1.1 - del@6.1.1: - dependencies: - globby: 11.1.0 - graceful-fs: 4.2.11 - is-glob: 4.0.3 - is-path-cwd: 2.2.0 - is-path-inside: 3.0.3 - p-map: 4.0.0 - rimraf: 3.0.2 - slash: 3.0.0 - depd@1.1.2: {} depd@2.0.0: {} @@ -7779,17 +8590,10 @@ snapshots: detect-node@2.1.0: {} - detect-port-alt@1.1.6: - dependencies: - address: 1.2.2 - debug: 2.6.9 - transitivePeerDependencies: - - supports-color - detect-port@1.6.1: dependencies: address: 1.2.2 - debug: 4.3.5 + debug: 4.4.3 transitivePeerDependencies: - supports-color @@ -7841,7 +8645,7 @@ snapshots: domelementtype: 2.3.0 domhandler: 4.3.1 - domutils@3.1.0: + domutils@3.2.2: dependencies: dom-serializer: 2.0.0 domelementtype: 2.3.0 @@ -7850,19 +8654,25 @@ snapshots: dot-case@3.0.4: dependencies: no-case: 3.0.4 - tslib: 2.6.3 + tslib: 2.8.1 dot-prop@6.0.1: dependencies: is-obj: 2.0.0 + dunder-proto@1.0.1: + dependencies: + call-bind-apply-helpers: 1.0.2 + es-errors: 1.3.0 + gopd: 1.2.0 + duplexer@0.1.2: {} eastasianwidth@0.2.0: {} ee-first@1.1.1: {} - electron-to-chromium@1.4.810: {} + electron-to-chromium@1.5.227: {} emoji-regex@8.0.0: {} @@ -7872,32 +8682,57 @@ snapshots: emojis-list@3.0.0: {} - emoticon@4.0.1: {} + emoticon@4.1.0: {} encodeurl@1.0.2: {} - enhanced-resolve@5.17.0: + encodeurl@2.0.0: {} + + encoding-sniffer@0.2.1: + dependencies: + iconv-lite: 0.6.3 + whatwg-encoding: 3.1.1 + + enhanced-resolve@5.18.3: dependencies: graceful-fs: 4.2.11 - tapable: 2.2.1 + tapable: 2.2.3 entities@2.2.0: {} entities@4.5.0: {} - error-ex@1.3.2: + entities@6.0.1: {} + + error-ex@1.3.4: dependencies: is-arrayish: 0.2.1 - es-define-property@1.0.0: - dependencies: - get-intrinsic: 1.2.4 + es-define-property@1.0.1: {} es-errors@1.3.0: {} - es-module-lexer@1.5.3: {} + es-module-lexer@1.7.0: {} + + es-object-atoms@1.1.1: + dependencies: + es-errors: 1.3.0 + + esast-util-from-estree@2.0.0: + dependencies: + '@types/estree-jsx': 1.0.5 + devlop: 1.1.0 + estree-util-visit: 2.0.0 + unist-util-position-from-estree: 2.0.0 + + esast-util-from-js@2.0.1: + dependencies: + '@types/estree-jsx': 1.0.5 + acorn: 8.15.0 + esast-util-from-estree: 2.0.0 + vfile-message: 4.0.3 - escalade@3.1.2: {} + escalade@3.2.0: {} escape-goat@4.0.0: {} @@ -7926,7 +8761,7 @@ snapshots: estree-util-attach-comments@3.0.0: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 estree-util-build-jsx@3.0.1: dependencies: @@ -7937,24 +8772,29 @@ snapshots: estree-util-is-identifier-name@3.0.0: {} + estree-util-scope@1.0.0: + dependencies: + '@types/estree': 1.0.8 + devlop: 1.1.0 + estree-util-to-js@2.0.0: dependencies: '@types/estree-jsx': 1.0.5 - astring: 1.8.6 - source-map: 0.7.4 + astring: 1.9.0 + source-map: 0.7.6 - estree-util-value-to-estree@3.1.2: + estree-util-value-to-estree@3.4.0: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 estree-util-visit@2.0.0: dependencies: '@types/estree-jsx': 1.0.5 - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 estree-walker@3.0.3: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 esutils@2.0.3: {} @@ -7964,16 +8804,18 @@ snapshots: eval@0.1.8: dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 require-like: 0.1.2 eventemitter3@4.0.7: {} events@3.3.0: {} + eventsource-parser@3.0.6: {} + execa@5.1.1: dependencies: - cross-spawn: 7.0.3 + cross-spawn: 7.0.6 get-stream: 6.0.1 human-signals: 2.1.0 is-stream: 2.0.1 @@ -7983,34 +8825,34 @@ snapshots: signal-exit: 3.0.7 strip-final-newline: 2.0.0 - express@4.19.2: + express@4.21.2: dependencies: accepts: 1.3.8 array-flatten: 1.1.1 - body-parser: 1.20.2 + body-parser: 1.20.3 content-disposition: 0.5.4 content-type: 1.0.5 - cookie: 0.6.0 + cookie: 0.7.1 cookie-signature: 1.0.6 debug: 2.6.9 depd: 2.0.0 - encodeurl: 1.0.2 + encodeurl: 2.0.0 escape-html: 1.0.3 etag: 1.8.1 - finalhandler: 1.2.0 + finalhandler: 1.3.1 fresh: 0.5.2 http-errors: 2.0.0 - merge-descriptors: 1.0.1 + merge-descriptors: 1.0.3 methods: 1.1.2 on-finished: 2.4.1 parseurl: 1.3.3 - path-to-regexp: 0.1.7 + path-to-regexp: 0.1.12 proxy-addr: 2.0.7 - qs: 6.11.0 + qs: 6.13.0 range-parser: 1.2.1 safe-buffer: 5.2.1 - send: 0.18.0 - serve-static: 1.15.0 + send: 0.19.0 + serve-static: 1.16.2 setprototypeof: 1.2.0 statuses: 2.0.1 type-is: 1.6.18 @@ -8027,23 +8869,21 @@ snapshots: fast-deep-equal@3.1.3: {} - fast-glob@3.3.2: + fast-glob@3.3.3: dependencies: '@nodelib/fs.stat': 2.0.5 '@nodelib/fs.walk': 1.2.8 glob-parent: 5.1.2 merge2: 1.4.1 - micromatch: 4.0.7 + micromatch: 4.0.8 fast-json-stable-stringify@2.1.0: {} - fast-url-parser@1.1.3: - dependencies: - punycode: 1.4.1 + fast-uri@3.1.0: {} - fastq@1.17.1: + fastq@1.19.1: dependencies: - reusify: 1.0.4 + reusify: 1.1.0 fault@2.0.1: dependencies: @@ -8057,22 +8897,24 @@ snapshots: dependencies: xml-js: 1.6.11 - file-loader@6.2.0(webpack@5.92.1): + figures@3.2.0: + dependencies: + escape-string-regexp: 1.0.5 + + file-loader@6.2.0(webpack@5.101.3): dependencies: loader-utils: 2.0.4 schema-utils: 3.3.0 - webpack: 5.92.1 - - filesize@8.0.7: {} + webpack: 5.101.3 fill-range@7.1.1: dependencies: to-regex-range: 5.0.1 - finalhandler@1.2.0: + finalhandler@1.3.1: dependencies: debug: 2.6.9 - encodeurl: 1.0.2 + encodeurl: 2.0.0 escape-html: 1.0.3 on-finished: 2.4.1 parseurl: 1.3.3 @@ -8086,15 +8928,6 @@ snapshots: common-path-prefix: 3.0.0 pkg-dir: 7.0.0 - find-up@3.0.0: - dependencies: - locate-path: 3.0.0 - - find-up@5.0.0: - dependencies: - locate-path: 6.0.0 - path-exists: 4.0.0 - find-up@6.3.0: dependencies: locate-path: 7.2.0 @@ -8102,33 +8935,15 @@ snapshots: flat@5.0.2: {} - follow-redirects@1.15.6(debug@4.3.5): + follow-redirects@1.15.11(debug@4.4.3): optionalDependencies: - debug: 4.3.5 + debug: 4.4.3 - foreground-child@3.2.1: + foreground-child@3.3.1: dependencies: - cross-spawn: 7.0.3 + cross-spawn: 7.0.6 signal-exit: 4.1.0 - fork-ts-checker-webpack-plugin@6.5.3(typescript@5.2.2)(webpack@5.92.1): - dependencies: - '@babel/code-frame': 7.24.7 - '@types/json-schema': 7.0.15 - chalk: 4.1.2 - chokidar: 3.6.0 - cosmiconfig: 6.0.0 - deepmerge: 4.3.1 - fs-extra: 9.1.0 - glob: 7.2.3 - memfs: 3.5.3 - minimatch: 3.1.2 - schema-utils: 2.7.0 - semver: 7.6.2 - tapable: 1.1.3 - typescript: 5.2.2 - webpack: 5.92.1 - form-data-encoder@2.1.4: {} format@0.2.2: {} @@ -8142,26 +8957,15 @@ snapshots: fs-extra@10.1.0: dependencies: graceful-fs: 4.2.11 - jsonfile: 6.1.0 - universalify: 2.0.1 - - fs-extra@11.2.0: - dependencies: - graceful-fs: 4.2.11 - jsonfile: 6.1.0 + jsonfile: 6.2.0 universalify: 2.0.1 - fs-extra@9.1.0: + fs-extra@11.3.2: dependencies: - at-least-node: 1.0.0 graceful-fs: 4.2.11 - jsonfile: 6.1.0 + jsonfile: 6.2.0 universalify: 2.0.1 - fs-monkey@1.0.6: {} - - fs.realpath@1.0.0: {} - fsevents@2.3.3: optional: true @@ -8169,16 +8973,26 @@ snapshots: gensync@1.0.0-beta.2: {} - get-intrinsic@1.2.4: + get-intrinsic@1.3.0: dependencies: + call-bind-apply-helpers: 1.0.2 + es-define-property: 1.0.1 es-errors: 1.3.0 + es-object-atoms: 1.1.1 function-bind: 1.1.2 - has-proto: 1.0.3 - has-symbols: 1.0.3 + get-proto: 1.0.1 + gopd: 1.2.0 + has-symbols: 1.1.0 hasown: 2.0.2 + math-intrinsics: 1.1.0 get-own-enumerable-property-symbols@3.0.2: {} + get-proto@1.0.1: + dependencies: + dunder-proto: 1.0.1 + es-object-atoms: 1.1.1 + get-stream@6.0.1: {} github-slugger@1.5.0: {} @@ -8191,62 +9005,43 @@ snapshots: dependencies: is-glob: 4.0.3 - glob-to-regexp@0.4.1: {} - - glob@10.4.2: - dependencies: - foreground-child: 3.2.1 - jackspeak: 3.4.0 - minimatch: 9.0.5 - minipass: 7.1.2 - package-json-from-dist: 1.0.0 - path-scurry: 1.11.1 - - glob@7.2.3: + glob-to-regex.js@1.0.1(tslib@2.8.1): dependencies: - fs.realpath: 1.0.0 - inflight: 1.0.6 - inherits: 2.0.4 - minimatch: 3.1.2 - once: 1.4.0 - path-is-absolute: 1.0.1 + tslib: 2.8.1 - global-dirs@3.0.1: - dependencies: - ini: 2.0.0 + glob-to-regexp@0.4.1: {} - global-modules@2.0.0: + glob@10.4.5: dependencies: - global-prefix: 3.0.0 + foreground-child: 3.3.1 + jackspeak: 3.4.3 + minimatch: 9.0.5 + minipass: 7.1.2 + package-json-from-dist: 1.0.1 + path-scurry: 1.11.1 - global-prefix@3.0.0: + global-dirs@3.0.1: dependencies: - ini: 1.3.8 - kind-of: 6.0.3 - which: 1.3.1 - - globals@11.12.0: {} + ini: 2.0.0 globby@11.1.0: dependencies: array-union: 2.1.0 dir-glob: 3.0.1 - fast-glob: 3.3.2 - ignore: 5.3.1 + fast-glob: 3.3.3 + ignore: 5.3.2 merge2: 1.4.1 slash: 3.0.0 globby@13.2.2: dependencies: dir-glob: 3.0.1 - fast-glob: 3.3.2 - ignore: 5.3.1 + fast-glob: 3.3.3 + ignore: 5.3.2 merge2: 1.4.1 slash: 4.0.0 - gopd@1.0.1: - dependencies: - get-intrinsic: 1.2.4 + gopd@1.2.0: {} got@12.6.1: dependencies: @@ -8279,17 +9074,13 @@ snapshots: handle-thing@2.0.1: {} - has-flag@3.0.0: {} - has-flag@4.0.0: {} has-property-descriptors@1.0.2: dependencies: - es-define-property: 1.0.0 - - has-proto@1.0.3: {} + es-define-property: 1.0.1 - has-symbols@1.0.3: {} + has-symbols@1.1.0: {} has-yarn@3.0.0: {} @@ -8297,40 +9088,40 @@ snapshots: dependencies: function-bind: 1.1.2 - hast-util-from-parse5@8.0.1: + hast-util-from-parse5@8.0.3: dependencies: '@types/hast': 3.0.4 - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 devlop: 1.1.0 - hastscript: 8.0.0 - property-information: 6.5.0 - vfile: 6.0.1 - vfile-location: 5.0.2 + hastscript: 9.0.1 + property-information: 7.1.0 + vfile: 6.0.3 + vfile-location: 5.0.3 web-namespaces: 2.0.1 hast-util-parse-selector@4.0.0: dependencies: '@types/hast': 3.0.4 - hast-util-raw@9.0.4: + hast-util-raw@9.1.0: dependencies: '@types/hast': 3.0.4 - '@types/unist': 3.0.2 - '@ungap/structured-clone': 1.2.0 - hast-util-from-parse5: 8.0.1 + '@types/unist': 3.0.3 + '@ungap/structured-clone': 1.3.0 + hast-util-from-parse5: 8.0.3 hast-util-to-parse5: 8.0.0 html-void-elements: 3.0.0 mdast-util-to-hast: 13.2.0 - parse5: 7.1.2 + parse5: 7.3.0 unist-util-position: 5.0.0 unist-util-visit: 5.0.0 - vfile: 6.0.1 + vfile: 6.0.3 web-namespaces: 2.0.1 zwitch: 2.0.4 - hast-util-to-estree@3.1.0: + hast-util-to-estree@3.1.3: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 '@types/estree-jsx': 1.0.5 '@types/hast': 3.0.4 comma-separated-tokens: 2.0.3 @@ -8338,34 +9129,34 @@ snapshots: estree-util-attach-comments: 3.0.0 estree-util-is-identifier-name: 3.0.0 hast-util-whitespace: 3.0.0 - mdast-util-mdx-expression: 2.0.0 - mdast-util-mdx-jsx: 3.1.2 + mdast-util-mdx-expression: 2.0.1 + mdast-util-mdx-jsx: 3.2.0 mdast-util-mdxjs-esm: 2.0.1 - property-information: 6.5.0 + property-information: 7.1.0 space-separated-tokens: 2.0.2 - style-to-object: 0.4.4 + style-to-js: 1.1.17 unist-util-position: 5.0.0 zwitch: 2.0.4 transitivePeerDependencies: - supports-color - hast-util-to-jsx-runtime@2.3.0: + hast-util-to-jsx-runtime@2.3.6: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 '@types/hast': 3.0.4 - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 comma-separated-tokens: 2.0.3 devlop: 1.1.0 estree-util-is-identifier-name: 3.0.0 hast-util-whitespace: 3.0.0 - mdast-util-mdx-expression: 2.0.0 - mdast-util-mdx-jsx: 3.1.2 + mdast-util-mdx-expression: 2.0.1 + mdast-util-mdx-jsx: 3.2.0 mdast-util-mdxjs-esm: 2.0.1 - property-information: 6.5.0 + property-information: 7.1.0 space-separated-tokens: 2.0.2 - style-to-object: 1.0.6 + style-to-js: 1.1.17 unist-util-position: 5.0.0 - vfile-message: 4.0.2 + vfile-message: 4.0.3 transitivePeerDependencies: - supports-color @@ -8383,19 +9174,19 @@ snapshots: dependencies: '@types/hast': 3.0.4 - hastscript@8.0.0: + hastscript@9.0.1: dependencies: '@types/hast': 3.0.4 comma-separated-tokens: 2.0.3 hast-util-parse-selector: 4.0.0 - property-information: 6.5.0 + property-information: 7.1.0 space-separated-tokens: 2.0.2 he@1.2.0: {} history@4.10.1: dependencies: - '@babel/runtime': 7.24.7 + '@babel/runtime': 7.28.4 loose-envify: 1.4.0 resolve-pathname: 3.0.0 tiny-invariant: 1.3.3 @@ -8413,8 +9204,6 @@ snapshots: readable-stream: 2.3.8 wbuf: 1.7.3 - html-entities@2.5.2: {} - html-escaper@2.0.2: {} html-minifier-terser@6.1.0: @@ -8425,7 +9214,7 @@ snapshots: he: 1.2.0 param-case: 3.0.4 relateurl: 0.2.7 - terser: 5.31.1 + terser: 5.44.0 html-minifier-terser@7.2.0: dependencies: @@ -8435,21 +9224,28 @@ snapshots: entities: 4.5.0 param-case: 3.0.4 relateurl: 0.2.7 - terser: 5.31.1 + terser: 5.44.0 html-tags@3.3.1: {} html-void-elements@3.0.0: {} - html-webpack-plugin@5.6.0(webpack@5.92.1): + html-webpack-plugin@5.6.4(webpack@5.101.3): dependencies: '@types/html-minifier-terser': 6.1.0 html-minifier-terser: 6.1.0 lodash: 4.17.21 pretty-error: 4.0.0 - tapable: 2.2.1 + tapable: 2.2.3 optionalDependencies: - webpack: 5.92.1 + webpack: 5.101.3 + + htmlparser2@10.0.0: + dependencies: + domelementtype: 2.3.0 + domhandler: 5.0.3 + domutils: 3.2.2 + entities: 6.0.1 htmlparser2@6.1.0: dependencies: @@ -8462,10 +9258,10 @@ snapshots: dependencies: domelementtype: 2.3.0 domhandler: 5.0.3 - domutils: 3.1.0 + domutils: 3.2.2 entities: 4.5.0 - http-cache-semantics@4.1.1: {} + http-cache-semantics@4.2.0: {} http-deceiver@1.2.7: {} @@ -8484,24 +9280,24 @@ snapshots: statuses: 2.0.1 toidentifier: 1.0.1 - http-parser-js@0.5.8: {} + http-parser-js@0.5.10: {} - http-proxy-middleware@2.0.6(@types/express@4.17.21)(debug@4.3.5): + http-proxy-middleware@2.0.9(@types/express@4.17.23)(debug@4.4.3): dependencies: - '@types/http-proxy': 1.17.14 - http-proxy: 1.18.1(debug@4.3.5) + '@types/http-proxy': 1.17.16 + http-proxy: 1.18.1(debug@4.4.3) is-glob: 4.0.3 is-plain-obj: 3.0.0 - micromatch: 4.0.7 + micromatch: 4.0.8 optionalDependencies: - '@types/express': 4.17.21 + '@types/express': 4.17.23 transitivePeerDependencies: - debug - http-proxy@1.18.1(debug@4.3.5): + http-proxy@1.18.1(debug@4.4.3): dependencies: eventemitter3: 4.0.7 - follow-redirects: 1.15.6(debug@4.3.5) + follow-redirects: 1.15.11(debug@4.4.3) requires-port: 1.0.0 transitivePeerDependencies: - debug @@ -8513,25 +9309,27 @@ snapshots: human-signals@2.1.0: {} + hyperdyperid@1.2.0: {} + iconv-lite@0.4.24: dependencies: safer-buffer: 2.1.2 - icss-utils@5.1.0(postcss@8.4.38): + iconv-lite@0.6.3: dependencies: - postcss: 8.4.38 - - ignore@5.3.1: {} + safer-buffer: 2.1.2 - image-size@1.1.1: + icss-utils@5.1.0(postcss@8.5.6): dependencies: - queue: 6.0.2 + postcss: 8.5.6 - immediate@3.3.0: {} + ignore@5.3.2: {} + + image-size@2.0.2: {} - immer@9.0.21: {} + immediate@3.3.0: {} - import-fresh@3.3.0: + import-fresh@3.3.1: dependencies: parent-module: 1.0.1 resolve-from: 4.0.0 @@ -8542,12 +9340,7 @@ snapshots: indent-string@4.0.0: {} - infima@0.2.0-alpha.43: {} - - inflight@1.0.6: - dependencies: - once: 1.4.0 - wrappy: 1.0.2 + infima@0.2.0-alpha.45: {} inherits@2.0.3: {} @@ -8557,11 +9350,7 @@ snapshots: ini@2.0.0: {} - inline-style-parser@0.1.1: {} - - inline-style-parser@0.2.3: {} - - interpret@1.4.0: {} + inline-style-parser@0.2.4: {} invariant@2.2.4: dependencies: @@ -8588,7 +9377,7 @@ snapshots: dependencies: ci-info: 3.9.0 - is-core-module@2.14.0: + is-core-module@2.16.1: dependencies: hasown: 2.0.2 @@ -8596,6 +9385,8 @@ snapshots: is-docker@2.2.1: {} + is-docker@3.0.0: {} + is-extendable@0.1.1: {} is-extglob@2.1.1: {} @@ -8608,12 +9399,18 @@ snapshots: is-hexadecimal@2.0.1: {} + is-inside-container@1.0.0: + dependencies: + is-docker: 3.0.0 + is-installed-globally@0.4.0: dependencies: global-dirs: 3.0.1 is-path-inside: 3.0.3 - is-npm@6.0.0: {} + is-network-error@1.3.0: {} + + is-npm@6.1.0: {} is-number@7.0.0: {} @@ -8621,8 +9418,6 @@ snapshots: is-obj@2.0.0: {} - is-path-cwd@2.2.0: {} - is-path-inside@3.0.3: {} is-plain-obj@3.0.0: {} @@ -8633,14 +9428,8 @@ snapshots: dependencies: isobject: 3.0.1 - is-reference@3.0.2: - dependencies: - '@types/estree': 1.0.5 - is-regexp@1.0.0: {} - is-root@2.1.0: {} - is-stream@2.0.1: {} is-typedarray@1.0.0: {} @@ -8649,6 +9438,10 @@ snapshots: dependencies: is-docker: 2.2.1 + is-wsl@3.1.0: + dependencies: + is-inside-container: 1.0.0 + is-yarn-global@0.4.1: {} isarray@0.0.1: {} @@ -8659,7 +9452,7 @@ snapshots: isobject@3.0.1: {} - jackspeak@3.4.0: + jackspeak@3.4.3: dependencies: '@isaacs/cliui': 8.0.2 optionalDependencies: @@ -8668,7 +9461,7 @@ snapshots: jest-util@29.7.0: dependencies: '@jest/types': 29.6.3 - '@types/node': 20.14.8 + '@types/node': 24.5.2 chalk: 4.1.2 ci-info: 3.9.0 graceful-fs: 4.2.11 @@ -8676,18 +9469,18 @@ snapshots: jest-worker@27.5.1: dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 merge-stream: 2.0.0 supports-color: 8.1.1 jest-worker@29.7.0: dependencies: - '@types/node': 20.14.8 + '@types/node': 24.5.2 jest-util: 29.7.0 merge-stream: 2.0.0 supports-color: 8.1.1 - jiti@1.21.6: {} + jiti@1.21.7: {} joi@17.13.3: dependencies: @@ -8708,9 +9501,7 @@ snapshots: dependencies: argparse: 2.0.1 - jsesc@0.5.0: {} - - jsesc@2.5.2: {} + jsesc@3.1.0: {} json-buffer@3.0.1: {} @@ -8720,9 +9511,11 @@ snapshots: json-schema-traverse@1.0.0: {} + json-schema@0.4.0: {} + json5@2.2.3: {} - jsonfile@6.1.0: + jsonfile@6.2.0: dependencies: universalify: 2.0.1 optionalDependencies: @@ -8744,16 +9537,14 @@ snapshots: dependencies: package-json: 8.1.1 - launch-editor@2.8.0: + launch-editor@2.11.1: dependencies: - picocolors: 1.0.1 - shell-quote: 1.8.1 + picocolors: 1.1.1 + shell-quote: 1.8.3 leven@3.1.0: {} - lilconfig@2.1.0: {} - - lilconfig@3.1.2: {} + lilconfig@3.1.3: {} lines-and-columns@1.2.4: {} @@ -8765,17 +9556,6 @@ snapshots: emojis-list: 3.0.0 json5: 2.2.3 - loader-utils@3.3.1: {} - - locate-path@3.0.0: - dependencies: - p-locate: 3.0.0 - path-exists: 3.0.0 - - locate-path@6.0.0: - dependencies: - p-locate: 5.0.0 - locate-path@7.2.0: dependencies: p-locate: 6.0.0 @@ -8796,11 +9576,11 @@ snapshots: lower-case@2.0.2: dependencies: - tslib: 2.6.3 + tslib: 2.8.1 lowercase-keys@3.0.0: {} - lru-cache@10.3.0: {} + lru-cache@10.4.3: {} lru-cache@5.1.1: dependencies: @@ -8814,41 +9594,50 @@ snapshots: markdown-extensions@2.0.0: {} - markdown-table@3.0.3: {} + markdown-table@2.0.0: + dependencies: + repeat-string: 1.6.1 + + markdown-table@3.0.4: {} + + marked@16.3.0: {} - mdast-util-directive@3.0.0: + math-intrinsics@1.1.0: {} + + mdast-util-directive@3.1.0: dependencies: '@types/mdast': 4.0.4 - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 + ccount: 2.0.1 devlop: 1.1.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 - parse-entities: 4.0.1 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 + parse-entities: 4.0.2 stringify-entities: 4.0.4 unist-util-visit-parents: 6.0.1 transitivePeerDependencies: - supports-color - mdast-util-find-and-replace@3.0.1: + mdast-util-find-and-replace@3.0.2: dependencies: '@types/mdast': 4.0.4 escape-string-regexp: 5.0.0 unist-util-is: 6.0.0 unist-util-visit-parents: 6.0.1 - mdast-util-from-markdown@2.0.1: + mdast-util-from-markdown@2.0.2: dependencies: '@types/mdast': 4.0.4 - '@types/unist': 3.0.2 - decode-named-character-reference: 1.0.2 + '@types/unist': 3.0.3 + decode-named-character-reference: 1.2.0 devlop: 1.1.0 mdast-util-to-string: 4.0.0 - micromark: 4.0.0 - micromark-util-decode-numeric-character-reference: 2.0.1 - micromark-util-decode-string: 2.0.0 - micromark-util-normalize-identifier: 2.0.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark: 4.0.2 + micromark-util-decode-numeric-character-reference: 2.0.2 + micromark-util-decode-string: 2.0.1 + micromark-util-normalize-identifier: 2.0.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 unist-util-stringify-position: 4.0.0 transitivePeerDependencies: - supports-color @@ -8858,35 +9647,35 @@ snapshots: '@types/mdast': 4.0.4 devlop: 1.1.0 escape-string-regexp: 5.0.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 micromark-extension-frontmatter: 2.0.0 transitivePeerDependencies: - supports-color - mdast-util-gfm-autolink-literal@2.0.0: + mdast-util-gfm-autolink-literal@2.0.1: dependencies: '@types/mdast': 4.0.4 ccount: 2.0.1 devlop: 1.1.0 - mdast-util-find-and-replace: 3.0.1 - micromark-util-character: 2.1.0 + mdast-util-find-and-replace: 3.0.2 + micromark-util-character: 2.1.1 - mdast-util-gfm-footnote@2.0.0: + mdast-util-gfm-footnote@2.1.0: dependencies: '@types/mdast': 4.0.4 devlop: 1.1.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 - micromark-util-normalize-identifier: 2.0.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 + micromark-util-normalize-identifier: 2.0.1 transitivePeerDependencies: - supports-color mdast-util-gfm-strikethrough@2.0.0: dependencies: '@types/mdast': 4.0.4 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color @@ -8894,9 +9683,9 @@ snapshots: dependencies: '@types/mdast': 4.0.4 devlop: 1.1.0 - markdown-table: 3.0.3 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 + markdown-table: 3.0.4 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color @@ -8904,59 +9693,58 @@ snapshots: dependencies: '@types/mdast': 4.0.4 devlop: 1.1.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color - mdast-util-gfm@3.0.0: + mdast-util-gfm@3.1.0: dependencies: - mdast-util-from-markdown: 2.0.1 - mdast-util-gfm-autolink-literal: 2.0.0 - mdast-util-gfm-footnote: 2.0.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-gfm-autolink-literal: 2.0.1 + mdast-util-gfm-footnote: 2.1.0 mdast-util-gfm-strikethrough: 2.0.0 mdast-util-gfm-table: 2.0.0 mdast-util-gfm-task-list-item: 2.0.0 - mdast-util-to-markdown: 2.1.0 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color - mdast-util-mdx-expression@2.0.0: + mdast-util-mdx-expression@2.0.1: dependencies: '@types/estree-jsx': 1.0.5 '@types/hast': 3.0.4 '@types/mdast': 4.0.4 devlop: 1.1.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color - mdast-util-mdx-jsx@3.1.2: + mdast-util-mdx-jsx@3.2.0: dependencies: '@types/estree-jsx': 1.0.5 '@types/hast': 3.0.4 '@types/mdast': 4.0.4 - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 ccount: 2.0.1 devlop: 1.1.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 - parse-entities: 4.0.1 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 + parse-entities: 4.0.2 stringify-entities: 4.0.4 - unist-util-remove-position: 5.0.0 unist-util-stringify-position: 4.0.0 - vfile-message: 4.0.2 + vfile-message: 4.0.3 transitivePeerDependencies: - supports-color mdast-util-mdx@3.0.0: dependencies: - mdast-util-from-markdown: 2.0.1 - mdast-util-mdx-expression: 2.0.0 - mdast-util-mdx-jsx: 3.1.2 + mdast-util-from-markdown: 2.0.2 + mdast-util-mdx-expression: 2.0.1 + mdast-util-mdx-jsx: 3.2.0 mdast-util-mdxjs-esm: 2.0.1 - mdast-util-to-markdown: 2.1.0 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color @@ -8966,8 +9754,8 @@ snapshots: '@types/hast': 3.0.4 '@types/mdast': 4.0.4 devlop: 1.1.0 - mdast-util-from-markdown: 2.0.1 - mdast-util-to-markdown: 2.1.0 + mdast-util-from-markdown: 2.0.2 + mdast-util-to-markdown: 2.1.2 transitivePeerDependencies: - supports-color @@ -8980,22 +9768,23 @@ snapshots: dependencies: '@types/hast': 3.0.4 '@types/mdast': 4.0.4 - '@ungap/structured-clone': 1.2.0 + '@ungap/structured-clone': 1.3.0 devlop: 1.1.0 - micromark-util-sanitize-uri: 2.0.0 + micromark-util-sanitize-uri: 2.0.1 trim-lines: 3.0.1 unist-util-position: 5.0.0 unist-util-visit: 5.0.0 - vfile: 6.0.1 + vfile: 6.0.3 - mdast-util-to-markdown@2.1.0: + mdast-util-to-markdown@2.1.2: dependencies: '@types/mdast': 4.0.4 - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 longest-streak: 3.1.0 mdast-util-phrasing: 4.1.0 mdast-util-to-string: 4.0.0 - micromark-util-decode-string: 2.0.0 + micromark-util-classify-character: 2.0.1 + micromark-util-decode-string: 2.0.1 unist-util-visit: 5.0.0 zwitch: 2.0.4 @@ -9009,11 +9798,16 @@ snapshots: media-typer@0.3.0: {} - memfs@3.5.3: + memfs@4.47.0: dependencies: - fs-monkey: 1.0.6 + '@jsonjoy.com/json-pack': 1.14.0(tslib@2.8.1) + '@jsonjoy.com/util': 1.9.0(tslib@2.8.1) + glob-to-regex.js: 1.0.1(tslib@2.8.1) + thingies: 2.5.0(tslib@2.8.1) + tree-dump: 1.1.0(tslib@2.8.1) + tslib: 2.8.1 - merge-descriptors@1.0.1: {} + merge-descriptors@1.0.3: {} merge-stream@2.0.0: {} @@ -9021,302 +9815,302 @@ snapshots: methods@1.1.2: {} - micromark-core-commonmark@2.0.1: + micromark-core-commonmark@2.0.3: dependencies: - decode-named-character-reference: 1.0.2 + decode-named-character-reference: 1.2.0 devlop: 1.1.0 - micromark-factory-destination: 2.0.0 - micromark-factory-label: 2.0.0 - micromark-factory-space: 2.0.0 - micromark-factory-title: 2.0.0 - micromark-factory-whitespace: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-chunked: 2.0.0 - micromark-util-classify-character: 2.0.0 - micromark-util-html-tag-name: 2.0.0 - micromark-util-normalize-identifier: 2.0.0 - micromark-util-resolve-all: 2.0.0 - micromark-util-subtokenize: 2.0.1 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 - - micromark-extension-directive@3.0.0: + micromark-factory-destination: 2.0.1 + micromark-factory-label: 2.0.1 + micromark-factory-space: 2.0.1 + micromark-factory-title: 2.0.1 + micromark-factory-whitespace: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-chunked: 2.0.1 + micromark-util-classify-character: 2.0.1 + micromark-util-html-tag-name: 2.0.1 + micromark-util-normalize-identifier: 2.0.1 + micromark-util-resolve-all: 2.0.1 + micromark-util-subtokenize: 2.1.0 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 + + micromark-extension-directive@3.0.2: dependencies: devlop: 1.1.0 - micromark-factory-space: 2.0.0 - micromark-factory-whitespace: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 - parse-entities: 4.0.1 + micromark-factory-space: 2.0.1 + micromark-factory-whitespace: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 + parse-entities: 4.0.2 micromark-extension-frontmatter@2.0.0: dependencies: fault: 2.0.1 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-extension-gfm-autolink-literal@2.0.0: + micromark-extension-gfm-autolink-literal@2.1.0: dependencies: - micromark-util-character: 2.1.0 - micromark-util-sanitize-uri: 2.0.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-sanitize-uri: 2.0.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-extension-gfm-footnote@2.0.0: + micromark-extension-gfm-footnote@2.1.0: dependencies: devlop: 1.1.0 - micromark-core-commonmark: 2.0.1 - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-normalize-identifier: 2.0.0 - micromark-util-sanitize-uri: 2.0.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-core-commonmark: 2.0.3 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-normalize-identifier: 2.0.1 + micromark-util-sanitize-uri: 2.0.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-extension-gfm-strikethrough@2.0.0: + micromark-extension-gfm-strikethrough@2.1.0: dependencies: devlop: 1.1.0 - micromark-util-chunked: 2.0.0 - micromark-util-classify-character: 2.0.0 - micromark-util-resolve-all: 2.0.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-chunked: 2.0.1 + micromark-util-classify-character: 2.0.1 + micromark-util-resolve-all: 2.0.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-extension-gfm-table@2.0.0: + micromark-extension-gfm-table@2.1.1: dependencies: devlop: 1.1.0 - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 micromark-extension-gfm-tagfilter@2.0.0: dependencies: - micromark-util-types: 2.0.0 + micromark-util-types: 2.0.2 - micromark-extension-gfm-task-list-item@2.0.1: + micromark-extension-gfm-task-list-item@2.1.0: dependencies: devlop: 1.1.0 - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 micromark-extension-gfm@3.0.0: dependencies: - micromark-extension-gfm-autolink-literal: 2.0.0 - micromark-extension-gfm-footnote: 2.0.0 - micromark-extension-gfm-strikethrough: 2.0.0 - micromark-extension-gfm-table: 2.0.0 + micromark-extension-gfm-autolink-literal: 2.1.0 + micromark-extension-gfm-footnote: 2.1.0 + micromark-extension-gfm-strikethrough: 2.1.0 + micromark-extension-gfm-table: 2.1.1 micromark-extension-gfm-tagfilter: 2.0.0 - micromark-extension-gfm-task-list-item: 2.0.1 - micromark-util-combine-extensions: 2.0.0 - micromark-util-types: 2.0.0 + micromark-extension-gfm-task-list-item: 2.1.0 + micromark-util-combine-extensions: 2.0.1 + micromark-util-types: 2.0.2 - micromark-extension-mdx-expression@3.0.0: + micromark-extension-mdx-expression@3.0.1: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 devlop: 1.1.0 - micromark-factory-mdx-expression: 2.0.1 - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-events-to-acorn: 2.0.2 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-factory-mdx-expression: 2.0.3 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-events-to-acorn: 2.0.3 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-extension-mdx-jsx@3.0.0: + micromark-extension-mdx-jsx@3.0.2: dependencies: - '@types/acorn': 4.0.6 - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 devlop: 1.1.0 estree-util-is-identifier-name: 3.0.0 - micromark-factory-mdx-expression: 2.0.1 - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 - vfile-message: 4.0.2 + micromark-factory-mdx-expression: 2.0.3 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-events-to-acorn: 2.0.3 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 + vfile-message: 4.0.3 micromark-extension-mdx-md@2.0.0: dependencies: - micromark-util-types: 2.0.0 + micromark-util-types: 2.0.2 micromark-extension-mdxjs-esm@3.0.0: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 devlop: 1.1.0 - micromark-core-commonmark: 2.0.1 - micromark-util-character: 2.1.0 - micromark-util-events-to-acorn: 2.0.2 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-core-commonmark: 2.0.3 + micromark-util-character: 2.1.1 + micromark-util-events-to-acorn: 2.0.3 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 unist-util-position-from-estree: 2.0.0 - vfile-message: 4.0.2 + vfile-message: 4.0.3 micromark-extension-mdxjs@3.0.0: dependencies: - acorn: 8.12.0 - acorn-jsx: 5.3.2(acorn@8.12.0) - micromark-extension-mdx-expression: 3.0.0 - micromark-extension-mdx-jsx: 3.0.0 + acorn: 8.15.0 + acorn-jsx: 5.3.2(acorn@8.15.0) + micromark-extension-mdx-expression: 3.0.1 + micromark-extension-mdx-jsx: 3.0.2 micromark-extension-mdx-md: 2.0.0 micromark-extension-mdxjs-esm: 3.0.0 - micromark-util-combine-extensions: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-combine-extensions: 2.0.1 + micromark-util-types: 2.0.2 - micromark-factory-destination@2.0.0: + micromark-factory-destination@2.0.1: dependencies: - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-factory-label@2.0.0: + micromark-factory-label@2.0.1: dependencies: devlop: 1.1.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-factory-mdx-expression@2.0.1: + micromark-factory-mdx-expression@2.0.3: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 devlop: 1.1.0 - micromark-util-character: 2.1.0 - micromark-util-events-to-acorn: 2.0.2 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-events-to-acorn: 2.0.3 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 unist-util-position-from-estree: 2.0.0 - vfile-message: 4.0.2 + vfile-message: 4.0.3 micromark-factory-space@1.1.0: dependencies: micromark-util-character: 1.2.0 micromark-util-types: 1.1.0 - micromark-factory-space@2.0.0: + micromark-factory-space@2.0.1: dependencies: - micromark-util-character: 2.1.0 - micromark-util-types: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-types: 2.0.2 - micromark-factory-title@2.0.0: + micromark-factory-title@2.0.1: dependencies: - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-factory-whitespace@2.0.0: + micromark-factory-whitespace@2.0.1: dependencies: - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 micromark-util-character@1.2.0: dependencies: micromark-util-symbol: 1.1.0 micromark-util-types: 1.1.0 - micromark-util-character@2.1.0: + micromark-util-character@2.1.1: dependencies: - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-util-chunked@2.0.0: + micromark-util-chunked@2.0.1: dependencies: - micromark-util-symbol: 2.0.0 + micromark-util-symbol: 2.0.1 - micromark-util-classify-character@2.0.0: + micromark-util-classify-character@2.0.1: dependencies: - micromark-util-character: 2.1.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 - micromark-util-combine-extensions@2.0.0: + micromark-util-combine-extensions@2.0.1: dependencies: - micromark-util-chunked: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-chunked: 2.0.1 + micromark-util-types: 2.0.2 - micromark-util-decode-numeric-character-reference@2.0.1: + micromark-util-decode-numeric-character-reference@2.0.2: dependencies: - micromark-util-symbol: 2.0.0 + micromark-util-symbol: 2.0.1 - micromark-util-decode-string@2.0.0: + micromark-util-decode-string@2.0.1: dependencies: - decode-named-character-reference: 1.0.2 - micromark-util-character: 2.1.0 - micromark-util-decode-numeric-character-reference: 2.0.1 - micromark-util-symbol: 2.0.0 + decode-named-character-reference: 1.2.0 + micromark-util-character: 2.1.1 + micromark-util-decode-numeric-character-reference: 2.0.2 + micromark-util-symbol: 2.0.1 - micromark-util-encode@2.0.0: {} + micromark-util-encode@2.0.1: {} - micromark-util-events-to-acorn@2.0.2: + micromark-util-events-to-acorn@2.0.3: dependencies: - '@types/acorn': 4.0.6 - '@types/estree': 1.0.5 - '@types/unist': 3.0.2 + '@types/estree': 1.0.8 + '@types/unist': 3.0.3 devlop: 1.1.0 estree-util-visit: 2.0.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 - vfile-message: 4.0.2 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 + vfile-message: 4.0.3 - micromark-util-html-tag-name@2.0.0: {} + micromark-util-html-tag-name@2.0.1: {} - micromark-util-normalize-identifier@2.0.0: + micromark-util-normalize-identifier@2.0.1: dependencies: - micromark-util-symbol: 2.0.0 + micromark-util-symbol: 2.0.1 - micromark-util-resolve-all@2.0.0: + micromark-util-resolve-all@2.0.1: dependencies: - micromark-util-types: 2.0.0 + micromark-util-types: 2.0.2 - micromark-util-sanitize-uri@2.0.0: + micromark-util-sanitize-uri@2.0.1: dependencies: - micromark-util-character: 2.1.0 - micromark-util-encode: 2.0.0 - micromark-util-symbol: 2.0.0 + micromark-util-character: 2.1.1 + micromark-util-encode: 2.0.1 + micromark-util-symbol: 2.0.1 - micromark-util-subtokenize@2.0.1: + micromark-util-subtokenize@2.1.0: dependencies: devlop: 1.1.0 - micromark-util-chunked: 2.0.0 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-util-chunked: 2.0.1 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 micromark-util-symbol@1.1.0: {} - micromark-util-symbol@2.0.0: {} + micromark-util-symbol@2.0.1: {} micromark-util-types@1.1.0: {} - micromark-util-types@2.0.0: {} + micromark-util-types@2.0.2: {} - micromark@4.0.0: + micromark@4.0.2: dependencies: '@types/debug': 4.1.12 - debug: 4.3.5 - decode-named-character-reference: 1.0.2 + debug: 4.4.3 + decode-named-character-reference: 1.2.0 devlop: 1.1.0 - micromark-core-commonmark: 2.0.1 - micromark-factory-space: 2.0.0 - micromark-util-character: 2.1.0 - micromark-util-chunked: 2.0.0 - micromark-util-combine-extensions: 2.0.0 - micromark-util-decode-numeric-character-reference: 2.0.1 - micromark-util-encode: 2.0.0 - micromark-util-normalize-identifier: 2.0.0 - micromark-util-resolve-all: 2.0.0 - micromark-util-sanitize-uri: 2.0.0 - micromark-util-subtokenize: 2.0.1 - micromark-util-symbol: 2.0.0 - micromark-util-types: 2.0.0 + micromark-core-commonmark: 2.0.3 + micromark-factory-space: 2.0.1 + micromark-util-character: 2.1.1 + micromark-util-chunked: 2.0.1 + micromark-util-combine-extensions: 2.0.1 + micromark-util-decode-numeric-character-reference: 2.0.2 + micromark-util-encode: 2.0.1 + micromark-util-normalize-identifier: 2.0.1 + micromark-util-resolve-all: 2.0.1 + micromark-util-sanitize-uri: 2.0.1 + micromark-util-subtokenize: 2.1.0 + micromark-util-symbol: 2.0.1 + micromark-util-types: 2.0.2 transitivePeerDependencies: - supports-color - micromatch@4.0.7: + micromatch@4.0.8: dependencies: braces: 3.0.3 picomatch: 2.3.1 @@ -9325,6 +10119,8 @@ snapshots: mime-db@1.52.0: {} + mime-db@1.54.0: {} + mime-types@2.1.18: dependencies: mime-db: 1.33.0 @@ -9333,6 +10129,10 @@ snapshots: dependencies: mime-db: 1.52.0 + mime-types@3.0.1: + dependencies: + mime-db: 1.54.0 + mime@1.6.0: {} mimic-fn@2.1.0: {} @@ -9341,32 +10141,30 @@ snapshots: mimic-response@4.0.0: {} - mini-css-extract-plugin@2.9.0(webpack@5.92.1): + mini-css-extract-plugin@2.9.4(webpack@5.101.3): dependencies: - schema-utils: 4.2.0 - tapable: 2.2.1 - webpack: 5.92.1 + schema-utils: 4.3.2 + tapable: 2.2.3 + webpack: 5.101.3 minimalistic-assert@1.0.1: {} minimatch@3.1.2: dependencies: - brace-expansion: 1.1.11 + brace-expansion: 1.1.12 minimatch@9.0.5: dependencies: - brace-expansion: 2.0.1 + brace-expansion: 2.0.2 minimist@1.2.8: {} minipass@7.1.2: {} - mrmime@2.0.0: {} + mrmime@2.0.1: {} ms@2.0.0: {} - ms@2.1.2: {} - ms@2.1.3: {} multicast-dns@7.2.5: @@ -9380,18 +10178,20 @@ snapshots: object-assign: 4.1.1 thenify-all: 1.6.0 - nanoid@3.3.7: {} + nanoid@3.3.11: {} negotiator@0.6.3: {} + negotiator@0.6.4: {} + neo-async@2.6.2: {} no-case@3.0.4: dependencies: lower-case: 2.0.2 - tslib: 2.6.3 + tslib: 2.8.1 - node-emoji@2.1.3: + node-emoji@2.2.0: dependencies: '@sindresorhus/is': 4.6.0 char-regex: 1.0.2 @@ -9400,13 +10200,13 @@ snapshots: node-forge@1.3.1: {} - node-releases@2.0.14: {} + node-releases@2.0.21: {} normalize-path@3.0.0: {} normalize-range@0.1.2: {} - normalize-url@8.0.1: {} + normalize-url@8.1.0: {} npm-run-path@4.0.1: dependencies: @@ -9418,19 +10218,27 @@ snapshots: dependencies: boolbase: 1.0.0 + null-loader@4.0.1(webpack@5.101.3): + dependencies: + loader-utils: 2.0.4 + schema-utils: 3.3.0 + webpack: 5.101.3 + object-assign@4.1.1: {} object-hash@3.0.0: {} - object-inspect@1.13.2: {} + object-inspect@1.13.4: {} object-keys@1.1.1: {} - object.assign@4.1.5: + object.assign@4.1.7: dependencies: - call-bind: 1.0.7 + call-bind: 1.0.8 + call-bound: 1.0.4 define-properties: 1.2.1 - has-symbols: 1.0.3 + es-object-atoms: 1.1.1 + has-symbols: 1.1.0 object-keys: 1.1.1 obuf@1.1.2: {} @@ -9439,16 +10247,19 @@ snapshots: dependencies: ee-first: 1.1.1 - on-headers@1.0.2: {} - - once@1.4.0: - dependencies: - wrappy: 1.0.2 + on-headers@1.1.0: {} onetime@5.1.2: dependencies: mimic-fn: 2.1.0 + open@10.2.0: + dependencies: + default-browser: 5.2.1 + define-lazy-prop: 3.0.0 + is-inside-container: 1.0.0 + wsl-utils: 0.1.0 + open@8.4.2: dependencies: define-lazy-prop: 2.0.0 @@ -9459,25 +10270,11 @@ snapshots: p-cancelable@3.0.0: {} - p-limit@2.3.0: - dependencies: - p-try: 2.2.0 - - p-limit@3.1.0: - dependencies: - yocto-queue: 0.1.0 + p-finally@1.0.0: {} p-limit@4.0.0: dependencies: - yocto-queue: 1.0.0 - - p-locate@3.0.0: - dependencies: - p-limit: 2.3.0 - - p-locate@5.0.0: - dependencies: - p-limit: 3.1.0 + yocto-queue: 1.2.1 p-locate@6.0.0: dependencies: @@ -9487,75 +10284,80 @@ snapshots: dependencies: aggregate-error: 3.1.0 - p-retry@4.6.2: + p-queue@6.6.2: + dependencies: + eventemitter3: 4.0.7 + p-timeout: 3.2.0 + + p-retry@6.2.1: dependencies: - '@types/retry': 0.12.0 + '@types/retry': 0.12.2 + is-network-error: 1.3.0 retry: 0.13.1 - p-try@2.2.0: {} + p-timeout@3.2.0: + dependencies: + p-finally: 1.0.0 - package-json-from-dist@1.0.0: {} + package-json-from-dist@1.0.1: {} package-json@8.1.1: dependencies: got: 12.6.1 - registry-auth-token: 5.0.2 + registry-auth-token: 5.1.0 registry-url: 6.0.1 - semver: 7.6.2 + semver: 7.7.2 param-case@3.0.4: dependencies: dot-case: 3.0.4 - tslib: 2.6.3 + tslib: 2.8.1 parent-module@1.0.1: dependencies: callsites: 3.1.0 - parse-entities@4.0.1: + parse-entities@4.0.2: dependencies: - '@types/unist': 2.0.10 - character-entities: 2.0.2 + '@types/unist': 2.0.11 character-entities-legacy: 3.0.0 character-reference-invalid: 2.0.1 - decode-named-character-reference: 1.0.2 + decode-named-character-reference: 1.2.0 is-alphanumerical: 2.0.1 is-decimal: 2.0.1 is-hexadecimal: 2.0.1 parse-json@5.2.0: dependencies: - '@babel/code-frame': 7.24.7 - error-ex: 1.3.2 + '@babel/code-frame': 7.27.1 + error-ex: 1.3.4 json-parse-even-better-errors: 2.3.1 lines-and-columns: 1.2.4 parse-numeric-range@1.3.0: {} - parse5-htmlparser2-tree-adapter@7.0.0: + parse5-htmlparser2-tree-adapter@7.1.0: dependencies: domhandler: 5.0.3 - parse5: 7.1.2 + parse5: 7.3.0 - parse5@7.1.2: + parse5-parser-stream@7.1.2: dependencies: - entities: 4.5.0 + parse5: 7.3.0 + + parse5@7.3.0: + dependencies: + entities: 6.0.1 parseurl@1.3.3: {} pascal-case@3.1.2: dependencies: no-case: 3.0.4 - tslib: 2.6.3 - - path-exists@3.0.0: {} - - path-exists@4.0.0: {} + tslib: 2.8.1 path-exists@5.0.0: {} - path-is-absolute@1.0.1: {} - path-is-inside@1.0.2: {} path-key@3.1.1: {} @@ -9564,280 +10366,491 @@ snapshots: path-scurry@1.11.1: dependencies: - lru-cache: 10.3.0 + lru-cache: 10.4.3 minipass: 7.1.2 - path-to-regexp@0.1.7: {} + path-to-regexp@0.1.12: {} - path-to-regexp@1.8.0: + path-to-regexp@1.9.0: dependencies: isarray: 0.0.1 - path-to-regexp@2.2.1: {} + path-to-regexp@3.3.0: {} path-type@4.0.0: {} - periscopic@3.1.0: - dependencies: - '@types/estree': 1.0.5 - estree-walker: 3.0.3 - is-reference: 3.0.2 - - picocolors@1.0.1: {} + picocolors@1.1.1: {} picomatch@2.3.1: {} pify@2.3.0: {} - pirates@4.0.6: {} + pirates@4.0.7: {} pkg-dir@7.0.0: dependencies: find-up: 6.3.0 - pkg-up@3.1.0: + postcss-attribute-case-insensitive@7.0.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + postcss-calc@9.0.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 + postcss-value-parser: 4.2.0 + + postcss-clamp@4.1.0(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + + postcss-color-functional-notation@7.0.12(postcss@8.5.6): dependencies: - find-up: 3.0.0 + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - postcss-calc@9.0.1(postcss@8.4.38): + postcss-color-hex-alpha@10.0.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-colormin@6.1.0(postcss@8.4.38): + postcss-color-rebeccapurple@10.0.0(postcss@8.5.6): dependencies: - browserslist: 4.23.1 + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + + postcss-colormin@6.1.0(postcss@8.5.6): + dependencies: + browserslist: 4.26.2 caniuse-api: 3.0.0 colord: 2.9.3 - postcss: 8.4.38 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + + postcss-convert-values@6.1.0(postcss@8.5.6): + dependencies: + browserslist: 4.26.2 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + + postcss-custom-media@11.0.6(postcss@8.5.6): + dependencies: + '@csstools/cascade-layer-name-parser': 2.0.5(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/media-query-list-parser': 4.0.3(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + postcss: 8.5.6 + + postcss-custom-properties@14.0.6(postcss@8.5.6): + dependencies: + '@csstools/cascade-layer-name-parser': 2.0.5(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-convert-values@6.1.0(postcss@8.4.38): + postcss-custom-selectors@8.0.5(postcss@8.5.6): + dependencies: + '@csstools/cascade-layer-name-parser': 2.0.5(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + postcss-dir-pseudo-class@9.0.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + postcss-discard-comments@6.0.2(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + postcss-discard-duplicates@6.0.3(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + postcss-discard-empty@6.0.3(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + postcss-discard-overridden@6.0.2(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + postcss-discard-unused@6.0.5(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 + + postcss-double-position-gradients@6.0.4(postcss@8.5.6): dependencies: - browserslist: 4.23.1 - postcss: 8.4.38 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-discard-comments@6.0.2(postcss@8.4.38): + postcss-focus-visible@10.0.1(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 - postcss-discard-duplicates@6.0.3(postcss@8.4.38): + postcss-focus-within@9.0.1(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 - postcss-discard-empty@6.0.3(postcss@8.4.38): + postcss-font-variant@5.0.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 - postcss-discard-overridden@6.0.2(postcss@8.4.38): + postcss-gap-properties@6.0.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 - postcss-discard-unused@6.0.5(postcss@8.4.38): + postcss-image-set-function@7.0.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - postcss-import@15.1.0(postcss@8.4.38): + postcss-import@15.1.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 read-cache: 1.0.0 - resolve: 1.22.8 + resolve: 1.22.10 - postcss-js@4.0.1(postcss@8.4.38): + postcss-js@4.1.0(postcss@8.5.6): dependencies: camelcase-css: 2.0.1 - postcss: 8.4.38 + postcss: 8.5.6 + + postcss-lab-function@7.0.12(postcss@8.5.6): + dependencies: + '@csstools/css-color-parser': 3.1.0(@csstools/css-parser-algorithms@3.0.5(@csstools/css-tokenizer@3.0.4))(@csstools/css-tokenizer@3.0.4) + '@csstools/css-parser-algorithms': 3.0.5(@csstools/css-tokenizer@3.0.4) + '@csstools/css-tokenizer': 3.0.4 + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/utilities': 2.0.0(postcss@8.5.6) + postcss: 8.5.6 - postcss-load-config@4.0.2(postcss@8.4.38): + postcss-load-config@4.0.2(postcss@8.5.6): dependencies: - lilconfig: 3.1.2 - yaml: 2.4.5 + lilconfig: 3.1.3 + yaml: 2.8.1 optionalDependencies: - postcss: 8.4.38 + postcss: 8.5.6 - postcss-loader@7.3.4(postcss@8.4.38)(typescript@5.2.2)(webpack@5.92.1): + postcss-loader@7.3.4(postcss@8.5.6)(typescript@5.2.2)(webpack@5.101.3): dependencies: cosmiconfig: 8.3.6(typescript@5.2.2) - jiti: 1.21.6 - postcss: 8.4.38 - semver: 7.6.2 - webpack: 5.92.1 + jiti: 1.21.7 + postcss: 8.5.6 + semver: 7.7.2 + webpack: 5.101.3 transitivePeerDependencies: - typescript - postcss-merge-idents@6.0.3(postcss@8.4.38): + postcss-logical@8.1.0(postcss@8.5.6): dependencies: - cssnano-utils: 4.0.2(postcss@8.4.38) - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-merge-longhand@6.0.5(postcss@8.4.38): + postcss-merge-idents@6.0.3(postcss@8.5.6): dependencies: - postcss: 8.4.38 + cssnano-utils: 4.0.2(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - stylehacks: 6.1.1(postcss@8.4.38) - postcss-merge-rules@6.1.1(postcss@8.4.38): + postcss-merge-longhand@6.0.5(postcss@8.5.6): dependencies: - browserslist: 4.23.1 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + stylehacks: 6.1.1(postcss@8.5.6) + + postcss-merge-rules@6.1.1(postcss@8.5.6): + dependencies: + browserslist: 4.26.2 caniuse-api: 3.0.0 - cssnano-utils: 4.0.2(postcss@8.4.38) - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + cssnano-utils: 4.0.2(postcss@8.5.6) + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 - postcss-minify-font-values@6.1.0(postcss@8.4.38): + postcss-minify-font-values@6.1.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-minify-gradients@6.0.3(postcss@8.4.38): + postcss-minify-gradients@6.0.3(postcss@8.5.6): dependencies: colord: 2.9.3 - cssnano-utils: 4.0.2(postcss@8.4.38) - postcss: 8.4.38 + cssnano-utils: 4.0.2(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-minify-params@6.1.0(postcss@8.4.38): + postcss-minify-params@6.1.0(postcss@8.5.6): dependencies: - browserslist: 4.23.1 - cssnano-utils: 4.0.2(postcss@8.4.38) - postcss: 8.4.38 + browserslist: 4.26.2 + cssnano-utils: 4.0.2(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-minify-selectors@6.0.4(postcss@8.4.38): + postcss-minify-selectors@6.0.4(postcss@8.5.6): dependencies: - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 - postcss-modules-extract-imports@3.1.0(postcss@8.4.38): + postcss-modules-extract-imports@3.1.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 - postcss-modules-local-by-default@4.0.5(postcss@8.4.38): + postcss-modules-local-by-default@4.2.0(postcss@8.5.6): dependencies: - icss-utils: 5.1.0(postcss@8.4.38) - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + icss-utils: 5.1.0(postcss@8.5.6) + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 postcss-value-parser: 4.2.0 - postcss-modules-scope@3.2.0(postcss@8.4.38): + postcss-modules-scope@3.2.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + postcss-modules-values@4.0.0(postcss@8.5.6): + dependencies: + icss-utils: 5.1.0(postcss@8.5.6) + postcss: 8.5.6 + + postcss-nested@6.2.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 - postcss-modules-values@4.0.0(postcss@8.4.38): + postcss-nesting@13.0.2(postcss@8.5.6): dependencies: - icss-utils: 5.1.0(postcss@8.4.38) - postcss: 8.4.38 + '@csstools/selector-resolve-nested': 3.1.0(postcss-selector-parser@7.1.0) + '@csstools/selector-specificity': 5.0.0(postcss-selector-parser@7.1.0) + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 - postcss-nested@6.0.1(postcss@8.4.38): + postcss-normalize-charset@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + postcss: 8.5.6 - postcss-normalize-charset@6.0.2(postcss@8.4.38): + postcss-normalize-display-values@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 + postcss-value-parser: 4.2.0 - postcss-normalize-display-values@6.0.2(postcss@8.4.38): + postcss-normalize-positions@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-positions@6.0.2(postcss@8.4.38): + postcss-normalize-repeat-style@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-repeat-style@6.0.2(postcss@8.4.38): + postcss-normalize-string@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-string@6.0.2(postcss@8.4.38): + postcss-normalize-timing-functions@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-timing-functions@6.0.2(postcss@8.4.38): + postcss-normalize-unicode@6.1.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + browserslist: 4.26.2 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-unicode@6.1.0(postcss@8.4.38): + postcss-normalize-url@6.0.2(postcss@8.5.6): dependencies: - browserslist: 4.23.1 - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-url@6.0.2(postcss@8.4.38): + postcss-normalize-whitespace@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-normalize-whitespace@6.0.2(postcss@8.4.38): + postcss-opacity-percentage@3.0.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 + + postcss-ordered-values@6.0.2(postcss@8.5.6): + dependencies: + cssnano-utils: 4.0.2(postcss@8.5.6) + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-ordered-values@6.0.2(postcss@8.4.38): + postcss-overflow-shorthand@6.0.0(postcss@8.5.6): dependencies: - cssnano-utils: 4.0.2(postcss@8.4.38) - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-reduce-idents@6.0.3(postcss@8.4.38): + postcss-page-break@3.0.4(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + postcss-place@10.0.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-reduce-initial@6.1.0(postcss@8.4.38): + postcss-preset-env@10.4.0(postcss@8.5.6): + dependencies: + '@csstools/postcss-alpha-function': 1.0.1(postcss@8.5.6) + '@csstools/postcss-cascade-layers': 5.0.2(postcss@8.5.6) + '@csstools/postcss-color-function': 4.0.12(postcss@8.5.6) + '@csstools/postcss-color-function-display-p3-linear': 1.0.1(postcss@8.5.6) + '@csstools/postcss-color-mix-function': 3.0.12(postcss@8.5.6) + '@csstools/postcss-color-mix-variadic-function-arguments': 1.0.2(postcss@8.5.6) + '@csstools/postcss-content-alt-text': 2.0.8(postcss@8.5.6) + '@csstools/postcss-contrast-color-function': 2.0.12(postcss@8.5.6) + '@csstools/postcss-exponential-functions': 2.0.9(postcss@8.5.6) + '@csstools/postcss-font-format-keywords': 4.0.0(postcss@8.5.6) + '@csstools/postcss-gamut-mapping': 2.0.11(postcss@8.5.6) + '@csstools/postcss-gradients-interpolation-method': 5.0.12(postcss@8.5.6) + '@csstools/postcss-hwb-function': 4.0.12(postcss@8.5.6) + '@csstools/postcss-ic-unit': 4.0.4(postcss@8.5.6) + '@csstools/postcss-initial': 2.0.1(postcss@8.5.6) + '@csstools/postcss-is-pseudo-class': 5.0.3(postcss@8.5.6) + '@csstools/postcss-light-dark-function': 2.0.11(postcss@8.5.6) + '@csstools/postcss-logical-float-and-clear': 3.0.0(postcss@8.5.6) + '@csstools/postcss-logical-overflow': 2.0.0(postcss@8.5.6) + '@csstools/postcss-logical-overscroll-behavior': 2.0.0(postcss@8.5.6) + '@csstools/postcss-logical-resize': 3.0.0(postcss@8.5.6) + '@csstools/postcss-logical-viewport-units': 3.0.4(postcss@8.5.6) + '@csstools/postcss-media-minmax': 2.0.9(postcss@8.5.6) + '@csstools/postcss-media-queries-aspect-ratio-number-values': 3.0.5(postcss@8.5.6) + '@csstools/postcss-nested-calc': 4.0.0(postcss@8.5.6) + '@csstools/postcss-normalize-display-values': 4.0.0(postcss@8.5.6) + '@csstools/postcss-oklab-function': 4.0.12(postcss@8.5.6) + '@csstools/postcss-progressive-custom-properties': 4.2.1(postcss@8.5.6) + '@csstools/postcss-random-function': 2.0.1(postcss@8.5.6) + '@csstools/postcss-relative-color-syntax': 3.0.12(postcss@8.5.6) + '@csstools/postcss-scope-pseudo-class': 4.0.1(postcss@8.5.6) + '@csstools/postcss-sign-functions': 1.1.4(postcss@8.5.6) + '@csstools/postcss-stepped-value-functions': 4.0.9(postcss@8.5.6) + '@csstools/postcss-text-decoration-shorthand': 4.0.3(postcss@8.5.6) + '@csstools/postcss-trigonometric-functions': 4.0.9(postcss@8.5.6) + '@csstools/postcss-unset-value': 4.0.0(postcss@8.5.6) + autoprefixer: 10.4.21(postcss@8.5.6) + browserslist: 4.26.2 + css-blank-pseudo: 7.0.1(postcss@8.5.6) + css-has-pseudo: 7.0.3(postcss@8.5.6) + css-prefers-color-scheme: 10.0.0(postcss@8.5.6) + cssdb: 8.4.2 + postcss: 8.5.6 + postcss-attribute-case-insensitive: 7.0.1(postcss@8.5.6) + postcss-clamp: 4.1.0(postcss@8.5.6) + postcss-color-functional-notation: 7.0.12(postcss@8.5.6) + postcss-color-hex-alpha: 10.0.0(postcss@8.5.6) + postcss-color-rebeccapurple: 10.0.0(postcss@8.5.6) + postcss-custom-media: 11.0.6(postcss@8.5.6) + postcss-custom-properties: 14.0.6(postcss@8.5.6) + postcss-custom-selectors: 8.0.5(postcss@8.5.6) + postcss-dir-pseudo-class: 9.0.1(postcss@8.5.6) + postcss-double-position-gradients: 6.0.4(postcss@8.5.6) + postcss-focus-visible: 10.0.1(postcss@8.5.6) + postcss-focus-within: 9.0.1(postcss@8.5.6) + postcss-font-variant: 5.0.0(postcss@8.5.6) + postcss-gap-properties: 6.0.0(postcss@8.5.6) + postcss-image-set-function: 7.0.0(postcss@8.5.6) + postcss-lab-function: 7.0.12(postcss@8.5.6) + postcss-logical: 8.1.0(postcss@8.5.6) + postcss-nesting: 13.0.2(postcss@8.5.6) + postcss-opacity-percentage: 3.0.0(postcss@8.5.6) + postcss-overflow-shorthand: 6.0.0(postcss@8.5.6) + postcss-page-break: 3.0.4(postcss@8.5.6) + postcss-place: 10.0.0(postcss@8.5.6) + postcss-pseudo-class-any-link: 10.0.1(postcss@8.5.6) + postcss-replace-overflow-wrap: 4.0.0(postcss@8.5.6) + postcss-selector-not: 8.0.1(postcss@8.5.6) + + postcss-pseudo-class-any-link@10.0.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + postcss-reduce-idents@6.0.3(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-value-parser: 4.2.0 + + postcss-reduce-initial@6.1.0(postcss@8.5.6): dependencies: - browserslist: 4.23.1 + browserslist: 4.26.2 caniuse-api: 3.0.0 - postcss: 8.4.38 + postcss: 8.5.6 - postcss-reduce-transforms@6.0.2(postcss@8.4.38): + postcss-reduce-transforms@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 - postcss-selector-parser@6.1.0: + postcss-replace-overflow-wrap@4.0.0(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + + postcss-selector-not@8.0.1(postcss@8.5.6): + dependencies: + postcss: 8.5.6 + postcss-selector-parser: 7.1.0 + + postcss-selector-parser@6.1.2: + dependencies: + cssesc: 3.0.0 + util-deprecate: 1.0.2 + + postcss-selector-parser@7.1.0: dependencies: cssesc: 3.0.0 util-deprecate: 1.0.2 - postcss-sort-media-queries@5.2.0(postcss@8.4.38): + postcss-sort-media-queries@5.2.0(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 sort-css-media-queries: 2.2.0 - postcss-svgo@6.0.3(postcss@8.4.38): + postcss-svgo@6.0.3(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 postcss-value-parser: 4.2.0 svgo: 3.3.2 - postcss-unique-selectors@6.0.4(postcss@8.4.38): + postcss-unique-selectors@6.0.4(postcss@8.5.6): dependencies: - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 postcss-value-parser@4.2.0: {} - postcss-zindex@6.0.2(postcss@8.4.38): + postcss-zindex@6.0.2(postcss@8.5.6): dependencies: - postcss: 8.4.38 + postcss: 8.5.6 - postcss@8.4.38: + postcss@8.5.6: dependencies: - nanoid: 3.3.7 - picocolors: 1.0.1 - source-map-js: 1.2.0 + nanoid: 3.3.11 + picocolors: 1.1.1 + source-map-js: 1.2.1 pretty-error@4.0.0: dependencies: @@ -9846,13 +10859,13 @@ snapshots: pretty-time@1.1.0: {} - prism-react-renderer@2.3.1(react@18.3.1): + prism-react-renderer@2.4.1(react@18.3.1): dependencies: - '@types/prismjs': 1.26.4 + '@types/prismjs': 1.26.5 clsx: 2.1.1 react: 18.3.1 - prismjs@https://codeload.github.com/PrismJS/prism/tar.gz/59e5a3471377057de1f401ba38337aca27b80e03: {} + prismjs@1.30.0: {} process-nextick-args@2.0.1: {} @@ -9869,6 +10882,8 @@ snapshots: property-information@6.5.0: {} + property-information@7.1.0: {} + proto-list@1.2.4: {} proxy-addr@2.0.7: @@ -9876,24 +10891,18 @@ snapshots: forwarded: 0.2.0 ipaddr.js: 1.9.1 - punycode@1.4.1: {} - punycode@2.3.1: {} - pupa@3.1.0: + pupa@3.3.0: dependencies: escape-goat: 4.0.0 - qs@6.11.0: + qs@6.13.0: dependencies: - side-channel: 1.0.6 + side-channel: 1.1.0 queue-microtask@1.2.3: {} - queue@6.0.2: - dependencies: - inherits: 2.0.4 - quick-lru@5.1.1: {} randombytes@2.1.0: @@ -9918,88 +10927,35 @@ snapshots: minimist: 1.2.8 strip-json-comments: 2.0.1 - react-dev-utils@12.0.1(typescript@5.2.2)(webpack@5.92.1): - dependencies: - '@babel/code-frame': 7.24.7 - address: 1.2.2 - browserslist: 4.23.1 - chalk: 4.1.2 - cross-spawn: 7.0.3 - detect-port-alt: 1.1.6 - escape-string-regexp: 4.0.0 - filesize: 8.0.7 - find-up: 5.0.0 - fork-ts-checker-webpack-plugin: 6.5.3(typescript@5.2.2)(webpack@5.92.1) - global-modules: 2.0.0 - globby: 11.1.0 - gzip-size: 6.0.0 - immer: 9.0.21 - is-root: 2.1.0 - loader-utils: 3.3.1 - open: 8.4.2 - pkg-up: 3.1.0 - prompts: 2.4.2 - react-error-overlay: 6.0.11 - recursive-readdir: 2.2.3 - shell-quote: 1.8.1 - strip-ansi: 6.0.1 - text-table: 0.2.0 - webpack: 5.92.1 - optionalDependencies: - typescript: 5.2.2 - transitivePeerDependencies: - - eslint - - supports-color - - vue-template-compiler - react-dom@18.3.1(react@18.3.1): dependencies: loose-envify: 1.4.0 react: 18.3.1 scheduler: 0.23.2 - react-error-overlay@6.0.11: {} - react-fast-compare@3.2.2: {} - react-helmet-async@1.3.0(react-dom@18.3.1(react@18.3.1))(react@18.3.1): - dependencies: - '@babel/runtime': 7.24.7 - invariant: 2.2.4 - prop-types: 15.8.1 - react: 18.3.1 - react-dom: 18.3.1(react@18.3.1) - react-fast-compare: 3.2.2 - shallowequal: 1.1.0 - - react-helmet-async@2.0.5(react@18.3.1): - dependencies: - invariant: 2.2.4 - react: 18.3.1 - react-fast-compare: 3.2.2 - shallowequal: 1.1.0 - react-is@16.13.1: {} - react-json-view-lite@1.4.0(react@18.3.1): + react-json-view-lite@2.5.0(react@18.3.1): dependencies: react: 18.3.1 - react-loadable-ssr-addon-v5-slorber@1.0.1(@docusaurus/react-loadable@6.0.0(react@18.3.1))(webpack@5.92.1): + react-loadable-ssr-addon-v5-slorber@1.0.1(@docusaurus/react-loadable@6.0.0(react@18.3.1))(webpack@5.101.3): dependencies: - '@babel/runtime': 7.24.7 + '@babel/runtime': 7.28.4 react-loadable: '@docusaurus/react-loadable@6.0.0(react@18.3.1)' - webpack: 5.92.1 + webpack: 5.101.3 react-router-config@5.1.1(react-router@5.3.4(react@18.3.1))(react@18.3.1): dependencies: - '@babel/runtime': 7.24.7 + '@babel/runtime': 7.28.4 react: 18.3.1 react-router: 5.3.4(react@18.3.1) react-router-dom@5.3.4(react@18.3.1): dependencies: - '@babel/runtime': 7.24.7 + '@babel/runtime': 7.28.4 history: 4.10.1 loose-envify: 1.4.0 prop-types: 15.8.1 @@ -10010,11 +10966,11 @@ snapshots: react-router@5.3.4(react@18.3.1): dependencies: - '@babel/runtime': 7.24.7 + '@babel/runtime': 7.28.4 history: 4.10.1 hoist-non-react-statics: 3.3.2 loose-envify: 1.4.0 - path-to-regexp: 1.8.0 + path-to-regexp: 1.9.0 prop-types: 15.8.1 react: 18.3.1 react-is: 16.13.1 @@ -10049,62 +11005,85 @@ snapshots: dependencies: picomatch: 2.3.1 - reading-time@1.5.0: {} + recma-build-jsx@1.0.0: + dependencies: + '@types/estree': 1.0.8 + estree-util-build-jsx: 3.0.1 + vfile: 6.0.3 + + recma-jsx@1.0.1(acorn@8.15.0): + dependencies: + acorn: 8.15.0 + acorn-jsx: 5.3.2(acorn@8.15.0) + estree-util-to-js: 2.0.0 + recma-parse: 1.0.0 + recma-stringify: 1.0.0 + unified: 11.0.5 - rechoir@0.6.2: + recma-parse@1.0.0: dependencies: - resolve: 1.22.8 + '@types/estree': 1.0.8 + esast-util-from-js: 2.0.1 + unified: 11.0.5 + vfile: 6.0.3 - recursive-readdir@2.2.3: + recma-stringify@1.0.0: dependencies: - minimatch: 3.1.2 + '@types/estree': 1.0.8 + estree-util-to-js: 2.0.0 + unified: 11.0.5 + vfile: 6.0.3 - regenerate-unicode-properties@10.1.1: + regenerate-unicode-properties@10.2.2: dependencies: regenerate: 1.4.2 regenerate@1.4.2: {} - regenerator-runtime@0.14.1: {} - - regenerator-transform@0.15.2: - dependencies: - '@babel/runtime': 7.24.7 - - regexpu-core@5.3.2: + regexpu-core@6.4.0: dependencies: - '@babel/regjsgen': 0.8.0 regenerate: 1.4.2 - regenerate-unicode-properties: 10.1.1 - regjsparser: 0.9.1 + regenerate-unicode-properties: 10.2.2 + regjsgen: 0.8.0 + regjsparser: 0.13.0 unicode-match-property-ecmascript: 2.0.0 - unicode-match-property-value-ecmascript: 2.1.0 + unicode-match-property-value-ecmascript: 2.2.1 - registry-auth-token@5.0.2: + registry-auth-token@5.1.0: dependencies: - '@pnpm/npm-conf': 2.2.2 + '@pnpm/npm-conf': 2.3.1 registry-url@6.0.1: dependencies: rc: 1.2.8 - regjsparser@0.9.1: + regjsgen@0.8.0: {} + + regjsparser@0.13.0: dependencies: - jsesc: 0.5.0 + jsesc: 3.1.0 rehype-raw@7.0.0: dependencies: '@types/hast': 3.0.4 - hast-util-raw: 9.0.4 - vfile: 6.0.1 + hast-util-raw: 9.1.0 + vfile: 6.0.3 + + rehype-recma@1.0.0: + dependencies: + '@types/estree': 1.0.8 + '@types/hast': 3.0.4 + hast-util-to-estree: 3.1.3 + transitivePeerDependencies: + - supports-color relateurl@0.2.7: {} - remark-directive@3.0.0: + remark-directive@3.0.1: dependencies: '@types/mdast': 4.0.4 - mdast-util-directive: 3.0.0 - micromark-extension-directive: 3.0.0 + mdast-util-directive: 3.1.0 + micromark-extension-directive: 3.0.2 unified: 11.0.5 transitivePeerDependencies: - supports-color @@ -10112,9 +11091,9 @@ snapshots: remark-emoji@4.0.1: dependencies: '@types/mdast': 4.0.4 - emoticon: 4.0.1 - mdast-util-find-and-replace: 3.0.1 - node-emoji: 2.1.3 + emoticon: 4.1.0 + mdast-util-find-and-replace: 3.0.2 + node-emoji: 2.2.0 unified: 11.0.5 remark-frontmatter@5.0.0: @@ -10126,10 +11105,10 @@ snapshots: transitivePeerDependencies: - supports-color - remark-gfm@4.0.0: + remark-gfm@4.0.1: dependencies: '@types/mdast': 4.0.4 - mdast-util-gfm: 3.0.0 + mdast-util-gfm: 3.1.0 micromark-extension-gfm: 3.0.0 remark-parse: 11.0.0 remark-stringify: 11.0.0 @@ -10137,7 +11116,7 @@ snapshots: transitivePeerDependencies: - supports-color - remark-mdx@3.0.1: + remark-mdx@3.1.1: dependencies: mdast-util-mdx: 3.0.0 micromark-extension-mdxjs: 3.0.0 @@ -10147,24 +11126,24 @@ snapshots: remark-parse@11.0.0: dependencies: '@types/mdast': 4.0.4 - mdast-util-from-markdown: 2.0.1 - micromark-util-types: 2.0.0 + mdast-util-from-markdown: 2.0.2 + micromark-util-types: 2.0.2 unified: 11.0.5 transitivePeerDependencies: - supports-color - remark-rehype@11.1.0: + remark-rehype@11.1.2: dependencies: '@types/hast': 3.0.4 '@types/mdast': 4.0.4 mdast-util-to-hast: 13.2.0 unified: 11.0.5 - vfile: 6.0.1 + vfile: 6.0.3 remark-stringify@11.0.0: dependencies: '@types/mdast': 4.0.4 - mdast-util-to-markdown: 2.1.0 + mdast-util-to-markdown: 2.1.2 unified: 11.0.5 renderkid@3.0.0: @@ -10175,6 +11154,8 @@ snapshots: lodash: 4.17.21 strip-ansi: 6.0.1 + repeat-string@1.6.1: {} + require-from-string@2.0.2: {} require-like@0.1.2: {} @@ -10187,9 +11168,9 @@ snapshots: resolve-pathname@3.0.0: {} - resolve@1.22.8: + resolve@1.22.10: dependencies: - is-core-module: 2.14.0 + is-core-module: 2.16.1 path-parse: 1.0.7 supports-preserve-symlinks-flag: 1.0.0 @@ -10199,21 +11180,17 @@ snapshots: retry@0.13.1: {} - reusify@1.0.4: {} + reusify@1.1.0: {} - rimraf@3.0.2: + rtlcss@4.3.0: dependencies: - glob: 7.2.3 - - rtl-detect@1.1.2: {} - - rtlcss@4.1.1: - dependencies: - escalade: 3.1.2 - picocolors: 1.0.1 - postcss: 8.4.38 + escalade: 3.2.0 + picocolors: 1.1.1 + postcss: 8.5.6 strip-json-comments: 3.1.1 + run-applescript@7.1.0: {} + run-parallel@1.2.0: dependencies: queue-microtask: 1.2.3 @@ -10230,11 +11207,7 @@ snapshots: dependencies: loose-envify: 1.4.0 - schema-utils@2.7.0: - dependencies: - '@types/json-schema': 7.0.15 - ajv: 6.12.6 - ajv-keywords: 3.5.2(ajv@6.12.6) + schema-dts@1.1.5: {} schema-utils@3.3.0: dependencies: @@ -10242,14 +11215,14 @@ snapshots: ajv: 6.12.6 ajv-keywords: 3.5.2(ajv@6.12.6) - schema-utils@4.2.0: + schema-utils@4.3.2: dependencies: '@types/json-schema': 7.0.15 - ajv: 8.16.0 - ajv-formats: 2.1.1(ajv@8.16.0) - ajv-keywords: 5.1.0(ajv@8.16.0) + ajv: 8.17.1 + ajv-formats: 2.1.1(ajv@8.17.1) + ajv-keywords: 5.1.0(ajv@8.17.1) - search-insights@2.14.0: {} + search-insights@2.17.3: {} section-matter@1.0.0: dependencies: @@ -10260,18 +11233,18 @@ snapshots: selfsigned@2.4.1: dependencies: - '@types/node-forge': 1.3.11 + '@types/node-forge': 1.3.14 node-forge: 1.3.1 semver-diff@4.0.0: dependencies: - semver: 7.6.2 + semver: 7.7.2 semver@6.3.1: {} - semver@7.6.2: {} + semver@7.7.2: {} - send@0.18.0: + send@0.19.0: dependencies: debug: 2.6.9 depd: 2.0.0 @@ -10293,15 +11266,14 @@ snapshots: dependencies: randombytes: 2.1.0 - serve-handler@6.1.5: + serve-handler@6.1.6: dependencies: bytes: 3.0.0 content-disposition: 0.5.2 - fast-url-parser: 1.1.3 mime-types: 2.1.18 minimatch: 3.1.2 path-is-inside: 1.0.2 - path-to-regexp: 2.2.1 + path-to-regexp: 3.3.0 range-parser: 1.2.0 serve-index@1.9.1: @@ -10316,12 +11288,12 @@ snapshots: transitivePeerDependencies: - supports-color - serve-static@1.15.0: + serve-static@1.16.2: dependencies: - encodeurl: 1.0.2 + encodeurl: 2.0.0 escape-html: 1.0.3 parseurl: 1.3.3 - send: 0.18.0 + send: 0.19.0 transitivePeerDependencies: - supports-color @@ -10330,8 +11302,8 @@ snapshots: define-data-property: 1.1.4 es-errors: 1.3.0 function-bind: 1.1.2 - get-intrinsic: 1.2.4 - gopd: 1.0.1 + get-intrinsic: 1.3.0 + gopd: 1.2.0 has-property-descriptors: 1.0.2 setprototypeof@1.1.0: {} @@ -10350,20 +11322,35 @@ snapshots: shebang-regex@3.0.0: {} - shell-quote@1.8.1: {} + shell-quote@1.8.3: {} + + side-channel-list@1.0.0: + dependencies: + es-errors: 1.3.0 + object-inspect: 1.13.4 + + side-channel-map@1.0.1: + dependencies: + call-bound: 1.0.4 + es-errors: 1.3.0 + get-intrinsic: 1.3.0 + object-inspect: 1.13.4 - shelljs@0.8.5: + side-channel-weakmap@1.0.2: dependencies: - glob: 7.2.3 - interpret: 1.4.0 - rechoir: 0.6.2 + call-bound: 1.0.4 + es-errors: 1.3.0 + get-intrinsic: 1.3.0 + object-inspect: 1.13.4 + side-channel-map: 1.0.1 - side-channel@1.0.6: + side-channel@1.1.0: dependencies: - call-bind: 1.0.7 es-errors: 1.3.0 - get-intrinsic: 1.2.4 - object-inspect: 1.13.2 + object-inspect: 1.13.4 + side-channel-list: 1.0.0 + side-channel-map: 1.0.1 + side-channel-weakmap: 1.0.2 signal-exit@3.0.7: {} @@ -10371,8 +11358,8 @@ snapshots: sirv@2.0.4: dependencies: - '@polka/url': 1.0.0-next.25 - mrmime: 2.0.0 + '@polka/url': 1.0.0-next.29 + mrmime: 2.0.1 totalist: 3.0.1 sisteransi@1.0.5: {} @@ -10395,7 +11382,7 @@ snapshots: snake-case@3.0.4: dependencies: dot-case: 3.0.4 - tslib: 2.6.3 + tslib: 2.8.1 sockjs@0.3.24: dependencies: @@ -10405,7 +11392,7 @@ snapshots: sort-css-media-queries@2.2.0: {} - source-map-js@1.2.0: {} + source-map-js@1.2.1: {} source-map-support@0.5.21: dependencies: @@ -10414,13 +11401,13 @@ snapshots: source-map@0.6.1: {} - source-map@0.7.4: {} + source-map@0.7.6: {} space-separated-tokens@2.0.2: {} spdy-transport@3.0.0: dependencies: - debug: 4.3.5 + debug: 4.4.3 detect-node: 2.1.0 hpack.js: 2.1.6 obuf: 1.1.2 @@ -10431,7 +11418,7 @@ snapshots: spdy@4.0.2: dependencies: - debug: 4.3.5 + debug: 4.4.3 handle-thing: 2.0.1 http-deceiver: 1.2.7 select-hose: 2.0.0 @@ -10447,7 +11434,7 @@ snapshots: statuses@2.0.1: {} - std-env@3.7.0: {} + std-env@3.9.0: {} string-width@4.2.3: dependencies: @@ -10459,7 +11446,7 @@ snapshots: dependencies: eastasianwidth: 0.2.0 emoji-regex: 9.2.2 - strip-ansi: 7.1.0 + strip-ansi: 7.1.2 string_decoder@1.1.1: dependencies: @@ -10484,9 +11471,9 @@ snapshots: dependencies: ansi-regex: 5.0.1 - strip-ansi@7.1.0: + strip-ansi@7.1.2: dependencies: - ansi-regex: 6.0.1 + ansi-regex: 6.2.2 strip-bom-string@1.0.0: {} @@ -10496,34 +11483,30 @@ snapshots: strip-json-comments@3.1.1: {} - style-to-object@0.4.4: + style-to-js@1.1.17: dependencies: - inline-style-parser: 0.1.1 + style-to-object: 1.0.9 - style-to-object@1.0.6: + style-to-object@1.0.9: dependencies: - inline-style-parser: 0.2.3 + inline-style-parser: 0.2.4 - stylehacks@6.1.1(postcss@8.4.38): + stylehacks@6.1.1(postcss@8.5.6): dependencies: - browserslist: 4.23.1 - postcss: 8.4.38 - postcss-selector-parser: 6.1.0 + browserslist: 4.26.2 + postcss: 8.5.6 + postcss-selector-parser: 6.1.2 sucrase@3.35.0: dependencies: - '@jridgewell/gen-mapping': 0.3.5 + '@jridgewell/gen-mapping': 0.3.13 commander: 4.1.1 - glob: 10.4.2 + glob: 10.4.5 lines-and-columns: 1.2.4 mz: 2.7.0 - pirates: 4.0.6 + pirates: 4.0.7 ts-interface-checker: 0.1.13 - supports-color@5.5.0: - dependencies: - has-flag: 3.0.0 - supports-color@7.2.0: dependencies: has-flag: 4.0.0 @@ -10540,61 +11523,63 @@ snapshots: dependencies: '@trysound/sax': 0.2.0 commander: 7.2.0 - css-select: 5.1.0 + css-select: 5.2.2 css-tree: 2.3.1 - css-what: 6.1.0 + css-what: 6.2.2 csso: 5.0.5 - picocolors: 1.0.1 + picocolors: 1.1.1 + + swr@2.3.6(react@18.3.1): + dependencies: + dequal: 2.0.3 + react: 18.3.1 + use-sync-external-store: 1.5.0(react@18.3.1) - tailwindcss@3.4.4: + tailwindcss@3.4.17: dependencies: '@alloc/quick-lru': 5.2.0 arg: 5.0.2 chokidar: 3.6.0 didyoumean: 1.2.2 dlv: 1.1.3 - fast-glob: 3.3.2 + fast-glob: 3.3.3 glob-parent: 6.0.2 is-glob: 4.0.3 - jiti: 1.21.6 - lilconfig: 2.1.0 - micromatch: 4.0.7 + jiti: 1.21.7 + lilconfig: 3.1.3 + micromatch: 4.0.8 normalize-path: 3.0.0 object-hash: 3.0.0 - picocolors: 1.0.1 - postcss: 8.4.38 - postcss-import: 15.1.0(postcss@8.4.38) - postcss-js: 4.0.1(postcss@8.4.38) - postcss-load-config: 4.0.2(postcss@8.4.38) - postcss-nested: 6.0.1(postcss@8.4.38) - postcss-selector-parser: 6.1.0 - resolve: 1.22.8 + picocolors: 1.1.1 + postcss: 8.5.6 + postcss-import: 15.1.0(postcss@8.5.6) + postcss-js: 4.1.0(postcss@8.5.6) + postcss-load-config: 4.0.2(postcss@8.5.6) + postcss-nested: 6.2.0(postcss@8.5.6) + postcss-selector-parser: 6.1.2 + resolve: 1.22.10 sucrase: 3.35.0 transitivePeerDependencies: - ts-node - tapable@1.1.3: {} + tapable@2.2.3: {} - tapable@2.2.1: {} - - terser-webpack-plugin@5.3.10(webpack@5.92.1): + terser-webpack-plugin@5.3.14(webpack@5.101.3): dependencies: - '@jridgewell/trace-mapping': 0.3.25 + '@jridgewell/trace-mapping': 0.3.31 jest-worker: 27.5.1 - schema-utils: 3.3.0 + schema-utils: 4.3.2 serialize-javascript: 6.0.2 - terser: 5.31.1 - webpack: 5.92.1 + terser: 5.44.0 + webpack: 5.101.3 - terser@5.31.1: + terser@5.44.0: dependencies: - '@jridgewell/source-map': 0.3.6 - acorn: 8.12.0 + '@jridgewell/source-map': 0.3.11 + acorn: 8.15.0 commander: 2.20.3 source-map-support: 0.5.21 - text-table@0.2.0: {} - thenify-all@1.6.0: dependencies: thenify: 3.3.1 @@ -10603,13 +11588,19 @@ snapshots: dependencies: any-promise: 1.3.0 + thingies@2.5.0(tslib@2.8.1): + dependencies: + tslib: 2.8.1 + + throttleit@2.1.0: {} + thunky@1.1.0: {} tiny-invariant@1.3.3: {} tiny-warning@1.0.3: {} - to-fast-properties@2.0.0: {} + tinypool@1.1.1: {} to-regex-range@5.0.1: dependencies: @@ -10619,13 +11610,19 @@ snapshots: totalist@3.0.1: {} + tree-dump@1.1.0(tslib@2.8.1): + dependencies: + tslib: 2.8.1 + trim-lines@3.0.1: {} trough@2.2.0: {} ts-interface-checker@0.1.13: {} - tslib@2.6.3: {} + tslib@2.8.1: {} + + type-fest@0.21.3: {} type-fest@1.4.0: {} @@ -10642,30 +11639,32 @@ snapshots: typescript@5.2.2: {} - undici-types@5.26.5: {} + undici-types@7.12.0: {} + + undici@7.16.0: {} - unicode-canonical-property-names-ecmascript@2.0.0: {} + unicode-canonical-property-names-ecmascript@2.0.1: {} unicode-emoji-modifier-base@1.0.0: {} unicode-match-property-ecmascript@2.0.0: dependencies: - unicode-canonical-property-names-ecmascript: 2.0.0 - unicode-property-aliases-ecmascript: 2.1.0 + unicode-canonical-property-names-ecmascript: 2.0.1 + unicode-property-aliases-ecmascript: 2.2.0 - unicode-match-property-value-ecmascript@2.1.0: {} + unicode-match-property-value-ecmascript@2.2.1: {} - unicode-property-aliases-ecmascript@2.1.0: {} + unicode-property-aliases-ecmascript@2.2.0: {} unified@11.0.5: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 bail: 2.0.2 devlop: 1.1.0 extend: 3.0.2 is-plain-obj: 4.1.0 trough: 2.2.0 - vfile: 6.0.1 + vfile: 6.0.3 unique-string@3.0.0: dependencies: @@ -10673,33 +11672,28 @@ snapshots: unist-util-is@6.0.0: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 unist-util-position-from-estree@2.0.0: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 unist-util-position@5.0.0: dependencies: - '@types/unist': 3.0.2 - - unist-util-remove-position@5.0.0: - dependencies: - '@types/unist': 3.0.2 - unist-util-visit: 5.0.0 + '@types/unist': 3.0.3 unist-util-stringify-position@4.0.0: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 unist-util-visit-parents@6.0.1: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 unist-util-is: 6.0.0 unist-util-visit@5.0.0: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 unist-util-is: 6.0.0 unist-util-visit-parents: 6.0.1 @@ -10707,26 +11701,26 @@ snapshots: unpipe@1.0.0: {} - update-browserslist-db@1.0.16(browserslist@4.23.1): + update-browserslist-db@1.1.3(browserslist@4.26.2): dependencies: - browserslist: 4.23.1 - escalade: 3.1.2 - picocolors: 1.0.1 + browserslist: 4.26.2 + escalade: 3.2.0 + picocolors: 1.1.1 update-notifier@6.0.2: dependencies: boxen: 7.1.1 - chalk: 5.3.0 + chalk: 5.6.2 configstore: 6.0.0 has-yarn: 3.0.0 import-lazy: 4.0.0 is-ci: 3.0.1 is-installed-globally: 0.4.0 - is-npm: 6.0.0 + is-npm: 6.1.0 is-yarn-global: 0.4.1 latest-version: 7.0.0 - pupa: 3.1.0 - semver: 7.6.2 + pupa: 3.3.0 + semver: 7.7.2 semver-diff: 4.0.0 xdg-basedir: 5.1.0 @@ -10734,14 +11728,18 @@ snapshots: dependencies: punycode: 2.3.1 - url-loader@4.1.1(file-loader@6.2.0(webpack@5.92.1))(webpack@5.92.1): + url-loader@4.1.1(file-loader@6.2.0(webpack@5.101.3))(webpack@5.101.3): dependencies: loader-utils: 2.0.4 mime-types: 2.1.35 schema-utils: 3.3.0 - webpack: 5.92.1 + webpack: 5.101.3 optionalDependencies: - file-loader: 6.2.0(webpack@5.92.1) + file-loader: 6.2.0(webpack@5.101.3) + + use-sync-external-store@1.5.0(react@18.3.1): + dependencies: + react: 18.3.1 util-deprecate@1.0.2: {} @@ -10757,23 +11755,22 @@ snapshots: vary@1.1.2: {} - vfile-location@5.0.2: + vfile-location@5.0.3: dependencies: - '@types/unist': 3.0.2 - vfile: 6.0.1 + '@types/unist': 3.0.3 + vfile: 6.0.3 - vfile-message@4.0.2: + vfile-message@4.0.3: dependencies: - '@types/unist': 3.0.2 + '@types/unist': 3.0.3 unist-util-stringify-position: 4.0.0 - vfile@6.0.1: + vfile@6.0.3: dependencies: - '@types/unist': 3.0.2 - unist-util-stringify-position: 4.0.0 - vfile-message: 4.0.2 + '@types/unist': 3.0.3 + vfile-message: 4.0.3 - watchpack@2.4.1: + watchpack@2.4.4: dependencies: glob-to-regexp: 0.4.1 graceful-fs: 4.2.11 @@ -10787,64 +11784,64 @@ snapshots: webpack-bundle-analyzer@4.10.2: dependencies: '@discoveryjs/json-ext': 0.5.7 - acorn: 8.12.0 - acorn-walk: 8.3.3 + acorn: 8.15.0 + acorn-walk: 8.3.4 commander: 7.2.0 debounce: 1.2.1 escape-string-regexp: 4.0.0 gzip-size: 6.0.0 html-escaper: 2.0.2 opener: 1.5.2 - picocolors: 1.0.1 + picocolors: 1.1.1 sirv: 2.0.4 ws: 7.5.10 transitivePeerDependencies: - bufferutil - utf-8-validate - webpack-dev-middleware@5.3.4(webpack@5.92.1): + webpack-dev-middleware@7.4.5(webpack@5.101.3): dependencies: colorette: 2.0.20 - memfs: 3.5.3 - mime-types: 2.1.35 + memfs: 4.47.0 + mime-types: 3.0.1 + on-finished: 2.4.1 range-parser: 1.2.1 - schema-utils: 4.2.0 - webpack: 5.92.1 + schema-utils: 4.3.2 + optionalDependencies: + webpack: 5.101.3 - webpack-dev-server@4.15.2(debug@4.3.5)(webpack@5.92.1): + webpack-dev-server@5.2.2(debug@4.4.3)(webpack@5.101.3): dependencies: '@types/bonjour': 3.5.13 '@types/connect-history-api-fallback': 1.5.4 - '@types/express': 4.17.21 + '@types/express': 4.17.23 + '@types/express-serve-static-core': 4.19.6 '@types/serve-index': 1.9.4 - '@types/serve-static': 1.15.7 + '@types/serve-static': 1.15.8 '@types/sockjs': 0.3.36 - '@types/ws': 8.5.10 + '@types/ws': 8.18.1 ansi-html-community: 0.0.8 - bonjour-service: 1.2.1 + bonjour-service: 1.3.0 chokidar: 3.6.0 colorette: 2.0.20 - compression: 1.7.4 + compression: 1.8.1 connect-history-api-fallback: 2.0.0 - default-gateway: 6.0.3 - express: 4.19.2 + express: 4.21.2 graceful-fs: 4.2.11 - html-entities: 2.5.2 - http-proxy-middleware: 2.0.6(@types/express@4.17.21)(debug@4.3.5) + http-proxy-middleware: 2.0.9(@types/express@4.17.23)(debug@4.4.3) ipaddr.js: 2.2.0 - launch-editor: 2.8.0 - open: 8.4.2 - p-retry: 4.6.2 - rimraf: 3.0.2 - schema-utils: 4.2.0 + launch-editor: 2.11.1 + open: 10.2.0 + p-retry: 6.2.1 + schema-utils: 4.3.2 selfsigned: 2.4.1 serve-index: 1.9.1 sockjs: 0.3.24 spdy: 4.0.2 - webpack-dev-middleware: 5.3.4(webpack@5.92.1) - ws: 8.17.1 + webpack-dev-middleware: 7.4.5(webpack@5.101.3) + ws: 8.18.3 optionalDependencies: - webpack: 5.92.1 + webpack: 5.101.3 transitivePeerDependencies: - bufferutil - debug @@ -10857,21 +11854,28 @@ snapshots: flat: 5.0.2 wildcard: 2.0.1 - webpack-sources@3.2.3: {} + webpack-merge@6.0.1: + dependencies: + clone-deep: 4.0.1 + flat: 5.0.2 + wildcard: 2.0.1 + + webpack-sources@3.3.3: {} - webpack@5.92.1: + webpack@5.101.3: dependencies: '@types/eslint-scope': 3.7.7 - '@types/estree': 1.0.5 - '@webassemblyjs/ast': 1.12.1 - '@webassemblyjs/wasm-edit': 1.12.1 - '@webassemblyjs/wasm-parser': 1.12.1 - acorn: 8.12.0 - acorn-import-attributes: 1.9.5(acorn@8.12.0) - browserslist: 4.23.1 + '@types/estree': 1.0.8 + '@types/json-schema': 7.0.15 + '@webassemblyjs/ast': 1.14.1 + '@webassemblyjs/wasm-edit': 1.14.1 + '@webassemblyjs/wasm-parser': 1.14.1 + acorn: 8.15.0 + acorn-import-phases: 1.0.4(acorn@8.15.0) + browserslist: 4.26.2 chrome-trace-event: 1.0.4 - enhanced-resolve: 5.17.0 - es-module-lexer: 1.5.3 + enhanced-resolve: 5.18.3 + es-module-lexer: 1.7.0 eslint-scope: 5.1.1 events: 3.3.0 glob-to-regexp: 0.4.1 @@ -10880,35 +11884,41 @@ snapshots: loader-runner: 4.3.0 mime-types: 2.1.35 neo-async: 2.6.2 - schema-utils: 3.3.0 - tapable: 2.2.1 - terser-webpack-plugin: 5.3.10(webpack@5.92.1) - watchpack: 2.4.1 - webpack-sources: 3.2.3 + schema-utils: 4.3.2 + tapable: 2.2.3 + terser-webpack-plugin: 5.3.14(webpack@5.101.3) + watchpack: 2.4.4 + webpack-sources: 3.3.3 transitivePeerDependencies: - '@swc/core' - esbuild - uglify-js - webpackbar@5.0.2(webpack@5.92.1): + webpackbar@6.0.1(webpack@5.101.3): dependencies: + ansi-escapes: 4.3.2 chalk: 4.1.2 - consola: 2.15.3 + consola: 3.4.2 + figures: 3.2.0 + markdown-table: 2.0.0 pretty-time: 1.1.0 - std-env: 3.7.0 - webpack: 5.92.1 + std-env: 3.9.0 + webpack: 5.101.3 + wrap-ansi: 7.0.0 websocket-driver@0.7.4: dependencies: - http-parser-js: 0.5.8 + http-parser-js: 0.5.10 safe-buffer: 5.2.1 websocket-extensions: 0.1.4 websocket-extensions@0.1.4: {} - which@1.3.1: + whatwg-encoding@3.1.1: dependencies: - isexe: 2.0.0 + iconv-lite: 0.6.3 + + whatwg-mimetype@4.0.0: {} which@2.0.2: dependencies: @@ -10928,11 +11938,9 @@ snapshots: wrap-ansi@8.1.0: dependencies: - ansi-styles: 6.2.1 + ansi-styles: 6.2.3 string-width: 5.1.2 - strip-ansi: 7.1.0 - - wrappy@1.0.2: {} + strip-ansi: 7.1.2 write-file-atomic@3.0.3: dependencies: @@ -10943,7 +11951,11 @@ snapshots: ws@7.5.10: {} - ws@8.17.1: {} + ws@8.18.3: {} + + wsl-utils@0.1.0: + dependencies: + is-wsl: 3.1.0 xdg-basedir@5.1.0: {} @@ -10953,12 +11965,10 @@ snapshots: yallist@3.1.1: {} - yaml@1.10.2: {} - - yaml@2.4.5: {} + yaml@2.8.1: {} - yocto-queue@0.1.0: {} + yocto-queue@1.2.1: {} - yocto-queue@1.0.0: {} + zod@4.1.11: {} zwitch@2.0.4: {} From 764f7b4270861c2efe660284a80dca850012a58d Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Mon, 29 Sep 2025 05:51:23 +0500 Subject: [PATCH 34/96] docs(gen-docs): add in packagemanager (#1937) This adds in packagemanager as recently workflows were revamped to get the pnpm version from the package.json --- gen-docs/package.json | 1 + 1 file changed, 1 insertion(+) diff --git a/gen-docs/package.json b/gen-docs/package.json index d4506996fb..c83f7de8d5 100644 --- a/gen-docs/package.json +++ b/gen-docs/package.json @@ -2,6 +2,7 @@ "name": "gen-docs", "version": "0.0.0", "private": true, + "packageManager": "pnpm@10.17.1", "scripts": { "docusaurus": "docusaurus", "start": "docusaurus start", From 53dc80269687e32a64e7b18d78f945b63277e8d9 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 29 Sep 2025 06:30:02 +0100 Subject: [PATCH 35/96] ci: replace pnpm cache with custom cache (#1938) * removed the node pnpm cache in favour of the cache we setup * updated release to remove the cache:pnpm from the node setup step --- .github/workflows/docs-deploy.yml | 1 - .github/workflows/release.yml | 1 - 2 files changed, 2 deletions(-) diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index aa0ec3f50b..c9fb07f14d 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -29,7 +29,6 @@ jobs: uses: actions/setup-node@v4 with: node-version-file: package.json - cache: 'pnpm' - name: Pnpm Setup uses: pnpm/action-setup@v4 diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 23687cd746..e869f2a0d5 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -30,7 +30,6 @@ jobs: uses: actions/setup-node@v4 with: node-version-file: package.json - cache: 'pnpm' - name: Pnpm Setup uses: pnpm/action-setup@v4 From 872fc4581e938d7859e857f27037d7f0bdb59eda Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+Fallenbagel@users.noreply.github.com> Date: Mon, 29 Sep 2025 13:33:11 +0800 Subject: [PATCH 36/96] docs: rename kubernetes to state its an advanced step --- docs/getting-started/kubernetes.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/getting-started/kubernetes.mdx b/docs/getting-started/kubernetes.mdx index c3e36ef134..5fd0d6d519 100644 --- a/docs/getting-started/kubernetes.mdx +++ b/docs/getting-started/kubernetes.mdx @@ -1,5 +1,5 @@ --- -title: Kubernetes +title: Kubernetes (Advanced) description: Install Jellyseerr in Kubernetes sidebar_position: 5 --- From f2bd0abcd89f8c29b66ca332f25017e90234b315 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Wed, 1 Oct 2025 11:42:10 +0200 Subject: [PATCH 37/96] fix(api): add a migration script to rename *arr tags with spaces (#1946) * fix(api): add a migration script to rename *arr tags with spaces This PR adds a migration script that will run at the startup of the app to remove the spaces from the *arr tags of Jellyseerr. fix #1897 re #1913 re https://github.com/Radarr/Radarr/issues/11251 * fix: add error message to logs --- server/api/servarr/base.ts | 19 ++++ server/lib/settings/index.ts | 10 ++ .../migrations/0007_migrate_arr_tags.ts | 93 +++++++++++++++++++ 3 files changed, 122 insertions(+) create mode 100644 server/lib/settings/migrations/0007_migrate_arr_tags.ts diff --git a/server/api/servarr/base.ts b/server/api/servarr/base.ts index c49b936106..5343898f5a 100644 --- a/server/api/servarr/base.ts +++ b/server/api/servarr/base.ts @@ -198,6 +198,25 @@ class ServarrBase extends ExternalAPI { } }; + public renameTag = async ({ + id, + label, + }: { + id: number; + label: string; + }): Promise => { + try { + const response = await this.axios.put(`/tag/${id}`, { + id, + label, + }); + + return response.data; + } catch (e) { + throw new Error(`[${this.apiName}] Failed to rename tag: ${e.message}`); + } + }; + async refreshMonitoredDownloads(): Promise { await this.runCommand('RefreshMonitoredDownloads', {}); } diff --git a/server/lib/settings/index.ts b/server/lib/settings/index.ts index ce3e4b2409..73bc951b70 100644 --- a/server/lib/settings/index.ts +++ b/server/lib/settings/index.ts @@ -363,6 +363,7 @@ export interface AllSettings { jobs: Record; network: NetworkSettings; metadataSettings: MetadataSettings; + migrations: string[]; } const SETTINGS_PATH = process.env.CONFIG_DIRECTORY @@ -593,6 +594,7 @@ class Settings { forceMaxTtl: -1, }, }, + migrations: [], }; if (initialSettings) { this.data = merge(this.data, initialSettings); @@ -722,6 +724,14 @@ class Settings { this.data.network = data; } + get migrations(): string[] { + return this.data.migrations; + } + + set migrations(data: string[]) { + this.data.migrations = data; + } + get clientId(): string { return this.data.clientId; } diff --git a/server/lib/settings/migrations/0007_migrate_arr_tags.ts b/server/lib/settings/migrations/0007_migrate_arr_tags.ts new file mode 100644 index 0000000000..25911f93b5 --- /dev/null +++ b/server/lib/settings/migrations/0007_migrate_arr_tags.ts @@ -0,0 +1,93 @@ +import RadarrAPI from '@server/api/servarr/radarr'; +import SonarrAPI from '@server/api/servarr/sonarr'; +import { getRepository } from '@server/datasource'; +import { User } from '@server/entity/User'; +import type { AllSettings } from '@server/lib/settings'; + +const migrationArrTags = async (settings: any): Promise => { + if ( + Array.isArray(settings.migrations) && + settings.migrations.includes('0007_migrate_arr_tags') + ) { + return settings; + } + + const userRepository = getRepository(User); + const users = await userRepository.find({ + select: ['id'], + }); + + let errorOccurred = false; + + for (const radarrSettings of settings.radarr || []) { + if (!radarrSettings.tagRequests) { + continue; + } + try { + const radarr = new RadarrAPI({ + apiKey: radarrSettings.apiKey, + url: RadarrAPI.buildUrl(radarrSettings, '/api/v3'), + }); + const radarrTags = await radarr.getTags(); + for (const user of users) { + const userTag = radarrTags.find((v) => + v.label.startsWith(user.id + ' - ') + ); + if (!userTag) { + continue; + } + await radarr.renameTag({ + id: userTag.id, + label: userTag.label.replace(`${user.id} - `, `${user.id}-`), + }); + } + } catch (error) { + console.error( + `Unable to rename Radarr tags to the new format. Please check your Radarr connection settings for the instance "${radarrSettings.name}".`, + error.message + ); + errorOccurred = true; + } + } + + for (const sonarrSettings of settings.sonarr || []) { + if (!sonarrSettings.tagRequests) { + continue; + } + try { + const sonarr = new SonarrAPI({ + apiKey: sonarrSettings.apiKey, + url: SonarrAPI.buildUrl(sonarrSettings, '/api/v3'), + }); + const sonarrTags = await sonarr.getTags(); + for (const user of users) { + const userTag = sonarrTags.find((v) => + v.label.startsWith(user.id + ' - ') + ); + if (!userTag) { + continue; + } + await sonarr.renameTag({ + id: userTag.id, + label: userTag.label.replace(`${user.id} - `, `${user.id}-`), + }); + } + } catch (error) { + console.error( + `Unable to rename Sonarr tags to the new format. Please check your Sonarr connection settings for the instance "${sonarrSettings.name}".`, + error.message + ); + errorOccurred = true; + } + } + + if (!errorOccurred) { + if (!Array.isArray(settings.migrations)) { + settings.migrations = []; + } + settings.migrations.push('0007_migrate_arr_tags'); + } + return settings; +}; + +export default migrationArrTags; From afeb34f368daf7c6850b4614ad3b07b64f89fbc8 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Sat, 4 Oct 2025 18:33:40 +0300 Subject: [PATCH 38/96] ci: add stale bot (#1960) * ci: add yaml-langage-server to workflow files Signed-off-by: Ludovic Ortega * ci: add stale workflow Signed-off-by: Ludovic Ortega --------- Signed-off-by: Ludovic Ortega --- .github/stale.yml | 44 -------------------------- .github/workflows/ci.yml | 2 ++ .github/workflows/codeql.yml | 2 ++ .github/workflows/conflict_labeler.yml | 2 ++ .github/workflows/cypress.yml | 2 ++ .github/workflows/docs-deploy.yml | 2 ++ .github/workflows/helm.yml | 2 ++ .github/workflows/lint-helm-charts.yml | 2 ++ .github/workflows/preview.yml | 2 ++ .github/workflows/release.yml | 2 ++ .github/workflows/stale.yml | 35 ++++++++++++++++++++ .github/workflows/support.yml | 2 ++ .github/workflows/test-docs-deploy.yml | 2 ++ 13 files changed, 57 insertions(+), 44 deletions(-) delete mode 100644 .github/stale.yml create mode 100644 .github/workflows/stale.yml diff --git a/.github/stale.yml b/.github/stale.yml deleted file mode 100644 index a0c96e871f..0000000000 --- a/.github/stale.yml +++ /dev/null @@ -1,44 +0,0 @@ -# Configuration for probot-stale - https://github.com/probot/stale - -# Number of days of inactivity before an Issue or Pull Request becomes stale -daysUntilStale: 60 - -# Number of days of inactivity before an Issue or Pull Request with the stale label is closed. -# Set to false to disable. If disabled, issues still need to be closed manually, but will remain marked as stale. -daysUntilClose: 7 - -# Issues or Pull Requests with these labels will never be considered stale. Set to `[]` to disable -exemptLabels: - - pinned - - security - - dependencies - - never-stale - - priority:high - - priority:medium - -# Label to use when marking as stale -staleLabel: stale - -# Comment to post when marking as stale. Set to `false` to disable -markComment: > - This issue has been automatically marked as stale because it has not had - recent activity. It will be closed if no further activity occurs. Thank you - for your contributions. - -# Comment to post when removing the stale label. -# unmarkComment: > -# Your comment here. - -# Comment to post when closing a stale Issue or Pull Request. -# closeComment: > -# Your comment here. - -# Limit to only `issues` or `pulls` -# only: issues - -# Optionally, specify configuration settings that are specific to just 'issues' or 'pulls': -pulls: - markComment: > - This pull request has been automatically marked as stale because it has not had - recent activity. It will be closed if no further activity occurs. Thank you - for your contributions. diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 866c2f661f..d8ab81972a 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Jellyseerr CI on: diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index b2266728ef..d019b2f997 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: 'CodeQL' on: diff --git a/.github/workflows/conflict_labeler.yml b/.github/workflows/conflict_labeler.yml index a9c885d0f3..b198a24cc6 100644 --- a/.github/workflows/conflict_labeler.yml +++ b/.github/workflows/conflict_labeler.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Merge Conflict Labeler on: diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index 15c1566b84..0baa1fa3c0 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Cypress Tests on: diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index c9fb07f14d..bd54722ecf 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Deploy to GitHub Pages on: diff --git a/.github/workflows/helm.yml b/.github/workflows/helm.yml index 914264c681..2e49b36cfa 100644 --- a/.github/workflows/helm.yml +++ b/.github/workflows/helm.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Release Charts on: diff --git a/.github/workflows/lint-helm-charts.yml b/.github/workflows/lint-helm-charts.yml index 585dbb902b..461158f234 100644 --- a/.github/workflows/lint-helm-charts.yml +++ b/.github/workflows/lint-helm-charts.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Lint and Test Charts on: diff --git a/.github/workflows/preview.yml b/.github/workflows/preview.yml index 51f3b52dde..96e280e319 100644 --- a/.github/workflows/preview.yml +++ b/.github/workflows/preview.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Jellyseerr Preview on: diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index e869f2a0d5..cad9f2c451 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Jellyseerr Release on: diff --git a/.github/workflows/stale.yml b/.github/workflows/stale.yml new file mode 100644 index 0000000000..8d940f04e8 --- /dev/null +++ b/.github/workflows/stale.yml @@ -0,0 +1,35 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json +name: Close stale issues and PRs + +on: + schedule: + - cron: '0 7 * * *' + +permissions: {} + +concurrency: + group: close-stale-${{ github.ref }} + cancel-in-progress: true + +jobs: + stale: + name: Close stale issues and PRs + runs-on: ubuntu-24.04 + permissions: + actions: write + issues: write + pull-requests: write + steps: + - uses: actions/stale@v10.1.0 + with: + any-of-labels: "pending author's response" + exempt-issue-labels: 'confirmed' + days-before-stale: 30 + days-before-close: 30 + stale-issue-label: 'stale' + stale-issue-message: 'This issue is stale because it has been open 30 days with no activity. Please provide an update or the requested information to keep it open.' + close-issue-message: 'This issue was closed because it has been stalled for 30 days with no activity. Feel free to reopen it once you provide the required update or information.' + stale-pr-label: 'stale' + stale-pr-message: 'This PR is stale because it has been open 30 days with no activity. Please address the feedback or provide an update to keep it open.' + close-pr-message: 'This PR was closed because it has been stalled for 30 days with no activity. You can reopen it once you address the feedback or provide the requested changes.' diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index 2a351482de..977d576c5a 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: 'Support requests' on: diff --git a/.github/workflows/test-docs-deploy.yml b/.github/workflows/test-docs-deploy.yml index 6091c38caf..323bb05043 100644 --- a/.github/workflows/test-docs-deploy.yml +++ b/.github/workflows/test-docs-deploy.yml @@ -1,3 +1,5 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Test Docs deployment on: From 5c0a9690e1f488a83457625882610dd22cddd533 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Sat, 4 Oct 2025 19:13:13 +0300 Subject: [PATCH 39/96] chore: cleanup repository reference (#1921) Signed-off-by: Ludovic Ortega --- .all-contributorsrc | 4 ++-- .github/CODEOWNERS | 2 +- .github/ISSUE_TEMPLATE/bug.yml | 2 +- .github/PULL_REQUEST_TEMPLATE.md | 2 +- CONTRIBUTING.md | 6 +++--- README.md | 16 ++++++++-------- charts/jellyseerr-chart/Chart.yaml | 10 +++++----- charts/jellyseerr-chart/README.md | 6 +++--- docs/README.md | 2 +- docs/getting-started/buildfromsource.mdx | 4 ++-- docs/getting-started/kubernetes.mdx | 6 +++--- docs/using-jellyseerr/notifications/index.mdx | 2 +- .../src/components/JellyseerrVersion/index.tsx | 4 ++-- 13 files changed, 33 insertions(+), 33 deletions(-) diff --git a/.all-contributorsrc b/.all-contributorsrc index a22b044ad1..7c31686a09 100644 --- a/.all-contributorsrc +++ b/.all-contributorsrc @@ -15,10 +15,10 @@ "commitType": "docs", "contributors": [ { - "login": "Fallenbagel", + "login": "fallenbagel", "name": "Fallenbagel", "avatar_url": "https://avatars.githubusercontent.com/u/98979876?v=4", - "profile": "https://github.com/Fallenbagel", + "profile": "https://github.com/fallenbagel", "contributions": [ "code", "maintenance" diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index 280424a454..e7752c011d 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,2 +1,2 @@ # Global code ownership -* @Fallenbagel @gauthier-th +* @fallenbagel @gauthier-th diff --git a/.github/ISSUE_TEMPLATE/bug.yml b/.github/ISSUE_TEMPLATE/bug.yml index 94a91e93d7..2bdb0a2593 100644 --- a/.github/ISSUE_TEMPLATE/bug.yml +++ b/.github/ISSUE_TEMPLATE/bug.yml @@ -95,7 +95,7 @@ body: id: terms attributes: label: Code of Conduct - description: By submitting this issue, you agree to follow our [Code of Conduct](https://github.com/fallenbagel/jellyseerr/blob/develop/CODE_OF_CONDUCT.md) + description: By submitting this issue, you agree to follow our [Code of Conduct](/../../CODE_OF_CONDUCT.md) options: - label: I agree to follow Jellyseerr's Code of Conduct required: true diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md index 831ea0a3e5..5e7910254b 100644 --- a/.github/PULL_REQUEST_TEMPLATE.md +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -4,7 +4,7 @@ #### To-Dos -- [ ] Disclosed any use of AI (see our [policy](https://github.com/fallenbagel/jellyseerr/blob/develop/CONTRIBUTING.md#ai-assistance-notice)) +- [ ] Disclosed any use of AI (see our [policy](../CONTRIBUTING.md#ai-assistance-notice)) - [ ] Successful build `pnpm build` - [ ] Translation keys `pnpm i18n:extract` - [ ] Database migration (if required) diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index fec9b93a3e..12f07c6de3 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -120,7 +120,7 @@ Steps: ### Contributing Code -- If you are taking on an existing bug or feature ticket, please comment on the [issue](https://github.com/fallenbagel/jellyseerr/issues) to avoid multiple people working on the same thing. +- If you are taking on an existing bug or feature ticket, please comment on the [issue](/../../issues) to avoid multiple people working on the same thing. - All commits **must** follow [Conventional Commits](https://www.conventionalcommits.org/en/v1.0.0/) - Pull requests with commits not following this standard will **not** be merged. - Please make meaningful commits, or squash them prior to opening a pull request. @@ -130,7 +130,7 @@ Steps: - You can create a "draft" pull request early to get feedback on your work. - Your code **must** be formatted correctly, or the tests will fail. - We use Prettier to format our code base. It should automatically run with a Git hook, but it is recommended to have the Prettier extension installed in your editor and format on save. -- If you have questions or need help, you can reach out via [Discussions](https://github.com/fallenbagel/jellyseerr/discussions) or our [Discord server](https://discord.gg/ckbvBtDJgC). +- If you have questions or need help, you can reach out via [Discussions](/../../discussions) or our [Discord server](https://discord.gg/ckbvBtDJgC). - Only open pull requests to `develop`, never `master`! Any pull requests opened to `master` will be closed. ### UI Text Style @@ -151,7 +151,7 @@ When adding new UI text, please try to adhere to the following guidelines: ## Translation -We use [Weblate](https://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/) for our translations, and your help with localizing Jellyseerr would be greatly appreciated! If your language is not listed below, please [open a feature request](https://github.com/fallenbagel/jellyseerr/issues/new/choose). +We use [Weblate](https://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/) for our translations, and your help with localizing Jellyseerr would be greatly appreciated! If your language is not listed below, please [open a feature request](/../../issues/new/choose). Translation status diff --git a/README.md b/README.md index 164311b7cb..ccddc00721 100644 --- a/README.md +++ b/README.md @@ -2,8 +2,8 @@ Jellyseerr

-Jellyseerr Release -Jellyseerr CI +Jellyseerr Release +Jellyseerr CI

Discord @@ -31,7 +31,7 @@ - Mobile-friendly design, for when you need to approve requests on the go! - Support for watchlisting & blacklisting media. -With more features on the way! Check out our [issue tracker](https://github.com/fallenbagel/jellyseerr/issues) to see the features which have already been requested. +With more features on the way! Check out our [issue tracker](/../../issues) to see the features which have already been requested. ## Getting Started @@ -55,8 +55,8 @@ Nix: [Nixpkg](https://search.nixos.org/packages?channel=unstable&show=jellyseerr - Check out the [Jellyseerr Documentation](https://docs.jellyseerr.dev) before asking for help. Your question might already be in the docs! - You can get support on [Discord](https://discord.gg/ckbvBtDJgC). -- You can ask questions in the Help category of our [GitHub Discussions](https://github.com/fallenbagel/jellyseerr/discussions). -- Bug reports and feature requests can be submitted via [GitHub Issues](https://github.com/fallenbagel/jellyseerr/issues). +- You can ask questions in the Help category of our [GitHub Discussions](/../../discussions). +- Bug reports and feature requests can be submitted via [GitHub Issues](/../../issues). ## API Documentation @@ -64,15 +64,15 @@ You can access the API documentation from your local Jellyseerr install at http: ## Community -You can ask questions, share ideas, and more in [GitHub Discussions](https://github.com/fallenbagel/jellyseerr/discussions). +You can ask questions, share ideas, and more in [GitHub Discussions](/../../discussions). If you would like to chat with other members of our growing community, [join the Jellyseerr Discord server](https://discord.gg/ckbvBtDJgC)! -Our [Code of Conduct](https://github.com/fallenbagel/jellyseerr/blob/develop/CODE_OF_CONDUCT.md) applies to all Jellyseerr community channels. +Our [Code of Conduct](./CODE_OF_CONDUCT.md) applies to all Jellyseerr community channels. ## Contributing -You can help improve Jellyseerr too! Check out our [Contribution Guide](https://github.com/fallenbagel/jellyseerr/blob/develop/CONTRIBUTING.md) to get started. +You can help improve Jellyseerr too! Check out our [Contribution Guide](./CONTRIBUTING.md) to get started. ## Contributors ✨ diff --git a/charts/jellyseerr-chart/Chart.yaml b/charts/jellyseerr-chart/Chart.yaml index 72e2c3bbe7..6d3db70ee2 100644 --- a/charts/jellyseerr-chart/Chart.yaml +++ b/charts/jellyseerr-chart/Chart.yaml @@ -1,13 +1,13 @@ apiVersion: v2 -kubeVersion: ">=1.23.0-0" +kubeVersion: '>=1.23.0-0' name: jellyseerr-chart description: Jellyseerr helm chart for Kubernetes type: application version: 2.7.0 -appVersion: "2.7.3" +appVersion: '2.7.3' maintainers: - name: Jellyseerr - url: https://github.com/Fallenbagel/jellyseerr + url: https://github.com/fallenbagel/jellyseerr sources: - - https://github.com/Fallenbagel/jellyseerr/tree/main/charts/jellyseerr -home: https://github.com/Fallenbagel/jellyseerr + - https://github.com/fallenbagel/jellyseerr/tree/main/charts/jellyseerr +home: https://github.com/fallenbagel/jellyseerr diff --git a/charts/jellyseerr-chart/README.md b/charts/jellyseerr-chart/README.md index 88c374658c..4f656c1716 100644 --- a/charts/jellyseerr-chart/README.md +++ b/charts/jellyseerr-chart/README.md @@ -4,17 +4,17 @@ Jellyseerr helm chart for Kubernetes -**Homepage:** +**Homepage:** ## Maintainers | Name | Email | Url | | ---- | ------ | --- | -| Jellyseerr | | | +| Jellyseerr | | | ## Source Code -* +* ## Requirements diff --git a/docs/README.md b/docs/README.md index c2f4ff32d1..8b2d7a0cef 100644 --- a/docs/README.md +++ b/docs/README.md @@ -32,7 +32,7 @@ The primary motivation for starting Jellyseerr was to bring Jellyfin and Emby su ## We need your help! -[Jellyseerr](https://github.com/Fallenbagel/jellyseerr) is an ambitious project where developers/contributors poured a lot of work into, and that builds on top of [Overseerr](https://github.com/sct/overseerr). And we have a lot more to do as well. +[Jellyseerr](https://github.com/fallenbagel/jellyseerr) is an ambitious project where developers/contributors poured a lot of work into, and that builds on top of [Overseerr](https://github.com/sct/overseerr). And we have a lot more to do as well. We value your feedback and support in identifying and fixing bugs to make Jellyseerr even better. As an open-source project, we welcome contributions from everyone. While Jellyseerr has diverged from Overseerr and evolved into its own unique application, we still encourage contributions to Overseerr, as it played a crucial role in inspiring what Jellyseerr has become today. diff --git a/docs/getting-started/buildfromsource.mdx b/docs/getting-started/buildfromsource.mdx index fe3235648c..219b200c92 100644 --- a/docs/getting-started/buildfromsource.mdx +++ b/docs/getting-started/buildfromsource.mdx @@ -26,7 +26,7 @@ sudo mkdir -p /opt/jellyseerr && cd /opt/jellyseerr ``` 2. Clone the Jellyseerr repository and checkout the develop branch: ```bash -git clone https://github.com/Fallenbagel/jellyseerr.git +git clone https://github.com/fallenbagel/jellyseerr.git cd jellyseerr git checkout main ``` @@ -201,7 +201,7 @@ cd C:\jellyseerr ``` 2. Clone the Jellyseerr repository and checkout the develop branch: ```powershell -git clone https://github.com/Fallenbagel/jellyseerr.git . +git clone https://github.com/fallenbagel/jellyseerr.git . git checkout main ``` 3. Install the dependencies: diff --git a/docs/getting-started/kubernetes.mdx b/docs/getting-started/kubernetes.mdx index 5fd0d6d519..4720abed96 100644 --- a/docs/getting-started/kubernetes.mdx +++ b/docs/getting-started/kubernetes.mdx @@ -12,10 +12,10 @@ This method is not recommended for most users. It is intended for advanced users ```console helm install jellyseerr oci://ghcr.io/fallenbagel/jellyseerr/jellyseerr-chart ``` -Helm values can be found in the Jellyseerr repository under [charts/jellyseerr-chart/README.md](https://github.com/Fallenbagel/jellyseerr/tree/develop/charts/jellyseerr-chart). +Helm values can be found in the Jellyseerr repository under [charts/jellyseerr-chart/README.md](https://github.com/fallenbagel/jellyseerr/tree/develop/charts/jellyseerr-chart). Verify the signature with [cosign](https://docs.sigstore.dev/cosign/system_config/installation/) (replace [tag], with the TAG you want to verify) : ```console -cosign verify ghcr.io/fallenbagel/jellyseerr/jellyseerr-chart:[tag] --certificate-identity=https://github.com/Fallenbagel/jellyseerr/.github/workflows/helm.yml@refs/heads/main --certificate-oidc-issuer=https://token.ac +cosign verify ghcr.io/fallenbagel/jellyseerr/jellyseerr-chart:[tag] --certificate-identity=https://github.com/fallenbagel/jellyseerr/.github/workflows/helm.yml@refs/heads/main --certificate-oidc-issuer=https://token.ac tions.githubusercontent.com -``` \ No newline at end of file +``` diff --git a/docs/using-jellyseerr/notifications/index.mdx b/docs/using-jellyseerr/notifications/index.mdx index 6fd0b1ce9d..84d15d0281 100644 --- a/docs/using-jellyseerr/notifications/index.mdx +++ b/docs/using-jellyseerr/notifications/index.mdx @@ -22,4 +22,4 @@ Users can customize their notification preferences in their own user notificatio ## Requesting New Notification Agents -If we do not currently support your preferred notification agent, feel free to [submit a feature request on GitHub](https://github.com/Fallenbagel/jellyseerr/issues). However, please be sure to search first and confirm that there is not already an existing request for the agent! +If we do not currently support your preferred notification agent, feel free to [submit a feature request on GitHub](https://github.com/fallenbagel/jellyseerr/issues). However, please be sure to search first and confirm that there is not already an existing request for the agent! diff --git a/gen-docs/src/components/JellyseerrVersion/index.tsx b/gen-docs/src/components/JellyseerrVersion/index.tsx index 355f74443c..77e9027541 100644 --- a/gen-docs/src/components/JellyseerrVersion/index.tsx +++ b/gen-docs/src/components/JellyseerrVersion/index.tsx @@ -7,7 +7,7 @@ export const JellyseerrVersion = () => { async function fetchVersion() { try { const response = await fetch( - 'https://raw.githubusercontent.com/Fallenbagel/jellyseerr/main/package.json' + 'https://raw.githubusercontent.com/fallenbagel/jellyseerr/main/package.json' ); const data = await response.json(); @@ -36,7 +36,7 @@ export const NixpkgVersion = () => { const unstableUrl = 'https://raw.githubusercontent.com/NixOS/nixpkgs/refs/heads/nixos-unstable/pkgs/by-name/je/jellyseerr/package.nix'; const stableUrl = - 'https://raw.githubusercontent.com/NixOS/nixpkgs/refs/heads/nixos-24.11/pkgs/servers/jellyseerr/default.nix'; + 'https://raw.githubusercontent.com/NixOS/nixpkgs/refs/heads/nixos-25.05/pkgs/by-name/je/jellyseerr/package.nix'; const [unstableResponse, stableResponse] = await Promise.all([ fetch(unstableUrl), From e8e9fc1ab9a932b8857a028691717451b4f2d9f5 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Sun, 5 Oct 2025 23:03:31 +0300 Subject: [PATCH 40/96] chore: migrate compose postgres to compose v2 (#1962) Signed-off-by: Ludovic Ortega --- docker-compose.postgres.yaml => compose.postgres.yaml | 2 -- 1 file changed, 2 deletions(-) rename docker-compose.postgres.yaml => compose.postgres.yaml (98%) diff --git a/docker-compose.postgres.yaml b/compose.postgres.yaml similarity index 98% rename from docker-compose.postgres.yaml rename to compose.postgres.yaml index 2ed270f3d4..937beac170 100644 --- a/docker-compose.postgres.yaml +++ b/compose.postgres.yaml @@ -1,5 +1,3 @@ ---- -version: '3.8' services: jellyseerr: build: From 9ca63ba50453aba7e02b8ff07e44016a02f3f02f Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Sun, 5 Oct 2025 23:04:21 +0300 Subject: [PATCH 41/96] chore: remove snap package reference (#1965) Signed-off-by: Ludovic Ortega --- .dockerignore | 1 - README.md | 2 - snap/snapcraft.yaml | 121 -------------------------------------------- 3 files changed, 124 deletions(-) delete mode 100644 snap/snapcraft.yaml diff --git a/.dockerignore b/.dockerignore index 5a009f2afb..842babd44d 100644 --- a/.dockerignore +++ b/.dockerignore @@ -24,6 +24,5 @@ LICENSE node_modules public/os_logo_filled.png public/preview.jpg -snap stylelint.config.js cypress diff --git a/README.md b/README.md index ccddc00721..ddfffa4ddc 100644 --- a/README.md +++ b/README.md @@ -45,8 +45,6 @@ Archlinux: [AUR](https://aur.archlinux.org/packages/jellyseerr) Nix: [Nixpkg](https://search.nixos.org/packages?channel=unstable&show=jellyseerr) -~Snap: [Snap](https://snapcraft.io/jellyseerr)~(Deprecated) - ## Preview diff --git a/snap/snapcraft.yaml b/snap/snapcraft.yaml deleted file mode 100644 index ba4a83457b..0000000000 --- a/snap/snapcraft.yaml +++ /dev/null @@ -1,121 +0,0 @@ -name: jellyseerr -adopt-info: jellyseerr -license: MIT -summary: Request management and media discovery tool for media servers -description: > - Jellyseerr is a free and open source software application for managing requests for your media library. - It is a a fork of Overseerr built to bring support for & focusing mainly on Jellyfin & Emby media servers! - It integrates with your existing services such as Sonarr, Radarr, and Jellyfin/Emby/Plex. -base: core20 -confinement: strict - -architectures: - - build-on: amd64 - - build-on: arm64 - # - build-on: armhf - -parts: - jellyseerr: - plugin: nil - build-packages: - - git - - ca-certificates - - curl - - gnupg - - on arm64: - - build-essential - - automake - - python-gi - - python-gi-dev - # - on armhf: - # - libatomic1 - # - build-essential - # - automake - # - python-gi - # - python-gi-dev - source: . - override-pull: | - snapcraftctl pull - # Get information to determine snap grade and version - git config --global --add safe.directory /data/parts/jellyseerr/src - #setup yarn.rc - echo "--install.frozen-lockfile\n--install.network-timeout 1000000" > .yarnrc - BRANCH=$(git rev-parse --abbrev-ref HEAD) - COMMIT=$(git rev-parse HEAD) - COMMIT_SHORT=$(git rev-parse --short HEAD) - VERSION='v'$(cat package.json | grep 'version' | head -1 | sed 's/.*"\(.*\)"\,/\1/') - if [ "$VERSION" = "v0.1.0" ]; then - SNAP_VERSION=$COMMIT_SHORT - GRADE=stable - else - SNAP_VERSION=$VERSION - GRADE=stable - fi - # Write COMMIT_TAG as it is needed durring the build process - echo $COMMIT > commit.txt - # Print debug info for build version - echo "{\"commitShort\": \"$COMMIT_SHORT\", \ - \"version\": \"$VERSION\", \ - \"snapVersion\": \"$SNAP_VERSION\", \ - \"snapGrade\": \"$GRADE\", \ - \"branch\": \"$BRANCH\", \ - \"commit\": \"$COMMIT\"}" - echo "{\"commitTag\": \"$COMMIT\"}" > committag.json - # Set snap version and grade - snapcraftctl set-version "$SNAP_VERSION" - snapcraftctl set-grade "$GRADE" - build-environment: - - PATH: '$SNAPCRAFT_PART_BUILD/node_modules/.bin:$PATH' - - CYPRESS_INSTALL_BINARY: '0' - override-build: | - set -e - # Install necessary packages - mkdir -p /etc/apt/keyrings - # Add Node.js repository key - curl -fsSL https://deb.nodesource.com/gpgkey/nodesource-repo.gpg.key | gpg --dearmor -o /etc/apt/keyrings/nodesource.gpg - - # Set Node.js version - NODE_MAJOR=20 - # Add Node.js repository to sources list - echo "deb [signed-by=/etc/apt/keyrings/nodesource.gpg] https://deb.nodesource.com/node_$NODE_MAJOR.x nodistro main" | tee /etc/apt/sources.list.d/nodesource.list - - # Update package sources and install Node.js - apt-get update - apt-get install nodejs -y - - # Install Yarn - npm install -g yarn - # Set COMMIT_TAG before the build begins - export COMMIT_TAG=$(cat $SNAPCRAFT_PART_BUILD/commit.txt) - snapcraftctl build - yarn install --frozen-lockfile --network-timeout 1000000 - yarn build - # Copy files needed for staging - cp $SNAPCRAFT_PART_BUILD/committag.json $SNAPCRAFT_PART_INSTALL/ - cp -R $SNAPCRAFT_PART_BUILD/.next $SNAPCRAFT_PART_INSTALL/ - cp -R $SNAPCRAFT_PART_BUILD/dist $SNAPCRAFT_PART_INSTALL/ - cp -R $SNAPCRAFT_PART_BUILD/node_modules $SNAPCRAFT_PART_INSTALL/ - # Remove .github and gitbook as it will fail snap lint - rm -rf $SNAPCRAFT_PART_INSTALL/.github - # stage-packages: - # - on armhf: - # - libatomic1 - stage: [.next, ./*] - prime: [.next, ./*] - -apps: - daemon: - command: /bin/sh -c "cd $SNAP && node dist/index.js" - daemon: simple - restart-condition: on-failure - restart-delay: 5s - plugs: - - home - - network - - network-bind - environment: - PATH: '$SNAP/usr/sbin:$SNAP/usr/bin:$SNAP/sbin:$SNAP/bin:$PATH' - OVERSEERR_SNAP: 'True' - CONFIG_DIRECTORY: $SNAP_USER_COMMON - LOG_LEVEL: 'debug' - NODE_ENV: 'production' From 42eec245b71e521557ea3742e98db42a0a0c5dd1 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Mon, 6 Oct 2025 02:54:14 +0200 Subject: [PATCH 42/96] docs: add a warning about the new mount point in Postgres (#1968) * docs: add a warning about the new mount point in Postgres * fix: update path Co-authored-by: fallenbagel <98979876+fallenbagel@users.noreply.github.com> --------- Co-authored-by: fallenbagel <98979876+fallenbagel@users.noreply.github.com> --- docs/extending-jellyseerr/database-config.mdx | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/docs/extending-jellyseerr/database-config.mdx b/docs/extending-jellyseerr/database-config.mdx index a952167828..df099187c6 100644 --- a/docs/extending-jellyseerr/database-config.mdx +++ b/docs/extending-jellyseerr/database-config.mdx @@ -19,6 +19,10 @@ DB_LOG_QUERIES="false" # (optional) Whether to log the DB queries for debugging. ## PostgreSQL Options +:::caution +When migrating Postgres from version 17 to 18 in Docker, note that the data mount point has changed. Instead of using `/var/lib/postgresql/data`, the correct mount path is now `/var/lib/postgresql`. +::: + ### TCP Connection If your PostgreSQL server is configured to accept TCP connections, you can specify the host and port using the `DB_HOST` and `DB_PORT` environment variables. This is useful for remote connections where the server uses a network host and port. From 0217096a1c1647531c9f1c6733638e4b2750f9ef Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 6 Oct 2025 19:03:22 +0100 Subject: [PATCH 43/96] docs: add comprehensive security policy (#1970) * docs: add comprehensive security policy * Update SECURITY.md Co-authored-by: Ludovic Ortega * Update SECURITY.md Co-authored-by: Ludovic Ortega * Update SECURITY.md Co-authored-by: Ludovic Ortega --------- Co-authored-by: Ludovic Ortega --- SECURITY.md | 51 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 51 insertions(+) create mode 100644 SECURITY.md diff --git a/SECURITY.md b/SECURITY.md new file mode 100644 index 0000000000..5ea6370792 --- /dev/null +++ b/SECURITY.md @@ -0,0 +1,51 @@ +# Security Policy + +## Reporting Security Issues + +Maintainers and community take security bugs seriously. We appreciate your efforts to responsibly disclose your findings, and will make every effort to acknowledge your contributions. + +To report a security issue, please use the GitHub Security Advisory ["Report a Vulnerability"](../../security/advisories/new) tab. + +**Please do not report security vulnerabilities through public GitHub issues, discussions, or Discord.** + +## What to Include in Your Report + +To help us better understand and resolve the issue, please include as much of the following information as possible: + +- Full paths of source file(s) related to the manifestation of the issue +- The location of the affected source code (tag/branch/commit or direct URL) +- Any special configuration required to reproduce the issue +- Step-by-step instructions to reproduce the issue +- Proof-of-concept or exploit code (if possible) +- Impact of the issue + +## Response Timeline + +We will send a response indicating the next steps in handling your report. After the initial reply to your report, the security team will keep you informed of the progress towards a fix and full announcement, and may ask for additional information or guidance. + +## Disclosure Policy + +- Security issues will be disclosed in a coordinated manner +- We will credit reporters in the security advisory unless anonymity is requested +- We request that you do not publicly disclose the issue until we have released a fix + +## Third-Party Dependencies + +If you discover a security vulnerability in a third-party dependency used by Jellyseerr, please report it directly to the maintainers of that module. You can also notify us through our security advisory process so we can: + +- Track the issue and monitor for updates +- Apply patches or workarounds if available +- Coordinate with upstream maintainers when necessary +- Communicate the impact to our users + +We regularly monitor and update our dependencies to address known security vulnerabilities. + +## Security Updates + +Security updates and advisories will be published on our [GitHub Security Advisories page](../../security/advisories). + +## Community + +For general questions and support (non-security related): +- [GitHub Discussions](../../discussions) +- [Discord](https://discord.gg/ckbvBtDJgC) \ No newline at end of file From a53e180caae9a351a24c8fbb1cfab8f2dcb08238 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Mon, 6 Oct 2025 21:46:06 +0300 Subject: [PATCH 44/96] chore: use seerr-core in codeowners (#1973) Signed-off-by: Ludovic Ortega --- .github/CODEOWNERS | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/CODEOWNERS b/.github/CODEOWNERS index e7752c011d..86314273de 100644 --- a/.github/CODEOWNERS +++ b/.github/CODEOWNERS @@ -1,2 +1,2 @@ # Global code ownership -* @fallenbagel @gauthier-th +* @seerr-team/seerr-core From 500ced0fdd5c6ed51fa044457e6651dff6c05b75 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 6 Oct 2025 19:49:03 +0100 Subject: [PATCH 45/96] chore: updated the security policy discord links (#1976) --- SECURITY.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SECURITY.md b/SECURITY.md index 5ea6370792..3b15aeb5f0 100644 --- a/SECURITY.md +++ b/SECURITY.md @@ -48,4 +48,4 @@ Security updates and advisories will be published on our [GitHub Security Adviso For general questions and support (non-security related): - [GitHub Discussions](../../discussions) -- [Discord](https://discord.gg/ckbvBtDJgC) \ No newline at end of file +- [Discord](https://discord.gg/seerr) \ No newline at end of file From 32ae099552c770ff29a4e89a830fe1b502f84db7 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 6 Oct 2025 19:49:35 +0100 Subject: [PATCH 46/96] ci: add link checks to the docs (#1971) * ci: add link checks to the docs * updated regex * stop 403s from discord support links --- .github/workflows/docs-link-check.yml | 74 +++++++++++++++++++++++++++ 1 file changed, 74 insertions(+) create mode 100644 .github/workflows/docs-link-check.yml diff --git a/.github/workflows/docs-link-check.yml b/.github/workflows/docs-link-check.yml new file mode 100644 index 0000000000..6fd5442f59 --- /dev/null +++ b/.github/workflows/docs-link-check.yml @@ -0,0 +1,74 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json +name: Check Docs Links + +on: + pull_request: + branches: + - '*' + paths: + - 'docs/**' + - 'gen-docs/**' + - '.github/workflows/docs-link-check.yml' + push: + branches: + - develop + paths: + - 'docs/**' + - 'gen-docs/**' + - '.github/workflows/docs-link-check.yml' + schedule: + - cron: '50 7 * * 5' + workflow_dispatch: + +permissions: + contents: read + +concurrency: + group: docs-link-check-${{ github.ref }} + cancel-in-progress: true + +jobs: + link-check: + name: Verify external links in Markdown and MDX + runs-on: ubuntu-24.04 + timeout-minutes: 20 + + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + persist-credentials: false + + - name: Run Lychee link checker + uses: lycheeverse/lychee-action@v2 + with: + fail: false + args: >- + --verbose + --no-progress + --accept 200..204,300..304,307,308,404,429,999 + --include '^(http|https)://.*' + --exclude '^file://' + --exclude '^https?://localhost' + --exclude '^https?://127\.0\.0\.1' + --exclude '^https?://0\.0\.0\.0' + --exclude '^https?://\[\:\:1\]' + --exclude '^https?://\[\:\:\]' + --exclude '^https?://support.discord.com' + './docs/**/*.md' + './docs/**/*.mdx' + './gen-docs/**/*.md' + './gen-docs/**/*.mdx' + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Upload Lychee report + uses: actions/upload-artifact@v4 + with: + name: lychee-report + path: | + lychee/out.md + lychee/results.json + if-no-files-found: ignore From 166e2404b2ac6146721160a4712da1c3a2f3fd6e Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Mon, 6 Oct 2025 21:50:38 +0300 Subject: [PATCH 47/96] chore: remove unused files (#1966) * chore: removed unused files Signed-off-by: Ludovic Ortega * chore: remove cypress deprecated config option Signed-off-by: Ludovic Ortega * chore: remove deprecated log file Signed-off-by: Ludovic Ortega --------- Signed-off-by: Ludovic Ortega --- .dockerignore | 1 - .gitbook.yaml | 5 ----- .github/holopin.yml | 5 ----- .github/lock.yml | 38 -------------------------------------- .stoplight.json | 9 --------- cypress.config.ts | 1 - server/logger.ts | 11 ----------- 7 files changed, 70 deletions(-) delete mode 100644 .gitbook.yaml delete mode 100644 .github/holopin.yml delete mode 100644 .github/lock.yml delete mode 100644 .stoplight.json diff --git a/.dockerignore b/.dockerignore index 842babd44d..a12de07ad0 100644 --- a/.dockerignore +++ b/.dockerignore @@ -6,7 +6,6 @@ .editorconfig .eslintrc.js .git -.gitbook.yaml .gitconfig .github .gitignore diff --git a/.gitbook.yaml b/.gitbook.yaml deleted file mode 100644 index 2b0a6c4e86..0000000000 --- a/.gitbook.yaml +++ /dev/null @@ -1,5 +0,0 @@ -root: ./docs - -​structure: - readme: README.md - summary: SUMMARY.md​ diff --git a/.github/holopin.yml b/.github/holopin.yml deleted file mode 100644 index ee4edc81b3..0000000000 --- a/.github/holopin.yml +++ /dev/null @@ -1,5 +0,0 @@ -organization: overseerr -defaultSticker: clcyagj1j329008l468ya8pu2 -stickers: - - id: clcyagj1j329008l468ya8pu2 - alias: overseerr-contributor diff --git a/.github/lock.yml b/.github/lock.yml deleted file mode 100644 index 03a53feac9..0000000000 --- a/.github/lock.yml +++ /dev/null @@ -1,38 +0,0 @@ -# Configuration for Lock Threads - https://github.com/dessant/lock-threads-app - -# Number of days of inactivity before a closed issue or pull request is locked -daysUntilLock: 365 - -# Skip issues and pull requests created before a given timestamp. Timestamp must -# follow ISO 8601 (`YYYY-MM-DD`). Set to `false` to disable -skipCreatedBefore: false - -# Issues and pull requests with these labels will be ignored. Set to `[]` to disable -exemptLabels: - - dependencies - -# Label to add before locking, such as `outdated`. Set to `false` to disable -lockLabel: false - -# Comment to post before locking. Set to `false` to disable -lockComment: > - This thread has been automatically locked since there has not been - any recent activity after it was closed. Please open a new issue for - related bugs. - -# Assign `resolved` as the reason for locking. Set to `false` to disable -setLockReason: true -# Limit to only `issues` or `pulls` -# only: issues - -# Optionally, specify configuration settings just for `issues` or `pulls` -# issues: -# exemptLabels: -# - help-wanted -# lockLabel: outdated - -# pulls: -# daysUntilLock: 30 - -# Repository to extend settings from -# _extends: repo diff --git a/.stoplight.json b/.stoplight.json deleted file mode 100644 index 0a876a9eb6..0000000000 --- a/.stoplight.json +++ /dev/null @@ -1,9 +0,0 @@ -{ - "formats": { - "openapi": { - "rootDir": ".", - "include": ["**"] - } - }, - "exclude": ["docs"] -} diff --git a/cypress.config.ts b/cypress.config.ts index 598bcb736f..793a207f09 100644 --- a/cypress.config.ts +++ b/cypress.config.ts @@ -5,7 +5,6 @@ export default defineConfig({ e2e: { baseUrl: 'http://localhost:5055', video: true, - experimentalSessionAndOrigin: true, }, env: { ADMIN_EMAIL: 'admin@seerr.dev', diff --git a/server/logger.ts b/server/logger.ts index 4708dd20d7..bf4d9ab785 100644 --- a/server/logger.ts +++ b/server/logger.ts @@ -1,18 +1,7 @@ -import fs from 'fs'; import path from 'path'; import * as winston from 'winston'; import 'winston-daily-rotate-file'; -// Migrate away from old log -const OLD_LOG_FILE = path.join(__dirname, '../config/logs/overseerr.log'); -if (fs.existsSync(OLD_LOG_FILE)) { - const file = fs.lstatSync(OLD_LOG_FILE); - - if (!file.isSymbolicLink()) { - fs.unlinkSync(OLD_LOG_FILE); - } -} - const hformat = winston.format.printf( ({ level, label, message, timestamp, ...metadata }) => { let msg = `${timestamp} [${level}]${ From 06ebd49a8e264514f0967d4ed05002be0ca85e02 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Mon, 6 Oct 2025 21:50:58 +0300 Subject: [PATCH 48/96] build(docker): enable corepack so we don't need to pin pnpm version (#1961) * build(docker): enable corepack so we don't need to pin pnpm version Signed-off-by: Ludovic Ortega * build(docker): fix StageNameCasing error Signed-off-by: Ludovic Ortega --------- Signed-off-by: Ludovic Ortega --- Dockerfile | 18 +++++++++++------- Dockerfile.local | 6 ++++-- 2 files changed, 15 insertions(+), 9 deletions(-) diff --git a/Dockerfile b/Dockerfile index 00a4a13aef..650027e45e 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,6 +1,4 @@ -FROM node:22-alpine AS BUILD_IMAGE - -WORKDIR /app +FROM node:22-alpine AS build_image ARG SOURCE_DATE_EPOCH ARG TARGETPLATFORM @@ -8,6 +6,10 @@ ARG COMMIT_TAG ENV TARGETPLATFORM=${TARGETPLATFORM:-linux/amd64} ENV COMMIT_TAG=${COMMIT_TAG} +ENV PNPM_HOME="/pnpm" +ENV PATH="$PNPM_HOME:$PATH" +RUN corepack enable + RUN \ case "${TARGETPLATFORM}" in \ 'linux/arm64' | 'linux/arm/v7') \ @@ -17,7 +19,7 @@ RUN \ ;; \ esac -RUN npm install --global pnpm@10 +WORKDIR /app COPY package.json pnpm-lock.yaml postinstall-win.js ./ RUN CYPRESS_INSTALL_BINARY=0 pnpm install --frozen-lockfile @@ -33,14 +35,16 @@ RUN pnpm prune --prod --ignore-scripts && \ FROM node:22-alpine +ENV PNPM_HOME="/pnpm" +ENV PATH="$PNPM_HOME:$PATH" +RUN corepack enable + WORKDIR /app RUN apk add --no-cache tzdata tini && rm -rf /tmp/* -RUN npm install -g pnpm@10 - # copy from build image -COPY --from=BUILD_IMAGE /app ./ +COPY --from=build_image /app ./ ENTRYPOINT [ "/sbin/tini", "--" ] CMD [ "pnpm", "start" ] diff --git a/Dockerfile.local b/Dockerfile.local index 1f7708d982..8d0ce3f33f 100644 --- a/Dockerfile.local +++ b/Dockerfile.local @@ -1,10 +1,12 @@ FROM node:22-alpine +ENV PNPM_HOME="/pnpm" +ENV PATH="$PNPM_HOME:$PATH" +RUN corepack enable + COPY . /app WORKDIR /app -RUN npm install --global pnpm@10 - RUN pnpm install CMD pnpm dev From adcbeb9f8929bcfdd24dc615ae528e3da974da07 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 6 Oct 2025 20:04:37 +0100 Subject: [PATCH 49/96] ci: updated the release workflow names and introduced the trivy vuln scan wf (#1978) --- .github/workflows/ci.yml | 2 +- .github/workflows/preview.yml | 2 +- .github/workflows/release.yml | 2 +- .github/workflows/stale.yml | 2 +- .github/workflows/trivy-scan.yml | 61 ++++++++++++++++++++++++++++++++ 5 files changed, 65 insertions(+), 4 deletions(-) create mode 100644 .github/workflows/trivy-scan.yml diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index d8ab81972a..de10883657 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -1,6 +1,6 @@ --- # yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json -name: Jellyseerr CI +name: Seerr CI on: pull_request: diff --git a/.github/workflows/preview.yml b/.github/workflows/preview.yml index 96e280e319..4b86393cea 100644 --- a/.github/workflows/preview.yml +++ b/.github/workflows/preview.yml @@ -1,6 +1,6 @@ --- # yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json -name: Jellyseerr Preview +name: Seerr Preview on: push: diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index cad9f2c451..2baa238547 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,6 +1,6 @@ --- # yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json -name: Jellyseerr Release +name: Seerr Release on: workflow_dispatch: diff --git a/.github/workflows/stale.yml b/.github/workflows/stale.yml index 8d940f04e8..3a4ce1099d 100644 --- a/.github/workflows/stale.yml +++ b/.github/workflows/stale.yml @@ -1,6 +1,6 @@ --- # yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json -name: Close stale issues and PRs +name: Close Stale Issues and PRs on: schedule: diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml new file mode 100644 index 0000000000..d38021e947 --- /dev/null +++ b/.github/workflows/trivy-scan.yml @@ -0,0 +1,61 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json +name: Trivy Container Vulnerability Scan + +on: + workflow_run: + workflows: + - Jellyseerr Release + types: + - completed + schedule: + - cron: '50 7 * * 5' + workflow_dispatch: + +permissions: + contents: read + +concurrency: + group: trivy-scan-${{ github.ref }} + cancel-in-progress: true + +jobs: + trivy: + if: ${{ github.event_name != 'workflow_run' || github.event.workflow_run.conclusion == 'success' }} + name: Scan latest container image + runs-on: ubuntu-24.04 + + permissions: + contents: read + security-events: write + + env: + TRIVY_CACHE_DIR: .trivycache + + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + fetch-depth: 0 + persist-credentials: false + + - name: Cache Trivy DB + uses: actions/cache@v4 + with: + path: .trivycache + key: trivy-${{ runner.os }}-${{ hashFiles('**/Dockerfile') }} + restore-keys: | + trivy-${{ runner.os }}- + + - name: Run Trivy image scan + uses: aquasecurity/trivy-action@b6643a29fecd7f34b3597bc6acb0a98b03d33ff8 # v0.33.1 + with: + image-ref: ghcr.io/${{ github.repository }}:latest + format: sarif + output: trivy.sarif + ignore-unfixed: true + + - name: Upload SARIF to code scanning + uses: github/codeql-action/upload-sarif@v3 + with: + sarif_file: trivy.sarif From 9674358c0f72167409b668d64741ed0d15513bb1 Mon Sep 17 00:00:00 2001 From: Ryan Cohen Date: Mon, 6 Oct 2025 13:10:19 -0600 Subject: [PATCH 50/96] docs: updates funding and contributor information (#1977) [skip ci] --- .all-contributorsrc | 665 -------------------------------------------- .dockerignore | 1 - .gitattributes | 1 - .github/FUNDING.yml | 2 +- README.md | 265 +----------------- 5 files changed, 5 insertions(+), 929 deletions(-) delete mode 100644 .all-contributorsrc diff --git a/.all-contributorsrc b/.all-contributorsrc deleted file mode 100644 index 7c31686a09..0000000000 --- a/.all-contributorsrc +++ /dev/null @@ -1,665 +0,0 @@ -{ - "files": [ - "README.md" - ], - "imageSize": 100, - "commit": false, - "badgeTemplate": "\"All-orange.svg\"/>", - "contributorsPerLine": 7, - "projectName": "jellyseerr", - "projectOwner": "fallenbagel", - "repoType": "github", - "repoHost": "https://github.com", - "skipCi": true, - "commitConvention": "angular", - "commitType": "docs", - "contributors": [ - { - "login": "fallenbagel", - "name": "Fallenbagel", - "avatar_url": "https://avatars.githubusercontent.com/u/98979876?v=4", - "profile": "https://github.com/fallenbagel", - "contributions": [ - "code", - "maintenance" - ] - }, - { - "login": "seanzhang98", - "name": "Sean", - "avatar_url": "https://avatars.githubusercontent.com/u/34902361?v=4", - "profile": "https://github.com/seanzhang98", - "contributions": [ - "translation", - "code" - ] - }, - { - "login": "notfakie", - "name": "notfakie", - "avatar_url": "https://avatars.githubusercontent.com/u/103784113?v=4", - "profile": "https://github.com/notfakie", - "contributions": [ - "code" - ] - }, - { - "login": "Jumail", - "name": "Mohamed Jumail", - "avatar_url": "https://avatars.githubusercontent.com/u/7672055?v=4", - "profile": "https://github.com/Jumail", - "contributions": [ - "review" - ] - }, - { - "login": "jsl9208", - "name": "Shilong Jiang", - "avatar_url": "https://avatars.githubusercontent.com/u/4048787?v=4", - "profile": "https://www.heywhale.com", - "contributions": [ - "code" - ] - }, - { - "login": "boring-dragon", - "name": "Boring Dragon", - "avatar_url": "https://avatars.githubusercontent.com/u/28459081?v=4", - "profile": "https://jinas.me", - "contributions": [ - "code" - ] - }, - { - "login": "sambartik", - "name": "Samuel Bartík", - "avatar_url": "https://avatars.githubusercontent.com/u/63553146?v=4", - "profile": "https://github.com/sambartik", - "contributions": [ - "code" - ] - }, - { - "login": "CyferShepard", - "name": "Thegan Govender", - "avatar_url": "https://avatars.githubusercontent.com/u/24864904?v=4", - "profile": "https://github.com/CyferShepard", - "contributions": [ - "code" - ] - }, - { - "login": "jab416171", - "name": "jab416171", - "avatar_url": "https://avatars.githubusercontent.com/u/345752?v=4", - "profile": "https://github.com/jab416171", - "contributions": [ - "doc", - "code" - ] - }, - { - "login": "NicolaiVdS", - "name": "Nicolai Van der Storm", - "avatar_url": "https://avatars.githubusercontent.com/u/5257222?v=4", - "profile": "https://nvds.be", - "contributions": [ - "code" - ] - }, - { - "login": "Smexhy", - "name": "Smexhy", - "avatar_url": "https://avatars.githubusercontent.com/u/4880625?v=4", - "profile": "https://github.com/Smexhy", - "contributions": [ - "translation" - ] - }, - { - "login": "dd060606", - "name": "dd060606", - "avatar_url": "https://avatars.githubusercontent.com/u/58089504?v=4", - "profile": "https://dd06-dev.fr", - "contributions": [ - "code" - ] - }, - { - "login": "darmiel", - "name": "Daniel", - "avatar_url": "https://avatars.githubusercontent.com/u/71837281?v=4", - "profile": "https://qwer.tz", - "contributions": [ - "code" - ] - }, - { - "login": "undone37", - "name": "undone37", - "avatar_url": "https://avatars.githubusercontent.com/u/10513808?v=4", - "profile": "https://github.com/undone37", - "contributions": [ - "translation" - ] - }, - { - "login": "CheChu10", - "name": "Chechu García", - "avatar_url": "https://avatars.githubusercontent.com/u/32913133?v=4", - "profile": "https://github.com/CheChu10", - "contributions": [ - "translation" - ] - }, - { - "login": "DimitriDR", - "name": "Dimitri", - "avatar_url": "https://avatars.githubusercontent.com/u/56969769?v=4", - "profile": "https://github.com/DimitriDR", - "contributions": [ - "translation" - ] - }, - { - "login": "andrey4korop", - "name": "andrey4korop", - "avatar_url": "https://avatars.githubusercontent.com/u/24610708?v=4", - "profile": "https://github.com/andrey4korop", - "contributions": [ - "code", - "translation" - ] - }, - { - "login": "GeoffreyCoulaud", - "name": "Geoffrey Coulaud", - "avatar_url": "https://avatars.githubusercontent.com/u/20744730?v=4", - "profile": "https://geoffrey-coulaud.fr", - "contributions": [ - "translation" - ] - }, - { - "login": "Pikachu920", - "name": "Pikachu920", - "avatar_url": "https://avatars.githubusercontent.com/u/28607612?v=4", - "profile": "https://github.com/Pikachu920", - "contributions": [ - "code" - ] - }, - { - "login": "yalagin", - "name": "Maxim Yalagin", - "avatar_url": "https://avatars.githubusercontent.com/u/12879142?v=4", - "profile": "https://github.com/yalagin", - "contributions": [ - "code" - ] - }, - { - "login": "jeaboswell", - "name": "Jesse Boswell", - "avatar_url": "https://avatars.githubusercontent.com/u/11653068?v=4", - "profile": "https://github.com/jeaboswell", - "contributions": [ - "code" - ] - }, - { - "login": "d-fendrich", - "name": "d-fendrich", - "avatar_url": "https://avatars.githubusercontent.com/u/27904138?v=4", - "profile": "https://github.com/d-fendrich", - "contributions": [ - "translation" - ] - }, - { - "login": "davidfdezalcoba", - "name": "David Fernández Alcoba", - "avatar_url": "https://avatars.githubusercontent.com/u/15996018?v=4", - "profile": "https://github.com/davidfdezalcoba", - "contributions": [ - "code" - ] - }, - { - "login": "Gauvino", - "name": "Gauvino", - "avatar_url": "https://avatars.githubusercontent.com/u/68083474?v=4", - "profile": "https://github.com/Gauvino", - "contributions": [ - "translation" - ] - }, - { - "login": "EthanArmbrust", - "name": "EthanArmbrust", - "avatar_url": "https://avatars.githubusercontent.com/u/22754714?v=4", - "profile": "https://github.com/EthanArmbrust", - "contributions": [ - "code" - ] - }, - { - "login": "SirMartin", - "name": "Eduardo", - "avatar_url": "https://avatars.githubusercontent.com/u/854646?v=4", - "profile": "http://www.piribisoft.com", - "contributions": [ - "doc", - "code" - ] - }, - { - "login": "RickLuiken", - "name": "RickLuiken", - "avatar_url": "https://avatars.githubusercontent.com/u/34110371?v=4", - "profile": "https://github.com/RickLuiken", - "contributions": [ - "code" - ] - }, - { - "login": "Br33ce", - "name": "Br33ce", - "avatar_url": "https://avatars.githubusercontent.com/u/124933490?v=4", - "profile": "https://github.com/Br33ce", - "contributions": [ - "translation" - ] - }, - { - "login": "athphane", - "name": "Athfan Khaleel", - "avatar_url": "https://avatars.githubusercontent.com/u/13810742?v=4", - "profile": "https://athfan.com", - "contributions": [ - "doc", - "code" - ] - }, - { - "login": "mdll23", - "name": "Michael Dallinger", - "avatar_url": "https://avatars.githubusercontent.com/u/142844478?v=4", - "profile": "https://github.com/mdll23", - "contributions": [ - "translation" - ] - }, - { - "login": "xeruf", - "name": "Janek", - "avatar_url": "https://avatars.githubusercontent.com/u/13354331?v=4", - "profile": "https://github.com/xeruf", - "contributions": [ - "doc", - "code" - ] - }, - { - "login": "aleksasiriski", - "name": "Aleksa Siriški", - "avatar_url": "https://avatars.githubusercontent.com/u/31509435?v=4", - "profile": "https://aleksasiriski.dev", - "contributions": [ - "infra" - ] - }, - { - "login": "Danish-H", - "name": "Danish Humair", - "avatar_url": "https://avatars.githubusercontent.com/u/121830048?v=4", - "profile": "http://danishhumair.com", - "contributions": [ - "code" - ] - }, - { - "login": "trackmastersteve", - "name": "Stephen Harris", - "avatar_url": "https://avatars.githubusercontent.com/u/16858514?v=4", - "profile": "https://arm0.red", - "contributions": [ - "doc" - ] - }, - { - "login": "joshuaboniface", - "name": "Joshua M. Boniface", - "avatar_url": "https://avatars.githubusercontent.com/u/4031396?v=4", - "profile": "https://www.boniface.me", - "contributions": [ - "code" - ] - }, - { - "login": "gauthier-th", - "name": "Gauthier", - "avatar_url": "https://avatars.githubusercontent.com/u/37781713?v=4", - "profile": "https://gauthierth.fr/", - "contributions": [ - "code", - "maintenance" - ] - }, - { - "login": "Kara-Zor-El", - "name": "Kara", - "avatar_url": "https://avatars.githubusercontent.com/u/69772087?v=4", - "profile": "https://github.com/Kara-Zor-El", - "contributions": [ - "infra" - ] - }, - { - "login": "JoaquinOlivero", - "name": "Joaquin Olivero", - "avatar_url": "https://avatars.githubusercontent.com/u/66050823?v=4", - "profile": "https://joaquinolivero.com", - "contributions": [ - "code" - ] - }, - { - "login": "Bretterteig", - "name": "Julian Behr", - "avatar_url": "https://avatars.githubusercontent.com/u/47298401?v=4", - "profile": "https://github.com/Bretterteig", - "contributions": [ - "translation" - ] - }, - { - "login": "ThowZzy", - "name": "ThowZzy", - "avatar_url": "https://avatars.githubusercontent.com/u/61882536?v=4", - "profile": "https://github.com/ThowZzy", - "contributions": [ - "code" - ] - }, - { - "login": "mobihen", - "name": "Nir Israel Hen", - "avatar_url": "https://avatars.githubusercontent.com/u/35529491?v=4", - "profile": "https://mobihen.com", - "contributions": [ - "translation" - ] - }, - { - "login": "XDark187", - "name": "Baraa", - "avatar_url": "https://avatars.githubusercontent.com/u/39034192?v=4", - "profile": "https://github.com/XDark187", - "contributions": [ - "code" - ] - }, - { - "login": "franciscofsales", - "name": "Francisco Sales", - "avatar_url": "https://avatars.githubusercontent.com/u/7977645?v=4", - "profile": "https://github.com/franciscofsales", - "contributions": [ - "code" - ] - }, - { - "login": "myselfolli", - "name": "Oliver Laing", - "avatar_url": "https://avatars.githubusercontent.com/u/37535998?v=4", - "profile": "https://github.com/myselfolli", - "contributions": [ - "code" - ] - }, - { - "login": "M0NsTeRRR", - "name": "Ludovic Ortega", - "avatar_url": "https://avatars.githubusercontent.com/u/37785089?v=4", - "profile": "https://github.com/M0NsTeRRR", - "contributions": [ - "security" - ] - }, - { - "login": "Zariel", - "name": "Chris Bannister", - "avatar_url": "https://avatars.githubusercontent.com/u/2213?v=4", - "profile": "https://github.com/Zariel", - "contributions": [ - "code" - ] - }, - { - "login": "C4J3", - "name": "Joe", - "avatar_url": "https://avatars.githubusercontent.com/u/13005453?v=4", - "profile": "https://github.com/C4J3", - "contributions": [ - "doc" - ] - }, - { - "login": "guillaumearnx", - "name": "Guillaume ARNOUX", - "avatar_url": "https://avatars.githubusercontent.com/u/37373941?v=4", - "profile": "https://me.garnx.fr", - "contributions": [ - "code" - ] - }, - { - "login": "dr-carrot", - "name": "dr-carrot", - "avatar_url": "https://avatars.githubusercontent.com/u/17272571?v=4", - "profile": "https://github.com/dr-carrot", - "contributions": [ - "code" - ] - }, - { - "login": "gageorsburn", - "name": "Gage Orsburn", - "avatar_url": "https://avatars.githubusercontent.com/u/4692734?v=4", - "profile": "https://github.com/gageorsburn", - "contributions": [ - "code" - ] - }, - { - "login": "GkhnGRBZ", - "name": "GkhnGRBZ", - "avatar_url": "https://avatars.githubusercontent.com/u/127258824?v=4", - "profile": "https://github.com/GkhnGRBZ", - "contributions": [ - "code" - ] - }, - { - "login": "benhaney", - "name": "Ben Haney", - "avatar_url": "https://avatars.githubusercontent.com/u/31331498?v=4", - "profile": "http://benhaney.com", - "contributions": [ - "code" - ] - }, - { - "login": "Wunderharke", - "name": "Wunderharke", - "avatar_url": "https://avatars.githubusercontent.com/u/5105672?v=4", - "profile": "https://github.com/Wunderharke", - "contributions": [ - "doc" - ] - }, - { - "login": "methbkts", - "name": "Metin Bektas", - "avatar_url": "https://avatars.githubusercontent.com/u/30674934?v=4", - "profile": "https://github.com/methbkts", - "contributions": [ - "infra" - ] - }, - { - "login": "andrewkolda", - "name": "andrewkolda", - "avatar_url": "https://avatars.githubusercontent.com/u/158614532?v=4", - "profile": "https://github.com/andrewkolda", - "contributions": [ - "design" - ] - }, - { - "login": "ishanjain28", - "name": "Ishan Jain", - "avatar_url": "https://avatars.githubusercontent.com/u/7921368?v=4", - "profile": "https://ishanjain.me", - "contributions": [ - "code" - ] - }, - { - "login": "michaelhthomas", - "name": "Michael Thomas", - "avatar_url": "https://avatars.githubusercontent.com/u/18223295?v=4", - "profile": "http://michaelt.xyz", - "contributions": [ - "code" - ] - }, - { - "login": "RankWeis", - "name": "RankWeis", - "avatar_url": "https://avatars.githubusercontent.com/u/733691?v=4", - "profile": "https://github.com/RankWeis", - "contributions": [ - "code" - ] - }, - { - "login": "jessielw", - "name": "Jessie Wilson", - "avatar_url": "https://avatars.githubusercontent.com/u/48299282?v=4", - "profile": "http://www.linkedin.com/in/jessielwilson", - "contributions": [ - "code" - ] - }, - { - "login": "brotaxt", - "name": "DominicKo", - "avatar_url": "https://avatars.githubusercontent.com/u/25477935?v=4", - "profile": "https://github.com/brotaxt", - "contributions": [ - "code" - ] - }, - { - "login": "corentinnormand", - "name": "Corentin Normand", - "avatar_url": "https://avatars.githubusercontent.com/u/30508927?v=4", - "profile": "https://doctolib.com", - "contributions": [ - "code" - ] - }, - { - "login": "benbeauchamp7", - "name": "Ben Beauchamp", - "avatar_url": "https://avatars.githubusercontent.com/u/43358492?v=4", - "profile": "https://github.com/benbeauchamp7", - "contributions": [ - "code" - ] - }, - { - "login": "vfaergestad", - "name": "vfaergestad", - "avatar_url": "https://avatars.githubusercontent.com/u/49147564?v=4", - "profile": "https://github.com/vfaergestad", - "contributions": [ - "code" - ] - }, - { - "login": "wolffman122", - "name": "wolffman122", - "avatar_url": "https://avatars.githubusercontent.com/u/19178872?v=4", - "profile": "https://github.com/wolffman122", - "contributions": [ - "code" - ] - }, - { - "login": "Schrottfresser", - "name": "Schrottfresser", - "avatar_url": "https://avatars.githubusercontent.com/u/39998368?v=4", - "profile": "https://github.com/Schrottfresser", - "contributions": [ - "code" - ] - }, - { - "login": "DillionLowry", - "name": "Dillion", - "avatar_url": "https://avatars.githubusercontent.com/u/91228469?v=4", - "profile": "https://github.com/DillionLowry", - "contributions": [ - "code" - ] - }, - { - "login": "JamsRepos", - "name": "Jam", - "avatar_url": "https://avatars.githubusercontent.com/u/1347620?v=4", - "profile": "https://github.com/JamsRepos", - "contributions": [ - "code" - ] - }, - { - "login": "joelowrance", - "name": "Joe Lowrance", - "avatar_url": "https://avatars.githubusercontent.com/u/63176?v=4", - "profile": "http://www.joelowrance.com", - "contributions": [ - "code" - ] - }, - { - "login": "0xSysR3ll", - "name": "0xsysr3ll", - "avatar_url": "https://avatars.githubusercontent.com/u/31414959?v=4", - "profile": "https://github.com/0xSysR3ll", - "contributions": [ - "code" - ] - }, - { - "login": "sudo-kraken", - "name": "Joe Harrison", - "avatar_url": "https://avatars.githubusercontent.com/u/53116754?v=4", - "profile": "https://sudo-kraken.github.io/docs/", - "contributions": [ - "infra" - ] - }, - { - "login": "ale183", - "name": "ale183", - "avatar_url": "https://avatars.githubusercontent.com/u/8809439?v=4", - "profile": "https://github.com/ale183", - "contributions": [ - "code" - ] - } - ] -} diff --git a/.dockerignore b/.dockerignore index a12de07ad0..9c94daaee4 100644 --- a/.dockerignore +++ b/.dockerignore @@ -1,7 +1,6 @@ **/*.md **/.gitkeep **/.vscode -.all-contributorsrc .dockerignore .editorconfig .eslintrc.js diff --git a/.gitattributes b/.gitattributes index d9863caf69..29f7c31fe3 100644 --- a/.gitattributes +++ b/.gitattributes @@ -37,7 +37,6 @@ docs export-ignore *ignore export-ignore *.md export-ignore -.all-contributorsrc export-ignore .editorconfig export-ignore Dockerfile.local export-ignore compose.yaml export-ignore diff --git a/.github/FUNDING.yml b/.github/FUNDING.yml index e6282061ea..a1650a8c3f 100644 --- a/.github/FUNDING.yml +++ b/.github/FUNDING.yml @@ -1 +1 @@ -buy_me_a_coffee: fallen.bagel +open_collective: seerr diff --git a/README.md b/README.md index ddfffa4ddc..71ab22bc20 100644 --- a/README.md +++ b/README.md @@ -6,13 +6,10 @@ Jellyseerr CI

-Discord +Discord Docker pulls Translation status GitHub - -All Contributors - **Jellyseerr** is a free and open source software application for managing requests for your media library. It integrates with the media server of your choice: [Jellyfin](https://jellyfin.org), [Plex](https://plex.tv), and [Emby](https://emby.media/). In addition, it integrates with your existing services, such as **[Sonarr](https://sonarr.tv/)**, **[Radarr](https://radarr.video/)**. @@ -74,262 +71,8 @@ You can help improve Jellyseerr too! Check out our [Contribution Guide](./CONTRI ## Contributors ✨ -Thanks goes to these wonderful people from Overseerr ([emoji key](https://allcontributors.org/docs/en/emoji-key)) and all those that contributed directly to Jellyseerr: +[![contributors](https://opencollective.com/seerr/contributors.svg?width=890)](https://opencollective.com/seerr/#backers) -### Jellyseerr Contributors ✨ +[![backers](https://opencollective.com/seerr/backers.svg?width=890)](https://opencollective.com/seerr/#backers) - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
Fallenbagel
Fallenbagel

💻 🚧
Sean
Sean

🌍 💻
notfakie
notfakie

💻
Mohamed Jumail
Mohamed Jumail

👀
Shilong Jiang
Shilong Jiang

💻
Boring Dragon
Boring Dragon

💻
Samuel Bartík
Samuel Bartík

💻
Thegan Govender
Thegan Govender

💻
jab416171
jab416171

📖 💻
Nicolai Van der Storm
Nicolai Van der Storm

💻
Smexhy
Smexhy

🌍
dd060606
dd060606

💻
Daniel
Daniel

💻
undone37
undone37

🌍
Chechu García
Chechu García

🌍
Dimitri
Dimitri

🌍
andrey4korop
andrey4korop

💻 🌍
Geoffrey Coulaud
Geoffrey Coulaud

🌍
Pikachu920
Pikachu920

💻
Maxim Yalagin
Maxim Yalagin

💻
Jesse Boswell
Jesse Boswell

💻
d-fendrich
d-fendrich

🌍
David Fernández Alcoba
David Fernández Alcoba

💻
Gauvino
Gauvino

🌍
EthanArmbrust
EthanArmbrust

💻
Eduardo
Eduardo

📖 💻
RickLuiken
RickLuiken

💻
Br33ce
Br33ce

🌍
Athfan Khaleel
Athfan Khaleel

📖 💻
Michael Dallinger
Michael Dallinger

🌍
Janek
Janek

📖 💻
Aleksa Siriški
Aleksa Siriški

🚇
Danish Humair
Danish Humair

💻
Stephen Harris
Stephen Harris

📖
Joshua M. Boniface
Joshua M. Boniface

💻
Gauthier
Gauthier

💻 🚧
Kara
Kara

🚇
Joaquin Olivero
Joaquin Olivero

💻
Julian Behr
Julian Behr

🌍
ThowZzy
ThowZzy

💻
Nir Israel Hen
Nir Israel Hen

🌍
Baraa
Baraa

💻
Francisco Sales
Francisco Sales

💻
Oliver Laing
Oliver Laing

💻
Ludovic Ortega
Ludovic Ortega

🛡️
Chris Bannister
Chris Bannister

💻
Joe
Joe

📖
Guillaume ARNOUX
Guillaume ARNOUX

💻
dr-carrot
dr-carrot

💻
Gage Orsburn
Gage Orsburn

💻
GkhnGRBZ
GkhnGRBZ

💻
Ben Haney
Ben Haney

💻
Wunderharke
Wunderharke

📖
Metin Bektas
Metin Bektas

🚇
andrewkolda
andrewkolda

🎨
Ishan Jain
Ishan Jain

💻
Michael Thomas
Michael Thomas

💻
RankWeis
RankWeis

💻
Jessie Wilson
Jessie Wilson

💻
DominicKo
DominicKo

💻
Corentin Normand
Corentin Normand

💻
Ben Beauchamp
Ben Beauchamp

💻
vfaergestad
vfaergestad

💻
wolffman122
wolffman122

💻
Schrottfresser
Schrottfresser

💻
Dillion
Dillion

💻
Jam
Jam

💻
Joe Lowrance
Joe Lowrance

💻
0xsysr3ll
0xsysr3ll

💻
Joe Harrison
Joe Harrison

🚇
ale183
ale183

💻
- - - - - - -### Overseerr Contributors ✨ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
sct
sct

💻 🎨 🤔
Alex Zoitos
Alex Zoitos

💻
Brandon Cohen
Brandon Cohen

💻 📖
Ahreluth
Ahreluth

🌍
KovalevArtem
KovalevArtem

🌍
GiyomuWeb
GiyomuWeb

🌍
Angry Cuban
Angry Cuban

📖
jvennik
jvennik

🌍
darknessgp
darknessgp

💻
salty
salty

🚇
Shutruk
Shutruk

🌍
Krystian Charubin
Krystian Charubin

🎨
Kieron Boswell
Kieron Boswell

💻
samwiseg0
samwiseg0

💬 🚇
ecelebi29
ecelebi29

💻 📖
Mārtiņš Možeiko
Mārtiņš Možeiko

💻
mazzetta86
mazzetta86

🌍
Paul Hagedorn
Paul Hagedorn

🌍
Shagon94
Shagon94

🌍
sebstrgg
sebstrgg

🌍
Danshil Mungur
Danshil Mungur

💻 📖
doob187
doob187

🚇
johnpyp
johnpyp

💻
Jakob Ankarhem
Jakob Ankarhem

📖 💻 🌍
Jayesh
Jayesh

💻
flying-sausages
flying-sausages

📖
hirenshah
hirenshah

📖
TheCatLady
TheCatLady

💻 🌍 📖
Chris Pritchard
Chris Pritchard

💻 📖
Tamberlox
Tamberlox

🌍
David
David

💻
Douglas Parker
Douglas Parker

📖
Daniel Carter
Daniel Carter

💻
nuro
nuro

📖
ᗪєνιη ᗷυнʟ
ᗪєνιη ᗷυнʟ

🚇
JonnyWong16
JonnyWong16

📖
Roxedus
Roxedus

📖
WoisWoi
WoisWoi

🌍
HubDuck
HubDuck

🌍 📖
costaht
costaht

📖 🌍
Shjosan
Shjosan

🌍
kobaubarr
kobaubarr

🌍
Ricardo González
Ricardo González

🌍
Torkil
Torkil

🌍
Jagandeep Brar
Jagandeep Brar

📖
dtalens
dtalens

🌍
Alex Cortelyou
Alex Cortelyou

💻
Jono Cairns
Jono Cairns

💻
DJScias
DJScias

🌍
Dabu-dot
Dabu-dot

🌍
Jabster28
Jabster28

💻
littlerooster
littlerooster

🌍
Dustin Hildebrandt
Dustin Hildebrandt

💻
Bruno Guerreiro
Bruno Guerreiro

🌍
Alexander Neuhäuser
Alexander Neuhäuser

🌍
Livio
Livio

🎨
tangentThought
tangentThought

💻
Nicolás Espinoza
Nicolás Espinoza

💻
sootylunatic
sootylunatic

🌍
JoKerIsCraZy
JoKerIsCraZy

🌍
Daddie0
Daddie0

🌍
Simone
Simone

🌍
Seohyun Joo
Seohyun Joo

🌍
Sergey
Sergey

🌍
Shaaft
Shaaft

🌍
sr093906
sr093906

🌍
Nackophilz
Nackophilz

🌍
Sean Chambers
Sean Chambers

💻
deniscerri
deniscerri

🌍
tomgacz
tomgacz

🌍
Andersborrits
Andersborrits

🌍
Maxent
Maxent

🌍
Samuel Bartík
Samuel Bartík

💻
Chun Yeung Wong
Chun Yeung Wong

💻
TheMeanCanEHdian
TheMeanCanEHdian

💻
Gylesie
Gylesie

💻
Fhd-pro
Fhd-pro

🌍
PovilasID
PovilasID

🌍
byakurau
byakurau

🌍
miknii
miknii

🌍
Mackenzie
Mackenzie

💻
soup
soup

📖 💻
ceptonit
ceptonit

📖
aedelbro
aedelbro

💻
Pedro Nascimento
Pedro Nascimento

💻
Owen Voke
Owen Voke

💻
Sebastian K
Sebastian K

💻
jariz
jariz

💻
Alex
Alex

💻
Zeb Muller
Zeb Muller

💻
Shane Friedman
Shane Friedman

💻
Izaac Brånn
Izaac Brånn

💻
Salman Tariq
Salman Tariq

💻
Andrew Kennedy
Andrew Kennedy

💻
Fallenbagel
Fallenbagel

💻
Anton K. (ai Doge)
Anton K. (ai Doge)

💻
Marco Faggian
Marco Faggian

💻
Eric Nemchik
Eric Nemchik

💻
RemiRigal
RemiRigal

💻
Joseph Risk
Joseph Risk

💻
Loetwiek
Loetwiek

💻
Fuochi
Fuochi

📖
David Emrich
David Emrich

💻
Max T. Kristiansen
Max T. Kristiansen

💻
Damien Fajole
Damien Fajole

💻
Ahmed Siddiqui
Ahmed Siddiqui

💻
JackOXI
JackOXI

💻
Stancu Florin
Stancu Florin

💻
Lukas Miklosko
Lukas Miklosko

💻
Gauthier
Gauthier

💻
vfaergestad
vfaergestad

💻
+[![sponsors](https://opencollective.com/seerr/sponsors.svg?width=890)](https://opencollective.com/seerr/#sponsors) From a3196fd3a3c97ad8d16b54ee6a57576025acd32f Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 6 Oct 2025 20:27:57 +0100 Subject: [PATCH 51/96] ci: fix seerr reference in workflow run (#1979) --- .github/workflows/trivy-scan.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml index d38021e947..5832f7310a 100644 --- a/.github/workflows/trivy-scan.yml +++ b/.github/workflows/trivy-scan.yml @@ -5,7 +5,7 @@ name: Trivy Container Vulnerability Scan on: workflow_run: workflows: - - Jellyseerr Release + - Seerr Release types: - completed schedule: From 00b2e97f8d7a50d6b68c66158c7aa8e229aec1ec Mon Sep 17 00:00:00 2001 From: TheCatLady <52870424+TheCatLady@users.noreply.github.com> Date: Mon, 6 Oct 2025 12:32:38 -0700 Subject: [PATCH 52/96] chore: update Discord URL (#1980) [skip ci] --- .github/ISSUE_TEMPLATE/config.yml | 2 +- .github/workflows/support.yml | 2 +- CONTRIBUTING.md | 2 +- README.md | 4 ++-- gen-docs/docusaurus.config.ts | 2 +- src/components/Settings/SettingsAbout/index.tsx | 4 ++-- 6 files changed, 8 insertions(+), 8 deletions(-) diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml index 3cce2bb41e..34d243051e 100644 --- a/.github/ISSUE_TEMPLATE/config.yml +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -1,7 +1,7 @@ blank_issues_enabled: false contact_links: - name: 💬 Support via Discord - url: https://discord.gg/ckbvBtDJgC + url: https://discord.gg/seerr about: Chat with other users and the Jellyseerr dev team - name: 💬 Support via GitHub Discussions url: https://github.com/fallenbagel/jellyseerr/discussions diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index 977d576c5a..c360f0fb61 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -35,7 +35,7 @@ jobs: to be a support request. Please use our support channels to get help with Jellyseerr. - - [Discord](https://discord.gg/ckbvBtDJgC) + - [Discord](https://discord.gg/seerr) run: | retry() { n=0; until "$@"; do n=$((n+1)); [ $n -ge 3 ] && break; echo "retry $n: $*" >&2; sleep 2; done; } retry gh issue comment "$NUMBER" -R "$GH_REPO" -b "$BODY" || true diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 12f07c6de3..a9a4ec4b38 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -130,7 +130,7 @@ Steps: - You can create a "draft" pull request early to get feedback on your work. - Your code **must** be formatted correctly, or the tests will fail. - We use Prettier to format our code base. It should automatically run with a Git hook, but it is recommended to have the Prettier extension installed in your editor and format on save. -- If you have questions or need help, you can reach out via [Discussions](/../../discussions) or our [Discord server](https://discord.gg/ckbvBtDJgC). +- If you have questions or need help, you can reach out via [Discussions](/../../discussions) or our [Discord server](https://discord.gg/seerr). - Only open pull requests to `develop`, never `master`! Any pull requests opened to `master` will be closed. ### UI Text Style diff --git a/README.md b/README.md index 71ab22bc20..11276eb94c 100644 --- a/README.md +++ b/README.md @@ -49,7 +49,7 @@ Nix: [Nixpkg](https://search.nixos.org/packages?channel=unstable&show=jellyseerr ## Support - Check out the [Jellyseerr Documentation](https://docs.jellyseerr.dev) before asking for help. Your question might already be in the docs! -- You can get support on [Discord](https://discord.gg/ckbvBtDJgC). +- You can get support on [Discord](https://discord.gg/seerr). - You can ask questions in the Help category of our [GitHub Discussions](/../../discussions). - Bug reports and feature requests can be submitted via [GitHub Issues](/../../issues). @@ -61,7 +61,7 @@ You can access the API documentation from your local Jellyseerr install at http: You can ask questions, share ideas, and more in [GitHub Discussions](/../../discussions). -If you would like to chat with other members of our growing community, [join the Jellyseerr Discord server](https://discord.gg/ckbvBtDJgC)! +If you would like to chat with other members of our growing community, [join the Jellyseerr Discord server](https://discord.gg/seerr)! Our [Code of Conduct](./CODE_OF_CONDUCT.md) applies to all Jellyseerr community channels. diff --git a/gen-docs/docusaurus.config.ts b/gen-docs/docusaurus.config.ts index db5be48407..08a1fe1458 100644 --- a/gen-docs/docusaurus.config.ts +++ b/gen-docs/docusaurus.config.ts @@ -110,7 +110,7 @@ const config: Config = { items: [ { label: 'Discord', - href: 'https://discord.gg/ckbvBtDJgC', + href: 'https://discord.gg/seerr', }, { label: 'Github Discussions', diff --git a/src/components/Settings/SettingsAbout/index.tsx b/src/components/Settings/SettingsAbout/index.tsx index 7b23cb6b40..e6305b9636 100644 --- a/src/components/Settings/SettingsAbout/index.tsx +++ b/src/components/Settings/SettingsAbout/index.tsx @@ -179,12 +179,12 @@ const SettingsAbout = () => { - https://discord.gg/ckbvBtDJgC + https://discord.gg/seerr From 1a503e9fa4b83060e9961d5098433aa0c98ccfa8 Mon Sep 17 00:00:00 2001 From: Ryan Cohen Date: Mon, 6 Oct 2025 14:11:13 -0600 Subject: [PATCH 53/96] ci: update cypress project id (#1981) [skip ci] * ci: update cypress project id * try without cache * add install command * install cypress dep manually * use enable pre-post-scripts instead of manually installing * revert back to manual install * move cypress binary install after cache --- .github/workflows/cypress.yml | 18 +++++++++--------- cypress.config.ts | 2 +- 2 files changed, 10 insertions(+), 10 deletions(-) diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index 0baa1fa3c0..4d3e1cfe3b 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -39,6 +39,9 @@ jobs: - name: Pnpm Setup uses: pnpm/action-setup@v4 + - name: Install dependencies + run: pnpm install --frozen-lockfile + - name: Setup cypress cache uses: actions/cache@v4 with: @@ -47,9 +50,15 @@ jobs: restore-keys: | ${{ runner.os }}-cypress-store- + - name: Install Cypress binary + env: + CYPRESS_CACHE_FOLDER: ~/.cache/Cypress + run: pnpm exec cypress install + - name: Cypress run uses: cypress-io/github-action@v6 with: + install: false build: pnpm cypress:build start: pnpm start wait-on: 'http://localhost:5055' @@ -61,12 +70,3 @@ jobs: # Fix test titles in cypress dashboard COMMIT_INFO_MESSAGE: ${{github.event.pull_request.title}} COMMIT_INFO_SHA: ${{github.event.pull_request.head.sha}} - - - name: Upload video files - if: always() - uses: actions/upload-artifact@v4 - with: - name: cypress-videos - path: | - cypress/videos - cypress/screenshots diff --git a/cypress.config.ts b/cypress.config.ts index 793a207f09..0fa88d2f9a 100644 --- a/cypress.config.ts +++ b/cypress.config.ts @@ -1,7 +1,7 @@ import { defineConfig } from 'cypress'; export default defineConfig({ - projectId: 'xkm1b4', + projectId: 'onnqy3', e2e: { baseUrl: 'http://localhost:5055', video: true, From de1033575f0421bcfb12248060f44da7ee7417bb Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Tue, 7 Oct 2025 01:02:24 +0300 Subject: [PATCH 54/96] chore: migrate helm-chart to the new org (#1985) Signed-off-by: Ludovic Ortega --- charts/jellyseerr-chart/Chart.yaml | 13 ---------- charts/jellyseerr-chart/artifacthub-repo.yml | 1 - .../templates/tests/test-connection.yaml | 15 ----------- .../.helmignore | 0 charts/seerr-chart/Chart.yaml | 14 ++++++++++ .../README.md | 22 +++++++++------- .../README.md.gotmpl | 6 ++++- charts/seerr-chart/artifacthub-repo.yml | 1 + .../templates/NOTES.txt | 0 .../templates/_helpers.tpl | 26 +++++++++---------- .../templates/ingress.yaml | 6 ++--- .../templates/persistentvolumeclaim.yaml | 6 ++--- .../templates/service.yaml | 6 ++--- .../templates/serviceaccount.yaml | 4 +-- .../templates/statefulset.yaml | 14 +++++----- .../templates/tests/test-connection.yaml | 15 +++++++++++ .../values.yaml | 20 +++++++------- 17 files changed, 89 insertions(+), 80 deletions(-) delete mode 100644 charts/jellyseerr-chart/Chart.yaml delete mode 100644 charts/jellyseerr-chart/artifacthub-repo.yml delete mode 100644 charts/jellyseerr-chart/templates/tests/test-connection.yaml rename charts/{jellyseerr-chart => seerr-chart}/.helmignore (100%) create mode 100644 charts/seerr-chart/Chart.yaml rename charts/{jellyseerr-chart => seerr-chart}/README.md (83%) rename charts/{jellyseerr-chart => seerr-chart}/README.md.gotmpl (72%) create mode 100644 charts/seerr-chart/artifacthub-repo.yml rename charts/{jellyseerr-chart => seerr-chart}/templates/NOTES.txt (100%) rename charts/{jellyseerr-chart => seerr-chart}/templates/_helpers.tpl (70%) rename charts/{jellyseerr-chart => seerr-chart}/templates/ingress.yaml (85%) rename charts/{jellyseerr-chart => seerr-chart}/templates/persistentvolumeclaim.yaml (77%) rename charts/{jellyseerr-chart => seerr-chart}/templates/service.yaml (60%) rename charts/{jellyseerr-chart => seerr-chart}/templates/serviceaccount.yaml (72%) rename charts/{jellyseerr-chart => seerr-chart}/templates/statefulset.yaml (91%) create mode 100644 charts/seerr-chart/templates/tests/test-connection.yaml rename charts/{jellyseerr-chart => seerr-chart}/values.yaml (93%) diff --git a/charts/jellyseerr-chart/Chart.yaml b/charts/jellyseerr-chart/Chart.yaml deleted file mode 100644 index 6d3db70ee2..0000000000 --- a/charts/jellyseerr-chart/Chart.yaml +++ /dev/null @@ -1,13 +0,0 @@ -apiVersion: v2 -kubeVersion: '>=1.23.0-0' -name: jellyseerr-chart -description: Jellyseerr helm chart for Kubernetes -type: application -version: 2.7.0 -appVersion: '2.7.3' -maintainers: - - name: Jellyseerr - url: https://github.com/fallenbagel/jellyseerr -sources: - - https://github.com/fallenbagel/jellyseerr/tree/main/charts/jellyseerr -home: https://github.com/fallenbagel/jellyseerr diff --git a/charts/jellyseerr-chart/artifacthub-repo.yml b/charts/jellyseerr-chart/artifacthub-repo.yml deleted file mode 100644 index 849fcf8d97..0000000000 --- a/charts/jellyseerr-chart/artifacthub-repo.yml +++ /dev/null @@ -1 +0,0 @@ -repositoryID: c6b3f2dc-444c-4e37-b397-6a5ff563ee8b diff --git a/charts/jellyseerr-chart/templates/tests/test-connection.yaml b/charts/jellyseerr-chart/templates/tests/test-connection.yaml deleted file mode 100644 index 6adc5d3088..0000000000 --- a/charts/jellyseerr-chart/templates/tests/test-connection.yaml +++ /dev/null @@ -1,15 +0,0 @@ -apiVersion: v1 -kind: Pod -metadata: - name: "{{ include "jellyseerr.fullname" . }}-test-connection" - labels: - {{- include "jellyseerr.labels" . | nindent 4 }} - annotations: - "helm.sh/hook": test -spec: - containers: - - name: wget - image: busybox - command: ['wget'] - args: ['{{ include "jellyseerr.fullname" . }}:{{ .Values.service.port }}'] - restartPolicy: Never diff --git a/charts/jellyseerr-chart/.helmignore b/charts/seerr-chart/.helmignore similarity index 100% rename from charts/jellyseerr-chart/.helmignore rename to charts/seerr-chart/.helmignore diff --git a/charts/seerr-chart/Chart.yaml b/charts/seerr-chart/Chart.yaml new file mode 100644 index 0000000000..15d9f3cfb8 --- /dev/null +++ b/charts/seerr-chart/Chart.yaml @@ -0,0 +1,14 @@ +apiVersion: v2 +kubeVersion: '>=1.23.0-0' +name: seerr-chart +description: Seerr helm chart for Kubernetes +type: application +version: 3.0.0 +# renovate: image=ghcr.io/fallenbagel/jellyseerr +appVersion: '2.7.3' +maintainers: + - name: Seerr Team + url: https://github.com/orgs/seerr-team/people +sources: + - https://github.com/seerr-team/seerr/tree/main/charts/seerr +home: https://github.com/seerr-team/seerr diff --git a/charts/jellyseerr-chart/README.md b/charts/seerr-chart/README.md similarity index 83% rename from charts/jellyseerr-chart/README.md rename to charts/seerr-chart/README.md index 4f656c1716..318f90b3c8 100644 --- a/charts/jellyseerr-chart/README.md +++ b/charts/seerr-chart/README.md @@ -1,20 +1,20 @@ -# jellyseerr-chart +# seerr-chart -![Version: 2.7.0](https://img.shields.io/badge/Version-2.7.0-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 2.7.3](https://img.shields.io/badge/AppVersion-2.7.3-informational?style=flat-square) +![Version: 3.0.0](https://img.shields.io/badge/Version-3.0.0-informational?style=flat-square) ![Type: application](https://img.shields.io/badge/Type-application-informational?style=flat-square) ![AppVersion: 2.7.3](https://img.shields.io/badge/AppVersion-2.7.3-informational?style=flat-square) -Jellyseerr helm chart for Kubernetes +Seerr helm chart for Kubernetes -**Homepage:** +**Homepage:** ## Maintainers | Name | Email | Url | | ---- | ------ | --- | -| Jellyseerr | | | +| Seerr Team | | | ## Source Code -* +* ## Requirements @@ -22,9 +22,13 @@ Kubernetes: `>=1.23.0-0` ## Update Notes +### Updating to 3.0.0 + +Nothing has changed; we just rebranded the `jellyseerr` Helm chart to `seerr` 🥳. + ### Updating to 2.7.0 -Jellyseerr is a stateful application and it is not designed to have multiple replicas. In version 2.7.0 we address this by: +Seerr is a stateful application and it is not designed to have multiple replicas. In version 2.7.0 we address this by: - replacing `Deployment` with `StatefulSet` - removing `replicaCount` value @@ -42,8 +46,8 @@ If `replicaCount` value was used - remove it. Helm update should work fine after | config.persistence.name | string | `""` | Config name | | config.persistence.size | string | `"5Gi"` | Size of persistent disk | | config.persistence.volumeName | string | `""` | Name of the permanent volume to reference in the claim. Can be used to bind to existing volumes. | -| extraEnv | list | `[]` | Environment variables to add to the jellyseerr pods | -| extraEnvFrom | list | `[]` | Environment variables from secrets or configmaps to add to the jellyseerr pods | +| extraEnv | list | `[]` | Environment variables to add to the seerr pods | +| extraEnvFrom | list | `[]` | Environment variables from secrets or configmaps to add to the seerr pods | | fullnameOverride | string | `""` | | | image.pullPolicy | string | `"IfNotPresent"` | | | image.registry | string | `"ghcr.io"` | | diff --git a/charts/jellyseerr-chart/README.md.gotmpl b/charts/seerr-chart/README.md.gotmpl similarity index 72% rename from charts/jellyseerr-chart/README.md.gotmpl rename to charts/seerr-chart/README.md.gotmpl index a057a11bd0..cdf6937404 100644 --- a/charts/jellyseerr-chart/README.md.gotmpl +++ b/charts/seerr-chart/README.md.gotmpl @@ -16,9 +16,13 @@ ## Update Notes +### Updating to 3.0.0 + +Nothing change we just rebranded `jellyseerr` helm-chart to `seerr` :) + ### Updating to 2.7.0 -Jellyseerr is a stateful application and it is not designed to have multiple replicas. In version 2.7.0 we address this by: +Seerr is a stateful application and it is not designed to have multiple replicas. In version 2.7.0 we address this by: - replacing `Deployment` with `StatefulSet` - removing `replicaCount` value diff --git a/charts/seerr-chart/artifacthub-repo.yml b/charts/seerr-chart/artifacthub-repo.yml new file mode 100644 index 0000000000..525cf1f220 --- /dev/null +++ b/charts/seerr-chart/artifacthub-repo.yml @@ -0,0 +1 @@ +repositoryID: 249547ec-2a30-48de-a5bc-07bfd5aa2e8f diff --git a/charts/jellyseerr-chart/templates/NOTES.txt b/charts/seerr-chart/templates/NOTES.txt similarity index 100% rename from charts/jellyseerr-chart/templates/NOTES.txt rename to charts/seerr-chart/templates/NOTES.txt diff --git a/charts/jellyseerr-chart/templates/_helpers.tpl b/charts/seerr-chart/templates/_helpers.tpl similarity index 70% rename from charts/jellyseerr-chart/templates/_helpers.tpl rename to charts/seerr-chart/templates/_helpers.tpl index bb4b4ef6e7..3f93f05b87 100644 --- a/charts/jellyseerr-chart/templates/_helpers.tpl +++ b/charts/seerr-chart/templates/_helpers.tpl @@ -1,7 +1,7 @@ {{/* Expand the name of the chart. */}} -{{- define "jellyseerr.name" -}} +{{- define "seerr.name" -}} {{- default .Chart.Name .Values.nameOverride | trunc 63 | trimSuffix "-" }} {{- end }} @@ -10,7 +10,7 @@ Create a default fully qualified app name. We truncate at 63 chars because some Kubernetes name fields are limited to this (by the DNS naming spec). If release name contains chart name it will be used as a full name. */}} -{{- define "jellyseerr.fullname" -}} +{{- define "seerr.fullname" -}} {{- if .Values.fullnameOverride }} {{- .Values.fullnameOverride | trunc 63 | trimSuffix "-" }} {{- else }} @@ -26,16 +26,16 @@ If release name contains chart name it will be used as a full name. {{/* Create chart name and version as used by the chart label. */}} -{{- define "jellyseerr.chart" -}} +{{- define "seerr.chart" -}} {{- printf "%s-%s" .Chart.Name .Chart.Version | replace "+" "_" | trunc 63 | trimSuffix "-" }} {{- end }} {{/* Common labels */}} -{{- define "jellyseerr.labels" -}} -helm.sh/chart: {{ include "jellyseerr.chart" . }} -{{ include "jellyseerr.selectorLabels" . }} +{{- define "seerr.labels" -}} +helm.sh/chart: {{ include "seerr.chart" . }} +{{ include "seerr.selectorLabels" . }} {{- if .Chart.AppVersion }} app.kubernetes.io/version: {{ .Chart.AppVersion | quote }} {{- end }} @@ -46,17 +46,17 @@ app.kubernetes.io/managed-by: {{ .Release.Service }} {{/* Selector labels */}} -{{- define "jellyseerr.selectorLabels" -}} -app.kubernetes.io/name: {{ include "jellyseerr.name" . }} +{{- define "seerr.selectorLabels" -}} +app.kubernetes.io/name: {{ include "seerr.name" . }} app.kubernetes.io/instance: {{ .Release.Name }} {{- end }} {{/* Create the name of the service account to use */}} -{{- define "jellyseerr.serviceAccountName" -}} +{{- define "seerr.serviceAccountName" -}} {{- if .Values.serviceAccount.create }} -{{- default (include "jellyseerr.fullname" .) .Values.serviceAccount.name }} +{{- default (include "seerr.fullname" .) .Values.serviceAccount.name }} {{- else }} {{- default "default" .Values.serviceAccount.name }} {{- end }} @@ -65,6 +65,6 @@ Create the name of the service account to use {{/* Create the name of the pvc config to use */}} -{{- define "jellyseerr.configPersistenceName" -}} -{{- default (printf "%s-config" (include "jellyseerr.fullname" .)) .Values.config.persistence.name }} -{{- end }} \ No newline at end of file +{{- define "seerr.configPersistenceName" -}} +{{- default (printf "%s-config" (include "seerr.fullname" .)) .Values.config.persistence.name }} +{{- end }} diff --git a/charts/jellyseerr-chart/templates/ingress.yaml b/charts/seerr-chart/templates/ingress.yaml similarity index 85% rename from charts/jellyseerr-chart/templates/ingress.yaml rename to charts/seerr-chart/templates/ingress.yaml index 85f1125a04..e4ee1b8a00 100644 --- a/charts/jellyseerr-chart/templates/ingress.yaml +++ b/charts/seerr-chart/templates/ingress.yaml @@ -2,9 +2,9 @@ apiVersion: networking.k8s.io/v1 kind: Ingress metadata: - name: {{ include "jellyseerr.fullname" . }} + name: {{ include "seerr.fullname" . }} labels: - {{- include "jellyseerr.labels" . | nindent 4 }} + {{- include "seerr.labels" . | nindent 4 }} {{- with .Values.ingress.annotations }} annotations: {{- toYaml . | nindent 4 }} @@ -33,7 +33,7 @@ spec: pathType: {{ .pathType }} backend: service: - name: {{ include "jellyseerr.fullname" $ }} + name: {{ include "seerr.fullname" $ }} port: number: {{ $.Values.service.port }} {{- end }} diff --git a/charts/jellyseerr-chart/templates/persistentvolumeclaim.yaml b/charts/seerr-chart/templates/persistentvolumeclaim.yaml similarity index 77% rename from charts/jellyseerr-chart/templates/persistentvolumeclaim.yaml rename to charts/seerr-chart/templates/persistentvolumeclaim.yaml index a9363ee007..530419d8a8 100644 --- a/charts/jellyseerr-chart/templates/persistentvolumeclaim.yaml +++ b/charts/seerr-chart/templates/persistentvolumeclaim.yaml @@ -1,9 +1,9 @@ apiVersion: v1 kind: PersistentVolumeClaim metadata: - name: {{ include "jellyseerr.configPersistenceName" . }} + name: {{ include "seerr.configPersistenceName" . }} labels: - {{- include "jellyseerr.labels" . | nindent 4 }} + {{- include "seerr.labels" . | nindent 4 }} {{- with .Values.config.persistence.annotations }} annotations: {{- toYaml . | nindent 4 }} @@ -21,4 +21,4 @@ spec: {{- end }} resources: requests: - storage: "{{ .Values.config.persistence.size }}" \ No newline at end of file + storage: "{{ .Values.config.persistence.size }}" diff --git a/charts/jellyseerr-chart/templates/service.yaml b/charts/seerr-chart/templates/service.yaml similarity index 60% rename from charts/jellyseerr-chart/templates/service.yaml rename to charts/seerr-chart/templates/service.yaml index 5c915e3b49..75e286b632 100644 --- a/charts/jellyseerr-chart/templates/service.yaml +++ b/charts/seerr-chart/templates/service.yaml @@ -1,9 +1,9 @@ apiVersion: v1 kind: Service metadata: - name: {{ include "jellyseerr.fullname" . }} + name: {{ include "seerr.fullname" . }} labels: - {{- include "jellyseerr.labels" . | nindent 4 }} + {{- include "seerr.labels" . | nindent 4 }} spec: type: {{ .Values.service.type }} ports: @@ -12,5 +12,5 @@ spec: protocol: TCP name: http selector: - {{- include "jellyseerr.selectorLabels" . | nindent 4 }} + {{- include "seerr.selectorLabels" . | nindent 4 }} ipFamilyPolicy: PreferDualStack diff --git a/charts/jellyseerr-chart/templates/serviceaccount.yaml b/charts/seerr-chart/templates/serviceaccount.yaml similarity index 72% rename from charts/jellyseerr-chart/templates/serviceaccount.yaml rename to charts/seerr-chart/templates/serviceaccount.yaml index 6a2dcfd0ac..1f0e4c2726 100644 --- a/charts/jellyseerr-chart/templates/serviceaccount.yaml +++ b/charts/seerr-chart/templates/serviceaccount.yaml @@ -2,9 +2,9 @@ apiVersion: v1 kind: ServiceAccount metadata: - name: {{ include "jellyseerr.serviceAccountName" . }} + name: {{ include "seerr.serviceAccountName" . }} labels: - {{- include "jellyseerr.labels" . | nindent 4 }} + {{- include "seerr.labels" . | nindent 4 }} {{- with .Values.serviceAccount.annotations }} annotations: {{- toYaml . | nindent 4 }} diff --git a/charts/jellyseerr-chart/templates/statefulset.yaml b/charts/seerr-chart/templates/statefulset.yaml similarity index 91% rename from charts/jellyseerr-chart/templates/statefulset.yaml rename to charts/seerr-chart/templates/statefulset.yaml index ecdd9fce73..d088553a39 100644 --- a/charts/jellyseerr-chart/templates/statefulset.yaml +++ b/charts/seerr-chart/templates/statefulset.yaml @@ -1,14 +1,14 @@ apiVersion: apps/v1 kind: StatefulSet metadata: - name: {{ include "jellyseerr.fullname" . }} + name: {{ include "seerr.fullname" . }} labels: - {{- include "jellyseerr.labels" . | nindent 4 }} + {{- include "seerr.labels" . | nindent 4 }} spec: - serviceName: {{ include "jellyseerr.fullname" . }} + serviceName: {{ include "seerr.fullname" . }} selector: matchLabels: - {{- include "jellyseerr.selectorLabels" . | nindent 6 }} + {{- include "seerr.selectorLabels" . | nindent 6 }} template: metadata: {{- with .Values.podAnnotations }} @@ -16,7 +16,7 @@ spec: {{- toYaml . | nindent 8 }} {{- end }} labels: - {{- include "jellyseerr.labels" . | nindent 8 }} + {{- include "seerr.labels" . | nindent 8 }} {{- with .Values.podLabels }} {{- toYaml . | nindent 8 }} {{- end }} @@ -25,7 +25,7 @@ spec: imagePullSecrets: {{- toYaml . | nindent 8 }} {{- end }} - serviceAccountName: {{ include "jellyseerr.serviceAccountName" . }} + serviceAccountName: {{ include "seerr.serviceAccountName" . }} securityContext: {{- toYaml .Values.podSecurityContext | nindent 8 }} containers: @@ -103,7 +103,7 @@ spec: volumes: - name: config persistentVolumeClaim: - claimName: {{ include "jellyseerr.configPersistenceName" . }} + claimName: {{ include "seerr.configPersistenceName" . }} {{- with .Values.volumes }} {{- toYaml . | nindent 8 }} {{- end }} diff --git a/charts/seerr-chart/templates/tests/test-connection.yaml b/charts/seerr-chart/templates/tests/test-connection.yaml new file mode 100644 index 0000000000..dd52065a6d --- /dev/null +++ b/charts/seerr-chart/templates/tests/test-connection.yaml @@ -0,0 +1,15 @@ +apiVersion: v1 +kind: Pod +metadata: + name: "{{ include "seerr.fullname" . }}-test-connection" + labels: + {{- include "seerr.labels" . | nindent 4 }} + annotations: + "helm.sh/hook": test +spec: + containers: + - name: wget + image: busybox + command: ['wget'] + args: ['{{ include "seerr.fullname" . }}:{{ .Values.service.port }}'] + restartPolicy: Never diff --git a/charts/jellyseerr-chart/values.yaml b/charts/seerr-chart/values.yaml similarity index 93% rename from charts/jellyseerr-chart/values.yaml rename to charts/seerr-chart/values.yaml index 09aa757f27..96d1fb8bba 100644 --- a/charts/jellyseerr-chart/values.yaml +++ b/charts/seerr-chart/values.yaml @@ -3,12 +3,12 @@ image: repository: fallenbagel/jellyseerr pullPolicy: IfNotPresent # -- Overrides the image tag whose default is the chart appVersion. - tag: "" - sha: "" + tag: '' + sha: '' imagePullSecrets: [] -nameOverride: "" -fullnameOverride: "" +nameOverride: '' +fullnameOverride: '' # Liveness / Readiness / Startup Probes probes: @@ -31,9 +31,9 @@ probes: # tcpSocket: # port: http -# -- Environment variables to add to the jellyseerr pods +# -- Environment variables to add to the seerr pods extraEnv: [] -# -- Environment variables from secrets or configmaps to add to the jellyseerr pods +# -- Environment variables from secrets or configmaps to add to the seerr pods extraEnvFrom: [] serviceAccount: @@ -45,7 +45,7 @@ serviceAccount: annotations: {} # -- The name of the service account to use. # -- If not set and create is true, a name is generated using the fullname template - name: "" + name: '' podAnnotations: {} podLabels: {} @@ -76,14 +76,14 @@ config: accessModes: - ReadWriteOnce # -- Config name - name: "" + name: '' # -- Name of the permanent volume to reference in the claim. # Can be used to bind to existing volumes. - volumeName: "" + volumeName: '' ingress: enabled: false - ingressClassName: "" + ingressClassName: '' annotations: {} # kubernetes.io/ingress.class: nginx # kubernetes.io/tls-acme: "true" From e7aed5b594c05b7b0d57c2b7f7fc75605dc4e7e6 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Mon, 6 Oct 2025 23:16:25 +0100 Subject: [PATCH 55/96] ci: updated cypress paths to stop noisy runs (#1986) --- .github/workflows/cypress.yml | 22 ++++++++++++++++------ 1 file changed, 16 insertions(+), 6 deletions(-) diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index 4d3e1cfe3b..ae12d01f53 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -5,14 +5,24 @@ name: Cypress Tests on: pull_request: branches: ['*'] - paths-ignore: - - '**/*.md' - - 'docs/**' + paths: + - '{src,server,config,cypress}/**' + - 'cypress.config.ts' + - 'package.json' + - 'pnpm-lock.yaml' + - 'next.config.js' + - 'tsconfig.json' + - '.github/workflows/cypress.yml' push: branches: [develop] - paths-ignore: - - '**/*.md' - - 'docs/**' + paths: + - '{src,server,config,cypress}/**' + - 'cypress.config.ts' + - 'package.json' + - 'pnpm-lock.yaml' + - 'next.config.js' + - 'tsconfig.json' + - '.github/workflows/cypress.yml' permissions: contents: read From 2e2d2a031b174435a63d5154c503cb0df6c3efd3 Mon Sep 17 00:00:00 2001 From: TheCatLady <52870424+TheCatLady@users.noreply.github.com> Date: Mon, 6 Oct 2025 15:22:36 -0700 Subject: [PATCH 56/96] chore: rename Jellyseerr -> Seerr, part 1 (#1984) * chore: rename Jellyseerr -> Seerr, part 1 * chore: update Jellyfin bot name --- .github/ISSUE_TEMPLATE/bug.yml | 4 +- .github/ISSUE_TEMPLATE/config.yml | 4 +- .github/ISSUE_TEMPLATE/enhancement.yml | 4 +- .github/workflows/support.yml | 2 +- CONTRIBUTING.md | 18 ++++----- README.md | 22 +++++------ SECURITY.md | 5 ++- cypress/config/settings.cypress.json | 4 +- package.json | 6 +-- public/site.webmanifest | 4 +- jellyseerr-api.yml => seerr-api.yml | 16 ++++---- server/api/github.ts | 12 +++--- server/api/jellyfin.ts | 6 +-- server/api/plexapi.ts | 6 +-- server/index.ts | 4 +- server/lib/notifications/agents/slack.ts | 2 +- server/lib/settings/index.ts | 4 +- .../migrations/0002_migrate_apitokens.ts | 2 +- server/lib/settings/migrator.ts | 4 +- server/lib/watchlistsync.ts | 2 +- server/routes/auth.ts | 39 ++++++++----------- server/routes/avatarproxy.ts | 4 +- server/routes/index.ts | 6 +-- server/routes/user/index.ts | 2 +- server/routes/user/usersettings.ts | 11 ++---- 25 files changed, 93 insertions(+), 100 deletions(-) rename jellyseerr-api.yml => seerr-api.yml (99%) diff --git a/.github/ISSUE_TEMPLATE/bug.yml b/.github/ISSUE_TEMPLATE/bug.yml index 2bdb0a2593..a7caedf585 100644 --- a/.github/ISSUE_TEMPLATE/bug.yml +++ b/.github/ISSUE_TEMPLATE/bug.yml @@ -19,7 +19,7 @@ body: id: version attributes: label: Version - description: What version of Jellyseerr are you running? (You can find this in Settings → About → Version.) + description: What version of Seerr are you running? (You can find this in Settings → About → Version.) validations: required: true - type: textarea @@ -97,5 +97,5 @@ body: label: Code of Conduct description: By submitting this issue, you agree to follow our [Code of Conduct](/../../CODE_OF_CONDUCT.md) options: - - label: I agree to follow Jellyseerr's Code of Conduct + - label: I agree to follow Seerr's Code of Conduct required: true diff --git a/.github/ISSUE_TEMPLATE/config.yml b/.github/ISSUE_TEMPLATE/config.yml index 34d243051e..9719140ce6 100644 --- a/.github/ISSUE_TEMPLATE/config.yml +++ b/.github/ISSUE_TEMPLATE/config.yml @@ -2,7 +2,7 @@ blank_issues_enabled: false contact_links: - name: 💬 Support via Discord url: https://discord.gg/seerr - about: Chat with other users and the Jellyseerr dev team + about: Chat with other users and the Seerr dev team - name: 💬 Support via GitHub Discussions - url: https://github.com/fallenbagel/jellyseerr/discussions + url: https://github.com/seerr-team/seerr/discussions about: Ask questions and discuss with other community members diff --git a/.github/ISSUE_TEMPLATE/enhancement.yml b/.github/ISSUE_TEMPLATE/enhancement.yml index 4327a8f651..8e9f8fc779 100644 --- a/.github/ISSUE_TEMPLATE/enhancement.yml +++ b/.github/ISSUE_TEMPLATE/enhancement.yml @@ -31,7 +31,7 @@ body: id: terms attributes: label: Code of Conduct - description: By submitting this issue, you agree to follow our [Code of Conduct](https://github.com/fallenbagel/jellyseerr/blob/develop/CODE_OF_CONDUCT.md) + description: By submitting this issue, you agree to follow our [Code of Conduct](https://github.com/seerr-team/seerr/blob/develop/CODE_OF_CONDUCT.md) options: - - label: I agree to follow Jellyseerr's Code of Conduct + - label: I agree to follow Seerr's Code of Conduct required: true diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index c360f0fb61..8d4018d281 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -33,7 +33,7 @@ jobs: :wave: @${{ env.ISSUE_AUTHOR }}, we use the issue tracker exclusively for bug reports and feature requests. However, this issue appears to be a support request. Please use our support channels - to get help with Jellyseerr. + to get help with Seerr. - [Discord](https://discord.gg/seerr) run: | diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index a9a4ec4b38..864d120a1a 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,4 +1,4 @@ -# Contributing to Jellyseerr +# Contributing to Seerr All help is welcome and greatly appreciated! If you would like to contribute to the project, the following instructions should get you started... @@ -6,10 +6,10 @@ All help is welcome and greatly appreciated! If you would like to contribute to > [!IMPORTANT] > -> If you are using **any kind of AI assistance** to contribute to Jellyseerr, +> If you are using **any kind of AI assistance** to contribute to Seerr, > it must be disclosed in the pull request. -If you are using any kind of AI assistance while contributing to Jellyseerr, +If you are using any kind of AI assistance while contributing to Seerr, **this must be disclosed in the pull request**, along with the extent to which AI assistance was used (e.g. docs only vs. code generation). If PR responses are being generated by an AI, disclose that as well. @@ -56,14 +56,14 @@ Please be respectful to maintainers and disclose AI assistance. 1. [Fork](https://help.github.com/articles/fork-a-repo/) the repository to your own GitHub account and [clone](https://help.github.com/articles/cloning-a-repository/) it to your local device: ```bash - git clone https://github.com/YOUR_USERNAME/jellyseerr.git - cd jellyseerr/ + git clone https://github.com/YOUR_USERNAME/seerr.git + cd seerr/ ``` 2. Add the remote `upstream`: ```bash - git remote add upstream https://github.com/fallenbagel/jellyseerr.git + git remote add upstream https://github.com/seerr-team/seerr.git ``` 3. Create a new branch: @@ -147,11 +147,11 @@ When adding new UI text, please try to adhere to the following guidelines: 8. If an additional description or "tip" is required for a form field, it should be styled using the global CSS class `label-tip`. 9. In full sentences, abbreviations like "info" or "auto" should not be used in place of full words, unless referencing the name/label of a specific setting or option which has an abbreviation in its name. 10. Do your best to check for spelling errors and grammatical mistakes. -11. Do not misspell "Jellyseerr." +11. Do not misspell "Seerr." ## Translation -We use [Weblate](https://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/) for our translations, and your help with localizing Jellyseerr would be greatly appreciated! If your language is not listed below, please [open a feature request](/../../issues/new/choose). +We use [Weblate](https://jellyseerr.borgcube.de/projects/jellyseerr/jellyseerr-frontend/) for our translations, and your help with localizing Seerr would be greatly appreciated! If your language is not listed below, please [open a feature request](/../../issues/new/choose). Translation status @@ -197,4 +197,4 @@ DB_TYPE="postgres" DB_USER=postgres DB_PASS=postgres pnpm migration:generate ser ## Attribution -This contribution guide was inspired by the [Next.js](https://github.com/vercel/next.js), [Radarr](https://github.com/Radarr/Radarr), [Overseerr](https://github.com/sct/Overseerr) and [Ghostty](https://github.com/ghostty-org/ghostty) contribution guides. +This contribution guide was inspired by the [Next.js](https://github.com/vercel/next.js), [Radarr](https://github.com/Radarr/Radarr), and [Ghostty](https://github.com/ghostty-org/ghostty) contribution guides. diff --git a/README.md b/README.md index 11276eb94c..869730776f 100644 --- a/README.md +++ b/README.md @@ -2,16 +2,16 @@ Jellyseerr

-Jellyseerr Release -Jellyseerr CI +Seerr Release +Seerr CI

Discord Docker pulls Translation status -GitHub +GitHub -**Jellyseerr** is a free and open source software application for managing requests for your media library. It integrates with the media server of your choice: [Jellyfin](https://jellyfin.org), [Plex](https://plex.tv), and [Emby](https://emby.media/). In addition, it integrates with your existing services, such as **[Sonarr](https://sonarr.tv/)**, **[Radarr](https://radarr.video/)**. +**Seerr** is a free and open source software application for managing requests for your media library. It integrates with the media server of your choice: [Jellyfin](https://jellyfin.org), [Plex](https://plex.tv), and [Emby](https://emby.media/). In addition, it integrates with your existing services, such as **[Sonarr](https://sonarr.tv/)**, **[Radarr](https://radarr.video/)**. ## Current Features @@ -19,7 +19,7 @@ - Support for **PostgreSQL** and **SQLite** databases. - Supports Movies, Shows and Mixed Libraries. - Ability to change email addresses for SMTP purposes. -- Easy integration with your existing services. Currently, Jellyseerr supports Sonarr and Radarr. More to come! +- Easy integration with your existing services. Currently, Seerr supports Sonarr and Radarr. More to come! - Jellyfin/Emby/Plex library scan, to keep track of the titles which are already available. - Customizable request system, which allows users to request individual seasons or movies in a friendly, easy-to-use interface. - Incredibly simple request management UI. Don't dig through the app to simply approve recent requests! @@ -32,7 +32,7 @@ With more features on the way! Check out our [issue tracker](/../../issues) to s ## Getting Started -Check out our documentation for instructions on how to install and run Jellyseerr: +Check out our documentation for instructions on how to install and run Seerr: https://docs.jellyseerr.dev/getting-started/ @@ -48,26 +48,26 @@ Nix: [Nixpkg](https://search.nixos.org/packages?channel=unstable&show=jellyseerr ## Support -- Check out the [Jellyseerr Documentation](https://docs.jellyseerr.dev) before asking for help. Your question might already be in the docs! +- Check out the [Seerr Documentation](https://docs.jellyseerr.dev) before asking for help. Your question might already be in the docs! - You can get support on [Discord](https://discord.gg/seerr). - You can ask questions in the Help category of our [GitHub Discussions](/../../discussions). - Bug reports and feature requests can be submitted via [GitHub Issues](/../../issues). ## API Documentation -You can access the API documentation from your local Jellyseerr install at http://localhost:5055/api-docs +You can access the API documentation from your local Seerr install at http://localhost:5055/api-docs ## Community You can ask questions, share ideas, and more in [GitHub Discussions](/../../discussions). -If you would like to chat with other members of our growing community, [join the Jellyseerr Discord server](https://discord.gg/seerr)! +If you would like to chat with other members of our growing community, [join the Seerr Discord server](https://discord.gg/seerr)! -Our [Code of Conduct](./CODE_OF_CONDUCT.md) applies to all Jellyseerr community channels. +Our [Code of Conduct](./CODE_OF_CONDUCT.md) applies to all Seerr community channels. ## Contributing -You can help improve Jellyseerr too! Check out our [Contribution Guide](./CONTRIBUTING.md) to get started. +You can help improve Seerr too! Check out our [Contribution Guide](./CONTRIBUTING.md) to get started. ## Contributors ✨ diff --git a/SECURITY.md b/SECURITY.md index 3b15aeb5f0..f50d561107 100644 --- a/SECURITY.md +++ b/SECURITY.md @@ -31,7 +31,7 @@ We will send a response indicating the next steps in handling your report. After ## Third-Party Dependencies -If you discover a security vulnerability in a third-party dependency used by Jellyseerr, please report it directly to the maintainers of that module. You can also notify us through our security advisory process so we can: +If you discover a security vulnerability in a third-party dependency used by Seerr, please report it directly to the maintainers of that module. You can also notify us through our security advisory process so we can: - Track the issue and monitor for updates - Apply patches or workarounds if available @@ -47,5 +47,6 @@ Security updates and advisories will be published on our [GitHub Security Adviso ## Community For general questions and support (non-security related): + - [GitHub Discussions](../../discussions) -- [Discord](https://discord.gg/seerr) \ No newline at end of file +- [Discord](https://discord.gg/seerr) diff --git a/cypress/config/settings.cypress.json b/cypress/config/settings.cypress.json index e30dde8616..973f4c591c 100644 --- a/cypress/config/settings.cypress.json +++ b/cypress/config/settings.cypress.json @@ -4,7 +4,7 @@ "vapidPublic": "BK_EpP8NDm9waor2zn6_S28o3ZYv4kCkJOfYpO3pt3W6jnPmxrgTLANUBNbbyaNatPnSQ12De9CeqSYQrqWzHTs", "main": { "apiKey": "testkey", - "applicationTitle": "Jellyseerr", + "applicationTitle": "Seerr", "applicationUrl": "", "cacheImages": false, "defaultPermissions": 32, @@ -70,7 +70,7 @@ "ignoreTls": false, "requireTls": false, "allowSelfSigned": false, - "senderName": "Jellyseerr" + "senderName": "Seerr" } }, "discord": { diff --git a/package.json b/package.json index fe6857b47b..8e2b0bd60c 100644 --- a/package.json +++ b/package.json @@ -1,12 +1,12 @@ { - "name": "jellyseerr", + "name": "seerr", "version": "0.1.0", "private": true, "packageManager": "pnpm@10.17.1", "scripts": { "preinstall": "npx only-allow pnpm", "postinstall": "node postinstall-win.js", - "dev": "nodemon -e ts --watch server --watch jellyseerr-api.yml -e .json,.ts,.yml -x ts-node -r tsconfig-paths/register --files --project server/tsconfig.json server/index.ts", + "dev": "nodemon -e ts --watch server --watch seerr-api.yml -e .json,.ts,.yml -x ts-node -r tsconfig-paths/register --files --project server/tsconfig.json server/index.ts", "build:server": "tsc --project server/tsconfig.json && copyfiles -u 2 server/templates/**/*.{html,pug} dist/templates && tsc-alias -p server/tsconfig.json", "build:next": "next build", "build": "pnpm build:next && pnpm build:server", @@ -29,7 +29,7 @@ }, "repository": { "type": "git", - "url": "https://github.com/fallenbagel/jellyseerr.git" + "url": "https://github.com/seerr-team/seerr.git" }, "license": "MIT", "dependencies": { diff --git a/public/site.webmanifest b/public/site.webmanifest index fb38d80476..86ca0aa57f 100644 --- a/public/site.webmanifest +++ b/public/site.webmanifest @@ -1,6 +1,6 @@ { - "name": "Jellyseerr", - "short_name": "Jellyseerr", + "name": "Seerr", + "short_name": "Seerr", "start_url": "./", "icons": [ { diff --git a/jellyseerr-api.yml b/seerr-api.yml similarity index 99% rename from jellyseerr-api.yml rename to seerr-api.yml index 767e336ba2..3b1d134fdc 100644 --- a/jellyseerr-api.yml +++ b/seerr-api.yml @@ -1,19 +1,19 @@ openapi: '3.0.2' info: - title: 'Jellyseerr API' + title: 'Seerr API' version: '1.0.0' description: | - This is the documentation for the Jellyseerr API backend. + This is the documentation for the Seerr API backend. Two primary authentication methods are supported: - **Cookie Authentication**: A valid sign-in to the `/auth/plex` or `/auth/local` will generate a valid authentication cookie. - - **API Key Authentication**: Sign-in is also possible by passing an `X-Api-Key` header along with a valid API Key generated by Jellyseerr. + - **API Key Authentication**: Sign-in is also possible by passing an `X-Api-Key` header along with a valid API Key generated by Seerr. tags: - name: public description: Public API endpoints requiring no authentication. - name: settings - description: Endpoints related to Jellyseerr's settings and configuration. + description: Endpoints related to Seerr's settings and configuration. - name: auth description: Endpoints related to logging in or out, and the currently authenticated user. - name: users @@ -229,7 +229,7 @@ components: example: en applicationTitle: type: string - example: Jellyseerr + example: Seerr applicationUrl: type: string example: https://os.example.com @@ -1570,7 +1570,7 @@ components: example: no-reply@example.com senderName: type: string - example: Jellyseerr + example: Seerr smtpHost: type: string example: 127.0.0.1 @@ -2136,8 +2136,8 @@ components: paths: /status: get: - summary: Get Jellyseerr status - description: Returns the current Jellyseerr status in a JSON object. + summary: Get Seerr status + description: Returns the current Seerr status in a JSON object. security: [] tags: - public diff --git a/server/api/github.ts b/server/api/github.ts index 3a85d91bb8..009a82c1db 100644 --- a/server/api/github.ts +++ b/server/api/github.ts @@ -76,14 +76,14 @@ class GithubAPI extends ExternalAPI { ); } - public async getJellyseerrReleases({ + public async getSeerrReleases({ take = 20, }: { take?: number; } = {}): Promise { try { const data = await this.get( - '/repos/fallenbagel/jellyseerr/releases', + '/repos/seerr-team/seerr/releases', { params: { per_page: take, @@ -94,14 +94,14 @@ class GithubAPI extends ExternalAPI { return data; } catch (e) { logger.warn( - "Failed to retrieve GitHub releases. This may be an issue on GitHub's end. Jellyseerr can't check if it's on the latest version.", + "Failed to retrieve GitHub releases. This may be an issue on GitHub's end. Seerr can't check if it's on the latest version.", { label: 'GitHub API', errorMessage: e.message } ); return []; } } - public async getJellyseerrCommits({ + public async getSeerrCommits({ take = 20, branch = 'develop', }: { @@ -110,7 +110,7 @@ class GithubAPI extends ExternalAPI { } = {}): Promise { try { const data = await this.get( - '/repos/fallenbagel/jellyseerr/commits', + '/repos/seerr-team/seerr/commits', { params: { per_page: take, @@ -122,7 +122,7 @@ class GithubAPI extends ExternalAPI { return data; } catch (e) { logger.warn( - "Failed to retrieve GitHub commits. This may be an issue on GitHub's end. Jellyseerr can't check if it's on the latest version.", + "Failed to retrieve GitHub commits. This may be an issue on GitHub's end. Seerr can't check if it's on the latest version.", { label: 'GitHub API', errorMessage: e.message } ); return []; diff --git a/server/api/jellyfin.ts b/server/api/jellyfin.ts index 2c5b05936d..e143ad9642 100644 --- a/server/api/jellyfin.ts +++ b/server/api/jellyfin.ts @@ -131,13 +131,13 @@ class JellyfinAPI extends ExternalAPI { const safeDeviceId = deviceId && deviceId.length > 0 ? deviceId - : Buffer.from('BOT_jellyseerr').toString('base64'); + : Buffer.from('BOT_seerr').toString('base64'); let authHeaderVal: string; if (authToken) { - authHeaderVal = `MediaBrowser Client="Jellyseerr", Device="Jellyseerr", DeviceId="${safeDeviceId}", Version="${getAppVersion()}", Token="${authToken}"`; + authHeaderVal = `MediaBrowser Client="Seerr", Device="Seerr", DeviceId="${safeDeviceId}", Version="${getAppVersion()}", Token="${authToken}"`; } else { - authHeaderVal = `MediaBrowser Client="Jellyseerr", Device="Jellyseerr", DeviceId="${safeDeviceId}", Version="${getAppVersion()}"`; + authHeaderVal = `MediaBrowser Client="Seerr", Device="Seerr", DeviceId="${safeDeviceId}", Version="${getAppVersion()}"`; } super( diff --git a/server/api/plexapi.ts b/server/api/plexapi.ts index 5007fe05e0..03cdaf6662 100644 --- a/server/api/plexapi.ts +++ b/server/api/plexapi.ts @@ -124,9 +124,9 @@ class PlexAPI { // }, options: { identifier: settings.clientId, - product: 'Jellyseerr', - deviceName: 'Jellyseerr', - platform: 'Jellyseerr', + product: 'Seerr', + deviceName: 'Seerr', + platform: 'Seerr', }, }); } diff --git a/server/index.ts b/server/index.ts index 9d7a74b88d..b98e3b2fae 100644 --- a/server/index.ts +++ b/server/index.ts @@ -43,9 +43,9 @@ import path from 'path'; import swaggerUi from 'swagger-ui-express'; import YAML from 'yamljs'; -const API_SPEC_PATH = path.join(__dirname, '../jellyseerr-api.yml'); +const API_SPEC_PATH = path.join(__dirname, '../seerr-api.yml'); -logger.info(`Starting Jellyseerr version ${getAppVersion()}`); +logger.info(`Starting Seerr version ${getAppVersion()}`); const dev = process.env.NODE_ENV !== 'production'; const app = next({ dev }); const handle = app.getRequestHandler(); diff --git a/server/lib/notifications/agents/slack.ts b/server/lib/notifications/agents/slack.ts index f5dd2442d9..04be7b1f2c 100644 --- a/server/lib/notifications/agents/slack.ts +++ b/server/lib/notifications/agents/slack.ts @@ -192,7 +192,7 @@ class SlackAgent type: 'actions', elements: [ { - action_id: 'open-in-jellyseerr', + action_id: 'open-in-seerr', type: 'button', url, text: { diff --git a/server/lib/settings/index.ts b/server/lib/settings/index.ts index 73bc951b70..2491577d79 100644 --- a/server/lib/settings/index.ts +++ b/server/lib/settings/index.ts @@ -380,7 +380,7 @@ class Settings { vapidPublic: '', main: { apiKey: '', - applicationTitle: 'Jellyseerr', + applicationTitle: 'Seerr', applicationUrl: '', cacheImages: false, defaultPermissions: Permission.REQUEST, @@ -447,7 +447,7 @@ class Settings { ignoreTls: false, requireTls: false, allowSelfSigned: false, - senderName: 'Jellyseerr', + senderName: 'Seerr', }, }, discord: { diff --git a/server/lib/settings/migrations/0002_migrate_apitokens.ts b/server/lib/settings/migrations/0002_migrate_apitokens.ts index 0149c3e37f..0390678262 100644 --- a/server/lib/settings/migrations/0002_migrate_apitokens.ts +++ b/server/lib/settings/migrations/0002_migrate_apitokens.ts @@ -28,7 +28,7 @@ const migrateApiTokens = async (settings: any): Promise => { ); jellyfinClient.setUserId(admin.jellyfinUserId ?? ''); try { - const apiKey = await jellyfinClient.createApiToken('Jellyseerr'); + const apiKey = await jellyfinClient.createApiToken('Seerr'); settings.jellyfin.apiKey = apiKey; } catch { throw new Error( diff --git a/server/lib/settings/migrator.ts b/server/lib/settings/migrator.ts index 801140000a..743b4adc39 100644 --- a/server/lib/settings/migrator.ts +++ b/server/lib/settings/migrator.ts @@ -44,7 +44,7 @@ export const runMigrations = async ( } migrated = newSettings; } catch (e) { - // we stop jellyseerr if the migration failed + // we stop Seerr if the migration failed logger.error( `Error while running migration '${migration}': ${e.message}`, { @@ -81,7 +81,7 @@ export const runMigrations = async ( await fs.writeFile(BACKUP_PATH, oldBackup.toString()); } } catch (e) { - // we stop jellyseerr if the migration failed + // we stop Seerr if the migration failed logger.error( `Something went wrong while running settings migrations: ${e.message}`, { diff --git a/server/lib/watchlistsync.ts b/server/lib/watchlistsync.ts index ed4887677a..aeb0480920 100644 --- a/server/lib/watchlistsync.ts +++ b/server/lib/watchlistsync.ts @@ -130,7 +130,7 @@ class WatchlistSync { switch (e.constructor) { // During watchlist sync, these errors aren't necessarily - // a problem with Jellyseerr. Since we are auto syncing these constantly, it's + // a problem with Seerr. Since we are auto syncing these constantly, it's // possible they are unexpectedly at their quota limit, for example. So we'll // instead log these as debug messages. case RequestPermissionError: diff --git a/server/routes/auth.ts b/server/routes/auth.ts index b8e78a2d0e..3b93cf6cfd 100644 --- a/server/routes/auth.ts +++ b/server/routes/auth.ts @@ -161,7 +161,7 @@ authRoutes.post('/plex', async (req, res, next) => { }); } else { logger.info( - 'Sign-in attempt from Plex user with access to the media server; creating new Jellyseerr user', + 'Sign-in attempt from Plex user with access to the media server; creating new Seerr user', { label: 'API', ip: req.ip, @@ -277,16 +277,14 @@ authRoutes.post('/jellyfin', async (req, res, next) => { select: { id: true, jellyfinDeviceId: true }, }); - let deviceId = 'BOT_jellyseerr'; + let deviceId = 'BOT_seerr'; if (user && user.id === 1) { - // Admin is always BOT_jellyseerr - deviceId = 'BOT_jellyseerr'; + // Admin is always BOT_seerr + deviceId = 'BOT_seerr'; } else if (user && user.jellyfinDeviceId) { deviceId = user.jellyfinDeviceId; } else if (body.username) { - deviceId = Buffer.from(`BOT_jellyseerr_${body.username}`).toString( - 'base64' - ); + deviceId = Buffer.from(`BOT_seerr_${body.username}`).toString('base64'); } // First we need to attempt to log the user in to jellyfin @@ -334,7 +332,7 @@ authRoutes.post('/jellyfin', async (req, res, next) => { if (missingAdminUser) { logger.info( - 'Sign-in attempt from Jellyfin user with access to the media server; creating initial admin user for Jellyseerr', + 'Sign-in attempt from Jellyfin user with access to the media server; creating initial admin user for Seerr', { label: 'API', ip: req.ip, @@ -363,7 +361,7 @@ authRoutes.post('/jellyfin', async (req, res, next) => { await userRepository.save(user); } else { logger.info( - 'Sign-in attempt from Jellyfin user with access to the media server; editing admin user for Jellyseerr', + 'Sign-in attempt from Jellyfin user with access to the media server; editing admin user for Seerr', { label: 'API', ip: req.ip, @@ -400,7 +398,7 @@ authRoutes.post('/jellyfin', async (req, res, next) => { account.AccessToken, deviceId ); - const apiKey = await jellyfinClient.createApiToken('Jellyseerr'); + const apiKey = await jellyfinClient.createApiToken('Seerr'); const serverName = await jellyfinserver.getServerName(); @@ -456,7 +454,7 @@ authRoutes.post('/jellyfin', async (req, res, next) => { }); } else if (!user) { logger.info( - 'Sign-in attempt from Jellyfin user with access to the media server; creating new Jellyseerr user', + 'Sign-in attempt from Jellyfin user with access to the media server; creating new Seerr user', { label: 'API', ip: req.ip, @@ -616,7 +614,7 @@ authRoutes.post('/local', async (req, res, next) => { .getOne(); if (!user || !(await user.passwordMatch(body.password))) { - logger.warn('Failed sign-in attempt using invalid Jellyseerr password', { + logger.warn('Failed sign-in attempt using invalid Seerr password', { label: 'API', ip: req.ip, email: body.email, @@ -705,15 +703,12 @@ authRoutes.post('/local', async (req, res, next) => { return res.status(200).json(user?.filter() ?? {}); } catch (e) { - logger.error( - 'Something went wrong authenticating with Jellyseerr password', - { - label: 'API', - errorMessage: e.message, - ip: req.ip, - email: body.email, - } - ); + logger.error('Something went wrong authenticating with Seerr password', { + label: 'API', + errorMessage: e.message, + ip: req.ip, + email: body.email, + }); return next({ status: 500, message: 'Unable to authenticate.', @@ -747,7 +742,7 @@ authRoutes.post('/logout', async (req, res, next) => { await axios.delete(`${baseUrl}/Devices`, { params: { Id: user.jellyfinDeviceId }, headers: { - 'X-Emby-Authorization': `MediaBrowser Client="Jellyseerr", Device="Jellyseerr", DeviceId="jellyseerr", Version="${getAppVersion()}", Token="${ + 'X-Emby-Authorization': `MediaBrowser Client="Seerr", Device="Seerr", DeviceId="seerr", Version="${getAppVersion()}", Token="${ settings.jellyfin.apiKey }"`, }, diff --git a/server/routes/avatarproxy.ts b/server/routes/avatarproxy.ts index fc48313ea7..17df52110e 100644 --- a/server/routes/avatarproxy.ts +++ b/server/routes/avatarproxy.ts @@ -23,11 +23,11 @@ async function initAvatarImageProxy() { select: ['id', 'jellyfinUserId', 'jellyfinDeviceId'], order: { id: 'ASC' }, }); - const deviceId = admin?.jellyfinDeviceId || 'BOT_jellyseerr'; + const deviceId = admin?.jellyfinDeviceId || 'BOT_seerr'; const authToken = getSettings().jellyfin.apiKey; _avatarImageProxy = new ImageProxy('avatar', '', { headers: { - 'X-Emby-Authorization': `MediaBrowser Client="Jellyseerr", Device="Jellyseerr", DeviceId="${deviceId}", Version="${getAppVersion()}", Token="${authToken}"`, + 'X-Emby-Authorization': `MediaBrowser Client="Seerr", Device="Seerr", DeviceId="${deviceId}", Version="${getAppVersion()}", Token="${authToken}"`, }, }); } diff --git a/server/routes/index.ts b/server/routes/index.ts index b284213962..6155f3508f 100644 --- a/server/routes/index.ts +++ b/server/routes/index.ts @@ -55,7 +55,7 @@ router.get('/status', async (req, res) => { let commitsBehind = 0; if (currentVersion.startsWith('develop-') && commitTag !== 'local') { - const commits = await githubApi.getJellyseerrCommits(); + const commits = await githubApi.getSeerrCommits(); if (commits.length) { const filteredCommits = commits.filter( @@ -74,7 +74,7 @@ router.get('/status', async (req, res) => { } } } else if (commitTag !== 'local') { - const releases = await githubApi.getJellyseerrReleases(); + const releases = await githubApi.getSeerrReleases(); if (releases.length) { const latestVersion = releases[0]; @@ -445,7 +445,7 @@ router.get('/certifications/tv', isAuthenticated(), async (req, res, next) => { router.get('/', (_req, res) => { return res.status(200).json({ - api: 'Jellyseerr API', + api: 'Seerr API', version: '1.0', }); }); diff --git a/server/routes/user/index.ts b/server/routes/user/index.ts index f817a9cb33..9dd8ca03b5 100644 --- a/server/routes/user/index.ts +++ b/server/routes/user/index.ts @@ -633,7 +633,7 @@ router.post( jellyfinUsername: jellyfinUser?.Name, jellyfinUserId: jellyfinUser?.Id, jellyfinDeviceId: Buffer.from( - `BOT_jellyseerr_${jellyfinUser?.Name ?? ''}` + `BOT_seerr_${jellyfinUser?.Name ?? ''}` ).toString('base64'), email: jellyfinUser?.Name, permissions: settings.main.defaultPermissions, diff --git a/server/routes/user/usersettings.ts b/server/routes/user/usersettings.ts index 690cff8309..50ea7c5a5f 100644 --- a/server/routes/user/usersettings.ts +++ b/server/routes/user/usersettings.ts @@ -312,7 +312,7 @@ userSettingsRoutes.post<{ authToken: string }>( // Do not allow linking of an already linked account if (await userRepository.exist({ where: { plexId: account.id } })) { return res.status(422).json({ - message: 'This Plex account is already linked to a Jellyseerr user', + message: 'This Plex account is already linked to a Seerr user', }); } @@ -415,15 +415,13 @@ userSettingsRoutes.post<{ username: string; password: string }>( }) ) { return res.status(422).json({ - message: 'The specified account is already linked to a Jellyseerr user', + message: 'The specified account is already linked to a Seerr user', }); } const hostname = getHostname(); const deviceId = Buffer.from( - req.user?.id === 1 - ? 'BOT_jellyseerr' - : `BOT_jellyseerr_${req.user.username ?? ''}` + req.user?.id === 1 ? 'BOT_seerr' : `BOT_seerr_${req.user.username ?? ''}` ).toString('base64'); const jellyfinserver = new JellyfinAPI(hostname, undefined, deviceId); @@ -452,8 +450,7 @@ userSettingsRoutes.post<{ username: string; password: string }>( }) ) { return res.status(422).json({ - message: - 'The specified account is already linked to a Jellyseerr user', + message: 'The specified account is already linked to a Seerr user', }); } From 94a43ea480d12ec037102ec0ba75481314b95c78 Mon Sep 17 00:00:00 2001 From: TheCatLady <52870424+TheCatLady@users.noreply.github.com> Date: Mon, 6 Oct 2025 16:47:10 -0700 Subject: [PATCH 57/96] chore: rename Jellyseerr -> Seerr, part 2 (#1987) --- README.md | 7 +- src/components/Layout/VersionStatus/index.tsx | 4 +- src/components/Login/index.tsx | 4 +- src/components/PWAHeader/index.tsx | 2 +- .../NotificationsPushover/index.tsx | 2 +- .../Notifications/NotificationsTelegram.tsx | 3 +- .../NotificationsWebPush/index.tsx | 2 +- .../Settings/SettingsAbout/Releases/index.tsx | 2 +- .../Settings/SettingsAbout/index.tsx | 68 +++++-------------- src/components/Settings/SettingsBadge.tsx | 2 +- src/components/Settings/SettingsJellyfin.tsx | 2 +- .../Settings/SettingsJobsCache/index.tsx | 8 +-- .../Settings/SettingsMain/index.tsx | 2 +- .../Settings/SettingsNetwork/index.tsx | 6 +- src/components/Settings/SettingsPlex.tsx | 8 +-- src/components/Setup/LoginWithPlex.tsx | 2 +- src/components/Setup/SetupLogin.tsx | 2 +- src/components/Setup/index.tsx | 2 +- src/context/SettingsContext.tsx | 2 +- src/i18n/locale/en.json | 50 +++++++------- src/utils/plex.ts | 4 +- 21 files changed, 72 insertions(+), 112 deletions(-) diff --git a/README.md b/README.md index 869730776f..aec85a8138 100644 --- a/README.md +++ b/README.md @@ -71,8 +71,7 @@ You can help improve Seerr too! Check out our [Contribution Guide](./CONTRIBUTIN ## Contributors ✨ -[![contributors](https://opencollective.com/seerr/contributors.svg?width=890)](https://opencollective.com/seerr/#backers) +[![Contributors](https://opencollective.com/seerr/contributors.svg?width=890)](https://opencollective.com/seerr/#backers) -[![backers](https://opencollective.com/seerr/backers.svg?width=890)](https://opencollective.com/seerr/#backers) - -[![sponsors](https://opencollective.com/seerr/sponsors.svg?width=890)](https://opencollective.com/seerr/#sponsors) +[![Become a Backer](https://opencollective.com/seerr/backers.svg)](https://opencollective.com/seerr/#backers) +[![Become a Sponsor](https://opencollective.com/seerr/sponsors.svg)](https://opencollective.com/seerr/#sponsors) diff --git a/src/components/Layout/VersionStatus/index.tsx b/src/components/Layout/VersionStatus/index.tsx index 238e6ce3e6..02c3396417 100644 --- a/src/components/Layout/VersionStatus/index.tsx +++ b/src/components/Layout/VersionStatus/index.tsx @@ -11,8 +11,8 @@ import { useIntl } from 'react-intl'; import useSWR from 'swr'; const messages = defineMessages('components.Layout.VersionStatus', { - streamdevelop: 'Jellyseerr Develop', - streamstable: 'Jellyseerr Stable', + streamdevelop: 'Seerr Develop', + streamstable: 'Seerr Stable', outofdate: 'Out of Date', commitsbehind: '{commitsBehind} {commitsBehind, plural, one {commit} other {commits}} behind', diff --git a/src/components/Login/index.tsx b/src/components/Login/index.tsx index 907da8f2f7..a8bfac7e8e 100644 --- a/src/components/Login/index.tsx +++ b/src/components/Login/index.tsx @@ -122,8 +122,8 @@ const Login = () => { settings.currentSettings.localLogin && (mediaServerLogin ? (

- - - - https://github.com/sponsors/sct - - - {intl.formatMessage(messages.preferredmethod)} - - - - - https://patreon.com/overseerr - - - -
-
- - + + - https://www.buymeacoffee.com/fallen.bagel + https://opencollective.com/seerr - - {intl.formatMessage(messages.preferredmethod)} -
diff --git a/src/components/Settings/SettingsBadge.tsx b/src/components/Settings/SettingsBadge.tsx index 26e387290a..8fcef6aea3 100644 --- a/src/components/Settings/SettingsBadge.tsx +++ b/src/components/Settings/SettingsBadge.tsx @@ -10,7 +10,7 @@ const messages = defineMessages('components.Settings', { experimentalTooltip: 'Enabling this setting may result in unexpected application behavior', restartrequiredTooltip: - 'Jellyseerr must be restarted for changes to this setting to take effect', + 'Seerr must be restarted for changes to this setting to take effect', }); const SettingsBadge = ({ diff --git a/src/components/Settings/SettingsJellyfin.tsx b/src/components/Settings/SettingsJellyfin.tsx index 324a0dce79..961337e4e1 100644 --- a/src/components/Settings/SettingsJellyfin.tsx +++ b/src/components/Settings/SettingsJellyfin.tsx @@ -52,7 +52,7 @@ const messages = defineMessages('components.Settings', { syncJellyfin: 'Sync Libraries', manualscanJellyfin: 'Manual Library Scan', manualscanDescriptionJellyfin: - "Normally, this will only be run once every 24 hours. Jellyseerr will check your {mediaServerName} server's recently added more aggressively. If this is your first time configuring Jellyseerr, a one-time full manual library scan is recommended!", + "Normally, this will only be run once every 24 hours. Seerr will check your {mediaServerName} server's recently added more aggressively. If this is your first time configuring Seerr, a one-time full manual library scan is recommended!", notrunning: 'Not Running', currentlibrary: 'Current Library: {name}', librariesRemaining: 'Libraries Remaining: {count}', diff --git a/src/components/Settings/SettingsJobsCache/index.tsx b/src/components/Settings/SettingsJobsCache/index.tsx index 4b4c98f445..5355f4d3ae 100644 --- a/src/components/Settings/SettingsJobsCache/index.tsx +++ b/src/components/Settings/SettingsJobsCache/index.tsx @@ -35,7 +35,7 @@ const messages: { [messageName: string]: MessageDescriptor } = defineMessages( jobsandcache: 'Jobs & Cache', jobs: 'Jobs', jobsDescription: - 'Jellyseerr performs certain maintenance tasks as regularly-scheduled jobs, but they can also be manually triggered below. Manually running a job will not alter its schedule.', + 'Seerr performs certain maintenance tasks as regularly-scheduled jobs, but they can also be manually triggered below. Manually running a job will not alter its schedule.', jobname: 'Job Name', jobtype: 'Type', nextexecution: 'Next Execution', @@ -47,7 +47,7 @@ const messages: { [messageName: string]: MessageDescriptor } = defineMessages( command: 'Command', cache: 'Cache', cacheDescription: - 'Jellyseerr caches requests to external API endpoints to optimize performance and avoid making unnecessary API calls.', + 'Seerr caches requests to external API endpoints to optimize performance and avoid making unnecessary API calls.', cacheflushed: '{cachename} cache flushed.', cachename: 'Cache Name', cachehits: 'Hits', @@ -58,7 +58,7 @@ const messages: { [messageName: string]: MessageDescriptor } = defineMessages( flushcache: 'Flush Cache', dnsCache: 'DNS Cache', dnsCacheDescription: - 'Jellyseerr caches DNS lookups to optimize performance and avoid making unnecessary API calls.', + 'Seerr caches DNS lookups to optimize performance and avoid making unnecessary API calls.', dnscacheflushed: '{hostname} dns cache flushed.', dnscachename: 'Hostname', dnscacheactiveaddress: 'Active Address', @@ -104,7 +104,7 @@ const messages: { [messageName: string]: MessageDescriptor } = defineMessages( 'Every {jobScheduleSeconds, plural, one {second} other {{jobScheduleSeconds} seconds}}', imagecache: 'Image Cache', imagecacheDescription: - 'When enabled in settings, Jellyseerr will proxy and cache images from pre-configured external sources. Cached images are saved into your config folder. You can find the files in {appDataPath}/cache/images.', + 'When enabled in settings, Seerr will proxy and cache images from pre-configured external sources. Cached images are saved into your config folder. You can find the files in {appDataPath}/cache/images.', imagecachecount: 'Images Cached', imagecachesize: 'Total Cache Size', usersavatars: "Users' Avatars", diff --git a/src/components/Settings/SettingsMain/index.tsx b/src/components/Settings/SettingsMain/index.tsx index 4423010c09..7de8f83785 100644 --- a/src/components/Settings/SettingsMain/index.tsx +++ b/src/components/Settings/SettingsMain/index.tsx @@ -29,7 +29,7 @@ const messages = defineMessages('components.Settings.SettingsMain', { general: 'General', generalsettings: 'General Settings', generalsettingsDescription: - 'Configure global and default settings for Jellyseerr.', + 'Configure global and default settings for Seerr.', apikey: 'API Key', apikeyCopied: 'Copied API key to clipboard.', applicationTitle: 'Application Title', diff --git a/src/components/Settings/SettingsNetwork/index.tsx b/src/components/Settings/SettingsNetwork/index.tsx index f0d08a7f88..0e5231989c 100644 --- a/src/components/Settings/SettingsNetwork/index.tsx +++ b/src/components/Settings/SettingsNetwork/index.tsx @@ -20,14 +20,14 @@ const messages = defineMessages('components.Settings.SettingsNetwork', { network: 'Network', networksettings: 'Network Settings', networksettingsDescription: - 'Configure network settings for your Jellyseerr instance.', + 'Configure network settings for your Seerr instance.', csrfProtection: 'Enable CSRF Protection', csrfProtectionTip: 'Set external API access to read-only (requires HTTPS)', csrfProtectionHoverTip: 'Do NOT enable this setting unless you understand what you are doing!', trustProxy: 'Enable Proxy Support', trustProxyTip: - 'Allow Jellyseerr to correctly register client IP addresses behind a proxy', + 'Allow Seerr to correctly register client IP addresses behind a proxy', proxyEnabled: 'HTTP(S) Proxy', proxyHostname: 'Proxy Hostname', proxyPort: 'Proxy Port', @@ -44,7 +44,7 @@ const messages = defineMessages('components.Settings.SettingsNetwork', { docs: 'documentation', forceIpv4First: 'Force IPv4 Resolution First', forceIpv4FirstTip: - 'Force Jellyseerr to resolve IPv4 addresses first instead of IPv6', + 'Force Seerr to resolve IPv4 addresses first instead of IPv6', dnsCache: 'DNS Cache', dnsCacheTip: 'Enable caching of DNS lookups to optimize performance and avoid making unnecessary API calls', diff --git a/src/components/Settings/SettingsPlex.tsx b/src/components/Settings/SettingsPlex.tsx index cac73fb94a..b670d52099 100644 --- a/src/components/Settings/SettingsPlex.tsx +++ b/src/components/Settings/SettingsPlex.tsx @@ -30,7 +30,7 @@ const messages = defineMessages('components.Settings', { plex: 'Plex', plexsettings: 'Plex Settings', plexsettingsDescription: - 'Configure the settings for your Plex server. Jellyseerr scans your Plex libraries to determine content availability.', + 'Configure the settings for your Plex server. Seerr scans your Plex libraries to determine content availability.', serverpreset: 'Server', serverLocal: 'local', serverRemote: 'remote', @@ -51,12 +51,12 @@ const messages = defineMessages('components.Settings', { enablessl: 'Use SSL', plexlibraries: 'Plex Libraries', plexlibrariesDescription: - 'The libraries Jellyseerr scans for titles. Set up and save your Plex connection settings, then click the button below if no libraries are listed.', + 'The libraries Seerr scans for titles. Set up and save your Plex connection settings, then click the button below if no libraries are listed.', scanning: 'Syncing…', scan: 'Sync Libraries', manualscan: 'Manual Library Scan', manualscanDescription: - "Normally, this will only be run once every 24 hours. Jellyseerr will check your Plex server's recently added more aggressively. If this is your first time configuring Plex, a one-time full manual library scan is recommended!", + "Normally, this will only be run once every 24 hours. Seerr will check your Plex server's recently added more aggressively. If this is your first time configuring Plex, a one-time full manual library scan is recommended!", notrunning: 'Not Running', currentlibrary: 'Current Library: {name}', librariesRemaining: 'Libraries Remaining: {count}', @@ -69,7 +69,7 @@ const messages = defineMessages('components.Settings', { 'Optionally direct users to the web app on your server instead of the "hosted" web app', tautulliSettings: 'Tautulli Settings', tautulliSettingsDescription: - 'Optionally configure the settings for your Tautulli server. Jellyseerr fetches watch history data for your Plex media from Tautulli.', + 'Optionally configure the settings for your Tautulli server. Seerr fetches watch history data for your Plex media from Tautulli.', urlBase: 'URL Base', tautulliApiKey: 'API Key', externalUrl: 'External URL', diff --git a/src/components/Setup/LoginWithPlex.tsx b/src/components/Setup/LoginWithPlex.tsx index 469788f143..85e83423cd 100644 --- a/src/components/Setup/LoginWithPlex.tsx +++ b/src/components/Setup/LoginWithPlex.tsx @@ -6,7 +6,7 @@ import { useEffect, useState } from 'react'; import { useIntl } from 'react-intl'; const messages = defineMessages('components.Setup', { - welcome: 'Welcome to Jellyseerr', + welcome: 'Welcome to Seerr', signinMessage: 'Get started by signing in with your Plex account', }); diff --git a/src/components/Setup/SetupLogin.tsx b/src/components/Setup/SetupLogin.tsx index 768218081c..c9539d1f47 100644 --- a/src/components/Setup/SetupLogin.tsx +++ b/src/components/Setup/SetupLogin.tsx @@ -9,7 +9,7 @@ import { useEffect, useState } from 'react'; import { FormattedMessage } from 'react-intl'; const messages = defineMessages('components.Setup', { - welcome: 'Welcome to Jellyseerr', + welcome: 'Welcome to Seerr', signinMessage: 'Get started by signing in', signin: 'Sign in to your account', signinWithJellyfin: 'Enter your Jellyfin details', diff --git a/src/components/Setup/index.tsx b/src/components/Setup/index.tsx index 4d6ea4cefd..4a329dcc07 100644 --- a/src/components/Setup/index.tsx +++ b/src/components/Setup/index.tsx @@ -25,7 +25,7 @@ import useSWR, { mutate } from 'swr'; import SetupLogin from './SetupLogin'; const messages = defineMessages('components.Setup', { - welcome: 'Welcome to Jellyseerr', + welcome: 'Welcome to Seerr', subtitle: 'Get started by choosing your media server', configjellyfin: 'Configure Jellyfin', configplex: 'Configure Plex', diff --git a/src/context/SettingsContext.tsx b/src/context/SettingsContext.tsx index aa838b4060..4907171b6c 100644 --- a/src/context/SettingsContext.tsx +++ b/src/context/SettingsContext.tsx @@ -10,7 +10,7 @@ export interface SettingsContextProps { const defaultSettings = { initialized: false, - applicationTitle: 'Jellyseerr', + applicationTitle: 'Seerr', applicationUrl: '', hideAvailable: false, hideBlacklisted: false, diff --git a/src/i18n/locale/en.json b/src/i18n/locale/en.json index 69573dc0ba..1e6abbb33a 100644 --- a/src/i18n/locale/en.json +++ b/src/i18n/locale/en.json @@ -237,8 +237,8 @@ "components.Layout.UserWarnings.passwordRequired": "A password is required.", "components.Layout.VersionStatus.commitsbehind": "{commitsBehind} {commitsBehind, plural, one {commit} other {commits}} behind", "components.Layout.VersionStatus.outofdate": "Out of Date", - "components.Layout.VersionStatus.streamdevelop": "Jellyseerr Develop", - "components.Layout.VersionStatus.streamstable": "Jellyseerr Stable", + "components.Layout.VersionStatus.streamdevelop": "Seerr Develop", + "components.Layout.VersionStatus.streamstable": "Seerr Stable", "components.Login.adminerror": "You must use an admin account to sign in.", "components.Login.back": "Go back", "components.Login.credentialerror": "The username or password is incorrect.", @@ -653,7 +653,7 @@ "components.Settings.Notifications.NotificationsPushbullet.validationAccessTokenRequired": "You must provide an access token", "components.Settings.Notifications.NotificationsPushbullet.validationTypes": "You must select at least one notification type", "components.Settings.Notifications.NotificationsPushover.accessToken": "Application API Token", - "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Register an application for use with Jellyseerr", + "components.Settings.Notifications.NotificationsPushover.accessTokenTip": "Register an application for use with Seerr", "components.Settings.Notifications.NotificationsPushover.agentenabled": "Enable Agent", "components.Settings.Notifications.NotificationsPushover.deviceDefault": "Device Default", "components.Settings.Notifications.NotificationsPushover.embedPoster": "Embed Poster", @@ -699,7 +699,7 @@ "components.Settings.Notifications.NotificationsWebhook.webhooksettingssaved": "Webhook notification settings saved successfully!", "components.Settings.Notifications.NotificationsWebPush.agentenabled": "Enable Agent", "components.Settings.Notifications.NotificationsWebPush.embedPoster": "Embed Poster", - "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "In order to receive web push notifications, Jellyseerr must be served over HTTPS.", + "components.Settings.Notifications.NotificationsWebPush.httpsRequirement": "In order to receive web push notifications, Seerr must be served over HTTPS.", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestFailed": "Web push test notification failed to send.", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSending": "Sending web push test notification…", "components.Settings.Notifications.NotificationsWebPush.toastWebPushTestSuccess": "Web push test notification sent!", @@ -710,7 +710,7 @@ "components.Settings.Notifications.authPass": "SMTP Password", "components.Settings.Notifications.authUser": "SMTP Username", "components.Settings.Notifications.botAPI": "Bot Authorization Token", - "components.Settings.Notifications.botApiTip": "Create a bot for use with Jellyseerr", + "components.Settings.Notifications.botApiTip": "Create a bot for use with Seerr", "components.Settings.Notifications.botAvatarUrl": "Bot Avatar URL", "components.Settings.Notifications.botUsername": "Bot Username", "components.Settings.Notifications.botUsernameTip": "Allow users to also start a chat with your bot and configure their own notifications", @@ -857,18 +857,16 @@ "components.Settings.SettingsAbout.Releases.viewchangelog": "View Changelog", "components.Settings.SettingsAbout.Releases.viewongithub": "View on GitHub", "components.Settings.SettingsAbout.about": "About", + "components.Settings.SettingsAbout.aboutseerr": "About Seerr", "components.Settings.SettingsAbout.appDataPath": "Data Directory", "components.Settings.SettingsAbout.betawarning": "This is BETA software. Features may be broken and/or unstable. Please report any issues on GitHub!", + "components.Settings.SettingsAbout.contribute": "Make a Contribution", "components.Settings.SettingsAbout.documentation": "Documentation", "components.Settings.SettingsAbout.gettingsupport": "Getting Support", "components.Settings.SettingsAbout.githubdiscussions": "GitHub Discussions", - "components.Settings.SettingsAbout.helppaycoffee": "Help Pay for Coffee", "components.Settings.SettingsAbout.outofdate": "Out of Date", - "components.Settings.SettingsAbout.overseerrinformation": "About Jellyseerr", - "components.Settings.SettingsAbout.preferredmethod": "Preferred", - "components.Settings.SettingsAbout.runningDevelop": "You are running the develop branch of Jellyseerr, which is only recommended for those contributing to development or assisting with bleeding-edge testing.", - "components.Settings.SettingsAbout.supportjellyseerr": "Support Jellyseerr", - "components.Settings.SettingsAbout.supportoverseerr": "Support Overseerr", + "components.Settings.SettingsAbout.runningDevelop": "You are running the develop branch of Seerr, which is only recommended for those contributing to development or assisting with bleeding-edge testing.", + "components.Settings.SettingsAbout.supportseerr": "Support Seerr", "components.Settings.SettingsAbout.timezone": "Time Zone", "components.Settings.SettingsAbout.totalmedia": "Total Media", "components.Settings.SettingsAbout.totalrequests": "Total Requests", @@ -876,7 +874,7 @@ "components.Settings.SettingsAbout.version": "Version", "components.Settings.SettingsJobsCache.availability-sync": "Media Availability Sync", "components.Settings.SettingsJobsCache.cache": "Cache", - "components.Settings.SettingsJobsCache.cacheDescription": "Jellyseerr caches requests to external API endpoints to optimize performance and avoid making unnecessary API calls.", + "components.Settings.SettingsJobsCache.cacheDescription": "Seerr caches requests to external API endpoints to optimize performance and avoid making unnecessary API calls.", "components.Settings.SettingsJobsCache.cacheflushed": "{cachename} cache flushed.", "components.Settings.SettingsJobsCache.cachehits": "Hits", "components.Settings.SettingsJobsCache.cachekeys": "Total Keys", @@ -887,7 +885,7 @@ "components.Settings.SettingsJobsCache.canceljob": "Cancel Job", "components.Settings.SettingsJobsCache.command": "Command", "components.Settings.SettingsJobsCache.dnsCache": "DNS Cache", - "components.Settings.SettingsJobsCache.dnsCacheDescription": "Jellyseerr caches DNS lookups to optimize performance and avoid making unnecessary API calls.", + "components.Settings.SettingsJobsCache.dnsCacheDescription": "Seerr caches DNS lookups to optimize performance and avoid making unnecessary API calls.", "components.Settings.SettingsJobsCache.dnsCacheGlobalStats": "Global DNS Cache Stats", "components.Settings.SettingsJobsCache.dnsCacheGlobalStatsDescription": "These stats are aggregated across all DNS cache entries.", "components.Settings.SettingsJobsCache.dnscacheactiveaddress": "Active Address", @@ -912,7 +910,7 @@ "components.Settings.SettingsJobsCache.hits": "Hits", "components.Settings.SettingsJobsCache.image-cache-cleanup": "Image Cache Cleanup", "components.Settings.SettingsJobsCache.imagecache": "Image Cache", - "components.Settings.SettingsJobsCache.imagecacheDescription": "When enabled in settings, Jellyseerr will proxy and cache images from pre-configured external sources. Cached images are saved into your config folder. You can find the files in {appDataPath}/cache/images.", + "components.Settings.SettingsJobsCache.imagecacheDescription": "When enabled in settings, Seerr will proxy and cache images from pre-configured external sources. Cached images are saved into your config folder. You can find the files in {appDataPath}/cache/images.", "components.Settings.SettingsJobsCache.imagecachecount": "Images Cached", "components.Settings.SettingsJobsCache.imagecachesize": "Total Cache Size", "components.Settings.SettingsJobsCache.ipv4Fallbacks": "IPv4 Fallbacks", @@ -923,7 +921,7 @@ "components.Settings.SettingsJobsCache.jobcancelled": "{jobname} canceled.", "components.Settings.SettingsJobsCache.jobname": "Job Name", "components.Settings.SettingsJobsCache.jobs": "Jobs", - "components.Settings.SettingsJobsCache.jobsDescription": "Jellyseerr performs certain maintenance tasks as regularly-scheduled jobs, but they can also be manually triggered below. Manually running a job will not alter its schedule.", + "components.Settings.SettingsJobsCache.jobsDescription": "Seerr performs certain maintenance tasks as regularly-scheduled jobs, but they can also be manually triggered below. Manually running a job will not alter its schedule.", "components.Settings.SettingsJobsCache.jobsandcache": "Jobs & Cache", "components.Settings.SettingsJobsCache.jobstarted": "{jobname} started.", "components.Settings.SettingsJobsCache.jobtype": "Type", @@ -974,7 +972,7 @@ "components.Settings.SettingsMain.enableSpecialEpisodes": "Allow Special Episodes Requests", "components.Settings.SettingsMain.general": "General", "components.Settings.SettingsMain.generalsettings": "General Settings", - "components.Settings.SettingsMain.generalsettingsDescription": "Configure global and default settings for Jellyseerr.", + "components.Settings.SettingsMain.generalsettingsDescription": "Configure global and default settings for Seerr.", "components.Settings.SettingsMain.hideAvailable": "Hide Available Media", "components.Settings.SettingsMain.hideAvailableTip": "Hide available media from the discover pages but not search results", "components.Settings.SettingsMain.hideBlacklisted": "Hide Blacklisted Items", @@ -1006,11 +1004,11 @@ "components.Settings.SettingsNetwork.dnsCacheTip": "Enable caching of DNS lookups to optimize performance and avoid making unnecessary API calls", "components.Settings.SettingsNetwork.docs": "documentation", "components.Settings.SettingsNetwork.forceIpv4First": "Force IPv4 Resolution First", - "components.Settings.SettingsNetwork.forceIpv4FirstTip": "Force Jellyseerr to resolve IPv4 addresses first instead of IPv6", + "components.Settings.SettingsNetwork.forceIpv4FirstTip": "Force Seerr to resolve IPv4 addresses first instead of IPv6", "components.Settings.SettingsNetwork.network": "Network", "components.Settings.SettingsNetwork.networkDisclaimer": "Network parameters from your container/system should be used instead of these settings. See the {docs} for more information.", "components.Settings.SettingsNetwork.networksettings": "Network Settings", - "components.Settings.SettingsNetwork.networksettingsDescription": "Configure network settings for your Jellyseerr instance.", + "components.Settings.SettingsNetwork.networksettingsDescription": "Configure network settings for your Seerr instance.", "components.Settings.SettingsNetwork.proxyBypassFilter": "Proxy Ignored Addresses", "components.Settings.SettingsNetwork.proxyBypassFilterTip": "Use ',' as a separator, and '*.' as a wildcard for subdomains", "components.Settings.SettingsNetwork.proxyBypassLocalAddresses": "Bypass Proxy for Local Addresses", @@ -1023,7 +1021,7 @@ "components.Settings.SettingsNetwork.toastSettingsFailure": "Something went wrong while saving settings.", "components.Settings.SettingsNetwork.toastSettingsSuccess": "Settings saved successfully!", "components.Settings.SettingsNetwork.trustProxy": "Enable Proxy Support", - "components.Settings.SettingsNetwork.trustProxyTip": "Allow Jellyseerr to correctly register client IP addresses behind a proxy", + "components.Settings.SettingsNetwork.trustProxyTip": "Allow Seerr to correctly register client IP addresses behind a proxy", "components.Settings.SettingsNetwork.validationProxyPort": "You must provide a valid port", "components.Settings.SettingsUsers.atLeastOneAuth": "At least one authentication method must be selected.", "components.Settings.SettingsUsers.defaultPermissions": "Default Permissions", @@ -1150,8 +1148,8 @@ "components.Settings.jellyfinsettingsDescription": "Configure the settings for your {mediaServerName} server. {mediaServerName} scans your {mediaServerName} libraries to see what content is available.", "components.Settings.librariesRemaining": "Libraries Remaining: {count}", "components.Settings.manualscan": "Manual Library Scan", - "components.Settings.manualscanDescription": "Normally, this will only be run once every 24 hours. Jellyseerr will check your Plex server's recently added more aggressively. If this is your first time configuring Plex, a one-time full manual library scan is recommended!", - "components.Settings.manualscanDescriptionJellyfin": "Normally, this will only be run once every 24 hours. Jellyseerr will check your {mediaServerName} server's recently added more aggressively. If this is your first time configuring Jellyseerr, a one-time full manual library scan is recommended!", + "components.Settings.manualscanDescription": "Normally, this will only be run once every 24 hours. Seerr will check your Plex server's recently added more aggressively. If this is your first time configuring Plex, a one-time full manual library scan is recommended!", + "components.Settings.manualscanDescriptionJellyfin": "Normally, this will only be run once every 24 hours. Seerr will check your {mediaServerName} server's recently added more aggressively. If this is your first time configuring Seerr, a one-time full manual library scan is recommended!", "components.Settings.manualscanJellyfin": "Manual Library Scan", "components.Settings.mediaTypeMovie": "movie", "components.Settings.mediaTypeSeries": "series", @@ -1186,13 +1184,13 @@ "components.Settings.overrideRulesDescription": "Override rules allow you to specify properties that will be replaced if a request matches the rule.", "components.Settings.plex": "Plex", "components.Settings.plexlibraries": "Plex Libraries", - "components.Settings.plexlibrariesDescription": "The libraries Jellyseerr scans for titles. Set up and save your Plex connection settings, then click the button below if no libraries are listed.", + "components.Settings.plexlibrariesDescription": "The libraries Seerr scans for titles. Set up and save your Plex connection settings, then click the button below if no libraries are listed.", "components.Settings.plexsettings": "Plex Settings", - "components.Settings.plexsettingsDescription": "Configure the settings for your Plex server. Jellyseerr scans your Plex libraries to determine content availability.", + "components.Settings.plexsettingsDescription": "Configure the settings for your Plex server. Seerr scans your Plex libraries to determine content availability.", "components.Settings.port": "Port", "components.Settings.providerStatus": "Metadata Provider Status", "components.Settings.radarrsettings": "Radarr Settings", - "components.Settings.restartrequiredTooltip": "Jellyseerr must be restarted for changes to this setting to take effect", + "components.Settings.restartrequiredTooltip": "Seerr must be restarted for changes to this setting to take effect", "components.Settings.save": "Save Changes", "components.Settings.saving": "Saving…", "components.Settings.scan": "Sync Libraries", @@ -1219,7 +1217,7 @@ "components.Settings.syncing": "Syncing", "components.Settings.tautulliApiKey": "API Key", "components.Settings.tautulliSettings": "Tautulli Settings", - "components.Settings.tautulliSettingsDescription": "Optionally configure the settings for your Tautulli server. Jellyseerr fetches watch history data for your Plex media from Tautulli.", + "components.Settings.tautulliSettingsDescription": "Optionally configure the settings for your Tautulli server. Seerr fetches watch history data for your Plex media from Tautulli.", "components.Settings.timeout": "Timeout", "components.Settings.tip": "Tip", "components.Settings.tmdbProviderDoesnotWork": "TMDB provider does not work, please select another metadata provider", @@ -1264,7 +1262,7 @@ "components.Setup.signinWithJellyfin": "Enter your Jellyfin details", "components.Setup.signinWithPlex": "Enter your Plex details", "components.Setup.subtitle": "Get started by choosing your media server", - "components.Setup.welcome": "Welcome to Jellyseerr", + "components.Setup.welcome": "Welcome to Seerr", "components.StatusBadge.managemedia": "Manage {mediaType}", "components.StatusBadge.openinarr": "Open in {arr}", "components.StatusBadge.playonplex": "Play on {mediaServerName}", diff --git a/src/utils/plex.ts b/src/utils/plex.ts index dd16c4355d..5bf7aeafb8 100644 --- a/src/utils/plex.ts +++ b/src/utils/plex.ts @@ -58,14 +58,14 @@ class PlexOAuth { const browser = Bowser.getParser(window.navigator.userAgent); this.plexHeaders = { Accept: 'application/json', - 'X-Plex-Product': 'Jellyseerr', + 'X-Plex-Product': 'Seerr', 'X-Plex-Version': 'Plex OAuth', 'X-Plex-Client-Identifier': clientId, 'X-Plex-Model': 'Plex OAuth', 'X-Plex-Platform': browser.getBrowserName(), 'X-Plex-Platform-Version': browser.getBrowserVersion(), 'X-Plex-Device': browser.getOSName(), - 'X-Plex-Device-Name': `${browser.getBrowserName()} (Jellyseerr)`, + 'X-Plex-Device-Name': `${browser.getBrowserName()} (Seerr)`, 'X-Plex-Device-Screen-Resolution': window.screen.width + 'x' + window.screen.height, 'X-Plex-Language': 'en', From 0af453ee33ab58ac084c83945aaf62ab614e0d5b Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Tue, 7 Oct 2025 05:21:18 +0100 Subject: [PATCH 58/96] chore: add renovate bot modular configuration (#1983) --- .github/renovate.json5 | 24 +++++++++++++++++++ .github/renovate/actions.json5 | 14 +++++++++++ .github/renovate/groups.json5 | 21 ++++++++++++++++ .github/renovate/helm.json5 | 22 +++++++++++++++++ .github/renovate/labels.json5 | 29 ++++++++++++++++++++++ .github/renovate/pnpm.json5 | 11 +++++++++ .github/renovate/semanticCommits.json5 | 33 ++++++++++++++++++++++++++ renovate.json | 21 ---------------- 8 files changed, 154 insertions(+), 21 deletions(-) create mode 100644 .github/renovate.json5 create mode 100644 .github/renovate/actions.json5 create mode 100644 .github/renovate/groups.json5 create mode 100644 .github/renovate/helm.json5 create mode 100644 .github/renovate/labels.json5 create mode 100644 .github/renovate/pnpm.json5 create mode 100644 .github/renovate/semanticCommits.json5 delete mode 100644 renovate.json diff --git a/.github/renovate.json5 b/.github/renovate.json5 new file mode 100644 index 0000000000..71a90454e1 --- /dev/null +++ b/.github/renovate.json5 @@ -0,0 +1,24 @@ +{ + "$schema": "https://docs.renovatebot.com/renovate-schema.json", + "extends": [ + "config:recommended", + ":dependencyDashboard", + ":timezone(UTC)", + "docker:enableMajor", + "docker:pinDigests", + "group:nextjsMonorepo", + "group:reactMonorepo", + "group:typescript-eslintMonorepo", + "group:tailwindcssMonorepo", + "github>seerr-team/seerr//.github/renovate/actions.json5", + "github>seerr-team/seerr//.github/renovate/groups.json5", + "github>seerr-team/seerr//.github/renovate/helm.json5", + "github>seerr-team/seerr//.github/renovate/labels.json5", + "github>seerr-team/seerr//.github/renovate/pnpm.json5", + "github>seerr-team/seerr//.github/renovate/semanticCommits.json5" + ], + "dependencyDashboardTitle": "Renovate Dashboard 🤖", + "suppressNotifications": ["prEditedNotification", "prIgnoreNotification"], + "rebaseWhen": "conflicted", + "labels": ["dependencies"] +} diff --git a/.github/renovate/actions.json5 b/.github/renovate/actions.json5 new file mode 100644 index 0000000000..3e99b18075 --- /dev/null +++ b/.github/renovate/actions.json5 @@ -0,0 +1,14 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + extends: ['helpers:pinGitHubActionDigests'], + + packageRules: [ + // All GitHub Actions need manual review + { + matchManagers: ['github-actions'], + groupName: 'GitHub Actions', + minimumReleaseAge: '7 days', + }, + ], +} diff --git a/.github/renovate/groups.json5 b/.github/renovate/groups.json5 new file mode 100644 index 0000000000..73fa324862 --- /dev/null +++ b/.github/renovate/groups.json5 @@ -0,0 +1,21 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + packageRules: [ + // Node.js + { + matchPackageNames: ['node'], + matchManagers: ['dockerfile', 'npm'], + groupName: 'Node.js', + minimumReleaseAge: '7 days', + commitMessageTopic: 'Node.js', + }, + + // Database packages + { + matchPackageNames: ['pg', 'sqlite3', 'typeorm'], + groupName: 'Database', + minimumReleaseAge: '7 days', + }, + ], +} diff --git a/.github/renovate/helm.json5 b/.github/renovate/helm.json5 new file mode 100644 index 0000000000..1cbe05431d --- /dev/null +++ b/.github/renovate/helm.json5 @@ -0,0 +1,22 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + packageRules: [ + { + matchManagers: ['helm-values'], + matchFileNames: ['charts/*/values.yaml'], + }, + ], + + customManagers: [ + { + customType: 'regex', + description: 'Update appVersion in Chart.yaml to match Docker image', + fileMatch: ['(^|/)Chart\\.yaml$'], + matchStrings: [ + '#\\s+renovate:\\s+image=(?\\S*)\nappVersion:\\s+"(?\\S*)"', + ], + datasourceTemplate: 'docker', + }, + ], +} diff --git a/.github/renovate/labels.json5 b/.github/renovate/labels.json5 new file mode 100644 index 0000000000..7bb507372b --- /dev/null +++ b/.github/renovate/labels.json5 @@ -0,0 +1,29 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + packageRules: [ + // JavaScript/npm packages + { + matchManagers: ['npm'], + addLabels: ['javascript'], + }, + + // GitHub Actions + { + matchManagers: ['github-actions'], + addLabels: ['github_actions'], + }, + + // Docker images + { + matchManagers: ['dockerfile', 'docker-compose'], + addLabels: ['docker'], + }, + + // Helm charts + { + matchManagers: ['helm-values'], + addLabels: ['helm'], + }, + ], +} diff --git a/.github/renovate/pnpm.json5 b/.github/renovate/pnpm.json5 new file mode 100644 index 0000000000..2ec1f41eaf --- /dev/null +++ b/.github/renovate/pnpm.json5 @@ -0,0 +1,11 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + // Run pnpm dedupe after dependency updates + postUpdateOptions: ['pnpmDedupe'], + + lockFileMaintenance: { + enabled: true, + }, + +} diff --git a/.github/renovate/semanticCommits.json5 b/.github/renovate/semanticCommits.json5 new file mode 100644 index 0000000000..23e7763918 --- /dev/null +++ b/.github/renovate/semanticCommits.json5 @@ -0,0 +1,33 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + packageRules: [ + // Default for all dependencies + { + matchPackagePatterns: ['*'], + semanticCommitType: 'chore', + semanticCommitScope: 'deps', + }, + + // Node.js runtime + { + matchPackageNames: ['node'], + semanticCommitType: 'build', + semanticCommitScope: 'node', + }, + + // GitHub Actions + { + matchManagers: ['github-actions'], + semanticCommitType: 'ci', + semanticCommitScope: 'actions', + }, + + // Docker + { + matchManagers: ['dockerfile'], + semanticCommitType: 'build', + semanticCommitScope: 'docker', + }, + ], +} diff --git a/renovate.json b/renovate.json deleted file mode 100644 index bc68da3a10..0000000000 --- a/renovate.json +++ /dev/null @@ -1,21 +0,0 @@ -{ - "$schema": "https://docs.renovatebot.com/renovate-schema.json", - "extends": [ - "config:js-app", - "group:allNonMajor", - "docker:disableMajor", - "helpers:disableTypesNodeMajor" - ], - "packageRules": [ - { - "matchManagers": ["github-actions"], - "groupName": "GitHub Actions", - "groupSlug": "github-actions" - }, - { - "matchPackageNames": ["node"], - "groupName": "Node.js", - "groupSlug": "node" - } - ] -} From 3de457f5bbe0d0e307a13c57f83a68adce784fa0 Mon Sep 17 00:00:00 2001 From: Ryan Cohen Date: Tue, 7 Oct 2025 10:48:51 -0600 Subject: [PATCH 59/96] docs: update docs links to docs.seerr.dev (#1990) [skip ci] --- README.md | 4 ++-- gen-docs/README.md | 2 +- gen-docs/docusaurus.config.ts | 2 +- gen-docs/static/CNAME | 2 +- server/index.ts | 2 +- .../Settings/Notifications/NotificationsWebhook/index.tsx | 4 ++-- src/components/Settings/SettingsAbout/index.tsx | 4 ++-- 7 files changed, 10 insertions(+), 10 deletions(-) diff --git a/README.md b/README.md index aec85a8138..c13a18cfd9 100644 --- a/README.md +++ b/README.md @@ -34,7 +34,7 @@ With more features on the way! Check out our [issue tracker](/../../issues) to s Check out our documentation for instructions on how to install and run Seerr: -https://docs.jellyseerr.dev/getting-started/ +https://docs.seerr.dev/getting-started/ ### Packages: @@ -48,7 +48,7 @@ Nix: [Nixpkg](https://search.nixos.org/packages?channel=unstable&show=jellyseerr ## Support -- Check out the [Seerr Documentation](https://docs.jellyseerr.dev) before asking for help. Your question might already be in the docs! +- Check out the [Seerr Documentation](https://docs.seerr.dev) before asking for help. Your question might already be in the docs! - You can get support on [Discord](https://discord.gg/seerr). - You can ask questions in the Help category of our [GitHub Discussions](/../../discussions). - Bug reports and feature requests can be submitted via [GitHub Issues](/../../issues). diff --git a/gen-docs/README.md b/gen-docs/README.md index 231d9a3e4f..46a19b58a1 100644 --- a/gen-docs/README.md +++ b/gen-docs/README.md @@ -2,7 +2,7 @@ Jellyseerr docs is built using [Docusaurus](https://docusaurus.io/), a modern static website generator. -Jellyseerr docs will be available at [docs.jellyseerr.dev](https://docs.jellyseerr.dev). +Jellyseerr docs will be available at [docs.seerr.dev](https://docs.seerr.dev). ### Installation diff --git a/gen-docs/docusaurus.config.ts b/gen-docs/docusaurus.config.ts index 08a1fe1458..a5c8ee72ee 100644 --- a/gen-docs/docusaurus.config.ts +++ b/gen-docs/docusaurus.config.ts @@ -7,7 +7,7 @@ const config: Config = { tagline: 'One Stop Solution for all your media request needs', favicon: 'img/favicon.ico', - url: 'https://docs.jellyseerr.dev', + url: 'https://docs.seerr.dev', baseUrl: '/', trailingSlash: false, diff --git a/gen-docs/static/CNAME b/gen-docs/static/CNAME index db1468fbc6..cf91dc24f7 100644 --- a/gen-docs/static/CNAME +++ b/gen-docs/static/CNAME @@ -1 +1 @@ -docs.jellyseerr.dev \ No newline at end of file +docs.seerr.dev diff --git a/server/index.ts b/server/index.ts index b98e3b2fae..a817eb102a 100644 --- a/server/index.ts +++ b/server/index.ts @@ -52,7 +52,7 @@ const handle = app.getRequestHandler(); if (!appDataPermissions()) { logger.error( - 'Something went wrong while checking config folder! Please ensure the config folder is set up properly.\nhttps://docs.jellyseerr.dev/getting-started' + 'Something went wrong while checking config folder! Please ensure the config folder is set up properly.\nhttps://docs.seerr.dev/getting-started' ); } diff --git a/src/components/Settings/Notifications/NotificationsWebhook/index.tsx b/src/components/Settings/Notifications/NotificationsWebhook/index.tsx index 2c3d436d2c..a3dc9f05c9 100644 --- a/src/components/Settings/Notifications/NotificationsWebhook/index.tsx +++ b/src/components/Settings/Notifications/NotificationsWebhook/index.tsx @@ -288,7 +288,7 @@ const NotificationsWebhook = () => { {values.supportVariables && (
@@ -376,7 +376,7 @@ const NotificationsWebhook = () => { {intl.formatMessage(messages.resetPayload)} diff --git a/src/components/Settings/SettingsAbout/index.tsx b/src/components/Settings/SettingsAbout/index.tsx index 795ac9a139..c129b22141 100644 --- a/src/components/Settings/SettingsAbout/index.tsx +++ b/src/components/Settings/SettingsAbout/index.tsx @@ -157,12 +157,12 @@ const SettingsAbout = () => { - https://docs.jellyseerr.dev + https://docs.seerr.dev From 3ff1c061b88ef989046a3d3a958f72bc7301e823 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Tue, 7 Oct 2025 20:44:00 +0300 Subject: [PATCH 60/96] docs: fix docusaurus config for seerr (#1991) Signed-off-by: Ludovic Ortega --- gen-docs/docusaurus.config.ts | 19 +++++++++---------- 1 file changed, 9 insertions(+), 10 deletions(-) diff --git a/gen-docs/docusaurus.config.ts b/gen-docs/docusaurus.config.ts index a5c8ee72ee..a7b7366ccd 100644 --- a/gen-docs/docusaurus.config.ts +++ b/gen-docs/docusaurus.config.ts @@ -3,7 +3,7 @@ import type { Config } from '@docusaurus/types'; import { themes as prismThemes } from 'prism-react-renderer'; const config: Config = { - title: 'Jellyseerr', + title: 'Seerr', tagline: 'One Stop Solution for all your media request needs', favicon: 'img/favicon.ico', @@ -11,8 +11,8 @@ const config: Config = { baseUrl: '/', trailingSlash: false, - organizationName: 'fallenbagel', - projectName: 'Jellyseerr', + organizationName: 'seerr-team', + projectName: 'seerr', deploymentBranch: 'gh-pages', onBrokenLinks: 'throw', @@ -31,8 +31,7 @@ const config: Config = { sidebarPath: './sidebars.ts', routeBasePath: '/', path: '../docs', - editUrl: - 'https://github.com/fallenbagel/jellyseerr/edit/develop/docs/', + editUrl: 'https://github.com/seerr-team/seerr/edit/develop/docs/', }, pages: false, theme: { @@ -64,7 +63,7 @@ const config: Config = { }, navbar: { logo: { - alt: 'Jellyseerr', + alt: 'Seerr', src: 'img/logo.svg', }, items: [ @@ -74,7 +73,7 @@ const config: Config = { position: 'right', }, { - href: 'https://github.com/fallenbagel/jellyseerr', + href: 'https://github.com/seerr-team/seerr', label: 'GitHub', position: 'right', }, @@ -101,7 +100,7 @@ const config: Config = { }, { label: 'GitHub', - href: 'https://github.com/fallenbagel/jellyseerr', + href: 'https://github.com/seerr-team/seerr', }, ], }, @@ -114,12 +113,12 @@ const config: Config = { }, { label: 'Github Discussions', - href: 'https://github.com/fallenbagel/jellyseerr/discussions', + href: 'https://github.com/seerr-team/seerr/discussions', }, ], }, ], - copyright: `Copyright © ${new Date().getFullYear()} Jellyseerr. Built with Docusaurus.`, + copyright: `Copyright © ${new Date().getFullYear()} Seerr. Built with Docusaurus.`, }, prism: { theme: prismThemes.shadesOfPurple, From 2e6a19d3b55e172d48bbf2e0ea38bf821b44c508 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Tue, 7 Oct 2025 19:55:56 +0100 Subject: [PATCH 61/96] ci: updated all workflows to be pinned to commit hashes ahead of renovate connection (#1989) * ci: updated all workflows to be pineed to commit hashes ahead of renovate connection * ci: update doc links regex * ci: bump version for codeql-action * ci: bump version for action/cache to v4.2.0 * ci: adding package-manager-cache: false to the node v5 setup steps * ci: remove the --include to test precedence as it was overriding * chore: added missing @ from commit hash * ci: updates to shas to bring up to latest, also update to renovate config to account for major versions * chore: update renovate global minimum age settings * updated node sha * Apply suggestion from @M0NsTeRRR Co-authored-by: Ludovic Ortega * Apply suggestion from @M0NsTeRRR Co-authored-by: Ludovic Ortega * Apply suggestion from @M0NsTeRRR Co-authored-by: Ludovic Ortega * Apply suggestion from @M0NsTeRRR * Apply suggestion from @M0NsTeRRR --------- Co-authored-by: Ludovic Ortega --- .github/renovate.json5 | 6 ++--- .github/renovate/actions.json5 | 1 - .github/renovate/docker.json5 | 8 +++++++ .github/renovate/groups.json5 | 2 -- .github/renovate/helm.json5 | 1 + .github/workflows/ci.yml | 26 ++++++++++---------- .github/workflows/codeql.yml | 8 +++---- .github/workflows/conflict_labeler.yml | 2 +- .github/workflows/cypress.yml | 11 +++++---- .github/workflows/docs-deploy.yml | 13 +++++----- .github/workflows/docs-link-check.yml | 15 ++++-------- .github/workflows/helm.yml | 22 ++++++++--------- .github/workflows/lint-helm-charts.yml | 8 +++---- .github/workflows/preview.yml | 18 +++++++------- .github/workflows/release.yml | 33 +++++++++++++------------- .github/workflows/stale.yml | 2 +- .github/workflows/test-docs-deploy.yml | 9 +++---- .github/workflows/trivy-scan.yml | 6 ++--- Dockerfile | 4 ++-- Dockerfile.local | 2 +- 20 files changed, 101 insertions(+), 96 deletions(-) create mode 100644 .github/renovate/docker.json5 diff --git a/.github/renovate.json5 b/.github/renovate.json5 index 71a90454e1..1c47932c62 100644 --- a/.github/renovate.json5 +++ b/.github/renovate.json5 @@ -4,13 +4,12 @@ "config:recommended", ":dependencyDashboard", ":timezone(UTC)", - "docker:enableMajor", - "docker:pinDigests", "group:nextjsMonorepo", "group:reactMonorepo", "group:typescript-eslintMonorepo", "group:tailwindcssMonorepo", "github>seerr-team/seerr//.github/renovate/actions.json5", + "github>seerr-team/seerr//.github/renovate/docker.json5", "github>seerr-team/seerr//.github/renovate/groups.json5", "github>seerr-team/seerr//.github/renovate/helm.json5", "github>seerr-team/seerr//.github/renovate/labels.json5", @@ -20,5 +19,6 @@ "dependencyDashboardTitle": "Renovate Dashboard 🤖", "suppressNotifications": ["prEditedNotification", "prIgnoreNotification"], "rebaseWhen": "conflicted", - "labels": ["dependencies"] + "labels": ["dependencies"], + "minimumReleaseAge": "7 days" } diff --git a/.github/renovate/actions.json5 b/.github/renovate/actions.json5 index 3e99b18075..77671a7d65 100644 --- a/.github/renovate/actions.json5 +++ b/.github/renovate/actions.json5 @@ -8,7 +8,6 @@ { matchManagers: ['github-actions'], groupName: 'GitHub Actions', - minimumReleaseAge: '7 days', }, ], } diff --git a/.github/renovate/docker.json5 b/.github/renovate/docker.json5 new file mode 100644 index 0000000000..9817e86a19 --- /dev/null +++ b/.github/renovate/docker.json5 @@ -0,0 +1,8 @@ +{ + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + + extends: [ + 'docker:enableMajor', + 'docker:pinDigests' + ], +} \ No newline at end of file diff --git a/.github/renovate/groups.json5 b/.github/renovate/groups.json5 index 73fa324862..97dbe6703a 100644 --- a/.github/renovate/groups.json5 +++ b/.github/renovate/groups.json5 @@ -7,7 +7,6 @@ matchPackageNames: ['node'], matchManagers: ['dockerfile', 'npm'], groupName: 'Node.js', - minimumReleaseAge: '7 days', commitMessageTopic: 'Node.js', }, @@ -15,7 +14,6 @@ { matchPackageNames: ['pg', 'sqlite3', 'typeorm'], groupName: 'Database', - minimumReleaseAge: '7 days', }, ], } diff --git a/.github/renovate/helm.json5 b/.github/renovate/helm.json5 index 1cbe05431d..e2f6e53a59 100644 --- a/.github/renovate/helm.json5 +++ b/.github/renovate/helm.json5 @@ -5,6 +5,7 @@ { matchManagers: ['helm-values'], matchFileNames: ['charts/*/values.yaml'], + minimumReleaseAge: '0' }, ], diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index de10883657..838b05be4c 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -26,12 +26,12 @@ jobs: container: node:22-alpine steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false - name: Pnpm Setup - uses: pnpm/action-setup@v4 + uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 - name: Get pnpm store directory shell: sh @@ -39,7 +39,7 @@ jobs: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV - name: Setup pnpm cache - uses: actions/cache@v4 + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 with: path: ${{ env.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} @@ -75,7 +75,7 @@ jobs: runs-on: ${{ matrix.runner }} steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false @@ -84,10 +84,10 @@ jobs: run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 + uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - name: Warm cache (no push) — ${{ matrix.platform }} - uses: docker/build-push-action@v6 + uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . file: ./Dockerfile @@ -111,7 +111,7 @@ jobs: id-token: write steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false @@ -120,16 +120,16 @@ jobs: run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 + uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - name: Log in to Docker Hub - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: registry: ghcr.io username: ${{ github.repository_owner }} @@ -137,7 +137,7 @@ jobs: - name: Extract metadata id: meta - uses: docker/metadata-action@v5 + uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 with: images: | ${{ github.repository }} @@ -149,7 +149,7 @@ jobs: org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} - name: Build & Push (multi-arch, single tag) - uses: docker/build-push-action@v6 + uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . file: ./Dockerfile @@ -184,7 +184,7 @@ jobs: fi - name: Post Status to Discord - uses: sarisia/actions-status-discord@v1 + uses: sarisia/actions-status-discord@58667542682a27f270460405363e3a982f57a7ee # v1.0.0 with: webhook: ${{ secrets.DISCORD_WEBHOOK }} status: ${{ steps.status.outputs.status }} diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index d019b2f997..199b830dfd 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -37,20 +37,20 @@ jobs: language: [actions, javascript] steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false - name: Initialize CodeQL - uses: github/codeql-action/init@v3 + uses: github/codeql-action/init@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 with: languages: ${{ matrix.language }} queries: +security-and-quality - name: Autobuild - uses: github/codeql-action/autobuild@v3 + uses: github/codeql-action/autobuild@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@v3 + uses: github/codeql-action/analyze@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 with: category: '/language:${{ matrix.language }}' diff --git a/.github/workflows/conflict_labeler.yml b/.github/workflows/conflict_labeler.yml index b198a24cc6..4709c67ecb 100644 --- a/.github/workflows/conflict_labeler.yml +++ b/.github/workflows/conflict_labeler.yml @@ -27,7 +27,7 @@ jobs: pull-requests: write steps: - name: Apply label - uses: eps1lon/actions-label-merge-conflict@v3 + uses: eps1lon/actions-label-merge-conflict@1df065ebe6e3310545d4f4c4e862e43bdca146f0 # v3.0.3 with: dirtyLabel: 'merge conflict' commentOnDirty: 'This pull request has merge conflicts. Please resolve the conflicts so the PR can be successfully reviewed and merged.' diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index ae12d01f53..76ffa21517 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -37,23 +37,24 @@ jobs: runs-on: ubuntu-24.04 steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false - name: Set up Node.js - uses: actions/setup-node@v4 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version-file: package.json + package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@v4 + uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 - name: Install dependencies run: pnpm install --frozen-lockfile - name: Setup cypress cache - uses: actions/cache@v4 + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 with: path: ~/.cache/Cypress key: ${{ runner.os }}-cypress-store-${{ hashFiles('**/pnpm-lock.yaml') }} @@ -66,7 +67,7 @@ jobs: run: pnpm exec cypress install - name: Cypress run - uses: cypress-io/github-action@v6 + uses: cypress-io/github-action@b8ba51a856ba5f4c15cf39007636d4ab04f23e3c # v6.10.2 with: install: false build: pnpm cypress:build diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index bd54722ecf..fc98ab7935 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -22,18 +22,19 @@ jobs: name: Build Docusaurus runs-on: ubuntu-24.04 steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Set up Node.js - uses: actions/setup-node@v4 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version-file: package.json + package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@v4 + uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 - name: Get pnpm store directory shell: sh @@ -41,7 +42,7 @@ jobs: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV - name: Setup pnpm cache - uses: actions/cache@v4 + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 with: path: ${{ env.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} @@ -58,7 +59,7 @@ jobs: run: pnpm build - name: Upload Build Artifact - uses: actions/upload-pages-artifact@v4 + uses: actions/upload-pages-artifact@7b1f4a764d45c48632c6b24a0339c27f5614fb0b6 # v4.0.0 with: path: gen-docs/build @@ -76,4 +77,4 @@ jobs: steps: - name: Deploy to GitHub Pages id: deployment - uses: actions/deploy-pages@v4 + uses: actions/deploy-pages@d6db90164ac5ed86f2b6aed7e0febac5b3c0c03e # v4.0.5 diff --git a/.github/workflows/docs-link-check.yml b/.github/workflows/docs-link-check.yml index 6fd5442f59..26f71ca428 100644 --- a/.github/workflows/docs-link-check.yml +++ b/.github/workflows/docs-link-check.yml @@ -36,27 +36,22 @@ jobs: steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Run Lychee link checker - uses: lycheeverse/lychee-action@v2 + uses: lycheeverse/lychee-action@885c65f3dc543b57c898c8099f4e08c8afd178a2 # v2.6.1 with: fail: false args: >- --verbose --no-progress --accept 200..204,300..304,307,308,404,429,999 - --include '^(http|https)://.*' --exclude '^file://' - --exclude '^https?://localhost' - --exclude '^https?://127\.0\.0\.1' - --exclude '^https?://0\.0\.0\.0' - --exclude '^https?://\[\:\:1\]' - --exclude '^https?://\[\:\:\]' - --exclude '^https?://support.discord.com' + --exclude '^https?://(localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|\[::\])' + --exclude '^https?://support\.discord\.com' './docs/**/*.md' './docs/**/*.mdx' './gen-docs/**/*.md' @@ -65,7 +60,7 @@ jobs: GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - name: Upload Lychee report - uses: actions/upload-artifact@v4 + uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 with: name: lychee-report path: | diff --git a/.github/workflows/helm.yml b/.github/workflows/helm.yml index 2e49b36cfa..48df8e1e99 100644 --- a/.github/workflows/helm.yml +++ b/.github/workflows/helm.yml @@ -28,19 +28,19 @@ jobs: has_artifacts: ${{ steps.check-artifacts.outputs.has_artifacts }} steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Install helm - uses: azure/setup-helm@v4 + uses: azure/setup-helm@1a275c3b69536ee54be43f2070a358922e12c8d4 # v4.3.1 - name: Install Oras - uses: oras-project/setup-oras@v1 + uses: oras-project/setup-oras@22ce207df3b08e061f537244349aac6ae1d214f6 # v1.2.4 - name: Login to GitHub Container Registry - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: registry: ghcr.io username: ${{ github.actor }} @@ -76,7 +76,7 @@ jobs: fi - name: Upload artifacts - uses: actions/upload-artifact@v4 + uses: actions/upload-artifact@c7d193f32edcb7bfad88892161225aeda64e9392 # v4.0.0 if: steps.check-artifacts.outputs.has_artifacts == 'true' with: name: artifacts @@ -93,28 +93,28 @@ jobs: if: needs.package-helm-chart.outputs.has_artifacts == 'true' steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Install helm - uses: azure/setup-helm@v4 + uses: azure/setup-helm@1a275c3b69536ee54be43f2070a358922e12c8d4 # v4.3.1 - name: Install Oras - uses: oras-project/setup-oras@v1 + uses: oras-project/setup-oras@22ce207df3b08e061f537244349aac6ae1d214f6 # v1.2.4 - name: Install Cosign - uses: sigstore/cosign-installer@v3 + uses: sigstore/cosign-installer@d7543c93d881b35a8faa02e8e3605f69b7a1ce62 # v3.10.0 - name: Downloads artifacts - uses: actions/download-artifact@v4 + uses: actions/download-artifact@634f93cb2916e3fdff6788551b99b062d0335ce0 # v5.0.0 with: name: artifacts path: .cr-release-packages/ - name: Login to GitHub Container Registry - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: registry: ghcr.io username: ${{ github.actor }} diff --git a/.github/workflows/lint-helm-charts.yml b/.github/workflows/lint-helm-charts.yml index 461158f234..b0533fbd0c 100644 --- a/.github/workflows/lint-helm-charts.yml +++ b/.github/workflows/lint-helm-charts.yml @@ -28,19 +28,19 @@ jobs: contents: read steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Set up Helm - uses: azure/setup-helm@v4 + uses: azure/setup-helm@1a275c3b69536ee54be43f2070a358922e12c8d4 # v4.3.1 - name: Set up chart-testing - uses: helm/chart-testing-action@v2 + uses: helm/chart-testing-action@0d28d3144d3a25ea2cc349d6e59901c4ff469b3b # v2.7.0 - name: Ensure documentation is updated - uses: docker://jnorwood/helm-docs:v1.14.2 + uses: docker://jnorwood/helm-docs@sha256:7e562b49ab6b1dbc50c3da8f2dd6ffa8a5c6bba327b1c6335cc15ce29267979c # v1.14.2 - name: Run chart-testing (list-changed) id: list-changed diff --git a/.github/workflows/preview.yml b/.github/workflows/preview.yml index 4b86393cea..edaac172a0 100644 --- a/.github/workflows/preview.yml +++ b/.github/workflows/preview.yml @@ -30,7 +30,7 @@ jobs: runs-on: ${{ matrix.runner }} steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false @@ -39,7 +39,7 @@ jobs: run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 + uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - name: Derive preview version from tag id: ver @@ -52,7 +52,7 @@ jobs: echo "Building preview version: ${VER}" - name: Warm cache (no push) — ${{ matrix.platform }} - uses: docker/build-push-action@v6 + uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . file: ./Dockerfile @@ -76,7 +76,7 @@ jobs: id-token: write steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false @@ -85,16 +85,16 @@ jobs: run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 + uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - name: Log in to Docker Hub - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: registry: ghcr.io username: ${{ github.repository_owner }} @@ -112,7 +112,7 @@ jobs: - name: Extract metadata id: meta - uses: docker/metadata-action@v5 + uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 with: images: | ${{ github.repository }} @@ -124,7 +124,7 @@ jobs: org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} - name: Build & Push (multi-arch, single tag) - uses: docker/build-push-action@v6 + uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . file: ./Dockerfile diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 2baa238547..49bc2ff67f 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -23,18 +23,19 @@ jobs: new_release_version: ${{ steps.release.outputs.new_release_version }} steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Set up Node.js - uses: actions/setup-node@v4 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version-file: package.json + package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@v4 + uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 - name: Get pnpm store directory shell: sh @@ -42,7 +43,7 @@ jobs: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV - name: Setup pnpm cache - uses: actions/cache@v4 + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 with: path: ${{ env.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} @@ -54,7 +55,7 @@ jobs: - name: Release id: release - uses: cycjimmy/semantic-release-action@v5 + uses: cycjimmy/semantic-release-action@9cc899c47e6841430bbaedb43de1560a568dfd16 # v5.0.0 with: extra_plugins: | @semantic-release/git@10 @@ -79,7 +80,7 @@ jobs: runs-on: ${{ matrix.runner }} steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false @@ -88,10 +89,10 @@ jobs: run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 + uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - name: Warm cache (no push) — ${{ matrix.platform }} - uses: docker/build-push-action@v6 + uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . file: ./Dockerfile @@ -116,7 +117,7 @@ jobs: packages: write steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: persist-credentials: false @@ -125,16 +126,16 @@ jobs: run: echo "TIMESTAMP=$(git log -1 --pretty=%ct)" >> "$GITHUB_OUTPUT" - name: Set up Docker Buildx - uses: docker/setup-buildx-action@v3 + uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - name: Log in to Docker Hub - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: username: ${{ secrets.DOCKER_USERNAME }} password: ${{ secrets.DOCKER_TOKEN }} - name: Log in to GitHub Container Registry - uses: docker/login-action@v3 + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 with: registry: ghcr.io username: ${{ github.repository_owner }} @@ -142,7 +143,7 @@ jobs: - name: Extract metadata id: meta - uses: docker/metadata-action@v5 + uses: docker/metadata-action@c1e51972afc2121e065aed6d45c65596fe445f3f # v5.8.0 with: images: | ${{ github.repository }} @@ -153,7 +154,7 @@ jobs: org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} - name: Build & Push (multi-arch, single tag) - uses: docker/build-push-action@v6 + uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . file: ./Dockerfile @@ -191,7 +192,7 @@ jobs: runs-on: ubuntu-24.04 steps: - name: Get Build Job Status - uses: technote-space/workflow-conclusion-action@v3 + uses: technote-space/workflow-conclusion-action@45ce8e0eb155657ab8ccf346ade734257fd196a5 # v3.0.3 - name: Combine Job Status id: status @@ -204,7 +205,7 @@ jobs: fi - name: Post Status to Discord - uses: sarisia/actions-status-discord@v1 + uses: sarisia/actions-status-discord@58667542682a27f270460405363e3a982f57a7ee # v1.0.0 with: webhook: ${{ secrets.DISCORD_WEBHOOK }} status: ${{ steps.status.outputs.status }} diff --git a/.github/workflows/stale.yml b/.github/workflows/stale.yml index 3a4ce1099d..4ccd7c88cc 100644 --- a/.github/workflows/stale.yml +++ b/.github/workflows/stale.yml @@ -21,7 +21,7 @@ jobs: issues: write pull-requests: write steps: - - uses: actions/stale@v10.1.0 + - uses: actions/stale@5f858e3efba33a5ca4407a664cc011ad407f2008 # v10.1.0 with: any-of-labels: "pending author's response" exempt-issue-labels: 'confirmed' diff --git a/.github/workflows/test-docs-deploy.yml b/.github/workflows/test-docs-deploy.yml index 323bb05043..1fb49859dc 100644 --- a/.github/workflows/test-docs-deploy.yml +++ b/.github/workflows/test-docs-deploy.yml @@ -24,18 +24,19 @@ jobs: permissions: contents: read steps: - - uses: actions/checkout@v4 + - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Set up Node.js - uses: actions/setup-node@v4 + uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 with: node-version-file: package.json + package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@v4 + uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 - name: Get pnpm store directory shell: sh @@ -43,7 +44,7 @@ jobs: echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV - name: Setup pnpm cache - uses: actions/cache@v4 + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 with: path: ${{ env.STORE_PATH }} key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml index 5832f7310a..2f5dd1dc05 100644 --- a/.github/workflows/trivy-scan.yml +++ b/.github/workflows/trivy-scan.yml @@ -34,13 +34,13 @@ jobs: steps: - name: Checkout - uses: actions/checkout@v4 + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: fetch-depth: 0 persist-credentials: false - name: Cache Trivy DB - uses: actions/cache@v4 + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 with: path: .trivycache key: trivy-${{ runner.os }}-${{ hashFiles('**/Dockerfile') }} @@ -56,6 +56,6 @@ jobs: ignore-unfixed: true - name: Upload SARIF to code scanning - uses: github/codeql-action/upload-sarif@v3 + uses: github/codeql-action/upload-sarif@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 with: sarif_file: trivy.sarif diff --git a/Dockerfile b/Dockerfile index 650027e45e..9bb6853b95 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM node:22-alpine AS build_image +FROM node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 AS build_image ARG SOURCE_DATE_EPOCH ARG TARGETPLATFORM @@ -33,7 +33,7 @@ RUN pnpm prune --prod --ignore-scripts && \ touch config/DOCKER && \ echo "{\"commitTag\": \"${COMMIT_TAG}\"}" > committag.json -FROM node:22-alpine +FROM node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 ENV PNPM_HOME="/pnpm" ENV PATH="$PNPM_HOME:$PATH" diff --git a/Dockerfile.local b/Dockerfile.local index 8d0ce3f33f..1cefe8f29e 100644 --- a/Dockerfile.local +++ b/Dockerfile.local @@ -1,4 +1,4 @@ -FROM node:22-alpine +FROM node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 ENV PNPM_HOME="/pnpm" ENV PATH="$PNPM_HOME:$PATH" From 393cb1a4ce151f0621dae9cae65ded27ef5d3a2b Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Tue, 7 Oct 2025 22:23:26 +0300 Subject: [PATCH 62/96] chore(renovate): fix trivy action tag (#1993) [skip-ci] Signed-off-by: Ludovic Ortega --- .github/workflows/docs-link-check.yml | 110 +++++++++++++------------- .github/workflows/trivy-scan.yml | 100 +++++++++++------------ 2 files changed, 105 insertions(+), 105 deletions(-) diff --git a/.github/workflows/docs-link-check.yml b/.github/workflows/docs-link-check.yml index 26f71ca428..6f5363de72 100644 --- a/.github/workflows/docs-link-check.yml +++ b/.github/workflows/docs-link-check.yml @@ -3,67 +3,67 @@ name: Check Docs Links on: - pull_request: - branches: - - '*' - paths: - - 'docs/**' - - 'gen-docs/**' - - '.github/workflows/docs-link-check.yml' - push: - branches: - - develop - paths: - - 'docs/**' - - 'gen-docs/**' - - '.github/workflows/docs-link-check.yml' - schedule: - - cron: '50 7 * * 5' - workflow_dispatch: + pull_request: + branches: + - '*' + paths: + - 'docs/**' + - 'gen-docs/**' + - '.github/workflows/docs-link-check.yml' + push: + branches: + - develop + paths: + - 'docs/**' + - 'gen-docs/**' + - '.github/workflows/docs-link-check.yml' + schedule: + - cron: '50 7 * * 5' + workflow_dispatch: permissions: - contents: read + contents: read concurrency: - group: docs-link-check-${{ github.ref }} - cancel-in-progress: true + group: docs-link-check-${{ github.ref }} + cancel-in-progress: true jobs: - link-check: - name: Verify external links in Markdown and MDX - runs-on: ubuntu-24.04 - timeout-minutes: 20 + link-check: + name: Verify external links in Markdown and MDX + runs-on: ubuntu-24.04 + timeout-minutes: 20 - steps: - - name: Checkout - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - with: - fetch-depth: 0 - persist-credentials: false + steps: + - name: Checkout + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + with: + fetch-depth: 0 + persist-credentials: false - - name: Run Lychee link checker - uses: lycheeverse/lychee-action@885c65f3dc543b57c898c8099f4e08c8afd178a2 # v2.6.1 - with: - fail: false - args: >- - --verbose - --no-progress - --accept 200..204,300..304,307,308,404,429,999 - --exclude '^file://' - --exclude '^https?://(localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|\[::\])' - --exclude '^https?://support\.discord\.com' - './docs/**/*.md' - './docs/**/*.mdx' - './gen-docs/**/*.md' - './gen-docs/**/*.mdx' - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Run Lychee link checker + uses: lycheeverse/lychee-action@885c65f3dc543b57c898c8099f4e08c8afd178a2 # v2.6.1 + with: + fail: false + args: >- + --verbose + --no-progress + --accept 200..204,300..304,307,308,404,429,999 + --exclude '^file://' + --exclude '^https?://(localhost|127\.0\.0\.1|0\.0\.0\.0|\[::1\]|\[::\])' + --exclude '^https?://support\.discord\.com' + './docs/**/*.md' + './docs/**/*.mdx' + './gen-docs/**/*.md' + './gen-docs/**/*.mdx' + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} - - name: Upload Lychee report - uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 - with: - name: lychee-report - path: | - lychee/out.md - lychee/results.json - if-no-files-found: ignore + - name: Upload Lychee report + uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 + with: + name: lychee-report + path: | + lychee/out.md + lychee/results.json + if-no-files-found: ignore diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml index 2f5dd1dc05..008c648623 100644 --- a/.github/workflows/trivy-scan.yml +++ b/.github/workflows/trivy-scan.yml @@ -3,59 +3,59 @@ name: Trivy Container Vulnerability Scan on: - workflow_run: - workflows: - - Seerr Release - types: - - completed - schedule: - - cron: '50 7 * * 5' - workflow_dispatch: + workflow_run: + workflows: + - Seerr Release + types: + - completed + schedule: + - cron: '50 7 * * 5' + workflow_dispatch: permissions: - contents: read + contents: read concurrency: - group: trivy-scan-${{ github.ref }} - cancel-in-progress: true + group: trivy-scan-${{ github.ref }} + cancel-in-progress: true jobs: - trivy: - if: ${{ github.event_name != 'workflow_run' || github.event.workflow_run.conclusion == 'success' }} - name: Scan latest container image - runs-on: ubuntu-24.04 - - permissions: - contents: read - security-events: write - - env: - TRIVY_CACHE_DIR: .trivycache - - steps: - - name: Checkout - uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 - with: - fetch-depth: 0 - persist-credentials: false - - - name: Cache Trivy DB - uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 - with: - path: .trivycache - key: trivy-${{ runner.os }}-${{ hashFiles('**/Dockerfile') }} - restore-keys: | - trivy-${{ runner.os }}- - - - name: Run Trivy image scan - uses: aquasecurity/trivy-action@b6643a29fecd7f34b3597bc6acb0a98b03d33ff8 # v0.33.1 - with: - image-ref: ghcr.io/${{ github.repository }}:latest - format: sarif - output: trivy.sarif - ignore-unfixed: true - - - name: Upload SARIF to code scanning - uses: github/codeql-action/upload-sarif@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 - with: - sarif_file: trivy.sarif + trivy: + if: ${{ github.event_name != 'workflow_run' || github.event.workflow_run.conclusion == 'success' }} + name: Scan latest container image + runs-on: ubuntu-24.04 + + permissions: + contents: read + security-events: write + + env: + TRIVY_CACHE_DIR: .trivycache + + steps: + - name: Checkout + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + with: + fetch-depth: 0 + persist-credentials: false + + - name: Cache Trivy DB + uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 + with: + path: .trivycache + key: trivy-${{ runner.os }}-${{ hashFiles('**/Dockerfile') }} + restore-keys: | + trivy-${{ runner.os }}- + + - name: Run Trivy image scan + uses: aquasecurity/trivy-action@b6643a29fecd7f34b3597bc6acb0a98b03d33ff8 # 0.33.1 + with: + image-ref: ghcr.io/${{ github.repository }}:latest + format: sarif + output: trivy.sarif + ignore-unfixed: true + + - name: Upload SARIF to code scanning + uses: github/codeql-action/upload-sarif@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 + with: + sarif_file: trivy.sarif From 5f46ee8af67f294f13a00176cb7b2178f2bdb45f Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Tue, 7 Oct 2025 22:27:45 +0100 Subject: [PATCH 63/96] chore: update renovate bot logic to remove pin from compose files and charts (#1999) --- .github/renovate/docker.json5 | 9 ++++++++- .github/renovate/helm.json5 | 3 ++- 2 files changed, 10 insertions(+), 2 deletions(-) diff --git a/.github/renovate/docker.json5 b/.github/renovate/docker.json5 index 9817e86a19..7c97fefc4a 100644 --- a/.github/renovate/docker.json5 +++ b/.github/renovate/docker.json5 @@ -5,4 +5,11 @@ 'docker:enableMajor', 'docker:pinDigests' ], -} \ No newline at end of file + + packageRules: [ + { + matchManagers: ['docker-compose'], + pinDigests: false, + }, + ], +} diff --git a/.github/renovate/helm.json5 b/.github/renovate/helm.json5 index e2f6e53a59..0b479c3a60 100644 --- a/.github/renovate/helm.json5 +++ b/.github/renovate/helm.json5 @@ -5,7 +5,8 @@ { matchManagers: ['helm-values'], matchFileNames: ['charts/*/values.yaml'], - minimumReleaseAge: '0' + minimumReleaseAge: '0', + pinDigests: false, }, ], From c4348a1bb62d0747ce7e04e515aba1e6d5961f4b Mon Sep 17 00:00:00 2001 From: TheCatLady <52870424+TheCatLady@users.noreply.github.com> Date: Tue, 7 Oct 2025 15:14:12 -0700 Subject: [PATCH 64/96] chore(renovate): group non-major deps (#2002) [skip ci] --- .github/renovate.json5 | 43 +++++++++++++++++++++--------------------- 1 file changed, 22 insertions(+), 21 deletions(-) diff --git a/.github/renovate.json5 b/.github/renovate.json5 index 1c47932c62..8ecd1d4b4e 100644 --- a/.github/renovate.json5 +++ b/.github/renovate.json5 @@ -1,24 +1,25 @@ { - "$schema": "https://docs.renovatebot.com/renovate-schema.json", - "extends": [ - "config:recommended", - ":dependencyDashboard", - ":timezone(UTC)", - "group:nextjsMonorepo", - "group:reactMonorepo", - "group:typescript-eslintMonorepo", - "group:tailwindcssMonorepo", - "github>seerr-team/seerr//.github/renovate/actions.json5", - "github>seerr-team/seerr//.github/renovate/docker.json5", - "github>seerr-team/seerr//.github/renovate/groups.json5", - "github>seerr-team/seerr//.github/renovate/helm.json5", - "github>seerr-team/seerr//.github/renovate/labels.json5", - "github>seerr-team/seerr//.github/renovate/pnpm.json5", - "github>seerr-team/seerr//.github/renovate/semanticCommits.json5" + $schema: 'https://docs.renovatebot.com/renovate-schema.json', + extends: [ + 'config:recommended', + ':dependencyDashboard', + ':timezone(UTC)', + 'group:allNonMajor', + 'group:nextjsMonorepo', + 'group:reactMonorepo', + 'group:typescript-eslintMonorepo', + 'group:tailwindcssMonorepo', + 'github>seerr-team/seerr//.github/renovate/actions.json5', + 'github>seerr-team/seerr//.github/renovate/docker.json5', + 'github>seerr-team/seerr//.github/renovate/groups.json5', + 'github>seerr-team/seerr//.github/renovate/helm.json5', + 'github>seerr-team/seerr//.github/renovate/labels.json5', + 'github>seerr-team/seerr//.github/renovate/pnpm.json5', + 'github>seerr-team/seerr//.github/renovate/semanticCommits.json5', ], - "dependencyDashboardTitle": "Renovate Dashboard 🤖", - "suppressNotifications": ["prEditedNotification", "prIgnoreNotification"], - "rebaseWhen": "conflicted", - "labels": ["dependencies"], - "minimumReleaseAge": "7 days" + dependencyDashboardTitle: 'Renovate Dashboard 🤖', + suppressNotifications: ['prEditedNotification', 'prIgnoreNotification'], + rebaseWhen: 'conflicted', + labels: ['dependencies'], + minimumReleaseAge: '7 days', } From 1213a1d7654f5ea7692b691102d1e538c5bec4c3 Mon Sep 17 00:00:00 2001 From: Brandon Cohen Date: Tue, 7 Oct 2025 21:17:55 -0400 Subject: [PATCH 65/96] chore: update readme logo and add note to top (#2007) --- README.md | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/README.md b/README.md index c13a18cfd9..37bbf9c164 100644 --- a/README.md +++ b/README.md @@ -1,6 +1,6 @@ -

-Jellyseerr -

+
⚠️ NOTE: We are currently in the process of merging Overseerr and Jellyseerr into this unified repository.
+ +

🚧 Seerr

Seerr Release Seerr CI From 4846c6abc4f7d3eaa25ffc53c96cdfa738481ce4 Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Wed, 8 Oct 2025 12:47:08 +0100 Subject: [PATCH 66/96] ci(ci.yml,release.yml): removes the need for 3rd party actions (#2018) * ci(ci.yml,release.yml): removes the need for 3rd party actions This will stop the need to use `sarisia/actions-status-discord` & `technote-space/workflow-conclusion-action` * revert(ci.yml): added the logic back to the if condition --- .github/workflows/ci.yml | 46 +++++++++++++++++++++----------- .github/workflows/release.yml | 49 ++++++++++++++++++++++------------- 2 files changed, 62 insertions(+), 33 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 838b05be4c..2dbbb98911 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -173,20 +173,36 @@ jobs: if: always() && github.event_name != 'pull_request' && !contains(github.event.head_commit.message, '[skip ci]') runs-on: ubuntu-24.04 steps: - - name: Combine Job Status + - name: Determine Workflow Status id: status run: | - failures=(neutral, skipped, timed_out, action_required) - if [[ ${array[@]} =~ ${{ needs.publish.result }} ]]; then - echo "status=failure" >> $GITHUB_OUTPUT - else - echo "status=${{ needs.publish.result }}" >> $GITHUB_OUTPUT - fi - - - name: Post Status to Discord - uses: sarisia/actions-status-discord@58667542682a27f270460405363e3a982f57a7ee # v1.0.0 - with: - webhook: ${{ secrets.DISCORD_WEBHOOK }} - status: ${{ steps.status.outputs.status }} - title: ${{ github.workflow }} - nofail: true + case "${{ needs.publish.result }}" in + success) echo "status=Success" >> $GITHUB_OUTPUT; echo "colour=3066993" >> $GITHUB_OUTPUT ;; + failure) echo "status=Failure" >> $GITHUB_OUTPUT; echo "colour=15158332" >> $GITHUB_OUTPUT ;; + cancelled) echo "status=Cancelled" >> $GITHUB_OUTPUT; echo "colour=10181046" >> $GITHUB_OUTPUT ;; + *) echo "status=Skipped" >> $GITHUB_OUTPUT; echo "colour=9807270" >> $GITHUB_OUTPUT ;; + esac + + - name: Send Discord notification + shell: bash + run: | + WEBHOOK="${{ secrets.DISCORD_WEBHOOK }}" + + PAYLOAD=$(cat <> $GITHUB_OUTPUT - else - echo "status=$WORKFLOW_CONCLUSION" >> $GITHUB_OUTPUT - fi - - - name: Post Status to Discord - uses: sarisia/actions-status-discord@58667542682a27f270460405363e3a982f57a7ee # v1.0.0 - with: - webhook: ${{ secrets.DISCORD_WEBHOOK }} - status: ${{ steps.status.outputs.status }} - title: ${{ github.workflow }} - nofail: true + case "${{ needs.publish.result }}" in + success) echo "status=Success" >> $GITHUB_OUTPUT; echo "colour=3066993" >> $GITHUB_OUTPUT ;; + failure) echo "status=Failure" >> $GITHUB_OUTPUT; echo "colour=15158332" >> $GITHUB_OUTPUT ;; + cancelled) echo "status=Cancelled" >> $GITHUB_OUTPUT; echo "colour=10181046" >> $GITHUB_OUTPUT ;; + *) echo "status=Skipped" >> $GITHUB_OUTPUT; echo "colour=9807270" >> $GITHUB_OUTPUT ;; + esac + + - name: Send Discord notification + shell: bash + run: | + WEBHOOK="${{ secrets.DISCORD_WEBHOOK }}" + + PAYLOAD=$(cat < Date: Wed, 8 Oct 2025 13:35:01 +0100 Subject: [PATCH 67/96] ci: updating digests re pr-1998 (#2020) --- .github/workflows/ci.yml | 2 +- .github/workflows/helm.yml | 2 +- .github/workflows/lint-helm-charts.yml | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 2dbbb98911..d0f7800b41 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -23,7 +23,7 @@ jobs: name: Lint & Test Build if: github.event_name == 'pull_request' runs-on: ubuntu-24.04 - container: node:22-alpine + container: node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 steps: - name: Checkout uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/.github/workflows/helm.yml b/.github/workflows/helm.yml index 48df8e1e99..4b1b4a7511 100644 --- a/.github/workflows/helm.yml +++ b/.github/workflows/helm.yml @@ -76,7 +76,7 @@ jobs: fi - name: Upload artifacts - uses: actions/upload-artifact@c7d193f32edcb7bfad88892161225aeda64e9392 # v4.0.0 + uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 if: steps.check-artifacts.outputs.has_artifacts == 'true' with: name: artifacts diff --git a/.github/workflows/lint-helm-charts.yml b/.github/workflows/lint-helm-charts.yml index b0533fbd0c..32fc4e3ba9 100644 --- a/.github/workflows/lint-helm-charts.yml +++ b/.github/workflows/lint-helm-charts.yml @@ -40,7 +40,7 @@ jobs: uses: helm/chart-testing-action@0d28d3144d3a25ea2cc349d6e59901c4ff469b3b # v2.7.0 - name: Ensure documentation is updated - uses: docker://jnorwood/helm-docs@sha256:7e562b49ab6b1dbc50c3da8f2dd6ffa8a5c6bba327b1c6335cc15ce29267979c # v1.14.2 + uses: docker://jnorwood/helm-docs:v1.14.2@sha256:7e562b49ab6b1dbc50c3da8f2dd6ffa8a5c6bba327b1c6335cc15ce29267979c - name: Run chart-testing (list-changed) id: list-changed From f292d93d10489584bc1866ab250de08847c8741f Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Wed, 8 Oct 2025 14:10:38 +0100 Subject: [PATCH 68/96] ci: ci: update node hash to be multi arch sha index (#2023) --- .github/workflows/ci.yml | 2 +- Dockerfile | 4 ++-- Dockerfile.local | 2 +- 3 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index d0f7800b41..4d8610e837 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -23,7 +23,7 @@ jobs: name: Lint & Test Build if: github.event_name == 'pull_request' runs-on: ubuntu-24.04 - container: node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 + container: node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 steps: - name: Checkout uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 diff --git a/Dockerfile b/Dockerfile index 9bb6853b95..6354ee43ad 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 AS build_image +FROM node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 AS build_image ARG SOURCE_DATE_EPOCH ARG TARGETPLATFORM @@ -33,7 +33,7 @@ RUN pnpm prune --prod --ignore-scripts && \ touch config/DOCKER && \ echo "{\"commitTag\": \"${COMMIT_TAG}\"}" > committag.json -FROM node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 +FROM node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 ENV PNPM_HOME="/pnpm" ENV PATH="$PNPM_HOME:$PATH" diff --git a/Dockerfile.local b/Dockerfile.local index 1cefe8f29e..cd41e60383 100644 --- a/Dockerfile.local +++ b/Dockerfile.local @@ -1,4 +1,4 @@ -FROM node:22.20.0-alpine3.22@sha256:096829fd4bb8c2ce2340ed64dd2f857951f8704325f7acf53e3dc0561c36a214 +FROM node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 ENV PNPM_HOME="/pnpm" ENV PATH="$PNPM_HOME:$PATH" From 34fcc5d2c7786fa130ce2c81e11f9f0585761a53 Mon Sep 17 00:00:00 2001 From: Gauthier Date: Thu, 9 Oct 2025 05:34:31 +0200 Subject: [PATCH 69/96] chore: merge upstream (#2024) --- .../migrations/0002_migrate_apitokens.ts | 2 +- src/components/ServiceWorkerSetup/index.tsx | 47 +++- .../UserNotificationsWebPush/DeviceItem.tsx | 35 ++- .../UserNotificationsWebPush/index.tsx | 253 ++++++++---------- src/i18n/locale/en.json | 1 + src/utils/pushSubscriptionHelpers.ts | 162 +++++++++++ 6 files changed, 353 insertions(+), 147 deletions(-) create mode 100644 src/utils/pushSubscriptionHelpers.ts diff --git a/server/lib/settings/migrations/0002_migrate_apitokens.ts b/server/lib/settings/migrations/0002_migrate_apitokens.ts index 0390678262..dcfa327f8e 100644 --- a/server/lib/settings/migrations/0002_migrate_apitokens.ts +++ b/server/lib/settings/migrations/0002_migrate_apitokens.ts @@ -8,7 +8,7 @@ import { getHostname } from '@server/utils/getHostname'; const migrateApiTokens = async (settings: any): Promise => { const mediaServerType = settings.main.mediaServerType; if ( - !settings.jellyfin.apiKey && + !settings.jellyfin?.apiKey && (mediaServerType === MediaServerType.JELLYFIN || mediaServerType === MediaServerType.EMBY) ) { diff --git a/src/components/ServiceWorkerSetup/index.tsx b/src/components/ServiceWorkerSetup/index.tsx index 2e0313f4db..929580a7c6 100644 --- a/src/components/ServiceWorkerSetup/index.tsx +++ b/src/components/ServiceWorkerSetup/index.tsx @@ -1,10 +1,14 @@ /* eslint-disable no-console */ +import useSettings from '@app/hooks/useSettings'; import { useUser } from '@app/hooks/useUser'; +import { verifyAndResubscribePushSubscription } from '@app/utils/pushSubscriptionHelpers'; import { useEffect } from 'react'; const ServiceWorkerSetup = () => { const { user } = useUser(); + const { currentSettings } = useSettings(); + useEffect(() => { if ('serviceWorker' in navigator && user?.id) { navigator.serviceWorker @@ -14,12 +18,53 @@ const ServiceWorkerSetup = () => { '[SW] Registration successful, scope is:', registration.scope ); + + const pushNotificationsEnabled = + localStorage.getItem('pushNotificationsEnabled') === 'true'; + + // Reset the notifications flag if permissions were revoked + if ( + Notification.permission !== 'granted' && + pushNotificationsEnabled + ) { + localStorage.setItem('pushNotificationsEnabled', 'false'); + console.warn( + '[SW] Push permissions not granted — skipping resubscribe' + ); + + return; + } + + // Bypass resubscribing if we have manually disabled push notifications + if (!pushNotificationsEnabled) { + return; + } + + const subscription = await registration.pushManager.getSubscription(); + + console.log( + '[SW] Existing push subscription:', + subscription?.endpoint + ); + + const verified = await verifyAndResubscribePushSubscription( + user.id, + currentSettings + ); + + if (verified) { + console.log('[SW] Push subscription verified or refreshed.'); + } else { + console.warn( + '[SW] Push subscription verification failed or not available.' + ); + } }) .catch(function (error) { console.log('[SW] Service worker registration failed, error:', error); }); } - }, [user]); + }, [currentSettings, user]); return null; }; diff --git a/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/DeviceItem.tsx b/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/DeviceItem.tsx index 7fdefa4a5f..55922ed9a8 100644 --- a/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/DeviceItem.tsx +++ b/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/DeviceItem.tsx @@ -1,16 +1,18 @@ +import Button from '@app/components/Common/Button'; import ConfirmButton from '@app/components/Common/ConfirmButton'; import globalMessages from '@app/i18n/globalMessages'; import defineMessages from '@app/utils/defineMessages'; import { ComputerDesktopIcon, DevicePhoneMobileIcon, + LockClosedIcon, TrashIcon, } from '@heroicons/react/24/solid'; import { useIntl } from 'react-intl'; import { UAParser } from 'ua-parser-js'; interface DeviceItemProps { - disablePushNotifications: (p256dh: string) => void; + deletePushSubscriptionFromBackend: (endpoint: string) => void; device: { endpoint: string; p256dh: string; @@ -18,6 +20,7 @@ interface DeviceItemProps { userAgent: string; createdAt: Date; }; + subEndpoint: string | null; } const messages = defineMessages( @@ -28,10 +31,15 @@ const messages = defineMessages( engine: 'Engine', deletesubscription: 'Delete Subscription', unknown: 'Unknown', + activesubscription: 'Active Subscription', } ); -const DeviceItem = ({ disablePushNotifications, device }: DeviceItemProps) => { +const DeviceItem = ({ + deletePushSubscriptionFromBackend, + device, + subEndpoint, +}: DeviceItemProps) => { const intl = useIntl(); const parsedUserAgent = UAParser(device.userAgent); @@ -91,14 +99,21 @@ const DeviceItem = ({ disablePushNotifications, device }: DeviceItemProps) => {

- disablePushNotifications(device.endpoint)} - confirmText={intl.formatMessage(globalMessages.areyousure)} - className="w-full" - > - - {intl.formatMessage(messages.deletesubscription)} - + {subEndpoint === device.endpoint ? ( + + ) : ( + deletePushSubscriptionFromBackend(device.endpoint)} + confirmText={intl.formatMessage(globalMessages.areyousure)} + className="w-full" + > + + {intl.formatMessage(messages.deletesubscription)} + + )}
); diff --git a/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx b/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx index 11e082901d..fbe03f7cc6 100644 --- a/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx +++ b/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx @@ -9,17 +9,22 @@ import useSettings from '@app/hooks/useSettings'; import { useUser } from '@app/hooks/useUser'; import globalMessages from '@app/i18n/globalMessages'; import defineMessages from '@app/utils/defineMessages'; +import { + getPushSubscription, + subscribeToPushNotifications, + unsubscribeToPushNotifications, + verifyPushSubscription, +} from '@app/utils/pushSubscriptionHelpers'; import { ArrowDownOnSquareIcon } from '@heroicons/react/24/outline'; import { CloudArrowDownIcon, CloudArrowUpIcon, } from '@heroicons/react/24/solid'; -import type { UserPushSubscription } from '@server/entity/UserPushSubscription'; import type { UserSettingsNotificationsResponse } from '@server/interfaces/api/userSettingsInterfaces'; import axios from 'axios'; import { Form, Formik } from 'formik'; import { useRouter } from 'next/router'; -import { useEffect, useState } from 'react'; +import { useEffect, useMemo, useState } from 'react'; import { useIntl } from 'react-intl'; import { useToasts } from 'react-toast-notifications'; import useSWR, { mutate } from 'swr'; @@ -53,6 +58,7 @@ const UserWebPushSettings = () => { const { user } = useUser({ id: Number(router.query.userId) }); const { currentSettings } = useSettings(); const [webPushEnabled, setWebPushEnabled] = useState(false); + const [subEndpoint, setSubEndpoint] = useState(null); const { data, error, @@ -72,141 +78,122 @@ const UserWebPushSettings = () => { // Subscribes to the push manager // Will only add to the database if subscribing for the first time - const enablePushNotifications = () => { - if ('serviceWorker' in navigator && user?.id) { - navigator.serviceWorker - .getRegistration('/sw.js') - .then(async (registration) => { - if (currentSettings.enablePushRegistration) { - const sub = await registration?.pushManager.subscribe({ - userVisibleOnly: true, - applicationServerKey: currentSettings.vapidPublic, - }); - const parsedSub = JSON.parse(JSON.stringify(sub)); + const enablePushNotifications = async () => { + try { + const isSubscribed = await subscribeToPushNotifications( + user?.id, + currentSettings + ); - if (parsedSub.keys.p256dh && parsedSub.keys.auth) { - await axios.post('/api/v1/user/registerPushSubscription', { - endpoint: parsedSub.endpoint, - p256dh: parsedSub.keys.p256dh, - auth: parsedSub.keys.auth, - userAgent: navigator.userAgent, - }); - setWebPushEnabled(true); - addToast(intl.formatMessage(messages.webpushhasbeenenabled), { - appearance: 'success', - autoDismiss: true, - }); - } - } - }) - .catch(function () { - addToast(intl.formatMessage(messages.enablingwebpusherror), { - autoDismiss: true, - appearance: 'error', - }); - }) - .finally(function () { - revalidateDevices(); + if (isSubscribed) { + localStorage.setItem('pushNotificationsEnabled', 'true'); + setWebPushEnabled(true); + addToast(intl.formatMessage(messages.webpushhasbeenenabled), { + appearance: 'success', + autoDismiss: true, }); + } else { + throw new Error('Subscription failed'); + } + } catch (error) { + addToast(intl.formatMessage(messages.enablingwebpusherror), { + appearance: 'error', + autoDismiss: true, + }); + } finally { + revalidateDevices(); } }; // Unsubscribes from the push manager // Deletes/disables corresponding push subscription from database const disablePushNotifications = async (endpoint?: string) => { - if ('serviceWorker' in navigator && user?.id) { - navigator.serviceWorker.getRegistration('/sw.js').then((registration) => { - registration?.pushManager - .getSubscription() - .then(async (subscription) => { - const parsedSub = JSON.parse(JSON.stringify(subscription)); + try { + await unsubscribeToPushNotifications(user?.id, endpoint); - await axios.delete( - `/api/v1/user/${user.id}/pushSubscription/${encodeURIComponent( - endpoint ?? parsedSub.endpoint - )}` - ); + localStorage.setItem('pushNotificationsEnabled', 'false'); + setWebPushEnabled(false); + addToast(intl.formatMessage(messages.webpushhasbeendisabled), { + autoDismiss: true, + appearance: 'success', + }); + } catch (error) { + addToast(intl.formatMessage(messages.disablingwebpusherror), { + autoDismiss: true, + appearance: 'error', + }); + } finally { + revalidateDevices(); + } + }; - if ( - subscription && - (endpoint === parsedSub.endpoint || !endpoint) - ) { - subscription.unsubscribe(); - setWebPushEnabled(false); - } - addToast( - intl.formatMessage( - endpoint - ? messages.subscriptiondeleted - : messages.webpushhasbeendisabled - ), - { - autoDismiss: true, - appearance: 'success', - } - ); - }) - .catch(function () { - addToast( - intl.formatMessage( - endpoint - ? messages.subscriptiondeleteerror - : messages.disablingwebpusherror - ), - { - autoDismiss: true, - appearance: 'error', - } - ); - }) - .finally(function () { - revalidateDevices(); - }); + const deletePushSubscriptionFromBackend = async (endpoint: string) => { + try { + await axios.delete( + `/api/v1/user/${user?.id}/pushSubscription/${encodeURIComponent( + endpoint + )}` + ); + + addToast(intl.formatMessage(messages.subscriptiondeleted), { + autoDismiss: true, + appearance: 'success', }); + } catch (error) { + addToast(intl.formatMessage(messages.subscriptiondeleteerror), { + autoDismiss: true, + appearance: 'error', + }); + } finally { + revalidateDevices(); } }; - // Checks our current subscription on page load - // Will set the web push state to true if subscribed useEffect(() => { - if ('serviceWorker' in navigator && user?.id) { - navigator.serviceWorker - .getRegistration('/sw.js') - .then(async (registration) => { - await registration?.pushManager - .getSubscription() - .then(async (subscription) => { - if (subscription) { - const parsedKey = JSON.parse(JSON.stringify(subscription)); - const currentUserPushSub = - await axios.get( - `/api/v1/user/${ - user.id - }/pushSubscription/${encodeURIComponent( - parsedKey.endpoint - )}` - ); + const verifyWebPush = async () => { + const enabled = await verifyPushSubscription(user?.id, currentSettings); + setWebPushEnabled(enabled); + }; - if (currentUserPushSub.data.endpoint !== parsedKey.endpoint) { - return; - } + if (user?.id) { + verifyWebPush(); + } + }, [user?.id, currentSettings]); - setWebPushEnabled(true); - } else { - setWebPushEnabled(false); - } - }); - }) - .catch(function (error) { - setWebPushEnabled(false); - // eslint-disable-next-line no-console - console.log( - '[SW] Failure retrieving push manager subscription, error:', - error - ); - }); + useEffect(() => { + const getSubscriptionEndpoint = async () => { + if ('serviceWorker' in navigator && 'PushManager' in window) { + const { subscription } = await getPushSubscription(); + + if (subscription) { + setSubEndpoint(subscription.endpoint); + } else { + setSubEndpoint(null); + } + } + }; + + getSubscriptionEndpoint(); + }, [webPushEnabled]); + + const sortedDevices = useMemo(() => { + if (!dataDevices || !subEndpoint) { + return dataDevices; } - }, [user?.id]); + + return [...dataDevices].sort((a, b) => { + if (a.endpoint === subEndpoint) { + return -1; + } + if (b.endpoint === subEndpoint) { + return 1; + } + + const dateA = a.createdAt ? new Date(a.createdAt).getTime() : 0; + const dateB = b.createdAt ? new Date(b.createdAt).getTime() : 0; + return dateB - dateA; + }); + }, [dataDevices, subEndpoint]); if (!data && !error) { return ; @@ -324,22 +311,18 @@ const UserWebPushSettings = () => { {intl.formatMessage(messages.managedevices)}
- {dataDevices?.length ? ( - dataDevices - ?.sort((a, b) => { - const dateA = a.createdAt ? new Date(a.createdAt).getTime() : 0; - const dateB = b.createdAt ? new Date(b.createdAt).getTime() : 0; - return dateB - dateA; - }) - .map((device, index) => ( -
- -
- )) + {sortedDevices?.length ? ( + sortedDevices.map((device) => ( +
+ +
+ )) ) : ( <> { + const registration = await navigator.serviceWorker.ready; + const subscription = await registration.pushManager.getSubscription(); + return { registration, subscription }; +}; + +export const verifyPushSubscription = async ( + userId: number | undefined, + currentSettings: PublicSettingsResponse +): Promise => { + if (!('serviceWorker' in navigator) || !userId) { + return false; + } + + try { + const { subscription } = await getPushSubscription(); + + if (!subscription) { + return false; + } + + const appServerKey = subscription.options?.applicationServerKey; + if (!(appServerKey instanceof ArrayBuffer)) { + return false; + } + + const currentServerKey = new Uint8Array(appServerKey).toString(); + const expectedServerKey = urlBase64ToUint8Array( + currentSettings.vapidPublic + ).toString(); + + const endpoint = subscription.endpoint; + + const { data } = await axios.get( + `/api/v1/user/${userId}/pushSubscription/${encodeURIComponent(endpoint)}` + ); + + return expectedServerKey === currentServerKey && data.endpoint === endpoint; + } catch { + return false; + } +}; + +export const verifyAndResubscribePushSubscription = async ( + userId: number | undefined, + currentSettings: PublicSettingsResponse +): Promise => { + const isValid = await verifyPushSubscription(userId, currentSettings); + + if (isValid) { + return true; + } + + if (currentSettings.enablePushRegistration) { + try { + // Unsubscribe from the backend to clear the existing push subscription (keys and endpoint) + await unsubscribeToPushNotifications(userId); + + // Subscribe again to generate a fresh push subscription with updated keys and endpoint + await subscribeToPushNotifications(userId, currentSettings); + + return true; + } catch (error) { + throw new Error(`[SW] Resubscribe failed: ${error.message}`); + } + } + + return false; +}; + +export const subscribeToPushNotifications = async ( + userId: number | undefined, + currentSettings: PublicSettingsResponse +) => { + if ( + !('serviceWorker' in navigator) || + !userId || + !currentSettings.enablePushRegistration + ) { + return false; + } + + try { + const { registration } = await getPushSubscription(); + + if (!registration) { + return false; + } + + const subscription = await registration.pushManager.subscribe({ + userVisibleOnly: true, + applicationServerKey: currentSettings.vapidPublic, + }); + + const { endpoint, keys } = subscription.toJSON(); + + if (keys?.p256dh && keys?.auth) { + await axios.post('/api/v1/user/registerPushSubscription', { + endpoint, + p256dh: keys.p256dh, + auth: keys.auth, + userAgent: navigator.userAgent, + }); + + return true; + } + + return false; + } catch (error) { + throw new Error( + `Issue subscribing to push notifications: ${error.message}` + ); + } +}; + +export const unsubscribeToPushNotifications = async ( + userId: number | undefined, + endpoint?: string +) => { + if (!('serviceWorker' in navigator) || !userId) { + return; + } + + try { + const { subscription } = await getPushSubscription(); + + if (!subscription) { + return false; + } + + const { endpoint: currentEndpoint } = subscription.toJSON(); + + if (!endpoint || endpoint === currentEndpoint) { + await subscription.unsubscribe(); + return true; + } + } catch (error) { + throw new Error( + `Issue unsubscribing to push notifications: ${error.message}` + ); + } +}; From a8c7e35f5693ef0719fac8b3bc570bc8a37c1f21 Mon Sep 17 00:00:00 2001 From: salty Date: Sun, 12 Oct 2025 17:19:51 +0200 Subject: [PATCH 70/96] fix(api): cleanup radarr bits in sonarr api (#2035) --- server/api/servarr/sonarr.ts | 8 ++++---- server/routes/media.ts | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/server/api/servarr/sonarr.ts b/server/api/servarr/sonarr.ts index 0e623cef6a..9dec8ebf95 100644 --- a/server/api/servarr/sonarr.ts +++ b/server/api/servarr/sonarr.ts @@ -257,7 +257,7 @@ class SonarrAPI extends ServarrBase<{ series: createdSeriesResponse.data, }); } else { - logger.error('Failed to add movie to Sonarr', { + logger.error('Failed to add series to Sonarr', { label: 'Sonarr', options, }); @@ -342,7 +342,7 @@ class SonarrAPI extends ServarrBase<{ return newSeasons; } - public removeSerie = async (serieId: number): Promise => { + public removeSeries = async (serieId: number): Promise => { try { const { id, title } = await this.getSeriesByTvdbId(serieId); await this.axios.delete(`/series/${id}`, { @@ -351,9 +351,9 @@ class SonarrAPI extends ServarrBase<{ addImportExclusion: false, }, }); - logger.info(`[Radarr] Removed serie ${title}`); + logger.info(`[Sonarr] Removed series ${title}`); } catch (e) { - throw new Error(`[Radarr] Failed to remove serie: ${e.message}`); + throw new Error(`[Sonarr] Failed to remove series: ${e.message}`); } }; diff --git a/server/routes/media.ts b/server/routes/media.ts index b9983d8bf9..f4fc878bd1 100644 --- a/server/routes/media.ts +++ b/server/routes/media.ts @@ -271,7 +271,7 @@ mediaRoutes.delete( if (!tvdbId) { throw new Error('TVDB ID not found'); } - await (service as SonarrAPI).removeSerie(tvdbId); + await (service as SonarrAPI).removeSeries(tvdbId); } return res.status(204).send(); From 0354debd2ba9107137fa6d08a8a93bb08d21b5f4 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Tue, 14 Oct 2025 23:49:57 +0300 Subject: [PATCH 71/96] build(docker): setup rootless image (#2032) [skip ci] * build(docker): setup rootless image --------- Signed-off-by: Ludovic Ortega --- .dockerignore | 5 +++- .github/workflows/ci.yml | 2 +- Dockerfile | 49 +++++++++++++++++---------------- bin/prepare.js | 9 ++++++ docs/getting-started/docker.mdx | 4 +++ package.json | 2 +- 6 files changed, 45 insertions(+), 26 deletions(-) create mode 100644 bin/prepare.js diff --git a/.dockerignore b/.dockerignore index 9c94daaee4..76aae0c402 100644 --- a/.dockerignore +++ b/.dockerignore @@ -11,16 +11,19 @@ .husky .next .prettierignore +.vscode +charts config/db/* config/logs/* config/*.json +cypress dist Dockerfile* compose.yaml +gen-docs docs LICENSE node_modules public/os_logo_filled.png public/preview.jpg stylelint.config.js -cypress diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 4d8610e837..04fa51cfee 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -48,7 +48,7 @@ jobs: - name: Install dependencies env: - HUSKY: 0 + CI: true run: pnpm install - name: Lint diff --git a/Dockerfile b/Dockerfile index 6354ee43ad..039b0ca88d 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,15 +1,20 @@ -FROM node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 AS build_image - +FROM node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 AS base ARG SOURCE_DATE_EPOCH ARG TARGETPLATFORM -ARG COMMIT_TAG ENV TARGETPLATFORM=${TARGETPLATFORM:-linux/amd64} -ENV COMMIT_TAG=${COMMIT_TAG} ENV PNPM_HOME="/pnpm" ENV PATH="$PNPM_HOME:$PATH" RUN corepack enable +COPY . ./app +WORKDIR /app + +FROM base AS prod-deps +RUN --mount=type=cache,id=pnpm,target=/pnpm/store CI=true pnpm install --prod --frozen-lockfile + +FROM base as build + RUN \ case "${TARGETPLATFORM}" in \ 'linux/arm64' | 'linux/arm/v7') \ @@ -19,34 +24,32 @@ RUN \ ;; \ esac -WORKDIR /app +RUN --mount=type=cache,id=pnpm,target=/pnpm/store CYPRESS_INSTALL_BINARY=0 pnpm install --frozen-lockfile -COPY package.json pnpm-lock.yaml postinstall-win.js ./ -RUN CYPRESS_INSTALL_BINARY=0 pnpm install --frozen-lockfile - -COPY . ./ RUN pnpm build -# remove development dependencies -RUN pnpm prune --prod --ignore-scripts && \ - rm -rf src server .next/cache charts gen-docs docs && \ - touch config/DOCKER && \ - echo "{\"commitTag\": \"${COMMIT_TAG}\"}" > committag.json +RUN rm -rf .next/cache FROM node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 +ARG SOURCE_DATE_EPOCH +ARG COMMIT_TAG +ENV NODE_ENV=production +ENV COMMIT_TAG=${COMMIT_TAG} -ENV PNPM_HOME="/pnpm" -ENV PATH="$PNPM_HOME:$PATH" -RUN corepack enable +RUN apk add --no-cache tzdata -WORKDIR /app +USER node:node -RUN apk add --no-cache tzdata tini && rm -rf /tmp/* +WORKDIR /app -# copy from build image -COPY --from=build_image /app ./ +COPY --chown=node:node . . +COPY --chown=node:node --from=prod-deps /app/node_modules ./node_modules +COPY --chown=node:node --from=build /app/.next ./.next +COPY --chown=node:node --from=build /app/dist ./dist -ENTRYPOINT [ "/sbin/tini", "--" ] -CMD [ "pnpm", "start" ] +RUN touch config/DOCKER && \ + echo "{\"commitTag\": \"${COMMIT_TAG}\"}" > committag.json EXPOSE 5055 + +CMD [ "npm", "start" ] diff --git a/bin/prepare.js b/bin/prepare.js new file mode 100644 index 0000000000..5f19878a1d --- /dev/null +++ b/bin/prepare.js @@ -0,0 +1,9 @@ +#!/usr/bin/env node + +/** + * Do not run husky in CI environments + */ +const isCi = process.env.CI !== undefined; +if (!isCi) { + require('husky').install(); +} diff --git a/docs/getting-started/docker.mdx b/docs/getting-started/docker.mdx index d71e3a19d7..a771693e63 100644 --- a/docs/getting-started/docker.mdx +++ b/docs/getting-started/docker.mdx @@ -31,6 +31,7 @@ For details on the Docker CLI, please [review the official `docker run` document ```bash docker run -d \ --name jellyseerr \ + --init \ -e LOG_LEVEL=debug \ -e TZ=Asia/Tashkent \ -e PORT=5055 \ @@ -85,6 +86,7 @@ Define the `jellyseerr` service in your `compose.yaml` as follows: services: jellyseerr: image: fallenbagel/jellyseerr:latest + init: true container_name: jellyseerr environment: - LOG_LEVEL=debug @@ -156,6 +158,7 @@ Then, create and start the Jellyseerr container: ```bash docker run -d \ --name jellyseerr \ + --init \ -e LOG_LEVEL=debug \ -e TZ=Asia/Tashkent \ -e PORT=5055 \ @@ -193,6 +196,7 @@ docker compose up -d services: jellyseerr: image: fallenbagel/jellyseerr:latest + init: true container_name: jellyseerr environment: - LOG_LEVEL=debug diff --git a/package.json b/package.json index 8e2b0bd60c..19d88b1fa0 100644 --- a/package.json +++ b/package.json @@ -22,7 +22,7 @@ "typecheck": "pnpm typecheck:server && pnpm typecheck:client", "typecheck:server": "tsc --project server/tsconfig.json --noEmit", "typecheck:client": "tsc --noEmit", - "prepare": "husky install", + "prepare": "node bin/prepare.js", "cypress:open": "cypress open", "cypress:prepare": "ts-node -r tsconfig-paths/register --files --project server/tsconfig.json server/scripts/prepareTestDb.ts", "cypress:build": "pnpm build && pnpm cypress:prepare" From d5ff0c11ca5d2b3c2d249f545c47d1a7090cfb39 Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Wed, 15 Oct 2025 04:56:33 +0800 Subject: [PATCH 72/96] fix(subscriber): prevent infinite loop when requesting existing media with scan disabled (#2043) --- server/subscriber/MediaRequestSubscriber.ts | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/server/subscriber/MediaRequestSubscriber.ts b/server/subscriber/MediaRequestSubscriber.ts index 52c3482648..5c1b9bb022 100644 --- a/server/subscriber/MediaRequestSubscriber.ts +++ b/server/subscriber/MediaRequestSubscriber.ts @@ -341,9 +341,11 @@ export class MediaRequestSubscriber mediaId: entity.media.id, }); - const requestRepository = getRepository(MediaRequest); - entity.status = MediaRequestStatus.APPROVED; - await requestRepository.save(entity); + if (entity.status !== MediaRequestStatus.APPROVED) { + const requestRepository = getRepository(MediaRequest); + entity.status = MediaRequestStatus.APPROVED; + await requestRepository.save(entity); + } return; } @@ -505,9 +507,11 @@ export class MediaRequestSubscriber mediaId: entity.media.id, }); - const requestRepository = getRepository(MediaRequest); - entity.status = MediaRequestStatus.APPROVED; - await requestRepository.save(entity); + if (entity.status !== MediaRequestStatus.APPROVED) { + const requestRepository = getRepository(MediaRequest); + entity.status = MediaRequestStatus.APPROVED; + await requestRepository.save(entity); + } return; } From 9d174baa708aa12818b76af6c2238cf0ef2b61d3 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Wed, 15 Oct 2025 00:27:56 +0300 Subject: [PATCH 73/96] chore: use ghcr.io instead of dockerhub as default (#2045) Signed-off-by: Ludovic Ortega --- docs/getting-started/docker.mdx | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/getting-started/docker.mdx b/docs/getting-started/docker.mdx index a771693e63..69d01632d2 100644 --- a/docs/getting-started/docker.mdx +++ b/docs/getting-started/docker.mdx @@ -38,7 +38,7 @@ docker run -d \ -p 5055:5055 \ -v /path/to/appdata/config:/app/config \ --restart unless-stopped \ - fallenbagel/jellyseerr + ghcr.io/fallenbagel/jellyseerr:latest ``` The argument `-e PORT=5055` is optional. @@ -62,7 +62,7 @@ docker stop jellyseerr && docker rm jellyseerr ``` Pull the latest image: ```bash -docker pull fallenbagel/jellyseerr +docker pull ghcr.io/fallenbagel/jellyseerr:latest ``` Finally, run the container with the same parameters originally used to create the container: ```bash @@ -85,7 +85,7 @@ Define the `jellyseerr` service in your `compose.yaml` as follows: --- services: jellyseerr: - image: fallenbagel/jellyseerr:latest + image: ghcr.io/fallenbagel/jellyseerr:latest init: true container_name: jellyseerr environment: @@ -165,7 +165,7 @@ docker run -d \ -p 5055:5055 \ -v jellyseerr-data:/app/config \ --restart unless-stopped \ - fallenbagel/jellyseerr + ghcr.io/fallenbagel/jellyseerr:latest ``` The argument `-e PORT=5055` is optional. @@ -195,7 +195,7 @@ docker compose up -d --- services: jellyseerr: - image: fallenbagel/jellyseerr:latest + image: ghcr.io/fallenbagel/jellyseerr:latest init: true container_name: jellyseerr environment: From d95cccac6ae39760236e336d2d9c59892600fe25 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Wed, 15 Oct 2025 01:09:43 +0300 Subject: [PATCH 74/96] docs: postgres 18 documentation (#2046) Signed-off-by: Ludovic Ortega --- compose.postgres.yaml | 4 ++-- docs/extending-jellyseerr/database-config.mdx | 3 ++- 2 files changed, 4 insertions(+), 3 deletions(-) diff --git a/compose.postgres.yaml b/compose.postgres.yaml index 937beac170..148932b329 100644 --- a/compose.postgres.yaml +++ b/compose.postgres.yaml @@ -23,7 +23,7 @@ services: links: - postgres postgres: - image: postgres + image: postgres:18 environment: POSTGRES_USER: jellyseerr POSTGRES_PASSWORD: jellyseerr @@ -31,6 +31,6 @@ services: ports: - '5432:5432' volumes: - - postgres:/var/lib/postgresql/data + - postgres:var/lib/postgresql/18/docker volumes: postgres: diff --git a/docs/extending-jellyseerr/database-config.mdx b/docs/extending-jellyseerr/database-config.mdx index df099187c6..4763d7f883 100644 --- a/docs/extending-jellyseerr/database-config.mdx +++ b/docs/extending-jellyseerr/database-config.mdx @@ -20,7 +20,8 @@ DB_LOG_QUERIES="false" # (optional) Whether to log the DB queries for debugging. ## PostgreSQL Options :::caution -When migrating Postgres from version 17 to 18 in Docker, note that the data mount point has changed. Instead of using `/var/lib/postgresql/data`, the correct mount path is now `/var/lib/postgresql`. +When migrating Postgres from version 17 to 18 in Docker, note that the data mount point has changed. Instead of using `/var/lib/postgresql/data`, the correct mount path is now `/var/lib/postgresql/18/docker`. +Refer to the [PostgreSQL Docker documentation](https://hub.docker.com/_/postgres/#pgdata) to learn how to migrate or opt out of this change. ::: ### TCP Connection From de0e9b1f354b310c817716e9d49da75038fbec4e Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Thu, 16 Oct 2025 06:36:56 +0100 Subject: [PATCH 75/96] fix: path in docs and compose for postgres 18 (#2049) --- compose.postgres.yaml | 2 +- docs/extending-jellyseerr/database-config.mdx | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/compose.postgres.yaml b/compose.postgres.yaml index 148932b329..eee2758c7f 100644 --- a/compose.postgres.yaml +++ b/compose.postgres.yaml @@ -31,6 +31,6 @@ services: ports: - '5432:5432' volumes: - - postgres:var/lib/postgresql/18/docker + - postgres:/var/lib/postgresql volumes: postgres: diff --git a/docs/extending-jellyseerr/database-config.mdx b/docs/extending-jellyseerr/database-config.mdx index 4763d7f883..e8b726b2ba 100644 --- a/docs/extending-jellyseerr/database-config.mdx +++ b/docs/extending-jellyseerr/database-config.mdx @@ -20,7 +20,7 @@ DB_LOG_QUERIES="false" # (optional) Whether to log the DB queries for debugging. ## PostgreSQL Options :::caution -When migrating Postgres from version 17 to 18 in Docker, note that the data mount point has changed. Instead of using `/var/lib/postgresql/data`, the correct mount path is now `/var/lib/postgresql/18/docker`. +When migrating Postgres from version 17 to 18 in Docker, note that the data mount point has changed. Instead of using `/var/lib/postgresql/data`, the correct mount path is now `/var/lib/postgresql`. Refer to the [PostgreSQL Docker documentation](https://hub.docker.com/_/postgres/#pgdata) to learn how to migrate or opt out of this change. ::: From 8688645a3266f0e8d01e4a5e2c8025d9cfc94e1c Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Thu, 16 Oct 2025 12:53:02 +0100 Subject: [PATCH 76/96] ci: update to release workflow (#2047) * ci: update to release workflow * build: re-ran lock file update with typeorm 0.3.12 * build: resync lockfile with develop * ci: syntax fix in cliff.toml * Update .github/workflows/release.yml Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * reverting co-pilots nonsense @fallenbagel's fault Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com> --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> Co-authored-by: Copilot Autofix powered by AI <62310815+github-advanced-security[bot]@users.noreply.github.com> --- .github/cliff.toml | 94 +++++++++++++ .github/workflows/release.yml | 247 +++++++++++++++++++++++++--------- package.json | 64 --------- 3 files changed, 275 insertions(+), 130 deletions(-) create mode 100644 .github/cliff.toml diff --git a/.github/cliff.toml b/.github/cliff.toml new file mode 100644 index 0000000000..f83e601a23 --- /dev/null +++ b/.github/cliff.toml @@ -0,0 +1,94 @@ +# git-cliff ~ configuration +# https://git-cliff.org/docs/configuration + +[changelog] +header = "" +body = """ +{%- macro remote_url() -%} + https://github.com/{{ remote.github.owner }}/{{ remote.github.repo }} +{%- endmacro -%} + +{%- set excluded_users = ["github-actions[bot]", "dependabot[bot]", "renovate[bot]"] -%} + +{% macro print_commit(commit) -%} + - {% if commit.scope %}*({{ commit.scope }})* {% endif %}\ + {% if commit.breaking %}[**breaking**] {% endif %}\ + {{ commit.message | upper_first }} - \ + ([{{ commit.id | truncate(length=7, end="") }}]({{ self::remote_url() }}/commit/{{ commit.id }}))\ +{% endmacro -%} + +{% if version %}\ + {% if previous.version %}\ + ## [{{ version | trim_start_matches(pat="v") }}]({{ self::remote_url() }}/compare/{{ previous.version }}..{{ version }}) - {{ timestamp | date(format="%Y-%m-%d") }} + {% else %}\ + ## [{{ version | trim_start_matches(pat="v") }}] - {{ timestamp | date(format="%Y-%m-%d") }} + {% endif %}\ +{% else %}\ + ## [unreleased] +{% endif %}\ + +{%- for group, commits in commits | group_by(attribute="group") %} + ### {{ group | striptags | trim | upper_first }} + {%- for commit in commits | filter(attribute="scope") | sort(attribute="scope") %} + {{ self::print_commit(commit=commit) }} + {%- endfor %} + {%- for commit in commits %} + {%- if not commit.scope -%} + {{ self::print_commit(commit=commit) }} + {%- endif -%} + {%- endfor -%} +{%- endfor -%} + +{%- set valid_contributors = [] -%} +{%- for c in github.contributors | filter(attribute="is_first_time", value=true) %} + {%- if c.username and c.username not in excluded_users and c.username not in valid_contributors %} + {%- set_global valid_contributors = valid_contributors | concat(with=c.username) %} + {%- endif %} +{%- endfor %} + +{%- if valid_contributors | length > 0 %} +## New Contributors ❤️ + {%- for username in valid_contributors %} +* @{{ username }} made their first contribution + {%- endfor %} +{%- endif %} +""" +footer = """ + +""" +trim = true +postprocessors = [] + +[git] +conventional_commits = true +filter_unconventional = true +split_commits = false +filter_commits = true +commit_preprocessors = [ + { pattern = '.*\[skip ci\].*', replace = "" }, + { pattern = '.*\[ci skip\].*', replace = "" }, +] +commit_parsers = [ + { message = "^feat", group = "🚀 Features" }, + { message = "^fix", group = "🐛 Bug Fixes" }, + { message = "^doc", group = "📖 Documentation" }, + { message = "^perf", group = "⚡ Performance" }, + { message = "^refactor", group = "🚜 Refactor" }, + { message = "^style", group = "🎨 Styling" }, + { message = "^test", group = "🧪 Testing" }, + { message = "^chore\\(release\\): prepare for", skip = true }, + { message = "^chore\\(deps.*\\)", skip = true }, + { message = "^chore\\(pr\\)", skip = true }, + { message = "^chore\\(pull\\)", skip = true }, + { message = "^chore\\(git-sync\\)", skip = true }, + { message = "^chore|^ci", group = "⚙️ Miscellaneous Tasks" }, + { body = ".*security", group = "🛡️ Security" }, + { message = "^revert", group = "◀️ Revert" }, + { message = '.*\[skip ci\].*', skip = true }, + { message = '.*\[ci skip\].*', skip = true }, +] +protect_breaking_commits = false +tag_pattern = "v?[0-9]+\\.[0-9]+\\.[0-9]+.*" +skip_tags = "beta|alpha|rc" +topo_order = false +sort_commits = "newest" diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index e23887b186..586528b0e6 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,9 +1,10 @@ ---- # yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Seerr Release on: - workflow_dispatch: + push: + tags: + - 'v*' permissions: contents: read @@ -13,14 +14,13 @@ concurrency: cancel-in-progress: true jobs: - semantic-release: - name: Tag and release latest version - runs-on: ubuntu-22.04 - env: - HUSKY: 0 + changelog: + name: Generate changelog + runs-on: ubuntu-24.04 + permissions: + contents: read outputs: - new_release_published: ${{ steps.release.outputs.new_release_published }} - new_release_version: ${{ steps.release.outputs.new_release_version }} + release_body: ${{ steps.git-cliff.outputs.content }} steps: - name: Checkout uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 @@ -28,46 +28,36 @@ jobs: fetch-depth: 0 persist-credentials: false - - name: Set up Node.js - uses: actions/setup-node@a0853c24544627f65ddf259abe73b1d18a591444 # v5.0.0 + - name: Generate changelog + id: git-cliff + uses: orhun/git-cliff-action@d77b37db2e3f7398432d34b72a12aa3e2ba87e51 # v4.6.0 with: - node-version-file: package.json - package-manager-cache: false - - - name: Pnpm Setup - uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 - - - name: Get pnpm store directory - shell: sh - run: | - echo "STORE_PATH=$(pnpm store path --silent)" >> $GITHUB_ENV + config: .github/cliff.toml + args: -vv --current + env: + OUTPUT: CHANGELOG.md + GITHUB_REPO: ${{ github.repository }} - - name: Setup pnpm cache - uses: actions/cache@0057852bfaa89a56745cba8c7296529d2fc39830 # v4.3.0 + create-draft-release: + name: Create draft release + runs-on: ubuntu-24.04 + permissions: + contents: write + needs: changelog + steps: + - name: Checkout + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 with: - path: ${{ env.STORE_PATH }} - key: ${{ runner.os }}-pnpm-store-${{ hashFiles('**/pnpm-lock.yaml') }} - restore-keys: | - ${{ runner.os }}-pnpm-store- - - - name: Install dependencies - run: pnpm install + persist-credentials: false - - name: Release - id: release - uses: cycjimmy/semantic-release-action@9cc899c47e6841430bbaedb43de1560a568dfd16 # v5.0.0 - with: - extra_plugins: | - @semantic-release/git@10 - @semantic-release/changelog@6 - @codedependant/semantic-release-docker@5 + - name: Draft Release + run: gh release create ${GITHUB_REF_NAME} -t "Release ${GITHUB_REF_NAME}" -n "${RELEASE_BODY}" --draft env: - GITHUB_TOKEN: ${{ secrets.GH_TOKEN }} + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + RELEASE_BODY: ${{ needs.changelog.outputs.release_body }} build: - name: Build (per-arch, native runners) - needs: semantic-release - if: needs.semantic-release.outputs.new_release_published == 'true' + name: Build (${{ matrix.arch }}) strategy: matrix: include: @@ -78,6 +68,8 @@ jobs: platform: linux/arm64 arch: arm64 runs-on: ${{ matrix.runner }} + env: + VERSION: ${{ github.ref_name }} steps: - name: Checkout uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 @@ -91,7 +83,7 @@ jobs: - name: Set up Docker Buildx uses: docker/setup-buildx-action@e468171a9de216ec08956ac3ada2f0791b6bd435 # v3.11.1 - - name: Warm cache (no push) — ${{ matrix.platform }} + - name: Warm cache [${{ matrix.platform }}] uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . @@ -100,21 +92,23 @@ jobs: push: false build-args: | COMMIT_TAG=${{ github.sha }} - BUILD_VERSION=${{ needs.semantic-release.outputs.new_release_version }} + BUILD_VERSION=${{ env.VERSION }} SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} cache-from: type=gha,scope=${{ matrix.platform }} cache-to: type=gha,mode=max,scope=${{ matrix.platform }} provenance: false publish: - name: Publish multi-arch image - needs: [semantic-release, build] - if: needs.semantic-release.outputs.new_release_published == 'true' + name: Publish multi-arch manifests + needs: build runs-on: ubuntu-24.04 permissions: contents: read - id-token: write packages: write + outputs: + image_digest: ${{ steps.digests.outputs.IMAGE_DIGEST }} + env: + VERSION: ${{ github.ref_name }} steps: - name: Checkout uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 @@ -149,11 +143,11 @@ jobs: ${{ github.repository }} ghcr.io/${{ github.repository }} tags: | - type=raw,value=${{ needs.semantic-release.outputs.new_release_version }} + type=raw,value=${{ env.VERSION }} labels: | org.opencontainers.image.created=${{ steps.ts.outputs.TIMESTAMP }} - - name: Build & Push (multi-arch, single tag) + - name: Build & Push (multi-arch) uses: docker/build-push-action@263435318d21b8e681c14492fe198d362a7d2c83 # v6.18.0 with: context: . @@ -162,7 +156,7 @@ jobs: push: true build-args: | COMMIT_TAG=${{ github.sha }} - BUILD_VERSION=${{ needs.semantic-release.outputs.new_release_version }} + BUILD_VERSION=${{ env.VERSION }} SOURCE_DATE_EPOCH=${{ steps.ts.outputs.TIMESTAMP }} labels: ${{ steps.meta.outputs.labels }} tags: ${{ steps.meta.outputs.tags }} @@ -172,37 +166,158 @@ jobs: cache-to: type=gha,mode=max provenance: false + - name: Resolve manifest digest + id: digests + run: | + DIGEST=$(docker buildx imagetools inspect "${{ github.repository }}:${{ env.VERSION }}" --format '{{json .Manifest.Digest}}' | tr -d '"') + echo "IMAGE_DIGEST=$DIGEST" >> $GITHUB_OUTPUT + - name: Also tag :latest (non-pre-release only) shell: bash + if: ${{ !contains(env.VERSION, '-') }} run: | - VER="${{ needs.semantic-release.outputs.new_release_version }}" - if [[ "$VER" != *"-"* ]]; then - docker buildx imagetools create \ - -t ${{ github.repository }}:latest \ - ${{ github.repository }}:${VER} - docker buildx imagetools create \ - -t ghcr.io/${{ github.repository }}:latest \ - ghcr.io/${{ github.repository }}:${VER} - fi + docker buildx imagetools create \ + -t ${{ github.repository }}:latest \ + ${{ github.repository }}:${{ env.VERSION }} + + docker buildx imagetools create \ + -t ghcr.io/${{ github.repository }}:latest \ + ghcr.io/${{ github.repository }}:${{ env.VERSION }} + + sign: + name: Sign images and create SBOM attestations + needs: publish + runs-on: ubuntu-24.04 + permissions: + contents: read + id-token: write + packages: write + env: + VERSION: ${{ github.ref_name }} + COSIGN_YES: 'true' + steps: + - name: Checkout + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + with: + persist-credentials: false + + - name: Install Cosign + uses: sigstore/cosign-installer@d7543c93d881b35a8faa02e8e3605f69b7a1ce62 # v3.10.0 + + - name: Install Trivy + uses: aquasecurity/setup-trivy@e6c2c5e321ed9123bda567646e2f96565e34abe1 # v0.2.4 + + - name: Log in to Docker Hub + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 + with: + username: ${{ secrets.DOCKER_USERNAME }} + password: ${{ secrets.DOCKER_TOKEN }} + + - name: Log in to GitHub Container Registry + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 + with: + registry: ghcr.io + username: ${{ github.repository_owner }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Sign images + run: | + cosign sign --recursive "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + cosign sign --recursive "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + + - name: Generate SBOMs + run: | + trivy image --format cyclonedx --output seerr-ghcr-image-${{ env.VERSION }}.sbom \ + "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + + trivy image --format cyclonedx --output seerr-dockerhub-image-${{ env.VERSION }}.sbom \ + "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + + - name: Attest SBOMs + run: | + cosign attest \ + --type cyclonedx \ + --predicate seerr-ghcr-image-${{ env.VERSION }}.sbom \ + "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + + cosign attest \ + --type cyclonedx \ + --predicate seerr-dockerhub-image-${{ env.VERSION }}.sbom \ + "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + + - name: Upload SBOMs + uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 + with: + name: sboms-${{ env.VERSION }} + path: '*.sbom' + if-no-files-found: error + retention-days: 1 + + verify: + name: Verify signatures and attestations + needs: [publish, sign] + runs-on: ubuntu-24.04 + permissions: + contents: read + env: + VERSION: ${{ github.ref_name }} + steps: + - name: Install Cosign + uses: sigstore/cosign-installer@d7543c93d881b35a8faa02e8e3605f69b7a1ce62 # v3.10.0 + + - name: Verify signatures + run: | + cosign verify "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" \ + --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" + + cosign verify "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" \ + --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" + + - name: Verify attestations + run: | + cosign verify-attestation "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" \ + --type cyclonedx \ + --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" > /dev/null + + cosign verify-attestation "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" \ + --type cyclonedx \ + --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" > /dev/null + + publish-release: + name: Publish release + needs: [create-draft-release, verify] + runs-on: ubuntu-24.04 + permissions: + contents: write + env: + VERSION: ${{ github.ref_name }} + steps: + - name: Publish release + run: gh release edit "${{ env.VERSION }}" --draft=false --repo "${{ github.repository }}" + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} discord: name: Send Discord Notification - needs: publish + needs: publish-release if: always() runs-on: ubuntu-24.04 steps: - - name: Determine Workflow Status + - name: Determine status id: status run: | - case "${{ needs.publish.result }}" in + case "${{ needs.publish-release.result }}" in success) echo "status=Success" >> $GITHUB_OUTPUT; echo "colour=3066993" >> $GITHUB_OUTPUT ;; failure) echo "status=Failure" >> $GITHUB_OUTPUT; echo "colour=15158332" >> $GITHUB_OUTPUT ;; cancelled) echo "status=Cancelled" >> $GITHUB_OUTPUT; echo "colour=10181046" >> $GITHUB_OUTPUT ;; *) echo "status=Skipped" >> $GITHUB_OUTPUT; echo "colour=9807270" >> $GITHUB_OUTPUT ;; esac - - name: Send Discord notification - shell: bash + - name: Send notification run: | WEBHOOK="${{ secrets.DISCORD_WEBHOOK }}" @@ -217,7 +332,7 @@ jobs: { "name": "Event", "value": "${{ github.event_name }}", "inline": true }, { "name": "Triggered by", "value": "${{ github.actor }}", "inline": true }, { "name": "Workflow", "value": "[${{ github.workflow }}](${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }})", "inline": true } - ], + ] }] } EOF diff --git a/package.json b/package.json index 19d88b1fa0..a598f12f0d 100644 --- a/package.json +++ b/package.json @@ -201,70 +201,6 @@ "@commitlint/config-conventional" ] }, - "release": { - "plugins": [ - "@semantic-release/commit-analyzer", - "@semantic-release/release-notes-generator", - "@semantic-release/npm", - [ - "@codedependant/semantic-release-docker", - { - "dockerArgs": { - "COMMIT_TAG": "${GITHUB_SHA}" - }, - "dockerLogin": false, - "dockerProject": "fallenbagel", - "dockerImage": "jellyseerr", - "dockerTags": [ - "latest", - "{{major}}", - "{{major}}.{{minor}}", - "{{major}}.{{minor}}.{{patch}}" - ], - "dockerPlatform": [ - "linux/amd64", - "linux/arm64" - ] - } - ], - [ - "@codedependant/semantic-release-docker", - { - "dockerArgs": { - "COMMIT_TAG": "${GITHUB_SHA}" - }, - "dockerLogin": false, - "dockerRegistry": "ghcr.io", - "dockerProject": "fallenbagel", - "dockerImage": "jellyseerr", - "dockerTags": [ - "latest", - "{{major}}", - "{{major}}.{{minor}}", - "{{major}}.{{minor}}.{{patch}}" - ], - "dockerPlatform": [ - "linux/amd64", - "linux/arm64" - ] - } - ], - [ - "@semantic-release/github", - { - "addReleases": "bottom" - } - ] - ], - "branches": [ - "main" - ], - "npmPublish": false, - "publish": [ - "@codedependant/semantic-release-docker", - "@semantic-release/github" - ] - }, "pnpm": { "onlyBuiltDependencies": [ "sqlite3", From 618563c6d7579e0781320c600a0f87ece4c5e97e Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Thu, 16 Oct 2025 13:10:09 +0100 Subject: [PATCH 77/96] docs: added guide for image verification (#2051) * docs: added guide for image verification * Update verifying-signed-images.mdx Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --------- Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> --- docs/getting-started/docker.mdx | 5 + docs/using-jellyseerr/advanced/index.mdx | 15 + .../advanced/verifying-signed-images.mdx | 278 ++++++++++++++++++ 3 files changed, 298 insertions(+) create mode 100644 docs/using-jellyseerr/advanced/index.mdx create mode 100644 docs/using-jellyseerr/advanced/verifying-signed-images.mdx diff --git a/docs/getting-started/docker.mdx b/docs/getting-started/docker.mdx index 69d01632d2..acc6257aa3 100644 --- a/docs/getting-started/docker.mdx +++ b/docs/getting-started/docker.mdx @@ -68,6 +68,11 @@ Finally, run the container with the same parameters originally used to create th ```bash docker run -d ... ``` +:::info +All official Seerr images are cryptographically signed and include a verified [Software Bill of Materials (SBOM)](https://cyclonedx.org/). + +To confirm that the container image you are using is authentic and unmodified, please refer to the [Verifying Signed Images](/using-jellyseerr/advanced/verifying-signed-images) guide. +::: :::tip You may alternatively use a third-party updating mechanism, such as [Watchtower](https://github.com/containrrr/watchtower) or [Ouroboros](https://github.com/pyouroboros/ouroboros), to keep Jellyseerr up-to-date automatically. diff --git a/docs/using-jellyseerr/advanced/index.mdx b/docs/using-jellyseerr/advanced/index.mdx new file mode 100644 index 0000000000..f0ffdc92f3 --- /dev/null +++ b/docs/using-jellyseerr/advanced/index.mdx @@ -0,0 +1,15 @@ +--- +title: Advanced Features +description: Advanced configuration and use cases. +sidebar_position: 6 +--- + +# Advanced Features + +## Advanced Configuration and Use Cases + +Seerr currently offers advanced features for power users and specific use cases: + +import DocCardList from '@theme/DocCardList'; + + diff --git a/docs/using-jellyseerr/advanced/verifying-signed-images.mdx b/docs/using-jellyseerr/advanced/verifying-signed-images.mdx new file mode 100644 index 0000000000..b05b2d255a --- /dev/null +++ b/docs/using-jellyseerr/advanced/verifying-signed-images.mdx @@ -0,0 +1,278 @@ +--- +id: verifying-signed-images +title: Verifying Signed Images +sidebar_label: Verify Signed Images +description: Learn how to verify Seerr's signed container images and SBOM attestations using Cosign, Docker, Podman, or Skopeo. +--- + +import Tabs from '@theme/Tabs'; +import TabItem from '@theme/TabItem'; + +# Verifying Signed Images + +All Seerr container images published to GitHub Container Registry (GHCR) are cryptographically signed using [Sigstore Cosign](https://docs.sigstore.dev/quickstart/quickstart-cosign/). +This ensures that the images you pull are authentic, tamper-proof, and built by the official Seerr release pipeline. + +Each image also includes a CycloneDX SBOM (Software Bill of Materials) attestation, generated with [Trivy](https://aquasecurity.github.io/trivy/), providing transparency about all dependencies included in the image. + +--- + +## Prerequisites + +You will need the following tools installed: + +- [Cosign](https://docs.sigstore.dev/cosign/system_config/installation/) +- [Docker](https://docs.docker.com/get-docker/) **or** +- [Podman](https://podman.io/getting-started/installation) (including [Skopeo](https://github.com/containers/skopeo/blob/main/install.md)) + +```bash +cosign version +``` + +If using **Podman**, ensure `skopeo` is available: + +```bash +skopeo --version +``` + +--- + +## Image Locations + +Official Seerr images are available from: + +- GitHub Container Registry (GHCR): `ghcr.io/seerr-team/seerr:` + +You can view all available tags on the [Seerr Releases page](https://github.com/seerr-team/seerr/releases). + +--- + +## Verifying a Specific Release Tag + +Each tagged release (for example `v2.7.4`) is immutable and cryptographically signed. +Verification should always be performed using the image digest (SHA256). + +### Retrieve the Image Digest + + + + +```bash +docker buildx imagetools inspect docker.io/seerr-team/seerr:v2.7.4 --format '{{json .Manifest.Digest}}' | tr -d '"' +``` + + + + +```bash +skopeo inspect docker://ghcr.io/seerr-team/seerr:v2.7.4 --format '{{.Digest}}' +``` + + + +Example output: + +``` +sha256:abcd1234... +``` + +--- + +### Verify the Image Signature + + + + +```bash +cosign verify ghcr.io/seerr-team/seerr@sha256:abcd1234... \ + --certificate-identity "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v2.7.4" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + + +```bash +cosign verify seerr/seerr@sha256:abcd1234... \ + --certificate-identity "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v2.7.4" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + +:::info Successful Verification Example +Verification for `ghcr.io/seerr-team/seerr@sha256:abcd1234...` + +The following checks were performed: + +- Cosign claims validated +- Signatures verified against the transparency log +- Certificate issued by Fulcio to the expected workflow identity +::: + +--- + +## Verifying the `latest` Tag + +:::warning Latest Tag Warning +The `latest` tag is **mutable**, meaning it will change with each new release. +Always verify the digest that `latest` currently points to. +::: + +### Retrieve the Digest for `latest` + + + + +```bash +docker buildx imagetools inspect ghcr.io/seerr-team/seerr:latest --format '{{json .Manifest.Digest}}' | tr -d '"' +``` + + + + +```bash +skopeo inspect docker://ghcr.io/seerr-team/seerr:latest --format '{{.Digest}}' +``` + + + +Example output: + +``` +sha256:abcd1234... +``` + +### Verify the Signature + + + + +```bash +cosign verify ghcr.io/seerr-team/seerr@sha256:abcd1234... \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v.*" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + + +```bash +cosign verify seerr/seerr@sha256:abcd1234... \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v.*" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + +:::tip +The wildcard `v.*` ensures verification works for any versioned release that `latest` represents. +::: + +--- + +## Verifying SBOM Attestations + +Each image includes a CycloneDX SBOM attestation. + +### Verify the Attestation + +```bash +cosign verify-attestation ghcr.io/seerr-team/seerr@sha256:abcd1234... \ + --type cyclonedx \ + --certificate-identity "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v2.7.4" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` +:::info Successful Verification Example +Verification for `ghcr.io/seerr-team/seerr@sha256:abcd1234...` + +The following checks were performed: + +- Cosign claims validated +- Signatures verified against the transparency log +- Certificate issued by Fulcio to the expected workflow identity +::: + +### Extract the SBOM for Inspection + +```bash +cosign verify-attestation ghcr.io/seerr-team/seerr@sha256:abcd1234... \ + --type cyclonedx \ + --certificate-identity "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v2.7.4" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" | jq -r '.payload | @base64d' > sbom.json +``` + +You can open `sbom.json` in a CycloneDX viewer or analyse it with [Trivy](https://aquasecurity.github.io/trivy/) or [Dependency-Track](https://dependencytrack.org/). + +--- + +## Expected Certificate Identity + +The expected certificate identity for all signed Seerr images is: + +``` +https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v* +``` + +This confirms that the image was: + +- Built by the official Seerr Release workflow +- Produced from the seerr-team/seerr repository +- Signed using GitHub’s OIDC identity via Sigstore Fulcio + +--- + +## Troubleshooting + +| Issue | Likely Cause | Suggested Fix | +|-------|---------------|----------------| +| `no matching signatures` | Incorrect digest or tag | Retrieve the digest again using Docker or Skopeo | +| `certificate identity does not match expected` | Workflow reference changed | Ensure your `--certificate-identity` matches this documentation | +| `cosign: command not found` | Cosign not installed | Install Cosign from the official release | +| `certificate expired` | Old release | Verify a newer tag or digest | + +--- + +## Example: Full Verification Flow + + + + +```bash +DIGEST=$(docker buildx imagetools inspect ghcr.io/seerr-team/seerr:latest --format '{{json .Manifest.Digest}}' | tr -d '"') + +cosign verify ghcr.io/seerr-team/seerr@"$DIGEST" \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v.*" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" + +cosign verify-attestation ghcr.io/seerr-team/seerr@"$DIGEST" \ + --type cyclonedx \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v.*" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + + +```bash +DIGEST=$(skopeo inspect docker://ghcr.io/seerr-team/seerr:latest --format '{{.Digest}}') + +cosign verify ghcr.io/seerr-team/seerr@"$DIGEST" \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/release.yml@refs/tags/v.*" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + +--- + +## Further Reading + +- [Sigstore Documentation](https://docs.sigstore.dev) +- [Cosign Verification Guide](https://docs.sigstore.dev/cosign/verifying/verify/) +- [CycloneDX Specification](https://cyclonedx.org/specification/overview/) +- [Trivy Documentation](https://trivy.dev/latest/docs/) +- [Skopeo Documentation](https://github.com/containers/skopeo) +- [Podman Documentation](https://podman.io/get-started/) +- [Docker Documentation](https://docs.docker.com/) +- [Seerr GitHub Repository](https://github.com/seerr-team/seerr) From a988f8e657cb506bb23192a41de02c6d4274ebdb Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Thu, 16 Oct 2025 14:12:17 +0100 Subject: [PATCH 78/96] fix: update github repo refs for docker hub (#2053) * fix: update github repo refs for docker hub * ci: updated wf to use env var for the docker hub space --- .github/workflows/release.yml | 17 ++++++++++------- .../advanced/verifying-signed-images.mdx | 2 +- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 586528b0e6..35188a3cee 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -13,6 +13,9 @@ concurrency: group: release-${{ github.ref }} cancel-in-progress: true +env: + DOCKER_HUB: seerr/seerr + jobs: changelog: name: Generate changelog @@ -177,8 +180,8 @@ jobs: if: ${{ !contains(env.VERSION, '-') }} run: | docker buildx imagetools create \ - -t ${{ github.repository }}:latest \ - ${{ github.repository }}:${{ env.VERSION }} + -t ${{ env.DOCKER_HUB }}:latest \ + ${{ env.DOCKER_HUB }}:${{ env.VERSION }} docker buildx imagetools create \ -t ghcr.io/${{ github.repository }}:latest \ @@ -223,7 +226,7 @@ jobs: - name: Sign images run: | cosign sign --recursive "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" - cosign sign --recursive "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + cosign sign --recursive "${{ env.DOCKER_HUB }}@${{ needs.publish.outputs.image_digest }}" - name: Generate SBOMs run: | @@ -231,7 +234,7 @@ jobs: "ghcr.io/${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" trivy image --format cyclonedx --output seerr-dockerhub-image-${{ env.VERSION }}.sbom \ - "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + "${{ env.DOCKER_HUB }}@${{ needs.publish.outputs.image_digest }}" - name: Attest SBOMs run: | @@ -243,7 +246,7 @@ jobs: cosign attest \ --type cyclonedx \ --predicate seerr-dockerhub-image-${{ env.VERSION }}.sbom \ - "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" + "${{ env.DOCKER_HUB }}@${{ needs.publish.outputs.image_digest }}" - name: Upload SBOMs uses: actions/upload-artifact@ea165f8d65b6e75b540449e92b4886f43607fa02 # v4.6.2 @@ -271,7 +274,7 @@ jobs: --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ --certificate-oidc-issuer "https://token.actions.githubusercontent.com" - cosign verify "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" \ + cosign verify "${{ env.DOCKER_HUB }}@${{ needs.publish.outputs.image_digest }}" \ --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ --certificate-oidc-issuer "https://token.actions.githubusercontent.com" @@ -282,7 +285,7 @@ jobs: --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ --certificate-oidc-issuer "https://token.actions.githubusercontent.com" > /dev/null - cosign verify-attestation "${{ github.repository }}@${{ needs.publish.outputs.image_digest }}" \ + cosign verify-attestation "${{ env.DOCKER_HUB }}@${{ needs.publish.outputs.image_digest }}" \ --type cyclonedx \ --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ --certificate-oidc-issuer "https://token.actions.githubusercontent.com" > /dev/null diff --git a/docs/using-jellyseerr/advanced/verifying-signed-images.mdx b/docs/using-jellyseerr/advanced/verifying-signed-images.mdx index b05b2d255a..5ebc406437 100644 --- a/docs/using-jellyseerr/advanced/verifying-signed-images.mdx +++ b/docs/using-jellyseerr/advanced/verifying-signed-images.mdx @@ -58,7 +58,7 @@ Verification should always be performed using the image digest (SHA256). ```bash -docker buildx imagetools inspect docker.io/seerr-team/seerr:v2.7.4 --format '{{json .Manifest.Digest}}' | tr -d '"' +docker buildx imagetools inspect ghcr.io/seerr-team/seerr:v2.7.4 --format '{{json .Manifest.Digest}}' | tr -d '"' ``` From f3d8f0d7ab274642ecf96ae6af5081beb2d91ec3 Mon Sep 17 00:00:00 2001 From: Terry Sposato Date: Fri, 17 Oct 2025 00:15:09 +1100 Subject: [PATCH 79/96] docs: add haproxy configuration example (#2048) --- docs/extending-jellyseerr/reverse-proxy.mdx | 33 ++++++++++++++++++++- docs/troubleshooting.mdx | 2 +- 2 files changed, 33 insertions(+), 2 deletions(-) diff --git a/docs/extending-jellyseerr/reverse-proxy.mdx b/docs/extending-jellyseerr/reverse-proxy.mdx index 82f30a4bbe..88ea5d5b89 100644 --- a/docs/extending-jellyseerr/reverse-proxy.mdx +++ b/docs/extending-jellyseerr/reverse-proxy.mdx @@ -249,7 +249,7 @@ Add the following Location block to your existing Server configuration. # Please Replace "FQDN" with your domain Header edit location ^/login https://FQDN/jellyseerr/login Header edit location ^/setup https://FQDN/jellyseerr/setup - + AddOutputFilterByType INFLATE;SUBSTITUTE text/html application/javascript application/json SubstituteMaxLineLength 2000K # This is HTML and JS update @@ -266,3 +266,34 @@ Add the following Location block to your existing Server configuration. + +## HAProxy (v3) + + This is third-party documentation maintained by the community. We can't provide support for this setup and are unable to test it. + + Add the following frontend and backend configurations for your seerr instance: + ```haproxy + frontend seerr-frontend + bind 0.0.0.0:80 + bind 0.0.0.0:443 ssl crt /etc/ssl/private/seerr.example.com.pem + mode http + log global + option httplog + option http-keep-alive + http-request set-header X-Real-IP %[src] + option forwardfor + acl seerr hdr(host) -i seerr.example.com + redirect scheme https code 301 if !{ ssl_fc } + use_backend seerr-backend if seerr + + backend seerr-backend + mode http + log global + option httplog + http-response set-header Strict-Transport-Security max-age=15552000 + option httpchk GET /api/v1/status + timeout connect 30000 + timeout server 30000 + retries 3 + server seerr 127.0.0.1:5055 check inter 1000 + ``` diff --git a/docs/troubleshooting.mdx b/docs/troubleshooting.mdx index a79b316b9a..c35e07361b 100644 --- a/docs/troubleshooting.mdx +++ b/docs/troubleshooting.mdx @@ -103,7 +103,7 @@ If you can't change your DNS servers or force IPV4 resolution, you can use Jelly In some places (like China), the ISP blocks not only the DNS resolution but also the connection to the TMDB API. -You can configure Jellyseerr to use a proxy with the [HTTP(S) Proxy](/using-jellyseerr/settings/general#https-proxy) setting. +You can configure Jellyseerr to use a proxy with the [HTTP(S) Proxy](/using-jellyseerr/settings/general#enable-proxy-support) setting. ### Option 3: Force IPV4 resolution first From c4236dce732a8bec067a7239af2381682409f962 Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Thu, 16 Oct 2025 21:48:13 +0800 Subject: [PATCH 80/96] docs: HAProxy documentation warning format (#2054) Updated warning message for HAProxy documentation. And fixed a typo --- docs/extending-jellyseerr/reverse-proxy.mdx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/extending-jellyseerr/reverse-proxy.mdx b/docs/extending-jellyseerr/reverse-proxy.mdx index 88ea5d5b89..9b248afae3 100644 --- a/docs/extending-jellyseerr/reverse-proxy.mdx +++ b/docs/extending-jellyseerr/reverse-proxy.mdx @@ -269,7 +269,9 @@ Add the following Location block to your existing Server configuration. ## HAProxy (v3) - This is third-party documentation maintained by the community. We can't provide support for this setup and are unable to test it. +:::warning +This is a third-party documentation maintained by the community. We can't provide support for this setup and are unable to test it. +::: Add the following frontend and backend configurations for your seerr instance: ```haproxy From a0893a5831fb8a4b5afd6eb0acf9559d9d6cf488 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 16 Oct 2025 21:19:33 +0200 Subject: [PATCH 81/96] ci(actions): update github actions (#2022) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/ci.yml | 4 ++-- .github/workflows/codeql.yml | 6 +++--- .github/workflows/cypress.yml | 2 +- .github/workflows/docs-deploy.yml | 2 +- .github/workflows/test-docs-deploy.yml | 2 +- .github/workflows/trivy-scan.yml | 2 +- 6 files changed, 9 insertions(+), 9 deletions(-) diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 04fa51cfee..5df2185ed2 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -23,7 +23,7 @@ jobs: name: Lint & Test Build if: github.event_name == 'pull_request' runs-on: ubuntu-24.04 - container: node:22.20.0-alpine3.22@sha256:cb3143549582cc5f74f26f0992cdef4a422b22128cb517f94173a5f910fa4ee7 + container: node:22.20.0-alpine3.22@sha256:dbcedd8aeab47fbc0f4dd4bffa55b7c3c729a707875968d467aaaea42d6225af steps: - name: Checkout uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 @@ -31,7 +31,7 @@ jobs: persist-credentials: false - name: Pnpm Setup - uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 + uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 - name: Get pnpm store directory shell: sh diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index 199b830dfd..55a3485db0 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -42,15 +42,15 @@ jobs: persist-credentials: false - name: Initialize CodeQL - uses: github/codeql-action/init@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 + uses: github/codeql-action/init@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 with: languages: ${{ matrix.language }} queries: +security-and-quality - name: Autobuild - uses: github/codeql-action/autobuild@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 + uses: github/codeql-action/autobuild@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 + uses: github/codeql-action/analyze@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 with: category: '/language:${{ matrix.language }}' diff --git a/.github/workflows/cypress.yml b/.github/workflows/cypress.yml index 76ffa21517..7c88b96b92 100644 --- a/.github/workflows/cypress.yml +++ b/.github/workflows/cypress.yml @@ -48,7 +48,7 @@ jobs: package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 + uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 - name: Install dependencies run: pnpm install --frozen-lockfile diff --git a/.github/workflows/docs-deploy.yml b/.github/workflows/docs-deploy.yml index fc98ab7935..4d072e4a40 100644 --- a/.github/workflows/docs-deploy.yml +++ b/.github/workflows/docs-deploy.yml @@ -34,7 +34,7 @@ jobs: package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 + uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 - name: Get pnpm store directory shell: sh diff --git a/.github/workflows/test-docs-deploy.yml b/.github/workflows/test-docs-deploy.yml index 1fb49859dc..040f7db0c3 100644 --- a/.github/workflows/test-docs-deploy.yml +++ b/.github/workflows/test-docs-deploy.yml @@ -36,7 +36,7 @@ jobs: package-manager-cache: false - name: Pnpm Setup - uses: pnpm/action-setup@a7487c7e89a18df4991f7f222e4898a00d66ddda # v4.1.0 + uses: pnpm/action-setup@41ff72655975bd51cab0327fa583b6e92b6d3061 # v4.2.0 - name: Get pnpm store directory shell: sh diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml index 008c648623..61d9427ab6 100644 --- a/.github/workflows/trivy-scan.yml +++ b/.github/workflows/trivy-scan.yml @@ -56,6 +56,6 @@ jobs: ignore-unfixed: true - name: Upload SARIF to code scanning - uses: github/codeql-action/upload-sarif@64d10c13136e1c5bce3e5fbde8d4906eeaafc885 # v3.30.6 + uses: github/codeql-action/upload-sarif@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 with: sarif_file: trivy.sarif From 669faccc85f817bbc4099d09be69fcbf8cf85412 Mon Sep 17 00:00:00 2001 From: "renovate[bot]" <29139614+renovate[bot]@users.noreply.github.com> Date: Thu, 16 Oct 2025 21:30:50 +0200 Subject: [PATCH 82/96] ci(actions): update github/codeql-action action to v4 (#2056) Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com> --- .github/workflows/codeql.yml | 6 +++--- .github/workflows/trivy-scan.yml | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/.github/workflows/codeql.yml b/.github/workflows/codeql.yml index 55a3485db0..a2fd40c96a 100644 --- a/.github/workflows/codeql.yml +++ b/.github/workflows/codeql.yml @@ -42,15 +42,15 @@ jobs: persist-credentials: false - name: Initialize CodeQL - uses: github/codeql-action/init@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 + uses: github/codeql-action/init@e296a935590eb16afc0c0108289f68c87e2a89a5 # v4.30.7 with: languages: ${{ matrix.language }} queries: +security-and-quality - name: Autobuild - uses: github/codeql-action/autobuild@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 + uses: github/codeql-action/autobuild@e296a935590eb16afc0c0108289f68c87e2a89a5 # v4.30.7 - name: Perform CodeQL Analysis - uses: github/codeql-action/analyze@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 + uses: github/codeql-action/analyze@e296a935590eb16afc0c0108289f68c87e2a89a5 # v4.30.7 with: category: '/language:${{ matrix.language }}' diff --git a/.github/workflows/trivy-scan.yml b/.github/workflows/trivy-scan.yml index 61d9427ab6..4b920746ab 100644 --- a/.github/workflows/trivy-scan.yml +++ b/.github/workflows/trivy-scan.yml @@ -56,6 +56,6 @@ jobs: ignore-unfixed: true - name: Upload SARIF to code scanning - uses: github/codeql-action/upload-sarif@a8d1ac45b9a34d11fe398d5503176af0d06b303e # v3.30.7 + uses: github/codeql-action/upload-sarif@e296a935590eb16afc0c0108289f68c87e2a89a5 # v4.30.7 with: sarif_file: trivy.sarif From 81eab7434fb2d6f76f843114c000b609f8cd04bf Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Fri, 17 Oct 2025 18:00:44 +0300 Subject: [PATCH 83/96] ci: fix concurrency issue on support workflows (#2062) [skip ci] Signed-off-by: Ludovic Ortega --- .github/workflows/support.yml | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/.github/workflows/support.yml b/.github/workflows/support.yml index 8d4018d281..c29eb9829e 100644 --- a/.github/workflows/support.yml +++ b/.github/workflows/support.yml @@ -9,14 +9,13 @@ on: permissions: issues: read -concurrency: - group: support-${{ github.event.issue.number }} - cancel-in-progress: true - jobs: support: if: github.event.label.name == 'support' || github.event.action == 'reopened' runs-on: ubuntu-24.04 + concurrency: + group: support-${{ github.event.issue.number }} + cancel-in-progress: true permissions: issues: write env: From 0dbbac02af8b4535e70ff93dd287b2392f80a9f2 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Fri, 17 Oct 2025 18:22:19 +0300 Subject: [PATCH 84/96] docs: add documentation for dockerhub (#2063) * docs: add documentation for dockerhub Signed-off-by: Ludovic Ortega * docs: typo fixes --------- Signed-off-by: Ludovic Ortega Co-authored-by: sudo-kraken --- docs/getting-started/docker.mdx | 6 +- ...ges.mdx => verifying-signed-artifacts.mdx} | 59 ++++++++++--------- 2 files changed, 37 insertions(+), 28 deletions(-) rename docs/using-jellyseerr/advanced/{verifying-signed-images.mdx => verifying-signed-artifacts.mdx} (86%) diff --git a/docs/getting-started/docker.mdx b/docs/getting-started/docker.mdx index acc6257aa3..7efb5a2de1 100644 --- a/docs/getting-started/docker.mdx +++ b/docs/getting-started/docker.mdx @@ -11,6 +11,10 @@ Details on how to install Docker can be found on the [official Docker website](h Refer to [Configuring Databases](/extending-jellyseerr/database-config#postgresql-options) for details on how to configure your database. ::: +:::info +An alternative Docker image is available on Docker Hub for this project. You can find it at [Docker Hub Repository Link](https://hub.docker.com/r/seerr/seerr) +::: + ## Unix (Linux, macOS) :::warning Be sure to replace `/path/to/appdata/config` in the below examples with a valid host directory path. If this volume mount is not configured correctly, your Jellyseerr settings/data will not be persisted when the container is recreated (e.g., when updating the image or rebooting your machine). @@ -71,7 +75,7 @@ docker run -d ... :::info All official Seerr images are cryptographically signed and include a verified [Software Bill of Materials (SBOM)](https://cyclonedx.org/). -To confirm that the container image you are using is authentic and unmodified, please refer to the [Verifying Signed Images](/using-jellyseerr/advanced/verifying-signed-images) guide. +To confirm that the container image you are using is authentic and unmodified, please refer to the [Verifying Signed Artifacts](/using-jellyseerr/advanced/verifying-signed-artifacts) guide. ::: :::tip diff --git a/docs/using-jellyseerr/advanced/verifying-signed-images.mdx b/docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx similarity index 86% rename from docs/using-jellyseerr/advanced/verifying-signed-images.mdx rename to docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx index 5ebc406437..c706fcab98 100644 --- a/docs/using-jellyseerr/advanced/verifying-signed-images.mdx +++ b/docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx @@ -1,19 +1,21 @@ --- -id: verifying-signed-images -title: Verifying Signed Images -sidebar_label: Verify Signed Images -description: Learn how to verify Seerr's signed container images and SBOM attestations using Cosign, Docker, Podman, or Skopeo. +id: verifying-signed-artifacts +title: Verifying Signed Artifacts +sidebar_label: Verify Signed Artifacts +description: Learn how to verify Seerr's signed artifacts and SBOM attestations. --- import Tabs from '@theme/Tabs'; import TabItem from '@theme/TabItem'; -# Verifying Signed Images +# Verifying Signed Artifacts + +These artifacts are cryptographically signed using [Sigstore Cosign](https://docs.sigstore.dev/quickstart/quickstart-cosign/): +- Container images -All Seerr container images published to GitHub Container Registry (GHCR) are cryptographically signed using [Sigstore Cosign](https://docs.sigstore.dev/quickstart/quickstart-cosign/). This ensures that the images you pull are authentic, tamper-proof, and built by the official Seerr release pipeline. -Each image also includes a CycloneDX SBOM (Software Bill of Materials) attestation, generated with [Trivy](https://aquasecurity.github.io/trivy/), providing transparency about all dependencies included in the image. +Additionally each container image also includes a CycloneDX SBOM (Software Bill of Materials) attestation, generated with [Trivy](https://aquasecurity.github.io/trivy/), providing transparency about all dependencies included in the image. --- @@ -22,37 +24,40 @@ Each image also includes a CycloneDX SBOM (Software Bill of Materials) attestati You will need the following tools installed: - [Cosign](https://docs.sigstore.dev/cosign/system_config/installation/) + +To verify images: + - [Docker](https://docs.docker.com/get-docker/) **or** - [Podman](https://podman.io/getting-started/installation) (including [Skopeo](https://github.com/containers/skopeo/blob/main/install.md)) -```bash -cosign version -``` +--- -If using **Podman**, ensure `skopeo` is available: +# Verifying Signed Images -```bash -skopeo --version -``` +All Seerr container images published to GitHub Container Registry (GHCR) are cryptographically signed using [Sigstore Cosign](https://docs.sigstore.dev/quickstart/quickstart-cosign/). +This ensures that the images you pull are authentic, tamper-proof, and built by the official Seerr release pipeline. + +Each image also includes a CycloneDX SBOM (Software Bill of Materials) attestation, generated with [Trivy](https://aquasecurity.github.io/trivy/), providing transparency about all dependencies included in the image. --- -## Image Locations +### Image Locations Official Seerr images are available from: - GitHub Container Registry (GHCR): `ghcr.io/seerr-team/seerr:` +- Docker Hub: `seerr/seerr:` You can view all available tags on the [Seerr Releases page](https://github.com/seerr-team/seerr/releases). --- -## Verifying a Specific Release Tag +### Verifying a Specific Release Tag Each tagged release (for example `v2.7.4`) is immutable and cryptographically signed. Verification should always be performed using the image digest (SHA256). -### Retrieve the Image Digest +#### Retrieve the Image Digest @@ -78,7 +83,7 @@ sha256:abcd1234... --- -### Verify the Image Signature +#### Verify the Image Signature @@ -112,14 +117,14 @@ The following checks were performed: --- -## Verifying the `latest` Tag +### Verifying the `latest` Tag :::warning Latest Tag Warning The `latest` tag is **mutable**, meaning it will change with each new release. Always verify the digest that `latest` currently points to. ::: -### Retrieve the Digest for `latest` +#### Retrieve the Digest for `latest` @@ -143,7 +148,7 @@ Example output: sha256:abcd1234... ``` -### Verify the Signature +#### Verify the Signature @@ -171,11 +176,11 @@ The wildcard `v.*` ensures verification works for any versioned release that `la --- -## Verifying SBOM Attestations +### Verifying SBOM Attestations Each image includes a CycloneDX SBOM attestation. -### Verify the Attestation +#### Verify the Attestation ```bash cosign verify-attestation ghcr.io/seerr-team/seerr@sha256:abcd1234... \ @@ -193,7 +198,7 @@ The following checks were performed: - Certificate issued by Fulcio to the expected workflow identity ::: -### Extract the SBOM for Inspection +#### Extract the SBOM for Inspection ```bash cosign verify-attestation ghcr.io/seerr-team/seerr@sha256:abcd1234... \ @@ -206,7 +211,7 @@ You can open `sbom.json` in a CycloneDX viewer or analyse it with [Trivy](https: --- -## Expected Certificate Identity +### Expected Certificate Identity The expected certificate identity for all signed Seerr images is: @@ -222,7 +227,7 @@ This confirms that the image was: --- -## Troubleshooting +### Troubleshooting | Issue | Likely Cause | Suggested Fix | |-------|---------------|----------------| @@ -233,7 +238,7 @@ This confirms that the image was: --- -## Example: Full Verification Flow +### Example: Full Verification Flow From 0d6bfa18ccddf4908b596bbbbe865f761aebf07f Mon Sep 17 00:00:00 2001 From: fallenbagel <98979876+fallenbagel@users.noreply.github.com> Date: Sat, 18 Oct 2025 03:10:02 +0800 Subject: [PATCH 85/96] fix(download-tracker): reset both service caches when resetting downloads (#2065) --- server/lib/downloadtracker.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/server/lib/downloadtracker.ts b/server/lib/downloadtracker.ts index b96bfca8d9..f160f6c89d 100644 --- a/server/lib/downloadtracker.ts +++ b/server/lib/downloadtracker.ts @@ -56,6 +56,7 @@ class DownloadTracker { public async resetDownloadTracker() { this.radarrServers = {}; + this.sonarrServers = {}; } public updateDownloads() { From a975ab25c36b3a262123039c462d332a5a3ff4b1 Mon Sep 17 00:00:00 2001 From: Brandon Cohen Date: Sat, 18 Oct 2025 12:03:28 -0400 Subject: [PATCH 86/96] fix: delete endpoint on push notification disable (#2067) fix: add endpoint deletion on disable fix: use definemessages util refactor: add code comment --- server/routes/user/index.ts | 12 ++++++++---- .../UserNotificationsWebPush/index.tsx | 5 +++++ 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/server/routes/user/index.ts b/server/routes/user/index.ts index 9dd8ca03b5..e3a5fd074c 100644 --- a/server/routes/user/index.ts +++ b/server/routes/user/index.ts @@ -269,16 +269,20 @@ router.delete<{ userId: number; endpoint: string }>( try { const userPushSubRepository = getRepository(UserPushSubscription); - const userPushSub = await userPushSubRepository.findOneOrFail({ - relations: { - user: true, - }, + const userPushSub = await userPushSubRepository.findOne({ + relations: { user: true }, where: { user: { id: req.params.userId }, endpoint: req.params.endpoint, }, }); + // If not found, just return 204 to prevent push disable failure + // (rare scenario where user push sub does not exist) + if (!userPushSub) { + return res.status(204).send(); + } + await userPushSubRepository.remove(userPushSub); return res.status(204).send(); } catch (e) { diff --git a/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx b/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx index fbe03f7cc6..cf054673fe 100644 --- a/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx +++ b/src/components/UserProfile/UserSettings/UserNotificationSettings/UserNotificationsWebPush/index.tsx @@ -111,6 +111,11 @@ const UserWebPushSettings = () => { try { await unsubscribeToPushNotifications(user?.id, endpoint); + // Delete from backend if endpoint is available + if (subEndpoint) { + await deletePushSubscriptionFromBackend(subEndpoint); + } + localStorage.setItem('pushNotificationsEnabled', 'false'); setWebPushEnabled(false); addToast(intl.formatMessage(messages.webpushhasbeendisabled), { From 082ba3d0373335865fa4d325951fa6e040bdf5ae Mon Sep 17 00:00:00 2001 From: Joe Harrison <53116754+sudo-kraken@users.noreply.github.com> Date: Sun, 19 Oct 2025 04:22:28 +0100 Subject: [PATCH 87/96] ci: added helm cosign verification and renovate app workflow to bump chart versions (#2064) * ci: added helm cosign verification and renovate app workflow to bump chart versions * docs: add helm artifacts verification Signed-off-by: Ludovic Ortega * fix: update app id Signed-off-by: Ludovic Ortega * docs: add documentation link in helm chart and seerr docs Signed-off-by: Ludovic Ortega --------- Signed-off-by: Ludovic Ortega Co-authored-by: Ludovic Ortega --- .github/workflows/helm.yml | 56 +++++- .github/workflows/release.yml | 1 + .../workflows/renovate-helm-custom-hooks.yml | 181 ++++++++++++++++++ charts/seerr-chart/README.md | 4 + charts/seerr-chart/README.md.gotmpl | 6 +- docs/getting-started/docker.mdx | 11 +- docs/getting-started/kubernetes.mdx | 6 + .../advanced/verifying-signed-artifacts.mdx | 145 ++++++++++++-- 8 files changed, 376 insertions(+), 34 deletions(-) create mode 100644 .github/workflows/renovate-helm-custom-hooks.yml diff --git a/.github/workflows/helm.yml b/.github/workflows/helm.yml index 4b1b4a7511..4af45586bc 100644 --- a/.github/workflows/helm.yml +++ b/.github/workflows/helm.yml @@ -55,7 +55,7 @@ jobs: # get current version current_version=$(grep '^version:' "$chart_path/Chart.yaml" | awk '{print $2}') # try to get current release version - if oras manifest fetch "ghcr.io/${GITHUB_REPOSITORY@L}/${chart_name}:${current_version}" >/dev/null 2>&1; then + if oras manifest fetch "ghcr.io/${{ github.repository }}/${chart_name}:${current_version}" >/dev/null 2>&1; then echo "No version change for $chart_name. Skipping." else helm dependency build "$chart_path" @@ -87,8 +87,8 @@ jobs: name: Publish to ghcr.io runs-on: ubuntu-24.04 permissions: - packages: write # needed for pushing to github registry - id-token: write # needed for signing the images with GitHub OIDC Token + packages: write + id-token: write needs: [package-helm-chart] if: needs.package-helm-chart.outputs.has_artifacts == 'true' steps: @@ -128,17 +128,59 @@ jobs: # push chart to OCI chart_release_file=$(basename "$chart_path") chart_name=${chart_release_file%-*} - helm push ${chart_path} oci://ghcr.io/${GITHUB_REPOSITORY@L} |& tee helm-push-output.log + helm push ${chart_path} oci://ghcr.io/${{ github.repository }} |& tee helm-push-output.log chart_digest=$(awk -F "[, ]+" '/Digest/{print $NF}' < helm-push-output.log) # sign chart - cosign sign "ghcr.io/${GITHUB_REPOSITORY@L}/${chart_name}@${chart_digest}" + cosign sign "ghcr.io/${{ github.repository }}/${chart_name}@${chart_digest}" # push artifacthub-repo.yml to OCI oras push \ - ghcr.io/${GITHUB_REPOSITORY@L}/${chart_name}:artifacthub.io \ + ghcr.io/${{ github.repository }}/${chart_name}:artifacthub.io \ --config /dev/null:application/vnd.cncf.artifacthub.config.v1+yaml \ charts/$chart_name/artifacthub-repo.yml:application/vnd.cncf.artifacthub.repository-metadata.layer.v1.yaml \ |& tee oras-push-output.log artifacthub_digest=$(grep "Digest:" oras-push-output.log | awk '{print $2}') # sign artifacthub-repo.yml - cosign sign "ghcr.io/${GITHUB_REPOSITORY@L}/${chart_name}:artifacthub.io@${artifacthub_digest}" + cosign sign "ghcr.io/${{ github.repository }}/${chart_name}:artifacthub.io@${artifacthub_digest}" + done + + verify: + name: Verify signatures for each chart tag + needs: [publish] + runs-on: ubuntu-24.04 + permissions: + contents: read + steps: + - name: Checkout + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + with: + fetch-depth: 0 + persist-credentials: false + + - name: Install Cosign + uses: sigstore/cosign-installer@d7543c93d881b35a8faa02e8e3605f69b7a1ce62 # v3.10.0 + + - name: Downloads artifacts + uses: actions/download-artifact@634f93cb2916e3fdff6788551b99b062d0335ce0 # v5.0.0 + with: + name: artifacts + path: .cr-release-packages/ + + - name: Login to GitHub Container Registry + uses: docker/login-action@5e57cd118135c172c3672efd75eb46360885c0ef # v3.6.0 + with: + registry: ghcr.io + username: ${{ github.actor }} + password: ${{ secrets.GITHUB_TOKEN }} + + - name: Verify signatures for each chart tag + run: | + for chart_path in $(find .cr-release-packages -name '*.tgz' -print); do + chart_release_file=$(basename "$chart_path") + chart_name=${chart_release_file%-*} + version=${chart_release_file#$chart_name-} + version=${version%.tgz} + + cosign verify "ghcr.io/${{ github.repository }}/${chart_name}:${version}" \ + --certificate-identity "https://github.com/${{ github.workflow_ref }}" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" done diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 35188a3cee..53b806f3d1 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -1,3 +1,4 @@ +--- # yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json name: Seerr Release diff --git a/.github/workflows/renovate-helm-custom-hooks.yml b/.github/workflows/renovate-helm-custom-hooks.yml new file mode 100644 index 0000000000..e833403a21 --- /dev/null +++ b/.github/workflows/renovate-helm-custom-hooks.yml @@ -0,0 +1,181 @@ +--- +# yaml-language-server: $schema=https://json.schemastore.org/github-workflow.json +name: Renovate Helm Hooks + +on: + pull_request: + branches: + - develop + paths: + - 'charts/**' + +permissions: {} + +concurrency: + group: renovate-helm-hooks-${{ github.ref }} + cancel-in-progress: true + +jobs: + renovate-post-run: + name: Renovate Bump Chart Version + runs-on: ubuntu-latest + permissions: + contents: read + pull-requests: write + if: github.actor == 'renovate[bot]' + steps: + - name: Checkout code + uses: actions/checkout@08c6903cd8c0fde910a37f88322edcfb5dd907a8 # v5.0.0 + with: + fetch-depth: 0 + persist-credentials: false + + - uses: actions/create-github-app-token@67018539274d69449ef7c02e8e71183d1719ab42 # v2.1.4 + id: app-token + with: + app-id: 2138788 + private-key: ${{ secrets.APP_SEERR_HELM_PRIVATE_KEY }} + + - name: Set up chart-testing + uses: helm/chart-testing-action@0d28d3144d3a25ea2cc349d6e59901c4ff469b3b # v2.7.0 + + - name: Run chart-testing (list-changed) + id: list-changed + run: | + changed="$(ct list-changed --target-branch ${TARGET_BRANCH})" + if [[ -n "$changed" ]]; then + echo "changed=true" >> "$GITHUB_OUTPUT" + echo "changed_list=${changed//$'\n'/ }" >> "$GITHUB_OUTPUT" + fi + env: + TARGET_BRANCH: ${{ github.event.repository.default_branch }} + + - name: Bump chart version + if: steps.list-changed.outputs.changed == 'true' + env: + CHART: ${{ steps.list-changed.outputs.changed_list }} + run: | + if [[ ! -d "${CHART}" ]]; then + echo "${CHART} directory not found" + exit 0 + fi + + # Extract current appVersion and chart version from Chart.yaml + APP_VERSION=$(grep -e "^appVersion:" "$CHART/Chart.yaml" | cut -d ":" -f 2 | tr -d '[:space:]' | tr -d '"') + CHART_VERSION=$(grep -e "^version:" "$CHART/Chart.yaml" | cut -d ":" -f 2 | tr -d '[:space:]' | tr -d '"') + + # Extract major, minor and patch versions of appVersion + APP_MAJOR_VERSION=$(printf '%s' "$APP_VERSION" | cut -d "." -f 1) + APP_MINOR_VERSION=$(printf '%s' "$APP_VERSION" | cut -d "." -f 2) + APP_PATCH_VERSION=$(printf '%s' "$APP_VERSION" | cut -d "." -f 3) + + # Extract major, minor and patch versions of chart version + CHART_MAJOR_VERSION=$(printf '%s' "$CHART_VERSION" | cut -d "." -f 1) + CHART_MINOR_VERSION=$(printf '%s' "$CHART_VERSION" | cut -d "." -f 2) + CHART_PATCH_VERSION=$(printf '%s' "$CHART_VERSION" | cut -d "." -f 3) + + # Get previous appVersion from the base commit of the pull request + BASE_COMMIT=$(git merge-base origin/main HEAD) + PREV_APP_VERSION=$(git show "$BASE_COMMIT":"$CHART/Chart.yaml" | grep -e "^appVersion:" | cut -d ":" -f 2 | tr -d '[:space:]' | tr -d '"') + + # Extract major, minor and patch versions of previous appVersion + PREV_APP_MAJOR_VERSION=$(printf '%s' "$PREV_APP_VERSION" | cut -d "." -f 1) + PREV_APP_MINOR_VERSION=$(printf '%s' "$PREV_APP_VERSION" | cut -d "." -f 2) + PREV_APP_PATCH_VERSION=$(printf '%s' "$PREV_APP_VERSION" | cut -d "." -f 3) + + # Check if the major, minor, or patch version of appVersion has changed + if [[ "$APP_MAJOR_VERSION" != "$PREV_APP_MAJOR_VERSION" ]]; then + # Bump major version of the chart and reset minor and patch versions to 0 + CHART_MAJOR_VERSION=$((CHART_MAJOR_VERSION+1)) + CHART_MINOR_VERSION=0 + CHART_PATCH_VERSION=0 + elif [[ "$APP_MINOR_VERSION" != "$PREV_APP_MINOR_VERSION" ]]; then + # Bump minor version of the chart and reset patch version to 0 + CHART_MINOR_VERSION=$((CHART_MINOR_VERSION+1)) + CHART_PATCH_VERSION=0 + elif [[ "$APP_PATCH_VERSION" != "$PREV_APP_PATCH_VERSION" ]]; then + # Bump patch version of the chart + CHART_PATCH_VERSION=$((CHART_PATCH_VERSION+1)) + fi + + # Update the chart version in Chart.yaml + CHART_NEW_VERSION="${CHART_MAJOR_VERSION}.${CHART_MINOR_VERSION}.${CHART_PATCH_VERSION}" + sed -i "s/^version:.*/version: ${CHART_NEW_VERSION}/" "$CHART/Chart.yaml" + + - name: Ensure documentation is updated + if: steps.list-changed.outputs.changed == 'true' + uses: docker://jnorwood/helm-docs:v1.14.2@sha256:7e562b49ab6b1dbc50c3da8f2dd6ffa8a5c6bba327b1c6335cc15ce29267979c + + - name: Commit changes + if: steps.list-changed.outputs.changed == 'true' + env: + CHART: ${{ steps.list-changed.outputs.changed_list }} + GITHUB_TOKEN: ${{ steps.app-token.outputs.token }} + GITHUB_HEAD_REF: ${{ github.head_ref }} + run: | + # Define the target directory + TARGET_DIR="$CHART" + + # Fetch deleted files in the target directory + DELETED_FILES=$(git diff --diff-filter=D --name-only HEAD -- "$TARGET_DIR") + + # Fetch added/modified files in the target directory + MODIFIED_FILES=$(git diff --diff-filter=ACM --name-only HEAD -- "$TARGET_DIR") + + # Create a temporary file for JSON output + FILE_CHANGES_JSON_FILE=$(mktemp) + + # Initialize JSON structure in the file + echo '{ "deletions": [], "additions": [] }' > "$FILE_CHANGES_JSON_FILE" + + # Add deletions + for file in $DELETED_FILES; do + jq --arg path "$file" '.deletions += [{"path": $path}]' "$FILE_CHANGES_JSON_FILE" > "$FILE_CHANGES_JSON_FILE.tmp" + mv "$FILE_CHANGES_JSON_FILE.tmp" "$FILE_CHANGES_JSON_FILE" + done + + # Add additions (new or modified files) + for file in $MODIFIED_FILES; do + BASE64_CONTENT=$(base64 -w 0 <"$file") # Encode file content + jq --arg path "$file" --arg content "$BASE64_CONTENT" \ + '.additions += [{"path": $path, "contents": $content}]' "$FILE_CHANGES_JSON_FILE" > "$FILE_CHANGES_JSON_FILE.tmp" + mv "$FILE_CHANGES_JSON_FILE.tmp" "$FILE_CHANGES_JSON_FILE" + done + + # Create a temporary file for the final JSON payload + JSON_PAYLOAD_FILE=$(mktemp) + + # Construct the final JSON using jq and store it in a file + jq -n --arg repo "$GITHUB_REPOSITORY" \ + --arg branch "$GITHUB_HEAD_REF" \ + --arg message "fix: post upgrade changes from renovate" \ + --arg expectedOid "$GITHUB_SHA" \ + --slurpfile fileChanges "$FILE_CHANGES_JSON_FILE" \ + '{ + query: "mutation ($input: CreateCommitOnBranchInput!) { + createCommitOnBranch(input: $input) { + commit { + url + } + } + }", + variables: { + input: { + branch: { + repositoryNameWithOwner: $repo, + branchName: $branch + }, + message: { headline: $message }, + fileChanges: $fileChanges[0], + expectedHeadOid: $expectedOid + } + } + }' > "$JSON_PAYLOAD_FILE" + + # Call GitHub API + curl https://api.github.com/graphql -f \ + -sSf -H "Authorization: Bearer $GITHUB_TOKEN" \ + --data "@$JSON_PAYLOAD_FILE" + + # Clean up temporary files + rm "$FILE_CHANGES_JSON_FILE" "$JSON_PAYLOAD_FILE" diff --git a/charts/seerr-chart/README.md b/charts/seerr-chart/README.md index 318f90b3c8..2b63be0317 100644 --- a/charts/seerr-chart/README.md +++ b/charts/seerr-chart/README.md @@ -20,6 +20,10 @@ Seerr helm chart for Kubernetes Kubernetes: `>=1.23.0-0` +## Installation + +Refer to [https://docs.seerr.dev/getting-started/kubernetes](Seerr kubernetes documentation) + ## Update Notes ### Updating to 3.0.0 diff --git a/charts/seerr-chart/README.md.gotmpl b/charts/seerr-chart/README.md.gotmpl index cdf6937404..15a45b0643 100644 --- a/charts/seerr-chart/README.md.gotmpl +++ b/charts/seerr-chart/README.md.gotmpl @@ -14,11 +14,15 @@ {{ template "chart.requirementsSection" . }} +## Installation + +Refer to [https://docs.seerr.dev/getting-started/kubernetes](Seerr kubernetes documentation) + ## Update Notes ### Updating to 3.0.0 -Nothing change we just rebranded `jellyseerr` helm-chart to `seerr` :) +Nothing has changed; we just rebranded the `jellyseerr` Helm chart to `seerr` 🥳. ### Updating to 2.7.0 diff --git a/docs/getting-started/docker.mdx b/docs/getting-started/docker.mdx index 7efb5a2de1..664882f8b2 100644 --- a/docs/getting-started/docker.mdx +++ b/docs/getting-started/docker.mdx @@ -15,6 +15,12 @@ Refer to [Configuring Databases](/extending-jellyseerr/database-config#postgresq An alternative Docker image is available on Docker Hub for this project. You can find it at [Docker Hub Repository Link](https://hub.docker.com/r/seerr/seerr) ::: +:::info +All official Seerr images are cryptographically signed and include a verified [Software Bill of Materials (SBOM)](https://cyclonedx.org/). + +To confirm that the container image you are using is authentic and unmodified, please refer to the [Verifying Signed Artifacts](/using-jellyseerr/advanced/verifying-signed-artifacts#verifying-signed-images) guide. +::: + ## Unix (Linux, macOS) :::warning Be sure to replace `/path/to/appdata/config` in the below examples with a valid host directory path. If this volume mount is not configured correctly, your Jellyseerr settings/data will not be persisted when the container is recreated (e.g., when updating the image or rebooting your machine). @@ -72,11 +78,6 @@ Finally, run the container with the same parameters originally used to create th ```bash docker run -d ... ``` -:::info -All official Seerr images are cryptographically signed and include a verified [Software Bill of Materials (SBOM)](https://cyclonedx.org/). - -To confirm that the container image you are using is authentic and unmodified, please refer to the [Verifying Signed Artifacts](/using-jellyseerr/advanced/verifying-signed-artifacts) guide. -::: :::tip You may alternatively use a third-party updating mechanism, such as [Watchtower](https://github.com/containrrr/watchtower) or [Ouroboros](https://github.com/pyouroboros/ouroboros), to keep Jellyseerr up-to-date automatically. diff --git a/docs/getting-started/kubernetes.mdx b/docs/getting-started/kubernetes.mdx index 4720abed96..1d5cb6ff00 100644 --- a/docs/getting-started/kubernetes.mdx +++ b/docs/getting-started/kubernetes.mdx @@ -8,6 +8,12 @@ sidebar_position: 5 This method is not recommended for most users. It is intended for advanced users who are using Kubernetes. ::: +:::info +All official Seerr charts are cryptographically signed and include a verified [Software Bill of Materials (SBOM)](https://cyclonedx.org/). + +To confirm that the chart you are using is authentic and unmodified, please refer to the [Verifying Signed Artifacts](/using-jellyseerr/advanced/verifying-signed-artifacts#verifying-signed-helm-charts) guide. +::: + ## Installation ```console helm install jellyseerr oci://ghcr.io/fallenbagel/jellyseerr/jellyseerr-chart diff --git a/docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx b/docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx index c706fcab98..3ed328676f 100644 --- a/docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx +++ b/docs/using-jellyseerr/advanced/verifying-signed-artifacts.mdx @@ -12,6 +12,7 @@ import TabItem from '@theme/TabItem'; These artifacts are cryptographically signed using [Sigstore Cosign](https://docs.sigstore.dev/quickstart/quickstart-cosign/): - Container images +- Helm charts This ensures that the images you pull are authentic, tamper-proof, and built by the official Seerr release pipeline. @@ -27,19 +28,11 @@ You will need the following tools installed: To verify images: -- [Docker](https://docs.docker.com/get-docker/) **or** -- [Podman](https://podman.io/getting-started/installation) (including [Skopeo](https://github.com/containers/skopeo/blob/main/install.md)) +- [Docker](https://docs.docker.com/get-docker/) **or** [Podman](https://podman.io/getting-started/installation) (including [Skopeo](https://github.com/containers/skopeo/blob/main/install.md)) --- -# Verifying Signed Images - -All Seerr container images published to GitHub Container Registry (GHCR) are cryptographically signed using [Sigstore Cosign](https://docs.sigstore.dev/quickstart/quickstart-cosign/). -This ensures that the images you pull are authentic, tamper-proof, and built by the official Seerr release pipeline. - -Each image also includes a CycloneDX SBOM (Software Bill of Materials) attestation, generated with [Trivy](https://aquasecurity.github.io/trivy/), providing transparency about all dependencies included in the image. - ---- +## Verifying Signed Images ### Image Locations @@ -227,17 +220,6 @@ This confirms that the image was: --- -### Troubleshooting - -| Issue | Likely Cause | Suggested Fix | -|-------|---------------|----------------| -| `no matching signatures` | Incorrect digest or tag | Retrieve the digest again using Docker or Skopeo | -| `certificate identity does not match expected` | Workflow reference changed | Ensure your `--certificate-identity` matches this documentation | -| `cosign: command not found` | Cosign not installed | Install Cosign from the official release | -| `certificate expired` | Old release | Verify a newer tag or digest | - ---- - ### Example: Full Verification Flow @@ -269,6 +251,127 @@ cosign verify ghcr.io/seerr-team/seerr@"$DIGEST" \ +## Verifying Signed Helm charts + +### Helm Chart Locations + +Official Seerr helm charts are available from: + +- GitHub Container Registry (GHCR): `ghcr.io/seerr-team/seerr/seerr-chart/seerr-chart:` + +You can view all available tags on the [Seerr Releases page](https://github.com/seerr-team/seerr/pkgs/container/seerr%2Fseerr-chart). + +--- + +### Verifying a Specific Release Tag + +Each tagged release (for example `3.0.0`) is immutable and cryptographically signed. +Verification should always be performed using the image digest (SHA256). + +#### Retrieve the Helm Chart Digest + + + + +```bash +docker buildx imagetools inspect ghcr.io/seerr-team/seerr/seerr-chart:3.0.0 --format '{{json .Manifest.Digest}}' | tr -d '"' +``` + + + + +```bash +skopeo inspect docker://ghcr.io/seerr-team/seerr/seerr-chart:3.0.0 --format '{{.Digest}}' +``` + + + +Example output: + +``` +sha256:abcd1234... +``` + +--- + +#### Verify the Helm Chart Signature + +```bash +cosign verify ghcr.io/seerr-team/seerr/seerr-chart@sha256:abcd1234... \ + --certificate-identity "https://github.com/seerr-team/seerr/.github/workflows/helm.yml@refs/heads/main" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + +:::info Successful Verification Example +Verification for `ghcr.io/seerr-team/seerr/seerr-chart@sha256:abcd1234...` + +The following checks were performed: + +- Cosign claims validated +- Signatures verified against the transparency log +- Certificate issued by Fulcio to the expected workflow identity +::: + +--- + +### Expected Certificate Identity + +The expected certificate identity for all signed Seerr images is: + +``` +https://github.com/seerr-team/seerr/.github/workflows/helm.yml@refs/heads/main +``` + +This confirms that the image was: + +- Built by the official Seerr Release workflow +- Produced from the seerr-team/seerr repository +- Signed using GitHub’s OIDC identity via Sigstore Fulcio + +--- + +### Example: Full Verification Flow + + + + +```bash +DIGEST=$(docker buildx imagetools inspect ghcr.io/seerr-team/seerr/seerr-chart:3.0.0 --format '{{json .Manifest.Digest}}' | tr -d '"') + +cosign verify ghcr.io/seerr-team/seerr/seerr-chart@"$DIGEST" \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/helm.yml@refs/heads/main" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" + +cosign verify-attestation ghcr.io/seerr-team/seerr/seerr-chart@"$DIGEST" \ + --type cyclonedx \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/helm.yml@refs/heads/main" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + + +```bash +DIGEST=$(skopeo inspect docker://ghcr.io/seerr-team/seerr/seerr-chart:3.0.0 --format '{{.Digest}}') + +cosign verify ghcr.io/seerr-team/seerr/seerr-chart@"$DIGEST" \ + --certificate-identity-regexp "https://github.com/seerr-team/seerr/.github/workflows/helm.yml@refs/heads/main" \ + --certificate-oidc-issuer "https://token.actions.githubusercontent.com" +``` + + + +--- + +## Troubleshooting + +| Issue | Likely Cause | Suggested Fix | +|-------|---------------|----------------| +| `no matching signatures` | Incorrect digest or tag | Retrieve the digest again using Docker or Skopeo | +| `certificate identity does not match expected` | Workflow reference changed | Ensure your `--certificate-identity` matches this documentation | +| `cosign: command not found` | Cosign not installed | Install Cosign from the official release | +| `certificate expired` | Old release | Verify a newer tag or digest | + --- ## Further Reading From a7909342b4bf9f6464a392fd14d4de20d7b05564 Mon Sep 17 00:00:00 2001 From: 0xsysr3ll <31414959+0xSysR3ll@users.noreply.github.com> Date: Sun, 19 Oct 2025 22:32:58 +0200 Subject: [PATCH 88/96] fix(api): correct Jellyfin users endpoint documentation (#2073) Signed-off-by: 0xsysr3ll <0xsysr3ll@pm.me> --- seerr-api.yml | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/seerr-api.yml b/seerr-api.yml index 3b1d134fdc..979dfd7173 100644 --- a/seerr-api.yml +++ b/seerr-api.yml @@ -2339,8 +2339,12 @@ paths: properties: username: type: string - userId: - type: integer + id: + type: string + thumb: + type: string + email: + type: string /settings/jellyfin/sync: get: summary: Get status of full Jellyfin library sync From f7f00ce361cdb8dbc2358f06d946fce22efdcfb1 Mon Sep 17 00:00:00 2001 From: "J. Winters-Brown" <117940901+ofgrenudo@users.noreply.github.com> Date: Sun, 19 Oct 2025 16:37:09 -0400 Subject: [PATCH 89/96] feat: migrate to validator from email-validator (#2059) * refactor(adds package): this adds the validator package and removes email-validator from dependencys * refactor(auth.ts and email.ts): migrates from EmailValidator to validator --- package.json | 3 ++- pnpm-lock.yaml | 26 ++++++++++++++++-------- server/lib/notifications/agents/email.ts | 6 +++--- server/routes/auth.ts | 4 ++-- 4 files changed, 24 insertions(+), 15 deletions(-) diff --git a/package.json b/package.json index a598f12f0d..4cf3fdeef1 100644 --- a/package.json +++ b/package.json @@ -60,7 +60,6 @@ "dayjs": "1.11.7", "dns-caching": "^0.2.7", "email-templates": "12.0.1", - "email-validator": "2.0.4", "express": "4.21.2", "express-openapi-validator": "4.13.8", "express-rate-limit": "6.7.0", @@ -107,6 +106,7 @@ "typeorm": "0.3.12", "ua-parser-js": "^1.0.35", "undici": "^7.3.0", + "validator": "^13.15.15", "web-push": "3.5.0", "wink-jaro-distance": "^2.0.0", "winston": "3.8.2", @@ -140,6 +140,7 @@ "@types/secure-random-password": "0.2.1", "@types/semver": "7.3.13", "@types/swagger-ui-express": "4.1.3", + "@types/validator": "^13.15.3", "@types/web-push": "3.3.2", "@types/xml2js": "0.4.11", "@types/yamljs": "0.2.31", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 2f39de3ea5..286b789037 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -89,9 +89,6 @@ importers: email-templates: specifier: 12.0.1 version: 12.0.1(@babel/core@7.24.7)(encoding@0.1.13)(handlebars@4.7.8)(mustache@4.2.0)(pug@3.0.3)(react-dom@18.3.1(react@18.3.1))(react@18.3.1)(underscore@1.13.7) - email-validator: - specifier: 2.0.4 - version: 2.0.4 express: specifier: 4.21.2 version: 4.21.2 @@ -230,6 +227,9 @@ importers: undici: specifier: ^7.3.0 version: 7.3.0 + validator: + specifier: ^13.15.15 + version: 13.15.15 web-push: specifier: 3.5.0 version: 3.5.0 @@ -324,6 +324,9 @@ importers: '@types/swagger-ui-express': specifier: 4.1.3 version: 4.1.3 + '@types/validator': + specifier: ^13.15.3 + version: 13.15.3 '@types/web-push': specifier: 3.3.2 version: 3.3.2 @@ -3340,6 +3343,9 @@ packages: '@types/unist@2.0.10': resolution: {integrity: sha512-IfYcSBWE3hLpBg8+X2SEa8LVkJdJEkT2Ese2aaLs3ptGdVtABxndrMaxuFlQ1qdFf9Q5rDvDpxI3WwgvKFAsQA==} + '@types/validator@13.15.3': + resolution: {integrity: sha512-7bcUmDyS6PN3EuD9SlGGOxM77F8WLVsrwkxyWxKnxzmXoequ6c7741QBrANq6htVRGOITJ7z72mTP6Z4XyuG+Q==} + '@types/web-push@3.3.2': resolution: {integrity: sha512-JxWGVL/m7mWTIg4mRYO+A6s0jPmBkr4iJr39DqJpRJAc+jrPiEe1/asmkwerzRon8ZZDxaZJpsxpv0Z18Wo9gw==} @@ -4735,10 +4741,6 @@ packages: resolution: {integrity: sha512-849pjBFVUAWWTa3HqhDjxlXHaSWmxf4CZOlZ9iVkrSAbQ8YCYi+7KiKqt35L6F20WhSViWX7lmMjno6zBv2rNQ==} engines: {node: '>=14'} - email-validator@2.0.4: - resolution: {integrity: sha512-gYCwo7kh5S3IDyZPLZf6hSS0MnZT8QmJFqYvbqlDZSbwdZlY6QZWxJ4i/6UhITOJ4XzyI647Bm2MXKCLqnJ4nQ==} - engines: {node: '>4.0'} - emoji-regex@10.3.0: resolution: {integrity: sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==} @@ -9049,6 +9051,10 @@ packages: validate-npm-package-license@3.0.4: resolution: {integrity: sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==} + validator@13.15.15: + resolution: {integrity: sha512-BgWVbCI72aIQy937xbawcs+hrVaN/CZ2UwutgaJ36hGqRrLNM+f5LUT/YPRbo8IV/ASeFzXszezV+y2+rq3l8A==} + engines: {node: '>= 0.10'} + vary@1.1.2: resolution: {integrity: sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==} engines: {node: '>= 0.8'} @@ -13256,6 +13262,8 @@ snapshots: '@types/unist@2.0.10': {} + '@types/validator@13.15.3': {} + '@types/web-push@3.3.2': dependencies: '@types/node': 22.10.5 @@ -14937,8 +14945,6 @@ snapshots: - walrus - whiskers - email-validator@2.0.4: {} - emoji-regex@10.3.0: {} emoji-regex@8.0.0: {} @@ -20048,6 +20054,8 @@ snapshots: spdx-correct: 3.2.0 spdx-expression-parse: 3.0.1 + validator@13.15.15: {} + vary@1.1.2: {} verror@1.10.0: diff --git a/server/lib/notifications/agents/email.ts b/server/lib/notifications/agents/email.ts index c33cc89491..96963dfa74 100644 --- a/server/lib/notifications/agents/email.ts +++ b/server/lib/notifications/agents/email.ts @@ -7,8 +7,8 @@ import type { NotificationAgentEmail } from '@server/lib/settings'; import { getSettings, NotificationAgentKey } from '@server/lib/settings'; import logger from '@server/logger'; import type { EmailOptions } from 'email-templates'; -import * as EmailValidator from 'email-validator'; import path from 'path'; +import validator from 'validator'; import { Notification, shouldSendAdminNotification } from '..'; import type { NotificationAgent, NotificationPayload } from './agent'; import { BaseAgent } from './agent'; @@ -221,7 +221,7 @@ class EmailAgent this.getSettings(), payload.notifyUser.settings?.pgpKey ); - if (EmailValidator.validate(payload.notifyUser.email)) { + if (validator.isEmail(payload.notifyUser.email)) { await email.send( this.buildMessage( type, @@ -283,7 +283,7 @@ class EmailAgent this.getSettings(), user.settings?.pgpKey ); - if (EmailValidator.validate(user.email)) { + if (validator.isEmail(user.email)) { await email.send( this.buildMessage(type, payload, user.email, user.displayName) ); diff --git a/server/routes/auth.ts b/server/routes/auth.ts index 3b93cf6cfd..a96b63dff0 100644 --- a/server/routes/auth.ts +++ b/server/routes/auth.ts @@ -15,9 +15,9 @@ import { ApiError } from '@server/types/error'; import { getAppVersion } from '@server/utils/appVersion'; import { getHostname } from '@server/utils/getHostname'; import axios from 'axios'; -import * as EmailValidator from 'email-validator'; import { Router } from 'express'; import net from 'net'; +import validator from 'validator'; const authRoutes = Router(); @@ -37,7 +37,7 @@ authRoutes.get('/me', isAuthenticated(), async (req, res) => { const settings = await getSettings(); if ( settings.notifications.agents.email.options.userEmailRequired && - !EmailValidator.validate(user.email) + !validator.isEmail(user.email) ) { user.warnings.push('userEmailRequired'); logger.warn(`User ${user.username} has no valid email address`); From 48a61d812b951b51763efeae93963549e43fffd7 Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Mon, 20 Oct 2025 11:03:21 +0300 Subject: [PATCH 90/96] docs: migrate third-parties documentation to a dedicated folder (#2068) * docs: migrate third party documentation to a dedidcated folders --------- Signed-off-by: Ludovic Ortega --- docs/getting-started/docker.mdx | 9 - docs/getting-started/index.mdx | 2 +- docs/getting-started/kubernetes.mdx | 4 +- docs/getting-started/nixpkg.mdx | 271 ------------------ .../{ => third-parties}/aur.mdx | 13 +- docs/getting-started/third-parties/index.mdx | 11 + docs/getting-started/third-parties/nixpkg.mdx | 17 ++ docs/getting-started/third-parties/unraid.mdx | 20 ++ 8 files changed, 57 insertions(+), 290 deletions(-) delete mode 100644 docs/getting-started/nixpkg.mdx rename docs/getting-started/{ => third-parties}/aur.mdx (80%) create mode 100644 docs/getting-started/third-parties/index.mdx create mode 100644 docs/getting-started/third-parties/nixpkg.mdx create mode 100644 docs/getting-started/third-parties/unraid.mdx diff --git a/docs/getting-started/docker.mdx b/docs/getting-started/docker.mdx index 664882f8b2..fd1cb77559 100644 --- a/docs/getting-started/docker.mdx +++ b/docs/getting-started/docker.mdx @@ -135,15 +135,6 @@ You may alternatively use a third-party mechanism like [dockge](https://github.c - -## Unraid - -1. Ensure you have the **Community Applications** plugin installed. -2. Inside the **Community Applications** app store, search for **Jellyseerr**. -3. Click the **Install Button**. -4. On the following **Add Container** screen, make changes to the **Host Port** and **Host Path 1** \(Appdata\) as needed. -5. Click apply and access "Jellyseerr" at your `` in a web browser. - ## Windows Please refer to the [Docker Desktop for Windows user manual](https://docs.docker.com/docker-for-windows/) for details on how to install Docker on Windows. There is no need to install a Linux distro if using named volumes like in the example below. diff --git a/docs/getting-started/index.mdx b/docs/getting-started/index.mdx index f31ddf6990..cf7818b930 100644 --- a/docs/getting-started/index.mdx +++ b/docs/getting-started/index.mdx @@ -7,4 +7,4 @@ import DocCardList from '@theme/DocCardList'; After running Jellyseerr for the first time, configure it by visiting the web UI at `http://[address]:5055` and completing the setup steps. ::: - \ No newline at end of file + diff --git a/docs/getting-started/kubernetes.mdx b/docs/getting-started/kubernetes.mdx index 1d5cb6ff00..a6a77a1ca2 100644 --- a/docs/getting-started/kubernetes.mdx +++ b/docs/getting-started/kubernetes.mdx @@ -1,10 +1,10 @@ --- title: Kubernetes (Advanced) description: Install Jellyseerr in Kubernetes -sidebar_position: 5 +sidebar_position: 3 --- # Kubernetes -:::info +:::warning This method is not recommended for most users. It is intended for advanced users who are using Kubernetes. ::: diff --git a/docs/getting-started/nixpkg.mdx b/docs/getting-started/nixpkg.mdx deleted file mode 100644 index e35fd184c5..0000000000 --- a/docs/getting-started/nixpkg.mdx +++ /dev/null @@ -1,271 +0,0 @@ ---- -title: Nix Package Manager (Advanced) -description: Install Jellyseerr using Nix -sidebar_position: 3 ---- - -import { JellyseerrVersion, NixpkgVersion } from '@site/src/components/JellyseerrVersion'; -import Admonition from '@theme/Admonition'; -import Tabs from '@theme/Tabs'; -import TabItem from '@theme/TabItem'; - -# Nix Package Manager (Advanced) -:::info -This method is not recommended for most users. It is intended for advanced users who are using Nix as their package manager. -::: - -export const VersionMismatchWarning = () => { - let jellyseerrVersion = null; - let nixpkgVersions = null; - try { - jellyseerrVersion = JellyseerrVersion(); - nixpkgVersions = NixpkgVersion(); - } catch (err) { - return ( - - Failed to load version information. Error: {err.message || JSON.stringify(err)} - - ); - } - - if (!nixpkgVersions || nixpkgVersions.error) { - return ( - - Failed to fetch Nixpkg versions: {nixpkgVersions?.error || 'Unknown error'} - - ); - } - - const isUnstableUpToDate = jellyseerrVersion === nixpkgVersions.unstable; - const isStableUpToDate = jellyseerrVersion === nixpkgVersions.stable; - - return ( - <> - {!isStableUpToDate ? ( - - The{' '} - - upstream Jellyseerr Nix Package (v{nixpkgVersions.stable}) - {' '} - is not up-to-date. If you want to use Jellyseerr v{jellyseerrVersion},{' '} - {isUnstableUpToDate ? ( - <> - consider using the{' '} - - unstable package - {' '} - instead. - - ) : ( - <> - you will need to{' '} - override the package derivation. - - )} - -) : null} - - ); -}; - - - -## Installation -To get up and running with jellyseerr using Nix, you can add the following to your `configuration.nix`: - -```nix -{ config, pkgs, ... }: - -{ - services.jellyseerr.enable = true; -} -``` - -If you want more advanced configuration options, you can use the following: - - - -```nix -{ config, pkgs, ... }: - -{ - services.jellyseerr = { - enable = true; - port = 5055; - openFirewall = true; - package = pkgs.jellyseerr; # Use the unstable package if stable is not up-to-date - }; -} -``` - - -In order to use postgres, you will need to add override the default module of jellyseerr with the following as the current default module is not compatible with postgres: -```nix -{ - config, - pkgs, - lib, - ... -}: -with lib; -let - cfg = config.services.jellyseerr; -in -{ - meta.maintainers = [ maintainers.camillemndn ]; - - disabledModules = [ "services/misc/jellyseerr.nix" ]; - - options.services.jellyseerr = { - enable = mkEnableOption ''Jellyseerr, a requests manager for Jellyfin''; - - openFirewall = mkOption { - type = types.bool; - default = false; - description = ''Open port in the firewall for the Jellyseerr web interface.''; - }; - - port = mkOption { - type = types.port; - default = 5055; - description = ''The port which the Jellyseerr web UI should listen to.''; - }; - - package = mkOption { - type = types.package; - default = pkgs.jellyseerr; - defaultText = literalExpression "pkgs.jellyseerr"; - description = '' - Jellyseerr package to use. - ''; - }; - - databaseConfig = mkOption { - type = types.attrsOf types.str; - default = { - type = "sqlite"; - configDirectory = "config"; - logQueries = "false"; - }; - description = '' - Database configuration. For "sqlite", only "type", "configDirectory", and "logQueries" are relevant. - For "postgres", include host, port, user, pass, name, and optionally socket. - Example: - { - type = "postgres"; - socket = "/run/postgresql"; - user = "jellyseerr"; - name = "jellyseerr"; - logQueries = "false"; - } - or - { - type = "postgres"; - host = "localhost"; - port = "5432"; - user = "dbuser"; - pass = "password"; - name = "jellyseerr"; - logQueries = "false"; - } - or - { - type = "sqlite"; - configDirectory = "config"; - logQueries = "false"; - } - ''; - }; - }; - - config = mkIf cfg.enable { - systemd.services.jellyseerr = { - description = "Jellyseerr, a requests manager for Jellyfin"; - after = [ "network.target" ]; - wantedBy = [ "multi-user.target" ]; - environment = - let - dbConfig = cfg.databaseConfig; - in - { - PORT = toString cfg.port; - DB_TYPE = toString dbConfig.type; - CONFIG_DIRECTORY = toString dbConfig.configDirectory or ""; - DB_LOG_QUERIES = toString dbConfig.logQueries; - DB_HOST = if dbConfig.type == "postgres" && !(hasAttr "socket" dbConfig) then toString dbConfig.host or "" else ""; - DB_PORT = if dbConfig.type == "postgres" && !(hasAttr "socket" dbConfig) then toString dbConfig.port or "" else ""; - DB_SOCKET_PATH = if dbConfig.type == "postgres" && hasAttr "socket" dbConfig then toString dbConfig.socket or "" else ""; - DB_USER = if dbConfig.type == "postgres" then toString dbConfig.user or "" else ""; - DB_PASS = if dbConfig.type == "postgres" then toString dbConfig.pass or "" else ""; - DB_NAME = if dbConfig.type == "postgres" then toString dbConfig.name or "" else ""; - }; - serviceConfig = { - Type = "exec"; - StateDirectory = "jellyseerr"; - WorkingDirectory = "${cfg.package}/libexec/jellyseerr"; - DynamicUser = true; - ExecStart = "${cfg.package}/bin/jellyseerr"; - BindPaths = [ "/var/lib/jellyseerr/:${cfg.package}/libexec/jellyseerr/config/" ]; - Restart = "on-failure"; - ProtectHome = true; - ProtectSystem = "strict"; - PrivateTmp = true; - PrivateDevices = true; - ProtectHostname = true; - ProtectClock = true; - ProtectKernelTunables = true; - ProtectKernelModules = true; - ProtectKernelLogs = true; - ProtectControlGroups = true; - NoNewPrivileges = true; - RestrictRealtime = true; - RestrictSUIDSGID = true; - RemoveIPC = true; - PrivateMounts = true; - }; - }; - - networking.firewall = mkIf cfg.openFirewall { allowedTCPPorts = [ cfg.port ]; }; - }; -} -``` -Then, import the module into your `configuration.nix`: -```nix -{ config, pkgs, ... }: -{ - imports = [ ./modules/jellyseerr.nix ]; - - services.jellyseerr = { - enable = true; - port = 5055; - openFirewall = true; - package = pkgs.unstable.jellyseerr; # use the unstable package if stable is not up-to-date - databaseConfig = { - type = "postgres"; - host = "localhost"; # or socket: "/run/postgresql" - port = "5432"; # if using socket, this is not needed - user = "jellyseerr"; - pass = "jellyseerr"; - name = "jellyseerr"; - logQueries = "false"; - }; - } -} -``` - - - -After adding the configuration to your `configuration.nix`, you can run the following command to install jellyseerr: - -```bash -nixos-rebuild switch -``` -After rebuild is complete jellyseerr should be running, verify that it is with the following command. -```bash -systemctl status jellyseerr -``` - -:::info -You can now access Jellyseerr by visiting `http://localhost:5055` in your web browser. -::: - diff --git a/docs/getting-started/aur.mdx b/docs/getting-started/third-parties/aur.mdx similarity index 80% rename from docs/getting-started/aur.mdx rename to docs/getting-started/third-parties/aur.mdx index 025118c8f8..b6f0b1e579 100644 --- a/docs/getting-started/aur.mdx +++ b/docs/getting-started/third-parties/aur.mdx @@ -1,16 +1,15 @@ --- -title: AUR (Arch User Repository) +title: AUR (Advanced) description: Install Jellyseerr using the Arch User Repository -sidebar_position: 4 +sidebar_position: 2 --- -# AUR (Arch User Repository) - -:::note Disclaimer -This AUR package is not maintained by us but by a third party. Please refer to the maintainer for any issues. +# AUR +:::warning +Third-party installation methods are maintained by the community. The Seerr team is not responsible for these packages. ::: -:::info +:::warning This method is not recommended for most users. It is intended for advanced users who are using Arch Linux or an Arch-based distribution. ::: diff --git a/docs/getting-started/third-parties/index.mdx b/docs/getting-started/third-parties/index.mdx new file mode 100644 index 0000000000..d2d8e02936 --- /dev/null +++ b/docs/getting-started/third-parties/index.mdx @@ -0,0 +1,11 @@ +--- +title: Third-party Installation Methods +--- +import DocCardList from '@theme/DocCardList'; + +:::warning +Third-party installation methods are maintained by the community. The Seerr team is not responsible for these packages. +::: + + + diff --git a/docs/getting-started/third-parties/nixpkg.mdx b/docs/getting-started/third-parties/nixpkg.mdx new file mode 100644 index 0000000000..293e0f1b72 --- /dev/null +++ b/docs/getting-started/third-parties/nixpkg.mdx @@ -0,0 +1,17 @@ +--- +title: Nix Package Manager (Advanced) +description: Install Jellyseerr using Nixpkgs +sidebar_position: 1 +--- + +import { JellyseerrVersion, NixpkgVersion } from '@site/src/components/JellyseerrVersion'; +import Admonition from '@theme/Admonition'; +import Tabs from '@theme/Tabs'; +import TabItem from '@theme/TabItem'; + +# Nix Package Manager +:::warning +Third-party installation methods are maintained by the community. The Seerr team is not responsible for these packages. +::: + +Refer to [NixOS documentation](https://search.nixos.org/options?channel=25.05&query=seerr) diff --git a/docs/getting-started/third-parties/unraid.mdx b/docs/getting-started/third-parties/unraid.mdx new file mode 100644 index 0000000000..daf0c3e0c3 --- /dev/null +++ b/docs/getting-started/third-parties/unraid.mdx @@ -0,0 +1,20 @@ +--- +title: Unraid (Advanced) +description: Install Jellyseerr using Unraid +sidebar_position: 3 +--- + +# Unraid +:::warning +Third-party installation methods are maintained by the community. The Seerr team is not responsible for these packages. +::: + +:::warning +This method is not recommended for most users. It is intended for advanced users who are using Unraid. +::: + +1. Ensure you have the **Community Applications** plugin installed. +2. Inside the **Community Applications** app store, search for **Jellyseerr**. +3. Click the **Install Button**. +4. On the following **Add Container** screen, make changes to the **Host Port** and **Host Path 1** \(Appdata\) as needed. +5. Click apply and access "Jellyseerr" at your `` in a web browser. From b34ca1543a133be2093b51e9ae7a9bc4bf64028b Mon Sep 17 00:00:00 2001 From: Ludovic Ortega Date: Mon, 20 Oct 2025 17:24:24 +0300 Subject: [PATCH 91/96] feat: do not enforce TLD on email (#2075) fix #1846 --- server/lib/notifications/agents/email.ts | 6 ++++-- server/routes/auth.ts | 2 +- src/components/Login/AddEmailModal.tsx | 7 ++++++- src/components/ResetPassword/RequestResetLink.tsx | 7 ++++++- .../Settings/Notifications/NotificationsEmail.tsx | 7 ++++++- src/components/Setup/JellyfinSetup.tsx | 7 ++++++- src/components/UserList/index.tsx | 7 ++++++- .../UserSettings/UserGeneralSettings/index.tsx | 15 ++++++++++++--- 8 files changed, 47 insertions(+), 11 deletions(-) diff --git a/server/lib/notifications/agents/email.ts b/server/lib/notifications/agents/email.ts index 96963dfa74..7b7a679fd9 100644 --- a/server/lib/notifications/agents/email.ts +++ b/server/lib/notifications/agents/email.ts @@ -221,7 +221,9 @@ class EmailAgent this.getSettings(), payload.notifyUser.settings?.pgpKey ); - if (validator.isEmail(payload.notifyUser.email)) { + if ( + validator.isEmail(payload.notifyUser.email, { require_tld: false }) + ) { await email.send( this.buildMessage( type, @@ -283,7 +285,7 @@ class EmailAgent this.getSettings(), user.settings?.pgpKey ); - if (validator.isEmail(user.email)) { + if (validator.isEmail(user.email, { require_tld: false })) { await email.send( this.buildMessage(type, payload, user.email, user.displayName) ); diff --git a/server/routes/auth.ts b/server/routes/auth.ts index a96b63dff0..9f670f3c80 100644 --- a/server/routes/auth.ts +++ b/server/routes/auth.ts @@ -37,7 +37,7 @@ authRoutes.get('/me', isAuthenticated(), async (req, res) => { const settings = await getSettings(); if ( settings.notifications.agents.email.options.userEmailRequired && - !validator.isEmail(user.email) + !validator.isEmail(user.email, { require_tld: false }) ) { user.warnings.push('userEmailRequired'); logger.warn(`User ${user.username} has no valid email address`); diff --git a/src/components/Login/AddEmailModal.tsx b/src/components/Login/AddEmailModal.tsx index cde0c8bdee..0ae4913148 100644 --- a/src/components/Login/AddEmailModal.tsx +++ b/src/components/Login/AddEmailModal.tsx @@ -5,6 +5,7 @@ import { Transition } from '@headlessui/react'; import axios from 'axios'; import { Field, Formik } from 'formik'; import { useIntl } from 'react-intl'; +import validator from 'validator'; import * as Yup from 'yup'; const messages = defineMessages('components.Login', { @@ -36,7 +37,11 @@ const AddEmailModal: React.FC = ({ const EmailSettingsSchema = Yup.object().shape({ email: Yup.string() - .email(intl.formatMessage(messages.validationEmailFormat)) + .test( + 'email', + intl.formatMessage(messages.validationEmailFormat), + (value) => !value || validator.isEmail(value, { require_tld: false }) + ) .required(intl.formatMessage(messages.validationEmailRequired)), }); diff --git a/src/components/ResetPassword/RequestResetLink.tsx b/src/components/ResetPassword/RequestResetLink.tsx index b331bb204b..3bc06d4925 100644 --- a/src/components/ResetPassword/RequestResetLink.tsx +++ b/src/components/ResetPassword/RequestResetLink.tsx @@ -10,6 +10,7 @@ import Image from 'next/image'; import Link from 'next/link'; import { useState } from 'react'; import { useIntl } from 'react-intl'; +import validator from 'validator'; import * as Yup from 'yup'; const messages = defineMessages('components.ResetPassword', { @@ -29,7 +30,11 @@ const ResetPassword = () => { const ResetSchema = Yup.object().shape({ email: Yup.string() - .email(intl.formatMessage(messages.validationemailrequired)) + .test( + 'email', + intl.formatMessage(messages.validationemailrequired), + (value) => !value || validator.isEmail(value, { require_tld: false }) + ) .required(intl.formatMessage(messages.validationemailrequired)), }); diff --git a/src/components/Settings/Notifications/NotificationsEmail.tsx b/src/components/Settings/Notifications/NotificationsEmail.tsx index d88906a517..214d87da0a 100644 --- a/src/components/Settings/Notifications/NotificationsEmail.tsx +++ b/src/components/Settings/Notifications/NotificationsEmail.tsx @@ -11,6 +11,7 @@ import { useState } from 'react'; import { useIntl } from 'react-intl'; import { useToasts } from 'react-toast-notifications'; import useSWR, { mutate } from 'swr'; +import validator from 'validator'; import * as Yup from 'yup'; const messages = defineMessages('components.Settings.Notifications', { @@ -77,7 +78,11 @@ const NotificationsEmail = () => { .required(intl.formatMessage(messages.validationEmail)), otherwise: Yup.string().nullable(), }) - .email(intl.formatMessage(messages.validationEmail)), + .test( + 'email', + intl.formatMessage(messages.validationEmail), + (value) => !value || validator.isEmail(value, { require_tld: false }) + ), smtpHost: Yup.string().when('enabled', { is: true, then: Yup.string() diff --git a/src/components/Setup/JellyfinSetup.tsx b/src/components/Setup/JellyfinSetup.tsx index 631f99fd46..036ee8c324 100644 --- a/src/components/Setup/JellyfinSetup.tsx +++ b/src/components/Setup/JellyfinSetup.tsx @@ -8,6 +8,7 @@ import axios from 'axios'; import { Field, Form, Formik } from 'formik'; import { FormattedMessage, useIntl } from 'react-intl'; import { useToasts } from 'react-toast-notifications'; +import validator from 'validator'; import * as Yup from 'yup'; const messages = defineMessages('components.Login', { @@ -90,7 +91,11 @@ function JellyfinSetup({ (value) => !value || !value.endsWith('/') ), email: Yup.string() - .email(intl.formatMessage(messages.validationemailformat)) + .test( + 'email', + intl.formatMessage(messages.validationemailformat), + (value) => !value || validator.isEmail(value, { require_tld: false }) + ) .required(intl.formatMessage(messages.validationemailrequired)), username: Yup.string().required( intl.formatMessage(messages.validationusernamerequired) diff --git a/src/components/UserList/index.tsx b/src/components/UserList/index.tsx index 877f95aecc..d2cde505e2 100644 --- a/src/components/UserList/index.tsx +++ b/src/components/UserList/index.tsx @@ -36,6 +36,7 @@ import { useEffect, useState } from 'react'; import { useIntl } from 'react-intl'; import { useToasts } from 'react-toast-notifications'; import useSWR from 'swr'; +import validator from 'validator'; import * as Yup from 'yup'; import JellyfinImportModal from './JellyfinImportModal'; @@ -210,7 +211,11 @@ const UserList = () => { ), email: Yup.string() .required() - .email(intl.formatMessage(messages.validationEmail)), + .test( + 'email', + intl.formatMessage(messages.validationEmail), + (value) => !value || validator.isEmail(value, { require_tld: false }) + ), password: Yup.lazy((value) => !value ? Yup.string() diff --git a/src/components/UserProfile/UserSettings/UserGeneralSettings/index.tsx b/src/components/UserProfile/UserSettings/UserGeneralSettings/index.tsx index 71476c5bec..3445e7c1c7 100644 --- a/src/components/UserProfile/UserSettings/UserGeneralSettings/index.tsx +++ b/src/components/UserProfile/UserSettings/UserGeneralSettings/index.tsx @@ -23,6 +23,7 @@ import { useEffect, useState } from 'react'; import { useIntl } from 'react-intl'; import { useToasts } from 'react-toast-notifications'; import useSWR from 'swr'; +import validator from 'validator'; import * as Yup from 'yup'; const messages = defineMessages( @@ -105,10 +106,18 @@ const UserGeneralSettings = () => { user?.id === 1 || (user?.userType !== UserType.JELLYFIN && user?.userType !== UserType.EMBY) ? Yup.string() - .email(intl.formatMessage(messages.validationemailformat)) + .test( + 'email', + intl.formatMessage(messages.validationemailformat), + (value) => + !value || validator.isEmail(value, { require_tld: false }) + ) .required(intl.formatMessage(messages.validationemailrequired)) - : Yup.string().email( - intl.formatMessage(messages.validationemailformat) + : Yup.string().test( + 'email', + intl.formatMessage(messages.validationemailformat), + (value) => + !value || validator.isEmail(value, { require_tld: false }) ), discordId: Yup.string() .nullable() From d61f3124bbefbb23971f21c6a9caa731b0c4b7f2 Mon Sep 17 00:00:00 2001 From: Jack Reggin Date: Wed, 22 Oct 2025 18:42:01 -0600 Subject: [PATCH 92/96] chore: missing type import for Public OidcProvider --- server/interfaces/api/settingsInterfaces.ts | 2 ++ 1 file changed, 2 insertions(+) diff --git a/server/interfaces/api/settingsInterfaces.ts b/server/interfaces/api/settingsInterfaces.ts index 5e058eccda..41544597e3 100644 --- a/server/interfaces/api/settingsInterfaces.ts +++ b/server/interfaces/api/settingsInterfaces.ts @@ -1,3 +1,4 @@ +import type { PublicOidcProvider } from '@server/lib/settings'; import type { DnsEntries, DnsStats } from 'dns-caching'; import type { PaginatedResponse } from './common'; @@ -48,6 +49,7 @@ export interface PublicSettingsResponse { emailEnabled: boolean; newPlexLogin: boolean; youtubeUrl: string; + openIdProviders: PublicOidcProvider[]; } export interface CacheItem { From da9a00eb3c97e59a6ec12182e57d7ce0d297a4c0 Mon Sep 17 00:00:00 2001 From: Jack Reggin Date: Wed, 22 Oct 2025 19:12:21 -0600 Subject: [PATCH 93/96] chore: added missing dependency for oidc login --- package.json | 1 + pnpm-lock.yaml | 3 +++ 2 files changed, 4 insertions(+) diff --git a/package.json b/package.json index 4cf3fdeef1..e470d7ab73 100644 --- a/package.json +++ b/package.json @@ -68,6 +68,7 @@ "gravatar-url": "3.1.0", "http-proxy-agent": "^7.0.2", "https-proxy-agent": "^7.0.6", + "jwt-decode": "^4.0.0", "lodash": "4.17.21", "mime": "3", "next": "^14.2.25", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 5c2ca0e7a0..91f982bbe9 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -113,6 +113,9 @@ importers: https-proxy-agent: specifier: ^7.0.6 version: 7.0.6 + jwt-decode: + specifier: ^4.0.0 + version: 4.0.0 lodash: specifier: 4.17.21 version: 4.17.21 From 262cd2c29d7e75be09ecd5d3340d1a276e778b3b Mon Sep 17 00:00:00 2001 From: Jack Reggin Date: Thu, 23 Oct 2025 09:23:05 -0600 Subject: [PATCH 94/96] chore: fixed missing imports --- server/routes/user/usersettings.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/routes/user/usersettings.ts b/server/routes/user/usersettings.ts index c355d7ec73..56c1eedb7c 100644 --- a/server/routes/user/usersettings.ts +++ b/server/routes/user/usersettings.ts @@ -21,7 +21,7 @@ import { ApiError } from '@server/types/error'; import { getHostname } from '@server/utils/getHostname'; import { Router } from 'express'; import net from 'net'; -import { Not } from 'typeorm'; +import { In, Not, type FindOptionsWhere } from 'typeorm'; import { canMakePermissionsChange } from '.'; const isOwnProfile = (): Middleware => { From f9e65a02894bd860bb8ecd963553aebc86e6c0e2 Mon Sep 17 00:00:00 2001 From: Jack Reggin Date: Thu, 23 Oct 2025 10:06:43 -0600 Subject: [PATCH 95/96] chore: added missing openIdProviders setting option --- server/lib/settings/index.ts | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/server/lib/settings/index.ts b/server/lib/settings/index.ts index c8bbcd3e88..acf9b58fc1 100644 --- a/server/lib/settings/index.ts +++ b/server/lib/settings/index.ts @@ -168,6 +168,7 @@ export interface MainSettings { enableSpecialEpisodes: boolean; locale: string; youtubeUrl: string; + openIdProviders: PublicOidcProvider[]; } export interface ProxySettings { @@ -225,6 +226,7 @@ interface FullPublicSettings extends PublicSettings { userEmailRequired: boolean; newPlexLogin: boolean; youtubeUrl: string; + openIdProviders: PublicOidcProvider[]; } export interface NotificationAgentConfig { @@ -427,6 +429,7 @@ class Settings { enableSpecialEpisodes: false, locale: 'en', youtubeUrl: '', + openIdProviders: [], }, plex: { name: '', @@ -732,6 +735,7 @@ class Settings { this.data.notifications.agents.email.options.userEmailRequired, newPlexLogin: this.data.main.newPlexLogin, youtubeUrl: this.data.main.youtubeUrl, + openIdProviders: this.data.main.openIdProviders, }; } From eb89653fdc1cdcd663e2e98b94c49a402d56d480 Mon Sep 17 00:00:00 2001 From: Jack Reggin Date: Thu, 23 Oct 2025 20:35:06 -0600 Subject: [PATCH 96/96] chore: wrong settings were set for getFullPublicSettings for oidc providers --- server/lib/settings/index.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/server/lib/settings/index.ts b/server/lib/settings/index.ts index acf9b58fc1..9a61b9555b 100644 --- a/server/lib/settings/index.ts +++ b/server/lib/settings/index.ts @@ -735,7 +735,7 @@ class Settings { this.data.notifications.agents.email.options.userEmailRequired, newPlexLogin: this.data.main.newPlexLogin, youtubeUrl: this.data.main.youtubeUrl, - openIdProviders: this.data.main.openIdProviders, + openIdProviders: this.data.oidc.providers, }; }