Compare commits
	
		
			19 Commits
		
	
	
		
			2024.9.0-a
			...
			KisaragiEf
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | ad1e2d8020 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 4f34a4e4d8 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 781e64aa7f | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | d6e1f022d4 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 2ea49703f6 | ||
|   | 1184436461 | ||
|   | 0871156780 | ||
|   | 088707c114 | ||
|   | 15f2e1425c | ||
|   | bb7e9505d3 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 57effa9ef0 | ||
|   | f0d0cd2e50 | ||
|   | c3b0e1a2bd | ||
|   | afbba1ff1c | ||
|   | 6964b919f8 | ||
|   | e5856c6b3b | ||
|   | 3f3c59e1ae | ||
|   | f49d7927aa | ||
|   | 9e9198086d | 
							
								
								
									
										14
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,3 +1,15 @@ | ||||
| ## Unreleased | ||||
|  | ||||
| ### General | ||||
| - | ||||
|  | ||||
| ### Client | ||||
| - | ||||
|  | ||||
| ### Server | ||||
| - | ||||
|  | ||||
|  | ||||
| ## 2024.9.0 | ||||
|  | ||||
| ### General | ||||
| @@ -5,6 +17,7 @@ | ||||
|   - 埋め込みコードやウェブサイトへの実装方法の詳細は https://misskey-hub.net/docs/for-users/features/embed/ をご覧ください | ||||
| - Feat: パスキーでログインボタンを実装 (#14574) | ||||
| - Feat: フォローされた際のメッセージを設定できるように | ||||
| - Feat: 連合をホワイトリスト制にできるように | ||||
| - Feat: UserWebhookとSystemWebhookのテスト送信機能を追加 (#14445) | ||||
| - Feat: モデレーターはユーザーにかかわらずファイルが添付されているノートを検索できるように   | ||||
|   (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/680) | ||||
| @@ -21,6 +34,7 @@ | ||||
| - Enhance: Play編集画面の項目の並びを少しリデザイン | ||||
| - Enhance: 各種メニューをドロワー表示するかどうか設定可能に | ||||
| - Enhance: AiScriptのMk:C:containerのオプションに`borderStyle`と`borderRadius`を追加 | ||||
| - Enhance: CWでも絵文字をクリックしてメニューを表示できるように | ||||
| - Fix: サーバーメトリクスが2つ以上あるとリロード直後の表示がおかしくなる問題を修正 | ||||
| - Fix: コントロールパネル内のAp requests内のチャートの表示がおかしかった問題を修正 | ||||
| - Fix: 月の違う同じ日はセパレータが表示されないのを修正 | ||||
|   | ||||
| @@ -451,7 +451,6 @@ or: "অথবা" | ||||
| language: "ভাষা" | ||||
| uiLanguage: "UI এর ভাষা" | ||||
| aboutX: "{x} সম্পর্কে" | ||||
| disableDrawer: "ড্রয়ার মেনু প্রদর্শন করবেন না" | ||||
| noHistory: "কোনো ইতিহাস নেই" | ||||
| signinHistory: "প্রবেশ করার ইতিহাস" | ||||
| doing: "প্রক্রিয়া করছে..." | ||||
|   | ||||
| @@ -509,7 +509,6 @@ uiLanguage: "Idioma de l'interfície" | ||||
| aboutX: "Respecte a {x}" | ||||
| emojiStyle: "Estil d'emoji" | ||||
| native: "Nadiu" | ||||
| disableDrawer: "No mostrar els menús en calaixos" | ||||
| showNoteActionsOnlyHover: "Només mostra accions de la nota en passar amb el cursor" | ||||
| showReactionsCount: "Mostra el nombre de reaccions a les publicacions" | ||||
| noHistory: "No hi ha un registre previ" | ||||
|   | ||||
| @@ -471,7 +471,6 @@ uiLanguage: "Jazyk uživatelského rozhraní" | ||||
| aboutX: "O {x}" | ||||
| emojiStyle: "Styl emoji" | ||||
| native: "Výchozí" | ||||
| disableDrawer: "Nepoužívat šuplíkové menu" | ||||
| showNoteActionsOnlyHover: "Zobrazit akce poznámky jenom při naběhnutí myši" | ||||
| noHistory: "Žádná historie" | ||||
| signinHistory: "Historie přihlášení" | ||||
|   | ||||
| @@ -491,7 +491,6 @@ uiLanguage: "Sprache der Benutzeroberfläche" | ||||
| aboutX: "Über {x}" | ||||
| emojiStyle: "Emoji-Stil" | ||||
| native: "Nativ" | ||||
| disableDrawer: "Keine ausfahrbaren Menüs verwenden" | ||||
| showNoteActionsOnlyHover: "Notizmenü nur bei Mouseover anzeigen" | ||||
| noHistory: "Kein Verlauf gefunden" | ||||
| signinHistory: "Anmeldungsverlauf" | ||||
|   | ||||
| @@ -509,7 +509,6 @@ uiLanguage: "User interface language" | ||||
| aboutX: "About {x}" | ||||
| emojiStyle: "Emoji style" | ||||
| native: "Native" | ||||
| disableDrawer: "Don't use drawer-style menus" | ||||
| showNoteActionsOnlyHover: "Only show note actions on hover" | ||||
| showReactionsCount: "See the number of reactions in notes" | ||||
| noHistory: "No history available" | ||||
|   | ||||
| @@ -502,7 +502,6 @@ uiLanguage: "Idioma de visualización de la interfaz" | ||||
| aboutX: "Acerca de {x}" | ||||
| emojiStyle: "Estilo de emoji" | ||||
| native: "Nativo" | ||||
| disableDrawer: "No mostrar los menús en cajones" | ||||
| showNoteActionsOnlyHover: "Mostrar acciones de la nota sólo al pasar el cursor" | ||||
| showReactionsCount: "Mostrar el número de reacciones en las notas" | ||||
| noHistory: "No hay datos en el historial" | ||||
|   | ||||
| @@ -493,7 +493,6 @@ uiLanguage: "Langue d’affichage de l’interface" | ||||
| aboutX: "À propos de {x}" | ||||
| emojiStyle: "Style des émojis" | ||||
| native: "Natif" | ||||
| disableDrawer: "Les menus ne s'affichent pas dans le tiroir" | ||||
| showNoteActionsOnlyHover: "Afficher les actions de note uniquement au survol" | ||||
| showReactionsCount: "Afficher le nombre de réactions des notes" | ||||
| noHistory: "Pas d'historique" | ||||
|   | ||||
| @@ -504,7 +504,6 @@ uiLanguage: "Bahasa antarmuka pengguna" | ||||
| aboutX: "Tentang {x}" | ||||
| emojiStyle: "Gaya emoji" | ||||
| native: "Native" | ||||
| disableDrawer: "Jangan gunakan menu bergaya laci" | ||||
| showNoteActionsOnlyHover: "Hanya tampilkan aksi catatan saat ditunjuk" | ||||
| showReactionsCount: "Lihat jumlah reaksi dalam catatan" | ||||
| noHistory: "Tidak ada riwayat" | ||||
|   | ||||
							
								
								
									
										10
									
								
								locales/index.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								locales/index.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -960,6 +960,14 @@ export interface Locale extends ILocale { | ||||
|      * メディアサイレンスしたいサーバーのホストを改行で区切って設定します。メディアサイレンスされたサーバーに所属するアカウントによるファイルはすべてセンシティブとして扱われ、カスタム絵文字が使用できないようになります。ブロックしたインスタンスには影響しません。 | ||||
|      */ | ||||
|     "mediaSilencedInstancesDescription": string; | ||||
|     /** | ||||
|      * 連合を許可するサーバー | ||||
|      */ | ||||
|     "federationAllowedHosts": string; | ||||
|     /** | ||||
|      * 連合を許可するサーバーのホストを改行で区切って設定します。 | ||||
|      */ | ||||
|     "federationAllowedHostsDescription": string; | ||||
|     /** | ||||
|      * ミュートとブロック | ||||
|      */ | ||||
| @@ -8730,7 +8738,7 @@ export interface Locale extends ILocale { | ||||
|          */ | ||||
|         "followedMessage": string; | ||||
|         /** | ||||
|          * フォローされた時に相手に表示するメッセージを設定できます。 | ||||
|          * フォローされた時に相手に表示する短いメッセージを設定できます。 | ||||
|          */ | ||||
|         "followedMessageDescription": string; | ||||
|         /** | ||||
|   | ||||
| @@ -334,6 +334,7 @@ renameFolder: "Rinomina cartella" | ||||
| deleteFolder: "Elimina cartella" | ||||
| folder: "Cartella" | ||||
| addFile: "Allega" | ||||
| showFile: "Visualizza file" | ||||
| emptyDrive: "Il Drive è vuoto" | ||||
| emptyFolder: "La cartella è vuota" | ||||
| unableToDelete: "Eliminazione impossibile" | ||||
| @@ -509,7 +510,10 @@ uiLanguage: "Lingua di visualizzazione dell'interfaccia" | ||||
| aboutX: "Informazioni su {x}" | ||||
| emojiStyle: "Stile emoji" | ||||
| native: "Nativo" | ||||
| disableDrawer: "Non mostrare il menù sul drawer" | ||||
| menuStyle: "Stile menu" | ||||
| style: "Stile" | ||||
| drawer: "Drawer" | ||||
| popup: "Popup" | ||||
| showNoteActionsOnlyHover: "Mostra le azioni delle Note solo al passaggio del mouse" | ||||
| showReactionsCount: "Visualizza il numero di reazioni su una nota" | ||||
| noHistory: "Nessuna cronologia" | ||||
| @@ -1270,6 +1274,13 @@ genEmbedCode: "Ottieni il codice di incorporamento" | ||||
| noteOfThisUser: "Elenco di Note di questo profilo" | ||||
| clipNoteLimitExceeded: "Non è possibile aggiungere ulteriori Note a questa Clip." | ||||
| performance: "Prestazioni" | ||||
| modified: "Modificato" | ||||
| discard: "Scarta" | ||||
| thereAreNChanges: "Ci sono {n} cambiamenti" | ||||
| signinWithPasskey: "Accedi con passkey" | ||||
| unknownWebAuthnKey: "Questa è una passkey sconosciuta." | ||||
| passkeyVerificationFailed: "La verifica della passkey non è riuscita." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "La verifica della passkey è riuscita, ma l'accesso senza password è disabilitato." | ||||
| _delivery: | ||||
|   status: "Stato della consegna" | ||||
|   stop: "Sospensione" | ||||
| @@ -2375,6 +2386,7 @@ _notification: | ||||
|   renotedBySomeUsers: "{n} Rinota" | ||||
|   followedBySomeUsers: "{n} follower" | ||||
|   flushNotification: "Azzera le notifiche" | ||||
|   exportOfXCompleted: "Abbiamo completato l'esportazione di {x}" | ||||
|   _types: | ||||
|     all: "Tutto" | ||||
|     note: "Nuove Note" | ||||
| @@ -2389,6 +2401,8 @@ _notification: | ||||
|     followRequestAccepted: "Richiesta di follow accettata" | ||||
|     roleAssigned: "Ruolo concesso" | ||||
|     achievementEarned: "Risultato raggiunto" | ||||
|     exportCompleted: "Esportazione completata" | ||||
|     test: "Prova la notifica" | ||||
|     app: "Notifiche da applicazioni" | ||||
|   _actions: | ||||
|     followBack: "Segui" | ||||
|   | ||||
| @@ -236,6 +236,8 @@ silencedInstances: "サイレンスしたサーバー" | ||||
| silencedInstancesDescription: "サイレンスしたいサーバーのホストを改行で区切って設定します。サイレンスされたサーバーに所属するアカウントはすべて「サイレンス」として扱われ、フォローがすべてリクエストになります。ブロックしたインスタンスには影響しません。" | ||||
| mediaSilencedInstances: "メディアサイレンスしたサーバー" | ||||
| mediaSilencedInstancesDescription: "メディアサイレンスしたいサーバーのホストを改行で区切って設定します。メディアサイレンスされたサーバーに所属するアカウントによるファイルはすべてセンシティブとして扱われ、カスタム絵文字が使用できないようになります。ブロックしたインスタンスには影響しません。" | ||||
| federationAllowedHosts: "連合を許可するサーバー" | ||||
| federationAllowedHostsDescription: "連合を許可するサーバーのホストを改行で区切って設定します。" | ||||
| muteAndBlock: "ミュートとブロック" | ||||
| mutedUsers: "ミュートしたユーザー" | ||||
| blockedUsers: "ブロックしたユーザー" | ||||
| @@ -2298,7 +2300,7 @@ _profile: | ||||
|   verifiedLinkDescription: "内容にURLを設定すると、リンク先のWebサイトに自分のプロフィールへのリンクが含まれている場合に所有者確認済みアイコンを表示させることができます。" | ||||
|   avatarDecorationMax: "最大{max}つまでデコレーションを付けられます。" | ||||
|   followedMessage: "フォローされた時のメッセージ" | ||||
|   followedMessageDescription: "フォローされた時に相手に表示するメッセージを設定できます。" | ||||
|   followedMessageDescription: "フォローされた時に相手に表示する短いメッセージを設定できます。" | ||||
|   followedMessageDescriptionForLockedAccount: "フォローを承認制にしている場合、フォローリクエストを許可した時に表示されます。" | ||||
|  | ||||
| _exportOrImport: | ||||
|   | ||||
| @@ -509,7 +509,6 @@ uiLanguage: "UIの表示言語" | ||||
| aboutX: "{x}について" | ||||
| emojiStyle: "絵文字のスタイル" | ||||
| native: "ネイティブ" | ||||
| disableDrawer: "メニューをドロワーで表示せえへん" | ||||
| showNoteActionsOnlyHover: "ノートの操作部をホバー時のみ表示するで" | ||||
| showReactionsCount: "ノートのリアクション数を表示する" | ||||
| noHistory: "履歴はないわ。" | ||||
|   | ||||
| @@ -476,7 +476,6 @@ uiLanguage: "UI 표시 언어" | ||||
| aboutX: "{x}에 대해서" | ||||
| emojiStyle: "이모지 모양" | ||||
| native: "기본" | ||||
| disableDrawer: "드로어 메뉴 쓰지 않기" | ||||
| showNoteActionsOnlyHover: "마우스 올맀을 때만 노트 액션 버턴 보이기" | ||||
| noHistory: "기록이 없십니다" | ||||
| signinHistory: "로그인 기록" | ||||
|   | ||||
| @@ -236,6 +236,8 @@ silencedInstances: "사일런스한 서버" | ||||
| silencedInstancesDescription: "사일런스하려는 서버의 호스트명을 한 줄에 하나씩 입력합니다. 사일런스된 서버에 소속된 유저는 모두 '사일런스'된 상태로 취급되며, 이 서버로부터의 팔로우가 프로필 설정과 무관하게 승인제로 변경되고, 팔로워가 아닌 로컬 유저에게는 멘션할 수 없게 됩니다. 정지된 서버에는 적용되지 않습니다." | ||||
| mediaSilencedInstances: "미디어를 사일런스한 서버" | ||||
| mediaSilencedInstancesDescription: "미디어를 사일런스 하려는 서버의 호스트를 한 줄에 하나씩 입력합니다. 미디어가 사일런스된 서버의 유저가 업로드한 파일은 모두 민감한 미디어로 처리되며, 커스텀 이모지를 사용할 수 없게 됩니다. 또한, 차단한 인스턴스에는 적용되지 않습니다." | ||||
| federationAllowedHosts: "연합을 허가하는 서버" | ||||
| federationAllowedHostsDescription: "연합을 허가하는 서버의 호스트를 엔터로 구분해서 설정합니다." | ||||
| muteAndBlock: "뮤트 및 차단" | ||||
| mutedUsers: "뮤트한 유저" | ||||
| blockedUsers: "차단한 유저" | ||||
| @@ -334,6 +336,7 @@ renameFolder: "폴더 이름 바꾸기" | ||||
| deleteFolder: "폴더 삭제" | ||||
| folder: "폴더" | ||||
| addFile: "파일 추가" | ||||
| showFile: "파일 표시하기" | ||||
| emptyDrive: "드라이브가 비어 있습니다" | ||||
| emptyFolder: "폴더가 비어 있습니다" | ||||
| unableToDelete: "삭제할 수 없습니다" | ||||
| @@ -509,7 +512,10 @@ uiLanguage: "UI 표시 언어" | ||||
| aboutX: "{x}에 대하여" | ||||
| emojiStyle: "이모지 스타일" | ||||
| native: "기본" | ||||
| disableDrawer: "드로어 메뉴를 사용하지 않기" | ||||
| menuStyle: "메뉴 스타일" | ||||
| style: "스타일" | ||||
| drawer: "서랍" | ||||
| popup: "팝업" | ||||
| showNoteActionsOnlyHover: "마우스가 올라간 때에만 노트 동작 버튼을 표시하기" | ||||
| showReactionsCount: "노트의 반응 수를 표시하기" | ||||
| noHistory: "기록이 없습니다" | ||||
| @@ -1273,6 +1279,10 @@ performance: "퍼포먼스" | ||||
| modified: "변경 있음" | ||||
| discard: "파기" | ||||
| thereAreNChanges: "{n}건 변경이 있습니다." | ||||
| signinWithPasskey: "패스키로 로그인" | ||||
| unknownWebAuthnKey: "등록되지 않은 패스키입니다." | ||||
| passkeyVerificationFailed: "패스키 검증을 실패했습니다." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "패스키를 검증했으나, 비밀번호 없이 로그인하기가 꺼져 있습니다." | ||||
| _delivery: | ||||
|   status: "전송 상태" | ||||
|   stop: "정지됨" | ||||
| @@ -2240,6 +2250,9 @@ _profile: | ||||
|   changeBanner: "배너 이미지 변경" | ||||
|   verifiedLinkDescription: "내용에 자신의 프로필로 향하는 링크가 포함된 페이지의 URL을 삽입하면 소유자 인증 마크가 표시됩니다." | ||||
|   avatarDecorationMax: "최대 {max}개까지 장식을 할 수 있습니다." | ||||
|   followedMessage: "팔로우 받았을 때 메시지" | ||||
|   followedMessageDescription: "팔로우 받았을 때 상대방에게 보여줄 단문 메시지를 설정할 수 있습니다." | ||||
|   followedMessageDescriptionForLockedAccount: "팔로우를 승인제로 한 경우, 팔로우 요청을 수락했을 때 보여줍니다." | ||||
| _exportOrImport: | ||||
|   allNotes: "모든 노트" | ||||
|   favoritedNotes: "즐겨찾기한 노트" | ||||
| @@ -2378,6 +2391,7 @@ _notification: | ||||
|   renotedBySomeUsers: "{n}명이 리노트했습니다" | ||||
|   followedBySomeUsers: "{n}명에게 팔로우됨" | ||||
|   flushNotification: "알림 이력을 초기화" | ||||
|   exportOfXCompleted: "{x} 추출에 성공했습니다." | ||||
|   _types: | ||||
|     all: "전부" | ||||
|     note: "사용자의 새 글" | ||||
| @@ -2392,6 +2406,8 @@ _notification: | ||||
|     followRequestAccepted: "팔로우 요청이 승인되었을 때" | ||||
|     roleAssigned: "역할이 부여 됨" | ||||
|     achievementEarned: "도전 과제 획득" | ||||
|     exportCompleted: "추출을 성공함" | ||||
|     test: "알림 테스트" | ||||
|     app: "연동된 앱을 통한 알림" | ||||
|   _actions: | ||||
|     followBack: "팔로우" | ||||
|   | ||||
| @@ -492,7 +492,6 @@ uiLanguage: "Język wyświetlania UI" | ||||
| aboutX: "O {x}" | ||||
| emojiStyle: "Styl emoji" | ||||
| native: "Natywny" | ||||
| disableDrawer: "Nie używaj menu w stylu szuflady" | ||||
| showNoteActionsOnlyHover: "Pokazuj akcje notatek tylko po najechaniu myszką" | ||||
| showReactionsCount: "Wyświetl liczbę reakcji na notatkę" | ||||
| noHistory: "Brak historii" | ||||
|   | ||||
| @@ -509,7 +509,6 @@ uiLanguage: "Idioma de exibição da interface " | ||||
| aboutX: "Sobre {x}" | ||||
| emojiStyle: "Estilo de emojis" | ||||
| native: "Nativo" | ||||
| disableDrawer: "Não mostrar o menu em formato de gaveta" | ||||
| showNoteActionsOnlyHover: "Exibir as ações da nota somente ao passar o cursor sobre ela" | ||||
| showReactionsCount: "Ver o número de reações nas notas" | ||||
| noHistory: "Ainda não há histórico" | ||||
|   | ||||
| @@ -453,7 +453,6 @@ or: "Sau" | ||||
| language: "Limbă" | ||||
| uiLanguage: "Limba interfeței" | ||||
| aboutX: "Despre {x}" | ||||
| disableDrawer: "Nu folosi meniuri în stil sertar" | ||||
| noHistory: "Nu există istoric" | ||||
| signinHistory: "Istoric autentificări" | ||||
| doing: "Se procesează..." | ||||
|   | ||||
| @@ -503,7 +503,6 @@ uiLanguage: "Язык интерфейса" | ||||
| aboutX: "Описание {x}" | ||||
| emojiStyle: "Стиль эмодзи" | ||||
| native: "Системные" | ||||
| disableDrawer: "Не использовать выдвижные меню" | ||||
| showNoteActionsOnlyHover: "Показывать кнопки у заметок только при наведении" | ||||
| showReactionsCount: "Видеть количество реакций на заметках" | ||||
| noHistory: "История пока пуста" | ||||
|   | ||||
| @@ -454,7 +454,6 @@ uiLanguage: "Jazyk používateľského prostredia" | ||||
| aboutX: "O {x}" | ||||
| emojiStyle: "Štýl emoji" | ||||
| native: "Natívne" | ||||
| disableDrawer: "Nepoužívať šuflíkové menu" | ||||
| showNoteActionsOnlyHover: "Ovládacie prvky poznámky sa zobrazujú len po nabehnutí myši" | ||||
| noHistory: "Žiadna história" | ||||
| signinHistory: "História prihlásení" | ||||
|   | ||||
| @@ -509,7 +509,6 @@ uiLanguage: "ภาษาอินเทอร์เฟซผู้ใช้ง | ||||
| aboutX: "เกี่ยวกับ {x}" | ||||
| emojiStyle: "สไตล์ของเอโมจิ" | ||||
| native: "ภาษาแม่" | ||||
| disableDrawer: "ไม่แสดงเมนูในรูปแบบลิ้นชัก" | ||||
| showNoteActionsOnlyHover: "แสดงการดำเนินการโน้ตเมื่อโฮเวอร์(วางเมาส์เหนือ)เท่านั้น" | ||||
| showReactionsCount: "แสดงจำนวนรีแอกชั่นในโน้ต" | ||||
| noHistory: "ไม่มีประวัติ" | ||||
|   | ||||
| @@ -452,7 +452,6 @@ language: "Мова" | ||||
| uiLanguage: "Мова інтерфейсу" | ||||
| aboutX: "Про {x}" | ||||
| native: "місцевий" | ||||
| disableDrawer: "Не використовувати висувні меню" | ||||
| noHistory: "Історія порожня" | ||||
| signinHistory: "Історія входів" | ||||
| enableAdvancedMfm: "Увімкнути розширений MFM" | ||||
|   | ||||
| @@ -471,7 +471,6 @@ uiLanguage: "Interfeys tili" | ||||
| aboutX: "{x} haqida" | ||||
| emojiStyle: "Emoji ko'rinishi" | ||||
| native: "Mahalliy" | ||||
| disableDrawer: "Slayd menyusidan foydalanmang" | ||||
| showNoteActionsOnlyHover: "Eslatma amallarini faqat sichqonchani olib borganda ko‘rsatish" | ||||
| noHistory: "Tarix yo'q" | ||||
| signinHistory: "kirish tarixi" | ||||
|   | ||||
| @@ -486,7 +486,6 @@ uiLanguage: "Ngôn ngữ giao diện" | ||||
| aboutX: "Giới thiệu {x}" | ||||
| emojiStyle: "Kiểu cách Emoji" | ||||
| native: "Bản xứ" | ||||
| disableDrawer: "Không dùng menu thanh bên" | ||||
| showNoteActionsOnlyHover: "Chỉ hiển thị các hành động ghi chú khi di chuột" | ||||
| noHistory: "Không có dữ liệu" | ||||
| signinHistory: "Lịch sử đăng nhập" | ||||
|   | ||||
| @@ -334,6 +334,7 @@ renameFolder: "重命名文件夹" | ||||
| deleteFolder: "删除文件夹" | ||||
| folder: "文件夹" | ||||
| addFile: "添加文件" | ||||
| showFile: "显示文件" | ||||
| emptyDrive: "网盘中无文件" | ||||
| emptyFolder: "此文件夹中无文件" | ||||
| unableToDelete: "无法删除" | ||||
| @@ -509,7 +510,9 @@ uiLanguage: "显示语言" | ||||
| aboutX: "关于 {x}" | ||||
| emojiStyle: "表情符号的样式" | ||||
| native: "原生" | ||||
| disableDrawer: "不显示抽屉菜单" | ||||
| menuStyle: "菜单样式" | ||||
| style: "样式" | ||||
| popup: "弹窗" | ||||
| showNoteActionsOnlyHover: "仅在悬停时显示帖子操作" | ||||
| showReactionsCount: "显示帖子的回应数" | ||||
| noHistory: "没有历史记录" | ||||
| @@ -1270,6 +1273,10 @@ genEmbedCode: "生成嵌入代码" | ||||
| noteOfThisUser: "此用户的帖子" | ||||
| clipNoteLimitExceeded: "无法再往此便签内添加更多帖子" | ||||
| performance: "性能" | ||||
| signinWithPasskey: "使用通行密钥登录" | ||||
| unknownWebAuthnKey: "此通行密钥未注册。" | ||||
| passkeyVerificationFailed: "验证通行密钥失败。" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "通行密钥验证成功,但账户未开启无密码登录。" | ||||
| _delivery: | ||||
|   status: "投递状态" | ||||
|   stop: "停止投递" | ||||
| @@ -2375,6 +2382,7 @@ _notification: | ||||
|   renotedBySomeUsers: "{n} 人转发了" | ||||
|   followedBySomeUsers: "被 {n} 人关注" | ||||
|   flushNotification: "重置通知历史" | ||||
|   exportOfXCompleted: "已完成 {x} 个导出" | ||||
|   _types: | ||||
|     all: "全部" | ||||
|     note: "用户的新帖子" | ||||
| @@ -2389,6 +2397,8 @@ _notification: | ||||
|     followRequestAccepted: "关注请求已通过" | ||||
|     roleAssigned: "授予的角色" | ||||
|     achievementEarned: "取得的成就" | ||||
|     exportCompleted: "已完成导出" | ||||
|     test: "测试通知" | ||||
|     app: "关联应用的通知" | ||||
|   _actions: | ||||
|     followBack: "回关" | ||||
|   | ||||
| @@ -236,6 +236,8 @@ silencedInstances: "被禁言的伺服器" | ||||
| silencedInstancesDescription: "設定要禁言的伺服器主機名稱,以換行分隔。隸屬於禁言伺服器的所有帳戶都將被視為「禁言帳戶」,只能發出「追隨請求」,而且無法提及未追隨的本地帳戶。這不會影響已封鎖的實例。" | ||||
| mediaSilencedInstances: "媒體被禁言的伺服器" | ||||
| mediaSilencedInstancesDescription: "設定您想要對媒體設定禁言的伺服器,以換行符號區隔。來自被媒體禁言的伺服器所屬帳戶的所有檔案都會被視為敏感檔案,且自訂表情符號不能使用。被封鎖的伺服器不受影響。" | ||||
| federationAllowedHosts: "允許聯邦通訊的伺服器" | ||||
| federationAllowedHostsDescription: "設定允許聯邦通訊的伺服器主機,以換行符號分隔。" | ||||
| muteAndBlock: "靜音和封鎖" | ||||
| mutedUsers: "被靜音的使用者" | ||||
| blockedUsers: "被封鎖的使用者" | ||||
| @@ -334,6 +336,7 @@ renameFolder: "重新命名資料夾" | ||||
| deleteFolder: "刪除資料夾" | ||||
| folder: "資料夾" | ||||
| addFile: "加入附件" | ||||
| showFile: "瀏覽文件" | ||||
| emptyDrive: "雲端硬碟為空" | ||||
| emptyFolder: "資料夾為空" | ||||
| unableToDelete: "無法刪除" | ||||
| @@ -509,7 +512,10 @@ uiLanguage: "介面語言" | ||||
| aboutX: "關於{x}" | ||||
| emojiStyle: "表情符號的風格" | ||||
| native: "原生" | ||||
| disableDrawer: "不顯示下拉式選單" | ||||
| menuStyle: "選單風格" | ||||
| style: "風格" | ||||
| drawer: "側邊欄" | ||||
| popup: "彈出式視窗" | ||||
| showNoteActionsOnlyHover: "僅在游標停留時顯示貼文的操作選項" | ||||
| showReactionsCount: "顯示貼文的反應數目" | ||||
| noHistory: "沒有歷史紀錄" | ||||
| @@ -1273,6 +1279,10 @@ performance: "性能" | ||||
| modified: "已變更" | ||||
| discard: "取消" | ||||
| thereAreNChanges: "有 {n} 處的變更" | ||||
| signinWithPasskey: "使用密碼金鑰登入" | ||||
| unknownWebAuthnKey: "未註冊的金鑰。" | ||||
| passkeyVerificationFailed: "驗證金鑰失敗。" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "雖然驗證金鑰成功,但是無密碼登入的方式是停用的。" | ||||
| _delivery: | ||||
|   status: "傳送狀態" | ||||
|   stop: "停止發送" | ||||
| @@ -2240,6 +2250,9 @@ _profile: | ||||
|   changeBanner: "變更橫幅圖像" | ||||
|   verifiedLinkDescription: "如果輸入包含您個人資料的網站 URL,欄位旁邊將出現驗證圖示。" | ||||
|   avatarDecorationMax: "最多可以設置 {max} 個裝飾。" | ||||
|   followedMessage: "被追隨時的訊息" | ||||
|   followedMessageDescription: "可以設定被追隨時顯示給對方的訊息。" | ||||
|   followedMessageDescriptionForLockedAccount: "如果追隨是需要審核的話,在允許追隨請求之後顯示。" | ||||
| _exportOrImport: | ||||
|   allNotes: "所有貼文" | ||||
|   favoritedNotes: "「我的最愛」貼文" | ||||
| @@ -2378,6 +2391,7 @@ _notification: | ||||
|   renotedBySomeUsers: "{n}人做了轉發" | ||||
|   followedBySomeUsers: "被{n}人追隨了" | ||||
|   flushNotification: "重置通知歷史紀錄" | ||||
|   exportOfXCompleted: "{x} 的匯出已完成。" | ||||
|   _types: | ||||
|     all: "全部 " | ||||
|     note: "使用者的最新貼文" | ||||
| @@ -2392,6 +2406,8 @@ _notification: | ||||
|     followRequestAccepted: "追隨請求已接受" | ||||
|     roleAssigned: "已授予角色" | ||||
|     achievementEarned: "獲得成就" | ||||
|     exportCompleted: "已完成匯出。" | ||||
|     test: "通知測試" | ||||
|     app: "應用程式通知" | ||||
|   _actions: | ||||
|     followBack: "追隨回去" | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"version": "2024.9.0-alpha.11", | ||||
| 	"version": "2024.9.0", | ||||
| 	"codename": "nasubi", | ||||
| 	"repository": { | ||||
| 		"type": "git", | ||||
|   | ||||
							
								
								
									
										16
									
								
								packages/backend/migration/1727491883993-user-score.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								packages/backend/migration/1727491883993-user-score.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class UserScore1727491883993 { | ||||
|     name = 'UserScore1727491883993' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "score" integer NOT NULL DEFAULT '0'`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "score"`); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										18
									
								
								packages/backend/migration/1727512908322-meta-federation.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								packages/backend/migration/1727512908322-meta-federation.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,18 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class MetaFederation1727512908322 { | ||||
|     name = 'MetaFederation1727512908322' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "federation" character varying(128) NOT NULL DEFAULT 'all'`); | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "federationHosts" character varying(1024) array NOT NULL DEFAULT '{}'`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "federationHosts"`); | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "federation"`); | ||||
|     } | ||||
| } | ||||
| @@ -67,9 +67,9 @@ | ||||
| 	"dependencies": { | ||||
| 		"@aws-sdk/client-s3": "3.620.0", | ||||
| 		"@aws-sdk/lib-storage": "3.620.0", | ||||
| 		"@bull-board/api": "5.23.0", | ||||
| 		"@bull-board/fastify": "5.23.0", | ||||
| 		"@bull-board/ui": "5.23.0", | ||||
| 		"@bull-board/api": "6.0.0", | ||||
| 		"@bull-board/fastify": "6.0.0", | ||||
| 		"@bull-board/ui": "6.0.0", | ||||
| 		"@discordapp/twemoji": "15.1.0", | ||||
| 		"@fastify/accepts": "5.0.0", | ||||
| 		"@fastify/cookie": "10.0.0", | ||||
|   | ||||
| @@ -10,12 +10,16 @@ import RE2 from 're2'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import type { Config } from '@/config.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { MiMeta } from '@/models/Meta.js'; | ||||
|  | ||||
| @Injectable() | ||||
| export class UtilityService { | ||||
| 	constructor( | ||||
| 		@Inject(DI.config) | ||||
| 		private config: Config, | ||||
|  | ||||
| 		@Inject(DI.meta) | ||||
| 		private meta: MiMeta, | ||||
| 	) { | ||||
| 	} | ||||
|  | ||||
| @@ -105,4 +109,19 @@ export class UtilityService { | ||||
| 		if (host == null) return null; | ||||
| 		return toASCII(host.toLowerCase()); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public isFederationAllowedHost(host: string): boolean { | ||||
| 		if (this.meta.federation === 'none') return false; | ||||
| 		if (this.meta.federation === 'specified' && !this.meta.federationHosts.some(x => `.${host.toLowerCase()}`.endsWith(`.${x}`))) return false; | ||||
| 		if (this.isBlockedHost(this.meta.blockedHosts, host)) return false; | ||||
|  | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public isFederationAllowedUri(uri: string): boolean { | ||||
| 		const host = this.extractDbHost(uri); | ||||
| 		return this.isFederationAllowedHost(host); | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -68,6 +68,7 @@ function generateDummyUser(override?: Partial<MiUser>): MiUser { | ||||
| 		isHibernated: false, | ||||
| 		isDeleted: false, | ||||
| 		emojis: [], | ||||
| 		score: 0, | ||||
| 		host: null, | ||||
| 		inbox: null, | ||||
| 		sharedInbox: null, | ||||
|   | ||||
| @@ -290,8 +290,8 @@ export class ApInboxService { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		// アナウンス先をブロックしてたら中断 | ||||
| 		if (this.utilityService.isBlockedHost(this.meta.blockedHosts, this.utilityService.extractDbHost(uri))) return; | ||||
| 		// アナウンス先が許可されているかチェック | ||||
| 		if (!this.utilityService.isFederationAllowedUri(uri)) return; | ||||
|  | ||||
| 		const unlock = await this.appLockService.getApLock(uri); | ||||
|  | ||||
|   | ||||
| @@ -93,7 +93,7 @@ export class Resolver { | ||||
| 			return await this.resolveLocal(value); | ||||
| 		} | ||||
|  | ||||
| 		if (this.utilityService.isBlockedHost(this.meta.blockedHosts, host)) { | ||||
| 		if (!this.utilityService.isFederationAllowedHost(host)) { | ||||
| 			throw new Error('Instance is blocked'); | ||||
| 		} | ||||
|  | ||||
|   | ||||
| @@ -336,8 +336,7 @@ export class ApNoteService { | ||||
| 	public async resolveNote(value: string | IObject, options: { sentFrom?: URL, resolver?: Resolver } = {}): Promise<MiNote | null> { | ||||
| 		const uri = getApId(value); | ||||
|  | ||||
| 		// ブロックしていたら中断 | ||||
| 		if (this.utilityService.isBlockedHost(this.meta.blockedHosts, this.utilityService.extractDbHost(uri))) { | ||||
| 		if (!this.utilityService.isFederationAllowedUri(uri)) { | ||||
| 			throw new StatusError('blocked host', 451); | ||||
| 		} | ||||
|  | ||||
|   | ||||
| @@ -630,4 +630,17 @@ export class MiMeta { | ||||
| 		nullable: true, | ||||
| 	}) | ||||
| 	public urlPreviewUserAgent: string | null; | ||||
|  | ||||
| 	@Column('varchar', { | ||||
| 		length: 128, | ||||
| 		default: 'all', | ||||
| 	}) | ||||
| 	public federation: 'all' | 'specified' | 'none'; | ||||
|  | ||||
| 	@Column('varchar', { | ||||
| 		length: 1024, | ||||
| 		array: true, | ||||
| 		default: '{}', | ||||
| 	}) | ||||
| 	public federationHosts: string[]; | ||||
| } | ||||
|   | ||||
| @@ -155,6 +155,11 @@ export class MiUser { | ||||
| 	}) | ||||
| 	public tags: string[]; | ||||
|  | ||||
| 	@Column('integer', { | ||||
| 		default: 0, | ||||
| 	}) | ||||
| 	public score: number; | ||||
|  | ||||
| 	@Column('boolean', { | ||||
| 		default: false, | ||||
| 		comment: 'Whether the User is suspended.', | ||||
|   | ||||
| @@ -53,8 +53,7 @@ export class DeliverProcessorService { | ||||
| 	public async process(job: Bull.Job<DeliverJobData>): Promise<string> { | ||||
| 		const { host } = new URL(job.data.to); | ||||
|  | ||||
| 		// ブロックしてたら中断 | ||||
| 		if (this.utilityService.isBlockedHost(this.meta.blockedHosts, this.utilityService.toPuny(host))) { | ||||
| 		if (!this.utilityService.isFederationAllowedUri(job.data.to)) { | ||||
| 			return 'skip (blocked)'; | ||||
| 		} | ||||
|  | ||||
|   | ||||
| @@ -75,8 +75,7 @@ export class InboxProcessorService implements OnApplicationShutdown { | ||||
|  | ||||
| 		const host = this.utilityService.toPuny(new URL(signature.keyId).hostname); | ||||
|  | ||||
| 		// ブロックしてたら中断 | ||||
| 		if (this.utilityService.isBlockedHost(this.meta.blockedHosts, host)) { | ||||
| 		if (!this.utilityService.isFederationAllowedHost(host)) { | ||||
| 			return `Blocked request: ${host}`; | ||||
| 		} | ||||
|  | ||||
| @@ -175,9 +174,8 @@ export class InboxProcessorService implements OnApplicationShutdown { | ||||
| 					throw new Bull.UnrecoverableError(`skip: LD-Signature user(${authUser.user.uri}) !== activity.actor(${activity.actor})`); | ||||
| 				} | ||||
|  | ||||
| 				// ブロックしてたら中断 | ||||
| 				const ldHost = this.utilityService.extractDbHost(authUser.user.uri); | ||||
| 				if (this.utilityService.isBlockedHost(this.meta.blockedHosts, ldHost)) { | ||||
| 				if (!this.utilityService.isFederationAllowedHost(ldHost)) { | ||||
| 					throw new Bull.UnrecoverableError(`Blocked request: ${ldHost}`); | ||||
| 				} | ||||
| 			} else { | ||||
|   | ||||
| @@ -495,6 +495,18 @@ export const meta = { | ||||
| 				type: 'string', | ||||
| 				optional: false, nullable: true, | ||||
| 			}, | ||||
| 			federation: { | ||||
| 				type: 'string', | ||||
| 				optional: false, nullable: false, | ||||
| 			}, | ||||
| 			federationHosts: { | ||||
| 				type: 'array', | ||||
| 				optional: false, nullable: false, | ||||
| 				items: { | ||||
| 					type: 'string', | ||||
| 					optional: false, nullable: false, | ||||
| 				}, | ||||
| 			}, | ||||
| 		}, | ||||
| 	}, | ||||
| } as const; | ||||
| @@ -630,6 +642,8 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- | ||||
| 				urlPreviewRequireContentLength: instance.urlPreviewRequireContentLength, | ||||
| 				urlPreviewUserAgent: instance.urlPreviewUserAgent, | ||||
| 				urlPreviewSummaryProxyUrl: instance.urlPreviewSummaryProxyUrl, | ||||
| 				federation: instance.federation, | ||||
| 				federationHosts: instance.federationHosts, | ||||
| 			}; | ||||
| 		}); | ||||
| 	} | ||||
|   | ||||
| @@ -168,6 +168,16 @@ export const paramDef = { | ||||
| 		urlPreviewRequireContentLength: { type: 'boolean' }, | ||||
| 		urlPreviewUserAgent: { type: 'string', nullable: true }, | ||||
| 		urlPreviewSummaryProxyUrl: { type: 'string', nullable: true }, | ||||
| 		federation: { | ||||
| 			type: 'string', | ||||
| 			enum: ['all', 'none', 'specified'], | ||||
| 		}, | ||||
| 		federationHosts: { | ||||
| 			type: 'array', | ||||
| 			items: { | ||||
| 				type: 'string', | ||||
| 			}, | ||||
| 		}, | ||||
| 	}, | ||||
| 	required: [], | ||||
| } as const; | ||||
| @@ -637,6 +647,14 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- | ||||
| 				set.urlPreviewSummaryProxyUrl = value === '' ? null : value; | ||||
| 			} | ||||
|  | ||||
| 			if (ps.federation !== undefined) { | ||||
| 				set.federation = ps.federation; | ||||
| 			} | ||||
|  | ||||
| 			if (Array.isArray(ps.federationHosts)) { | ||||
| 				set.blockedHosts = ps.federationHosts.filter(Boolean).map(x => x.toLowerCase()); | ||||
| 			} | ||||
|  | ||||
| 			const before = await this.metaService.fetch(true); | ||||
|  | ||||
| 			await this.metaService.update(set); | ||||
|   | ||||
| @@ -19,8 +19,6 @@ import { NoteEntityService } from '@/core/entities/NoteEntityService.js'; | ||||
| import { UtilityService } from '@/core/UtilityService.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { ApiError } from '../../error.js'; | ||||
| import { MiMeta } from '@/models/_.js'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
|  | ||||
| export const meta = { | ||||
| 	tags: ['federation'], | ||||
| @@ -89,9 +87,6 @@ export const paramDef = { | ||||
| @Injectable() | ||||
| export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint-disable-line import/no-default-export | ||||
| 	constructor( | ||||
| 		@Inject(DI.meta) | ||||
| 		private serverSettings: MiMeta, | ||||
|  | ||||
| 		private utilityService: UtilityService, | ||||
| 		private userEntityService: UserEntityService, | ||||
| 		private noteEntityService: NoteEntityService, | ||||
| @@ -115,8 +110,7 @@ export default class extends Endpoint<typeof meta, typeof paramDef> { // eslint- | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	private async fetchAny(uri: string, me: MiLocalUser | null | undefined): Promise<SchemaType<typeof meta['res']> | null> { | ||||
| 		// ブロックしてたら中断 | ||||
| 		if (this.utilityService.isBlockedHost(this.serverSettings.blockedHosts, this.utilityService.extractDbHost(uri))) return null; | ||||
| 		if (!this.utilityService.isFederationAllowedUri(uri)) return null; | ||||
|  | ||||
| 		let local = await this.mergePack(me, ...await Promise.all([ | ||||
| 			this.apDbResolverService.getUserFromApId(uri), | ||||
|   | ||||
| @@ -256,7 +256,7 @@ export class ClientServerService { | ||||
| 		}); | ||||
|  | ||||
| 		bullBoardServerAdapter.setBasePath(bullBoardPath); | ||||
| 		//(fastify.register as any)(bullBoardServerAdapter.registerPlugin(), { prefix: bullBoardPath }); | ||||
| 		(fastify.register as any)(bullBoardServerAdapter.registerPlugin(), { prefix: bullBoardPath }); | ||||
| 		//#endregion | ||||
|  | ||||
| 		fastify.register(fastifyView, { | ||||
|   | ||||
| @@ -180,7 +180,6 @@ describe('Webリソース', () => { | ||||
| 		})); | ||||
| 	}); | ||||
|  | ||||
| 	/* queueは一時的に無効化されている | ||||
| 	describe.each([{ path: '/queue' }])('$path', ({ path }) => { | ||||
| 		test('はログインしないとGETできない。', async () => await notOk({ | ||||
| 			path, | ||||
| @@ -198,7 +197,6 @@ describe('Webリソース', () => { | ||||
| 			cookie: cookie(alice), | ||||
| 		})); | ||||
| 	}); | ||||
| 	*/ | ||||
|  | ||||
| 	describe.each([{ path: '/streaming' }])('$path', ({ path }) => { | ||||
| 		test('はGETできない。', async () => await notOk({ | ||||
|   | ||||
| @@ -53,7 +53,14 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 			<MkInstanceTicker v-if="showTicker" :instance="appearNote.user.instance"/> | ||||
| 			<div style="container-type: inline-size;"> | ||||
| 				<p v-if="appearNote.cw != null" :class="$style.cw"> | ||||
| 					<Mfm v-if="appearNote.cw != ''" style="margin-right: 8px;" :text="appearNote.cw" :author="appearNote.user" :nyaize="'respect'"/> | ||||
| 					<Mfm | ||||
| 						v-if="appearNote.cw != ''" | ||||
| 						:text="appearNote.cw" | ||||
| 						:author="appearNote.user" | ||||
| 						:nyaize="'respect'" | ||||
| 						:enableEmojiMenu="true" | ||||
| 						:enableEmojiMenuReaction="true" | ||||
| 					/> | ||||
| 					<MkCwButton v-model="showContent" :text="appearNote.text" :renote="appearNote.renote" :files="appearNote.files" :poll="appearNote.poll" style="margin: 4px 0;"/> | ||||
| 				</p> | ||||
| 				<div v-show="appearNote.cw == null || showContent" :class="[{ [$style.contentCollapsed]: collapsed }]"> | ||||
|   | ||||
| @@ -68,7 +68,14 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 		</header> | ||||
| 		<div :class="$style.noteContent"> | ||||
| 			<p v-if="appearNote.cw != null" :class="$style.cw"> | ||||
| 				<Mfm v-if="appearNote.cw != ''" style="margin-right: 8px;" :text="appearNote.cw" :author="appearNote.user" :nyaize="'respect'"/> | ||||
| 				<Mfm | ||||
| 					v-if="appearNote.cw != ''" | ||||
| 					:text="appearNote.cw" | ||||
| 					:author="appearNote.user" | ||||
| 					:nyaize="'respect'" | ||||
| 					:enableEmojiMenu="true" | ||||
| 					:enableEmojiMenuReaction="true" | ||||
| 				/> | ||||
| 				<MkCwButton v-model="showContent" :text="appearNote.text" :renote="appearNote.renote" :files="appearNote.files" :poll="appearNote.poll"/> | ||||
| 			</p> | ||||
| 			<div v-show="appearNote.cw == null || showContent"> | ||||
|   | ||||
| @@ -5,7 +5,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
|  | ||||
| <template> | ||||
| <header :class="$style.root"> | ||||
| 	<MkCondensedLine :minScale="0" style="min-width: 0; flex: 1;"> | ||||
| 	<component :is="defaultStore.state.enableCondensedLine ? 'MkCondensedLine' : 'div'" :minScale="0.5" style="min-width: 0;"> | ||||
| 		<div style="display: flex; white-space: nowrap; align-items: baseline;"> | ||||
| 			<div v-if="mock" :class="$style.name"> | ||||
| 				<MkUserName :user="note.user"/> | ||||
| @@ -16,7 +16,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 			<div v-if="note.user.isBot" :class="$style.isBot">bot</div> | ||||
| 			<div :class="$style.username"><MkAcct :user="note.user"/></div> | ||||
| 		</div> | ||||
| 	</MkCondensedLine> | ||||
| 	</component> | ||||
| 	<div v-if="note.user.badgeRoles" :class="$style.badgeRoles"> | ||||
| 		<img v-for="(role, i) in note.user.badgeRoles" :key="i" v-tooltip="role.name" :class="$style.badgeRole" :src="role.iconUrl!"/> | ||||
| 	</div> | ||||
| @@ -44,6 +44,7 @@ import * as Misskey from 'misskey-js'; | ||||
| import { i18n } from '@/i18n.js'; | ||||
| import { notePage } from '@/filters/note.js'; | ||||
| import { userPage } from '@/filters/user.js'; | ||||
| import { defaultStore } from '@/store.js'; | ||||
|  | ||||
| defineProps<{ | ||||
| 	note: Misskey.entities.Note; | ||||
|   | ||||
| @@ -5,7 +5,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
|  | ||||
| <template> | ||||
| <span :class="$style.container"> | ||||
| 	<span ref="content" :class="$style.content"> | ||||
| 	<span ref="content" :class="$style.content" :style="{ maxWidth: `${100 / minScale}%` }"> | ||||
| 		<slot/> | ||||
| 	</span> | ||||
| </span> | ||||
|   | ||||
| @@ -210,6 +210,31 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 					</div> | ||||
| 				</MkFolder> | ||||
|  | ||||
| 				<MkFolder> | ||||
| 					<template #icon><i class="ti ti-planet"></i></template> | ||||
| 					<template #label>{{ i18n.ts.federation }}</template> | ||||
| 					<template v-if="federationForm.savedState.federation === 'all'" #suffix>{{ i18n.ts.all }}</template> | ||||
| 					<template v-else-if="federationForm.savedState.federation === 'specified'" #suffix>{{ i18n.ts.specifyHost }}</template> | ||||
| 					<template v-else-if="federationForm.savedState.federation === 'none'" #suffix>{{ i18n.ts.none }}</template> | ||||
| 					<template v-if="federationForm.modified.value" #footer> | ||||
| 						<MkFormFooter :form="federationForm"/> | ||||
| 					</template> | ||||
|  | ||||
| 					<div class="_gaps"> | ||||
| 						<MkRadios v-model="federationForm.state.federation"> | ||||
| 							<template #label>{{ i18n.ts.behavior }}<span v-if="federationForm.modifiedStates.federation" class="_modified">{{ i18n.ts.modified }}</span></template> | ||||
| 							<option value="all">{{ i18n.ts.all }}</option> | ||||
| 							<option value="specified">{{ i18n.ts.specifyHost }}</option> | ||||
| 							<option value="none">{{ i18n.ts.none }}</option> | ||||
| 						</MkRadios> | ||||
|  | ||||
| 						<MkTextarea v-if="federationForm.state.federation === 'specified'" v-model="federationForm.state.federationHosts"> | ||||
| 							<template #label>{{ i18n.ts.federationAllowedHosts }}<span v-if="federationForm.modifiedStates.federationHosts" class="_modified">{{ i18n.ts.modified }}</span></template> | ||||
| 							<template #caption>{{ i18n.ts.federationAllowedHostsDescription }}</template> | ||||
| 						</MkTextarea> | ||||
| 					</div> | ||||
| 				</MkFolder> | ||||
|  | ||||
| 				<MkFolder> | ||||
| 					<template #icon><i class="ti ti-ghost"></i></template> | ||||
| 					<template #label>{{ i18n.ts.proxyAccount }}</template> | ||||
| @@ -248,6 +273,7 @@ import MkFolder from '@/components/MkFolder.vue'; | ||||
| import MkKeyValue from '@/components/MkKeyValue.vue'; | ||||
| import { useForm } from '@/scripts/use-form.js'; | ||||
| import MkFormFooter from '@/components/MkFormFooter.vue'; | ||||
| import MkRadios from '@/components/MkRadios.vue'; | ||||
|  | ||||
| const meta = await misskeyApi('admin/meta'); | ||||
|  | ||||
| @@ -341,6 +367,17 @@ const urlPreviewForm = useForm({ | ||||
| 	fetchInstance(true); | ||||
| }); | ||||
|  | ||||
| const federationForm = useForm({ | ||||
| 	federation: meta.federation, | ||||
| 	federationHosts: meta.federationHosts.join('\n'), | ||||
| }, async (state) => { | ||||
| 	await os.apiWithDialog('admin/update-meta', { | ||||
| 		federation: state.federation, | ||||
| 		federationHosts: state.federationHosts.split('\n'), | ||||
| 	}); | ||||
| 	fetchInstance(true); | ||||
| }); | ||||
|  | ||||
| function chooseProxyAccount() { | ||||
| 	os.selectUser({ localOnly: true }).then(user => { | ||||
| 		proxyAccount.value = user; | ||||
|   | ||||
| @@ -51,6 +51,9 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 				<template #label>{{ i18n.ts.experimentalFeatures }}</template> | ||||
|  | ||||
| 				<div class="_gaps_m"> | ||||
| 					<MkSwitch v-model="enableCondensedLine"> | ||||
| 						<template #label>Enable condensed line</template> | ||||
| 					</MkSwitch> | ||||
| 				</div> | ||||
| 			</MkFolder> | ||||
|  | ||||
| @@ -101,6 +104,7 @@ import FormSection from '@/components/form/section.vue'; | ||||
| const $i = signinRequired(); | ||||
|  | ||||
| const reportError = computed(defaultStore.makeGetterSetter('reportError')); | ||||
| const enableCondensedLine = computed(defaultStore.makeGetterSetter('enableCondensedLine')); | ||||
| const devMode = computed(defaultStore.makeGetterSetter('devMode')); | ||||
| const defaultWithReplies = computed(defaultStore.makeGetterSetter('defaultWithReplies')); | ||||
|  | ||||
|   | ||||
| @@ -89,7 +89,7 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
| 	</FormSlot> | ||||
|  | ||||
| 	<MkInput v-model="profile.followedMessage" :max="200" manualSave :mfmPreview="false"> | ||||
| 		<template #label>{{ i18n.ts._profile.followedMessage }}</template> | ||||
| 		<template #label>{{ i18n.ts._profile.followedMessage }}<span class="_beta">{{ i18n.ts.beta }}</span></template> | ||||
| 		<template #caption> | ||||
| 			<div>{{ i18n.ts._profile.followedMessageDescription }}</div> | ||||
| 			<div>{{ i18n.ts._profile.followedMessageDescriptionForLockedAccount }}</div> | ||||
|   | ||||
| @@ -392,6 +392,10 @@ export const defaultStore = markRaw(new Storage('base', { | ||||
| 		where: 'device', | ||||
| 		default: 'horizontal' as 'vertical' | 'horizontal', | ||||
| 	}, | ||||
| 	enableCondensedLine: { | ||||
| 		where: 'device', | ||||
| 		default: false, | ||||
| 	}, | ||||
| 	additionalUnicodeEmojiIndexes: { | ||||
| 		where: 'device', | ||||
| 		default: {} as Record<string, Record<string, string[]>>, | ||||
|   | ||||
| @@ -1,7 +1,7 @@ | ||||
| { | ||||
| 	"type": "module", | ||||
| 	"name": "misskey-js", | ||||
| 	"version": "2024.9.0-alpha.11", | ||||
| 	"version": "2024.9.0", | ||||
| 	"description": "Misskey SDK for JavaScript", | ||||
| 	"license": "MIT", | ||||
| 	"main": "./built/index.js", | ||||
|   | ||||
							
								
								
									
										169
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										169
									
								
								pnpm-lock.yaml
									
									
									
										generated
									
									
									
								
							| @@ -90,14 +90,14 @@ importers: | ||||
|         specifier: 3.620.0 | ||||
|         version: 3.620.0(@aws-sdk/client-s3@3.620.0) | ||||
|       '@bull-board/api': | ||||
|         specifier: 5.23.0 | ||||
|         version: 5.23.0(@bull-board/ui@5.23.0) | ||||
|         specifier: 6.0.0 | ||||
|         version: 6.0.0(@bull-board/ui@6.0.0) | ||||
|       '@bull-board/fastify': | ||||
|         specifier: 5.23.0 | ||||
|         version: 5.23.0 | ||||
|         specifier: 6.0.0 | ||||
|         version: 6.0.0 | ||||
|       '@bull-board/ui': | ||||
|         specifier: 5.23.0 | ||||
|         version: 5.23.0 | ||||
|         specifier: 6.0.0 | ||||
|         version: 6.0.0 | ||||
|       '@discordapp/twemoji': | ||||
|         specifier: 15.1.0 | ||||
|         version: 15.1.0 | ||||
| @@ -1888,16 +1888,16 @@ packages: | ||||
|   '@bcoe/v8-coverage@0.2.3': | ||||
|     resolution: {integrity: sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw==} | ||||
|  | ||||
|   '@bull-board/api@5.23.0': | ||||
|     resolution: {integrity: sha512-ZZGsWJ+XBG49GAlNgAL9tTEV6Ms7gMkQnZDbzwUhjGChCKWy62RWuPoZSefNXau9QH9+QzlzHRUeFvt4xr5wiw==} | ||||
|   '@bull-board/api@6.0.0': | ||||
|     resolution: {integrity: sha512-O0IsIwAOU47bPTJnqRO7RtKFQToMvwRebbuPi6M+SG1gXyiqixLg9pycnfXgSeroaT9E7QQ2PsCPW1HO8VORvw==} | ||||
|     peerDependencies: | ||||
|       '@bull-board/ui': 5.23.0 | ||||
|       '@bull-board/ui': 6.0.0 | ||||
|  | ||||
|   '@bull-board/fastify@5.23.0': | ||||
|     resolution: {integrity: sha512-woCnCAav4IByuo05D13MZtETzZp0ej1y0R+6IY33pqLKDRKa6Dor6OMx1l6/nMc/wXeng4SXC5rnrAck7Py70w==} | ||||
|   '@bull-board/fastify@6.0.0': | ||||
|     resolution: {integrity: sha512-VrKa5BdxYmXh5fJvlSPSm71b+QA9VVXHyGk6xmI/qAefUQbwd2cWJo+ppqaWSaweXa9ymJc+V4l/un0K4oomVA==} | ||||
|  | ||||
|   '@bull-board/ui@5.23.0': | ||||
|     resolution: {integrity: sha512-iI/Ssl8T5ZEn9s899Qz67m92M6RU8thf/aqD7cUHB2yHmkCjqbw7s7NaODTsyArAsnyu7DGJMWm7EhbfFXDNgQ==} | ||||
|   '@bull-board/ui@6.0.0': | ||||
|     resolution: {integrity: sha512-wAFTlBTJbq5DSWxCzTV+FOyZDVwrXP+G1CQ2BpLG9o9+dpwYxUESx/VxNEDHnyPcy13gm29kB4fSRY+nkelkcQ==} | ||||
|  | ||||
|   '@bundled-es-modules/cookie@2.0.0': | ||||
|     resolution: {integrity: sha512-Or6YHg/kamKHpxULAdSqhGqnWFneIXu1NKvvfBBzKGwpVsYuFIQ5aBPHDnnoR3ghW1nvSkALd+EF9iMtY7Vjxw==} | ||||
| @@ -2707,10 +2707,6 @@ packages: | ||||
|     resolution: {integrity: sha512-vH9PiIMMwvhCx31Af3HiGzsVNULDbyVkHXwlemn/B0TFj/00ho3y55efXrUZTfQipxoHC5u4xq6zblww1zm1Ig==} | ||||
|     engines: {node: ^18.18.0 || ^20.9.0 || >=21.1.0} | ||||
|  | ||||
|   '@fastify/accept-negotiator@1.0.0': | ||||
|     resolution: {integrity: sha512-4R/N2KfYeld7A5LGkai+iUFMahXcxxYbDp+XS2B1yuL3cdmZLJ9TlCnNzT3q5xFTqsYm0GPpinLUwfSwjcVjyA==} | ||||
|     engines: {node: '>=14'} | ||||
|  | ||||
|   '@fastify/accept-negotiator@2.0.0': | ||||
|     resolution: {integrity: sha512-/Sce/kBzuTxIq5tJh85nVNOq9wKD8s+viIgX0fFMDBdw95gnpf53qmF1oBgJym3cPFliWUuSloVg/1w/rH0FcQ==} | ||||
|  | ||||
| @@ -2757,23 +2753,20 @@ packages: | ||||
|   '@fastify/reply-from@11.0.0': | ||||
|     resolution: {integrity: sha512-dv3o8hyy4sxhg1RN9l6ueM+PMMaIPKLjtL2T99H5M7h1Xt8d1RX3r+xC+sL5AqJqLvReX4N+7mTq9QDeB8i6Lg==} | ||||
|  | ||||
|   '@fastify/send@2.0.1': | ||||
|     resolution: {integrity: sha512-8jdouu0o5d0FMq1+zCKeKXc1tmOQ5tTGYdQP3MpyF9+WWrZT1KCBdh6hvoEYxOm3oJG/akdE9BpehLiJgYRvGw==} | ||||
|  | ||||
|   '@fastify/send@3.1.1': | ||||
|     resolution: {integrity: sha512-LdiV2mle/2tH8vh6GwGl0ubfUAgvY+9yF9oGI1iiwVyNUVOQamvw5n+OFu6iCNNoyuCY80FFURBn4TZCbTe8LA==} | ||||
|  | ||||
|   '@fastify/static@6.12.0': | ||||
|     resolution: {integrity: sha512-KK1B84E6QD/FcQWxDI2aiUCwHxMJBI1KeCUzm1BwYpPY1b742+jeKruGHP2uOluuM6OkBPI8CIANrXcCRtC2oQ==} | ||||
|  | ||||
|   '@fastify/static@8.0.0': | ||||
|     resolution: {integrity: sha512-VKGn1PQslB2VqzspyMKPu9xasF9vj+YuyGhVLb1ih6V60VVcRvcf0fFRcl3opt6c6YWwhKKdTUTfVE6COnpw6A==} | ||||
|  | ||||
|   '@fastify/static@8.0.1': | ||||
|     resolution: {integrity: sha512-7idyhbcgf14v4bjWzUeHEFvnVxvNJ1n5cyGPgFtwTZjnjUQ1wgC7a2FQai7OGKqCKywDEjzbPhAZRW+uEK1LMg==} | ||||
|  | ||||
|   '@fastify/view@10.0.0': | ||||
|     resolution: {integrity: sha512-2KnfgpSbAImKV5kKdNAkSyjV+9kYUYLvgDLx/wlzgqel92bN9Z520cwG3g3bAkr0yVnEJu62dIm2qAL9FASS1w==} | ||||
|  | ||||
|   '@fastify/view@8.2.0': | ||||
|     resolution: {integrity: sha512-hBSiBofCnJNlPHEMZWpO1SL84eqOaqujJ1hR3jntFyZZCkweH5jMs12DKYyGesjVll7SJFRRxPUBB8kmUmneRQ==} | ||||
|   '@fastify/view@10.0.1': | ||||
|     resolution: {integrity: sha512-rXtBN0oVDmoRZAS7lelrCIahf+qFtlMOOas8VPdA7JvrJ9ChcF7e36pIUPU0Vbs3KmHxESUb7XatavUZEe/k5Q==} | ||||
|  | ||||
|   '@github/webauthn-json@2.1.1': | ||||
|     resolution: {integrity: sha512-XrftRn4z75SnaJOmZQbt7Mk+IIjqVHw+glDGOxuHwXkZBZh/MBoRS7MHjSZMDaLhT4RjN2VqiEU7EOYleuJWSQ==} | ||||
| @@ -3078,10 +3071,6 @@ packages: | ||||
|     resolution: {integrity: sha512-uSvJdwQU5nK+Vdf6zxcWAY2A8r7uqe+gePwLWzJ+fsQehq18pc0I2hJKwypZ2aLM90+Er9u1xn4iLJPZ+xlL4g==} | ||||
|     engines: {node: '>=8'} | ||||
|  | ||||
|   '@lukeed/ms@2.0.1': | ||||
|     resolution: {integrity: sha512-Xs/4RZltsAL7pkvaNStUQt7netTkyxrS0K+RILcVr3TRMS/ToOg4I6uNfhB9SlGsnWBym4U+EaXq0f0cEMNkHA==} | ||||
|     engines: {node: '>=8'} | ||||
|  | ||||
|   '@lukeed/ms@2.0.2': | ||||
|     resolution: {integrity: sha512-9I2Zn6+NJLfaGoz9jN3lpwDgAYvfGeNYdbAIjJOqzs4Tpc+VU3Jqq4IofSUBKajiDS8k9fZIg18/z13mpk1bsA==} | ||||
|     engines: {node: '>=8'} | ||||
| @@ -6909,9 +6898,6 @@ packages: | ||||
|     resolution: {integrity: sha512-/PlTQCI96+fZMAOLMZK4CWG1ItCbfZ/0jx7UIJFChPNrx7tcEgerUgWbeieCM9MfHInUDyK8DWYZ+YrywDJuTg==} | ||||
|     hasBin: true | ||||
|  | ||||
|   fastify-plugin@4.5.0: | ||||
|     resolution: {integrity: sha512-79ak0JxddO0utAXAQ5ccKhvs6vX2MGyHHMMsmZkBANrq3hXc1CHzvNPHOcvTsVMEPl5I+NT+RO4YKMGehOfSIg==} | ||||
|  | ||||
|   fastify-plugin@4.5.1: | ||||
|     resolution: {integrity: sha512-stRHYGeuqpEZTL1Ef0Ovr2ltazUT9g844X5z/zEBFLG8RYlpDiOCIG+ATvYEp+/zmc7sN29mcIMp8gvYplYPIQ==} | ||||
|  | ||||
| @@ -7372,9 +7358,6 @@ packages: | ||||
|   hash-sum@2.0.0: | ||||
|     resolution: {integrity: sha512-WdZTbAByD+pHfl/g9QSsBIIwy8IT+EsPiKDs0KNX+zSHhdDLFKdZu0BQHljvO+0QI/BasbMSUa8wYNCZTvhslg==} | ||||
|  | ||||
|   hashlru@2.3.0: | ||||
|     resolution: {integrity: sha512-0cMsjjIC8I+D3M44pOQdsy0OHXGLVz6Z0beRuufhKa0KfaD2wGwAev6jILzXsd3/vpnNQJmWyZtIILqM1N+n5A==} | ||||
|  | ||||
|   hasown@2.0.0: | ||||
|     resolution: {integrity: sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==} | ||||
|     engines: {node: '>= 0.4'} | ||||
| @@ -12240,7 +12223,7 @@ snapshots: | ||||
|       '@babel/traverse': 7.23.5 | ||||
|       '@babel/types': 7.24.7 | ||||
|       convert-source-map: 2.0.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       gensync: 1.0.0-beta.2 | ||||
|       json5: 2.2.3 | ||||
|       semver: 6.3.1 | ||||
| @@ -12260,7 +12243,7 @@ snapshots: | ||||
|       '@babel/traverse': 7.24.7 | ||||
|       '@babel/types': 7.24.7 | ||||
|       convert-source-map: 2.0.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       gensync: 1.0.0-beta.2 | ||||
|       json5: 2.2.3 | ||||
|       semver: 6.3.1 | ||||
| @@ -12519,7 +12502,7 @@ snapshots: | ||||
|       '@babel/helper-split-export-declaration': 7.22.6 | ||||
|       '@babel/parser': 7.24.7 | ||||
|       '@babel/types': 7.24.7 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       globals: 11.12.0 | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| @@ -12534,7 +12517,7 @@ snapshots: | ||||
|       '@babel/helper-split-export-declaration': 7.24.7 | ||||
|       '@babel/parser': 7.24.7 | ||||
|       '@babel/types': 7.24.7 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       globals: 11.12.0 | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| @@ -12555,22 +12538,22 @@ snapshots: | ||||
|  | ||||
|   '@bcoe/v8-coverage@0.2.3': {} | ||||
|  | ||||
|   '@bull-board/api@5.23.0(@bull-board/ui@5.23.0)': | ||||
|   '@bull-board/api@6.0.0(@bull-board/ui@6.0.0)': | ||||
|     dependencies: | ||||
|       '@bull-board/ui': 5.23.0 | ||||
|       '@bull-board/ui': 6.0.0 | ||||
|       redis-info: 3.1.0 | ||||
|  | ||||
|   '@bull-board/fastify@5.23.0': | ||||
|   '@bull-board/fastify@6.0.0': | ||||
|     dependencies: | ||||
|       '@bull-board/api': 5.23.0(@bull-board/ui@5.23.0) | ||||
|       '@bull-board/ui': 5.23.0 | ||||
|       '@fastify/static': 6.12.0 | ||||
|       '@fastify/view': 8.2.0 | ||||
|       '@bull-board/api': 6.0.0(@bull-board/ui@6.0.0) | ||||
|       '@bull-board/ui': 6.0.0 | ||||
|       '@fastify/static': 8.0.1 | ||||
|       '@fastify/view': 10.0.1 | ||||
|       ejs: 3.1.10 | ||||
|  | ||||
|   '@bull-board/ui@5.23.0': | ||||
|   '@bull-board/ui@6.0.0': | ||||
|     dependencies: | ||||
|       '@bull-board/api': 5.23.0(@bull-board/ui@5.23.0) | ||||
|       '@bull-board/api': 6.0.0(@bull-board/ui@6.0.0) | ||||
|  | ||||
|   '@bundled-es-modules/cookie@2.0.0': | ||||
|     dependencies: | ||||
| @@ -13108,8 +13091,6 @@ snapshots: | ||||
|     dependencies: | ||||
|       levn: 0.4.1 | ||||
|  | ||||
|   '@fastify/accept-negotiator@1.0.0': {} | ||||
|  | ||||
|   '@fastify/accept-negotiator@2.0.0': {} | ||||
|  | ||||
|   '@fastify/accepts@5.0.0': | ||||
| @@ -13184,14 +13165,6 @@ snapshots: | ||||
|       toad-cache: 3.7.0 | ||||
|       undici: 6.19.8 | ||||
|  | ||||
|   '@fastify/send@2.0.1': | ||||
|     dependencies: | ||||
|       '@lukeed/ms': 2.0.1 | ||||
|       escape-html: 1.0.3 | ||||
|       fast-decode-uri-component: 1.0.1 | ||||
|       http-errors: 2.0.0 | ||||
|       mime: 3.0.0 | ||||
|  | ||||
|   '@fastify/send@3.1.1': | ||||
|     dependencies: | ||||
|       '@lukeed/ms': 2.0.2 | ||||
| @@ -13200,15 +13173,6 @@ snapshots: | ||||
|       http-errors: 2.0.0 | ||||
|       mime: 3.0.0 | ||||
|  | ||||
|   '@fastify/static@6.12.0': | ||||
|     dependencies: | ||||
|       '@fastify/accept-negotiator': 1.0.0 | ||||
|       '@fastify/send': 2.0.1 | ||||
|       content-disposition: 0.5.4 | ||||
|       fastify-plugin: 4.5.0 | ||||
|       glob: 8.1.0 | ||||
|       p-limit: 3.1.0 | ||||
|  | ||||
|   '@fastify/static@8.0.0': | ||||
|     dependencies: | ||||
|       '@fastify/accept-negotiator': 2.0.0 | ||||
| @@ -13218,15 +13182,24 @@ snapshots: | ||||
|       fastq: 1.17.1 | ||||
|       glob: 11.0.0 | ||||
|  | ||||
|   '@fastify/static@8.0.1': | ||||
|     dependencies: | ||||
|       '@fastify/accept-negotiator': 2.0.0 | ||||
|       '@fastify/send': 3.1.1 | ||||
|       content-disposition: 0.5.4 | ||||
|       fastify-plugin: 5.0.0 | ||||
|       fastq: 1.17.1 | ||||
|       glob: 11.0.0 | ||||
|  | ||||
|   '@fastify/view@10.0.0': | ||||
|     dependencies: | ||||
|       fastify-plugin: 5.0.0 | ||||
|       toad-cache: 3.7.0 | ||||
|  | ||||
|   '@fastify/view@8.2.0': | ||||
|   '@fastify/view@10.0.1': | ||||
|     dependencies: | ||||
|       fastify-plugin: 4.5.0 | ||||
|       hashlru: 2.3.0 | ||||
|       fastify-plugin: 5.0.0 | ||||
|       toad-cache: 3.7.0 | ||||
|  | ||||
|   '@github/webauthn-json@2.1.1': {} | ||||
|  | ||||
| @@ -13602,8 +13575,6 @@ snapshots: | ||||
|  | ||||
|   '@lukeed/csprng@1.0.1': {} | ||||
|  | ||||
|   '@lukeed/ms@2.0.1': {} | ||||
|  | ||||
|   '@lukeed/ms@2.0.2': {} | ||||
|  | ||||
|   '@mapbox/node-pre-gyp@1.0.9(encoding@0.1.13)': | ||||
| @@ -15924,7 +15895,7 @@ snapshots: | ||||
|       '@typescript-eslint/types': 7.17.0 | ||||
|       '@typescript-eslint/typescript-estree': 7.17.0(typescript@5.5.4) | ||||
|       '@typescript-eslint/visitor-keys': 7.17.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.11.0 | ||||
|     optionalDependencies: | ||||
|       typescript: 5.5.4 | ||||
| @@ -15937,7 +15908,7 @@ snapshots: | ||||
|       '@typescript-eslint/types': 7.17.0 | ||||
|       '@typescript-eslint/typescript-estree': 7.17.0(typescript@5.6.2) | ||||
|       '@typescript-eslint/visitor-keys': 7.17.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.11.0 | ||||
|     optionalDependencies: | ||||
|       typescript: 5.6.2 | ||||
| @@ -15950,7 +15921,7 @@ snapshots: | ||||
|       '@typescript-eslint/types': 7.17.0 | ||||
|       '@typescript-eslint/typescript-estree': 7.17.0(typescript@5.6.2) | ||||
|       '@typescript-eslint/visitor-keys': 7.17.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.8.0 | ||||
|     optionalDependencies: | ||||
|       typescript: 5.6.2 | ||||
| @@ -15971,7 +15942,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/typescript-estree': 7.1.0(typescript@5.3.3) | ||||
|       '@typescript-eslint/utils': 7.1.0(eslint@9.11.0)(typescript@5.3.3) | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.11.0 | ||||
|       ts-api-utils: 1.0.1(typescript@5.3.3) | ||||
|     optionalDependencies: | ||||
| @@ -15983,7 +15954,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/typescript-estree': 7.17.0(typescript@5.5.4) | ||||
|       '@typescript-eslint/utils': 7.17.0(eslint@9.11.0)(typescript@5.5.4) | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.11.0 | ||||
|       ts-api-utils: 1.3.0(typescript@5.5.4) | ||||
|     optionalDependencies: | ||||
| @@ -15995,7 +15966,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/typescript-estree': 7.17.0(typescript@5.6.2) | ||||
|       '@typescript-eslint/utils': 7.17.0(eslint@9.11.0)(typescript@5.6.2) | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.11.0 | ||||
|       ts-api-utils: 1.3.0(typescript@5.6.2) | ||||
|     optionalDependencies: | ||||
| @@ -16007,7 +15978,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/typescript-estree': 7.17.0(typescript@5.6.2) | ||||
|       '@typescript-eslint/utils': 7.17.0(eslint@9.8.0)(typescript@5.6.2) | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.8.0 | ||||
|       ts-api-utils: 1.3.0(typescript@5.6.2) | ||||
|     optionalDependencies: | ||||
| @@ -16023,7 +15994,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/types': 7.1.0 | ||||
|       '@typescript-eslint/visitor-keys': 7.1.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       globby: 11.1.0 | ||||
|       is-glob: 4.0.3 | ||||
|       minimatch: 9.0.3 | ||||
| @@ -16038,7 +16009,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/types': 7.17.0 | ||||
|       '@typescript-eslint/visitor-keys': 7.17.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       globby: 11.1.0 | ||||
|       is-glob: 4.0.3 | ||||
|       minimatch: 9.0.4 | ||||
| @@ -16053,7 +16024,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@typescript-eslint/types': 7.17.0 | ||||
|       '@typescript-eslint/visitor-keys': 7.17.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       globby: 11.1.0 | ||||
|       is-glob: 4.0.3 | ||||
|       minimatch: 9.0.4 | ||||
| @@ -16132,7 +16103,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@ampproject/remapping': 2.2.1 | ||||
|       '@bcoe/v8-coverage': 0.2.3 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       istanbul-lib-coverage: 3.2.2 | ||||
|       istanbul-lib-report: 3.0.1 | ||||
|       istanbul-lib-source-maps: 5.0.4 | ||||
| @@ -16151,7 +16122,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@ampproject/remapping': 2.2.1 | ||||
|       '@bcoe/v8-coverage': 0.2.3 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       istanbul-lib-coverage: 3.2.2 | ||||
|       istanbul-lib-report: 3.0.1 | ||||
|       istanbul-lib-source-maps: 5.0.4 | ||||
| @@ -16465,14 +16436,14 @@ snapshots: | ||||
|  | ||||
|   agent-base@6.0.2: | ||||
|     dependencies: | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|     optional: true | ||||
|  | ||||
|   agent-base@7.1.0: | ||||
|     dependencies: | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|  | ||||
| @@ -18800,8 +18771,6 @@ snapshots: | ||||
|     dependencies: | ||||
|       strnum: 1.0.5 | ||||
|  | ||||
|   fastify-plugin@4.5.0: {} | ||||
|  | ||||
|   fastify-plugin@4.5.1: {} | ||||
|  | ||||
|   fastify-plugin@5.0.0: {} | ||||
| @@ -19361,8 +19330,6 @@ snapshots: | ||||
|  | ||||
|   hash-sum@2.0.0: {} | ||||
|  | ||||
|   hashlru@2.3.0: {} | ||||
|  | ||||
|   hasown@2.0.0: | ||||
|     dependencies: | ||||
|       function-bind: 1.1.2 | ||||
| @@ -19447,7 +19414,7 @@ snapshots: | ||||
|   http-proxy-agent@7.0.2: | ||||
|     dependencies: | ||||
|       agent-base: 7.1.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|  | ||||
| @@ -19486,7 +19453,7 @@ snapshots: | ||||
|   https-proxy-agent@5.0.1: | ||||
|     dependencies: | ||||
|       agent-base: 6.0.2 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|     optional: true | ||||
| @@ -19494,14 +19461,14 @@ snapshots: | ||||
|   https-proxy-agent@7.0.2: | ||||
|     dependencies: | ||||
|       agent-base: 7.1.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|  | ||||
|   https-proxy-agent@7.0.5: | ||||
|     dependencies: | ||||
|       agent-base: 7.1.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
|  | ||||
| @@ -19865,7 +19832,7 @@ snapshots: | ||||
|  | ||||
|   istanbul-lib-source-maps@4.0.1: | ||||
|     dependencies: | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       istanbul-lib-coverage: 3.2.2 | ||||
|       source-map: 0.6.1 | ||||
|     transitivePeerDependencies: | ||||
| @@ -19874,7 +19841,7 @@ snapshots: | ||||
|   istanbul-lib-source-maps@5.0.4: | ||||
|     dependencies: | ||||
|       '@jridgewell/trace-mapping': 0.3.25 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       istanbul-lib-coverage: 3.2.2 | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| @@ -20296,7 +20263,7 @@ snapshots: | ||||
|       whatwg-encoding: 3.1.1 | ||||
|       whatwg-mimetype: 4.0.0 | ||||
|       whatwg-url: 14.0.0 | ||||
|       ws: 8.18.0(bufferutil@4.0.7)(utf-8-validate@6.0.3) | ||||
|       ws: 8.18.0(bufferutil@4.0.8)(utf-8-validate@6.0.4) | ||||
|       xml-name-validator: 5.0.0 | ||||
|     transitivePeerDependencies: | ||||
|       - bufferutil | ||||
| @@ -22889,7 +22856,7 @@ snapshots: | ||||
|     dependencies: | ||||
|       '@hapi/hoek': 11.0.4 | ||||
|       '@hapi/wreck': 18.0.1 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       joi: 17.11.0 | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| @@ -22989,7 +22956,7 @@ snapshots: | ||||
|   socks-proxy-agent@8.0.2: | ||||
|     dependencies: | ||||
|       agent-base: 7.1.0 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       socks: 2.7.1 | ||||
|     transitivePeerDependencies: | ||||
|       - supports-color | ||||
| @@ -23838,7 +23805,7 @@ snapshots: | ||||
|   vite-node@1.6.0(@types/node@20.14.12)(sass@1.79.3)(terser@5.33.0): | ||||
|     dependencies: | ||||
|       cac: 6.7.14 | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       pathe: 1.1.2 | ||||
|       picocolors: 1.0.1 | ||||
|       vite: 5.4.8(@types/node@20.14.12)(sass@1.79.3)(terser@5.33.0) | ||||
| @@ -24006,7 +23973,7 @@ snapshots: | ||||
|  | ||||
|   vue-eslint-parser@9.4.3(eslint@9.11.0): | ||||
|     dependencies: | ||||
|       debug: 4.3.5(supports-color@5.5.0) | ||||
|       debug: 4.3.5(supports-color@8.1.1) | ||||
|       eslint: 9.11.0 | ||||
|       eslint-scope: 7.2.2 | ||||
|       eslint-visitor-keys: 3.4.3 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user