From 969a34b4c39fc6eba227e24e37f57eba547fe9ae Mon Sep 17 00:00:00 2001 From: HidemaruOwO Date: Tue, 28 Jan 2025 18:51:00 +0900 Subject: [PATCH] =?UTF-8?q?=F0=9F=8E=89=20First=20Commit=20(.config/cypres?= =?UTF-8?q?s-devcontainer.yml,=20.config/docker=5Fe...)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .config/cypress-devcontainer.yml | 242 + .config/docker_example.env | 11 + .config/docker_example.yml | 319 + .config/example.yml | 355 + .config/test-example.yml | 17 + .devcontainer/Dockerfile | 1 + .devcontainer/compose.yml | 53 + .devcontainer/devcontainer.json | 26 + .devcontainer/devcontainer.yml | 211 + .devcontainer/init.sh | 17 + .dockerignore | 30 + .dockleignore | 3 + .editorconfig | 15 + .gitattributes | 8 + .gitignore | 89 + .gitlab-ci.yml | 114 + .gitlab/issue_templates/bug.md | 35 + .gitlab/issue_templates/feature.md | 21 + .gitlab/merge_request_templates/default.md | 12 + .gitmodules | 6 + .node-version | 1 + .npmrc | 2 + .okteto/okteto-pipeline.yml | 6 + .vsls.json | 4 + CHANGELOG.md | 2824 ++ CODE_OF_CONDUCT.md | 132 + CONTRIBUTING.md | 726 + COPYING | 19 + Dockerfile | 86 + IMPORTANT_NOTES.md | 16 + LICENSE | 661 + Procfile | 1 + README.md | 53 + ROADMAP.md | 40 + SECURITY.md | 16 + UPGRADE_NOTES.md | 74 + assets/about/drive.png | Bin 0 -> 96460 bytes assets/about/post.png | Bin 0 -> 324167 bytes assets/about/reaction.png | Bin 0 -> 24621 bytes assets/about/ui.png | Bin 0 -> 97127 bytes assets/ai-orig.png | Bin 0 -> 204466 bytes assets/ai.png | Bin 0 -> 240564 bytes assets/backend.png | Bin 0 -> 41726 bytes assets/banner.afdesign | Bin 0 -> 73201 bytes assets/mi-white.afdesign | Bin 0 -> 29485 bytes assets/mi.afdesign | Bin 0 -> 31543 bytes assets/ss/explore.jpg | Bin 0 -> 243786 bytes assets/ss/user.jpg | Bin 0 -> 151706 bytes assets/title.png | Bin 0 -> 3888 bytes assets/title_float.svg | 67 + chart/Chart.yaml | 4 + chart/files/default.yml | 234 + chart/templates/ConfigMap.yml | 8 + chart/templates/Deployment.yml | 47 + chart/templates/Service.yml | 14 + chart/templates/_helpers.tpl | 62 + chart/values.yml | 3 + codecov.yml | 4 + compose.local-db.yml | 40 + compose_example.yml | 97 + crowdin.yml | 4 + cypress.config.ts | 12 + cypress/e2e/basic.cy.ts | 255 + cypress/e2e/router.cy.ts | 35 + cypress/e2e/widgets.cy.ts | 76 + cypress/fixtures/example.json | 5 + cypress/plugins/index.js | 22 + cypress/support/commands.ts | 67 + cypress/support/e2e.ts | 34 + cypress/support/index.ts | 19 + cypress/tsconfig.json | 8 + eslint/locale.js | 251 + eslint/locale.test.js | 54 + healthcheck.sh | 7 + idea/MkAbuseReport.stories.impl.ts | 54 + idea/MkDisableSection.vue | 41 + idea/README.md | 1 + locales/README.md | 6 + locales/ar-SA.yml | 1586 + locales/bn-BD.yml | 1350 + locales/ca-ES.yml | 2746 ++ locales/cs-CZ.yml | 2026 + locales/da-DK.yml | 4 + locales/de-DE.yml | 2478 ++ locales/el-GR.yml | 399 + locales/en-US.yml | 2746 ++ locales/es-ES.yml | 2537 ++ locales/fr-FR.yml | 2366 ++ locales/generateDTS.js | 237 + locales/hr-HR.yml | 5 + locales/ht-HT.yml | 18 + locales/hu-HU.yml | 105 + locales/id-ID.yml | 2612 ++ locales/index.d.ts | 11618 ++++++ locales/index.js | 99 + locales/it-IT.yml | 2738 ++ locales/ja-JP.yml | 2828 ++ locales/ja-KS.yml | 2711 ++ locales/jbo-EN.yml | 3 + locales/kab-KAB.yml | 110 + locales/kn-IN.yml | 88 + locales/ko-GS.yml | 842 + locales/ko-KR.yml | 2746 ++ locales/lo-LA.yml | 476 + locales/nl-NL.yml | 503 + locales/no-NO.yml | 729 + locales/package.json | 3 + locales/pl-PL.yml | 1585 + locales/pt-PT.yml | 2638 ++ locales/ro-RO.yml | 735 + locales/ru-RU.yml | 2145 ++ locales/si-LK.yml | 22 + locales/sk-SK.yml | 1451 + locales/sv-SE.yml | 709 + locales/th-TH.yml | 2711 ++ locales/tr-TR.yml | 461 + locales/ug-CN.yml | 22 + locales/uk-UA.yml | 1626 + locales/uz-UZ.yml | 1096 + locales/verify.js | 59 + locales/version.d.ts | 1 + locales/version.js | 14 + locales/vi-VN.yml | 1932 + locales/zh-CN.yml | 2746 ++ locales/zh-TW.yml | 2746 ++ package.json | 83 + packages/backend/.madgerc | 3 + packages/backend/.swcrc | 24 + packages/backend/.vscode/settings.json | 10 + packages/backend/README.md | 2 + packages/backend/assets/api-doc.html | 20 + packages/backend/assets/api-doc.png | Bin 0 -> 5542 bytes packages/backend/assets/apple-touch-icon.png | Bin 0 -> 60657 bytes packages/backend/assets/avatar.png | Bin 0 -> 13477 bytes packages/backend/assets/embed.js | 31 + packages/backend/assets/emoji-unknown.png | Bin 0 -> 3518 bytes packages/backend/assets/favicon.ico | Bin 0 -> 15406 bytes packages/backend/assets/favicon.png | Bin 0 -> 67892 bytes .../assets/fonts/Lexend-VariableFont_wght.ttf | Bin 0 -> 176220 bytes .../assets/fonts/sharkey-icons/shark-font.svg | 30 + .../assets/fonts/sharkey-icons/shark-font.ttf | Bin 0 -> 2652 bytes .../fonts/sharkey-icons/shark-font.woff | Bin 0 -> 1736 bytes .../assets/fonts/sharkey-icons/style.css | 114 + packages/backend/assets/icons/192.png | Bin 0 -> 67892 bytes packages/backend/assets/icons/512.png | Bin 0 -> 321457 bytes packages/backend/assets/mi-white.png | Bin 0 -> 18767 bytes packages/backend/assets/robots.txt | 4 + packages/backend/assets/splash.png | Bin 0 -> 321457 bytes packages/backend/assets/tabler-badges/LICENSE | 24 + .../backend/assets/tabler-badges/antenna.png | Bin 0 -> 516 bytes .../assets/tabler-badges/arrow-back-up.png | Bin 0 -> 952 bytes packages/backend/assets/tabler-badges/at.png | Bin 0 -> 2909 bytes .../backend/assets/tabler-badges/bell.png | Bin 0 -> 1774 bytes .../assets/tabler-badges/chart-arrows.png | Bin 0 -> 829 bytes .../assets/tabler-badges/circle-check.png | Bin 0 -> 2307 bytes .../backend/assets/tabler-badges/login-2.png | Bin 0 -> 3770 bytes .../backend/assets/tabler-badges/medal.png | Bin 0 -> 1241 bytes .../backend/assets/tabler-badges/messages.png | Bin 0 -> 1056 bytes .../backend/assets/tabler-badges/null.png | Bin 0 -> 174 bytes .../backend/assets/tabler-badges/plus.png | Bin 0 -> 414 bytes .../backend/assets/tabler-badges/quote.png | Bin 0 -> 1011 bytes .../backend/assets/tabler-badges/repeat.png | Bin 0 -> 1206 bytes .../assets/tabler-badges/user-plus.png | Bin 0 -> 1431 bytes .../backend/assets/tabler-badges/users.png | Bin 0 -> 1911 bytes packages/backend/assets/transparent.png | Bin 0 -> 68 bytes packages/backend/assets/user-unknown.png | Bin 0 -> 3518 bytes packages/backend/eslint.config.js | 75 + packages/backend/jest.config.cjs | 220 + packages/backend/jest.config.e2e.cjs | 15 + packages/backend/jest.config.fed.cjs | 13 + packages/backend/jest.config.unit.cjs | 14 + packages/backend/jsconfig.json | 13 + .../backend/migration/1000000000000-Init.js | 485 + .../backend/migration/1556348509290-Pages.js | 31 + .../migration/1556746559567-UserProfile.js | 16 + .../migration/1557476068003-PinnedUsers.js | 13 + .../migration/1557761316509-AddSomeUrls.js | 17 + .../1557932705754-ObjectStorageSetting.js | 31 + .../migration/1558072954435-PageLike.js | 23 + .../migration/1558103093633-UserGroup.js | 41 + .../1558257926829-UserGroupInvite.js | 25 + .../1558266512381-UserListJoining.js | 13 + .../migration/1561706992953-webauthn.js | 29 + .../migration/1561873850023-ChartIndexes.js | 201 + .../1562422242907-PasswordLessLogin.js | 13 + .../migration/1562444565093-PinnedPage.js | 17 + .../1562448332510-PageTitleHideOption.js | 13 + .../migration/1562869971568-ModerationLog.js | 17 + .../migration/1563757595828-UsedUsername.js | 13 + .../backend/migration/1565634203341-room.js | 13 + .../1571220798684-CustomEmojiCategory.js | 13 + .../migration/1572760203493-nodeinfo.js | 29 + .../1576269851876-TalkFederationId.js | 16 + .../1576869585998-ProxyRemoteFiles.js | 16 + .../backend/migration/1579267006611-v12.js | 36 + .../backend/migration/1579270193251-v12-2.js | 16 + .../backend/migration/1579282808087-v12-3.js | 16 + .../backend/migration/1579544426412-v12-4.js | 18 + .../backend/migration/1579977526288-v12-5.js | 56 + .../backend/migration/1579993013959-v12-6.js | 20 + .../backend/migration/1580069531114-v12-7.js | 26 + .../backend/migration/1580148575182-v12-8.js | 18 + .../backend/migration/1580154400017-v12-9.js | 16 + .../backend/migration/1580276619901-v12-10.js | 21 + .../backend/migration/1580331224276-v12-11.js | 20 + .../backend/migration/1580508795118-v12-12.js | 48 + .../backend/migration/1580543501339-v12-13.js | 16 + .../backend/migration/1580864313253-v12-14.js | 22 + .../1581526429287-user-group-invitation.js | 40 + .../1581695816408-user-group-antenna.js | 30 + ...581708415836-drive-user-folder-id-index.js | 16 + .../backend/migration/1581979837262-promo.js | 30 + .../1582019042083-featured-injecttion.js | 16 + .../1582210532752-antenna-exclude.js | 16 + .../1582875306439-note-reaction-length.js | 16 + .../backend/migration/1585361548360-miauth.js | 38 + .../1585385921215-custom-notification.js | 50 + .../backend/migration/1585772678853-ap-url.js | 16 + .../1586624197029-AddObjectStorageUseProxy.js | 16 + .../1586641139527-remote-reaction.js | 16 + .../migration/1586708940386-pageAiScript.js | 16 + .../migration/1588044505511-hCaptcha.js | 20 + .../migration/1589023282116-pubRelay.js | 20 + .../migration/1595075960584-blurhash.js | 16 + ...595077605646-blurhash-for-avatar-banner.js | 22 + .../1595676934834-instance-icon-url.js | 16 + .../migration/1595771249699-word-mute.js | 32 + .../migration/1595782306083-word-mute2.js | 20 + .../migration/1596548170836-channel.js | 60 + .../migration/1596786425167-channel2.js | 16 + ...597230137744-objectStorageSetPublicRead.js | 16 + ...597236229720-IncludingNotificationTypes.js | 18 + .../1597385880794-add-sensitive-index.js | 16 + .../migration/1597459042300-channel-unread.js | 29 + .../1597893996136-ChannelNoteIdDescIndex.js | 18 + .../1600353287890-mutingNotificationTypes.js | 22 + .../1603094348345-refine-abuse-user-report.js | 34 + ...1603095701770-refine-abuse-user-report2.js | 22 + .../1603776877564-instance-theme-color.js | 16 + .../1603781553011-instance-favicon.js | 16 + .../1604821689616-delete-auto-watch.js | 16 + .../1605408848373-clip-description.js | 16 + .../migration/1605408971051-comments.js | 436 + .../1605585339718-instance-pinned-pages.js | 16 + .../1605965516823-instance-images.js | 18 + .../migration/1606191203881-no-crawle.js | 18 + .../1607151207216-instance-pinned-clip.js | 16 + .../migration/1607353487793-isExplorable.js | 20 + .../migration/1610277136869-registry.js | 24 + .../migration/1610277585759-registry2.js | 18 + .../migration/1610283021566-registry3.js | 16 + .../migration/1611354329133-followersUri.js | 18 + .../migration/1611397665007-gallery.js | 42 + ...547387175-objectStorageS3ForcePathStyle.js | 16 + .../1612619156584-announcement-email.js | 16 + .../1613155914446-emailNotificationTypes.js | 16 + .../migration/1613181457597-user-lang.js | 16 + ...1613503367223-use-bigint-for-driveUsage.js | 17 + .../migration/1615965918224-chart-v2.js | 219 + .../migration/1615966519402-chart-v2-2.js | 24 + .../1618637372000-user-last-active-date.js | 18 + .../1618639857000-user-hide-online-status.js | 16 + .../migration/1619942102890-password-reset.js | 22 + .../backend/migration/1620019354680-ad.js | 20 + .../backend/migration/1620364649428-ad2.js | 16 + .../1621479946000-add-note-indexes.js | 18 + ...9304522-user-profile-description-length.js | 16 + .../1622681548499-log-message-length.js | 16 + .../1626509500668-fix-remote-file-proxy.js | 25 + .../migration/1629004542760-chart-reindex.js | 184 + .../1629024377804-deepl-integration.js | 16 + .../1629288472000-fix-channel-userId.js | 16 + .../1629512953000-user-is-deleted.js | 17 + .../1629778475000-deepl-integration2.js | 16 + .../1629833361000-AddShowTLReplies.js | 17 + .../1629968054000_userInstanceBlocks.js | 17 + ...1633068642000-email-required-for-signup.js | 16 + .../migration/1633071909016-user-pending.js | 18 + .../1634486652000-user-public-reactions.js | 16 + .../migration/1634902659689-delete-log.js | 15 + .../1635500777168-note-thread-mute.js | 28 + .../migration/1636197624383-ff-visibility.js | 18 + .../1636697408073-remove-via-mobile.js | 16 + .../1637320813000-forwarded-report.js | 16 + .../migration/1639325650583-chart-v3.js | 192 + .../migration/1642611822809-emoji-url.js | 18 + ...1642613870898-drive-file-webpublic-type.js | 16 + .../migration/1643963705770-chart-v4.js | 66 + .../migration/1643966656277-chart-v5.js | 30 + .../migration/1643967331284-chart-v6.js | 346 + .../1644010796173-convert-hard-mutes.js | 69 + .../migration/1644058404077-chart-v7.js | 504 + .../migration/1644059847460-chart-v8.js | 28 + .../migration/1644060125705-chart-v9.js | 28 + .../migration/1644073149413-chart-v10.js | 38 + .../migration/1644095659741-chart-v11.js | 94 + .../migration/1644328606241-chart-v12.js | 30 + .../migration/1644331238153-chart-v13.js | 22 + .../migration/1644344266289-chart-v14.js | 50 + .../1644395759931-instance-theme-color.js | 16 + .../migration/1644481657998-chart-v15.js | 34 + .../1644551208096-following-indexes.js | 18 + ...45340161439-remove-max-note-text-length.js | 16 + .../1645599900873-federation-chart-pubsub.js | 18 + .../1646143552768-instance-default-theme.js | 18 + .../1646387162108-mute-expires-at.js | 18 + .../1646549089451-poll-ended-notification.js | 22 + .../1646633030285-chart-federation-active.js | 18 + ...655454495-remove-instance-drive-columns.js | 18 + ...2390560-chart-federation-active-sub-pub.js | 26 + .../migration/1648548247382-webhook.js | 24 + .../migration/1648816172177-webhook-2.js | 18 + .../migration/1651224615271-foreign-key.js | 94 + .../1652859567549-uniform-themecolor.js | 41 + .../migration/1655368940105-nsfw-detection.js | 28 + .../1655371960534-nsfw-detection-2.js | 20 + .../1655388169582-nsfw-detection-3.js | 26 + .../1655393015659-nsfw-detection-4.js | 30 + .../1655813815729-driveCapacityOverrideMb.js | 18 + .../migration/1655918165614-user-ip.js | 22 + .../migration/1656122560740-file-ip.js | 18 + .../1656251734807-nsfw-detection-5.js | 38 + .../backend/migration/1656328812281-ip-2.js | 18 + .../1656408772602-nsfw-detection-6.js | 16 + .../1656772790599-user-moderation-note.js | 16 + .../1657346559800-active-email-validation.js | 16 + .../migration/1664694635394-turnstile.js | 20 + .../1665091090561-add-renote-muting.js | 24 + ...6634-whetherPushNotifyToSendReadMessage.js | 16 + .../1671924750884-RetentionAggregation.js | 18 + .../1671926422832-RetentionAggregation2.js | 20 + .../migration/1672562400597-PerUserPvChart.js | 22 + ...672703171386-remove-latestRequestSentAt.js | 16 + ...1672704017999-remove-lastCommunicatedAt.js | 16 + .../1672704136584-remove-latestStatus.js | 16 + .../backend/migration/1672822262496-Flash.js | 34 + .../1673336077243-PollChoiceLength.js | 16 + .../backend/migration/1673500412259-Role.js | 42 + .../migration/1673515526953-RoleColor.js | 16 + .../migration/1673522856499-RoleIroiro.js | 18 + .../migration/1673524604156-RoleLastUsedAt.js | 18 + .../1673570377815-RoleConditional.js | 20 + .../migration/1673575973645-MetaClean.js | 16 + .../migration/1673783015567-Policies.js | 18 + .../1673812883772-firstRetrievedAt.js | 16 + .../1674086433654-flashScriptLength.js | 16 + .../migration/1674118260469-achievement.js | 38 + .../migration/1674255666603-loggedInDates.js | 16 + .../1675053125067-fixforeignkeyreports.js | 20 + .../migration/1675404035646-cleanup.js | 34 + .../1675557528704-role-icon-badge.js | 18 + .../migration/1676434944993-drop-group.js | 32 + .../backend/migration/1676438468213-ad3.js | 14 + .../backend/migration/1677054292210-ad4.js | 14 + ...677570181236-role-assignment-expires-at.js | 18 + ...8164627293-per-note-reaction-acceptance.js | 16 + .../1678426061773-tweak-varchar-length.js | 73 + .../migration/1678427401214-remove-unused.js | 18 + .../1678602320354-role-display-order.js | 16 + .../1678694614599-sensitive-words.js | 16 + .../1678869617549-retention-date-key.js | 19 + ...678945242650-add-props-for-custom-emoji.js | 16 + .../migration/1678953978856-clip-favorite.js | 28 + .../migration/1679309757174-antenna-active.js | 22 + ...1679639483253-enableChartsForRemoteUser.js | 16 + .../migration/1679651580149-cleanup.js | 16 + ...81809-enableChartsForFederatedInstances.js | 16 + .../1680228513388-channelFavorite.js | 26 + .../1680238118084-channelNotePining.js | 16 + .../migration/1680491187535-cleanup.js | 15 + .../migration/1680582195041-cleanup.js | 16 + .../migration/1680702787050-UserMemo.js | 23 + ...1680775031481-avatar-url-and-banner-url.js | 22 + .../migration/1680931179228-account-move.js | 22 + .../1680969937000-larger-image-comment.js | 17 + .../migration/1681400427971-serverRules.js | 16 + .../migration/1681870960239-RoleTLSetting.js | 17 + .../migration/1682190963894-movedAt.js | 18 + .../migration/1682753227899-NoteEdit.js | 58 + .../1682754135458-preservedUsernames.js | 16 + .../migration/1682985520254-channelColor.js | 16 + .../migration/1683328299359-channelArchive.js | 18 + .../1683682889948-prevent-ai-larning.js | 16 + ...683083083-public-reactions-default-true.js | 16 + .../migration/1683789676867-fix-typo.js | 16 + .../migration/1683847157541-UserList.js | 18 + .../1683869758873-UserListFavorites.js | 24 + ...684206886988-remove-showTimelineReplies.js | 16 + .../migration/1684386446061-emoji-improve.js | 20 + .../migration/1685973839966-errorImageUrl.js | 22 + .../1688280713783-add-meta-options.js | 18 + .../1688720440658-refactor-invite-system.js | 30 + .../1688880985544-add-index-to-relations.js | 18 + .../migration/1689102832143-nsfw-cache.js | 16 + .../1689325027964-UserBlacklistAnntena.js | 15 + .../1690417561185-fix-renote-muting.js | 17 + ...417561186-ChangeCacheRemoteFilesDefault.js | 16 + .../backend/migration/1690417561187-Fix.js | 86 + .../1690569881926-user-2fa-backup-codes.js | 16 + .../1690782653311-SensitiveChannel.js | 17 + .../1690796169261-play-visibility.js | 15 + .../migration/1691264431000-add-lb-to-user.js | 25 + .../1691649257651-refine-announcement.js | 32 + .../1691657412740-refine-announcement-2.js | 16 + .../1691959191872-passkey-support.js | 49 + ...1694850832075-server-icons-and-manifest.js | 20 + .../migration/1694915420864-clipped-count.js | 16 + .../migration/1695260774117-verified-links.js | 16 + .../1695288787870-following-notify.js | 18 + .../migration/1695440131671-short-name.js | 16 + .../1695605508898-mutingNotificationTypes.js | 26 + .../1695937489995-enableAchievements.js | 16 + ...1695944637565-notificationRecieveConfig.js | 18 + .../migration/1696003580220-AddSomeUrls.js | 17 + .../migration/1696222183852-withReplies.js | 20 + .../1696323464251-user-list-membership.js | 16 + .../migration/1696331570827-hibernation.js | 22 + .../backend/migration/1696332072038-clean.js | 23 + .../1696373953614-meta-cache-settings.js | 22 + .../migration/1696386694000-speakAsCat.js | 17 + .../migration/1696405744672-clean-up.js | 18 + .../migration/1696548899000-background.js | 24 + .../migration/1696569742153-clean-up.js | 18 + .../migration/1696581429196-clean-up.js | 15 + .../migration/1696743032098-AdsOnStream.js | 16 + .../migration/1696807733453-userListUserId.js | 21 + .../1696808725134-userListUserId-2.js | 16 + .../1697247230117-InstanceSilence.js | 16 + .../1697420555911-deleteCreatedAt.js | 144 + .../1697436246389-antenna-localOnly.js | 16 + .../1697441463087-FollowRequestWithReplies.js | 17 + .../migration/1697580470000-approvalSignup.js | 22 + .../migration/1697603945000-BotTrending.js | 16 + .../migration/1697624010000-isSilenced.js | 16 + ...673894459-note-reactionAndUserPairCache.js | 17 + .../1697847397844-avatar-decoration.js | 18 + .../1697941908548-avatar-decoration2.js | 18 + .../migration/1697970083000-alterNoteEdit.js | 18 + .../1697970083001-oldDateNoteEdit.js | 16 + .../migration/1698041201306-enable-ftt.js | 16 + ...8840138000-add-allow-renote-to-external.js | 16 + .../1699141698112-announcement-silence.js | 18 + .../migration/1699376974000-isIndexable.js | 16 + .../migration/1699437894737-scheduleNote.js | 17 + .../migration/1699819257000-defaultLike.js | 16 + ...96812223-enableFanoutTimelineDbFallback.js | 16 + .../1700228972000-update-indexable.js | 20 + .../1700303245007-supportVerifyMailApi.js | 18 + .../migration/1700383825690-hard-mute.js | 16 + .../migration/1700902349231-add-bday-index.js | 16 + .../1701647674000-BubbleInstances.js | 16 + .../migration/1701809447000-NSFW-Instance.js | 16 + .../migration/1702718871541-ffVisibility.js | 37 + .../1703209889304-bannedEmailDomains.js | 18 + .../1703658526000-supportTrueMailApi.js | 20 + .../1704373210054-support-mcaptcha.js | 22 + .../1704744370000-add-donation-url.js | 15 + .../1704959805077-bubble-game-record.js | 24 + ...58-optimize-note-index-for-array-column.js | 24 + .../migration/1705475608437-reversi.js | 22 + .../migration/1705654039457-reversi-2.js | 18 + .../migration/1705793785675-reversi-3.js | 18 + .../migration/1705794768153-reversi-4.js | 18 + .../migration/1705798904141-reversi-5.js | 16 + .../migration/1706081514499-reversi-6.js | 16 + .../backend/migration/1706232992000-deeplx.js | 18 + ...6791962000-fix-meta-disableRegistration.js | 16 + .../1707429690000-prohibited-words.js | 16 + ...1707808106310-MakeRepositoryUrlNullable.js | 16 + ...epositoryUrl-from-syuilo-to-misskey-dev.js | 16 + .../1708342829000-SharkeyRepositoryUrl.js | 22 + .../1708399372194-per-instance-mod-note.js | 16 + .../migration/1709462550083-MoreRepoUrl.js | 16 + .../1710512074000-url-preview-meta.js | 42 + .../1710919614510-antenna-exclude-bots.js | 16 + .../1711008460816-external-website-warn.js | 16 + ...1713656541000-abuse-report-notification.js | 62 + ...29964060-ChannelIdDenormalizedForMiPoll.js | 21 + .../1716197366117-MediaSilenceForHosts.js | 16 + .../1716345015347-NotRespondingSince.js | 16 + ...8870-SuspensionStateInsteadOfIsSspended.js | 50 + .../1716450883149-RemoveAntennaNotify.js | 16 + .../migration/1717117195275-inquiryUrl.js | 16 + .../migration/1721666053703-fixDriveUrl.js | 24 + .../1723944246767-followedMessage.js | 16 + .../1726804538569-reactions-buffering.js | 16 + .../migration/1727027985575-SidebarLogo.js | 16 + ...020265-enableStatsForFederatedInstances.js | 16 + .../migration/1727491883993-user-score.js | 16 + .../1727512908322-meta-federation.js | 18 + .../1727659258948-add_latest_note.js | 20 + ...1727998351561-increase_character_limits.js | 18 + .../1728085812127-refine-abuse-user-report.js | 18 + .../1728177700920-add-reject-reports.js | 16 + .../1728348353115-soft-limit-drive-comment.js | 16 + .../1728420772835-track-latest-note-type.js | 24 + .../migration/1728550878802-testcaptcha.js | 16 + ...8634286056-prohibitedWordsForNameOfUser.js | 14 + ...333924409-signinRequiredForShowContents.js | 16 + .../1729414690009-defaultSensitive.js | 16 + .../1729486255072-makeNotesHiddenBefore.js | 18 + .../1730505338000-friendlyCaptcha.js | 20 + .../1733748798177-add_user_enableRss.js | 13 + ...lter_user_hideOnlineStatus_default_true.js | 11 + packages/backend/ormconfig.js | 21 + packages/backend/package.json | 254 + packages/backend/scripts/check_connect.js | 60 + packages/backend/scripts/dev.mjs | 63 + packages/backend/scripts/generate_api_json.js | 36 + packages/backend/scripts/watch.mjs | 28 + packages/backend/src/@types/hcaptcha.d.ts | 16 + .../backend/src/@types/http-signature.d.ts | 82 + packages/backend/src/@types/os-utils.d.ts | 35 + packages/backend/src/@types/package.json.d.ts | 15 + .../backend/src/@types/probe-image-size.d.ts | 32 + packages/backend/src/@types/redis-lock.d.ts | 13 + packages/backend/src/GlobalModule.ts | 181 + packages/backend/src/MainModule.ts | 18 + packages/backend/src/NestLogger.ts | 54 + packages/backend/src/boot/common.ts | 45 + packages/backend/src/boot/entry.ts | 92 + packages/backend/src/boot/master.ts | 212 + packages/backend/src/boot/ready.ts | 6 + packages/backend/src/boot/worker.ts | 58 + packages/backend/src/config.ts | 506 + packages/backend/src/const.ts | 60 + .../core/AbuseReportNotificationService.ts | 432 + .../backend/src/core/AbuseReportService.ts | 176 + .../backend/src/core/AccountMoveService.ts | 347 + .../backend/src/core/AccountUpdateService.ts | 41 + .../backend/src/core/AchievementService.ts | 128 + .../backend/src/core/AnnouncementService.ts | 223 + packages/backend/src/core/AntennaService.ts | 222 + packages/backend/src/core/AppLockService.ts | 44 + .../src/core/AvatarDecorationService.ts | 129 + packages/backend/src/core/CacheService.ts | 201 + packages/backend/src/core/CaptchaService.ts | 166 + .../src/core/ChannelFollowingService.ts | 109 + packages/backend/src/core/ClipService.ts | 158 + packages/backend/src/core/CoreModule.ts | 918 + .../src/core/CreateSystemUserService.ts | 88 + .../backend/src/core/CustomEmojiService.ts | 456 + .../backend/src/core/DeleteAccountService.ts | 93 + packages/backend/src/core/DownloadService.ts | 134 + packages/backend/src/core/DriveService.ts | 864 + packages/backend/src/core/EmailService.ts | 366 + packages/backend/src/core/EnvService.ts | 20 + .../src/core/FanoutTimelineEndpointService.ts | 185 + .../backend/src/core/FanoutTimelineService.ts | 114 + packages/backend/src/core/FeaturedService.ts | 145 + .../src/core/FederatedInstanceService.ts | 129 + .../src/core/FetchInstanceMetadataService.ts | 328 + packages/backend/src/core/FileInfoService.ts | 310 + packages/backend/src/core/FlashService.ts | 40 + .../backend/src/core/GlobalEventService.ts | 410 + packages/backend/src/core/HashtagService.ts | 251 + .../backend/src/core/HttpRequestService.ts | 318 + packages/backend/src/core/IdService.ts | 73 + .../src/core/ImageProcessingService.ts | 164 + .../backend/src/core/InstanceActorService.ts | 57 + .../src/core/InternalStorageService.ts | 65 + .../backend/src/core/LatestNoteService.ts | 139 + packages/backend/src/core/LoggerService.ts | 21 + packages/backend/src/core/MetaService.ts | 159 + packages/backend/src/core/MfmService.ts | 694 + .../backend/src/core/ModerationLogService.ts | 34 + .../backend/src/core/NoteCreateService.ts | 1175 + .../backend/src/core/NoteDeleteService.ts | 230 + packages/backend/src/core/NoteEditService.ts | 1076 + .../backend/src/core/NotePiningService.ts | 127 + packages/backend/src/core/NoteReadService.ts | 147 + .../backend/src/core/NotificationService.ts | 235 + packages/backend/src/core/PollService.ts | 108 + .../backend/src/core/ProxyAccountService.ts | 28 + .../src/core/PushNotificationService.ts | 138 + packages/backend/src/core/QueryService.ts | 254 + packages/backend/src/core/QueueModule.ts | 157 + packages/backend/src/core/QueueService.ts | 604 + packages/backend/src/core/ReactionService.ts | 435 + .../src/core/ReactionsBufferingService.ts | 211 + .../backend/src/core/RegistryApiService.ts | 147 + packages/backend/src/core/RelayService.ts | 131 + .../backend/src/core/RemoteLoggerService.ts | 19 + .../src/core/RemoteUserResolveService.ts | 158 + packages/backend/src/core/ReversiService.ts | 635 + packages/backend/src/core/RoleService.ts | 709 + packages/backend/src/core/S3Service.ts | 69 + packages/backend/src/core/SearchService.ts | 298 + packages/backend/src/core/SignupService.ts | 164 + packages/backend/src/core/SponsorsService.ts | 87 + .../backend/src/core/SystemWebhookService.ts | 266 + packages/backend/src/core/TimeService.ts | 27 + packages/backend/src/core/UserAuthService.ts | 45 + .../backend/src/core/UserBlockingService.ts | 196 + .../backend/src/core/UserFollowingService.ts | 763 + .../backend/src/core/UserKeypairService.ts | 49 + packages/backend/src/core/UserListService.ts | 160 + .../backend/src/core/UserMutingService.ts | 51 + .../src/core/UserRenoteMutingService.ts | 52 + .../backend/src/core/UserSearchService.ts | 205 + packages/backend/src/core/UserService.ts | 75 + .../backend/src/core/UserSuspendService.ts | 165 + .../backend/src/core/UserWebhookService.ts | 136 + packages/backend/src/core/UtilityService.ts | 161 + .../src/core/VideoProcessingService.ts | 64 + packages/backend/src/core/WebAuthnService.ts | 328 + packages/backend/src/core/WebfingerService.ts | 116 + .../backend/src/core/WebhookTestService.ts | 503 + .../src/core/activitypub/ApAudienceService.ts | 112 + .../core/activitypub/ApDbResolverService.ts | 208 + .../activitypub/ApDeliverManagerService.ts | 211 + .../src/core/activitypub/ApInboxService.ts | 855 + .../src/core/activitypub/ApLoggerService.ts | 19 + .../src/core/activitypub/ApMfmService.ts | 45 + .../src/core/activitypub/ApRendererService.ts | 875 + .../src/core/activitypub/ApRequestService.ts | 268 + .../src/core/activitypub/ApResolverService.ts | 257 + .../src/core/activitypub/JsonLdService.ts | 180 + .../activitypub/misc/check-against-url.ts | 31 + .../src/core/activitypub/misc/contexts.ts | 584 + .../src/core/activitypub/misc/validator.ts | 39 + .../core/activitypub/models/ApImageService.ts | 110 + .../activitypub/models/ApMentionService.ts | 40 + .../core/activitypub/models/ApNoteService.ts | 717 + .../activitypub/models/ApPersonService.ts | 847 + .../activitypub/models/ApQuestionService.ts | 128 + .../src/core/activitypub/models/icon.ts | 10 + .../src/core/activitypub/models/identifier.ts | 10 + .../src/core/activitypub/models/tag.ts | 24 + packages/backend/src/core/activitypub/type.ts | 385 + .../src/core/chart/ChartLoggerService.ts | 19 + .../src/core/chart/ChartManagementService.ts | 89 + .../src/core/chart/charts/active-users.ts | 66 + .../src/core/chart/charts/ap-request.ts | 59 + .../backend/src/core/chart/charts/drive.ts | 55 + .../chart/charts/entities/active-users.ts | 22 + .../core/chart/charts/entities/ap-request.ts | 16 + .../src/core/chart/charts/entities/drive.ts | 21 + .../core/chart/charts/entities/federation.ts | 21 + .../core/chart/charts/entities/instance.ts | 37 + .../src/core/chart/charts/entities/notes.ts | 27 + .../chart/charts/entities/per-user-drive.ts | 19 + .../charts/entities/per-user-following.ts | 25 + .../chart/charts/entities/per-user-notes.ts | 20 + .../core/chart/charts/entities/per-user-pv.ts | 17 + .../charts/entities/per-user-reactions.ts | 15 + .../chart/charts/entities/test-grouped.ts | 16 + .../charts/entities/test-intersection.ts | 16 + .../core/chart/charts/entities/test-unique.ts | 14 + .../src/core/chart/charts/entities/test.ts | 16 + .../src/core/chart/charts/entities/users.ts | 19 + .../src/core/chart/charts/federation.ts | 129 + .../backend/src/core/chart/charts/instance.ts | 141 + .../backend/src/core/chart/charts/notes.ts | 66 + .../src/core/chart/charts/per-user-drive.ts | 66 + .../core/chart/charts/per-user-following.ts | 79 + .../src/core/chart/charts/per-user-notes.ts | 63 + .../src/core/chart/charts/per-user-pv.ts | 55 + .../core/chart/charts/per-user-reactions.ts | 50 + .../src/core/chart/charts/test-grouped.ts | 54 + .../core/chart/charts/test-intersection.ts | 52 + .../src/core/chart/charts/test-unique.ts | 45 + .../backend/src/core/chart/charts/test.ts | 62 + .../backend/src/core/chart/charts/users.ts | 67 + packages/backend/src/core/chart/core.ts | 730 + packages/backend/src/core/chart/entities.ts | 44 + ...eportNotificationRecipientEntityService.ts | 87 + .../entities/AbuseUserReportEntityService.ts | 82 + .../entities/AnnouncementEntityService.ts | 71 + .../src/core/entities/AntennaEntityService.ts | 49 + .../src/core/entities/AppEntityService.ts | 57 + .../core/entities/AuthSessionEntityService.ts | 38 + .../core/entities/BlockingEntityService.ts | 58 + .../src/core/entities/ChannelEntityService.ts | 102 + .../src/core/entities/ClipEntityService.ts | 71 + .../core/entities/DriveFileEntityService.ts | 294 + .../core/entities/DriveFolderEntityService.ts | 65 + .../src/core/entities/EmojiEntityService.ts | 75 + .../src/core/entities/FlashEntityService.ts | 88 + .../core/entities/FlashLikeEntityService.ts | 46 + .../entities/FollowRequestEntityService.ts | 62 + .../core/entities/FollowingEntityService.ts | 187 + .../core/entities/GalleryLikeEntityService.ts | 45 + .../core/entities/GalleryPostEntityService.ts | 74 + .../src/core/entities/HashtagEntityService.ts | 40 + .../core/entities/InstanceEntityService.ts | 75 + .../core/entities/InviteCodeEntityService.ts | 73 + .../src/core/entities/MetaEntityService.ts | 186 + .../entities/ModerationLogEntityService.ts | 59 + .../src/core/entities/MutingEntityService.ts | 61 + .../src/core/entities/NoteEntityService.ts | 633 + .../entities/NoteFavoriteEntityService.ts | 49 + .../entities/NoteReactionEntityService.ts | 92 + .../entities/NotificationEntityService.ts | 334 + .../src/core/entities/PageEntityService.ts | 125 + .../core/entities/PageLikeEntityService.ts | 46 + .../entities/RenoteMutingEntityService.ts | 60 + .../core/entities/ReversiGameEntityService.ts | 146 + .../src/core/entities/RoleEntityService.ts | 85 + .../src/core/entities/SigninEntityService.ts | 32 + .../entities/SystemWebhookEntityService.ts | 74 + .../src/core/entities/UserEntityService.ts | 783 + .../core/entities/UserListEntityService.ts | 65 + packages/backend/src/daemons/DaemonModule.ts | 26 + .../backend/src/daemons/QueueStatsService.ts | 99 + .../backend/src/daemons/ServerStatsService.ts | 115 + packages/backend/src/decorators.ts | 39 + packages/backend/src/di-symbols.ts | 91 + packages/backend/src/env.ts | 24 + packages/backend/src/global.d.ts | 6 + packages/backend/src/logger.ts | 120 + packages/backend/src/misc/FileWriterStream.ts | 36 + packages/backend/src/misc/JsonArrayStream.ts | 35 + packages/backend/src/misc/acct.ts | 19 + packages/backend/src/misc/cache.ts | 403 + packages/backend/src/misc/check-https.ts | 9 + packages/backend/src/misc/check-word-mute.ts | 70 + packages/backend/src/misc/clone.ts | 23 + packages/backend/src/misc/collapsed-queue.ts | 44 + .../backend/src/misc/content-disposition.ts | 11 + packages/backend/src/misc/correct-filename.ts | 58 + packages/backend/src/misc/create-temp.ts | 29 + packages/backend/src/misc/dev-null.ts | 16 + packages/backend/src/misc/emoji-regex.ts | 10 + .../misc/extract-custom-emojis-from-mfm.ts | 15 + packages/backend/src/misc/extract-hashtags.ts | 14 + packages/backend/src/misc/extract-mentions.ts | 16 + .../backend/src/misc/fastify-hook-handlers.ts | 14 + .../backend/src/misc/fastify-reply-error.ts | 16 + packages/backend/src/misc/from-tuple.ts | 7 + packages/backend/src/misc/gen-identicon.ts | 104 + packages/backend/src/misc/gen-key-pair.ts | 41 + .../backend/src/misc/generate-invite-code.ts | 25 + .../src/misc/generate-native-user-token.ts | 9 + packages/backend/src/misc/get-ip-hash.ts | 19 + packages/backend/src/misc/get-note-summary.ts | 59 + .../backend/src/misc/get-reaction-emoji.ts | 22 + packages/backend/src/misc/i18n.ts | 34 + packages/backend/src/misc/id/aid.ts | 40 + packages/backend/src/misc/id/aidx.ts | 47 + packages/backend/src/misc/id/meid.ts | 44 + packages/backend/src/misc/id/meidg.ts | 44 + packages/backend/src/misc/id/object-id.ts | 44 + packages/backend/src/misc/id/ulid.ts | 19 + .../backend/src/misc/identifiable-error.ts | 18 + .../src/misc/is-duplicate-key-value-error.ts | 10 + .../backend/src/misc/is-instance-muted.ts | 21 + packages/backend/src/misc/is-mime-image.ts | 16 + packages/backend/src/misc/is-native-token.ts | 7 + packages/backend/src/misc/is-renote.ts | 96 + packages/backend/src/misc/is-reply.ts | 10 + .../backend/src/misc/is-system-account.ts | 16 + packages/backend/src/misc/is-user-related.ts | 24 + packages/backend/src/misc/json-schema.ts | 251 + packages/backend/src/misc/json-value.ts | 12 + packages/backend/src/misc/langmap.ts | 671 + packages/backend/src/misc/loader.ts | 57 + .../backend/src/misc/normalize-for-search.ts | 11 + packages/backend/src/misc/prelude/README.md | 3 + packages/backend/src/misc/prelude/array.ts | 106 + .../backend/src/misc/prelude/await-all.ts | 26 + packages/backend/src/misc/prelude/relation.ts | 10 + packages/backend/src/misc/prelude/time.ts | 45 + packages/backend/src/misc/prelude/url.ts | 23 + packages/backend/src/misc/prelude/xml.ts | 46 + packages/backend/src/misc/promise-tracker.ts | 23 + packages/backend/src/misc/rate-limit-utils.ts | 161 + packages/backend/src/misc/reset-db.ts | 33 + packages/backend/src/misc/safe-for-sql.ts | 8 + packages/backend/src/misc/secure-rndstr.ts | 22 + .../backend/src/misc/show-machine-info.ts | 18 + packages/backend/src/misc/sql-like-escape.ts | 8 + packages/backend/src/misc/status-error.ts | 20 + packages/backend/src/misc/truncate.ts | 16 + .../AbuseReportNotificationRecipient.ts | 100 + .../backend/src/models/AbuseUserReport.ts | 98 + packages/backend/src/models/AccessToken.ts | 90 + packages/backend/src/models/Ad.ts | 68 + packages/backend/src/models/Announcement.ts | 95 + .../backend/src/models/AnnouncementRead.ts | 36 + packages/backend/src/models/Antenna.ts | 103 + packages/backend/src/models/App.ts | 59 + packages/backend/src/models/AuthSession.ts | 43 + .../backend/src/models/AvatarDecoration.ts | 39 + packages/backend/src/models/Blocking.ts | 41 + .../backend/src/models/BubbleGameRecord.ts | 57 + packages/backend/src/models/Channel.ts | 101 + .../backend/src/models/ChannelFavorite.ts | 40 + .../backend/src/models/ChannelFollowing.ts | 42 + packages/backend/src/models/Clip.ts | 50 + packages/backend/src/models/ClipFavorite.ts | 35 + packages/backend/src/models/ClipNote.ts | 42 + packages/backend/src/models/DriveFile.ts | 191 + packages/backend/src/models/DriveFolder.ts | 48 + packages/backend/src/models/Emoji.ts | 84 + packages/backend/src/models/Flash.ts | 70 + packages/backend/src/models/FlashLike.ts | 35 + packages/backend/src/models/FollowRequest.ts | 90 + packages/backend/src/models/Following.ts | 100 + packages/backend/src/models/GalleryLike.ts | 35 + packages/backend/src/models/GalleryPost.ts | 78 + packages/backend/src/models/Hashtag.ts | 92 + packages/backend/src/models/Instance.ts | 171 + packages/backend/src/models/LatestNote.ts | 100 + packages/backend/src/models/Meta.ts | 735 + packages/backend/src/models/ModerationLog.ts | 32 + packages/backend/src/models/Muting.ts | 47 + packages/backend/src/models/Note.ts | 254 + packages/backend/src/models/NoteEdit.ts | 61 + packages/backend/src/models/NoteFavorite.ts | 35 + packages/backend/src/models/NoteReaction.ts | 43 + packages/backend/src/models/NoteSchedule.ts | 58 + .../backend/src/models/NoteThreadMuting.ts | 33 + packages/backend/src/models/NoteUnread.ts | 68 + packages/backend/src/models/Notification.ts | 156 + packages/backend/src/models/Page.ts | 120 + packages/backend/src/models/PageLike.ts | 35 + .../src/models/PasswordResetRequest.ts | 32 + packages/backend/src/models/Poll.ts | 86 + packages/backend/src/models/PollVote.ts | 39 + packages/backend/src/models/PromoNote.ts | 33 + packages/backend/src/models/PromoRead.ts | 35 + .../backend/src/models/RegistrationTicket.ts | 62 + packages/backend/src/models/RegistryItem.ts | 58 + packages/backend/src/models/Relay.ts | 24 + packages/backend/src/models/RenoteMuting.ts | 41 + .../backend/src/models/RepositoryModule.ts | 671 + .../src/models/RetentionAggregation.ts | 46 + packages/backend/src/models/ReversiGame.ts | 148 + packages/backend/src/models/Role.ts | 270 + packages/backend/src/models/RoleAssignment.ts | 48 + packages/backend/src/models/Signin.ts | 35 + packages/backend/src/models/SwSubscription.ts | 44 + packages/backend/src/models/SystemWebhook.ts | 104 + packages/backend/src/models/UsedUsername.ts | 25 + packages/backend/src/models/User.ts | 380 + packages/backend/src/models/UserIp.ts | 28 + packages/backend/src/models/UserKeypair.ts | 38 + packages/backend/src/models/UserList.ts | 39 + .../backend/src/models/UserListFavorite.ts | 35 + .../backend/src/models/UserListMembership.ts | 55 + packages/backend/src/models/UserMemo.ts | 47 + packages/backend/src/models/UserNotePining.ts | 35 + packages/backend/src/models/UserPending.ts | 39 + packages/backend/src/models/UserProfile.ts | 309 + packages/backend/src/models/UserPublickey.ts | 39 + .../backend/src/models/UserSecurityKey.ts | 76 + packages/backend/src/models/Webhook.ts | 74 + packages/backend/src/models/_.ts | 276 + .../abuse-report-notification-recipient.ts | 50 + packages/backend/src/models/json-schema/ad.ts | 64 + .../src/models/json-schema/announcement.ts | 64 + .../backend/src/models/json-schema/antenna.ts | 104 + .../backend/src/models/json-schema/app.ts | 38 + .../src/models/json-schema/blocking.ts | 31 + .../backend/src/models/json-schema/channel.ts | 93 + .../backend/src/models/json-schema/clip.ts | 60 + .../src/models/json-schema/drive-file.ts | 112 + .../src/models/json-schema/drive-folder.ts | 44 + .../backend/src/models/json-schema/emoji.ts | 106 + .../models/json-schema/federation-instance.ts | 134 + .../backend/src/models/json-schema/flash.ts | 61 + .../src/models/json-schema/following.ts | 41 + .../src/models/json-schema/gallery-post.ts | 82 + .../backend/src/models/json-schema/hashtag.ts | 39 + .../src/models/json-schema/invite-code.ts | 50 + .../backend/src/models/json-schema/meta.ts | 406 + .../backend/src/models/json-schema/muting.ts | 36 + .../src/models/json-schema/note-edit.ts | 59 + .../src/models/json-schema/note-favorite.ts | 31 + .../src/models/json-schema/note-reaction.ts | 30 + .../backend/src/models/json-schema/note.ts | 265 + .../src/models/json-schema/notification.ts | 490 + .../backend/src/models/json-schema/page.ts | 209 + .../backend/src/models/json-schema/queue.ts | 30 + .../src/models/json-schema/renote-muting.ts | 31 + .../src/models/json-schema/reversi-game.ts | 243 + .../backend/src/models/json-schema/role.ts | 435 + .../backend/src/models/json-schema/signin.ts | 31 + .../src/models/json-schema/system-webhook.ts | 54 + .../src/models/json-schema/user-list.ts | 39 + .../backend/src/models/json-schema/user.ts | 814 + packages/backend/src/models/util/id.ts | 9 + packages/backend/src/postgres.ts | 257 + .../backend/src/queue/QueueLoggerService.ts | 19 + .../backend/src/queue/QueueProcessorModule.ts | 98 + .../src/queue/QueueProcessorService.ts | 586 + packages/backend/src/queue/const.ts | 30 + .../AggregateRetentionProcessorService.ts | 92 + .../BakeBufferedReactionsProcessorService.ts | 42 + .../CheckExpiredMutingsProcessorService.ts | 46 + ...CheckModeratorsActivityProcessorService.ts | 276 + .../processors/CleanChartsProcessorService.ts | 66 + .../queue/processors/CleanProcessorService.ts | 74 + .../CleanRemoteFilesProcessorService.ts | 80 + .../DeleteAccountProcessorService.ts | 170 + .../DeleteDriveFilesProcessorService.ts | 79 + .../processors/DeleteFileProcessorService.ts | 33 + .../processors/DeliverProcessorService.ts | 159 + .../EndedPollNotificationProcessorService.ts | 60 + .../ExportAccountDataProcessorService.ts | 817 + .../ExportAntennasProcessorService.ts | 110 + .../ExportBlockingProcessorService.ts | 123 + .../processors/ExportClipsProcessorService.ts | 213 + .../ExportCustomEmojisProcessorService.ts | 154 + .../ExportFavoritesProcessorService.ts | 167 + .../ExportFollowingProcessorService.ts | 127 + .../ExportMutingProcessorService.ts | 124 + .../processors/ExportNotesProcessorService.ts | 164 + .../ExportUserListsProcessorService.ts | 103 + .../ImportAntennasProcessorService.ts | 102 + .../ImportBlockingProcessorService.ts | 103 + .../ImportCustomEmojisProcessorService.ts | 128 + .../ImportFollowingProcessorService.ts | 103 + .../ImportMutingProcessorService.ts | 101 + .../processors/ImportNotesProcessorService.ts | 722 + .../ImportUserListsProcessorService.ts | 111 + .../queue/processors/InboxProcessorService.ts | 287 + .../RelationshipProcessorService.ts | 78 + .../ResyncChartsProcessorService.ts | 40 + .../ScheduleNotePostProcessorService.ts | 144 + .../SystemWebhookDeliverProcessorService.ts | 87 + .../processors/TickChartsProcessorService.ts | 66 + .../UserWebhookDeliverProcessorService.ts | 86 + packages/backend/src/queue/types.ts | 161 + .../src/server/ActivityPubServerService.ts | 942 + .../backend/src/server/FileServerService.ts | 680 + .../backend/src/server/HealthServerService.ts | 58 + .../src/server/NodeinfoServerService.ts | 180 + packages/backend/src/server/ServerModule.ts | 111 + packages/backend/src/server/ServerService.ts | 281 + .../src/server/SkRateLimiterService.md | 143 + .../src/server/WellKnownServerService.ts | 182 + .../backend/src/server/api/ApiCallService.ts | 462 + .../src/server/api/ApiLoggerService.ts | 19 + .../src/server/api/ApiServerService.ts | 202 + .../src/server/api/AuthenticateService.ts | 103 + .../backend/src/server/api/EndpointsModule.ts | 1634 + .../backend/src/server/api/GetterService.ts | 110 + .../src/server/api/RateLimiterService.ts | 107 + .../src/server/api/SigninApiService.ts | 323 + .../backend/src/server/api/SigninService.ts | 67 + .../server/api/SigninWithPasskeyApiService.ts | 176 + .../src/server/api/SignupApiService.ts | 365 + .../src/server/api/SkRateLimiterService.ts | 253 + .../server/api/StreamingApiServerService.ts | 246 + .../backend/src/server/api/endpoint-base.ts | 74 + packages/backend/src/server/api/endpoints.ts | 938 + .../notification-recipient/create.ts | 122 + .../notification-recipient/delete.ts | 44 + .../notification-recipient/list.ts | 55 + .../notification-recipient/show.ts | 64 + .../notification-recipient/update.ts | 128 + .../api/endpoints/admin/abuse-user-reports.ts | 140 + .../api/endpoints/admin/accounts/create.ts | 151 + .../api/endpoints/admin/accounts/delete.ts | 52 + .../endpoints/admin/accounts/find-by-email.ts | 67 + .../server/api/endpoints/admin/ad/create.ts | 85 + .../server/api/endpoints/admin/ad/delete.ts | 58 + .../src/server/api/endpoints/admin/ad/list.ts | 73 + .../server/api/endpoints/admin/ad/update.ts | 80 + .../endpoints/admin/announcements/create.ts | 92 + .../endpoints/admin/announcements/delete.ts | 53 + .../api/endpoints/admin/announcements/list.ts | 132 + .../endpoints/admin/announcements/update.ts | 74 + .../api/endpoints/admin/approve-user.ts | 62 + .../admin/avatar-decorations/create.ts | 100 + .../admin/avatar-decorations/delete.ts | 39 + .../admin/avatar-decorations/list.ts | 99 + .../admin/avatar-decorations/update.ts | 51 + .../api/endpoints/admin/decline-user.ts | 75 + .../api/endpoints/admin/delete-account.ts | 45 + .../admin/delete-all-files-of-a-user.ts | 46 + .../admin/drive/clean-remote-files.ts | 33 + .../api/endpoints/admin/drive/cleanup.ts | 45 + .../server/api/endpoints/admin/drive/files.ts | 89 + .../api/endpoints/admin/drive/show-file.ts | 242 + .../endpoints/admin/emoji/add-aliases-bulk.ts | 40 + .../server/api/endpoints/admin/emoji/add.ts | 99 + .../server/api/endpoints/admin/emoji/copy.ts | 105 + .../api/endpoints/admin/emoji/delete-bulk.ts | 37 + .../api/endpoints/admin/emoji/delete.ts | 43 + .../api/endpoints/admin/emoji/import-zip.ts | 33 + .../api/endpoints/admin/emoji/list-remote.ts | 113 + .../server/api/endpoints/admin/emoji/list.ts | 117 + .../admin/emoji/remove-aliases-bulk.ts | 40 + .../endpoints/admin/emoji/set-aliases-bulk.ts | 40 + .../admin/emoji/set-category-bulk.ts | 42 + .../endpoints/admin/emoji/set-license-bulk.ts | 42 + .../api/endpoints/admin/emoji/update.ts | 107 + .../admin/federation/delete-all-files.ts | 46 + .../refresh-remote-instance-metadata.ts | 48 + .../admin/federation/remove-all-following.ts | 57 + .../admin/federation/update-instance.ts | 105 + .../admin/forward-abuse-user-report.ts | 55 + .../api/endpoints/admin/get-index-stats.ts | 53 + .../api/endpoints/admin/get-table-stats.ts | 75 + .../api/endpoints/admin/get-user-ips.ts | 68 + .../api/endpoints/admin/invite/create.ts | 85 + .../server/api/endpoints/admin/invite/list.ts | 76 + .../src/server/api/endpoints/admin/meta.ts | 736 + .../server/api/endpoints/admin/nsfw-user.ts | 48 + .../api/endpoints/admin/promo/create.ts | 71 + .../server/api/endpoints/admin/queue/clear.ts | 37 + .../endpoints/admin/queue/deliver-delayed.ts | 71 + .../endpoints/admin/queue/inbox-delayed.ts | 71 + .../api/endpoints/admin/queue/promote.ts | 77 + .../server/api/endpoints/admin/queue/stats.ts | 74 + .../server/api/endpoints/admin/relays/add.ts | 78 + .../server/api/endpoints/admin/relays/list.ts | 64 + .../api/endpoints/admin/relays/remove.ts | 35 + .../api/endpoints/admin/reset-password.ts | 93 + .../admin/resolve-abuse-user-report.ts | 56 + .../api/endpoints/admin/roles/assign.ts | 90 + .../api/endpoints/admin/roles/create.ts | 74 + .../api/endpoints/admin/roles/delete.ts | 55 + .../server/api/endpoints/admin/roles/list.ts | 53 + .../server/api/endpoints/admin/roles/show.ts | 61 + .../api/endpoints/admin/roles/unassign.ts | 88 + .../admin/roles/update-default-policies.ts | 55 + .../api/endpoints/admin/roles/update.ts | 87 + .../server/api/endpoints/admin/roles/users.ts | 103 + .../server/api/endpoints/admin/send-email.ts | 37 + .../server/api/endpoints/admin/server-info.ts | 146 + .../endpoints/admin/show-moderation-logs.ts | 97 + .../server/api/endpoints/admin/show-user.ts | 274 + .../server/api/endpoints/admin/show-users.ts | 121 + .../api/endpoints/admin/silence-user.ts | 52 + .../api/endpoints/admin/suspend-user.ts | 52 + .../endpoints/admin/system-webhook/create.ts | 85 + .../endpoints/admin/system-webhook/delete.ts | 44 + .../endpoints/admin/system-webhook/list.ts | 60 + .../endpoints/admin/system-webhook/show.ts | 62 + .../endpoints/admin/system-webhook/test.ts | 77 + .../endpoints/admin/system-webhook/update.ts | 91 + .../server/api/endpoints/admin/unnsfw-user.ts | 48 + .../api/endpoints/admin/unset-user-avatar.ts | 61 + .../api/endpoints/admin/unset-user-banner.ts | 61 + .../api/endpoints/admin/unsilence-user.ts | 45 + .../api/endpoints/admin/unsuspend-user.ts | 46 + .../admin/update-abuse-user-report.ts | 58 + .../server/api/endpoints/admin/update-meta.ts | 745 + .../api/endpoints/admin/update-user-note.ts | 62 + .../src/server/api/endpoints/announcements.ts | 69 + .../api/endpoints/announcements/show.ts | 60 + .../server/api/endpoints/antennas/create.ts | 149 + .../server/api/endpoints/antennas/delete.ts | 66 + .../src/server/api/endpoints/antennas/list.ts | 58 + .../server/api/endpoints/antennas/notes.ts | 138 + .../src/server/api/endpoints/antennas/show.ts | 71 + .../server/api/endpoints/antennas/update.ts | 147 + .../src/server/api/endpoints/ap/get.ts | 51 + .../src/server/api/endpoints/ap/show.ts | 170 + .../src/server/api/endpoints/app/create.ts | 79 + .../src/server/api/endpoints/app/show.ts | 69 + .../src/server/api/endpoints/auth/accept.ts | 104 + .../api/endpoints/auth/session/generate.ts | 99 + .../server/api/endpoints/auth/session/show.ts | 83 + .../api/endpoints/auth/session/userkey.ts | 126 + .../server/api/endpoints/blocking/create.ts | 126 + .../server/api/endpoints/blocking/delete.ts | 125 + .../src/server/api/endpoints/blocking/list.ts | 67 + .../api/endpoints/bubble-game/ranking.ts | 89 + .../api/endpoints/bubble-game/register.ts | 89 + .../server/api/endpoints/channels/create.ts | 97 + .../server/api/endpoints/channels/favorite.ts | 72 + .../server/api/endpoints/channels/featured.ts | 59 + .../server/api/endpoints/channels/follow.ts | 64 + .../server/api/endpoints/channels/followed.ts | 67 + .../api/endpoints/channels/my-favorites.ts | 62 + .../server/api/endpoints/channels/owned.ts | 68 + .../server/api/endpoints/channels/search.ts | 81 + .../src/server/api/endpoints/channels/show.ts | 67 + .../server/api/endpoints/channels/timeline.ts | 162 + .../api/endpoints/channels/unfavorite.ts | 68 + .../server/api/endpoints/channels/unfollow.ts | 64 + .../server/api/endpoints/channels/update.ts | 131 + .../api/endpoints/charts/active-users.ts | 47 + .../server/api/endpoints/charts/ap-request.ts | 47 + .../src/server/api/endpoints/charts/drive.ts | 47 + .../server/api/endpoints/charts/federation.ts | 47 + .../server/api/endpoints/charts/instance.ts | 48 + .../src/server/api/endpoints/charts/notes.ts | 47 + .../server/api/endpoints/charts/user/drive.ts | 48 + .../api/endpoints/charts/user/following.ts | 48 + .../server/api/endpoints/charts/user/notes.ts | 48 + .../server/api/endpoints/charts/user/pv.ts | 48 + .../api/endpoints/charts/user/reactions.ts | 48 + .../src/server/api/endpoints/charts/users.ts | 47 + .../server/api/endpoints/clips/add-note.ts | 86 + .../src/server/api/endpoints/clips/create.ts | 72 + .../src/server/api/endpoints/clips/delete.ts | 57 + .../server/api/endpoints/clips/favorite.ts | 89 + .../src/server/api/endpoints/clips/list.ts | 58 + .../api/endpoints/clips/my-favorites.ts | 62 + .../src/server/api/endpoints/clips/notes.ts | 107 + .../server/api/endpoints/clips/remove-note.ts | 68 + .../src/server/api/endpoints/clips/show.ts | 74 + .../server/api/endpoints/clips/unfavorite.ts | 77 + .../src/server/api/endpoints/clips/update.ts | 73 + .../backend/src/server/api/endpoints/drive.ts | 63 + .../src/server/api/endpoints/drive/files.ts | 103 + .../endpoints/drive/files/attached-notes.ts | 94 + .../endpoints/drive/files/check-existence.ts | 57 + .../api/endpoints/drive/files/create.ts | 138 + .../api/endpoints/drive/files/delete.ts | 78 + .../api/endpoints/drive/files/find-by-hash.ts | 63 + .../server/api/endpoints/drive/files/find.ts | 66 + .../server/api/endpoints/drive/files/show.ts | 104 + .../api/endpoints/drive/files/update.ts | 136 + .../endpoints/drive/files/upload-from-url.ts | 79 + .../src/server/api/endpoints/drive/folders.ts | 77 + .../api/endpoints/drive/folders/create.ts | 93 + .../api/endpoints/drive/folders/delete.ts | 87 + .../api/endpoints/drive/folders/find.ts | 64 + .../api/endpoints/drive/folders/show.ts | 73 + .../api/endpoints/drive/folders/update.ts | 142 + .../src/server/api/endpoints/drive/stream.ts | 74 + .../api/endpoints/email-address/available.ts | 54 + .../backend/src/server/api/endpoints/emoji.ts | 62 + .../src/server/api/endpoints/emojis.ts | 69 + .../src/server/api/endpoints/endpoint.ts | 65 + .../src/server/api/endpoints/endpoints.ts | 51 + .../api/endpoints/export-custom-emojis.ts | 35 + .../api/endpoints/federation/followers.ts | 55 + .../api/endpoints/federation/following.ts | 55 + .../api/endpoints/federation/instances.ts | 215 + .../api/endpoints/federation/show-instance.ts | 55 + .../server/api/endpoints/federation/stats.ts | 123 + .../federation/update-remote-user.ts | 42 + .../server/api/endpoints/federation/users.ts | 66 + .../api/endpoints/fetch-external-resources.ts | 85 + .../src/server/api/endpoints/fetch-rss.ts | 241 + .../src/server/api/endpoints/flash/create.ts | 76 + .../src/server/api/endpoints/flash/delete.ts | 86 + .../server/api/endpoints/flash/featured.ts | 58 + .../src/server/api/endpoints/flash/like.ts | 100 + .../server/api/endpoints/flash/my-likes.ts | 78 + .../src/server/api/endpoints/flash/my.ts | 67 + .../src/server/api/endpoints/flash/show.ts | 65 + .../src/server/api/endpoints/flash/unlike.ts | 80 + .../src/server/api/endpoints/flash/update.ts | 82 + .../server/api/endpoints/following/create.ts | 117 + .../server/api/endpoints/following/delete.ts | 104 + .../api/endpoints/following/invalidate.ts | 102 + .../endpoints/following/requests/accept.ts | 68 + .../endpoints/following/requests/cancel.ts | 82 + .../api/endpoints/following/requests/list.ts | 83 + .../endpoints/following/requests/reject.ts | 60 + .../api/endpoints/following/requests/sent.ts | 83 + .../api/endpoints/following/update-all.ts | 54 + .../server/api/endpoints/following/update.ts | 109 + .../server/api/endpoints/gallery/featured.ts | 84 + .../server/api/endpoints/gallery/popular.ts | 58 + .../src/server/api/endpoints/gallery/posts.ts | 61 + .../api/endpoints/gallery/posts/create.ts | 91 + .../api/endpoints/gallery/posts/delete.ts | 86 + .../api/endpoints/gallery/posts/like.ts | 107 + .../api/endpoints/gallery/posts/show.ts | 67 + .../api/endpoints/gallery/posts/unlike.ts | 90 + .../api/endpoints/gallery/posts/update.ts | 96 + .../api/endpoints/get-avatar-decorations.ts | 88 + .../api/endpoints/get-online-users-count.ts | 59 + .../src/server/api/endpoints/hashtags/list.ts | 91 + .../server/api/endpoints/hashtags/search.ts | 61 + .../src/server/api/endpoints/hashtags/show.ts | 65 + .../server/api/endpoints/hashtags/trend.ts | 79 + .../server/api/endpoints/hashtags/users.ts | 88 + .../backend/src/server/api/endpoints/i.ts | 87 + .../src/server/api/endpoints/i/2fa/done.ts | 96 + .../server/api/endpoints/i/2fa/key-done.ts | 132 + .../api/endpoints/i/2fa/password-less.ts | 89 + .../api/endpoints/i/2fa/register-key.ts | 245 + .../server/api/endpoints/i/2fa/register.ts | 119 + .../server/api/endpoints/i/2fa/remove-key.ts | 116 + .../server/api/endpoints/i/2fa/unregister.ts | 92 + .../server/api/endpoints/i/2fa/update-key.ts | 86 + .../src/server/api/endpoints/i/apps.ts | 100 + .../server/api/endpoints/i/authorized-apps.ts | 96 + .../server/api/endpoints/i/change-password.ts | 76 + .../api/endpoints/i/claim-achievement.ts | 46 + .../server/api/endpoints/i/delete-account.ts | 78 + .../server/api/endpoints/i/export-antennas.ts | 35 + .../server/api/endpoints/i/export-blocking.ts | 35 + .../server/api/endpoints/i/export-clips.ts | 35 + .../src/server/api/endpoints/i/export-data.ts | 35 + .../api/endpoints/i/export-favorites.ts | 35 + .../api/endpoints/i/export-following.ts | 38 + .../src/server/api/endpoints/i/export-mute.ts | 35 + .../server/api/endpoints/i/export-notes.ts | 35 + .../api/endpoints/i/export-user-lists.ts | 35 + .../src/server/api/endpoints/i/favorites.ts | 68 + .../server/api/endpoints/i/gallery/likes.ts | 79 + .../server/api/endpoints/i/gallery/posts.ts | 67 + .../server/api/endpoints/i/import-antennas.ts | 90 + .../server/api/endpoints/i/import-blocking.ts | 87 + .../api/endpoints/i/import-following.ts | 87 + .../server/api/endpoints/i/import-muting.ts | 87 + .../server/api/endpoints/i/import-notes.ts | 77 + .../api/endpoints/i/import-user-lists.ts | 86 + .../src/server/api/endpoints/i/move.ts | 132 + .../api/endpoints/i/notifications-grouped.ts | 177 + .../server/api/endpoints/i/notifications.ts | 151 + .../src/server/api/endpoints/i/page-likes.ts | 78 + .../src/server/api/endpoints/i/pages.ts | 67 + .../backend/src/server/api/endpoints/i/pin.ts | 80 + .../api/endpoints/i/read-all-unread-notes.ts | 51 + .../api/endpoints/i/read-announcement.ts | 44 + .../api/endpoints/i/regenerate-token.ts | 71 + .../api/endpoints/i/registry/get-all.ts | 53 + .../api/endpoints/i/registry/get-detail.ts | 73 + .../api/endpoints/i/registry/get-unsecure.ts | 67 + .../server/api/endpoints/i/registry/get.ts | 61 + .../endpoints/i/registry/keys-with-type.ts | 64 + .../server/api/endpoints/i/registry/keys.ts | 48 + .../server/api/endpoints/i/registry/remove.ts | 53 + .../i/registry/scopes-with-domain.ts | 58 + .../server/api/endpoints/i/registry/set.ts | 43 + .../server/api/endpoints/i/revoke-token.ts | 63 + .../server/api/endpoints/i/signin-history.ts | 62 + .../src/server/api/endpoints/i/unpin.ts | 65 + .../server/api/endpoints/i/update-email.ts | 145 + .../src/server/api/endpoints/i/update.ts | 673 + .../server/api/endpoints/i/webhooks/create.ts | 123 + .../server/api/endpoints/i/webhooks/delete.ts | 68 + .../server/api/endpoints/i/webhooks/list.ts | 89 + .../server/api/endpoints/i/webhooks/show.ts | 100 + .../server/api/endpoints/i/webhooks/test.ts | 76 + .../server/api/endpoints/i/webhooks/update.ts | 86 + .../src/server/api/endpoints/invite/create.ts | 86 + .../src/server/api/endpoints/invite/delete.ts | 82 + .../src/server/api/endpoints/invite/limit.ts | 67 + .../src/server/api/endpoints/invite/list.ts | 69 + .../backend/src/server/api/endpoints/meta.ts | 47 + .../server/api/endpoints/miauth/gen-token.ts | 85 + .../src/server/api/endpoints/mute/create.ts | 104 + .../src/server/api/endpoints/mute/delete.ts | 93 + .../src/server/api/endpoints/mute/list.ts | 67 + .../src/server/api/endpoints/my/apps.ts | 68 + .../backend/src/server/api/endpoints/notes.ts | 99 + .../api/endpoints/notes/bubble-timeline.ts | 134 + .../server/api/endpoints/notes/children.ts | 91 + .../src/server/api/endpoints/notes/clips.ts | 83 + .../api/endpoints/notes/conversation.ts | 102 + .../server/api/endpoints/notes/create.test.ts | 270 + .../src/server/api/endpoints/notes/create.ts | 424 + .../src/server/api/endpoints/notes/delete.ts | 76 + .../src/server/api/endpoints/notes/edit.ts | 478 + .../api/endpoints/notes/favorites/create.ts | 93 + .../api/endpoints/notes/favorites/delete.ts | 79 + .../server/api/endpoints/notes/featured.ts | 115 + .../server/api/endpoints/notes/following.ts | 184 + .../api/endpoints/notes/global-timeline.ts | 135 + .../api/endpoints/notes/hybrid-timeline.ts | 300 + .../src/server/api/endpoints/notes/like.ts | 81 + .../api/endpoints/notes/local-timeline.ts | 194 + .../server/api/endpoints/notes/mentions.ts | 103 + .../endpoints/notes/polls/recommendation.ts | 124 + .../api/endpoints/notes/polls/refresh.ts | 104 + .../server/api/endpoints/notes/polls/vote.ts | 180 + .../server/api/endpoints/notes/reactions.ts | 91 + .../api/endpoints/notes/reactions/create.ts | 83 + .../api/endpoints/notes/reactions/delete.ts | 66 + .../src/server/api/endpoints/notes/renotes.ts | 102 + .../src/server/api/endpoints/notes/replies.ts | 73 + .../api/endpoints/notes/schedule/create.ts | 372 + .../api/endpoints/notes/schedule/delete.ts | 67 + .../api/endpoints/notes/schedule/list.ts | 131 + .../api/endpoints/notes/search-by-tag.ts | 174 + .../src/server/api/endpoints/notes/search.ts | 93 + .../src/server/api/endpoints/notes/show.ts | 88 + .../src/server/api/endpoints/notes/state.ts | 85 + .../endpoints/notes/thread-muting/create.ts | 81 + .../endpoints/notes/thread-muting/delete.ts | 63 + .../server/api/endpoints/notes/timeline.ts | 259 + .../server/api/endpoints/notes/translate.ts | 155 + .../server/api/endpoints/notes/unrenote.ts | 78 + .../api/endpoints/notes/user-list-timeline.ts | 244 + .../server/api/endpoints/notes/versions.ts | 102 + .../api/endpoints/notifications/create.ts | 50 + .../api/endpoints/notifications/flush.ts | 39 + .../notifications/mark-all-as-read.ts | 39 + .../notifications/test-notification.ts | 38 + .../src/server/api/endpoints/page-push.ts | 69 + .../src/server/api/endpoints/pages/create.ts | 125 + .../src/server/api/endpoints/pages/delete.ts | 87 + .../server/api/endpoints/pages/featured.ts | 59 + .../src/server/api/endpoints/pages/like.ts | 100 + .../src/server/api/endpoints/pages/show.ts | 90 + .../src/server/api/endpoints/pages/unlike.ts | 80 + .../src/server/api/endpoints/pages/update.ts | 130 + .../backend/src/server/api/endpoints/ping.ts | 48 + .../src/server/api/endpoints/pinned-users.ts | 63 + .../src/server/api/endpoints/promo/read.ts | 76 + .../api/endpoints/renote-mute/create.ts | 96 + .../api/endpoints/renote-mute/delete.ts | 93 + .../server/api/endpoints/renote-mute/list.ts | 67 + .../api/endpoints/request-reset-password.ts | 99 + .../src/server/api/endpoints/reset-db.ts | 55 + .../server/api/endpoints/reset-password.ts | 73 + .../src/server/api/endpoints/retention.ts | 82 + .../api/endpoints/reversi/cancel-match.ts | 47 + .../src/server/api/endpoints/reversi/games.ts | 70 + .../api/endpoints/reversi/invitations.ts | 45 + .../src/server/api/endpoints/reversi/match.ts | 79 + .../server/api/endpoints/reversi/show-game.ts | 60 + .../server/api/endpoints/reversi/surrender.ts | 74 + .../server/api/endpoints/reversi/verify.ts | 70 + .../src/server/api/endpoints/roles/list.ts | 59 + .../src/server/api/endpoints/roles/notes.ts | 120 + .../src/server/api/endpoints/roles/show.ts | 68 + .../src/server/api/endpoints/roles/users.ts | 110 + .../src/server/api/endpoints/server-info.ts | 121 + .../src/server/api/endpoints/sponsors.ts | 46 + .../backend/src/server/api/endpoints/stats.ts | 110 + .../src/server/api/endpoints/sw/register.ts | 118 + .../api/endpoints/sw/show-registration.ts | 77 + .../src/server/api/endpoints/sw/unregister.ts | 53 + .../api/endpoints/sw/update-registration.ts | 98 + .../backend/src/server/api/endpoints/test.ts | 71 + .../api/endpoints/username/available.ts | 71 + .../backend/src/server/api/endpoints/users.ts | 101 + .../api/endpoints/users/achievements.ts | 56 + .../src/server/api/endpoints/users/clips.ts | 67 + .../api/endpoints/users/featured-notes.ts | 106 + .../src/server/api/endpoints/users/flashs.ts | 68 + .../server/api/endpoints/users/followers.ts | 137 + .../server/api/endpoints/users/following.ts | 159 + .../api/endpoints/users/gallery/posts.ts | 66 + .../users/get-frequently-replied-users.ts | 140 + .../users/lists/create-from-public.ts | 165 + .../api/endpoints/users/lists/create.ts | 83 + .../api/endpoints/users/lists/delete.ts | 63 + .../api/endpoints/users/lists/favorite.ts | 85 + .../endpoints/users/lists/get-memberships.ts | 114 + .../server/api/endpoints/users/lists/list.ts | 94 + .../server/api/endpoints/users/lists/pull.ts | 84 + .../server/api/endpoints/users/lists/push.ts | 140 + .../server/api/endpoints/users/lists/show.ts | 99 + .../api/endpoints/users/lists/unfavorite.ts | 77 + .../users/lists/update-membership.ts | 85 + .../api/endpoints/users/lists/update.ts | 79 + .../src/server/api/endpoints/users/notes.ts | 271 + .../src/server/api/endpoints/users/pages.ts | 67 + .../server/api/endpoints/users/reactions.ts | 125 + .../api/endpoints/users/recommendation.ts | 88 + .../server/api/endpoints/users/relation.ts | 146 + .../api/endpoints/users/report-abuse.ts | 84 + .../users/search-by-username-and-host.ts | 64 + .../src/server/api/endpoints/users/search.ts | 131 + .../src/server/api/endpoints/users/show.ts | 162 + .../server/api/endpoints/users/update-memo.ts | 95 + packages/backend/src/server/api/error.ts | 33 + .../api/mastodon/MastodonApiServerService.ts | 911 + .../src/server/api/mastodon/converters.ts | 359 + .../src/server/api/mastodon/endpoints.ts | 22 + .../server/api/mastodon/endpoints/account.ts | 275 + .../src/server/api/mastodon/endpoints/auth.ts | 79 + .../server/api/mastodon/endpoints/filter.ts | 70 + .../src/server/api/mastodon/endpoints/meta.ts | 68 + .../api/mastodon/endpoints/notifications.ts | 75 + .../server/api/mastodon/endpoints/search.ts | 90 + .../server/api/mastodon/endpoints/status.ts | 415 + .../server/api/mastodon/endpoints/timeline.ts | 273 + .../api/openapi/OpenApiServerService.ts | 36 + .../backend/src/server/api/openapi/errors.ts | 73 + .../src/server/api/openapi/gen-spec.ts | 220 + .../backend/src/server/api/openapi/schemas.ts | 90 + .../src/server/api/stream/ChannelsService.ts | 75 + .../src/server/api/stream/Connection.ts | 379 + .../backend/src/server/api/stream/channel.ts | 111 + .../src/server/api/stream/channels/admin.ts | 43 + .../src/server/api/stream/channels/antenna.ts | 80 + .../api/stream/channels/bubble-timeline.ts | 110 + .../src/server/api/stream/channels/channel.ts | 91 + .../src/server/api/stream/channels/drive.ts | 43 + .../api/stream/channels/global-timeline.ts | 105 + .../src/server/api/stream/channels/hashtag.ts | 87 + .../api/stream/channels/home-timeline.ts | 122 + .../api/stream/channels/hybrid-timeline.ts | 144 + .../api/stream/channels/local-timeline.ts | 115 + .../src/server/api/stream/channels/main.ts | 86 + .../server/api/stream/channels/queue-stats.ts | 77 + .../api/stream/channels/reversi-game.ts | 131 + .../src/server/api/stream/channels/reversi.ts | 53 + .../api/stream/channels/role-timeline.ts | 85 + .../api/stream/channels/server-stats.ts | 75 + .../server/api/stream/channels/user-list.ts | 163 + .../backend/src/server/assets/bad-egg.png | Bin 0 -> 1676 bytes .../src/server/assets/cache-expired.png | Bin 0 -> 6048 bytes packages/backend/src/server/assets/dummy.png | Bin 0 -> 6285 bytes .../src/server/assets/not-an-image.png | Bin 0 -> 2780 bytes .../server/assets/thumbnail-not-available.png | Bin 0 -> 5705 bytes .../backend/src/server/assets/tombstone.png | Bin 0 -> 5028 bytes .../src/server/oauth/OAuth2ProviderService.ts | 205 + .../src/server/web/ClientLoggerService.ts | 19 + .../src/server/web/ClientServerService.ts | 1005 + .../backend/src/server/web/FeedService.ts | 118 + .../src/server/web/UrlPreviewService.ts | 189 + packages/backend/src/server/web/bios.css | 46 + packages/backend/src/server/web/bios.js | 62 + packages/backend/src/server/web/boot.embed.js | 208 + packages/backend/src/server/web/boot.js | 329 + packages/backend/src/server/web/cli.css | 25 + packages/backend/src/server/web/cli.js | 63 + packages/backend/src/server/web/error.css | 116 + packages/backend/src/server/web/manifest.json | 38 + packages/backend/src/server/web/style.css | 91 + .../backend/src/server/web/style.embed.css | 99 + .../src/server/web/views/announcement.pug | 21 + .../src/server/web/views/base-embed.pug | 74 + .../backend/src/server/web/views/base.pug | 110 + .../backend/src/server/web/views/bios.pug | 20 + .../backend/src/server/web/views/channel.pug | 19 + packages/backend/src/server/web/views/cli.pug | 21 + .../backend/src/server/web/views/clip.pug | 35 + .../backend/src/server/web/views/error.pug | 69 + .../backend/src/server/web/views/flash.pug | 35 + .../backend/src/server/web/views/flush.pug | 47 + .../src/server/web/views/gallery-post.pug | 41 + .../src/server/web/views/info-card.pug | 50 + .../backend/src/server/web/views/note.pug | 62 + .../backend/src/server/web/views/oauth.pug | 9 + .../backend/src/server/web/views/page.pug | 35 + .../src/server/web/views/reversi-game.pug | 20 + .../backend/src/server/web/views/user.pug | 43 + packages/backend/src/types.ts | 431 + .../test-federation/.config/example.conf | 70 + .../.config/example.default.yml | 24 + .../.config/example.docker.env | 5 + packages/backend/test-federation/.gitignore | 6 + packages/backend/test-federation/README.md | 24 + .../backend/test-federation/compose.a.yml | 64 + .../backend/test-federation/compose.b.yml | 64 + .../test-federation/compose.override.yaml | 117 + .../backend/test-federation/compose.tpl.yml | 101 + packages/backend/test-federation/compose.yml | 133 + packages/backend/test-federation/daemon.ts | 38 + .../backend/test-federation/eslint.config.js | 21 + packages/backend/test-federation/setup.sh | 35 + .../test-federation/test/abuse-report.test.ts | 52 + .../test-federation/test/block.test.ts | 224 + .../test-federation/test/drive.test.ts | 175 + .../test-federation/test/emoji.test.ts | 97 + .../backend/test-federation/test/move.test.ts | 52 + .../backend/test-federation/test/note.test.ts | 317 + .../test-federation/test/notification.test.ts | 107 + .../test-federation/test/timeline.test.ts | 328 + .../backend/test-federation/test/user.test.ts | 560 + .../backend/test-federation/test/utils.ts | 307 + .../backend/test-federation/tsconfig.json | 114 + packages/backend/test-server/.swcrc | 23 + packages/backend/test-server/entry.ts | 98 + packages/backend/test-server/eslint.config.js | 43 + packages/backend/test-server/tsconfig.json | 52 + packages/backend/test/compose.yml | 13 + packages/backend/test/e2e/2fa.ts | 491 + packages/backend/test/e2e/antennas.ts | 662 + packages/backend/test/e2e/api-visibility.ts | 472 + packages/backend/test/e2e/api.ts | 309 + packages/backend/test/e2e/block.ts | 86 + packages/backend/test/e2e/clips.ts | 929 + packages/backend/test/e2e/drive.ts | 85 + packages/backend/test/e2e/endpoints.ts | 1134 + packages/backend/test/e2e/exports.ts | 199 + packages/backend/test/e2e/fetch-resource.ts | 493 + .../test/e2e/fetch-validate-ap-deny.ts | 40 + packages/backend/test/e2e/ff-visibility.ts | 664 + packages/backend/test/e2e/move.ts | 475 + packages/backend/test/e2e/mute.ts | 320 + packages/backend/test/e2e/nodeinfo.ts | 29 + packages/backend/test/e2e/note.ts | 1041 + packages/backend/test/e2e/oauth.ts | 966 + packages/backend/test/e2e/renote-mute.ts | 119 + packages/backend/test/e2e/reversi-game.ts | 33 + packages/backend/test/e2e/streaming.ts | 906 + .../backend/test/e2e/synalio/abuse-report.ts | 354 + .../backend/test/e2e/synalio/user-create.ts | 130 + packages/backend/test/e2e/thread-mute.ts | 101 + packages/backend/test/e2e/timelines.ts | 1458 + packages/backend/test/e2e/user-notes.ts | 46 + packages/backend/test/e2e/users.ts | 918 + packages/backend/test/e2e/well-known.ts | 103 + packages/backend/test/eslint.config.js | 22 + packages/backend/test/global.d.ts | 7 + packages/backend/test/jest.setup.ts | 11 + packages/backend/test/misc/mock-resolver.ts | 86 + .../backend/test/prelude/get-api-validator.ts | 16 + packages/backend/test/prelude/url.ts | 18 + packages/backend/test/resources/192.jpg | Bin 0 -> 5131 bytes packages/backend/test/resources/192.png | Bin 0 -> 26568 bytes .../backend/test/resources/25000x25000.png | Bin 0 -> 75933 bytes packages/backend/test/resources/anime.gif | Bin 0 -> 2248 bytes packages/backend/test/resources/anime.png | Bin 0 -> 1868 bytes packages/backend/test/resources/emptyfile | 0 packages/backend/test/resources/image.svg | 1 + .../backend/test/resources/kick_gaba7.aac | Bin 0 -> 7291 bytes .../backend/test/resources/kick_gaba7.flac | Bin 0 -> 108793 bytes .../backend/test/resources/kick_gaba7.m4a | Bin 0 -> 9817 bytes .../backend/test/resources/kick_gaba7.mp3 | Bin 0 -> 19853 bytes .../backend/test/resources/kick_gaba7.wav | Bin 0 -> 87630 bytes .../backend/test/resources/kick_gaba7.webm | Bin 0 -> 8879 bytes packages/backend/test/resources/misskey.svg | 7 + packages/backend/test/resources/rotate.jpg | Bin 0 -> 12624 bytes .../backend/test/resources/with-alpha.avif | Bin 0 -> 10032 bytes .../backend/test/resources/with-alpha.png | Bin 0 -> 3772 bytes .../backend/test/resources/with-alpha.webp | Bin 0 -> 4984 bytes .../backend/test/resources/with-xml-def.svg | 2 + .../backend/test/resources/without-alpha.avif | Bin 0 -> 3982 bytes .../backend/test/resources/without-alpha.webp | Bin 0 -> 4474 bytes packages/backend/test/tsconfig.json | 45 + .../unit/AbuseReportNotificationService.ts | 347 + .../backend/test/unit/AnnouncementService.ts | 210 + packages/backend/test/unit/ApMfmService.ts | 49 + packages/backend/test/unit/DriveService.ts | 67 + .../test/unit/FetchInstanceMetadataService.ts | 136 + packages/backend/test/unit/FileInfoService.ts | 312 + packages/backend/test/unit/FlashService.ts | 152 + packages/backend/test/unit/MetaService.ts | 60 + packages/backend/test/unit/MfmService.ts | 119 + .../backend/test/unit/NoteCreateService.ts | 145 + packages/backend/test/unit/ReactionService.ts | 134 + packages/backend/test/unit/RelayService.ts | 106 + packages/backend/test/unit/RoleService.ts | 956 + packages/backend/test/unit/S3Service.ts | 88 + .../test/unit/SigninWithPasskeyApiService.ts | 190 + .../backend/test/unit/SystemWebhookService.ts | 517 + .../backend/test/unit/UserSearchService.ts | 265 + .../backend/test/unit/UserWebhookService.ts | 245 + packages/backend/test/unit/UtilityService.ts | 43 + .../backend/test/unit/WebhookTestService.ts | 225 + packages/backend/test/unit/activitypub.ts | 480 + packages/backend/test/unit/ap-request.ts | 61 + packages/backend/test/unit/chart.ts | 581 + .../test/unit/entities/UserEntityService.ts | 530 + .../backend/test/unit/extract-mentions.ts | 47 + .../test/unit/misc/check-against-url.ts | 55 + .../backend/test/unit/misc/check-word-mute.ts | 54 + .../test/unit/misc/correct-filename.ts | 48 + packages/backend/test/unit/misc/from-tuple.ts | 13 + packages/backend/test/unit/misc/id.ts | 57 + packages/backend/test/unit/misc/is-renote.ts | 109 + .../test/unit/misc/is-system-account.ts | 47 + packages/backend/test/unit/misc/loader.ts | 93 + packages/backend/test/unit/misc/others.ts | 19 + .../test/unit/misc/rate-limit-utils-tests.ts | 62 + .../backend/test/unit/models/LatestNote.ts | 149 + ...CheckModeratorsActivityProcessorService.ts | 379 + .../server/api/SkRateLimiterServiceTests.ts | 951 + packages/backend/test/utils.ts | 694 + packages/backend/tsconfig.json | 52 + packages/frontend-embed/.gitignore | 1 + packages/frontend-embed/@types/global.d.ts | 25 + packages/frontend-embed/@types/theme.d.ts | 12 + packages/frontend-embed/assets/dummy.png | Bin 0 -> 6285 bytes packages/frontend-embed/eslint.config.js | 109 + packages/frontend-embed/package.json | 72 + packages/frontend-embed/src/boot.ts | 161 + .../frontend-embed/src/components/EmA.vue | 21 + .../frontend-embed/src/components/EmAcct.vue | 24 + .../src/components/EmAvatar.vue | 255 + .../src/components/EmCustomEmoji.vue | 99 + .../frontend-embed/src/components/EmEmoji.vue | 26 + .../frontend-embed/src/components/EmError.vue | 43 + .../src/components/EmImgWithBlurhash.vue | 240 + .../src/components/EmInstanceTicker.vue | 87 + .../frontend-embed/src/components/EmLink.vue | 40 + .../src/components/EmLoading.vue | 112 + .../src/components/EmMediaBanner.vue | 56 + .../src/components/EmMediaImage.vue | 162 + .../src/components/EmMediaList.vue | 146 + .../src/components/EmMediaVideo.vue | 64 + .../src/components/EmMention.vue | 46 + .../frontend-embed/src/components/EmMfm.ts | 484 + .../frontend-embed/src/components/EmNote.vue | 604 + .../src/components/EmNoteDetailed.vue | 491 + .../src/components/EmNoteHeader.vue | 104 + .../src/components/EmNoteSimple.vue | 106 + .../src/components/EmNoteSub.vue | 151 + .../frontend-embed/src/components/EmNotes.vue | 52 + .../src/components/EmPagination.vue | 504 + .../frontend-embed/src/components/EmPoll.vue | 82 + .../src/components/EmReactionIcon.vue | 23 + .../components/EmReactionsViewer.reaction.vue | 99 + .../src/components/EmReactionsViewer.vue | 104 + .../src/components/EmSubNoteContent.vue | 114 + .../frontend-embed/src/components/EmTime.vue | 107 + .../src/components/EmTimelineContainer.vue | 39 + .../frontend-embed/src/components/EmUrl.vue | 96 + .../src/components/EmUserName.vue | 21 + .../frontend-embed/src/components/I18n.vue | 51 + packages/frontend-embed/src/custom-emojis.ts | 61 + packages/frontend-embed/src/di.ts | 17 + packages/frontend-embed/src/i18n.ts | 15 + packages/frontend-embed/src/index.html | 38 + packages/frontend-embed/src/misskey-api.ts | 99 + packages/frontend-embed/src/pages/clip.vue | 143 + .../frontend-embed/src/pages/not-found.vue | 24 + packages/frontend-embed/src/pages/note.vue | 52 + packages/frontend-embed/src/pages/tag.vue | 126 + .../src/pages/user-timeline.vue | 158 + packages/frontend-embed/src/post-message.ts | 49 + packages/frontend-embed/src/server-context.ts | 21 + .../frontend-embed/src/server-metadata.ts | 16 + packages/frontend-embed/src/style.scss | 477 + packages/frontend-embed/src/theme.ts | 108 + packages/frontend-embed/src/ui.vue | 110 + packages/frontend-embed/src/utils.ts | 23 + .../src/workers/draw-blurhash.ts | 22 + .../frontend-embed/src/workers/test-webgl2.ts | 14 + .../frontend-embed/src/workers/tsconfig.json | 5 + packages/frontend-embed/tsconfig.json | 56 + .../frontend-embed/vite.config.local-dev.ts | 96 + packages/frontend-embed/vite.config.ts | 161 + packages/frontend-embed/vite.json5.ts | 48 + packages/frontend-embed/vue-shims.d.ts | 6 + packages/frontend-shared/.gitignore | 2 + packages/frontend-shared/@types/global.d.ts | 27 + packages/frontend-shared/build.js | 106 + packages/frontend-shared/eslint.config.js | 109 + packages/frontend-shared/js/collapsed.ts | 22 + packages/frontend-shared/js/config.ts | 29 + packages/frontend-shared/js/const.ts | 214 + packages/frontend-shared/js/embed-page.ts | 97 + packages/frontend-shared/js/emoji-base.ts | 37 + packages/frontend-shared/js/emojilist.json | 1805 + packages/frontend-shared/js/emojilist.ts | 73 + .../js/extract-avg-color-from-blurhash.ts | 14 + packages/frontend-shared/js/i18n.ts | 251 + packages/frontend-shared/js/intl-const.ts | 51 + packages/frontend-shared/js/is-link.ts | 12 + packages/frontend-shared/js/media-proxy.ts | 63 + packages/frontend-shared/js/scroll.ts | 153 + packages/frontend-shared/js/url.ts | 28 + .../js/use-document-visibility.ts | 25 + packages/frontend-shared/js/use-interval.ts | 46 + .../js/worker-multi-dispatch.ts | 86 + packages/frontend-shared/package.json | 39 + packages/frontend-shared/themes/_dark.json5 | 96 + packages/frontend-shared/themes/_light.json5 | 96 + packages/frontend-shared/themes/d-astro.json5 | 66 + .../frontend-shared/themes/d-botanical.json5 | 26 + .../frontend-shared/themes/d-cherry.json5 | 21 + packages/frontend-shared/themes/d-dark.json5 | 26 + .../frontend-shared/themes/d-future.json5 | 27 + .../frontend-shared/themes/d-green-lime.json5 | 24 + .../themes/d-green-orange.json5 | 24 + packages/frontend-shared/themes/d-ice.json5 | 14 + .../frontend-shared/themes/d-persimmon.json5 | 26 + packages/frontend-shared/themes/d-u0.json5 | 80 + .../frontend-shared/themes/l-apricot.json5 | 23 + .../frontend-shared/themes/l-botanical.json5 | 30 + .../frontend-shared/themes/l-cherry.json5 | 22 + .../frontend-shared/themes/l-coffee.json5 | 22 + packages/frontend-shared/themes/l-light.json5 | 21 + packages/frontend-shared/themes/l-rainy.json5 | 22 + packages/frontend-shared/themes/l-sushi.json5 | 19 + packages/frontend-shared/themes/l-u0.json5 | 81 + packages/frontend-shared/themes/l-vivid.json5 | 69 + .../themes/rosepine-dawn.json5 | 89 + .../frontend-shared/themes/rosepine.json5 | 86 + packages/frontend-shared/tsconfig.json | 42 + packages/frontend/.gitignore | 1 + packages/frontend/.storybook/.gitignore | 7 + packages/frontend/.storybook/changes.ts | 87 + packages/frontend/.storybook/charts.ts | 48 + packages/frontend/.storybook/fakes.ts | 304 + packages/frontend/.storybook/generate.tsx | 428 + packages/frontend/.storybook/main.ts | 66 + packages/frontend/.storybook/manager.ts | 17 + packages/frontend/.storybook/mocks.ts | 44 + packages/frontend/.storybook/package.json | 3 + .../frontend/.storybook/preload-locale.ts | 13 + packages/frontend/.storybook/preload-theme.ts | 45 + .../frontend/.storybook/preview-head.html | 17 + packages/frontend/.storybook/preview.ts | 150 + packages/frontend/.storybook/tsconfig.json | 30 + packages/frontend/.vscode/settings.json | 11 + .../frontend/.vscode/storybook.code-snippets | 84 + packages/frontend/@types/global.d.ts | 25 + packages/frontend/@types/theme.d.ts | 12 + packages/frontend/assets/about-icon.png | Bin 0 -> 390835 bytes packages/frontend/assets/cookie.png | Bin 0 -> 38365 bytes .../frontend/assets/drop-and-fusion/bgm_1.mp3 | Bin 0 -> 1637271 bytes .../frontend/assets/drop-and-fusion/click.mp3 | Bin 0 -> 26496 bytes .../assets/drop-and-fusion/collision.mp3 | Bin 0 -> 18240 bytes .../assets/drop-and-fusion/collision_yen.mp3 | Bin 0 -> 7807 bytes .../assets/drop-and-fusion/drop-arrow.svg | 6 + .../frontend/assets/drop-and-fusion/drop.mp3 | Bin 0 -> 18240 bytes .../assets/drop-and-fusion/drop_yen.mp3 | Bin 0 -> 5850 bytes .../assets/drop-and-fusion/dropper.png | Bin 0 -> 32415 bytes .../assets/drop-and-fusion/frame-dark.svg | 28 + .../assets/drop-and-fusion/frame-light.svg | 28 + .../assets/drop-and-fusion/fusion.mp3 | Bin 0 -> 19328 bytes .../assets/drop-and-fusion/fusion_yen.mp3 | Bin 0 -> 7807 bytes .../assets/drop-and-fusion/gameover.mp3 | Bin 0 -> 31346 bytes .../assets/drop-and-fusion/gameover.png | Bin 0 -> 67156 bytes .../assets/drop-and-fusion/gameover_yen.mp3 | Bin 0 -> 46392 bytes .../frontend/assets/drop-and-fusion/go.png | Bin 0 -> 31115 bytes .../frontend/assets/drop-and-fusion/hold.mp3 | Bin 0 -> 21941 bytes .../frontend/assets/drop-and-fusion/logo.png | Bin 0 -> 254016 bytes .../normal_monos/cold_face.png | Bin 0 -> 40776 bytes .../normal_monos/exploding_head.png | Bin 0 -> 47230 bytes .../normal_monos/face_with_open_mouth.png | Bin 0 -> 36399 bytes .../face_with_symbols_on_mouth.png | Bin 0 -> 40322 bytes .../normal_monos/grinning_squinting_face.png | Bin 0 -> 41020 bytes .../normal_monos/heart_suit.png | Bin 0 -> 22437 bytes .../normal_monos/pleading_face.png | Bin 0 -> 44074 bytes .../normal_monos/smiling_face_with_hearts.png | Bin 0 -> 52432 bytes .../smiling_face_with_sunglasses.png | Bin 0 -> 47859 bytes .../normal_monos/zany_face.png | Bin 0 -> 44995 bytes .../frontend/assets/drop-and-fusion/ready.png | Bin 0 -> 34674 bytes .../drop-and-fusion/square_monos/keycap_1.png | Bin 0 -> 29193 bytes .../square_monos/keycap_10.png | Bin 0 -> 33717 bytes .../drop-and-fusion/square_monos/keycap_2.png | Bin 0 -> 32324 bytes .../drop-and-fusion/square_monos/keycap_3.png | Bin 0 -> 33127 bytes .../drop-and-fusion/square_monos/keycap_4.png | Bin 0 -> 31182 bytes .../drop-and-fusion/square_monos/keycap_5.png | Bin 0 -> 32745 bytes .../drop-and-fusion/square_monos/keycap_6.png | Bin 0 -> 32100 bytes .../drop-and-fusion/square_monos/keycap_7.png | Bin 0 -> 31318 bytes .../drop-and-fusion/square_monos/keycap_8.png | Bin 0 -> 32886 bytes .../drop-and-fusion/square_monos/keycap_9.png | Bin 0 -> 32483 bytes .../sweets_monos/candy_color.svg | 86 + .../sweets_monos/chocolate_bar_color.svg | 316 + .../sweets_monos/cookie_color.svg | 116 + .../sweets_monos/custard_color.svg | 22 + .../sweets_monos/doughnut_color.svg | 272 + .../sweets_monos/lollipop_color.svg | 112 + .../sweets_monos/pancakes_color.svg | 92 + .../sweets_monos/shaved_ice_color.svg | 161 + .../sweets_monos/shortcake_color.svg | 48 + .../sweets_monos/soft_ice_cream_color.svg | 140 + .../sweets_monos/verts/candy_color.svg | 5 + .../verts/chocolate_bar_color.svg | 5 + .../sweets_monos/verts/custard_color.svg | 5 + .../sweets_monos/verts/doughnut_color.svg | 5 + .../sweets_monos/verts/lollipop_color.svg | 5 + .../sweets_monos/verts/pancakes_color.svg | 5 + .../sweets_monos/verts/shaved_ice_color.svg | 5 + .../sweets_monos/verts/shortcake_color.svg | 5 + .../verts/soft_ice_cream_color.svg | 5 + .../drop-and-fusion/yen_monos/10000yen.png | Bin 0 -> 93558 bytes .../drop-and-fusion/yen_monos/1000yen.png | Bin 0 -> 98316 bytes .../drop-and-fusion/yen_monos/100yen.png | Bin 0 -> 55276 bytes .../drop-and-fusion/yen_monos/10yen.png | Bin 0 -> 67485 bytes .../assets/drop-and-fusion/yen_monos/1yen.png | Bin 0 -> 57534 bytes .../drop-and-fusion/yen_monos/2000yen.png | Bin 0 -> 88045 bytes .../drop-and-fusion/yen_monos/5000yen.png | Bin 0 -> 94334 bytes .../drop-and-fusion/yen_monos/500yen.png | Bin 0 -> 67547 bytes .../drop-and-fusion/yen_monos/50yen.png | Bin 0 -> 41915 bytes .../assets/drop-and-fusion/yen_monos/5yen.png | Bin 0 -> 60516 bytes packages/frontend/assets/dummy.png | Bin 0 -> 6285 bytes packages/frontend/assets/fedi.jpg | Bin 0 -> 77752 bytes packages/frontend/assets/label-red.svg | 6 + packages/frontend/assets/label.svg | 6 + packages/frontend/assets/oneko.gif | Bin 0 -> 3316 bytes packages/frontend/assets/remove.png | Bin 0 -> 424 bytes packages/frontend/assets/reversi/logo.png | Bin 0 -> 185387 bytes packages/frontend/assets/reversi/lose.mp3 | Bin 0 -> 9565 bytes packages/frontend/assets/reversi/matched.mp3 | Bin 0 -> 43884 bytes packages/frontend/assets/reversi/put.mp3 | Bin 0 -> 5014 bytes packages/frontend/assets/reversi/stone_b.png | Bin 0 -> 10794 bytes packages/frontend/assets/reversi/stone_w.png | Bin 0 -> 11546 bytes packages/frontend/assets/reversi/win.mp3 | Bin 0 -> 25703 bytes packages/frontend/assets/sharkey.svg | 1 + packages/frontend/assets/sounds/aisha/1.mp3 | Bin 0 -> 34480 bytes packages/frontend/assets/sounds/aisha/2.mp3 | Bin 0 -> 24031 bytes packages/frontend/assets/sounds/aisha/3.mp3 | Bin 0 -> 29256 bytes .../assets/sounds/noizenecio/kick_gaba1.mp3 | Bin 0 -> 18866 bytes .../assets/sounds/noizenecio/kick_gaba2.mp3 | Bin 0 -> 27144 bytes .../assets/sounds/noizenecio/kick_gaba3.mp3 | Bin 0 -> 19853 bytes .../assets/sounds/noizenecio/kick_gaba4.mp3 | Bin 0 -> 19853 bytes .../assets/sounds/noizenecio/kick_gaba5.mp3 | Bin 0 -> 19853 bytes .../assets/sounds/noizenecio/kick_gaba6.mp3 | Bin 0 -> 19853 bytes .../assets/sounds/noizenecio/kick_gaba7.mp3 | Bin 0 -> 19853 bytes .../frontend/assets/sounds/syuilo/bubble1.mp3 | Bin 0 -> 19328 bytes .../frontend/assets/sounds/syuilo/bubble2.mp3 | Bin 0 -> 19328 bytes .../frontend/assets/sounds/syuilo/down.mp3 | Bin 0 -> 18240 bytes .../frontend/assets/sounds/syuilo/kick.mp3 | Bin 0 -> 15672 bytes .../assets/sounds/syuilo/n-aec-4va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-aec-4vb.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-aec-8va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-aec-8vb.mp3 | Bin 0 -> 26880 bytes .../frontend/assets/sounds/syuilo/n-aec.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-cea-4va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-cea-4vb.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-cea-8va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-cea-8vb.mp3 | Bin 0 -> 26880 bytes .../frontend/assets/sounds/syuilo/n-cea.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-ea-4va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-ea-4vb.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-ea-8va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-ea-8vb.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-ea-harmony.mp3 | Bin 0 -> 26880 bytes .../frontend/assets/sounds/syuilo/n-ea.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-eca-4va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-eca-4vb.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-eca-8va.mp3 | Bin 0 -> 26880 bytes .../assets/sounds/syuilo/n-eca-8vb.mp3 | Bin 0 -> 26880 bytes .../frontend/assets/sounds/syuilo/n-eca.mp3 | Bin 0 -> 26880 bytes .../sounds/syuilo/pirori-square-wet.mp3 | Bin 0 -> 139200 bytes .../assets/sounds/syuilo/pirori-wet.mp3 | Bin 0 -> 139200 bytes .../frontend/assets/sounds/syuilo/pirori.mp3 | Bin 0 -> 19200 bytes .../frontend/assets/sounds/syuilo/poi1.mp3 | Bin 0 -> 18240 bytes .../frontend/assets/sounds/syuilo/poi2.mp3 | Bin 0 -> 18240 bytes .../frontend/assets/sounds/syuilo/pope1.mp3 | Bin 0 -> 18240 bytes .../frontend/assets/sounds/syuilo/pope2.mp3 | Bin 0 -> 18240 bytes .../frontend/assets/sounds/syuilo/popo.mp3 | Bin 0 -> 18240 bytes .../assets/sounds/syuilo/queue-jammed.mp3 | Bin 0 -> 351466 bytes .../assets/sounds/syuilo/reverved.mp3 | Bin 0 -> 276480 bytes .../frontend/assets/sounds/syuilo/ryukyu.mp3 | Bin 0 -> 139200 bytes .../frontend/assets/sounds/syuilo/snare.mp3 | Bin 0 -> 26121 bytes .../assets/sounds/syuilo/square-pico.mp3 | Bin 0 -> 19200 bytes .../frontend/assets/sounds/syuilo/triple.mp3 | Bin 0 -> 18240 bytes packages/frontend/assets/sounds/syuilo/up.mp3 | Bin 0 -> 18240 bytes .../frontend/assets/sounds/syuilo/waon.mp3 | Bin 0 -> 18240 bytes packages/frontend/assets/status/error.png | Bin 0 -> 26966 bytes .../frontend/assets/status/missingpage.webp | Bin 0 -> 6578 bytes .../frontend/assets/status/nothinghere.png | Bin 0 -> 36452 bytes packages/frontend/assets/tagcanvas.min.js | 21 + packages/frontend/assets/testcaptcha.png | Bin 0 -> 2634 bytes packages/frontend/assets/tutorial/ai.webp | Bin 0 -> 12238 bytes .../assets/tutorial/natto_failed.webp | Bin 0 -> 13196 bytes .../frontend/assets/tutorial/timeline_tab.png | Bin 0 -> 2860 bytes packages/frontend/assets/unread.svg | 7 + packages/frontend/eslint.config.js | 112 + ...lugin-unwind-css-module-class-name.test.ts | 599 + ...lup-plugin-unwind-css-module-class-name.ts | 483 + packages/frontend/package.json | 147 + packages/frontend/public/mockServiceWorker.js | 308 + packages/frontend/src/_boot_.ts | 19 + packages/frontend/src/_dev_boot_.ts | 90 + packages/frontend/src/account.ts | 391 + packages/frontend/src/boot/common.ts | 319 + packages/frontend/src/boot/main-boot.ts | 408 + packages/frontend/src/boot/sub-boot.ts | 16 + packages/frontend/src/cache.ts | 14 + .../frontend/src/components/CkFollowMouse.vue | 86 + .../frontend/src/components/MkAbuseReport.vue | 154 + .../MkAbuseReportWindow.stories.impl.ts | 54 + .../src/components/MkAbuseReportWindow.vue | 72 + .../components/MkAccountMoved.stories.impl.ts | 49 + .../src/components/MkAccountMoved.vue | 43 + .../components/MkAchievements.stories.impl.ts | 61 + .../src/components/MkAchievements.vue | 240 + .../components/MkAnalogClock.stories.impl.ts | 42 + .../frontend/src/components/MkAnalogClock.vue | 237 + packages/frontend/src/components/MkAnimBg.vue | 270 + .../MkAnnouncementDialog.stories.impl.ts | 65 + .../src/components/MkAnnouncementDialog.vue | 105 + .../MkAntennaEditor.stories.impl.ts | 62 + .../src/components/MkAntennaEditor.vue | 175 + .../MkAntennaEditorDialog.stories.impl.ts | 63 + .../src/components/MkAntennaEditorDialog.vue | 63 + .../src/components/MkAsUi.stories.impl.ts | 7 + packages/frontend/src/components/MkAsUi.vue | 171 + .../components/MkAuthConfirm.stories.impl.ts | 7 + .../frontend/src/components/MkAuthConfirm.vue | 450 + .../components/MkAutocomplete.stories.impl.ts | 180 + .../src/components/MkAutocomplete.vue | 463 + .../src/components/MkAvatars.stories.impl.ts | 51 + .../frontend/src/components/MkAvatars.vue | 34 + .../src/components/MkButton.stories.impl.ts | 84 + packages/frontend/src/components/MkButton.vue | 296 + .../src/components/MkCaptcha.stories.impl.ts | 7 + .../frontend/src/components/MkCaptcha.vue | 188 + .../MkChannelFollowButton.stories.impl.ts | 71 + .../src/components/MkChannelFollowButton.vue | 125 + .../components/MkChannelList.stories.impl.ts | 65 + .../frontend/src/components/MkChannelList.vue | 34 + .../MkChannelPreview.stories.impl.ts | 43 + .../src/components/MkChannelPreview.vue | 225 + .../src/components/MkChart.stories.impl.ts | 80 + packages/frontend/src/components/MkChart.vue | 873 + .../components/MkChartLegend.stories.impl.ts | 7 + .../frontend/src/components/MkChartLegend.vue | 85 + .../components/MkChartTooltip.stories.impl.ts | 7 + .../src/components/MkChartTooltip.vue | 54 + .../components/MkClickerGame.stories.impl.ts | 77 + .../frontend/src/components/MkClickerGame.vue | 97 + .../components/MkClipPreview.stories.impl.ts | 44 + .../frontend/src/components/MkClipPreview.vue | 79 + .../components/MkCode.core.stories.impl.ts | 7 + .../frontend/src/components/MkCode.core.vue | 163 + .../src/components/MkCode.stories.impl.ts | 44 + packages/frontend/src/components/MkCode.vue | 105 + .../components/MkCodeEditor.stories.impl.ts | 62 + .../frontend/src/components/MkCodeEditor.vue | 218 + .../components/MkCodeInline.stories.impl.ts | 37 + .../frontend/src/components/MkCodeInline.vue | 25 + .../components/MkColorInput.stories.impl.ts | 50 + .../frontend/src/components/MkColorInput.vue | 114 + .../components/MkContainer.stories.impl.ts | 7 + .../frontend/src/components/MkContainer.vue | 250 + .../components/MkContextMenu.stories.impl.ts | 58 + .../frontend/src/components/MkContextMenu.vue | 98 + .../MkCropperDialog.stories.impl.ts | 75 + .../src/components/MkCropperDialog.vue | 193 + ...kCustomEmojiDetailedDialog.stories.impl.ts | 38 + .../MkCustomEmojiDetailedDialog.vue | 108 + .../src/components/MkCwButton.stories.impl.ts | 79 + .../frontend/src/components/MkCwButton.vue | 56 + .../MkDateSeparatedList.stories.impl.ts | 7 + .../src/components/MkDateSeparatedList.vue | 271 + .../src/components/MkDialog.stories.impl.ts | 159 + packages/frontend/src/components/MkDialog.vue | 242 + .../components/MkDigitalClock.stories.impl.ts | 37 + .../src/components/MkDigitalClock.vue | 81 + .../src/components/MkDivider.stories.impl.ts | 7 + .../frontend/src/components/MkDivider.vue | 32 + .../src/components/MkDonation.stories.impl.ts | 54 + .../frontend/src/components/MkDonation.vue | 125 + .../components/MkDrive.file.stories.impl.ts | 48 + .../frontend/src/components/MkDrive.file.vue | 254 + .../components/MkDrive.folder.stories.impl.ts | 70 + .../src/components/MkDrive.folder.vue | 391 + .../MkDrive.navFolder.stories.impl.ts | 7 + .../src/components/MkDrive.navFolder.vue | 144 + .../src/components/MkDrive.stories.impl.ts | 82 + packages/frontend/src/components/MkDrive.vue | 884 + .../MkDriveFileThumbnail.stories.impl.ts | 41 + .../src/components/MkDriveFileThumbnail.vue | 104 + .../MkDriveSelectDialog.stories.impl.ts | 7 + .../src/components/MkDriveSelectDialog.vue | 63 + .../components/MkDriveWindow.stories.impl.ts | 7 + .../frontend/src/components/MkDriveWindow.vue | 35 + .../src/components/MkEmbedCodeGenDialog.vue | 414 + .../MkEmojiPicker.section.stories.impl.ts | 7 + .../src/components/MkEmojiPicker.section.vue | 96 + .../components/MkEmojiPicker.stories.impl.ts | 54 + .../frontend/src/components/MkEmojiPicker.vue | 769 + .../MkEmojiPickerDialog.stories.impl.ts | 7 + .../src/components/MkEmojiPickerDialog.vue | 94 + .../MkExtensionInstaller.stories.impl.ts | 83 + .../src/components/MkExtensionInstaller.vue | 146 + .../src/components/MkFeaturedPhotos.vue | 19 + .../components/MkFileCaptionEditWindow.vue | 62 + .../src/components/MkFileListForAdmin.vue | 118 + .../components/MkFlashPreview.stories.impl.ts | 53 + .../src/components/MkFlashPreview.vue | 131 + .../src/components/MkFoldableSection.vue | 139 + packages/frontend/src/components/MkFolder.vue | 245 + .../src/components/MkFollowButton.vue | 233 + .../src/components/MkForgotPassword.vue | 71 + .../src/components/MkFormDialog.file.vue | 71 + .../frontend/src/components/MkFormDialog.vue | 122 + .../frontend/src/components/MkFormFooter.vue | 49 + .../frontend/src/components/MkFukidashi.vue | 100 + .../MkGalleryPostPreview.stories.impl.ts | 95 + .../src/components/MkGalleryPostPreview.vue | 162 + packages/frontend/src/components/MkGoogle.vue | 61 + .../frontend/src/components/MkHeatmap.vue | 239 + .../src/components/MkHorizontalSwipe.vue | 239 + .../src/components/MkImgWithBlurhash.vue | 266 + packages/frontend/src/components/MkInfo.vue | 59 + packages/frontend/src/components/MkInput.vue | 294 + .../MkInstanceCardMini.stories.impl.ts | 65 + .../src/components/MkInstanceCardMini.vue | 117 + .../src/components/MkInstanceStats.vue | 277 + .../src/components/MkInstanceTicker.vue | 85 + .../components/MkInviteCode.stories.impl.ts | 65 + .../frontend/src/components/MkInviteCode.vue | 126 + .../frontend/src/components/MkKeyValue.vue | 63 + .../frontend/src/components/MkLaunchPad.vue | 151 + packages/frontend/src/components/MkLink.vue | 59 + .../frontend/src/components/MkMarquee.vue | 112 + .../frontend/src/components/MkMediaAudio.vue | 524 + .../frontend/src/components/MkMediaBanner.vue | 82 + .../frontend/src/components/MkMediaImage.vue | 271 + .../frontend/src/components/MkMediaList.vue | 382 + .../frontend/src/components/MkMediaRange.vue | 152 + .../frontend/src/components/MkMediaVideo.vue | 737 + .../frontend/src/components/MkMention.vue | 72 + .../frontend/src/components/MkMenu.child.vue | 93 + packages/frontend/src/components/MkMenu.vue | 676 + .../frontend/src/components/MkMiniChart.vue | 78 + packages/frontend/src/components/MkModal.vue | 515 + .../frontend/src/components/MkModalWindow.vue | 149 + packages/frontend/src/components/MkNote.vue | 1358 + .../src/components/MkNoteDetailed.vue | 1180 + .../frontend/src/components/MkNoteHeader.vue | 126 + .../frontend/src/components/MkNotePreview.vue | 99 + .../frontend/src/components/MkNoteSimple.vue | 162 + .../frontend/src/components/MkNoteSub.vue | 544 + packages/frontend/src/components/MkNotes.vue | 82 + .../src/components/MkNotification.vue | 487 + .../components/MkNotificationSelectWindow.vue | 78 + .../src/components/MkNotifications.vue | 116 + packages/frontend/src/components/MkNumber.vue | 43 + .../frontend/src/components/MkNumberDiff.vue | 37 + .../src/components/MkObjectView.value.vue | 149 + .../frontend/src/components/MkObjectView.vue | 19 + packages/frontend/src/components/MkOmit.vue | 84 + .../frontend/src/components/MkPagePreview.vue | 175 + .../frontend/src/components/MkPageWindow.vue | 188 + .../frontend/src/components/MkPagination.vue | 519 + .../src/components/MkPasswordDialog.vue | 76 + .../src/components/MkPlusOneEffect.vue | 77 + packages/frontend/src/components/MkPoll.vue | 176 + .../frontend/src/components/MkPollEditor.vue | 222 + .../frontend/src/components/MkPopupMenu.vue | 80 + .../frontend/src/components/MkPostForm.vue | 1526 + .../src/components/MkPostFormAttaches.vue | 243 + .../src/components/MkPostFormDialog.vue | 59 + .../frontend/src/components/MkPreview.vue | 150 + .../src/components/MkPullToRefresh.vue | 268 + .../MkPushNotificationAllowButton.vue | 178 + packages/frontend/src/components/MkRadio.vue | 134 + packages/frontend/src/components/MkRadios.vue | 87 + packages/frontend/src/components/MkRange.vue | 311 + .../src/components/MkReactionEffect.vue | 75 + .../src/components/MkReactionIcon.vue | 36 + .../src/components/MkReactionTooltip.vue | 48 + .../components/MkReactionsViewer.details.vue | 110 + .../components/MkReactionsViewer.reaction.vue | 241 + .../src/components/MkReactionsViewer.vue | 113 + .../src/components/MkRemoteCaution.vue | 33 + .../src/components/MkRetentionHeatmap.vue | 209 + .../src/components/MkRetentionLineChart.vue | 134 + .../src/components/MkRippleEffect.vue | 122 + .../frontend/src/components/MkRolePreview.vue | 93 + .../src/components/MkScheduleEditor.vue | 66 + .../components/MkSchedulePostListDialog.vue | 62 + packages/frontend/src/components/MkSelect.vue | 312 + .../src/components/MkSignin.input.vue | 206 + .../src/components/MkSignin.passkey.vue | 92 + .../src/components/MkSignin.password.vue | 195 + .../frontend/src/components/MkSignin.totp.vue | 74 + packages/frontend/src/components/MkSignin.vue | 424 + .../src/components/MkSigninDialog.vue | 107 + .../src/components/MkSignupDialog.form.vue | 352 + .../MkSignupDialog.rules.stories.impl.ts | 104 + .../src/components/MkSignupDialog.rules.vue | 193 + .../src/components/MkSignupDialog.vue | 91 + .../components/MkSourceCodeAvailablePopup.vue | 113 + .../frontend/src/components/MkSparkle.vue | 133 + .../src/components/MkSubNoteContent.vue | 175 + .../frontend/src/components/MkSuperMenu.vue | 188 + .../src/components/MkSwitch.button.vue | 91 + packages/frontend/src/components/MkSwitch.vue | 115 + .../components/MkSystemWebhookEditor.impl.ts | 47 + .../src/components/MkSystemWebhookEditor.vue | 312 + packages/frontend/src/components/MkTab.vue | 78 + .../frontend/src/components/MkTagCloud.vue | 91 + .../frontend/src/components/MkTextarea.vue | 234 + .../frontend/src/components/MkTimeline.vue | 306 + packages/frontend/src/components/MkToast.vue | 78 + .../src/components/MkTokenGenerateWindow.vue | 150 + .../frontend/src/components/MkTooltip.vue | 117 + .../src/components/MkTutorialDialog.Note.vue | 128 + .../components/MkTutorialDialog.PostNote.vue | 136 + .../components/MkTutorialDialog.Sensitive.vue | 146 + .../components/MkTutorialDialog.Timeline.vue | 86 + .../src/components/MkTutorialDialog.vue | 260 + .../frontend/src/components/MkUpdated.vue | 64 + .../frontend/src/components/MkUrlPreview.vue | 424 + .../src/components/MkUrlPreviewPopup.vue | 51 + .../src/components/MkUrlWarningDialog.vue | 131 + .../MkUserAnnouncementEditDialog.vue | 150 + .../src/components/MkUserCardMini.vue | 94 + .../frontend/src/components/MkUserInfo.vue | 181 + .../frontend/src/components/MkUserList.vue | 44 + .../src/components/MkUserOnlineIndicator.vue | 61 + .../frontend/src/components/MkUserPopup.vue | 318 + .../src/components/MkUserSelectDialog.vue | 232 + .../MkUserSetupDialog.Follow.stories.impl.ts | 56 + .../components/MkUserSetupDialog.Follow.vue | 68 + .../MkUserSetupDialog.Privacy.stories.impl.ts | 36 + .../components/MkUserSetupDialog.Privacy.vue | 61 + .../MkUserSetupDialog.Profile.stories.impl.ts | 36 + .../components/MkUserSetupDialog.Profile.vue | 108 + .../MkUserSetupDialog.User.stories.impl.ts | 37 + .../src/components/MkUserSetupDialog.User.vue | 105 + .../MkUserSetupDialog.stories.impl.ts | 56 + .../src/components/MkUserSetupDialog.vue | 259 + .../src/components/MkUsersTooltip.vue | 56 + .../src/components/MkVisibilityPicker.vue | 158 + .../MkVisitorDashboard.ActiveUsersChart.vue | 165 + .../src/components/MkVisitorDashboard.vue | 217 + .../src/components/MkWaitingDialog.vue | 79 + .../frontend/src/components/MkWidgets.vue | 181 + packages/frontend/src/components/MkWindow.vue | 655 + .../src/components/MkYouTubePlayer.vue | 80 + .../src/components/SkApprovalUser.vue | 110 + .../frontend/src/components/SkFlashPlayer.vue | 493 + .../src/components/SkFollowingFeedEntry.vue | 124 + .../src/components/SkFollowingRecentNotes.vue | 144 + .../frontend/src/components/SkFormula.vue | 33 + .../src/components/SkInstanceTicker.vue | 95 + .../frontend/src/components/SkMfmWindow.vue | 516 + .../frontend/src/components/SkModPlayer.vue | 697 + packages/frontend/src/components/SkNote.vue | 1421 + .../src/components/SkNoteDetailed.vue | 1270 + .../frontend/src/components/SkNoteHeader.vue | 266 + .../frontend/src/components/SkNoteSimple.vue | 118 + .../frontend/src/components/SkNoteSub.vue | 680 + .../src/components/SkOldNoteWindow.vue | 335 + packages/frontend/src/components/SkOneko.vue | 245 + .../components/SkRemoteFollowersWarning.vue | 32 + .../src/components/SkSearchResultWindow.vue | 36 + .../src/components/SkUserRecentNotes.vue | 110 + .../frontend/src/components/form/link.vue | 109 + .../frontend/src/components/form/section.vue | 55 + .../frontend/src/components/form/slot.vue | 44 + .../frontend/src/components/form/split.vue | 32 + .../frontend/src/components/form/suspense.vue | 70 + .../frontend/src/components/global/I18n.vue | 51 + .../src/components/global/MkA.stories.impl.ts | 51 + .../frontend/src/components/global/MkA.vue | 104 + .../components/global/MkAcct.stories.impl.ts | 80 + .../frontend/src/components/global/MkAcct.vue | 25 + .../components/global/MkAd.stories.impl.ts | 130 + .../frontend/src/components/global/MkAd.vue | 205 + .../global/MkAvatar.stories.impl.ts | 72 + .../src/components/global/MkAvatar.vue | 352 + .../global/MkCondensedLine.stories.impl.ts | 46 + .../src/components/global/MkCondensedLine.vue | 77 + .../global/MkCustomEmoji.stories.impl.ts | 65 + .../src/components/global/MkCustomEmoji.vue | 181 + .../global/MkEllipsis.stories.impl.ts | 37 + .../src/components/global/MkEllipsis.vue | 53 + .../components/global/MkEmoji.stories.impl.ts | 36 + .../src/components/global/MkEmoji.vue | 80 + .../components/global/MkError.stories.impl.ts | 46 + .../components/global/MkError.stories.meta.ts | 13 + .../src/components/global/MkError.vue | 49 + .../src/components/global/MkFooterSpacer.vue | 32 + .../frontend/src/components/global/MkLazy.vue | 53 + .../global/MkLoading.stories.impl.ts | 65 + .../src/components/global/MkLoading.vue | 112 + .../components/global/MkMfm.stories.impl.ts | 77 + .../frontend/src/components/global/MkMfm.ts | 547 + .../global/MkPageHeader.stories.impl.ts | 103 + .../global/MkPageHeader.tabs.stories.impl.ts | 8 + .../components/global/MkPageHeader.tabs.vue | 261 + .../src/components/global/MkPageHeader.vue | 318 + .../src/components/global/MkSpacer.vue | 57 + .../global/MkStickyContainer.stories.impl.ts | 8 + .../components/global/MkStickyContainer.vue | 105 + .../components/global/MkTime.stories.impl.ts | 318 + .../frontend/src/components/global/MkTime.vue | 108 + .../components/global/MkUrl.stories.impl.ts | 81 + .../frontend/src/components/global/MkUrl.vue | 116 + .../global/MkUserName.stories.impl.ts | 61 + .../src/components/global/MkUserName.vue | 20 + .../global/RouterView.stories.impl.ts | 8 + .../src/components/global/RouterView.vue | 101 + .../frontend/src/components/global/SkLazy.vue | 57 + packages/frontend/src/components/index.ts | 84 + .../src/components/page/page.block.vue | 48 + .../src/components/page/page.dynamic.vue | 43 + .../src/components/page/page.image.vue | 40 + .../src/components/page/page.note.vue | 41 + .../src/components/page/page.section.vue | 53 + .../src/components/page/page.text.vue | 36 + .../frontend/src/components/page/page.vue | 29 + packages/frontend/src/custom-emojis.ts | 76 + packages/frontend/src/debug.ts | 32 + .../frontend/src/directives/adaptive-bg.ts | 21 + .../src/directives/adaptive-border.ts | 21 + packages/frontend/src/directives/anim.ts | 23 + packages/frontend/src/directives/appear.ts | 27 + .../frontend/src/directives/click-anime.ts | 40 + .../frontend/src/directives/follow-append.ts | 40 + packages/frontend/src/directives/get-size.ts | 59 + packages/frontend/src/directives/hotkey.ts | 29 + packages/frontend/src/directives/index.ts | 39 + packages/frontend/src/directives/panel.ts | 21 + packages/frontend/src/directives/ripple.ts | 25 + packages/frontend/src/directives/tooltip.ts | 108 + .../frontend/src/directives/user-preview.ts | 123 + packages/frontend/src/events.ts | 13 + packages/frontend/src/filters/bytes.ts | 14 + packages/frontend/src/filters/date.ts | 9 + packages/frontend/src/filters/hms.ts | 65 + packages/frontend/src/filters/kmg.ts | 14 + packages/frontend/src/filters/note.ts | 8 + packages/frontend/src/filters/number.ts | 8 + packages/frontend/src/filters/user.ts | 19 + packages/frontend/src/i18n.ts | 15 + packages/frontend/src/index.html | 39 + packages/frontend/src/index.mdx | 12 + packages/frontend/src/instance.ts | 62 + packages/frontend/src/local-storage.ts | 68 + packages/frontend/src/navbar.ts | 199 + packages/frontend/src/nirax.ts | 467 + packages/frontend/src/os.ts | 743 + packages/frontend/src/pages/_empty_.vue | 12 + packages/frontend/src/pages/_error_.vue | 88 + packages/frontend/src/pages/_loading_.vue | 11 + packages/frontend/src/pages/about-sharkey.vue | 484 + packages/frontend/src/pages/about.emojis.vue | 98 + .../frontend/src/pages/about.federation.vue | 110 + .../frontend/src/pages/about.overview.vue | 263 + packages/frontend/src/pages/about.vue | 75 + packages/frontend/src/pages/achievements.vue | 59 + packages/frontend/src/pages/admin-file.vue | 174 + packages/frontend/src/pages/admin-user.vue | 701 + .../src/pages/admin/RolesEditorFormula.vue | 166 + .../frontend/src/pages/admin/_header_.vue | 296 + .../notification-recipient.editor.vue | 321 + .../notification-recipient.item.vue | 114 + .../abuse-report/notification-recipient.vue | 177 + packages/frontend/src/pages/admin/abuses.vue | 130 + packages/frontend/src/pages/admin/ads.vue | 275 + .../src/pages/admin/announcements.vue | 206 + .../frontend/src/pages/admin/approvals.vue | 72 + .../src/pages/admin/bot-protection.vue | 182 + .../frontend/src/pages/admin/branding.vue | 224 + .../frontend/src/pages/admin/database.vue | 40 + .../src/pages/admin/email-settings.vue | 144 + .../src/pages/admin/external-services.vue | 86 + .../frontend/src/pages/admin/federation.vue | 134 + packages/frontend/src/pages/admin/files.vue | 92 + packages/frontend/src/pages/admin/index.vue | 375 + packages/frontend/src/pages/admin/invites.vue | 132 + .../frontend/src/pages/admin/moderation.vue | 326 + .../src/pages/admin/modlog.ModLog.vue | 233 + packages/frontend/src/pages/admin/modlog.vue | 66 + .../src/pages/admin/object-storage.vue | 163 + .../src/pages/admin/overview.active-users.vue | 170 + .../overview.ap-requests.stories.impl.ts | 41 + .../src/pages/admin/overview.ap-requests.vue | 288 + .../src/pages/admin/overview.federation.vue | 195 + .../src/pages/admin/overview.heatmap.vue | 31 + .../src/pages/admin/overview.instances.vue | 55 + .../src/pages/admin/overview.moderators.vue | 60 + .../frontend/src/pages/admin/overview.pie.vue | 81 + .../src/pages/admin/overview.queue.chart.vue | 139 + .../src/pages/admin/overview.queue.vue | 132 + .../src/pages/admin/overview.retention.vue | 20 + .../src/pages/admin/overview.stats.vue | 178 + .../src/pages/admin/overview.users.vue | 64 + .../frontend/src/pages/admin/overview.vue | 199 + .../frontend/src/pages/admin/performance.vue | 209 + .../src/pages/admin/queue.chart.chart.vue | 139 + .../frontend/src/pages/admin/queue.chart.vue | 160 + packages/frontend/src/pages/admin/queue.vue | 77 + packages/frontend/src/pages/admin/relays.vue | 98 + .../frontend/src/pages/admin/roles.edit.vue | 101 + .../frontend/src/pages/admin/roles.editor.vue | 849 + .../frontend/src/pages/admin/roles.role.vue | 217 + packages/frontend/src/pages/admin/roles.vue | 365 + .../frontend/src/pages/admin/security.vue | 144 + .../frontend/src/pages/admin/server-rules.vue | 133 + .../frontend/src/pages/admin/settings.vue | 443 + .../src/pages/admin/system-webhook.item.vue | 80 + .../src/pages/admin/system-webhook.vue | 93 + packages/frontend/src/pages/admin/users.vue | 163 + packages/frontend/src/pages/ads.vue | 28 + packages/frontend/src/pages/announcement.vue | 151 + packages/frontend/src/pages/announcements.vue | 150 + .../frontend/src/pages/antenna-timeline.vue | 122 + packages/frontend/src/pages/api-console.vue | 94 + packages/frontend/src/pages/auth.form.vue | 70 + packages/frontend/src/pages/auth.vue | 132 + .../pages/avatar-decoration-edit-dialog.vue | 220 + .../frontend/src/pages/avatar-decorations.vue | 118 + .../frontend/src/pages/channel-editor.vue | 239 + packages/frontend/src/pages/channel.vue | 375 + packages/frontend/src/pages/channels.vue | 159 + packages/frontend/src/pages/clicker.vue | 27 + packages/frontend/src/pages/clip.vue | 217 + packages/frontend/src/pages/contact.vue | 48 + .../src/pages/custom-emojis-manager.vue | 431 + .../frontend/src/pages/drive.file.info.vue | 344 + .../frontend/src/pages/drive.file.notes.vue | 33 + packages/frontend/src/pages/drive.file.vue | 55 + packages/frontend/src/pages/drive.vue | 30 + .../src/pages/drop-and-fusion.game.vue | 1510 + .../frontend/src/pages/drop-and-fusion.vue | 160 + .../frontend/src/pages/emoji-edit-dialog.vue | 252 + packages/frontend/src/pages/emojis.emoji.vue | 116 + .../frontend/src/pages/explore.featured.vue | 38 + packages/frontend/src/pages/explore.roles.vue | 26 + packages/frontend/src/pages/explore.users.vue | 140 + packages/frontend/src/pages/explore.vue | 67 + packages/frontend/src/pages/favorites.vue | 59 + .../frontend/src/pages/flash/flash-edit.vue | 474 + .../frontend/src/pages/flash/flash-index.vue | 98 + packages/frontend/src/pages/flash/flash.vue | 403 + .../frontend/src/pages/follow-requests.vue | 195 + .../frontend/src/pages/following-feed.vue | 185 + packages/frontend/src/pages/gallery/edit.vue | 155 + packages/frontend/src/pages/gallery/index.vue | 135 + packages/frontend/src/pages/gallery/post.vue | 330 + packages/frontend/src/pages/games.vue | 41 + .../frontend/src/pages/install-extensions.vue | 286 + packages/frontend/src/pages/instance-info.vue | 512 + packages/frontend/src/pages/invite.vue | 118 + packages/frontend/src/pages/list.vue | 156 + packages/frontend/src/pages/lookup.vue | 97 + packages/frontend/src/pages/miauth.vue | 121 + .../frontend/src/pages/my-antennas/create.vue | 36 + .../frontend/src/pages/my-antennas/edit.vue | 48 + .../frontend/src/pages/my-antennas/index.vue | 88 + .../frontend/src/pages/my-clips/index.vue | 111 + .../frontend/src/pages/my-lists/index.vue | 102 + packages/frontend/src/pages/my-lists/list.vue | 241 + packages/frontend/src/pages/not-found.vue | 38 + packages/frontend/src/pages/note.vue | 215 + packages/frontend/src/pages/notifications.vue | 108 + packages/frontend/src/pages/oauth.vue | 103 + .../frontend/src/pages/page-editor/common.ts | 15 + .../page-editor/els/page-editor.el.image.vue | 64 + .../page-editor/els/page-editor.el.note.vue | 65 + .../els/page-editor.el.section.vue | 101 + .../page-editor/els/page-editor.el.text.vue | 71 + .../pages/page-editor/page-editor.blocks.vue | 71 + .../page-editor/page-editor.container.vue | 129 + .../src/pages/page-editor/page-editor.vue | 384 + packages/frontend/src/pages/page.vue | 539 + packages/frontend/src/pages/pages.vue | 95 + packages/frontend/src/pages/preview.vue | 26 + packages/frontend/src/pages/registry.keys.vue | 103 + .../frontend/src/pages/registry.value.vue | 130 + packages/frontend/src/pages/registry.vue | 80 + .../frontend/src/pages/reset-password.vue | 62 + .../frontend/src/pages/reversi/game.board.vue | 623 + .../src/pages/reversi/game.setting.vue | 298 + packages/frontend/src/pages/reversi/game.vue | 121 + packages/frontend/src/pages/reversi/index.vue | 353 + packages/frontend/src/pages/role.vue | 120 + packages/frontend/src/pages/scratchpad.vue | 276 + packages/frontend/src/pages/search.note.vue | 260 + .../frontend/src/pages/search.stories.impl.ts | 88 + packages/frontend/src/pages/search.user.vue | 127 + packages/frontend/src/pages/search.vue | 75 + .../src/pages/settings/2fa.qrdialog.vue | 198 + packages/frontend/src/pages/settings/2fa.vue | 229 + .../frontend/src/pages/settings/accounts.vue | 117 + packages/frontend/src/pages/settings/api.vue | 53 + packages/frontend/src/pages/settings/apps.vue | 101 + .../settings/avatar-decoration.decoration.vue | 75 + .../settings/avatar-decoration.dialog.vue | 168 + .../src/pages/settings/avatar-decoration.vue | 159 + .../src/pages/settings/custom-css.vue | 52 + packages/frontend/src/pages/settings/deck.vue | 43 + .../src/pages/settings/drive-cleaner.vue | 206 + .../frontend/src/pages/settings/drive.vue | 163 + .../frontend/src/pages/settings/email.vue | 120 + .../src/pages/settings/emoji-picker.vue | 316 + .../frontend/src/pages/settings/general.vue | 636 + .../src/pages/settings/import-export.vue | 263 + .../frontend/src/pages/settings/index.vue | 294 + .../frontend/src/pages/settings/migration.vue | 135 + .../settings/mute-block.instance-mute.vue | 50 + .../src/pages/settings/mute-block.vue | 276 + .../pages/settings/mute-block.word-mute.vue | 92 + .../frontend/src/pages/settings/navbar.vue | 152 + .../notifications.notification-config.vue | 75 + .../src/pages/settings/notifications.vue | 144 + .../frontend/src/pages/settings/other.vue | 192 + .../src/pages/settings/plugin.install.vue | 60 + .../frontend/src/pages/settings/plugin.vue | 146 + .../pages/settings/preferences-backups.vue | 489 + .../frontend/src/pages/settings/privacy.vue | 265 + .../frontend/src/pages/settings/profile.vue | 504 + .../frontend/src/pages/settings/roles.vue | 48 + .../frontend/src/pages/settings/security.vue | 162 + .../src/pages/settings/sounds.sound.vue | 208 + .../frontend/src/pages/settings/sounds.vue | 105 + .../pages/settings/statusbar.statusbar.vue | 145 + .../frontend/src/pages/settings/statusbar.vue | 57 + .../src/pages/settings/theme.install.vue | 66 + .../src/pages/settings/theme.manage.vue | 83 + .../frontend/src/pages/settings/theme.vue | 424 + .../src/pages/settings/webhook.edit.vue | 189 + .../src/pages/settings/webhook.new.vue | 89 + .../frontend/src/pages/settings/webhook.vue | 57 + packages/frontend/src/pages/share.vue | 206 + .../frontend/src/pages/signup-complete.vue | 94 + packages/frontend/src/pages/tag.vue | 89 + packages/frontend/src/pages/theme-editor.vue | 280 + packages/frontend/src/pages/timeline.vue | 388 + .../frontend/src/pages/user-list-timeline.vue | 139 + packages/frontend/src/pages/user-tag.vue | 42 + .../frontend/src/pages/user/achievements.vue | 56 + .../src/pages/user/activity.following.vue | 180 + .../src/pages/user/activity.notes.vue | 179 + .../frontend/src/pages/user/activity.pv.vue | 190 + packages/frontend/src/pages/user/activity.vue | 41 + packages/frontend/src/pages/user/clips.vue | 48 + packages/frontend/src/pages/user/flashs.vue | 31 + .../frontend/src/pages/user/follow-list.vue | 50 + .../frontend/src/pages/user/followers.vue | 65 + .../frontend/src/pages/user/following.vue | 65 + packages/frontend/src/pages/user/gallery.vue | 43 + .../src/pages/user/home.stories.impl.ts | 81 + packages/frontend/src/pages/user/home.vue | 863 + .../src/pages/user/index.activity.vue | 66 + .../frontend/src/pages/user/index.files.vue | 129 + .../src/pages/user/index.listenbrainz.vue | 140 + .../src/pages/user/index.timeline.vue | 81 + packages/frontend/src/pages/user/index.vue | 157 + packages/frontend/src/pages/user/lists.vue | 56 + packages/frontend/src/pages/user/pages.vue | 31 + packages/frontend/src/pages/user/raw.vue | 130 + .../frontend/src/pages/user/reactions.vue | 64 + .../frontend/src/pages/user/recent-notes.vue | 79 + .../frontend/src/pages/welcome.entrance.a.vue | 200 + packages/frontend/src/pages/welcome.setup.vue | 123 + .../src/pages/welcome.timeline.note.vue | 109 + .../frontend/src/pages/welcome.timeline.vue | 102 + packages/frontend/src/pages/welcome.vue | 36 + packages/frontend/src/pizzax.ts | 300 + packages/frontend/src/plugin.ts | 183 + packages/frontend/src/router/definition.ts | 605 + packages/frontend/src/router/main.ts | 198 + packages/frontend/src/router/supplier.ts | 30 + packages/frontend/src/scripts/achievements.ts | 513 + packages/frontend/src/scripts/admin-lookup.ts | 88 + packages/frontend/src/scripts/aiscript/api.ts | 93 + packages/frontend/src/scripts/aiscript/ui.ts | 625 + packages/frontend/src/scripts/array.ts | 118 + packages/frontend/src/scripts/autocomplete.ts | 316 + packages/frontend/src/scripts/boost-quote.ts | 81 + packages/frontend/src/scripts/cache.ts | 53 + packages/frontend/src/scripts/chart-legend.ts | 17 + packages/frontend/src/scripts/chart-vline.ts | 28 + .../src/scripts/check-animated-mfm.ts | 36 + .../frontend/src/scripts/check-permissions.ts | 19 + .../src/scripts/check-reaction-permissions.ts | 17 + .../frontend/src/scripts/check-word-mute.ts | 65 + packages/frontend/src/scripts/chiptune2.ts | 347 + packages/frontend/src/scripts/clear-cache.ts | 24 + packages/frontend/src/scripts/clicker-game.ts | 73 + packages/frontend/src/scripts/clone.ts | 25 + .../frontend/src/scripts/code-highlighter.ts | 97 + .../frontend/src/scripts/collect-page-vars.ts | 73 + packages/frontend/src/scripts/color.ts | 12 + packages/frontend/src/scripts/confetti.ts | 30 + packages/frontend/src/scripts/contains.ts | 14 + .../frontend/src/scripts/copy-to-clipboard.ts | 11 + packages/frontend/src/scripts/device-kind.ts | 24 + packages/frontend/src/scripts/emoji-picker.ts | 60 + .../frontend/src/scripts/extract-mentions.ts | 16 + .../src/scripts/extract-url-from-mfm.ts | 24 + packages/frontend/src/scripts/favicon-dot.ts | 145 + packages/frontend/src/scripts/focus-trap.ts | 134 + packages/frontend/src/scripts/focus.ts | 80 + .../src/scripts/following-feed-utils.ts | 181 + packages/frontend/src/scripts/form.ts | 104 + .../src/scripts/format-time-string.ts | 55 + packages/frontend/src/scripts/fullscreen.ts | 46 + .../frontend/src/scripts/gen-search-query.ts | 35 + .../src/scripts/get-account-from-id.ts | 12 + .../frontend/src/scripts/get-appear-note.ts | 10 + packages/frontend/src/scripts/get-bg-color.ts | 18 + .../src/scripts/get-dom-node-or-null.ts | 19 + .../src/scripts/get-drive-file-menu.ts | 162 + .../frontend/src/scripts/get-embed-code.ts | 87 + .../frontend/src/scripts/get-note-menu.ts | 708 + .../frontend/src/scripts/get-note-summary.ts | 64 + .../src/scripts/get-note-versions-menu.ts | 69 + .../frontend/src/scripts/get-user-menu.ts | 439 + .../frontend/src/scripts/get-user-name.ts | 8 + packages/frontend/src/scripts/hotkey.ts | 172 + packages/frontend/src/scripts/idb-proxy.ts | 53 + packages/frontend/src/scripts/idle-render.ts | 60 + packages/frontend/src/scripts/init-chart.ts | 58 + .../frontend/src/scripts/initialize-sw.ts | 18 + .../frontend/src/scripts/install-plugin.ts | 135 + .../frontend/src/scripts/install-theme.ts | 37 + packages/frontend/src/scripts/intl-const.ts | 50 + .../src/scripts/is-device-darkmode.ts | 8 + .../frontend/src/scripts/isFfVisibleForMe.ts | 24 + packages/frontend/src/scripts/langmap.ts | 671 + .../frontend/src/scripts/libopenmpt/LICENSE | 25 + .../src/scripts/libopenmpt/libopenmpt.js | 8 + .../src/scripts/libopenmpt/libopenmpt.wasm | Bin 0 -> 1101696 bytes .../frontend/src/scripts/libopenmpt/readme.md | 23 + packages/frontend/src/scripts/login-id.ts | 16 + packages/frontend/src/scripts/lookup.ts | 48 + .../frontend/src/scripts/media-has-audio.ts | 14 + packages/frontend/src/scripts/media-proxy.ts | 34 + packages/frontend/src/scripts/merge.ts | 35 + .../src/scripts/mfm-function-picker.ts | 56 + packages/frontend/src/scripts/misskey-api.ts | 104 + packages/frontend/src/scripts/navigator.ts | 8 + .../frontend/src/scripts/page-metadata.ts | 70 + packages/frontend/src/scripts/physics.ts | 157 + .../src/scripts/player-url-transform.ts | 26 + packages/frontend/src/scripts/please-login.ts | 68 + packages/frontend/src/scripts/popout.ts | 28 + .../frontend/src/scripts/popup-position.ts | 171 + packages/frontend/src/scripts/post-message.ts | 25 + .../frontend/src/scripts/reaction-picker.ts | 53 + packages/frontend/src/scripts/reload-ask.ts | 40 + .../frontend/src/scripts/sanitize-html.ts | 18 + packages/frontend/src/scripts/search-emoji.ts | 106 + .../frontend/src/scripts/search-engine-map.ts | 17 + packages/frontend/src/scripts/select-file.ts | 116 + .../frontend/src/scripts/show-moved-dialog.ts | 21 + .../src/scripts/show-suspended-dialog.ts | 15 + .../src/scripts/show-system-account-dialog.ts | 15 + packages/frontend/src/scripts/shuffle.ts | 25 + .../frontend/src/scripts/snowfall-effect.ts | 490 + packages/frontend/src/scripts/sound.ts | 253 + .../frontend/src/scripts/sticky-sidebar.ts | 55 + packages/frontend/src/scripts/stream-mock.ts | 81 + packages/frontend/src/scripts/test-utils.ts | 9 + packages/frontend/src/scripts/theme-editor.ts | 86 + packages/frontend/src/scripts/theme.ts | 190 + packages/frontend/src/scripts/time.ts | 45 + packages/frontend/src/scripts/timezones.ts | 54 + packages/frontend/src/scripts/touch.ts | 22 + .../frontend/src/scripts/unison-reload.ts | 20 + packages/frontend/src/scripts/upload.ts | 162 + .../src/scripts/upload/compress-config.ts | 36 + .../src/scripts/upload/isWebpSupported.ts | 15 + .../frontend/src/scripts/use-chart-tooltip.ts | 63 + packages/frontend/src/scripts/use-form.ts | 55 + .../frontend/src/scripts/use-leave-guard.ts | 50 + .../frontend/src/scripts/use-note-capture.ts | 162 + packages/frontend/src/scripts/use-tooltip.ts | 105 + .../src/scripts/warning-external-website.ts | 52 + packages/frontend/src/server-context.ts | 23 + packages/frontend/src/store.ts | 703 + packages/frontend/src/stream.ts | 51 + packages/frontend/src/style.scss | 734 + packages/frontend/src/theme-store.ts | 47 + packages/frontend/src/timelines.ts | 61 + packages/frontend/src/type.ts | 8 + .../frontend/src/types/date-separated-list.ts | 11 + packages/frontend/src/types/menu.ts | 30 + packages/frontend/src/types/page-header.ts | 11 + packages/frontend/src/types/post-form.ts | 24 + .../src/types/ruffle/config/default.d.ts | 2 + .../src/types/ruffle/config/index.d.ts | 10 + .../src/types/ruffle/config/load-options.d.ts | 620 + .../src/types/ruffle/player/flash.d.ts | 17 + .../src/types/ruffle/player/index.d.ts | 9 + .../src/types/ruffle/player/legacy.d.ts | 163 + .../types/ruffle/player/movie-metadata.d.ts | 38 + .../types/ruffle/player/player-element.d.ts | 12 + .../src/types/ruffle/setup/index.d.ts | 19 + .../src/types/ruffle/setup/install.d.ts | 28 + .../src/types/ruffle/setup/public-api.d.ts | 133 + .../src/types/ruffle/setup/source-api.d.ts | 34 + .../src/ui/_common_/announcements.vue | 80 + packages/frontend/src/ui/_common_/common.ts | 177 + packages/frontend/src/ui/_common_/common.vue | 287 + .../src/ui/_common_/navbar-for-mobile.vue | 279 + packages/frontend/src/ui/_common_/navbar.vue | 635 + .../frontend/src/ui/_common_/notification.vue | 29 + .../src/ui/_common_/statusbar-federation.vue | 118 + .../src/ui/_common_/statusbar-rss.vue | 105 + .../src/ui/_common_/statusbar-user-list.vue | 123 + .../frontend/src/ui/_common_/statusbars.vue | 95 + .../src/ui/_common_/stream-indicator.vue | 62 + .../frontend/src/ui/_common_/sw-inject.ts | 50 + packages/frontend/src/ui/_common_/upload.vue | 134 + packages/frontend/src/ui/classic.header.vue | 211 + packages/frontend/src/ui/classic.sidebar.vue | 247 + packages/frontend/src/ui/classic.vue | 336 + packages/frontend/src/ui/deck.vue | 498 + .../frontend/src/ui/deck/antenna-column.vue | 121 + .../frontend/src/ui/deck/channel-column.vue | 119 + packages/frontend/src/ui/deck/column.vue | 451 + packages/frontend/src/ui/deck/deck-store.ts | 341 + .../frontend/src/ui/deck/direct-column.vue | 42 + .../frontend/src/ui/deck/following-column.vue | 124 + packages/frontend/src/ui/deck/list-column.vue | 132 + packages/frontend/src/ui/deck/main-column.vue | 73 + .../frontend/src/ui/deck/mentions-column.vue | 39 + .../src/ui/deck/notifications-column.vue | 48 + .../src/ui/deck/role-timeline-column.vue | 85 + packages/frontend/src/ui/deck/tl-column.vue | 179 + .../src/ui/deck/tl-note-notification.ts | 107 + .../frontend/src/ui/deck/widgets-column.vue | 70 + packages/frontend/src/ui/minimum.vue | 49 + packages/frontend/src/ui/universal.vue | 492 + .../frontend/src/ui/universal.widgets.vue | 81 + packages/frontend/src/ui/visitor.vue | 297 + packages/frontend/src/ui/zen.vue | 89 + .../src/unicode-emoji-indexes/en-US.json | 1805 + .../src/unicode-emoji-indexes/ja-JP.json | 1866 + .../src/unicode-emoji-indexes/ja-JP_hira.json | 1866 + .../src/widgets/WidgetActivity.calendar.vue | 97 + .../src/widgets/WidgetActivity.chart.vue | 107 + .../frontend/src/widgets/WidgetActivity.vue | 98 + .../frontend/src/widgets/WidgetAichan.vue | 77 + .../frontend/src/widgets/WidgetAiscript.vue | 172 + .../src/widgets/WidgetAiscriptApp.vue | 116 + .../src/widgets/WidgetBirthdayFollowings.vue | 144 + .../frontend/src/widgets/WidgetButton.vue | 93 + .../frontend/src/widgets/WidgetCalendar.vue | 218 + .../frontend/src/widgets/WidgetClicker.vue | 45 + packages/frontend/src/widgets/WidgetClock.vue | 211 + .../src/widgets/WidgetDigitalClock.vue | 94 + .../frontend/src/widgets/WidgetFederation.vue | 152 + .../src/widgets/WidgetInstanceCloud.vue | 81 + .../src/widgets/WidgetInstanceInfo.vue | 99 + .../frontend/src/widgets/WidgetJobQueue.vue | 212 + packages/frontend/src/widgets/WidgetMemo.vue | 117 + .../src/widgets/WidgetNotifications.vue | 74 + .../src/widgets/WidgetOnlineUsers.vue | 77 + .../frontend/src/widgets/WidgetPhotos.vue | 127 + .../frontend/src/widgets/WidgetPostForm.vue | 37 + .../frontend/src/widgets/WidgetProfile.vue | 100 + packages/frontend/src/widgets/WidgetRss.vue | 125 + .../frontend/src/widgets/WidgetRssTicker.vue | 184 + .../frontend/src/widgets/WidgetSearch.vue | 181 + .../frontend/src/widgets/WidgetSlideshow.vue | 163 + .../frontend/src/widgets/WidgetTimeline.vue | 156 + .../frontend/src/widgets/WidgetTrends.vue | 125 + .../frontend/src/widgets/WidgetUnixClock.vue | 118 + .../frontend/src/widgets/WidgetUserList.vue | 141 + packages/frontend/src/widgets/index.ts | 70 + .../src/widgets/server-metric/cpu-mem.vue | 174 + .../src/widgets/server-metric/cpu.vue | 71 + .../src/widgets/server-metric/disk.vue | 63 + .../src/widgets/server-metric/index.vue | 91 + .../src/widgets/server-metric/mem.vue | 79 + .../src/widgets/server-metric/net.vue | 147 + .../src/widgets/server-metric/pie.vue | 59 + packages/frontend/src/widgets/widget.ts | 78 + .../frontend/src/workers/draw-blurhash.ts | 22 + packages/frontend/src/workers/test-webgl2.ts | 14 + packages/frontend/src/workers/tsconfig.json | 5 + packages/frontend/test/autocomplete.test.ts | 34 + packages/frontend/test/emoji.test.ts | 41 + packages/frontend/test/home.test.ts | 68 + packages/frontend/test/i18n.test.ts | 56 + packages/frontend/test/init.ts | 57 + packages/frontend/test/note.test.ts | 103 + packages/frontend/test/scroll.test.ts | 66 + packages/frontend/test/tsconfig.json | 43 + packages/frontend/test/url-preview.test.ts | 192 + packages/frontend/tsconfig.json | 59 + packages/frontend/vite.config.local-dev.ts | 102 + packages/frontend/vite.config.ts | 211 + packages/frontend/vite.json5.ts | 48 + packages/frontend/vite.replaceIcons.ts | 394 + packages/frontend/vue-shims.d.ts | 6 + packages/megalodon/.npmignore | 3 + packages/megalodon/package.json | 89 + packages/megalodon/src/axios.d.ts | 1 + packages/megalodon/src/cancel.ts | 13 + packages/megalodon/src/converter.ts | 3 + packages/megalodon/src/default.ts | 3 + packages/megalodon/src/detector.ts | 137 + packages/megalodon/src/entities/account.ts | 36 + packages/megalodon/src/entities/activity.ts | 8 + .../megalodon/src/entities/announcement.ts | 40 + .../megalodon/src/entities/application.ts | 7 + .../src/entities/async_attachment.ts | 14 + packages/megalodon/src/entities/attachment.ts | 49 + packages/megalodon/src/entities/card.ts | 18 + packages/megalodon/src/entities/context.ts | 8 + .../megalodon/src/entities/conversation.ts | 11 + packages/megalodon/src/entities/emoji.ts | 9 + .../megalodon/src/entities/featured_tag.ts | 8 + packages/megalodon/src/entities/field.ts | 7 + packages/megalodon/src/entities/filter.ts | 12 + .../megalodon/src/entities/follow_request.ts | 27 + packages/megalodon/src/entities/history.ts | 7 + .../megalodon/src/entities/identity_proof.ts | 9 + packages/megalodon/src/entities/instance.ts | 40 + packages/megalodon/src/entities/list.ts | 10 + packages/megalodon/src/entities/marker.ts | 15 + packages/megalodon/src/entities/mention.ts | 8 + .../megalodon/src/entities/notification.ts | 16 + packages/megalodon/src/entities/poll.ts | 15 + .../megalodon/src/entities/poll_option.ts | 6 + .../megalodon/src/entities/preferences.ts | 9 + .../src/entities/push_subscription.ts | 16 + packages/megalodon/src/entities/reaction.ts | 10 + .../megalodon/src/entities/relationship.ts | 17 + packages/megalodon/src/entities/report.ts | 18 + packages/megalodon/src/entities/results.ts | 11 + packages/megalodon/src/entities/role.ts | 5 + .../src/entities/scheduled_status.ts | 10 + packages/megalodon/src/entities/source.ts | 10 + packages/megalodon/src/entities/stats.ts | 7 + packages/megalodon/src/entities/status.ts | 50 + .../megalodon/src/entities/status_edit.ts | 23 + .../megalodon/src/entities/status_params.ts | 12 + .../megalodon/src/entities/status_source.ts | 7 + packages/megalodon/src/entities/tag.ts | 10 + packages/megalodon/src/entities/token.ts | 8 + packages/megalodon/src/entities/urls.ts | 5 + packages/megalodon/src/entity.ts | 40 + packages/megalodon/src/filter_context.ts | 11 + packages/megalodon/src/friendica.ts | 2868 ++ .../megalodon/src/friendica/api_client.ts | 769 + .../src/friendica/entities/account.ts | 29 + .../src/friendica/entities/activity.ts | 8 + .../src/friendica/entities/application.ts | 7 + .../friendica/entities/async_attachment.ts | 14 + .../src/friendica/entities/attachment.ts | 49 + .../megalodon/src/friendica/entities/card.ts | 17 + .../src/friendica/entities/context.ts | 8 + .../src/friendica/entities/conversation.ts | 11 + .../megalodon/src/friendica/entities/emoji.ts | 8 + .../src/friendica/entities/featured_tag.ts | 8 + .../megalodon/src/friendica/entities/field.ts | 7 + .../src/friendica/entities/filter.ts | 12 + .../src/friendica/entities/follow_request.ts | 27 + .../src/friendica/entities/history.ts | 7 + .../src/friendica/entities/identity_proof.ts | 9 + .../src/friendica/entities/instance.ts | 28 + .../megalodon/src/friendica/entities/list.ts | 9 + .../src/friendica/entities/marker.ts | 14 + .../src/friendica/entities/mention.ts | 8 + .../src/friendica/entities/notification.ts | 14 + .../megalodon/src/friendica/entities/poll.ts | 13 + .../src/friendica/entities/poll_option.ts | 6 + .../src/friendica/entities/preferences.ts | 9 + .../friendica/entities/push_subscription.ts | 16 + .../src/friendica/entities/relationship.ts | 17 + .../src/friendica/entities/report.ts | 16 + .../src/friendica/entities/results.ts | 11 + .../friendica/entities/scheduled_status.ts | 10 + .../src/friendica/entities/source.ts | 10 + .../megalodon/src/friendica/entities/stats.ts | 7 + .../src/friendica/entities/status.ts | 49 + .../src/friendica/entities/status_params.ts | 12 + .../src/friendica/entities/status_source.ts | 7 + .../megalodon/src/friendica/entities/tag.ts | 10 + .../megalodon/src/friendica/entities/token.ts | 8 + .../megalodon/src/friendica/entities/urls.ts | 5 + packages/megalodon/src/friendica/entity.ts | 38 + .../megalodon/src/friendica/notification.ts | 14 + .../megalodon/src/friendica/web_socket.ts | 18 + packages/megalodon/src/index.ts | 33 + packages/megalodon/src/mastodon.ts | 3169 ++ packages/megalodon/src/mastodon/api_client.ts | 662 + .../src/mastodon/entities/account.ts | 35 + .../src/mastodon/entities/activity.ts | 8 + .../src/mastodon/entities/announcement.ts | 40 + .../src/mastodon/entities/application.ts | 7 + .../src/mastodon/entities/async_attachment.ts | 14 + .../src/mastodon/entities/attachment.ts | 49 + .../megalodon/src/mastodon/entities/card.ts | 18 + .../src/mastodon/entities/context.ts | 8 + .../src/mastodon/entities/conversation.ts | 11 + .../megalodon/src/mastodon/entities/emoji.ts | 9 + .../src/mastodon/entities/featured_tag.ts | 8 + .../megalodon/src/mastodon/entities/field.ts | 7 + .../megalodon/src/mastodon/entities/filter.ts | 12 + .../src/mastodon/entities/history.ts | 7 + .../src/mastodon/entities/identity_proof.ts | 9 + .../src/mastodon/entities/instance.ts | 49 + .../megalodon/src/mastodon/entities/list.ts | 9 + .../megalodon/src/mastodon/entities/marker.ts | 14 + .../src/mastodon/entities/mention.ts | 8 + .../src/mastodon/entities/notification.ts | 14 + .../megalodon/src/mastodon/entities/poll.ts | 13 + .../src/mastodon/entities/poll_option.ts | 6 + .../src/mastodon/entities/preferences.ts | 9 + .../mastodon/entities/push_subscription.ts | 16 + .../src/mastodon/entities/relationship.ts | 18 + .../megalodon/src/mastodon/entities/report.ts | 17 + .../src/mastodon/entities/results.ts | 11 + .../megalodon/src/mastodon/entities/role.ts | 5 + .../src/mastodon/entities/scheduled_status.ts | 10 + .../megalodon/src/mastodon/entities/source.ts | 10 + .../megalodon/src/mastodon/entities/stats.ts | 7 + .../megalodon/src/mastodon/entities/status.ts | 50 + .../src/mastodon/entities/status_params.ts | 12 + .../src/mastodon/entities/status_source.ts | 7 + .../megalodon/src/mastodon/entities/tag.ts | 10 + .../megalodon/src/mastodon/entities/token.ts | 8 + .../megalodon/src/mastodon/entities/urls.ts | 5 + packages/megalodon/src/mastodon/entity.ts | 39 + .../megalodon/src/mastodon/notification.ts | 16 + packages/megalodon/src/mastodon/web_socket.ts | 348 + packages/megalodon/src/megalodon.ts | 1454 + packages/megalodon/src/misskey.ts | 2537 ++ packages/megalodon/src/misskey/api_client.ts | 667 + .../megalodon/src/misskey/entities/GetAll.ts | 6 + .../src/misskey/entities/announcement.ts | 11 + .../megalodon/src/misskey/entities/app.ts | 9 + .../src/misskey/entities/blocking.ts | 10 + .../src/misskey/entities/createdNote.ts | 7 + .../megalodon/src/misskey/entities/emoji.ts | 8 + .../src/misskey/entities/favorite.ts | 10 + .../megalodon/src/misskey/entities/field.ts | 8 + .../megalodon/src/misskey/entities/file.ts | 20 + .../src/misskey/entities/followRequest.ts | 9 + .../src/misskey/entities/follower.ts | 11 + .../src/misskey/entities/following.ts | 11 + .../megalodon/src/misskey/entities/hashtag.ts | 7 + .../megalodon/src/misskey/entities/list.ts | 8 + .../megalodon/src/misskey/entities/meta.ts | 49 + .../megalodon/src/misskey/entities/mute.ts | 10 + .../megalodon/src/misskey/entities/note.ts | 36 + .../src/misskey/entities/notification.ts | 17 + .../megalodon/src/misskey/entities/poll.ts | 13 + .../src/misskey/entities/reaction.ts | 10 + .../src/misskey/entities/relation.ts | 12 + .../megalodon/src/misskey/entities/session.ts | 6 + .../megalodon/src/misskey/entities/stats.ts | 9 + .../megalodon/src/misskey/entities/user.ts | 20 + .../src/misskey/entities/userDetail.ts | 34 + .../megalodon/src/misskey/entities/userkey.ts | 8 + packages/megalodon/src/misskey/entity.ts | 26 + .../megalodon/src/misskey/notification.ts | 16 + packages/megalodon/src/misskey/web_socket.ts | 413 + packages/megalodon/src/notification.ts | 26 + packages/megalodon/src/oauth.ts | 109 + packages/megalodon/src/parser.ts | 86 + packages/megalodon/src/pleroma.ts | 3217 ++ packages/megalodon/src/pleroma/api_client.ts | 824 + .../megalodon/src/pleroma/entities/account.ts | 31 + .../src/pleroma/entities/activity.ts | 8 + .../src/pleroma/entities/announcement.ts | 39 + .../src/pleroma/entities/application.ts | 7 + .../src/pleroma/entities/async_attachment.ts | 14 + .../src/pleroma/entities/attachment.ts | 49 + .../megalodon/src/pleroma/entities/card.ts | 11 + .../megalodon/src/pleroma/entities/context.ts | 8 + .../src/pleroma/entities/conversation.ts | 11 + .../megalodon/src/pleroma/entities/emoji.ts | 8 + .../src/pleroma/entities/featured_tag.ts | 8 + .../megalodon/src/pleroma/entities/field.ts | 7 + .../megalodon/src/pleroma/entities/filter.ts | 12 + .../megalodon/src/pleroma/entities/history.ts | 7 + .../src/pleroma/entities/identity_proof.ts | 9 + .../src/pleroma/entities/instance.ts | 46 + .../megalodon/src/pleroma/entities/list.ts | 6 + .../megalodon/src/pleroma/entities/marker.ts | 12 + .../megalodon/src/pleroma/entities/mention.ts | 8 + .../src/pleroma/entities/notification.ts | 16 + .../megalodon/src/pleroma/entities/poll.ts | 13 + .../src/pleroma/entities/poll_option.ts | 6 + .../src/pleroma/entities/preferences.ts | 9 + .../src/pleroma/entities/push_subscription.ts | 16 + .../src/pleroma/entities/reaction.ts | 10 + .../src/pleroma/entities/relationship.ts | 18 + .../megalodon/src/pleroma/entities/report.ts | 6 + .../megalodon/src/pleroma/entities/results.ts | 11 + .../src/pleroma/entities/scheduled_status.ts | 10 + .../megalodon/src/pleroma/entities/source.ts | 10 + .../megalodon/src/pleroma/entities/stats.ts | 7 + .../megalodon/src/pleroma/entities/status.ts | 65 + .../src/pleroma/entities/status_params.ts | 11 + .../src/pleroma/entities/status_source.ts | 7 + .../megalodon/src/pleroma/entities/tag.ts | 10 + .../megalodon/src/pleroma/entities/token.ts | 8 + .../megalodon/src/pleroma/entities/urls.ts | 5 + packages/megalodon/src/pleroma/entity.ts | 39 + .../megalodon/src/pleroma/notification.ts | 15 + packages/megalodon/src/pleroma/web_socket.ts | 349 + packages/megalodon/src/proxy_config.ts | 50 + packages/megalodon/src/response.ts | 8 + .../megalodon/test/integration/cancel.spec.ts | 38 + .../test/integration/cancelWorker.ts | 5 + .../test/integration/detector.spec.ts | 68 + .../test/integration/mastodon.spec.ts | 218 + .../integration/mastodon/api_client.spec.ts | 177 + .../test/integration/misskey.spec.ts | 218 + .../test/integration/pleroma.spec.ts | 222 + packages/megalodon/test/unit/mastodon.spec.ts | 6 + .../test/unit/mastodon/api_client.spec.ts | 80 + .../test/unit/misskey/api_client.spec.ts | 377 + packages/megalodon/test/unit/parser.spec.ts | 157 + .../test/unit/pleroma/api_client.spec.ts | 226 + .../megalodon/test/unit/webo_socket.spec.ts | 185 + packages/megalodon/tsconfig.json | 65 + packages/meta.json | 3 + packages/misskey-bubble-game/build.js | 104 + packages/misskey-bubble-game/eslint.config.js | 37 + packages/misskey-bubble-game/package.json | 44 + packages/misskey-bubble-game/src/game.ts | 505 + packages/misskey-bubble-game/src/index.ts | 14 + packages/misskey-bubble-game/src/monos.ts | 952 + packages/misskey-bubble-game/tsconfig.json | 34 + packages/misskey-js/.swcrc | 23 + packages/misskey-js/CONTRIBUTING.md | 90 + packages/misskey-js/LICENSE | 21 + packages/misskey-js/README.md | 158 + packages/misskey-js/api-extractor.json | 364 + packages/misskey-js/build.js | 104 + packages/misskey-js/docs/CONTRIBUTING.en.md | 30 + packages/misskey-js/eslint.config.js | 38 + packages/misskey-js/etc/misskey-js.api.md | 3535 ++ packages/misskey-js/generator/.gitignore | 1 + packages/misskey-js/generator/README.md | 19 + .../misskey-js/generator/eslint.config.js | 17 + packages/misskey-js/generator/package.json | 23 + .../misskey-js/generator/src/generator.ts | 390 + packages/misskey-js/generator/tsconfig.json | 20 + packages/misskey-js/jest.config.cjs | 207 + packages/misskey-js/package.json | 64 + packages/misskey-js/src/acct.ts | 15 + packages/misskey-js/src/api.ts | 128 + packages/misskey-js/src/api.types.ts | 109 + .../misskey-js/src/autogen/apiClientJSDoc.ts | 4493 +++ packages/misskey-js/src/autogen/endpoint.ts | 1018 + packages/misskey-js/src/autogen/entities.ts | 607 + packages/misskey-js/src/autogen/models.ts | 55 + packages/misskey-js/src/autogen/types.ts | 30953 ++++++++++++++++ packages/misskey-js/src/consts.ts | 457 + packages/misskey-js/src/entities.ts | 322 + packages/misskey-js/src/index.ts | 42 + packages/misskey-js/src/note.ts | 12 + packages/misskey-js/src/nyaize.ts | 32 + packages/misskey-js/src/streaming.ts | 393 + packages/misskey-js/src/streaming.types.ts | 291 + packages/misskey-js/test-d/api.ts | 45 + packages/misskey-js/test-d/streaming.ts | 12 + packages/misskey-js/test/api.ts | 300 + packages/misskey-js/test/nyaize.test.ts | 36 + packages/misskey-js/test/streaming.ts | 165 + packages/misskey-js/tsconfig.json | 35 + packages/misskey-reversi/build.js | 104 + packages/misskey-reversi/eslint.config.js | 24 + packages/misskey-reversi/package.json | 40 + packages/misskey-reversi/src/game.ts | 231 + packages/misskey-reversi/src/index.ts | 8 + packages/misskey-reversi/src/maps.ts | 697 + packages/misskey-reversi/src/serializer.ts | 98 + packages/misskey-reversi/tsconfig.json | 34 + packages/shared/eslint.config.js | 35 + packages/shared/package.json | 3 + packages/sw/build.js | 52 + packages/sw/eslint.config.js | 33 + packages/sw/package.json | 24 + packages/sw/src/@types/global.d.ts | 14 + .../sw/src/scripts/create-notification.ts | 332 + .../sw/src/scripts/get-account-from-id.ts | 16 + packages/sw/src/scripts/get-user-name.ts | 8 + packages/sw/src/scripts/lang.ts | 51 + packages/sw/src/scripts/login-id.ts | 10 + packages/sw/src/scripts/operations.ts | 91 + packages/sw/src/scripts/twemoji-base.ts | 13 + packages/sw/src/sw.ts | 223 + packages/sw/src/types.ts | 54 + packages/sw/tsconfig.json | 44 + pnpm-lock.yaml | 23235 ++++++++++++ pnpm-workspace.yaml | 11 + scripts/build-assets.mjs | 128 + scripts/build-pre.js | 27 + scripts/changelog-checker/eslint.config.js | 17 + scripts/clean-all.js | 43 + scripts/clean.js | 19 + scripts/dev.mjs | 113 + scripts/tarball.mjs | 37 + scripts/trim-deps.mjs | 40 + sharkey-locales/ar-SA.yml | 4 + sharkey-locales/bn-BD.yml | 5 + sharkey-locales/ca-ES.yml | 10 + sharkey-locales/cs-CZ.yml | 6 + sharkey-locales/da-DK.yml | 1 + sharkey-locales/de-DE.yml | 53 + sharkey-locales/el-GR.yml | 1 + sharkey-locales/en-US.yml | 432 + sharkey-locales/es-ES.yml | 14 + sharkey-locales/fr-FR.yml | 13 + sharkey-locales/hr-HR.yml | 1 + sharkey-locales/ht-HT.yml | 1 + sharkey-locales/hu-HU.yml | 1 + sharkey-locales/id-ID.yml | 10 + sharkey-locales/it-IT.yml | 18 + sharkey-locales/ja-JP.yml | 392 + sharkey-locales/ja-KS.yml | 79 + sharkey-locales/jbo-EN.yml | 1 + sharkey-locales/kab-KAB.yml | 1 + sharkey-locales/kn-IN.yml | 1 + sharkey-locales/ko-GS.yml | 4 + sharkey-locales/ko-KR.yml | 11 + sharkey-locales/lo-LA.yml | 1 + sharkey-locales/nl-NL.yml | 2 + sharkey-locales/no-NO.yml | 1 + sharkey-locales/pl-PL.yml | 8 + sharkey-locales/pt-PT.yml | 9 + sharkey-locales/ro-RO.yml | 6 + sharkey-locales/ru-RU.yml | 1 + sharkey-locales/si-LK.yml | 1 + sharkey-locales/sk-SK.yml | 6 + sharkey-locales/sv-SE.yml | 2 + sharkey-locales/th-TH.yml | 13 + sharkey-locales/tr-TR.yml | 1 + sharkey-locales/ug-CN.yml | 1 + sharkey-locales/uk-UA.yml | 5 + sharkey-locales/uz-UZ.yml | 6 + sharkey-locales/vi-VN.yml | 9 + sharkey-locales/zh-CN.yml | 9 + sharkey-locales/zh-TW.yml | 9 + 2982 files changed, 458800 insertions(+) create mode 100644 .config/cypress-devcontainer.yml create mode 100644 .config/docker_example.env create mode 100644 .config/docker_example.yml create mode 100644 .config/example.yml create mode 100644 .config/test-example.yml create mode 100644 .devcontainer/Dockerfile create mode 100644 .devcontainer/compose.yml create mode 100644 .devcontainer/devcontainer.json create mode 100644 .devcontainer/devcontainer.yml create mode 100755 .devcontainer/init.sh create mode 100644 .dockerignore create mode 100644 .dockleignore create mode 100644 .editorconfig create mode 100644 .gitattributes create mode 100644 .gitignore create mode 100644 .gitlab-ci.yml create mode 100644 .gitlab/issue_templates/bug.md create mode 100644 .gitlab/issue_templates/feature.md create mode 100644 .gitlab/merge_request_templates/default.md create mode 100644 .gitmodules create mode 100644 .node-version create mode 100644 .npmrc create mode 100644 .okteto/okteto-pipeline.yml create mode 100644 .vsls.json create mode 100644 CHANGELOG.md create mode 100644 CODE_OF_CONDUCT.md create mode 100644 CONTRIBUTING.md create mode 100644 COPYING create mode 100644 Dockerfile create mode 100644 IMPORTANT_NOTES.md create mode 100644 LICENSE create mode 100644 Procfile create mode 100644 README.md create mode 100644 ROADMAP.md create mode 100644 SECURITY.md create mode 100644 UPGRADE_NOTES.md create mode 100644 assets/about/drive.png create mode 100644 assets/about/post.png create mode 100644 assets/about/reaction.png create mode 100644 assets/about/ui.png create mode 100644 assets/ai-orig.png create mode 100644 assets/ai.png create mode 100644 assets/backend.png create mode 100644 assets/banner.afdesign create mode 100644 assets/mi-white.afdesign create mode 100644 assets/mi.afdesign create mode 100644 assets/ss/explore.jpg create mode 100644 assets/ss/user.jpg create mode 100644 assets/title.png create mode 100644 assets/title_float.svg create mode 100644 chart/Chart.yaml create mode 100644 chart/files/default.yml create mode 100644 chart/templates/ConfigMap.yml create mode 100644 chart/templates/Deployment.yml create mode 100644 chart/templates/Service.yml create mode 100644 chart/templates/_helpers.tpl create mode 100644 chart/values.yml create mode 100644 codecov.yml create mode 100644 compose.local-db.yml create mode 100644 compose_example.yml create mode 100644 crowdin.yml create mode 100644 cypress.config.ts create mode 100644 cypress/e2e/basic.cy.ts create mode 100644 cypress/e2e/router.cy.ts create mode 100644 cypress/e2e/widgets.cy.ts create mode 100644 cypress/fixtures/example.json create mode 100644 cypress/plugins/index.js create mode 100644 cypress/support/commands.ts create mode 100644 cypress/support/e2e.ts create mode 100644 cypress/support/index.ts create mode 100644 cypress/tsconfig.json create mode 100644 eslint/locale.js create mode 100644 eslint/locale.test.js create mode 100644 healthcheck.sh create mode 100644 idea/MkAbuseReport.stories.impl.ts create mode 100644 idea/MkDisableSection.vue create mode 100644 idea/README.md create mode 100644 locales/README.md create mode 100644 locales/ar-SA.yml create mode 100644 locales/bn-BD.yml create mode 100644 locales/ca-ES.yml create mode 100644 locales/cs-CZ.yml create mode 100644 locales/da-DK.yml create mode 100644 locales/de-DE.yml create mode 100644 locales/el-GR.yml create mode 100644 locales/en-US.yml create mode 100644 locales/es-ES.yml create mode 100644 locales/fr-FR.yml create mode 100644 locales/generateDTS.js create mode 100644 locales/hr-HR.yml create mode 100644 locales/ht-HT.yml create mode 100644 locales/hu-HU.yml create mode 100644 locales/id-ID.yml create mode 100644 locales/index.d.ts create mode 100644 locales/index.js create mode 100644 locales/it-IT.yml create mode 100644 locales/ja-JP.yml create mode 100644 locales/ja-KS.yml create mode 100644 locales/jbo-EN.yml create mode 100644 locales/kab-KAB.yml create mode 100644 locales/kn-IN.yml create mode 100644 locales/ko-GS.yml create mode 100644 locales/ko-KR.yml create mode 100644 locales/lo-LA.yml create mode 100644 locales/nl-NL.yml create mode 100644 locales/no-NO.yml create mode 100644 locales/package.json create mode 100644 locales/pl-PL.yml create mode 100644 locales/pt-PT.yml create mode 100644 locales/ro-RO.yml create mode 100644 locales/ru-RU.yml create mode 100644 locales/si-LK.yml create mode 100644 locales/sk-SK.yml create mode 100644 locales/sv-SE.yml create mode 100644 locales/th-TH.yml create mode 100644 locales/tr-TR.yml create mode 100644 locales/ug-CN.yml create mode 100644 locales/uk-UA.yml create mode 100644 locales/uz-UZ.yml create mode 100644 locales/verify.js create mode 100644 locales/version.d.ts create mode 100644 locales/version.js create mode 100644 locales/vi-VN.yml create mode 100644 locales/zh-CN.yml create mode 100644 locales/zh-TW.yml create mode 100644 package.json create mode 100644 packages/backend/.madgerc create mode 100644 packages/backend/.swcrc create mode 100644 packages/backend/.vscode/settings.json create mode 100644 packages/backend/README.md create mode 100644 packages/backend/assets/api-doc.html create mode 100644 packages/backend/assets/api-doc.png create mode 100644 packages/backend/assets/apple-touch-icon.png create mode 100644 packages/backend/assets/avatar.png create mode 100644 packages/backend/assets/embed.js create mode 100644 packages/backend/assets/emoji-unknown.png create mode 100644 packages/backend/assets/favicon.ico create mode 100644 packages/backend/assets/favicon.png create mode 100644 packages/backend/assets/fonts/Lexend-VariableFont_wght.ttf create mode 100644 packages/backend/assets/fonts/sharkey-icons/shark-font.svg create mode 100644 packages/backend/assets/fonts/sharkey-icons/shark-font.ttf create mode 100644 packages/backend/assets/fonts/sharkey-icons/shark-font.woff create mode 100644 packages/backend/assets/fonts/sharkey-icons/style.css create mode 100644 packages/backend/assets/icons/192.png create mode 100644 packages/backend/assets/icons/512.png create mode 100644 packages/backend/assets/mi-white.png create mode 100644 packages/backend/assets/robots.txt create mode 100644 packages/backend/assets/splash.png create mode 100644 packages/backend/assets/tabler-badges/LICENSE create mode 100644 packages/backend/assets/tabler-badges/antenna.png create mode 100644 packages/backend/assets/tabler-badges/arrow-back-up.png create mode 100644 packages/backend/assets/tabler-badges/at.png create mode 100644 packages/backend/assets/tabler-badges/bell.png create mode 100644 packages/backend/assets/tabler-badges/chart-arrows.png create mode 100644 packages/backend/assets/tabler-badges/circle-check.png create mode 100644 packages/backend/assets/tabler-badges/login-2.png create mode 100644 packages/backend/assets/tabler-badges/medal.png create mode 100644 packages/backend/assets/tabler-badges/messages.png create mode 100644 packages/backend/assets/tabler-badges/null.png create mode 100644 packages/backend/assets/tabler-badges/plus.png create mode 100644 packages/backend/assets/tabler-badges/quote.png create mode 100644 packages/backend/assets/tabler-badges/repeat.png create mode 100644 packages/backend/assets/tabler-badges/user-plus.png create mode 100644 packages/backend/assets/tabler-badges/users.png create mode 100644 packages/backend/assets/transparent.png create mode 100644 packages/backend/assets/user-unknown.png create mode 100644 packages/backend/eslint.config.js create mode 100644 packages/backend/jest.config.cjs create mode 100644 packages/backend/jest.config.e2e.cjs create mode 100644 packages/backend/jest.config.fed.cjs create mode 100644 packages/backend/jest.config.unit.cjs create mode 100644 packages/backend/jsconfig.json create mode 100644 packages/backend/migration/1000000000000-Init.js create mode 100644 packages/backend/migration/1556348509290-Pages.js create mode 100644 packages/backend/migration/1556746559567-UserProfile.js create mode 100644 packages/backend/migration/1557476068003-PinnedUsers.js create mode 100644 packages/backend/migration/1557761316509-AddSomeUrls.js create mode 100644 packages/backend/migration/1557932705754-ObjectStorageSetting.js create mode 100644 packages/backend/migration/1558072954435-PageLike.js create mode 100644 packages/backend/migration/1558103093633-UserGroup.js create mode 100644 packages/backend/migration/1558257926829-UserGroupInvite.js create mode 100644 packages/backend/migration/1558266512381-UserListJoining.js create mode 100644 packages/backend/migration/1561706992953-webauthn.js create mode 100644 packages/backend/migration/1561873850023-ChartIndexes.js create mode 100644 packages/backend/migration/1562422242907-PasswordLessLogin.js create mode 100644 packages/backend/migration/1562444565093-PinnedPage.js create mode 100644 packages/backend/migration/1562448332510-PageTitleHideOption.js create mode 100644 packages/backend/migration/1562869971568-ModerationLog.js create mode 100644 packages/backend/migration/1563757595828-UsedUsername.js create mode 100644 packages/backend/migration/1565634203341-room.js create mode 100644 packages/backend/migration/1571220798684-CustomEmojiCategory.js create mode 100644 packages/backend/migration/1572760203493-nodeinfo.js create mode 100644 packages/backend/migration/1576269851876-TalkFederationId.js create mode 100644 packages/backend/migration/1576869585998-ProxyRemoteFiles.js create mode 100644 packages/backend/migration/1579267006611-v12.js create mode 100644 packages/backend/migration/1579270193251-v12-2.js create mode 100644 packages/backend/migration/1579282808087-v12-3.js create mode 100644 packages/backend/migration/1579544426412-v12-4.js create mode 100644 packages/backend/migration/1579977526288-v12-5.js create mode 100644 packages/backend/migration/1579993013959-v12-6.js create mode 100644 packages/backend/migration/1580069531114-v12-7.js create mode 100644 packages/backend/migration/1580148575182-v12-8.js create mode 100644 packages/backend/migration/1580154400017-v12-9.js create mode 100644 packages/backend/migration/1580276619901-v12-10.js create mode 100644 packages/backend/migration/1580331224276-v12-11.js create mode 100644 packages/backend/migration/1580508795118-v12-12.js create mode 100644 packages/backend/migration/1580543501339-v12-13.js create mode 100644 packages/backend/migration/1580864313253-v12-14.js create mode 100644 packages/backend/migration/1581526429287-user-group-invitation.js create mode 100644 packages/backend/migration/1581695816408-user-group-antenna.js create mode 100644 packages/backend/migration/1581708415836-drive-user-folder-id-index.js create mode 100644 packages/backend/migration/1581979837262-promo.js create mode 100644 packages/backend/migration/1582019042083-featured-injecttion.js create mode 100644 packages/backend/migration/1582210532752-antenna-exclude.js create mode 100644 packages/backend/migration/1582875306439-note-reaction-length.js create mode 100644 packages/backend/migration/1585361548360-miauth.js create mode 100644 packages/backend/migration/1585385921215-custom-notification.js create mode 100644 packages/backend/migration/1585772678853-ap-url.js create mode 100644 packages/backend/migration/1586624197029-AddObjectStorageUseProxy.js create mode 100644 packages/backend/migration/1586641139527-remote-reaction.js create mode 100644 packages/backend/migration/1586708940386-pageAiScript.js create mode 100644 packages/backend/migration/1588044505511-hCaptcha.js create mode 100644 packages/backend/migration/1589023282116-pubRelay.js create mode 100644 packages/backend/migration/1595075960584-blurhash.js create mode 100644 packages/backend/migration/1595077605646-blurhash-for-avatar-banner.js create mode 100644 packages/backend/migration/1595676934834-instance-icon-url.js create mode 100644 packages/backend/migration/1595771249699-word-mute.js create mode 100644 packages/backend/migration/1595782306083-word-mute2.js create mode 100644 packages/backend/migration/1596548170836-channel.js create mode 100644 packages/backend/migration/1596786425167-channel2.js create mode 100644 packages/backend/migration/1597230137744-objectStorageSetPublicRead.js create mode 100644 packages/backend/migration/1597236229720-IncludingNotificationTypes.js create mode 100644 packages/backend/migration/1597385880794-add-sensitive-index.js create mode 100644 packages/backend/migration/1597459042300-channel-unread.js create mode 100644 packages/backend/migration/1597893996136-ChannelNoteIdDescIndex.js create mode 100644 packages/backend/migration/1600353287890-mutingNotificationTypes.js create mode 100644 packages/backend/migration/1603094348345-refine-abuse-user-report.js create mode 100644 packages/backend/migration/1603095701770-refine-abuse-user-report2.js create mode 100644 packages/backend/migration/1603776877564-instance-theme-color.js create mode 100644 packages/backend/migration/1603781553011-instance-favicon.js create mode 100644 packages/backend/migration/1604821689616-delete-auto-watch.js create mode 100644 packages/backend/migration/1605408848373-clip-description.js create mode 100644 packages/backend/migration/1605408971051-comments.js create mode 100644 packages/backend/migration/1605585339718-instance-pinned-pages.js create mode 100644 packages/backend/migration/1605965516823-instance-images.js create mode 100644 packages/backend/migration/1606191203881-no-crawle.js create mode 100644 packages/backend/migration/1607151207216-instance-pinned-clip.js create mode 100644 packages/backend/migration/1607353487793-isExplorable.js create mode 100644 packages/backend/migration/1610277136869-registry.js create mode 100644 packages/backend/migration/1610277585759-registry2.js create mode 100644 packages/backend/migration/1610283021566-registry3.js create mode 100644 packages/backend/migration/1611354329133-followersUri.js create mode 100644 packages/backend/migration/1611397665007-gallery.js create mode 100644 packages/backend/migration/1611547387175-objectStorageS3ForcePathStyle.js create mode 100644 packages/backend/migration/1612619156584-announcement-email.js create mode 100644 packages/backend/migration/1613155914446-emailNotificationTypes.js create mode 100644 packages/backend/migration/1613181457597-user-lang.js create mode 100644 packages/backend/migration/1613503367223-use-bigint-for-driveUsage.js create mode 100644 packages/backend/migration/1615965918224-chart-v2.js create mode 100644 packages/backend/migration/1615966519402-chart-v2-2.js create mode 100644 packages/backend/migration/1618637372000-user-last-active-date.js create mode 100644 packages/backend/migration/1618639857000-user-hide-online-status.js create mode 100644 packages/backend/migration/1619942102890-password-reset.js create mode 100644 packages/backend/migration/1620019354680-ad.js create mode 100644 packages/backend/migration/1620364649428-ad2.js create mode 100644 packages/backend/migration/1621479946000-add-note-indexes.js create mode 100644 packages/backend/migration/1622679304522-user-profile-description-length.js create mode 100644 packages/backend/migration/1622681548499-log-message-length.js create mode 100644 packages/backend/migration/1626509500668-fix-remote-file-proxy.js create mode 100644 packages/backend/migration/1629004542760-chart-reindex.js create mode 100644 packages/backend/migration/1629024377804-deepl-integration.js create mode 100644 packages/backend/migration/1629288472000-fix-channel-userId.js create mode 100644 packages/backend/migration/1629512953000-user-is-deleted.js create mode 100644 packages/backend/migration/1629778475000-deepl-integration2.js create mode 100644 packages/backend/migration/1629833361000-AddShowTLReplies.js create mode 100644 packages/backend/migration/1629968054000_userInstanceBlocks.js create mode 100644 packages/backend/migration/1633068642000-email-required-for-signup.js create mode 100644 packages/backend/migration/1633071909016-user-pending.js create mode 100644 packages/backend/migration/1634486652000-user-public-reactions.js create mode 100644 packages/backend/migration/1634902659689-delete-log.js create mode 100644 packages/backend/migration/1635500777168-note-thread-mute.js create mode 100644 packages/backend/migration/1636197624383-ff-visibility.js create mode 100644 packages/backend/migration/1636697408073-remove-via-mobile.js create mode 100644 packages/backend/migration/1637320813000-forwarded-report.js create mode 100644 packages/backend/migration/1639325650583-chart-v3.js create mode 100644 packages/backend/migration/1642611822809-emoji-url.js create mode 100644 packages/backend/migration/1642613870898-drive-file-webpublic-type.js create mode 100644 packages/backend/migration/1643963705770-chart-v4.js create mode 100644 packages/backend/migration/1643966656277-chart-v5.js create mode 100644 packages/backend/migration/1643967331284-chart-v6.js create mode 100644 packages/backend/migration/1644010796173-convert-hard-mutes.js create mode 100644 packages/backend/migration/1644058404077-chart-v7.js create mode 100644 packages/backend/migration/1644059847460-chart-v8.js create mode 100644 packages/backend/migration/1644060125705-chart-v9.js create mode 100644 packages/backend/migration/1644073149413-chart-v10.js create mode 100644 packages/backend/migration/1644095659741-chart-v11.js create mode 100644 packages/backend/migration/1644328606241-chart-v12.js create mode 100644 packages/backend/migration/1644331238153-chart-v13.js create mode 100644 packages/backend/migration/1644344266289-chart-v14.js create mode 100644 packages/backend/migration/1644395759931-instance-theme-color.js create mode 100644 packages/backend/migration/1644481657998-chart-v15.js create mode 100644 packages/backend/migration/1644551208096-following-indexes.js create mode 100644 packages/backend/migration/1645340161439-remove-max-note-text-length.js create mode 100644 packages/backend/migration/1645599900873-federation-chart-pubsub.js create mode 100644 packages/backend/migration/1646143552768-instance-default-theme.js create mode 100644 packages/backend/migration/1646387162108-mute-expires-at.js create mode 100644 packages/backend/migration/1646549089451-poll-ended-notification.js create mode 100644 packages/backend/migration/1646633030285-chart-federation-active.js create mode 100644 packages/backend/migration/1646655454495-remove-instance-drive-columns.js create mode 100644 packages/backend/migration/1646732390560-chart-federation-active-sub-pub.js create mode 100644 packages/backend/migration/1648548247382-webhook.js create mode 100644 packages/backend/migration/1648816172177-webhook-2.js create mode 100644 packages/backend/migration/1651224615271-foreign-key.js create mode 100644 packages/backend/migration/1652859567549-uniform-themecolor.js create mode 100644 packages/backend/migration/1655368940105-nsfw-detection.js create mode 100644 packages/backend/migration/1655371960534-nsfw-detection-2.js create mode 100644 packages/backend/migration/1655388169582-nsfw-detection-3.js create mode 100644 packages/backend/migration/1655393015659-nsfw-detection-4.js create mode 100644 packages/backend/migration/1655813815729-driveCapacityOverrideMb.js create mode 100644 packages/backend/migration/1655918165614-user-ip.js create mode 100644 packages/backend/migration/1656122560740-file-ip.js create mode 100644 packages/backend/migration/1656251734807-nsfw-detection-5.js create mode 100644 packages/backend/migration/1656328812281-ip-2.js create mode 100644 packages/backend/migration/1656408772602-nsfw-detection-6.js create mode 100644 packages/backend/migration/1656772790599-user-moderation-note.js create mode 100644 packages/backend/migration/1657346559800-active-email-validation.js create mode 100644 packages/backend/migration/1664694635394-turnstile.js create mode 100644 packages/backend/migration/1665091090561-add-renote-muting.js create mode 100644 packages/backend/migration/1669138716634-whetherPushNotifyToSendReadMessage.js create mode 100644 packages/backend/migration/1671924750884-RetentionAggregation.js create mode 100644 packages/backend/migration/1671926422832-RetentionAggregation2.js create mode 100644 packages/backend/migration/1672562400597-PerUserPvChart.js create mode 100644 packages/backend/migration/1672703171386-remove-latestRequestSentAt.js create mode 100644 packages/backend/migration/1672704017999-remove-lastCommunicatedAt.js create mode 100644 packages/backend/migration/1672704136584-remove-latestStatus.js create mode 100644 packages/backend/migration/1672822262496-Flash.js create mode 100644 packages/backend/migration/1673336077243-PollChoiceLength.js create mode 100644 packages/backend/migration/1673500412259-Role.js create mode 100644 packages/backend/migration/1673515526953-RoleColor.js create mode 100644 packages/backend/migration/1673522856499-RoleIroiro.js create mode 100644 packages/backend/migration/1673524604156-RoleLastUsedAt.js create mode 100644 packages/backend/migration/1673570377815-RoleConditional.js create mode 100644 packages/backend/migration/1673575973645-MetaClean.js create mode 100644 packages/backend/migration/1673783015567-Policies.js create mode 100644 packages/backend/migration/1673812883772-firstRetrievedAt.js create mode 100644 packages/backend/migration/1674086433654-flashScriptLength.js create mode 100644 packages/backend/migration/1674118260469-achievement.js create mode 100644 packages/backend/migration/1674255666603-loggedInDates.js create mode 100644 packages/backend/migration/1675053125067-fixforeignkeyreports.js create mode 100644 packages/backend/migration/1675404035646-cleanup.js create mode 100644 packages/backend/migration/1675557528704-role-icon-badge.js create mode 100644 packages/backend/migration/1676434944993-drop-group.js create mode 100644 packages/backend/migration/1676438468213-ad3.js create mode 100644 packages/backend/migration/1677054292210-ad4.js create mode 100644 packages/backend/migration/1677570181236-role-assignment-expires-at.js create mode 100644 packages/backend/migration/1678164627293-per-note-reaction-acceptance.js create mode 100644 packages/backend/migration/1678426061773-tweak-varchar-length.js create mode 100644 packages/backend/migration/1678427401214-remove-unused.js create mode 100644 packages/backend/migration/1678602320354-role-display-order.js create mode 100644 packages/backend/migration/1678694614599-sensitive-words.js create mode 100644 packages/backend/migration/1678869617549-retention-date-key.js create mode 100644 packages/backend/migration/1678945242650-add-props-for-custom-emoji.js create mode 100644 packages/backend/migration/1678953978856-clip-favorite.js create mode 100644 packages/backend/migration/1679309757174-antenna-active.js create mode 100644 packages/backend/migration/1679639483253-enableChartsForRemoteUser.js create mode 100644 packages/backend/migration/1679651580149-cleanup.js create mode 100644 packages/backend/migration/1679652081809-enableChartsForFederatedInstances.js create mode 100644 packages/backend/migration/1680228513388-channelFavorite.js create mode 100644 packages/backend/migration/1680238118084-channelNotePining.js create mode 100644 packages/backend/migration/1680491187535-cleanup.js create mode 100644 packages/backend/migration/1680582195041-cleanup.js create mode 100644 packages/backend/migration/1680702787050-UserMemo.js create mode 100644 packages/backend/migration/1680775031481-avatar-url-and-banner-url.js create mode 100644 packages/backend/migration/1680931179228-account-move.js create mode 100644 packages/backend/migration/1680969937000-larger-image-comment.js create mode 100644 packages/backend/migration/1681400427971-serverRules.js create mode 100644 packages/backend/migration/1681870960239-RoleTLSetting.js create mode 100644 packages/backend/migration/1682190963894-movedAt.js create mode 100644 packages/backend/migration/1682753227899-NoteEdit.js create mode 100644 packages/backend/migration/1682754135458-preservedUsernames.js create mode 100644 packages/backend/migration/1682985520254-channelColor.js create mode 100644 packages/backend/migration/1683328299359-channelArchive.js create mode 100644 packages/backend/migration/1683682889948-prevent-ai-larning.js create mode 100644 packages/backend/migration/1683683083083-public-reactions-default-true.js create mode 100644 packages/backend/migration/1683789676867-fix-typo.js create mode 100644 packages/backend/migration/1683847157541-UserList.js create mode 100644 packages/backend/migration/1683869758873-UserListFavorites.js create mode 100644 packages/backend/migration/1684206886988-remove-showTimelineReplies.js create mode 100644 packages/backend/migration/1684386446061-emoji-improve.js create mode 100644 packages/backend/migration/1685973839966-errorImageUrl.js create mode 100644 packages/backend/migration/1688280713783-add-meta-options.js create mode 100644 packages/backend/migration/1688720440658-refactor-invite-system.js create mode 100644 packages/backend/migration/1688880985544-add-index-to-relations.js create mode 100644 packages/backend/migration/1689102832143-nsfw-cache.js create mode 100644 packages/backend/migration/1689325027964-UserBlacklistAnntena.js create mode 100644 packages/backend/migration/1690417561185-fix-renote-muting.js create mode 100644 packages/backend/migration/1690417561186-ChangeCacheRemoteFilesDefault.js create mode 100644 packages/backend/migration/1690417561187-Fix.js create mode 100644 packages/backend/migration/1690569881926-user-2fa-backup-codes.js create mode 100644 packages/backend/migration/1690782653311-SensitiveChannel.js create mode 100644 packages/backend/migration/1690796169261-play-visibility.js create mode 100644 packages/backend/migration/1691264431000-add-lb-to-user.js create mode 100644 packages/backend/migration/1691649257651-refine-announcement.js create mode 100644 packages/backend/migration/1691657412740-refine-announcement-2.js create mode 100644 packages/backend/migration/1691959191872-passkey-support.js create mode 100644 packages/backend/migration/1694850832075-server-icons-and-manifest.js create mode 100644 packages/backend/migration/1694915420864-clipped-count.js create mode 100644 packages/backend/migration/1695260774117-verified-links.js create mode 100644 packages/backend/migration/1695288787870-following-notify.js create mode 100644 packages/backend/migration/1695440131671-short-name.js create mode 100644 packages/backend/migration/1695605508898-mutingNotificationTypes.js create mode 100644 packages/backend/migration/1695937489995-enableAchievements.js create mode 100644 packages/backend/migration/1695944637565-notificationRecieveConfig.js create mode 100644 packages/backend/migration/1696003580220-AddSomeUrls.js create mode 100644 packages/backend/migration/1696222183852-withReplies.js create mode 100644 packages/backend/migration/1696323464251-user-list-membership.js create mode 100644 packages/backend/migration/1696331570827-hibernation.js create mode 100644 packages/backend/migration/1696332072038-clean.js create mode 100644 packages/backend/migration/1696373953614-meta-cache-settings.js create mode 100644 packages/backend/migration/1696386694000-speakAsCat.js create mode 100644 packages/backend/migration/1696405744672-clean-up.js create mode 100644 packages/backend/migration/1696548899000-background.js create mode 100644 packages/backend/migration/1696569742153-clean-up.js create mode 100644 packages/backend/migration/1696581429196-clean-up.js create mode 100644 packages/backend/migration/1696743032098-AdsOnStream.js create mode 100644 packages/backend/migration/1696807733453-userListUserId.js create mode 100644 packages/backend/migration/1696808725134-userListUserId-2.js create mode 100644 packages/backend/migration/1697247230117-InstanceSilence.js create mode 100644 packages/backend/migration/1697420555911-deleteCreatedAt.js create mode 100644 packages/backend/migration/1697436246389-antenna-localOnly.js create mode 100644 packages/backend/migration/1697441463087-FollowRequestWithReplies.js create mode 100644 packages/backend/migration/1697580470000-approvalSignup.js create mode 100644 packages/backend/migration/1697603945000-BotTrending.js create mode 100644 packages/backend/migration/1697624010000-isSilenced.js create mode 100644 packages/backend/migration/1697673894459-note-reactionAndUserPairCache.js create mode 100644 packages/backend/migration/1697847397844-avatar-decoration.js create mode 100644 packages/backend/migration/1697941908548-avatar-decoration2.js create mode 100644 packages/backend/migration/1697970083000-alterNoteEdit.js create mode 100644 packages/backend/migration/1697970083001-oldDateNoteEdit.js create mode 100644 packages/backend/migration/1698041201306-enable-ftt.js create mode 100644 packages/backend/migration/1698840138000-add-allow-renote-to-external.js create mode 100644 packages/backend/migration/1699141698112-announcement-silence.js create mode 100644 packages/backend/migration/1699376974000-isIndexable.js create mode 100644 packages/backend/migration/1699437894737-scheduleNote.js create mode 100644 packages/backend/migration/1699819257000-defaultLike.js create mode 100644 packages/backend/migration/1700096812223-enableFanoutTimelineDbFallback.js create mode 100644 packages/backend/migration/1700228972000-update-indexable.js create mode 100644 packages/backend/migration/1700303245007-supportVerifyMailApi.js create mode 100644 packages/backend/migration/1700383825690-hard-mute.js create mode 100644 packages/backend/migration/1700902349231-add-bday-index.js create mode 100644 packages/backend/migration/1701647674000-BubbleInstances.js create mode 100644 packages/backend/migration/1701809447000-NSFW-Instance.js create mode 100644 packages/backend/migration/1702718871541-ffVisibility.js create mode 100644 packages/backend/migration/1703209889304-bannedEmailDomains.js create mode 100644 packages/backend/migration/1703658526000-supportTrueMailApi.js create mode 100644 packages/backend/migration/1704373210054-support-mcaptcha.js create mode 100644 packages/backend/migration/1704744370000-add-donation-url.js create mode 100644 packages/backend/migration/1704959805077-bubble-game-record.js create mode 100644 packages/backend/migration/1705222772858-optimize-note-index-for-array-column.js create mode 100644 packages/backend/migration/1705475608437-reversi.js create mode 100644 packages/backend/migration/1705654039457-reversi-2.js create mode 100644 packages/backend/migration/1705793785675-reversi-3.js create mode 100644 packages/backend/migration/1705794768153-reversi-4.js create mode 100644 packages/backend/migration/1705798904141-reversi-5.js create mode 100644 packages/backend/migration/1706081514499-reversi-6.js create mode 100644 packages/backend/migration/1706232992000-deeplx.js create mode 100644 packages/backend/migration/1706791962000-fix-meta-disableRegistration.js create mode 100644 packages/backend/migration/1707429690000-prohibited-words.js create mode 100644 packages/backend/migration/1707808106310-MakeRepositoryUrlNullable.js create mode 100644 packages/backend/migration/1708266695091-repositoryUrl-from-syuilo-to-misskey-dev.js create mode 100644 packages/backend/migration/1708342829000-SharkeyRepositoryUrl.js create mode 100644 packages/backend/migration/1708399372194-per-instance-mod-note.js create mode 100644 packages/backend/migration/1709462550083-MoreRepoUrl.js create mode 100644 packages/backend/migration/1710512074000-url-preview-meta.js create mode 100644 packages/backend/migration/1710919614510-antenna-exclude-bots.js create mode 100644 packages/backend/migration/1711008460816-external-website-warn.js create mode 100644 packages/backend/migration/1713656541000-abuse-report-notification.js create mode 100644 packages/backend/migration/1716129964060-ChannelIdDenormalizedForMiPoll.js create mode 100644 packages/backend/migration/1716197366117-MediaSilenceForHosts.js create mode 100644 packages/backend/migration/1716345015347-NotRespondingSince.js create mode 100644 packages/backend/migration/1716447138870-SuspensionStateInsteadOfIsSspended.js create mode 100644 packages/backend/migration/1716450883149-RemoveAntennaNotify.js create mode 100644 packages/backend/migration/1717117195275-inquiryUrl.js create mode 100644 packages/backend/migration/1721666053703-fixDriveUrl.js create mode 100644 packages/backend/migration/1723944246767-followedMessage.js create mode 100644 packages/backend/migration/1726804538569-reactions-buffering.js create mode 100644 packages/backend/migration/1727027985575-SidebarLogo.js create mode 100644 packages/backend/migration/1727318020265-enableStatsForFederatedInstances.js create mode 100644 packages/backend/migration/1727491883993-user-score.js create mode 100644 packages/backend/migration/1727512908322-meta-federation.js create mode 100644 packages/backend/migration/1727659258948-add_latest_note.js create mode 100644 packages/backend/migration/1727998351561-increase_character_limits.js create mode 100644 packages/backend/migration/1728085812127-refine-abuse-user-report.js create mode 100644 packages/backend/migration/1728177700920-add-reject-reports.js create mode 100644 packages/backend/migration/1728348353115-soft-limit-drive-comment.js create mode 100644 packages/backend/migration/1728420772835-track-latest-note-type.js create mode 100644 packages/backend/migration/1728550878802-testcaptcha.js create mode 100644 packages/backend/migration/1728634286056-prohibitedWordsForNameOfUser.js create mode 100644 packages/backend/migration/1729333924409-signinRequiredForShowContents.js create mode 100644 packages/backend/migration/1729414690009-defaultSensitive.js create mode 100644 packages/backend/migration/1729486255072-makeNotesHiddenBefore.js create mode 100644 packages/backend/migration/1730505338000-friendlyCaptcha.js create mode 100644 packages/backend/migration/1733748798177-add_user_enableRss.js create mode 100644 packages/backend/migration/1733754069260-alter_user_hideOnlineStatus_default_true.js create mode 100644 packages/backend/ormconfig.js create mode 100644 packages/backend/package.json create mode 100644 packages/backend/scripts/check_connect.js create mode 100644 packages/backend/scripts/dev.mjs create mode 100644 packages/backend/scripts/generate_api_json.js create mode 100644 packages/backend/scripts/watch.mjs create mode 100644 packages/backend/src/@types/hcaptcha.d.ts create mode 100644 packages/backend/src/@types/http-signature.d.ts create mode 100644 packages/backend/src/@types/os-utils.d.ts create mode 100644 packages/backend/src/@types/package.json.d.ts create mode 100644 packages/backend/src/@types/probe-image-size.d.ts create mode 100644 packages/backend/src/@types/redis-lock.d.ts create mode 100644 packages/backend/src/GlobalModule.ts create mode 100644 packages/backend/src/MainModule.ts create mode 100644 packages/backend/src/NestLogger.ts create mode 100644 packages/backend/src/boot/common.ts create mode 100644 packages/backend/src/boot/entry.ts create mode 100644 packages/backend/src/boot/master.ts create mode 100644 packages/backend/src/boot/ready.ts create mode 100644 packages/backend/src/boot/worker.ts create mode 100644 packages/backend/src/config.ts create mode 100644 packages/backend/src/const.ts create mode 100644 packages/backend/src/core/AbuseReportNotificationService.ts create mode 100644 packages/backend/src/core/AbuseReportService.ts create mode 100644 packages/backend/src/core/AccountMoveService.ts create mode 100644 packages/backend/src/core/AccountUpdateService.ts create mode 100644 packages/backend/src/core/AchievementService.ts create mode 100644 packages/backend/src/core/AnnouncementService.ts create mode 100644 packages/backend/src/core/AntennaService.ts create mode 100644 packages/backend/src/core/AppLockService.ts create mode 100644 packages/backend/src/core/AvatarDecorationService.ts create mode 100644 packages/backend/src/core/CacheService.ts create mode 100644 packages/backend/src/core/CaptchaService.ts create mode 100644 packages/backend/src/core/ChannelFollowingService.ts create mode 100644 packages/backend/src/core/ClipService.ts create mode 100644 packages/backend/src/core/CoreModule.ts create mode 100644 packages/backend/src/core/CreateSystemUserService.ts create mode 100644 packages/backend/src/core/CustomEmojiService.ts create mode 100644 packages/backend/src/core/DeleteAccountService.ts create mode 100644 packages/backend/src/core/DownloadService.ts create mode 100644 packages/backend/src/core/DriveService.ts create mode 100644 packages/backend/src/core/EmailService.ts create mode 100644 packages/backend/src/core/EnvService.ts create mode 100644 packages/backend/src/core/FanoutTimelineEndpointService.ts create mode 100644 packages/backend/src/core/FanoutTimelineService.ts create mode 100644 packages/backend/src/core/FeaturedService.ts create mode 100644 packages/backend/src/core/FederatedInstanceService.ts create mode 100644 packages/backend/src/core/FetchInstanceMetadataService.ts create mode 100644 packages/backend/src/core/FileInfoService.ts create mode 100644 packages/backend/src/core/FlashService.ts create mode 100644 packages/backend/src/core/GlobalEventService.ts create mode 100644 packages/backend/src/core/HashtagService.ts create mode 100644 packages/backend/src/core/HttpRequestService.ts create mode 100644 packages/backend/src/core/IdService.ts create mode 100644 packages/backend/src/core/ImageProcessingService.ts create mode 100644 packages/backend/src/core/InstanceActorService.ts create mode 100644 packages/backend/src/core/InternalStorageService.ts create mode 100644 packages/backend/src/core/LatestNoteService.ts create mode 100644 packages/backend/src/core/LoggerService.ts create mode 100644 packages/backend/src/core/MetaService.ts create mode 100644 packages/backend/src/core/MfmService.ts create mode 100644 packages/backend/src/core/ModerationLogService.ts create mode 100644 packages/backend/src/core/NoteCreateService.ts create mode 100644 packages/backend/src/core/NoteDeleteService.ts create mode 100644 packages/backend/src/core/NoteEditService.ts create mode 100644 packages/backend/src/core/NotePiningService.ts create mode 100644 packages/backend/src/core/NoteReadService.ts create mode 100644 packages/backend/src/core/NotificationService.ts create mode 100644 packages/backend/src/core/PollService.ts create mode 100644 packages/backend/src/core/ProxyAccountService.ts create mode 100644 packages/backend/src/core/PushNotificationService.ts create mode 100644 packages/backend/src/core/QueryService.ts create mode 100644 packages/backend/src/core/QueueModule.ts create mode 100644 packages/backend/src/core/QueueService.ts create mode 100644 packages/backend/src/core/ReactionService.ts create mode 100644 packages/backend/src/core/ReactionsBufferingService.ts create mode 100644 packages/backend/src/core/RegistryApiService.ts create mode 100644 packages/backend/src/core/RelayService.ts create mode 100644 packages/backend/src/core/RemoteLoggerService.ts create mode 100644 packages/backend/src/core/RemoteUserResolveService.ts create mode 100644 packages/backend/src/core/ReversiService.ts create mode 100644 packages/backend/src/core/RoleService.ts create mode 100644 packages/backend/src/core/S3Service.ts create mode 100644 packages/backend/src/core/SearchService.ts create mode 100644 packages/backend/src/core/SignupService.ts create mode 100644 packages/backend/src/core/SponsorsService.ts create mode 100644 packages/backend/src/core/SystemWebhookService.ts create mode 100644 packages/backend/src/core/TimeService.ts create mode 100644 packages/backend/src/core/UserAuthService.ts create mode 100644 packages/backend/src/core/UserBlockingService.ts create mode 100644 packages/backend/src/core/UserFollowingService.ts create mode 100644 packages/backend/src/core/UserKeypairService.ts create mode 100644 packages/backend/src/core/UserListService.ts create mode 100644 packages/backend/src/core/UserMutingService.ts create mode 100644 packages/backend/src/core/UserRenoteMutingService.ts create mode 100644 packages/backend/src/core/UserSearchService.ts create mode 100644 packages/backend/src/core/UserService.ts create mode 100644 packages/backend/src/core/UserSuspendService.ts create mode 100644 packages/backend/src/core/UserWebhookService.ts create mode 100644 packages/backend/src/core/UtilityService.ts create mode 100644 packages/backend/src/core/VideoProcessingService.ts create mode 100644 packages/backend/src/core/WebAuthnService.ts create mode 100644 packages/backend/src/core/WebfingerService.ts create mode 100644 packages/backend/src/core/WebhookTestService.ts create mode 100644 packages/backend/src/core/activitypub/ApAudienceService.ts create mode 100644 packages/backend/src/core/activitypub/ApDbResolverService.ts create mode 100644 packages/backend/src/core/activitypub/ApDeliverManagerService.ts create mode 100644 packages/backend/src/core/activitypub/ApInboxService.ts create mode 100644 packages/backend/src/core/activitypub/ApLoggerService.ts create mode 100644 packages/backend/src/core/activitypub/ApMfmService.ts create mode 100644 packages/backend/src/core/activitypub/ApRendererService.ts create mode 100644 packages/backend/src/core/activitypub/ApRequestService.ts create mode 100644 packages/backend/src/core/activitypub/ApResolverService.ts create mode 100644 packages/backend/src/core/activitypub/JsonLdService.ts create mode 100644 packages/backend/src/core/activitypub/misc/check-against-url.ts create mode 100644 packages/backend/src/core/activitypub/misc/contexts.ts create mode 100644 packages/backend/src/core/activitypub/misc/validator.ts create mode 100644 packages/backend/src/core/activitypub/models/ApImageService.ts create mode 100644 packages/backend/src/core/activitypub/models/ApMentionService.ts create mode 100644 packages/backend/src/core/activitypub/models/ApNoteService.ts create mode 100644 packages/backend/src/core/activitypub/models/ApPersonService.ts create mode 100644 packages/backend/src/core/activitypub/models/ApQuestionService.ts create mode 100644 packages/backend/src/core/activitypub/models/icon.ts create mode 100644 packages/backend/src/core/activitypub/models/identifier.ts create mode 100644 packages/backend/src/core/activitypub/models/tag.ts create mode 100644 packages/backend/src/core/activitypub/type.ts create mode 100644 packages/backend/src/core/chart/ChartLoggerService.ts create mode 100644 packages/backend/src/core/chart/ChartManagementService.ts create mode 100644 packages/backend/src/core/chart/charts/active-users.ts create mode 100644 packages/backend/src/core/chart/charts/ap-request.ts create mode 100644 packages/backend/src/core/chart/charts/drive.ts create mode 100644 packages/backend/src/core/chart/charts/entities/active-users.ts create mode 100644 packages/backend/src/core/chart/charts/entities/ap-request.ts create mode 100644 packages/backend/src/core/chart/charts/entities/drive.ts create mode 100644 packages/backend/src/core/chart/charts/entities/federation.ts create mode 100644 packages/backend/src/core/chart/charts/entities/instance.ts create mode 100644 packages/backend/src/core/chart/charts/entities/notes.ts create mode 100644 packages/backend/src/core/chart/charts/entities/per-user-drive.ts create mode 100644 packages/backend/src/core/chart/charts/entities/per-user-following.ts create mode 100644 packages/backend/src/core/chart/charts/entities/per-user-notes.ts create mode 100644 packages/backend/src/core/chart/charts/entities/per-user-pv.ts create mode 100644 packages/backend/src/core/chart/charts/entities/per-user-reactions.ts create mode 100644 packages/backend/src/core/chart/charts/entities/test-grouped.ts create mode 100644 packages/backend/src/core/chart/charts/entities/test-intersection.ts create mode 100644 packages/backend/src/core/chart/charts/entities/test-unique.ts create mode 100644 packages/backend/src/core/chart/charts/entities/test.ts create mode 100644 packages/backend/src/core/chart/charts/entities/users.ts create mode 100644 packages/backend/src/core/chart/charts/federation.ts create mode 100644 packages/backend/src/core/chart/charts/instance.ts create mode 100644 packages/backend/src/core/chart/charts/notes.ts create mode 100644 packages/backend/src/core/chart/charts/per-user-drive.ts create mode 100644 packages/backend/src/core/chart/charts/per-user-following.ts create mode 100644 packages/backend/src/core/chart/charts/per-user-notes.ts create mode 100644 packages/backend/src/core/chart/charts/per-user-pv.ts create mode 100644 packages/backend/src/core/chart/charts/per-user-reactions.ts create mode 100644 packages/backend/src/core/chart/charts/test-grouped.ts create mode 100644 packages/backend/src/core/chart/charts/test-intersection.ts create mode 100644 packages/backend/src/core/chart/charts/test-unique.ts create mode 100644 packages/backend/src/core/chart/charts/test.ts create mode 100644 packages/backend/src/core/chart/charts/users.ts create mode 100644 packages/backend/src/core/chart/core.ts create mode 100644 packages/backend/src/core/chart/entities.ts create mode 100644 packages/backend/src/core/entities/AbuseReportNotificationRecipientEntityService.ts create mode 100644 packages/backend/src/core/entities/AbuseUserReportEntityService.ts create mode 100644 packages/backend/src/core/entities/AnnouncementEntityService.ts create mode 100644 packages/backend/src/core/entities/AntennaEntityService.ts create mode 100644 packages/backend/src/core/entities/AppEntityService.ts create mode 100644 packages/backend/src/core/entities/AuthSessionEntityService.ts create mode 100644 packages/backend/src/core/entities/BlockingEntityService.ts create mode 100644 packages/backend/src/core/entities/ChannelEntityService.ts create mode 100644 packages/backend/src/core/entities/ClipEntityService.ts create mode 100644 packages/backend/src/core/entities/DriveFileEntityService.ts create mode 100644 packages/backend/src/core/entities/DriveFolderEntityService.ts create mode 100644 packages/backend/src/core/entities/EmojiEntityService.ts create mode 100644 packages/backend/src/core/entities/FlashEntityService.ts create mode 100644 packages/backend/src/core/entities/FlashLikeEntityService.ts create mode 100644 packages/backend/src/core/entities/FollowRequestEntityService.ts create mode 100644 packages/backend/src/core/entities/FollowingEntityService.ts create mode 100644 packages/backend/src/core/entities/GalleryLikeEntityService.ts create mode 100644 packages/backend/src/core/entities/GalleryPostEntityService.ts create mode 100644 packages/backend/src/core/entities/HashtagEntityService.ts create mode 100644 packages/backend/src/core/entities/InstanceEntityService.ts create mode 100644 packages/backend/src/core/entities/InviteCodeEntityService.ts create mode 100644 packages/backend/src/core/entities/MetaEntityService.ts create mode 100644 packages/backend/src/core/entities/ModerationLogEntityService.ts create mode 100644 packages/backend/src/core/entities/MutingEntityService.ts create mode 100644 packages/backend/src/core/entities/NoteEntityService.ts create mode 100644 packages/backend/src/core/entities/NoteFavoriteEntityService.ts create mode 100644 packages/backend/src/core/entities/NoteReactionEntityService.ts create mode 100644 packages/backend/src/core/entities/NotificationEntityService.ts create mode 100644 packages/backend/src/core/entities/PageEntityService.ts create mode 100644 packages/backend/src/core/entities/PageLikeEntityService.ts create mode 100644 packages/backend/src/core/entities/RenoteMutingEntityService.ts create mode 100644 packages/backend/src/core/entities/ReversiGameEntityService.ts create mode 100644 packages/backend/src/core/entities/RoleEntityService.ts create mode 100644 packages/backend/src/core/entities/SigninEntityService.ts create mode 100644 packages/backend/src/core/entities/SystemWebhookEntityService.ts create mode 100644 packages/backend/src/core/entities/UserEntityService.ts create mode 100644 packages/backend/src/core/entities/UserListEntityService.ts create mode 100644 packages/backend/src/daemons/DaemonModule.ts create mode 100644 packages/backend/src/daemons/QueueStatsService.ts create mode 100644 packages/backend/src/daemons/ServerStatsService.ts create mode 100644 packages/backend/src/decorators.ts create mode 100644 packages/backend/src/di-symbols.ts create mode 100644 packages/backend/src/env.ts create mode 100644 packages/backend/src/global.d.ts create mode 100644 packages/backend/src/logger.ts create mode 100644 packages/backend/src/misc/FileWriterStream.ts create mode 100644 packages/backend/src/misc/JsonArrayStream.ts create mode 100644 packages/backend/src/misc/acct.ts create mode 100644 packages/backend/src/misc/cache.ts create mode 100644 packages/backend/src/misc/check-https.ts create mode 100644 packages/backend/src/misc/check-word-mute.ts create mode 100644 packages/backend/src/misc/clone.ts create mode 100644 packages/backend/src/misc/collapsed-queue.ts create mode 100644 packages/backend/src/misc/content-disposition.ts create mode 100644 packages/backend/src/misc/correct-filename.ts create mode 100644 packages/backend/src/misc/create-temp.ts create mode 100644 packages/backend/src/misc/dev-null.ts create mode 100644 packages/backend/src/misc/emoji-regex.ts create mode 100644 packages/backend/src/misc/extract-custom-emojis-from-mfm.ts create mode 100644 packages/backend/src/misc/extract-hashtags.ts create mode 100644 packages/backend/src/misc/extract-mentions.ts create mode 100644 packages/backend/src/misc/fastify-hook-handlers.ts create mode 100644 packages/backend/src/misc/fastify-reply-error.ts create mode 100644 packages/backend/src/misc/from-tuple.ts create mode 100644 packages/backend/src/misc/gen-identicon.ts create mode 100644 packages/backend/src/misc/gen-key-pair.ts create mode 100644 packages/backend/src/misc/generate-invite-code.ts create mode 100644 packages/backend/src/misc/generate-native-user-token.ts create mode 100644 packages/backend/src/misc/get-ip-hash.ts create mode 100644 packages/backend/src/misc/get-note-summary.ts create mode 100644 packages/backend/src/misc/get-reaction-emoji.ts create mode 100644 packages/backend/src/misc/i18n.ts create mode 100644 packages/backend/src/misc/id/aid.ts create mode 100644 packages/backend/src/misc/id/aidx.ts create mode 100644 packages/backend/src/misc/id/meid.ts create mode 100644 packages/backend/src/misc/id/meidg.ts create mode 100644 packages/backend/src/misc/id/object-id.ts create mode 100644 packages/backend/src/misc/id/ulid.ts create mode 100644 packages/backend/src/misc/identifiable-error.ts create mode 100644 packages/backend/src/misc/is-duplicate-key-value-error.ts create mode 100644 packages/backend/src/misc/is-instance-muted.ts create mode 100644 packages/backend/src/misc/is-mime-image.ts create mode 100644 packages/backend/src/misc/is-native-token.ts create mode 100644 packages/backend/src/misc/is-renote.ts create mode 100644 packages/backend/src/misc/is-reply.ts create mode 100644 packages/backend/src/misc/is-system-account.ts create mode 100644 packages/backend/src/misc/is-user-related.ts create mode 100644 packages/backend/src/misc/json-schema.ts create mode 100644 packages/backend/src/misc/json-value.ts create mode 100644 packages/backend/src/misc/langmap.ts create mode 100644 packages/backend/src/misc/loader.ts create mode 100644 packages/backend/src/misc/normalize-for-search.ts create mode 100644 packages/backend/src/misc/prelude/README.md create mode 100644 packages/backend/src/misc/prelude/array.ts create mode 100644 packages/backend/src/misc/prelude/await-all.ts create mode 100644 packages/backend/src/misc/prelude/relation.ts create mode 100644 packages/backend/src/misc/prelude/time.ts create mode 100644 packages/backend/src/misc/prelude/url.ts create mode 100644 packages/backend/src/misc/prelude/xml.ts create mode 100644 packages/backend/src/misc/promise-tracker.ts create mode 100644 packages/backend/src/misc/rate-limit-utils.ts create mode 100644 packages/backend/src/misc/reset-db.ts create mode 100644 packages/backend/src/misc/safe-for-sql.ts create mode 100644 packages/backend/src/misc/secure-rndstr.ts create mode 100644 packages/backend/src/misc/show-machine-info.ts create mode 100644 packages/backend/src/misc/sql-like-escape.ts create mode 100644 packages/backend/src/misc/status-error.ts create mode 100644 packages/backend/src/misc/truncate.ts create mode 100644 packages/backend/src/models/AbuseReportNotificationRecipient.ts create mode 100644 packages/backend/src/models/AbuseUserReport.ts create mode 100644 packages/backend/src/models/AccessToken.ts create mode 100644 packages/backend/src/models/Ad.ts create mode 100644 packages/backend/src/models/Announcement.ts create mode 100644 packages/backend/src/models/AnnouncementRead.ts create mode 100644 packages/backend/src/models/Antenna.ts create mode 100644 packages/backend/src/models/App.ts create mode 100644 packages/backend/src/models/AuthSession.ts create mode 100644 packages/backend/src/models/AvatarDecoration.ts create mode 100644 packages/backend/src/models/Blocking.ts create mode 100644 packages/backend/src/models/BubbleGameRecord.ts create mode 100644 packages/backend/src/models/Channel.ts create mode 100644 packages/backend/src/models/ChannelFavorite.ts create mode 100644 packages/backend/src/models/ChannelFollowing.ts create mode 100644 packages/backend/src/models/Clip.ts create mode 100644 packages/backend/src/models/ClipFavorite.ts create mode 100644 packages/backend/src/models/ClipNote.ts create mode 100644 packages/backend/src/models/DriveFile.ts create mode 100644 packages/backend/src/models/DriveFolder.ts create mode 100644 packages/backend/src/models/Emoji.ts create mode 100644 packages/backend/src/models/Flash.ts create mode 100644 packages/backend/src/models/FlashLike.ts create mode 100644 packages/backend/src/models/FollowRequest.ts create mode 100644 packages/backend/src/models/Following.ts create mode 100644 packages/backend/src/models/GalleryLike.ts create mode 100644 packages/backend/src/models/GalleryPost.ts create mode 100644 packages/backend/src/models/Hashtag.ts create mode 100644 packages/backend/src/models/Instance.ts create mode 100644 packages/backend/src/models/LatestNote.ts create mode 100644 packages/backend/src/models/Meta.ts create mode 100644 packages/backend/src/models/ModerationLog.ts create mode 100644 packages/backend/src/models/Muting.ts create mode 100644 packages/backend/src/models/Note.ts create mode 100644 packages/backend/src/models/NoteEdit.ts create mode 100644 packages/backend/src/models/NoteFavorite.ts create mode 100644 packages/backend/src/models/NoteReaction.ts create mode 100644 packages/backend/src/models/NoteSchedule.ts create mode 100644 packages/backend/src/models/NoteThreadMuting.ts create mode 100644 packages/backend/src/models/NoteUnread.ts create mode 100644 packages/backend/src/models/Notification.ts create mode 100644 packages/backend/src/models/Page.ts create mode 100644 packages/backend/src/models/PageLike.ts create mode 100644 packages/backend/src/models/PasswordResetRequest.ts create mode 100644 packages/backend/src/models/Poll.ts create mode 100644 packages/backend/src/models/PollVote.ts create mode 100644 packages/backend/src/models/PromoNote.ts create mode 100644 packages/backend/src/models/PromoRead.ts create mode 100644 packages/backend/src/models/RegistrationTicket.ts create mode 100644 packages/backend/src/models/RegistryItem.ts create mode 100644 packages/backend/src/models/Relay.ts create mode 100644 packages/backend/src/models/RenoteMuting.ts create mode 100644 packages/backend/src/models/RepositoryModule.ts create mode 100644 packages/backend/src/models/RetentionAggregation.ts create mode 100644 packages/backend/src/models/ReversiGame.ts create mode 100644 packages/backend/src/models/Role.ts create mode 100644 packages/backend/src/models/RoleAssignment.ts create mode 100644 packages/backend/src/models/Signin.ts create mode 100644 packages/backend/src/models/SwSubscription.ts create mode 100644 packages/backend/src/models/SystemWebhook.ts create mode 100644 packages/backend/src/models/UsedUsername.ts create mode 100644 packages/backend/src/models/User.ts create mode 100644 packages/backend/src/models/UserIp.ts create mode 100644 packages/backend/src/models/UserKeypair.ts create mode 100644 packages/backend/src/models/UserList.ts create mode 100644 packages/backend/src/models/UserListFavorite.ts create mode 100644 packages/backend/src/models/UserListMembership.ts create mode 100644 packages/backend/src/models/UserMemo.ts create mode 100644 packages/backend/src/models/UserNotePining.ts create mode 100644 packages/backend/src/models/UserPending.ts create mode 100644 packages/backend/src/models/UserProfile.ts create mode 100644 packages/backend/src/models/UserPublickey.ts create mode 100644 packages/backend/src/models/UserSecurityKey.ts create mode 100644 packages/backend/src/models/Webhook.ts create mode 100644 packages/backend/src/models/_.ts create mode 100644 packages/backend/src/models/json-schema/abuse-report-notification-recipient.ts create mode 100644 packages/backend/src/models/json-schema/ad.ts create mode 100644 packages/backend/src/models/json-schema/announcement.ts create mode 100644 packages/backend/src/models/json-schema/antenna.ts create mode 100644 packages/backend/src/models/json-schema/app.ts create mode 100644 packages/backend/src/models/json-schema/blocking.ts create mode 100644 packages/backend/src/models/json-schema/channel.ts create mode 100644 packages/backend/src/models/json-schema/clip.ts create mode 100644 packages/backend/src/models/json-schema/drive-file.ts create mode 100644 packages/backend/src/models/json-schema/drive-folder.ts create mode 100644 packages/backend/src/models/json-schema/emoji.ts create mode 100644 packages/backend/src/models/json-schema/federation-instance.ts create mode 100644 packages/backend/src/models/json-schema/flash.ts create mode 100644 packages/backend/src/models/json-schema/following.ts create mode 100644 packages/backend/src/models/json-schema/gallery-post.ts create mode 100644 packages/backend/src/models/json-schema/hashtag.ts create mode 100644 packages/backend/src/models/json-schema/invite-code.ts create mode 100644 packages/backend/src/models/json-schema/meta.ts create mode 100644 packages/backend/src/models/json-schema/muting.ts create mode 100644 packages/backend/src/models/json-schema/note-edit.ts create mode 100644 packages/backend/src/models/json-schema/note-favorite.ts create mode 100644 packages/backend/src/models/json-schema/note-reaction.ts create mode 100644 packages/backend/src/models/json-schema/note.ts create mode 100644 packages/backend/src/models/json-schema/notification.ts create mode 100644 packages/backend/src/models/json-schema/page.ts create mode 100644 packages/backend/src/models/json-schema/queue.ts create mode 100644 packages/backend/src/models/json-schema/renote-muting.ts create mode 100644 packages/backend/src/models/json-schema/reversi-game.ts create mode 100644 packages/backend/src/models/json-schema/role.ts create mode 100644 packages/backend/src/models/json-schema/signin.ts create mode 100644 packages/backend/src/models/json-schema/system-webhook.ts create mode 100644 packages/backend/src/models/json-schema/user-list.ts create mode 100644 packages/backend/src/models/json-schema/user.ts create mode 100644 packages/backend/src/models/util/id.ts create mode 100644 packages/backend/src/postgres.ts create mode 100644 packages/backend/src/queue/QueueLoggerService.ts create mode 100644 packages/backend/src/queue/QueueProcessorModule.ts create mode 100644 packages/backend/src/queue/QueueProcessorService.ts create mode 100644 packages/backend/src/queue/const.ts create mode 100644 packages/backend/src/queue/processors/AggregateRetentionProcessorService.ts create mode 100644 packages/backend/src/queue/processors/BakeBufferedReactionsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/CheckExpiredMutingsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/CheckModeratorsActivityProcessorService.ts create mode 100644 packages/backend/src/queue/processors/CleanChartsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/CleanProcessorService.ts create mode 100644 packages/backend/src/queue/processors/CleanRemoteFilesProcessorService.ts create mode 100644 packages/backend/src/queue/processors/DeleteAccountProcessorService.ts create mode 100644 packages/backend/src/queue/processors/DeleteDriveFilesProcessorService.ts create mode 100644 packages/backend/src/queue/processors/DeleteFileProcessorService.ts create mode 100644 packages/backend/src/queue/processors/DeliverProcessorService.ts create mode 100644 packages/backend/src/queue/processors/EndedPollNotificationProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportAccountDataProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportAntennasProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportBlockingProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportClipsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportCustomEmojisProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportFavoritesProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportFollowingProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportMutingProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportNotesProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ExportUserListsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportAntennasProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportBlockingProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportCustomEmojisProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportFollowingProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportMutingProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportNotesProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ImportUserListsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/InboxProcessorService.ts create mode 100644 packages/backend/src/queue/processors/RelationshipProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ResyncChartsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/ScheduleNotePostProcessorService.ts create mode 100644 packages/backend/src/queue/processors/SystemWebhookDeliverProcessorService.ts create mode 100644 packages/backend/src/queue/processors/TickChartsProcessorService.ts create mode 100644 packages/backend/src/queue/processors/UserWebhookDeliverProcessorService.ts create mode 100644 packages/backend/src/queue/types.ts create mode 100644 packages/backend/src/server/ActivityPubServerService.ts create mode 100644 packages/backend/src/server/FileServerService.ts create mode 100644 packages/backend/src/server/HealthServerService.ts create mode 100644 packages/backend/src/server/NodeinfoServerService.ts create mode 100644 packages/backend/src/server/ServerModule.ts create mode 100644 packages/backend/src/server/ServerService.ts create mode 100644 packages/backend/src/server/SkRateLimiterService.md create mode 100644 packages/backend/src/server/WellKnownServerService.ts create mode 100644 packages/backend/src/server/api/ApiCallService.ts create mode 100644 packages/backend/src/server/api/ApiLoggerService.ts create mode 100644 packages/backend/src/server/api/ApiServerService.ts create mode 100644 packages/backend/src/server/api/AuthenticateService.ts create mode 100644 packages/backend/src/server/api/EndpointsModule.ts create mode 100644 packages/backend/src/server/api/GetterService.ts create mode 100644 packages/backend/src/server/api/RateLimiterService.ts create mode 100644 packages/backend/src/server/api/SigninApiService.ts create mode 100644 packages/backend/src/server/api/SigninService.ts create mode 100644 packages/backend/src/server/api/SigninWithPasskeyApiService.ts create mode 100644 packages/backend/src/server/api/SignupApiService.ts create mode 100644 packages/backend/src/server/api/SkRateLimiterService.ts create mode 100644 packages/backend/src/server/api/StreamingApiServerService.ts create mode 100644 packages/backend/src/server/api/endpoint-base.ts create mode 100644 packages/backend/src/server/api/endpoints.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/abuse-report/notification-recipient/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/abuse-report/notification-recipient/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/abuse-report/notification-recipient/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/abuse-report/notification-recipient/show.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/abuse-report/notification-recipient/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/abuse-user-reports.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/accounts/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/accounts/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/accounts/find-by-email.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/ad/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/ad/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/ad/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/ad/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/announcements/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/announcements/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/announcements/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/announcements/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/approve-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/avatar-decorations/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/avatar-decorations/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/avatar-decorations/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/avatar-decorations/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/decline-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/delete-account.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/delete-all-files-of-a-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/drive/clean-remote-files.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/drive/cleanup.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/drive/files.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/drive/show-file.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/add-aliases-bulk.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/add.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/copy.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/delete-bulk.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/import-zip.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/list-remote.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/remove-aliases-bulk.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/set-aliases-bulk.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/set-category-bulk.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/set-license-bulk.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/emoji/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/federation/delete-all-files.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/federation/refresh-remote-instance-metadata.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/federation/remove-all-following.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/federation/update-instance.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/forward-abuse-user-report.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/get-index-stats.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/get-table-stats.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/get-user-ips.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/invite/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/invite/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/meta.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/nsfw-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/promo/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/queue/clear.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/queue/deliver-delayed.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/queue/inbox-delayed.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/queue/promote.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/queue/stats.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/relays/add.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/relays/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/relays/remove.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/reset-password.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/resolve-abuse-user-report.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/assign.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/show.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/unassign.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/update-default-policies.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/roles/users.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/send-email.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/server-info.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/show-moderation-logs.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/show-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/show-users.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/silence-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/suspend-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/system-webhook/create.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/system-webhook/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/system-webhook/list.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/system-webhook/show.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/system-webhook/test.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/system-webhook/update.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/unnsfw-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/unset-user-avatar.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/unset-user-banner.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/unsilence-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/unsuspend-user.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/update-abuse-user-report.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/update-meta.ts create mode 100644 packages/backend/src/server/api/endpoints/admin/update-user-note.ts create mode 100644 packages/backend/src/server/api/endpoints/announcements.ts create mode 100644 packages/backend/src/server/api/endpoints/announcements/show.ts create mode 100644 packages/backend/src/server/api/endpoints/antennas/create.ts create mode 100644 packages/backend/src/server/api/endpoints/antennas/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/antennas/list.ts create mode 100644 packages/backend/src/server/api/endpoints/antennas/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/antennas/show.ts create mode 100644 packages/backend/src/server/api/endpoints/antennas/update.ts create mode 100644 packages/backend/src/server/api/endpoints/ap/get.ts create mode 100644 packages/backend/src/server/api/endpoints/ap/show.ts create mode 100644 packages/backend/src/server/api/endpoints/app/create.ts create mode 100644 packages/backend/src/server/api/endpoints/app/show.ts create mode 100644 packages/backend/src/server/api/endpoints/auth/accept.ts create mode 100644 packages/backend/src/server/api/endpoints/auth/session/generate.ts create mode 100644 packages/backend/src/server/api/endpoints/auth/session/show.ts create mode 100644 packages/backend/src/server/api/endpoints/auth/session/userkey.ts create mode 100644 packages/backend/src/server/api/endpoints/blocking/create.ts create mode 100644 packages/backend/src/server/api/endpoints/blocking/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/blocking/list.ts create mode 100644 packages/backend/src/server/api/endpoints/bubble-game/ranking.ts create mode 100644 packages/backend/src/server/api/endpoints/bubble-game/register.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/create.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/favorite.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/featured.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/follow.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/followed.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/my-favorites.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/owned.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/search.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/show.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/unfavorite.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/unfollow.ts create mode 100644 packages/backend/src/server/api/endpoints/channels/update.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/active-users.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/ap-request.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/drive.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/federation.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/instance.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/user/drive.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/user/following.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/user/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/user/pv.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/user/reactions.ts create mode 100644 packages/backend/src/server/api/endpoints/charts/users.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/add-note.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/create.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/favorite.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/list.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/my-favorites.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/remove-note.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/show.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/unfavorite.ts create mode 100644 packages/backend/src/server/api/endpoints/clips/update.ts create mode 100644 packages/backend/src/server/api/endpoints/drive.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/attached-notes.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/check-existence.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/create.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/find-by-hash.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/find.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/show.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/update.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/files/upload-from-url.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/folders.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/folders/create.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/folders/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/folders/find.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/folders/show.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/folders/update.ts create mode 100644 packages/backend/src/server/api/endpoints/drive/stream.ts create mode 100644 packages/backend/src/server/api/endpoints/email-address/available.ts create mode 100644 packages/backend/src/server/api/endpoints/emoji.ts create mode 100644 packages/backend/src/server/api/endpoints/emojis.ts create mode 100644 packages/backend/src/server/api/endpoints/endpoint.ts create mode 100644 packages/backend/src/server/api/endpoints/endpoints.ts create mode 100644 packages/backend/src/server/api/endpoints/export-custom-emojis.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/followers.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/following.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/instances.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/show-instance.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/stats.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/update-remote-user.ts create mode 100644 packages/backend/src/server/api/endpoints/federation/users.ts create mode 100644 packages/backend/src/server/api/endpoints/fetch-external-resources.ts create mode 100644 packages/backend/src/server/api/endpoints/fetch-rss.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/create.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/featured.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/like.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/my-likes.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/my.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/show.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/unlike.ts create mode 100644 packages/backend/src/server/api/endpoints/flash/update.ts create mode 100644 packages/backend/src/server/api/endpoints/following/create.ts create mode 100644 packages/backend/src/server/api/endpoints/following/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/following/invalidate.ts create mode 100644 packages/backend/src/server/api/endpoints/following/requests/accept.ts create mode 100644 packages/backend/src/server/api/endpoints/following/requests/cancel.ts create mode 100644 packages/backend/src/server/api/endpoints/following/requests/list.ts create mode 100644 packages/backend/src/server/api/endpoints/following/requests/reject.ts create mode 100644 packages/backend/src/server/api/endpoints/following/requests/sent.ts create mode 100644 packages/backend/src/server/api/endpoints/following/update-all.ts create mode 100644 packages/backend/src/server/api/endpoints/following/update.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/featured.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/popular.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts/create.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts/like.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts/show.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts/unlike.ts create mode 100644 packages/backend/src/server/api/endpoints/gallery/posts/update.ts create mode 100644 packages/backend/src/server/api/endpoints/get-avatar-decorations.ts create mode 100644 packages/backend/src/server/api/endpoints/get-online-users-count.ts create mode 100644 packages/backend/src/server/api/endpoints/hashtags/list.ts create mode 100644 packages/backend/src/server/api/endpoints/hashtags/search.ts create mode 100644 packages/backend/src/server/api/endpoints/hashtags/show.ts create mode 100644 packages/backend/src/server/api/endpoints/hashtags/trend.ts create mode 100644 packages/backend/src/server/api/endpoints/hashtags/users.ts create mode 100644 packages/backend/src/server/api/endpoints/i.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/done.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/key-done.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/password-less.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/register-key.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/register.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/remove-key.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/unregister.ts create mode 100644 packages/backend/src/server/api/endpoints/i/2fa/update-key.ts create mode 100644 packages/backend/src/server/api/endpoints/i/apps.ts create mode 100644 packages/backend/src/server/api/endpoints/i/authorized-apps.ts create mode 100644 packages/backend/src/server/api/endpoints/i/change-password.ts create mode 100644 packages/backend/src/server/api/endpoints/i/claim-achievement.ts create mode 100644 packages/backend/src/server/api/endpoints/i/delete-account.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-antennas.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-blocking.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-clips.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-data.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-favorites.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-following.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-mute.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-notes.ts create mode 100644 packages/backend/src/server/api/endpoints/i/export-user-lists.ts create mode 100644 packages/backend/src/server/api/endpoints/i/favorites.ts create mode 100644 packages/backend/src/server/api/endpoints/i/gallery/likes.ts create mode 100644 packages/backend/src/server/api/endpoints/i/gallery/posts.ts create mode 100644 packages/backend/src/server/api/endpoints/i/import-antennas.ts create mode 100644 packages/backend/src/server/api/endpoints/i/import-blocking.ts create mode 100644 packages/backend/src/server/api/endpoints/i/import-following.ts create mode 100644 packages/backend/src/server/api/endpoints/i/import-muting.ts create mode 100644 packages/backend/src/server/api/endpoints/i/import-notes.ts create mode 100644 packages/backend/src/server/api/endpoints/i/import-user-lists.ts create mode 100644 packages/backend/src/server/api/endpoints/i/move.ts create mode 100644 packages/backend/src/server/api/endpoints/i/notifications-grouped.ts create mode 100644 packages/backend/src/server/api/endpoints/i/notifications.ts create mode 100644 packages/backend/src/server/api/endpoints/i/page-likes.ts create mode 100644 packages/backend/src/server/api/endpoints/i/pages.ts create mode 100644 packages/backend/src/server/api/endpoints/i/pin.ts create mode 100644 packages/backend/src/server/api/endpoints/i/read-all-unread-notes.ts create mode 100644 packages/backend/src/server/api/endpoints/i/read-announcement.ts create mode 100644 packages/backend/src/server/api/endpoints/i/regenerate-token.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/get-all.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/get-detail.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/get-unsecure.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/get.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/keys-with-type.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/keys.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/remove.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/scopes-with-domain.ts create mode 100644 packages/backend/src/server/api/endpoints/i/registry/set.ts create mode 100644 packages/backend/src/server/api/endpoints/i/revoke-token.ts create mode 100644 packages/backend/src/server/api/endpoints/i/signin-history.ts create mode 100644 packages/backend/src/server/api/endpoints/i/unpin.ts create mode 100644 packages/backend/src/server/api/endpoints/i/update-email.ts create mode 100644 packages/backend/src/server/api/endpoints/i/update.ts create mode 100644 packages/backend/src/server/api/endpoints/i/webhooks/create.ts create mode 100644 packages/backend/src/server/api/endpoints/i/webhooks/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/i/webhooks/list.ts create mode 100644 packages/backend/src/server/api/endpoints/i/webhooks/show.ts create mode 100644 packages/backend/src/server/api/endpoints/i/webhooks/test.ts create mode 100644 packages/backend/src/server/api/endpoints/i/webhooks/update.ts create mode 100644 packages/backend/src/server/api/endpoints/invite/create.ts create mode 100644 packages/backend/src/server/api/endpoints/invite/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/invite/limit.ts create mode 100644 packages/backend/src/server/api/endpoints/invite/list.ts create mode 100644 packages/backend/src/server/api/endpoints/meta.ts create mode 100644 packages/backend/src/server/api/endpoints/miauth/gen-token.ts create mode 100644 packages/backend/src/server/api/endpoints/mute/create.ts create mode 100644 packages/backend/src/server/api/endpoints/mute/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/mute/list.ts create mode 100644 packages/backend/src/server/api/endpoints/my/apps.ts create mode 100644 packages/backend/src/server/api/endpoints/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/bubble-timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/children.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/clips.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/conversation.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/create.test.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/create.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/edit.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/favorites/create.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/favorites/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/featured.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/following.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/global-timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/hybrid-timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/like.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/local-timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/mentions.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/polls/recommendation.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/polls/refresh.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/polls/vote.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/reactions.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/reactions/create.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/reactions/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/renotes.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/replies.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/schedule/create.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/schedule/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/schedule/list.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/search-by-tag.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/search.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/show.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/state.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/thread-muting/create.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/thread-muting/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/translate.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/unrenote.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/user-list-timeline.ts create mode 100644 packages/backend/src/server/api/endpoints/notes/versions.ts create mode 100644 packages/backend/src/server/api/endpoints/notifications/create.ts create mode 100644 packages/backend/src/server/api/endpoints/notifications/flush.ts create mode 100644 packages/backend/src/server/api/endpoints/notifications/mark-all-as-read.ts create mode 100644 packages/backend/src/server/api/endpoints/notifications/test-notification.ts create mode 100644 packages/backend/src/server/api/endpoints/page-push.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/create.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/featured.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/like.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/show.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/unlike.ts create mode 100644 packages/backend/src/server/api/endpoints/pages/update.ts create mode 100644 packages/backend/src/server/api/endpoints/ping.ts create mode 100644 packages/backend/src/server/api/endpoints/pinned-users.ts create mode 100644 packages/backend/src/server/api/endpoints/promo/read.ts create mode 100644 packages/backend/src/server/api/endpoints/renote-mute/create.ts create mode 100644 packages/backend/src/server/api/endpoints/renote-mute/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/renote-mute/list.ts create mode 100644 packages/backend/src/server/api/endpoints/request-reset-password.ts create mode 100644 packages/backend/src/server/api/endpoints/reset-db.ts create mode 100644 packages/backend/src/server/api/endpoints/reset-password.ts create mode 100644 packages/backend/src/server/api/endpoints/retention.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/cancel-match.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/games.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/invitations.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/match.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/show-game.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/surrender.ts create mode 100644 packages/backend/src/server/api/endpoints/reversi/verify.ts create mode 100644 packages/backend/src/server/api/endpoints/roles/list.ts create mode 100644 packages/backend/src/server/api/endpoints/roles/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/roles/show.ts create mode 100644 packages/backend/src/server/api/endpoints/roles/users.ts create mode 100644 packages/backend/src/server/api/endpoints/server-info.ts create mode 100644 packages/backend/src/server/api/endpoints/sponsors.ts create mode 100644 packages/backend/src/server/api/endpoints/stats.ts create mode 100644 packages/backend/src/server/api/endpoints/sw/register.ts create mode 100644 packages/backend/src/server/api/endpoints/sw/show-registration.ts create mode 100644 packages/backend/src/server/api/endpoints/sw/unregister.ts create mode 100644 packages/backend/src/server/api/endpoints/sw/update-registration.ts create mode 100644 packages/backend/src/server/api/endpoints/test.ts create mode 100644 packages/backend/src/server/api/endpoints/username/available.ts create mode 100644 packages/backend/src/server/api/endpoints/users.ts create mode 100644 packages/backend/src/server/api/endpoints/users/achievements.ts create mode 100644 packages/backend/src/server/api/endpoints/users/clips.ts create mode 100644 packages/backend/src/server/api/endpoints/users/featured-notes.ts create mode 100644 packages/backend/src/server/api/endpoints/users/flashs.ts create mode 100644 packages/backend/src/server/api/endpoints/users/followers.ts create mode 100644 packages/backend/src/server/api/endpoints/users/following.ts create mode 100644 packages/backend/src/server/api/endpoints/users/gallery/posts.ts create mode 100644 packages/backend/src/server/api/endpoints/users/get-frequently-replied-users.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/create-from-public.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/create.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/delete.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/favorite.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/get-memberships.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/list.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/pull.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/push.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/show.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/unfavorite.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/update-membership.ts create mode 100644 packages/backend/src/server/api/endpoints/users/lists/update.ts create mode 100644 packages/backend/src/server/api/endpoints/users/notes.ts create mode 100644 packages/backend/src/server/api/endpoints/users/pages.ts create mode 100644 packages/backend/src/server/api/endpoints/users/reactions.ts create mode 100644 packages/backend/src/server/api/endpoints/users/recommendation.ts create mode 100644 packages/backend/src/server/api/endpoints/users/relation.ts create mode 100644 packages/backend/src/server/api/endpoints/users/report-abuse.ts create mode 100644 packages/backend/src/server/api/endpoints/users/search-by-username-and-host.ts create mode 100644 packages/backend/src/server/api/endpoints/users/search.ts create mode 100644 packages/backend/src/server/api/endpoints/users/show.ts create mode 100644 packages/backend/src/server/api/endpoints/users/update-memo.ts create mode 100644 packages/backend/src/server/api/error.ts create mode 100644 packages/backend/src/server/api/mastodon/MastodonApiServerService.ts create mode 100644 packages/backend/src/server/api/mastodon/converters.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/account.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/auth.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/filter.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/meta.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/notifications.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/search.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/status.ts create mode 100644 packages/backend/src/server/api/mastodon/endpoints/timeline.ts create mode 100644 packages/backend/src/server/api/openapi/OpenApiServerService.ts create mode 100644 packages/backend/src/server/api/openapi/errors.ts create mode 100644 packages/backend/src/server/api/openapi/gen-spec.ts create mode 100644 packages/backend/src/server/api/openapi/schemas.ts create mode 100644 packages/backend/src/server/api/stream/ChannelsService.ts create mode 100644 packages/backend/src/server/api/stream/Connection.ts create mode 100644 packages/backend/src/server/api/stream/channel.ts create mode 100644 packages/backend/src/server/api/stream/channels/admin.ts create mode 100644 packages/backend/src/server/api/stream/channels/antenna.ts create mode 100644 packages/backend/src/server/api/stream/channels/bubble-timeline.ts create mode 100644 packages/backend/src/server/api/stream/channels/channel.ts create mode 100644 packages/backend/src/server/api/stream/channels/drive.ts create mode 100644 packages/backend/src/server/api/stream/channels/global-timeline.ts create mode 100644 packages/backend/src/server/api/stream/channels/hashtag.ts create mode 100644 packages/backend/src/server/api/stream/channels/home-timeline.ts create mode 100644 packages/backend/src/server/api/stream/channels/hybrid-timeline.ts create mode 100644 packages/backend/src/server/api/stream/channels/local-timeline.ts create mode 100644 packages/backend/src/server/api/stream/channels/main.ts create mode 100644 packages/backend/src/server/api/stream/channels/queue-stats.ts create mode 100644 packages/backend/src/server/api/stream/channels/reversi-game.ts create mode 100644 packages/backend/src/server/api/stream/channels/reversi.ts create mode 100644 packages/backend/src/server/api/stream/channels/role-timeline.ts create mode 100644 packages/backend/src/server/api/stream/channels/server-stats.ts create mode 100644 packages/backend/src/server/api/stream/channels/user-list.ts create mode 100644 packages/backend/src/server/assets/bad-egg.png create mode 100644 packages/backend/src/server/assets/cache-expired.png create mode 100644 packages/backend/src/server/assets/dummy.png create mode 100644 packages/backend/src/server/assets/not-an-image.png create mode 100644 packages/backend/src/server/assets/thumbnail-not-available.png create mode 100644 packages/backend/src/server/assets/tombstone.png create mode 100644 packages/backend/src/server/oauth/OAuth2ProviderService.ts create mode 100644 packages/backend/src/server/web/ClientLoggerService.ts create mode 100644 packages/backend/src/server/web/ClientServerService.ts create mode 100644 packages/backend/src/server/web/FeedService.ts create mode 100644 packages/backend/src/server/web/UrlPreviewService.ts create mode 100644 packages/backend/src/server/web/bios.css create mode 100644 packages/backend/src/server/web/bios.js create mode 100644 packages/backend/src/server/web/boot.embed.js create mode 100644 packages/backend/src/server/web/boot.js create mode 100644 packages/backend/src/server/web/cli.css create mode 100644 packages/backend/src/server/web/cli.js create mode 100644 packages/backend/src/server/web/error.css create mode 100644 packages/backend/src/server/web/manifest.json create mode 100644 packages/backend/src/server/web/style.css create mode 100644 packages/backend/src/server/web/style.embed.css create mode 100644 packages/backend/src/server/web/views/announcement.pug create mode 100644 packages/backend/src/server/web/views/base-embed.pug create mode 100644 packages/backend/src/server/web/views/base.pug create mode 100644 packages/backend/src/server/web/views/bios.pug create mode 100644 packages/backend/src/server/web/views/channel.pug create mode 100644 packages/backend/src/server/web/views/cli.pug create mode 100644 packages/backend/src/server/web/views/clip.pug create mode 100644 packages/backend/src/server/web/views/error.pug create mode 100644 packages/backend/src/server/web/views/flash.pug create mode 100644 packages/backend/src/server/web/views/flush.pug create mode 100644 packages/backend/src/server/web/views/gallery-post.pug create mode 100644 packages/backend/src/server/web/views/info-card.pug create mode 100644 packages/backend/src/server/web/views/note.pug create mode 100644 packages/backend/src/server/web/views/oauth.pug create mode 100644 packages/backend/src/server/web/views/page.pug create mode 100644 packages/backend/src/server/web/views/reversi-game.pug create mode 100644 packages/backend/src/server/web/views/user.pug create mode 100644 packages/backend/src/types.ts create mode 100644 packages/backend/test-federation/.config/example.conf create mode 100644 packages/backend/test-federation/.config/example.default.yml create mode 100644 packages/backend/test-federation/.config/example.docker.env create mode 100644 packages/backend/test-federation/.gitignore create mode 100644 packages/backend/test-federation/README.md create mode 100644 packages/backend/test-federation/compose.a.yml create mode 100644 packages/backend/test-federation/compose.b.yml create mode 100644 packages/backend/test-federation/compose.override.yaml create mode 100644 packages/backend/test-federation/compose.tpl.yml create mode 100644 packages/backend/test-federation/compose.yml create mode 100644 packages/backend/test-federation/daemon.ts create mode 100644 packages/backend/test-federation/eslint.config.js create mode 100644 packages/backend/test-federation/setup.sh create mode 100644 packages/backend/test-federation/test/abuse-report.test.ts create mode 100644 packages/backend/test-federation/test/block.test.ts create mode 100644 packages/backend/test-federation/test/drive.test.ts create mode 100644 packages/backend/test-federation/test/emoji.test.ts create mode 100644 packages/backend/test-federation/test/move.test.ts create mode 100644 packages/backend/test-federation/test/note.test.ts create mode 100644 packages/backend/test-federation/test/notification.test.ts create mode 100644 packages/backend/test-federation/test/timeline.test.ts create mode 100644 packages/backend/test-federation/test/user.test.ts create mode 100644 packages/backend/test-federation/test/utils.ts create mode 100644 packages/backend/test-federation/tsconfig.json create mode 100644 packages/backend/test-server/.swcrc create mode 100644 packages/backend/test-server/entry.ts create mode 100644 packages/backend/test-server/eslint.config.js create mode 100644 packages/backend/test-server/tsconfig.json create mode 100644 packages/backend/test/compose.yml create mode 100644 packages/backend/test/e2e/2fa.ts create mode 100644 packages/backend/test/e2e/antennas.ts create mode 100644 packages/backend/test/e2e/api-visibility.ts create mode 100644 packages/backend/test/e2e/api.ts create mode 100644 packages/backend/test/e2e/block.ts create mode 100644 packages/backend/test/e2e/clips.ts create mode 100644 packages/backend/test/e2e/drive.ts create mode 100644 packages/backend/test/e2e/endpoints.ts create mode 100644 packages/backend/test/e2e/exports.ts create mode 100644 packages/backend/test/e2e/fetch-resource.ts create mode 100644 packages/backend/test/e2e/fetch-validate-ap-deny.ts create mode 100644 packages/backend/test/e2e/ff-visibility.ts create mode 100644 packages/backend/test/e2e/move.ts create mode 100644 packages/backend/test/e2e/mute.ts create mode 100644 packages/backend/test/e2e/nodeinfo.ts create mode 100644 packages/backend/test/e2e/note.ts create mode 100644 packages/backend/test/e2e/oauth.ts create mode 100644 packages/backend/test/e2e/renote-mute.ts create mode 100644 packages/backend/test/e2e/reversi-game.ts create mode 100644 packages/backend/test/e2e/streaming.ts create mode 100644 packages/backend/test/e2e/synalio/abuse-report.ts create mode 100644 packages/backend/test/e2e/synalio/user-create.ts create mode 100644 packages/backend/test/e2e/thread-mute.ts create mode 100644 packages/backend/test/e2e/timelines.ts create mode 100644 packages/backend/test/e2e/user-notes.ts create mode 100644 packages/backend/test/e2e/users.ts create mode 100644 packages/backend/test/e2e/well-known.ts create mode 100644 packages/backend/test/eslint.config.js create mode 100644 packages/backend/test/global.d.ts create mode 100644 packages/backend/test/jest.setup.ts create mode 100644 packages/backend/test/misc/mock-resolver.ts create mode 100644 packages/backend/test/prelude/get-api-validator.ts create mode 100644 packages/backend/test/prelude/url.ts create mode 100644 packages/backend/test/resources/192.jpg create mode 100644 packages/backend/test/resources/192.png create mode 100644 packages/backend/test/resources/25000x25000.png create mode 100644 packages/backend/test/resources/anime.gif create mode 100644 packages/backend/test/resources/anime.png create mode 100644 packages/backend/test/resources/emptyfile create mode 100644 packages/backend/test/resources/image.svg create mode 100644 packages/backend/test/resources/kick_gaba7.aac create mode 100644 packages/backend/test/resources/kick_gaba7.flac create mode 100644 packages/backend/test/resources/kick_gaba7.m4a create mode 100644 packages/backend/test/resources/kick_gaba7.mp3 create mode 100644 packages/backend/test/resources/kick_gaba7.wav create mode 100644 packages/backend/test/resources/kick_gaba7.webm create mode 100644 packages/backend/test/resources/misskey.svg create mode 100644 packages/backend/test/resources/rotate.jpg create mode 100644 packages/backend/test/resources/with-alpha.avif create mode 100644 packages/backend/test/resources/with-alpha.png create mode 100644 packages/backend/test/resources/with-alpha.webp create mode 100644 packages/backend/test/resources/with-xml-def.svg create mode 100644 packages/backend/test/resources/without-alpha.avif create mode 100644 packages/backend/test/resources/without-alpha.webp create mode 100644 packages/backend/test/tsconfig.json create mode 100644 packages/backend/test/unit/AbuseReportNotificationService.ts create mode 100644 packages/backend/test/unit/AnnouncementService.ts create mode 100644 packages/backend/test/unit/ApMfmService.ts create mode 100644 packages/backend/test/unit/DriveService.ts create mode 100644 packages/backend/test/unit/FetchInstanceMetadataService.ts create mode 100644 packages/backend/test/unit/FileInfoService.ts create mode 100644 packages/backend/test/unit/FlashService.ts create mode 100644 packages/backend/test/unit/MetaService.ts create mode 100644 packages/backend/test/unit/MfmService.ts create mode 100644 packages/backend/test/unit/NoteCreateService.ts create mode 100644 packages/backend/test/unit/ReactionService.ts create mode 100644 packages/backend/test/unit/RelayService.ts create mode 100644 packages/backend/test/unit/RoleService.ts create mode 100644 packages/backend/test/unit/S3Service.ts create mode 100644 packages/backend/test/unit/SigninWithPasskeyApiService.ts create mode 100644 packages/backend/test/unit/SystemWebhookService.ts create mode 100644 packages/backend/test/unit/UserSearchService.ts create mode 100644 packages/backend/test/unit/UserWebhookService.ts create mode 100644 packages/backend/test/unit/UtilityService.ts create mode 100644 packages/backend/test/unit/WebhookTestService.ts create mode 100644 packages/backend/test/unit/activitypub.ts create mode 100644 packages/backend/test/unit/ap-request.ts create mode 100644 packages/backend/test/unit/chart.ts create mode 100644 packages/backend/test/unit/entities/UserEntityService.ts create mode 100644 packages/backend/test/unit/extract-mentions.ts create mode 100644 packages/backend/test/unit/misc/check-against-url.ts create mode 100644 packages/backend/test/unit/misc/check-word-mute.ts create mode 100644 packages/backend/test/unit/misc/correct-filename.ts create mode 100644 packages/backend/test/unit/misc/from-tuple.ts create mode 100644 packages/backend/test/unit/misc/id.ts create mode 100644 packages/backend/test/unit/misc/is-renote.ts create mode 100644 packages/backend/test/unit/misc/is-system-account.ts create mode 100644 packages/backend/test/unit/misc/loader.ts create mode 100644 packages/backend/test/unit/misc/others.ts create mode 100644 packages/backend/test/unit/misc/rate-limit-utils-tests.ts create mode 100644 packages/backend/test/unit/models/LatestNote.ts create mode 100644 packages/backend/test/unit/queue/processors/CheckModeratorsActivityProcessorService.ts create mode 100644 packages/backend/test/unit/server/api/SkRateLimiterServiceTests.ts create mode 100644 packages/backend/test/utils.ts create mode 100644 packages/backend/tsconfig.json create mode 100644 packages/frontend-embed/.gitignore create mode 100644 packages/frontend-embed/@types/global.d.ts create mode 100644 packages/frontend-embed/@types/theme.d.ts create mode 100644 packages/frontend-embed/assets/dummy.png create mode 100644 packages/frontend-embed/eslint.config.js create mode 100644 packages/frontend-embed/package.json create mode 100644 packages/frontend-embed/src/boot.ts create mode 100644 packages/frontend-embed/src/components/EmA.vue create mode 100644 packages/frontend-embed/src/components/EmAcct.vue create mode 100644 packages/frontend-embed/src/components/EmAvatar.vue create mode 100644 packages/frontend-embed/src/components/EmCustomEmoji.vue create mode 100644 packages/frontend-embed/src/components/EmEmoji.vue create mode 100644 packages/frontend-embed/src/components/EmError.vue create mode 100644 packages/frontend-embed/src/components/EmImgWithBlurhash.vue create mode 100644 packages/frontend-embed/src/components/EmInstanceTicker.vue create mode 100644 packages/frontend-embed/src/components/EmLink.vue create mode 100644 packages/frontend-embed/src/components/EmLoading.vue create mode 100644 packages/frontend-embed/src/components/EmMediaBanner.vue create mode 100644 packages/frontend-embed/src/components/EmMediaImage.vue create mode 100644 packages/frontend-embed/src/components/EmMediaList.vue create mode 100644 packages/frontend-embed/src/components/EmMediaVideo.vue create mode 100644 packages/frontend-embed/src/components/EmMention.vue create mode 100644 packages/frontend-embed/src/components/EmMfm.ts create mode 100644 packages/frontend-embed/src/components/EmNote.vue create mode 100644 packages/frontend-embed/src/components/EmNoteDetailed.vue create mode 100644 packages/frontend-embed/src/components/EmNoteHeader.vue create mode 100644 packages/frontend-embed/src/components/EmNoteSimple.vue create mode 100644 packages/frontend-embed/src/components/EmNoteSub.vue create mode 100644 packages/frontend-embed/src/components/EmNotes.vue create mode 100644 packages/frontend-embed/src/components/EmPagination.vue create mode 100644 packages/frontend-embed/src/components/EmPoll.vue create mode 100644 packages/frontend-embed/src/components/EmReactionIcon.vue create mode 100644 packages/frontend-embed/src/components/EmReactionsViewer.reaction.vue create mode 100644 packages/frontend-embed/src/components/EmReactionsViewer.vue create mode 100644 packages/frontend-embed/src/components/EmSubNoteContent.vue create mode 100644 packages/frontend-embed/src/components/EmTime.vue create mode 100644 packages/frontend-embed/src/components/EmTimelineContainer.vue create mode 100644 packages/frontend-embed/src/components/EmUrl.vue create mode 100644 packages/frontend-embed/src/components/EmUserName.vue create mode 100644 packages/frontend-embed/src/components/I18n.vue create mode 100644 packages/frontend-embed/src/custom-emojis.ts create mode 100644 packages/frontend-embed/src/di.ts create mode 100644 packages/frontend-embed/src/i18n.ts create mode 100644 packages/frontend-embed/src/index.html create mode 100644 packages/frontend-embed/src/misskey-api.ts create mode 100644 packages/frontend-embed/src/pages/clip.vue create mode 100644 packages/frontend-embed/src/pages/not-found.vue create mode 100644 packages/frontend-embed/src/pages/note.vue create mode 100644 packages/frontend-embed/src/pages/tag.vue create mode 100644 packages/frontend-embed/src/pages/user-timeline.vue create mode 100644 packages/frontend-embed/src/post-message.ts create mode 100644 packages/frontend-embed/src/server-context.ts create mode 100644 packages/frontend-embed/src/server-metadata.ts create mode 100644 packages/frontend-embed/src/style.scss create mode 100644 packages/frontend-embed/src/theme.ts create mode 100644 packages/frontend-embed/src/ui.vue create mode 100644 packages/frontend-embed/src/utils.ts create mode 100644 packages/frontend-embed/src/workers/draw-blurhash.ts create mode 100644 packages/frontend-embed/src/workers/test-webgl2.ts create mode 100644 packages/frontend-embed/src/workers/tsconfig.json create mode 100644 packages/frontend-embed/tsconfig.json create mode 100644 packages/frontend-embed/vite.config.local-dev.ts create mode 100644 packages/frontend-embed/vite.config.ts create mode 100644 packages/frontend-embed/vite.json5.ts create mode 100644 packages/frontend-embed/vue-shims.d.ts create mode 100644 packages/frontend-shared/.gitignore create mode 100644 packages/frontend-shared/@types/global.d.ts create mode 100644 packages/frontend-shared/build.js create mode 100644 packages/frontend-shared/eslint.config.js create mode 100644 packages/frontend-shared/js/collapsed.ts create mode 100644 packages/frontend-shared/js/config.ts create mode 100644 packages/frontend-shared/js/const.ts create mode 100644 packages/frontend-shared/js/embed-page.ts create mode 100644 packages/frontend-shared/js/emoji-base.ts create mode 100644 packages/frontend-shared/js/emojilist.json create mode 100644 packages/frontend-shared/js/emojilist.ts create mode 100644 packages/frontend-shared/js/extract-avg-color-from-blurhash.ts create mode 100644 packages/frontend-shared/js/i18n.ts create mode 100644 packages/frontend-shared/js/intl-const.ts create mode 100644 packages/frontend-shared/js/is-link.ts create mode 100644 packages/frontend-shared/js/media-proxy.ts create mode 100644 packages/frontend-shared/js/scroll.ts create mode 100644 packages/frontend-shared/js/url.ts create mode 100644 packages/frontend-shared/js/use-document-visibility.ts create mode 100644 packages/frontend-shared/js/use-interval.ts create mode 100644 packages/frontend-shared/js/worker-multi-dispatch.ts create mode 100644 packages/frontend-shared/package.json create mode 100644 packages/frontend-shared/themes/_dark.json5 create mode 100644 packages/frontend-shared/themes/_light.json5 create mode 100644 packages/frontend-shared/themes/d-astro.json5 create mode 100644 packages/frontend-shared/themes/d-botanical.json5 create mode 100644 packages/frontend-shared/themes/d-cherry.json5 create mode 100644 packages/frontend-shared/themes/d-dark.json5 create mode 100644 packages/frontend-shared/themes/d-future.json5 create mode 100644 packages/frontend-shared/themes/d-green-lime.json5 create mode 100644 packages/frontend-shared/themes/d-green-orange.json5 create mode 100644 packages/frontend-shared/themes/d-ice.json5 create mode 100644 packages/frontend-shared/themes/d-persimmon.json5 create mode 100644 packages/frontend-shared/themes/d-u0.json5 create mode 100644 packages/frontend-shared/themes/l-apricot.json5 create mode 100644 packages/frontend-shared/themes/l-botanical.json5 create mode 100644 packages/frontend-shared/themes/l-cherry.json5 create mode 100644 packages/frontend-shared/themes/l-coffee.json5 create mode 100644 packages/frontend-shared/themes/l-light.json5 create mode 100644 packages/frontend-shared/themes/l-rainy.json5 create mode 100644 packages/frontend-shared/themes/l-sushi.json5 create mode 100644 packages/frontend-shared/themes/l-u0.json5 create mode 100644 packages/frontend-shared/themes/l-vivid.json5 create mode 100644 packages/frontend-shared/themes/rosepine-dawn.json5 create mode 100644 packages/frontend-shared/themes/rosepine.json5 create mode 100644 packages/frontend-shared/tsconfig.json create mode 100644 packages/frontend/.gitignore create mode 100644 packages/frontend/.storybook/.gitignore create mode 100644 packages/frontend/.storybook/changes.ts create mode 100644 packages/frontend/.storybook/charts.ts create mode 100644 packages/frontend/.storybook/fakes.ts create mode 100644 packages/frontend/.storybook/generate.tsx create mode 100644 packages/frontend/.storybook/main.ts create mode 100644 packages/frontend/.storybook/manager.ts create mode 100644 packages/frontend/.storybook/mocks.ts create mode 100644 packages/frontend/.storybook/package.json create mode 100644 packages/frontend/.storybook/preload-locale.ts create mode 100644 packages/frontend/.storybook/preload-theme.ts create mode 100644 packages/frontend/.storybook/preview-head.html create mode 100644 packages/frontend/.storybook/preview.ts create mode 100644 packages/frontend/.storybook/tsconfig.json create mode 100644 packages/frontend/.vscode/settings.json create mode 100644 packages/frontend/.vscode/storybook.code-snippets create mode 100644 packages/frontend/@types/global.d.ts create mode 100644 packages/frontend/@types/theme.d.ts create mode 100644 packages/frontend/assets/about-icon.png create mode 100644 packages/frontend/assets/cookie.png create mode 100644 packages/frontend/assets/drop-and-fusion/bgm_1.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/click.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/collision.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/collision_yen.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/drop-arrow.svg create mode 100644 packages/frontend/assets/drop-and-fusion/drop.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/drop_yen.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/dropper.png create mode 100644 packages/frontend/assets/drop-and-fusion/frame-dark.svg create mode 100644 packages/frontend/assets/drop-and-fusion/frame-light.svg create mode 100644 packages/frontend/assets/drop-and-fusion/fusion.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/fusion_yen.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/gameover.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/gameover.png create mode 100644 packages/frontend/assets/drop-and-fusion/gameover_yen.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/go.png create mode 100644 packages/frontend/assets/drop-and-fusion/hold.mp3 create mode 100644 packages/frontend/assets/drop-and-fusion/logo.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/cold_face.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/exploding_head.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/face_with_open_mouth.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/face_with_symbols_on_mouth.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/grinning_squinting_face.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/heart_suit.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/pleading_face.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/smiling_face_with_hearts.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/smiling_face_with_sunglasses.png create mode 100644 packages/frontend/assets/drop-and-fusion/normal_monos/zany_face.png create mode 100644 packages/frontend/assets/drop-and-fusion/ready.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_1.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_10.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_2.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_3.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_4.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_5.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_6.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_7.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_8.png create mode 100644 packages/frontend/assets/drop-and-fusion/square_monos/keycap_9.png create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/candy_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/chocolate_bar_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/cookie_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/custard_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/doughnut_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/lollipop_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/pancakes_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/shaved_ice_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/shortcake_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/soft_ice_cream_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/candy_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/chocolate_bar_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/custard_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/doughnut_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/lollipop_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/pancakes_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/shaved_ice_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/shortcake_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/sweets_monos/verts/soft_ice_cream_color.svg create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/10000yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/1000yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/100yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/10yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/1yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/2000yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/5000yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/500yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/50yen.png create mode 100644 packages/frontend/assets/drop-and-fusion/yen_monos/5yen.png create mode 100644 packages/frontend/assets/dummy.png create mode 100644 packages/frontend/assets/fedi.jpg create mode 100644 packages/frontend/assets/label-red.svg create mode 100644 packages/frontend/assets/label.svg create mode 100644 packages/frontend/assets/oneko.gif create mode 100644 packages/frontend/assets/remove.png create mode 100644 packages/frontend/assets/reversi/logo.png create mode 100644 packages/frontend/assets/reversi/lose.mp3 create mode 100644 packages/frontend/assets/reversi/matched.mp3 create mode 100644 packages/frontend/assets/reversi/put.mp3 create mode 100644 packages/frontend/assets/reversi/stone_b.png create mode 100644 packages/frontend/assets/reversi/stone_w.png create mode 100644 packages/frontend/assets/reversi/win.mp3 create mode 100644 packages/frontend/assets/sharkey.svg create mode 100644 packages/frontend/assets/sounds/aisha/1.mp3 create mode 100644 packages/frontend/assets/sounds/aisha/2.mp3 create mode 100644 packages/frontend/assets/sounds/aisha/3.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba1.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba2.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba3.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba4.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba5.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba6.mp3 create mode 100644 packages/frontend/assets/sounds/noizenecio/kick_gaba7.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/bubble1.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/bubble2.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/down.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/kick.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-aec-4va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-aec-4vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-aec-8va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-aec-8vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-aec.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-cea-4va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-cea-4vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-cea-8va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-cea-8vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-cea.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-ea-4va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-ea-4vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-ea-8va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-ea-8vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-ea-harmony.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-ea.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-eca-4va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-eca-4vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-eca-8va.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-eca-8vb.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/n-eca.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/pirori-square-wet.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/pirori-wet.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/pirori.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/poi1.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/poi2.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/pope1.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/pope2.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/popo.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/queue-jammed.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/reverved.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/ryukyu.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/snare.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/square-pico.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/triple.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/up.mp3 create mode 100644 packages/frontend/assets/sounds/syuilo/waon.mp3 create mode 100644 packages/frontend/assets/status/error.png create mode 100644 packages/frontend/assets/status/missingpage.webp create mode 100644 packages/frontend/assets/status/nothinghere.png create mode 100644 packages/frontend/assets/tagcanvas.min.js create mode 100644 packages/frontend/assets/testcaptcha.png create mode 100644 packages/frontend/assets/tutorial/ai.webp create mode 100644 packages/frontend/assets/tutorial/natto_failed.webp create mode 100644 packages/frontend/assets/tutorial/timeline_tab.png create mode 100644 packages/frontend/assets/unread.svg create mode 100644 packages/frontend/eslint.config.js create mode 100644 packages/frontend/lib/rollup-plugin-unwind-css-module-class-name.test.ts create mode 100644 packages/frontend/lib/rollup-plugin-unwind-css-module-class-name.ts create mode 100644 packages/frontend/package.json create mode 100644 packages/frontend/public/mockServiceWorker.js create mode 100644 packages/frontend/src/_boot_.ts create mode 100644 packages/frontend/src/_dev_boot_.ts create mode 100644 packages/frontend/src/account.ts create mode 100644 packages/frontend/src/boot/common.ts create mode 100644 packages/frontend/src/boot/main-boot.ts create mode 100644 packages/frontend/src/boot/sub-boot.ts create mode 100644 packages/frontend/src/cache.ts create mode 100644 packages/frontend/src/components/CkFollowMouse.vue create mode 100644 packages/frontend/src/components/MkAbuseReport.vue create mode 100644 packages/frontend/src/components/MkAbuseReportWindow.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAbuseReportWindow.vue create mode 100644 packages/frontend/src/components/MkAccountMoved.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAccountMoved.vue create mode 100644 packages/frontend/src/components/MkAchievements.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAchievements.vue create mode 100644 packages/frontend/src/components/MkAnalogClock.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAnalogClock.vue create mode 100644 packages/frontend/src/components/MkAnimBg.vue create mode 100644 packages/frontend/src/components/MkAnnouncementDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAnnouncementDialog.vue create mode 100644 packages/frontend/src/components/MkAntennaEditor.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAntennaEditor.vue create mode 100644 packages/frontend/src/components/MkAntennaEditorDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAntennaEditorDialog.vue create mode 100644 packages/frontend/src/components/MkAsUi.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAsUi.vue create mode 100644 packages/frontend/src/components/MkAuthConfirm.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAuthConfirm.vue create mode 100644 packages/frontend/src/components/MkAutocomplete.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAutocomplete.vue create mode 100644 packages/frontend/src/components/MkAvatars.stories.impl.ts create mode 100644 packages/frontend/src/components/MkAvatars.vue create mode 100644 packages/frontend/src/components/MkButton.stories.impl.ts create mode 100644 packages/frontend/src/components/MkButton.vue create mode 100644 packages/frontend/src/components/MkCaptcha.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCaptcha.vue create mode 100644 packages/frontend/src/components/MkChannelFollowButton.stories.impl.ts create mode 100644 packages/frontend/src/components/MkChannelFollowButton.vue create mode 100644 packages/frontend/src/components/MkChannelList.stories.impl.ts create mode 100644 packages/frontend/src/components/MkChannelList.vue create mode 100644 packages/frontend/src/components/MkChannelPreview.stories.impl.ts create mode 100644 packages/frontend/src/components/MkChannelPreview.vue create mode 100644 packages/frontend/src/components/MkChart.stories.impl.ts create mode 100644 packages/frontend/src/components/MkChart.vue create mode 100644 packages/frontend/src/components/MkChartLegend.stories.impl.ts create mode 100644 packages/frontend/src/components/MkChartLegend.vue create mode 100644 packages/frontend/src/components/MkChartTooltip.stories.impl.ts create mode 100644 packages/frontend/src/components/MkChartTooltip.vue create mode 100644 packages/frontend/src/components/MkClickerGame.stories.impl.ts create mode 100644 packages/frontend/src/components/MkClickerGame.vue create mode 100644 packages/frontend/src/components/MkClipPreview.stories.impl.ts create mode 100644 packages/frontend/src/components/MkClipPreview.vue create mode 100644 packages/frontend/src/components/MkCode.core.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCode.core.vue create mode 100644 packages/frontend/src/components/MkCode.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCode.vue create mode 100644 packages/frontend/src/components/MkCodeEditor.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCodeEditor.vue create mode 100644 packages/frontend/src/components/MkCodeInline.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCodeInline.vue create mode 100644 packages/frontend/src/components/MkColorInput.stories.impl.ts create mode 100644 packages/frontend/src/components/MkColorInput.vue create mode 100644 packages/frontend/src/components/MkContainer.stories.impl.ts create mode 100644 packages/frontend/src/components/MkContainer.vue create mode 100644 packages/frontend/src/components/MkContextMenu.stories.impl.ts create mode 100644 packages/frontend/src/components/MkContextMenu.vue create mode 100644 packages/frontend/src/components/MkCropperDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCropperDialog.vue create mode 100644 packages/frontend/src/components/MkCustomEmojiDetailedDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCustomEmojiDetailedDialog.vue create mode 100644 packages/frontend/src/components/MkCwButton.stories.impl.ts create mode 100644 packages/frontend/src/components/MkCwButton.vue create mode 100644 packages/frontend/src/components/MkDateSeparatedList.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDateSeparatedList.vue create mode 100644 packages/frontend/src/components/MkDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDialog.vue create mode 100644 packages/frontend/src/components/MkDigitalClock.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDigitalClock.vue create mode 100644 packages/frontend/src/components/MkDivider.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDivider.vue create mode 100644 packages/frontend/src/components/MkDonation.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDonation.vue create mode 100644 packages/frontend/src/components/MkDrive.file.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDrive.file.vue create mode 100644 packages/frontend/src/components/MkDrive.folder.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDrive.folder.vue create mode 100644 packages/frontend/src/components/MkDrive.navFolder.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDrive.navFolder.vue create mode 100644 packages/frontend/src/components/MkDrive.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDrive.vue create mode 100644 packages/frontend/src/components/MkDriveFileThumbnail.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDriveFileThumbnail.vue create mode 100644 packages/frontend/src/components/MkDriveSelectDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDriveSelectDialog.vue create mode 100644 packages/frontend/src/components/MkDriveWindow.stories.impl.ts create mode 100644 packages/frontend/src/components/MkDriveWindow.vue create mode 100644 packages/frontend/src/components/MkEmbedCodeGenDialog.vue create mode 100644 packages/frontend/src/components/MkEmojiPicker.section.stories.impl.ts create mode 100644 packages/frontend/src/components/MkEmojiPicker.section.vue create mode 100644 packages/frontend/src/components/MkEmojiPicker.stories.impl.ts create mode 100644 packages/frontend/src/components/MkEmojiPicker.vue create mode 100644 packages/frontend/src/components/MkEmojiPickerDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkEmojiPickerDialog.vue create mode 100644 packages/frontend/src/components/MkExtensionInstaller.stories.impl.ts create mode 100644 packages/frontend/src/components/MkExtensionInstaller.vue create mode 100644 packages/frontend/src/components/MkFeaturedPhotos.vue create mode 100644 packages/frontend/src/components/MkFileCaptionEditWindow.vue create mode 100644 packages/frontend/src/components/MkFileListForAdmin.vue create mode 100644 packages/frontend/src/components/MkFlashPreview.stories.impl.ts create mode 100644 packages/frontend/src/components/MkFlashPreview.vue create mode 100644 packages/frontend/src/components/MkFoldableSection.vue create mode 100644 packages/frontend/src/components/MkFolder.vue create mode 100644 packages/frontend/src/components/MkFollowButton.vue create mode 100644 packages/frontend/src/components/MkForgotPassword.vue create mode 100644 packages/frontend/src/components/MkFormDialog.file.vue create mode 100644 packages/frontend/src/components/MkFormDialog.vue create mode 100644 packages/frontend/src/components/MkFormFooter.vue create mode 100644 packages/frontend/src/components/MkFukidashi.vue create mode 100644 packages/frontend/src/components/MkGalleryPostPreview.stories.impl.ts create mode 100644 packages/frontend/src/components/MkGalleryPostPreview.vue create mode 100644 packages/frontend/src/components/MkGoogle.vue create mode 100644 packages/frontend/src/components/MkHeatmap.vue create mode 100644 packages/frontend/src/components/MkHorizontalSwipe.vue create mode 100644 packages/frontend/src/components/MkImgWithBlurhash.vue create mode 100644 packages/frontend/src/components/MkInfo.vue create mode 100644 packages/frontend/src/components/MkInput.vue create mode 100644 packages/frontend/src/components/MkInstanceCardMini.stories.impl.ts create mode 100644 packages/frontend/src/components/MkInstanceCardMini.vue create mode 100644 packages/frontend/src/components/MkInstanceStats.vue create mode 100644 packages/frontend/src/components/MkInstanceTicker.vue create mode 100644 packages/frontend/src/components/MkInviteCode.stories.impl.ts create mode 100644 packages/frontend/src/components/MkInviteCode.vue create mode 100644 packages/frontend/src/components/MkKeyValue.vue create mode 100644 packages/frontend/src/components/MkLaunchPad.vue create mode 100644 packages/frontend/src/components/MkLink.vue create mode 100644 packages/frontend/src/components/MkMarquee.vue create mode 100644 packages/frontend/src/components/MkMediaAudio.vue create mode 100644 packages/frontend/src/components/MkMediaBanner.vue create mode 100644 packages/frontend/src/components/MkMediaImage.vue create mode 100644 packages/frontend/src/components/MkMediaList.vue create mode 100644 packages/frontend/src/components/MkMediaRange.vue create mode 100644 packages/frontend/src/components/MkMediaVideo.vue create mode 100644 packages/frontend/src/components/MkMention.vue create mode 100644 packages/frontend/src/components/MkMenu.child.vue create mode 100644 packages/frontend/src/components/MkMenu.vue create mode 100644 packages/frontend/src/components/MkMiniChart.vue create mode 100644 packages/frontend/src/components/MkModal.vue create mode 100644 packages/frontend/src/components/MkModalWindow.vue create mode 100644 packages/frontend/src/components/MkNote.vue create mode 100644 packages/frontend/src/components/MkNoteDetailed.vue create mode 100644 packages/frontend/src/components/MkNoteHeader.vue create mode 100644 packages/frontend/src/components/MkNotePreview.vue create mode 100644 packages/frontend/src/components/MkNoteSimple.vue create mode 100644 packages/frontend/src/components/MkNoteSub.vue create mode 100644 packages/frontend/src/components/MkNotes.vue create mode 100644 packages/frontend/src/components/MkNotification.vue create mode 100644 packages/frontend/src/components/MkNotificationSelectWindow.vue create mode 100644 packages/frontend/src/components/MkNotifications.vue create mode 100644 packages/frontend/src/components/MkNumber.vue create mode 100644 packages/frontend/src/components/MkNumberDiff.vue create mode 100644 packages/frontend/src/components/MkObjectView.value.vue create mode 100644 packages/frontend/src/components/MkObjectView.vue create mode 100644 packages/frontend/src/components/MkOmit.vue create mode 100644 packages/frontend/src/components/MkPagePreview.vue create mode 100644 packages/frontend/src/components/MkPageWindow.vue create mode 100644 packages/frontend/src/components/MkPagination.vue create mode 100644 packages/frontend/src/components/MkPasswordDialog.vue create mode 100644 packages/frontend/src/components/MkPlusOneEffect.vue create mode 100644 packages/frontend/src/components/MkPoll.vue create mode 100644 packages/frontend/src/components/MkPollEditor.vue create mode 100644 packages/frontend/src/components/MkPopupMenu.vue create mode 100644 packages/frontend/src/components/MkPostForm.vue create mode 100644 packages/frontend/src/components/MkPostFormAttaches.vue create mode 100644 packages/frontend/src/components/MkPostFormDialog.vue create mode 100644 packages/frontend/src/components/MkPreview.vue create mode 100644 packages/frontend/src/components/MkPullToRefresh.vue create mode 100644 packages/frontend/src/components/MkPushNotificationAllowButton.vue create mode 100644 packages/frontend/src/components/MkRadio.vue create mode 100644 packages/frontend/src/components/MkRadios.vue create mode 100644 packages/frontend/src/components/MkRange.vue create mode 100644 packages/frontend/src/components/MkReactionEffect.vue create mode 100644 packages/frontend/src/components/MkReactionIcon.vue create mode 100644 packages/frontend/src/components/MkReactionTooltip.vue create mode 100644 packages/frontend/src/components/MkReactionsViewer.details.vue create mode 100644 packages/frontend/src/components/MkReactionsViewer.reaction.vue create mode 100644 packages/frontend/src/components/MkReactionsViewer.vue create mode 100644 packages/frontend/src/components/MkRemoteCaution.vue create mode 100644 packages/frontend/src/components/MkRetentionHeatmap.vue create mode 100644 packages/frontend/src/components/MkRetentionLineChart.vue create mode 100644 packages/frontend/src/components/MkRippleEffect.vue create mode 100644 packages/frontend/src/components/MkRolePreview.vue create mode 100644 packages/frontend/src/components/MkScheduleEditor.vue create mode 100644 packages/frontend/src/components/MkSchedulePostListDialog.vue create mode 100644 packages/frontend/src/components/MkSelect.vue create mode 100644 packages/frontend/src/components/MkSignin.input.vue create mode 100644 packages/frontend/src/components/MkSignin.passkey.vue create mode 100644 packages/frontend/src/components/MkSignin.password.vue create mode 100644 packages/frontend/src/components/MkSignin.totp.vue create mode 100644 packages/frontend/src/components/MkSignin.vue create mode 100644 packages/frontend/src/components/MkSigninDialog.vue create mode 100644 packages/frontend/src/components/MkSignupDialog.form.vue create mode 100644 packages/frontend/src/components/MkSignupDialog.rules.stories.impl.ts create mode 100644 packages/frontend/src/components/MkSignupDialog.rules.vue create mode 100644 packages/frontend/src/components/MkSignupDialog.vue create mode 100644 packages/frontend/src/components/MkSourceCodeAvailablePopup.vue create mode 100644 packages/frontend/src/components/MkSparkle.vue create mode 100644 packages/frontend/src/components/MkSubNoteContent.vue create mode 100644 packages/frontend/src/components/MkSuperMenu.vue create mode 100644 packages/frontend/src/components/MkSwitch.button.vue create mode 100644 packages/frontend/src/components/MkSwitch.vue create mode 100644 packages/frontend/src/components/MkSystemWebhookEditor.impl.ts create mode 100644 packages/frontend/src/components/MkSystemWebhookEditor.vue create mode 100644 packages/frontend/src/components/MkTab.vue create mode 100644 packages/frontend/src/components/MkTagCloud.vue create mode 100644 packages/frontend/src/components/MkTextarea.vue create mode 100644 packages/frontend/src/components/MkTimeline.vue create mode 100644 packages/frontend/src/components/MkToast.vue create mode 100644 packages/frontend/src/components/MkTokenGenerateWindow.vue create mode 100644 packages/frontend/src/components/MkTooltip.vue create mode 100644 packages/frontend/src/components/MkTutorialDialog.Note.vue create mode 100644 packages/frontend/src/components/MkTutorialDialog.PostNote.vue create mode 100644 packages/frontend/src/components/MkTutorialDialog.Sensitive.vue create mode 100644 packages/frontend/src/components/MkTutorialDialog.Timeline.vue create mode 100644 packages/frontend/src/components/MkTutorialDialog.vue create mode 100644 packages/frontend/src/components/MkUpdated.vue create mode 100644 packages/frontend/src/components/MkUrlPreview.vue create mode 100644 packages/frontend/src/components/MkUrlPreviewPopup.vue create mode 100644 packages/frontend/src/components/MkUrlWarningDialog.vue create mode 100644 packages/frontend/src/components/MkUserAnnouncementEditDialog.vue create mode 100644 packages/frontend/src/components/MkUserCardMini.vue create mode 100644 packages/frontend/src/components/MkUserInfo.vue create mode 100644 packages/frontend/src/components/MkUserList.vue create mode 100644 packages/frontend/src/components/MkUserOnlineIndicator.vue create mode 100644 packages/frontend/src/components/MkUserPopup.vue create mode 100644 packages/frontend/src/components/MkUserSelectDialog.vue create mode 100644 packages/frontend/src/components/MkUserSetupDialog.Follow.stories.impl.ts create mode 100644 packages/frontend/src/components/MkUserSetupDialog.Follow.vue create mode 100644 packages/frontend/src/components/MkUserSetupDialog.Privacy.stories.impl.ts create mode 100644 packages/frontend/src/components/MkUserSetupDialog.Privacy.vue create mode 100644 packages/frontend/src/components/MkUserSetupDialog.Profile.stories.impl.ts create mode 100644 packages/frontend/src/components/MkUserSetupDialog.Profile.vue create mode 100644 packages/frontend/src/components/MkUserSetupDialog.User.stories.impl.ts create mode 100644 packages/frontend/src/components/MkUserSetupDialog.User.vue create mode 100644 packages/frontend/src/components/MkUserSetupDialog.stories.impl.ts create mode 100644 packages/frontend/src/components/MkUserSetupDialog.vue create mode 100644 packages/frontend/src/components/MkUsersTooltip.vue create mode 100644 packages/frontend/src/components/MkVisibilityPicker.vue create mode 100644 packages/frontend/src/components/MkVisitorDashboard.ActiveUsersChart.vue create mode 100644 packages/frontend/src/components/MkVisitorDashboard.vue create mode 100644 packages/frontend/src/components/MkWaitingDialog.vue create mode 100644 packages/frontend/src/components/MkWidgets.vue create mode 100644 packages/frontend/src/components/MkWindow.vue create mode 100644 packages/frontend/src/components/MkYouTubePlayer.vue create mode 100644 packages/frontend/src/components/SkApprovalUser.vue create mode 100644 packages/frontend/src/components/SkFlashPlayer.vue create mode 100644 packages/frontend/src/components/SkFollowingFeedEntry.vue create mode 100644 packages/frontend/src/components/SkFollowingRecentNotes.vue create mode 100644 packages/frontend/src/components/SkFormula.vue create mode 100644 packages/frontend/src/components/SkInstanceTicker.vue create mode 100644 packages/frontend/src/components/SkMfmWindow.vue create mode 100644 packages/frontend/src/components/SkModPlayer.vue create mode 100644 packages/frontend/src/components/SkNote.vue create mode 100644 packages/frontend/src/components/SkNoteDetailed.vue create mode 100644 packages/frontend/src/components/SkNoteHeader.vue create mode 100644 packages/frontend/src/components/SkNoteSimple.vue create mode 100644 packages/frontend/src/components/SkNoteSub.vue create mode 100644 packages/frontend/src/components/SkOldNoteWindow.vue create mode 100644 packages/frontend/src/components/SkOneko.vue create mode 100644 packages/frontend/src/components/SkRemoteFollowersWarning.vue create mode 100644 packages/frontend/src/components/SkSearchResultWindow.vue create mode 100644 packages/frontend/src/components/SkUserRecentNotes.vue create mode 100644 packages/frontend/src/components/form/link.vue create mode 100644 packages/frontend/src/components/form/section.vue create mode 100644 packages/frontend/src/components/form/slot.vue create mode 100644 packages/frontend/src/components/form/split.vue create mode 100644 packages/frontend/src/components/form/suspense.vue create mode 100644 packages/frontend/src/components/global/I18n.vue create mode 100644 packages/frontend/src/components/global/MkA.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkA.vue create mode 100644 packages/frontend/src/components/global/MkAcct.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkAcct.vue create mode 100644 packages/frontend/src/components/global/MkAd.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkAd.vue create mode 100644 packages/frontend/src/components/global/MkAvatar.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkAvatar.vue create mode 100644 packages/frontend/src/components/global/MkCondensedLine.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkCondensedLine.vue create mode 100644 packages/frontend/src/components/global/MkCustomEmoji.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkCustomEmoji.vue create mode 100644 packages/frontend/src/components/global/MkEllipsis.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkEllipsis.vue create mode 100644 packages/frontend/src/components/global/MkEmoji.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkEmoji.vue create mode 100644 packages/frontend/src/components/global/MkError.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkError.stories.meta.ts create mode 100644 packages/frontend/src/components/global/MkError.vue create mode 100644 packages/frontend/src/components/global/MkFooterSpacer.vue create mode 100644 packages/frontend/src/components/global/MkLazy.vue create mode 100644 packages/frontend/src/components/global/MkLoading.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkLoading.vue create mode 100644 packages/frontend/src/components/global/MkMfm.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkMfm.ts create mode 100644 packages/frontend/src/components/global/MkPageHeader.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkPageHeader.tabs.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkPageHeader.tabs.vue create mode 100644 packages/frontend/src/components/global/MkPageHeader.vue create mode 100644 packages/frontend/src/components/global/MkSpacer.vue create mode 100644 packages/frontend/src/components/global/MkStickyContainer.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkStickyContainer.vue create mode 100644 packages/frontend/src/components/global/MkTime.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkTime.vue create mode 100644 packages/frontend/src/components/global/MkUrl.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkUrl.vue create mode 100644 packages/frontend/src/components/global/MkUserName.stories.impl.ts create mode 100644 packages/frontend/src/components/global/MkUserName.vue create mode 100644 packages/frontend/src/components/global/RouterView.stories.impl.ts create mode 100644 packages/frontend/src/components/global/RouterView.vue create mode 100644 packages/frontend/src/components/global/SkLazy.vue create mode 100644 packages/frontend/src/components/index.ts create mode 100644 packages/frontend/src/components/page/page.block.vue create mode 100644 packages/frontend/src/components/page/page.dynamic.vue create mode 100644 packages/frontend/src/components/page/page.image.vue create mode 100644 packages/frontend/src/components/page/page.note.vue create mode 100644 packages/frontend/src/components/page/page.section.vue create mode 100644 packages/frontend/src/components/page/page.text.vue create mode 100644 packages/frontend/src/components/page/page.vue create mode 100644 packages/frontend/src/custom-emojis.ts create mode 100644 packages/frontend/src/debug.ts create mode 100644 packages/frontend/src/directives/adaptive-bg.ts create mode 100644 packages/frontend/src/directives/adaptive-border.ts create mode 100644 packages/frontend/src/directives/anim.ts create mode 100644 packages/frontend/src/directives/appear.ts create mode 100644 packages/frontend/src/directives/click-anime.ts create mode 100644 packages/frontend/src/directives/follow-append.ts create mode 100644 packages/frontend/src/directives/get-size.ts create mode 100644 packages/frontend/src/directives/hotkey.ts create mode 100644 packages/frontend/src/directives/index.ts create mode 100644 packages/frontend/src/directives/panel.ts create mode 100644 packages/frontend/src/directives/ripple.ts create mode 100644 packages/frontend/src/directives/tooltip.ts create mode 100644 packages/frontend/src/directives/user-preview.ts create mode 100644 packages/frontend/src/events.ts create mode 100644 packages/frontend/src/filters/bytes.ts create mode 100644 packages/frontend/src/filters/date.ts create mode 100644 packages/frontend/src/filters/hms.ts create mode 100644 packages/frontend/src/filters/kmg.ts create mode 100644 packages/frontend/src/filters/note.ts create mode 100644 packages/frontend/src/filters/number.ts create mode 100644 packages/frontend/src/filters/user.ts create mode 100644 packages/frontend/src/i18n.ts create mode 100644 packages/frontend/src/index.html create mode 100644 packages/frontend/src/index.mdx create mode 100644 packages/frontend/src/instance.ts create mode 100644 packages/frontend/src/local-storage.ts create mode 100644 packages/frontend/src/navbar.ts create mode 100644 packages/frontend/src/nirax.ts create mode 100644 packages/frontend/src/os.ts create mode 100644 packages/frontend/src/pages/_empty_.vue create mode 100644 packages/frontend/src/pages/_error_.vue create mode 100644 packages/frontend/src/pages/_loading_.vue create mode 100644 packages/frontend/src/pages/about-sharkey.vue create mode 100644 packages/frontend/src/pages/about.emojis.vue create mode 100644 packages/frontend/src/pages/about.federation.vue create mode 100644 packages/frontend/src/pages/about.overview.vue create mode 100644 packages/frontend/src/pages/about.vue create mode 100644 packages/frontend/src/pages/achievements.vue create mode 100644 packages/frontend/src/pages/admin-file.vue create mode 100644 packages/frontend/src/pages/admin-user.vue create mode 100644 packages/frontend/src/pages/admin/RolesEditorFormula.vue create mode 100644 packages/frontend/src/pages/admin/_header_.vue create mode 100644 packages/frontend/src/pages/admin/abuse-report/notification-recipient.editor.vue create mode 100644 packages/frontend/src/pages/admin/abuse-report/notification-recipient.item.vue create mode 100644 packages/frontend/src/pages/admin/abuse-report/notification-recipient.vue create mode 100644 packages/frontend/src/pages/admin/abuses.vue create mode 100644 packages/frontend/src/pages/admin/ads.vue create mode 100644 packages/frontend/src/pages/admin/announcements.vue create mode 100644 packages/frontend/src/pages/admin/approvals.vue create mode 100644 packages/frontend/src/pages/admin/bot-protection.vue create mode 100644 packages/frontend/src/pages/admin/branding.vue create mode 100644 packages/frontend/src/pages/admin/database.vue create mode 100644 packages/frontend/src/pages/admin/email-settings.vue create mode 100644 packages/frontend/src/pages/admin/external-services.vue create mode 100644 packages/frontend/src/pages/admin/federation.vue create mode 100644 packages/frontend/src/pages/admin/files.vue create mode 100644 packages/frontend/src/pages/admin/index.vue create mode 100644 packages/frontend/src/pages/admin/invites.vue create mode 100644 packages/frontend/src/pages/admin/moderation.vue create mode 100644 packages/frontend/src/pages/admin/modlog.ModLog.vue create mode 100644 packages/frontend/src/pages/admin/modlog.vue create mode 100644 packages/frontend/src/pages/admin/object-storage.vue create mode 100644 packages/frontend/src/pages/admin/overview.active-users.vue create mode 100644 packages/frontend/src/pages/admin/overview.ap-requests.stories.impl.ts create mode 100644 packages/frontend/src/pages/admin/overview.ap-requests.vue create mode 100644 packages/frontend/src/pages/admin/overview.federation.vue create mode 100644 packages/frontend/src/pages/admin/overview.heatmap.vue create mode 100644 packages/frontend/src/pages/admin/overview.instances.vue create mode 100644 packages/frontend/src/pages/admin/overview.moderators.vue create mode 100644 packages/frontend/src/pages/admin/overview.pie.vue create mode 100644 packages/frontend/src/pages/admin/overview.queue.chart.vue create mode 100644 packages/frontend/src/pages/admin/overview.queue.vue create mode 100644 packages/frontend/src/pages/admin/overview.retention.vue create mode 100644 packages/frontend/src/pages/admin/overview.stats.vue create mode 100644 packages/frontend/src/pages/admin/overview.users.vue create mode 100644 packages/frontend/src/pages/admin/overview.vue create mode 100644 packages/frontend/src/pages/admin/performance.vue create mode 100644 packages/frontend/src/pages/admin/queue.chart.chart.vue create mode 100644 packages/frontend/src/pages/admin/queue.chart.vue create mode 100644 packages/frontend/src/pages/admin/queue.vue create mode 100644 packages/frontend/src/pages/admin/relays.vue create mode 100644 packages/frontend/src/pages/admin/roles.edit.vue create mode 100644 packages/frontend/src/pages/admin/roles.editor.vue create mode 100644 packages/frontend/src/pages/admin/roles.role.vue create mode 100644 packages/frontend/src/pages/admin/roles.vue create mode 100644 packages/frontend/src/pages/admin/security.vue create mode 100644 packages/frontend/src/pages/admin/server-rules.vue create mode 100644 packages/frontend/src/pages/admin/settings.vue create mode 100644 packages/frontend/src/pages/admin/system-webhook.item.vue create mode 100644 packages/frontend/src/pages/admin/system-webhook.vue create mode 100644 packages/frontend/src/pages/admin/users.vue create mode 100644 packages/frontend/src/pages/ads.vue create mode 100644 packages/frontend/src/pages/announcement.vue create mode 100644 packages/frontend/src/pages/announcements.vue create mode 100644 packages/frontend/src/pages/antenna-timeline.vue create mode 100644 packages/frontend/src/pages/api-console.vue create mode 100644 packages/frontend/src/pages/auth.form.vue create mode 100644 packages/frontend/src/pages/auth.vue create mode 100644 packages/frontend/src/pages/avatar-decoration-edit-dialog.vue create mode 100644 packages/frontend/src/pages/avatar-decorations.vue create mode 100644 packages/frontend/src/pages/channel-editor.vue create mode 100644 packages/frontend/src/pages/channel.vue create mode 100644 packages/frontend/src/pages/channels.vue create mode 100644 packages/frontend/src/pages/clicker.vue create mode 100644 packages/frontend/src/pages/clip.vue create mode 100644 packages/frontend/src/pages/contact.vue create mode 100644 packages/frontend/src/pages/custom-emojis-manager.vue create mode 100644 packages/frontend/src/pages/drive.file.info.vue create mode 100644 packages/frontend/src/pages/drive.file.notes.vue create mode 100644 packages/frontend/src/pages/drive.file.vue create mode 100644 packages/frontend/src/pages/drive.vue create mode 100644 packages/frontend/src/pages/drop-and-fusion.game.vue create mode 100644 packages/frontend/src/pages/drop-and-fusion.vue create mode 100644 packages/frontend/src/pages/emoji-edit-dialog.vue create mode 100644 packages/frontend/src/pages/emojis.emoji.vue create mode 100644 packages/frontend/src/pages/explore.featured.vue create mode 100644 packages/frontend/src/pages/explore.roles.vue create mode 100644 packages/frontend/src/pages/explore.users.vue create mode 100644 packages/frontend/src/pages/explore.vue create mode 100644 packages/frontend/src/pages/favorites.vue create mode 100644 packages/frontend/src/pages/flash/flash-edit.vue create mode 100644 packages/frontend/src/pages/flash/flash-index.vue create mode 100644 packages/frontend/src/pages/flash/flash.vue create mode 100644 packages/frontend/src/pages/follow-requests.vue create mode 100644 packages/frontend/src/pages/following-feed.vue create mode 100644 packages/frontend/src/pages/gallery/edit.vue create mode 100644 packages/frontend/src/pages/gallery/index.vue create mode 100644 packages/frontend/src/pages/gallery/post.vue create mode 100644 packages/frontend/src/pages/games.vue create mode 100644 packages/frontend/src/pages/install-extensions.vue create mode 100644 packages/frontend/src/pages/instance-info.vue create mode 100644 packages/frontend/src/pages/invite.vue create mode 100644 packages/frontend/src/pages/list.vue create mode 100644 packages/frontend/src/pages/lookup.vue create mode 100644 packages/frontend/src/pages/miauth.vue create mode 100644 packages/frontend/src/pages/my-antennas/create.vue create mode 100644 packages/frontend/src/pages/my-antennas/edit.vue create mode 100644 packages/frontend/src/pages/my-antennas/index.vue create mode 100644 packages/frontend/src/pages/my-clips/index.vue create mode 100644 packages/frontend/src/pages/my-lists/index.vue create mode 100644 packages/frontend/src/pages/my-lists/list.vue create mode 100644 packages/frontend/src/pages/not-found.vue create mode 100644 packages/frontend/src/pages/note.vue create mode 100644 packages/frontend/src/pages/notifications.vue create mode 100644 packages/frontend/src/pages/oauth.vue create mode 100644 packages/frontend/src/pages/page-editor/common.ts create mode 100644 packages/frontend/src/pages/page-editor/els/page-editor.el.image.vue create mode 100644 packages/frontend/src/pages/page-editor/els/page-editor.el.note.vue create mode 100644 packages/frontend/src/pages/page-editor/els/page-editor.el.section.vue create mode 100644 packages/frontend/src/pages/page-editor/els/page-editor.el.text.vue create mode 100644 packages/frontend/src/pages/page-editor/page-editor.blocks.vue create mode 100644 packages/frontend/src/pages/page-editor/page-editor.container.vue create mode 100644 packages/frontend/src/pages/page-editor/page-editor.vue create mode 100644 packages/frontend/src/pages/page.vue create mode 100644 packages/frontend/src/pages/pages.vue create mode 100644 packages/frontend/src/pages/preview.vue create mode 100644 packages/frontend/src/pages/registry.keys.vue create mode 100644 packages/frontend/src/pages/registry.value.vue create mode 100644 packages/frontend/src/pages/registry.vue create mode 100644 packages/frontend/src/pages/reset-password.vue create mode 100644 packages/frontend/src/pages/reversi/game.board.vue create mode 100644 packages/frontend/src/pages/reversi/game.setting.vue create mode 100644 packages/frontend/src/pages/reversi/game.vue create mode 100644 packages/frontend/src/pages/reversi/index.vue create mode 100644 packages/frontend/src/pages/role.vue create mode 100644 packages/frontend/src/pages/scratchpad.vue create mode 100644 packages/frontend/src/pages/search.note.vue create mode 100644 packages/frontend/src/pages/search.stories.impl.ts create mode 100644 packages/frontend/src/pages/search.user.vue create mode 100644 packages/frontend/src/pages/search.vue create mode 100644 packages/frontend/src/pages/settings/2fa.qrdialog.vue create mode 100644 packages/frontend/src/pages/settings/2fa.vue create mode 100644 packages/frontend/src/pages/settings/accounts.vue create mode 100644 packages/frontend/src/pages/settings/api.vue create mode 100644 packages/frontend/src/pages/settings/apps.vue create mode 100644 packages/frontend/src/pages/settings/avatar-decoration.decoration.vue create mode 100644 packages/frontend/src/pages/settings/avatar-decoration.dialog.vue create mode 100644 packages/frontend/src/pages/settings/avatar-decoration.vue create mode 100644 packages/frontend/src/pages/settings/custom-css.vue create mode 100644 packages/frontend/src/pages/settings/deck.vue create mode 100644 packages/frontend/src/pages/settings/drive-cleaner.vue create mode 100644 packages/frontend/src/pages/settings/drive.vue create mode 100644 packages/frontend/src/pages/settings/email.vue create mode 100644 packages/frontend/src/pages/settings/emoji-picker.vue create mode 100644 packages/frontend/src/pages/settings/general.vue create mode 100644 packages/frontend/src/pages/settings/import-export.vue create mode 100644 packages/frontend/src/pages/settings/index.vue create mode 100644 packages/frontend/src/pages/settings/migration.vue create mode 100644 packages/frontend/src/pages/settings/mute-block.instance-mute.vue create mode 100644 packages/frontend/src/pages/settings/mute-block.vue create mode 100644 packages/frontend/src/pages/settings/mute-block.word-mute.vue create mode 100644 packages/frontend/src/pages/settings/navbar.vue create mode 100644 packages/frontend/src/pages/settings/notifications.notification-config.vue create mode 100644 packages/frontend/src/pages/settings/notifications.vue create mode 100644 packages/frontend/src/pages/settings/other.vue create mode 100644 packages/frontend/src/pages/settings/plugin.install.vue create mode 100644 packages/frontend/src/pages/settings/plugin.vue create mode 100644 packages/frontend/src/pages/settings/preferences-backups.vue create mode 100644 packages/frontend/src/pages/settings/privacy.vue create mode 100644 packages/frontend/src/pages/settings/profile.vue create mode 100644 packages/frontend/src/pages/settings/roles.vue create mode 100644 packages/frontend/src/pages/settings/security.vue create mode 100644 packages/frontend/src/pages/settings/sounds.sound.vue create mode 100644 packages/frontend/src/pages/settings/sounds.vue create mode 100644 packages/frontend/src/pages/settings/statusbar.statusbar.vue create mode 100644 packages/frontend/src/pages/settings/statusbar.vue create mode 100644 packages/frontend/src/pages/settings/theme.install.vue create mode 100644 packages/frontend/src/pages/settings/theme.manage.vue create mode 100644 packages/frontend/src/pages/settings/theme.vue create mode 100644 packages/frontend/src/pages/settings/webhook.edit.vue create mode 100644 packages/frontend/src/pages/settings/webhook.new.vue create mode 100644 packages/frontend/src/pages/settings/webhook.vue create mode 100644 packages/frontend/src/pages/share.vue create mode 100644 packages/frontend/src/pages/signup-complete.vue create mode 100644 packages/frontend/src/pages/tag.vue create mode 100644 packages/frontend/src/pages/theme-editor.vue create mode 100644 packages/frontend/src/pages/timeline.vue create mode 100644 packages/frontend/src/pages/user-list-timeline.vue create mode 100644 packages/frontend/src/pages/user-tag.vue create mode 100644 packages/frontend/src/pages/user/achievements.vue create mode 100644 packages/frontend/src/pages/user/activity.following.vue create mode 100644 packages/frontend/src/pages/user/activity.notes.vue create mode 100644 packages/frontend/src/pages/user/activity.pv.vue create mode 100644 packages/frontend/src/pages/user/activity.vue create mode 100644 packages/frontend/src/pages/user/clips.vue create mode 100644 packages/frontend/src/pages/user/flashs.vue create mode 100644 packages/frontend/src/pages/user/follow-list.vue create mode 100644 packages/frontend/src/pages/user/followers.vue create mode 100644 packages/frontend/src/pages/user/following.vue create mode 100644 packages/frontend/src/pages/user/gallery.vue create mode 100644 packages/frontend/src/pages/user/home.stories.impl.ts create mode 100644 packages/frontend/src/pages/user/home.vue create mode 100644 packages/frontend/src/pages/user/index.activity.vue create mode 100644 packages/frontend/src/pages/user/index.files.vue create mode 100644 packages/frontend/src/pages/user/index.listenbrainz.vue create mode 100644 packages/frontend/src/pages/user/index.timeline.vue create mode 100644 packages/frontend/src/pages/user/index.vue create mode 100644 packages/frontend/src/pages/user/lists.vue create mode 100644 packages/frontend/src/pages/user/pages.vue create mode 100644 packages/frontend/src/pages/user/raw.vue create mode 100644 packages/frontend/src/pages/user/reactions.vue create mode 100644 packages/frontend/src/pages/user/recent-notes.vue create mode 100644 packages/frontend/src/pages/welcome.entrance.a.vue create mode 100644 packages/frontend/src/pages/welcome.setup.vue create mode 100644 packages/frontend/src/pages/welcome.timeline.note.vue create mode 100644 packages/frontend/src/pages/welcome.timeline.vue create mode 100644 packages/frontend/src/pages/welcome.vue create mode 100644 packages/frontend/src/pizzax.ts create mode 100644 packages/frontend/src/plugin.ts create mode 100644 packages/frontend/src/router/definition.ts create mode 100644 packages/frontend/src/router/main.ts create mode 100644 packages/frontend/src/router/supplier.ts create mode 100644 packages/frontend/src/scripts/achievements.ts create mode 100644 packages/frontend/src/scripts/admin-lookup.ts create mode 100644 packages/frontend/src/scripts/aiscript/api.ts create mode 100644 packages/frontend/src/scripts/aiscript/ui.ts create mode 100644 packages/frontend/src/scripts/array.ts create mode 100644 packages/frontend/src/scripts/autocomplete.ts create mode 100644 packages/frontend/src/scripts/boost-quote.ts create mode 100644 packages/frontend/src/scripts/cache.ts create mode 100644 packages/frontend/src/scripts/chart-legend.ts create mode 100644 packages/frontend/src/scripts/chart-vline.ts create mode 100644 packages/frontend/src/scripts/check-animated-mfm.ts create mode 100644 packages/frontend/src/scripts/check-permissions.ts create mode 100644 packages/frontend/src/scripts/check-reaction-permissions.ts create mode 100644 packages/frontend/src/scripts/check-word-mute.ts create mode 100644 packages/frontend/src/scripts/chiptune2.ts create mode 100644 packages/frontend/src/scripts/clear-cache.ts create mode 100644 packages/frontend/src/scripts/clicker-game.ts create mode 100644 packages/frontend/src/scripts/clone.ts create mode 100644 packages/frontend/src/scripts/code-highlighter.ts create mode 100644 packages/frontend/src/scripts/collect-page-vars.ts create mode 100644 packages/frontend/src/scripts/color.ts create mode 100644 packages/frontend/src/scripts/confetti.ts create mode 100644 packages/frontend/src/scripts/contains.ts create mode 100644 packages/frontend/src/scripts/copy-to-clipboard.ts create mode 100644 packages/frontend/src/scripts/device-kind.ts create mode 100644 packages/frontend/src/scripts/emoji-picker.ts create mode 100644 packages/frontend/src/scripts/extract-mentions.ts create mode 100644 packages/frontend/src/scripts/extract-url-from-mfm.ts create mode 100644 packages/frontend/src/scripts/favicon-dot.ts create mode 100644 packages/frontend/src/scripts/focus-trap.ts create mode 100644 packages/frontend/src/scripts/focus.ts create mode 100644 packages/frontend/src/scripts/following-feed-utils.ts create mode 100644 packages/frontend/src/scripts/form.ts create mode 100644 packages/frontend/src/scripts/format-time-string.ts create mode 100644 packages/frontend/src/scripts/fullscreen.ts create mode 100644 packages/frontend/src/scripts/gen-search-query.ts create mode 100644 packages/frontend/src/scripts/get-account-from-id.ts create mode 100644 packages/frontend/src/scripts/get-appear-note.ts create mode 100644 packages/frontend/src/scripts/get-bg-color.ts create mode 100644 packages/frontend/src/scripts/get-dom-node-or-null.ts create mode 100644 packages/frontend/src/scripts/get-drive-file-menu.ts create mode 100644 packages/frontend/src/scripts/get-embed-code.ts create mode 100644 packages/frontend/src/scripts/get-note-menu.ts create mode 100644 packages/frontend/src/scripts/get-note-summary.ts create mode 100644 packages/frontend/src/scripts/get-note-versions-menu.ts create mode 100644 packages/frontend/src/scripts/get-user-menu.ts create mode 100644 packages/frontend/src/scripts/get-user-name.ts create mode 100644 packages/frontend/src/scripts/hotkey.ts create mode 100644 packages/frontend/src/scripts/idb-proxy.ts create mode 100644 packages/frontend/src/scripts/idle-render.ts create mode 100644 packages/frontend/src/scripts/init-chart.ts create mode 100644 packages/frontend/src/scripts/initialize-sw.ts create mode 100644 packages/frontend/src/scripts/install-plugin.ts create mode 100644 packages/frontend/src/scripts/install-theme.ts create mode 100644 packages/frontend/src/scripts/intl-const.ts create mode 100644 packages/frontend/src/scripts/is-device-darkmode.ts create mode 100644 packages/frontend/src/scripts/isFfVisibleForMe.ts create mode 100644 packages/frontend/src/scripts/langmap.ts create mode 100644 packages/frontend/src/scripts/libopenmpt/LICENSE create mode 100644 packages/frontend/src/scripts/libopenmpt/libopenmpt.js create mode 100644 packages/frontend/src/scripts/libopenmpt/libopenmpt.wasm create mode 100644 packages/frontend/src/scripts/libopenmpt/readme.md create mode 100644 packages/frontend/src/scripts/login-id.ts create mode 100644 packages/frontend/src/scripts/lookup.ts create mode 100644 packages/frontend/src/scripts/media-has-audio.ts create mode 100644 packages/frontend/src/scripts/media-proxy.ts create mode 100644 packages/frontend/src/scripts/merge.ts create mode 100644 packages/frontend/src/scripts/mfm-function-picker.ts create mode 100644 packages/frontend/src/scripts/misskey-api.ts create mode 100644 packages/frontend/src/scripts/navigator.ts create mode 100644 packages/frontend/src/scripts/page-metadata.ts create mode 100644 packages/frontend/src/scripts/physics.ts create mode 100644 packages/frontend/src/scripts/player-url-transform.ts create mode 100644 packages/frontend/src/scripts/please-login.ts create mode 100644 packages/frontend/src/scripts/popout.ts create mode 100644 packages/frontend/src/scripts/popup-position.ts create mode 100644 packages/frontend/src/scripts/post-message.ts create mode 100644 packages/frontend/src/scripts/reaction-picker.ts create mode 100644 packages/frontend/src/scripts/reload-ask.ts create mode 100644 packages/frontend/src/scripts/sanitize-html.ts create mode 100644 packages/frontend/src/scripts/search-emoji.ts create mode 100644 packages/frontend/src/scripts/search-engine-map.ts create mode 100644 packages/frontend/src/scripts/select-file.ts create mode 100644 packages/frontend/src/scripts/show-moved-dialog.ts create mode 100644 packages/frontend/src/scripts/show-suspended-dialog.ts create mode 100644 packages/frontend/src/scripts/show-system-account-dialog.ts create mode 100644 packages/frontend/src/scripts/shuffle.ts create mode 100644 packages/frontend/src/scripts/snowfall-effect.ts create mode 100644 packages/frontend/src/scripts/sound.ts create mode 100644 packages/frontend/src/scripts/sticky-sidebar.ts create mode 100644 packages/frontend/src/scripts/stream-mock.ts create mode 100644 packages/frontend/src/scripts/test-utils.ts create mode 100644 packages/frontend/src/scripts/theme-editor.ts create mode 100644 packages/frontend/src/scripts/theme.ts create mode 100644 packages/frontend/src/scripts/time.ts create mode 100644 packages/frontend/src/scripts/timezones.ts create mode 100644 packages/frontend/src/scripts/touch.ts create mode 100644 packages/frontend/src/scripts/unison-reload.ts create mode 100644 packages/frontend/src/scripts/upload.ts create mode 100644 packages/frontend/src/scripts/upload/compress-config.ts create mode 100644 packages/frontend/src/scripts/upload/isWebpSupported.ts create mode 100644 packages/frontend/src/scripts/use-chart-tooltip.ts create mode 100644 packages/frontend/src/scripts/use-form.ts create mode 100644 packages/frontend/src/scripts/use-leave-guard.ts create mode 100644 packages/frontend/src/scripts/use-note-capture.ts create mode 100644 packages/frontend/src/scripts/use-tooltip.ts create mode 100644 packages/frontend/src/scripts/warning-external-website.ts create mode 100644 packages/frontend/src/server-context.ts create mode 100644 packages/frontend/src/store.ts create mode 100644 packages/frontend/src/stream.ts create mode 100644 packages/frontend/src/style.scss create mode 100644 packages/frontend/src/theme-store.ts create mode 100644 packages/frontend/src/timelines.ts create mode 100644 packages/frontend/src/type.ts create mode 100644 packages/frontend/src/types/date-separated-list.ts create mode 100644 packages/frontend/src/types/menu.ts create mode 100644 packages/frontend/src/types/page-header.ts create mode 100644 packages/frontend/src/types/post-form.ts create mode 100644 packages/frontend/src/types/ruffle/config/default.d.ts create mode 100644 packages/frontend/src/types/ruffle/config/index.d.ts create mode 100644 packages/frontend/src/types/ruffle/config/load-options.d.ts create mode 100644 packages/frontend/src/types/ruffle/player/flash.d.ts create mode 100644 packages/frontend/src/types/ruffle/player/index.d.ts create mode 100644 packages/frontend/src/types/ruffle/player/legacy.d.ts create mode 100644 packages/frontend/src/types/ruffle/player/movie-metadata.d.ts create mode 100644 packages/frontend/src/types/ruffle/player/player-element.d.ts create mode 100644 packages/frontend/src/types/ruffle/setup/index.d.ts create mode 100644 packages/frontend/src/types/ruffle/setup/install.d.ts create mode 100644 packages/frontend/src/types/ruffle/setup/public-api.d.ts create mode 100644 packages/frontend/src/types/ruffle/setup/source-api.d.ts create mode 100644 packages/frontend/src/ui/_common_/announcements.vue create mode 100644 packages/frontend/src/ui/_common_/common.ts create mode 100644 packages/frontend/src/ui/_common_/common.vue create mode 100644 packages/frontend/src/ui/_common_/navbar-for-mobile.vue create mode 100644 packages/frontend/src/ui/_common_/navbar.vue create mode 100644 packages/frontend/src/ui/_common_/notification.vue create mode 100644 packages/frontend/src/ui/_common_/statusbar-federation.vue create mode 100644 packages/frontend/src/ui/_common_/statusbar-rss.vue create mode 100644 packages/frontend/src/ui/_common_/statusbar-user-list.vue create mode 100644 packages/frontend/src/ui/_common_/statusbars.vue create mode 100644 packages/frontend/src/ui/_common_/stream-indicator.vue create mode 100644 packages/frontend/src/ui/_common_/sw-inject.ts create mode 100644 packages/frontend/src/ui/_common_/upload.vue create mode 100644 packages/frontend/src/ui/classic.header.vue create mode 100644 packages/frontend/src/ui/classic.sidebar.vue create mode 100644 packages/frontend/src/ui/classic.vue create mode 100644 packages/frontend/src/ui/deck.vue create mode 100644 packages/frontend/src/ui/deck/antenna-column.vue create mode 100644 packages/frontend/src/ui/deck/channel-column.vue create mode 100644 packages/frontend/src/ui/deck/column.vue create mode 100644 packages/frontend/src/ui/deck/deck-store.ts create mode 100644 packages/frontend/src/ui/deck/direct-column.vue create mode 100644 packages/frontend/src/ui/deck/following-column.vue create mode 100644 packages/frontend/src/ui/deck/list-column.vue create mode 100644 packages/frontend/src/ui/deck/main-column.vue create mode 100644 packages/frontend/src/ui/deck/mentions-column.vue create mode 100644 packages/frontend/src/ui/deck/notifications-column.vue create mode 100644 packages/frontend/src/ui/deck/role-timeline-column.vue create mode 100644 packages/frontend/src/ui/deck/tl-column.vue create mode 100644 packages/frontend/src/ui/deck/tl-note-notification.ts create mode 100644 packages/frontend/src/ui/deck/widgets-column.vue create mode 100644 packages/frontend/src/ui/minimum.vue create mode 100644 packages/frontend/src/ui/universal.vue create mode 100644 packages/frontend/src/ui/universal.widgets.vue create mode 100644 packages/frontend/src/ui/visitor.vue create mode 100644 packages/frontend/src/ui/zen.vue create mode 100644 packages/frontend/src/unicode-emoji-indexes/en-US.json create mode 100644 packages/frontend/src/unicode-emoji-indexes/ja-JP.json create mode 100644 packages/frontend/src/unicode-emoji-indexes/ja-JP_hira.json create mode 100644 packages/frontend/src/widgets/WidgetActivity.calendar.vue create mode 100644 packages/frontend/src/widgets/WidgetActivity.chart.vue create mode 100644 packages/frontend/src/widgets/WidgetActivity.vue create mode 100644 packages/frontend/src/widgets/WidgetAichan.vue create mode 100644 packages/frontend/src/widgets/WidgetAiscript.vue create mode 100644 packages/frontend/src/widgets/WidgetAiscriptApp.vue create mode 100644 packages/frontend/src/widgets/WidgetBirthdayFollowings.vue create mode 100644 packages/frontend/src/widgets/WidgetButton.vue create mode 100644 packages/frontend/src/widgets/WidgetCalendar.vue create mode 100644 packages/frontend/src/widgets/WidgetClicker.vue create mode 100644 packages/frontend/src/widgets/WidgetClock.vue create mode 100644 packages/frontend/src/widgets/WidgetDigitalClock.vue create mode 100644 packages/frontend/src/widgets/WidgetFederation.vue create mode 100644 packages/frontend/src/widgets/WidgetInstanceCloud.vue create mode 100644 packages/frontend/src/widgets/WidgetInstanceInfo.vue create mode 100644 packages/frontend/src/widgets/WidgetJobQueue.vue create mode 100644 packages/frontend/src/widgets/WidgetMemo.vue create mode 100644 packages/frontend/src/widgets/WidgetNotifications.vue create mode 100644 packages/frontend/src/widgets/WidgetOnlineUsers.vue create mode 100644 packages/frontend/src/widgets/WidgetPhotos.vue create mode 100644 packages/frontend/src/widgets/WidgetPostForm.vue create mode 100644 packages/frontend/src/widgets/WidgetProfile.vue create mode 100644 packages/frontend/src/widgets/WidgetRss.vue create mode 100644 packages/frontend/src/widgets/WidgetRssTicker.vue create mode 100644 packages/frontend/src/widgets/WidgetSearch.vue create mode 100644 packages/frontend/src/widgets/WidgetSlideshow.vue create mode 100644 packages/frontend/src/widgets/WidgetTimeline.vue create mode 100644 packages/frontend/src/widgets/WidgetTrends.vue create mode 100644 packages/frontend/src/widgets/WidgetUnixClock.vue create mode 100644 packages/frontend/src/widgets/WidgetUserList.vue create mode 100644 packages/frontend/src/widgets/index.ts create mode 100644 packages/frontend/src/widgets/server-metric/cpu-mem.vue create mode 100644 packages/frontend/src/widgets/server-metric/cpu.vue create mode 100644 packages/frontend/src/widgets/server-metric/disk.vue create mode 100644 packages/frontend/src/widgets/server-metric/index.vue create mode 100644 packages/frontend/src/widgets/server-metric/mem.vue create mode 100644 packages/frontend/src/widgets/server-metric/net.vue create mode 100644 packages/frontend/src/widgets/server-metric/pie.vue create mode 100644 packages/frontend/src/widgets/widget.ts create mode 100644 packages/frontend/src/workers/draw-blurhash.ts create mode 100644 packages/frontend/src/workers/test-webgl2.ts create mode 100644 packages/frontend/src/workers/tsconfig.json create mode 100644 packages/frontend/test/autocomplete.test.ts create mode 100644 packages/frontend/test/emoji.test.ts create mode 100644 packages/frontend/test/home.test.ts create mode 100644 packages/frontend/test/i18n.test.ts create mode 100644 packages/frontend/test/init.ts create mode 100644 packages/frontend/test/note.test.ts create mode 100644 packages/frontend/test/scroll.test.ts create mode 100644 packages/frontend/test/tsconfig.json create mode 100644 packages/frontend/test/url-preview.test.ts create mode 100644 packages/frontend/tsconfig.json create mode 100644 packages/frontend/vite.config.local-dev.ts create mode 100644 packages/frontend/vite.config.ts create mode 100644 packages/frontend/vite.json5.ts create mode 100644 packages/frontend/vite.replaceIcons.ts create mode 100644 packages/frontend/vue-shims.d.ts create mode 100644 packages/megalodon/.npmignore create mode 100644 packages/megalodon/package.json create mode 100644 packages/megalodon/src/axios.d.ts create mode 100644 packages/megalodon/src/cancel.ts create mode 100644 packages/megalodon/src/converter.ts create mode 100644 packages/megalodon/src/default.ts create mode 100644 packages/megalodon/src/detector.ts create mode 100644 packages/megalodon/src/entities/account.ts create mode 100644 packages/megalodon/src/entities/activity.ts create mode 100644 packages/megalodon/src/entities/announcement.ts create mode 100644 packages/megalodon/src/entities/application.ts create mode 100644 packages/megalodon/src/entities/async_attachment.ts create mode 100644 packages/megalodon/src/entities/attachment.ts create mode 100644 packages/megalodon/src/entities/card.ts create mode 100644 packages/megalodon/src/entities/context.ts create mode 100644 packages/megalodon/src/entities/conversation.ts create mode 100644 packages/megalodon/src/entities/emoji.ts create mode 100644 packages/megalodon/src/entities/featured_tag.ts create mode 100644 packages/megalodon/src/entities/field.ts create mode 100644 packages/megalodon/src/entities/filter.ts create mode 100644 packages/megalodon/src/entities/follow_request.ts create mode 100644 packages/megalodon/src/entities/history.ts create mode 100644 packages/megalodon/src/entities/identity_proof.ts create mode 100644 packages/megalodon/src/entities/instance.ts create mode 100644 packages/megalodon/src/entities/list.ts create mode 100644 packages/megalodon/src/entities/marker.ts create mode 100644 packages/megalodon/src/entities/mention.ts create mode 100644 packages/megalodon/src/entities/notification.ts create mode 100644 packages/megalodon/src/entities/poll.ts create mode 100644 packages/megalodon/src/entities/poll_option.ts create mode 100644 packages/megalodon/src/entities/preferences.ts create mode 100644 packages/megalodon/src/entities/push_subscription.ts create mode 100644 packages/megalodon/src/entities/reaction.ts create mode 100644 packages/megalodon/src/entities/relationship.ts create mode 100644 packages/megalodon/src/entities/report.ts create mode 100644 packages/megalodon/src/entities/results.ts create mode 100644 packages/megalodon/src/entities/role.ts create mode 100644 packages/megalodon/src/entities/scheduled_status.ts create mode 100644 packages/megalodon/src/entities/source.ts create mode 100644 packages/megalodon/src/entities/stats.ts create mode 100644 packages/megalodon/src/entities/status.ts create mode 100644 packages/megalodon/src/entities/status_edit.ts create mode 100644 packages/megalodon/src/entities/status_params.ts create mode 100644 packages/megalodon/src/entities/status_source.ts create mode 100644 packages/megalodon/src/entities/tag.ts create mode 100644 packages/megalodon/src/entities/token.ts create mode 100644 packages/megalodon/src/entities/urls.ts create mode 100644 packages/megalodon/src/entity.ts create mode 100644 packages/megalodon/src/filter_context.ts create mode 100644 packages/megalodon/src/friendica.ts create mode 100644 packages/megalodon/src/friendica/api_client.ts create mode 100644 packages/megalodon/src/friendica/entities/account.ts create mode 100644 packages/megalodon/src/friendica/entities/activity.ts create mode 100644 packages/megalodon/src/friendica/entities/application.ts create mode 100644 packages/megalodon/src/friendica/entities/async_attachment.ts create mode 100644 packages/megalodon/src/friendica/entities/attachment.ts create mode 100644 packages/megalodon/src/friendica/entities/card.ts create mode 100644 packages/megalodon/src/friendica/entities/context.ts create mode 100644 packages/megalodon/src/friendica/entities/conversation.ts create mode 100644 packages/megalodon/src/friendica/entities/emoji.ts create mode 100644 packages/megalodon/src/friendica/entities/featured_tag.ts create mode 100644 packages/megalodon/src/friendica/entities/field.ts create mode 100644 packages/megalodon/src/friendica/entities/filter.ts create mode 100644 packages/megalodon/src/friendica/entities/follow_request.ts create mode 100644 packages/megalodon/src/friendica/entities/history.ts create mode 100644 packages/megalodon/src/friendica/entities/identity_proof.ts create mode 100644 packages/megalodon/src/friendica/entities/instance.ts create mode 100644 packages/megalodon/src/friendica/entities/list.ts create mode 100644 packages/megalodon/src/friendica/entities/marker.ts create mode 100644 packages/megalodon/src/friendica/entities/mention.ts create mode 100644 packages/megalodon/src/friendica/entities/notification.ts create mode 100644 packages/megalodon/src/friendica/entities/poll.ts create mode 100644 packages/megalodon/src/friendica/entities/poll_option.ts create mode 100644 packages/megalodon/src/friendica/entities/preferences.ts create mode 100644 packages/megalodon/src/friendica/entities/push_subscription.ts create mode 100644 packages/megalodon/src/friendica/entities/relationship.ts create mode 100644 packages/megalodon/src/friendica/entities/report.ts create mode 100644 packages/megalodon/src/friendica/entities/results.ts create mode 100644 packages/megalodon/src/friendica/entities/scheduled_status.ts create mode 100644 packages/megalodon/src/friendica/entities/source.ts create mode 100644 packages/megalodon/src/friendica/entities/stats.ts create mode 100644 packages/megalodon/src/friendica/entities/status.ts create mode 100644 packages/megalodon/src/friendica/entities/status_params.ts create mode 100644 packages/megalodon/src/friendica/entities/status_source.ts create mode 100644 packages/megalodon/src/friendica/entities/tag.ts create mode 100644 packages/megalodon/src/friendica/entities/token.ts create mode 100644 packages/megalodon/src/friendica/entities/urls.ts create mode 100644 packages/megalodon/src/friendica/entity.ts create mode 100644 packages/megalodon/src/friendica/notification.ts create mode 100644 packages/megalodon/src/friendica/web_socket.ts create mode 100644 packages/megalodon/src/index.ts create mode 100644 packages/megalodon/src/mastodon.ts create mode 100644 packages/megalodon/src/mastodon/api_client.ts create mode 100644 packages/megalodon/src/mastodon/entities/account.ts create mode 100644 packages/megalodon/src/mastodon/entities/activity.ts create mode 100644 packages/megalodon/src/mastodon/entities/announcement.ts create mode 100644 packages/megalodon/src/mastodon/entities/application.ts create mode 100644 packages/megalodon/src/mastodon/entities/async_attachment.ts create mode 100644 packages/megalodon/src/mastodon/entities/attachment.ts create mode 100644 packages/megalodon/src/mastodon/entities/card.ts create mode 100644 packages/megalodon/src/mastodon/entities/context.ts create mode 100644 packages/megalodon/src/mastodon/entities/conversation.ts create mode 100644 packages/megalodon/src/mastodon/entities/emoji.ts create mode 100644 packages/megalodon/src/mastodon/entities/featured_tag.ts create mode 100644 packages/megalodon/src/mastodon/entities/field.ts create mode 100644 packages/megalodon/src/mastodon/entities/filter.ts create mode 100644 packages/megalodon/src/mastodon/entities/history.ts create mode 100644 packages/megalodon/src/mastodon/entities/identity_proof.ts create mode 100644 packages/megalodon/src/mastodon/entities/instance.ts create mode 100644 packages/megalodon/src/mastodon/entities/list.ts create mode 100644 packages/megalodon/src/mastodon/entities/marker.ts create mode 100644 packages/megalodon/src/mastodon/entities/mention.ts create mode 100644 packages/megalodon/src/mastodon/entities/notification.ts create mode 100644 packages/megalodon/src/mastodon/entities/poll.ts create mode 100644 packages/megalodon/src/mastodon/entities/poll_option.ts create mode 100644 packages/megalodon/src/mastodon/entities/preferences.ts create mode 100644 packages/megalodon/src/mastodon/entities/push_subscription.ts create mode 100644 packages/megalodon/src/mastodon/entities/relationship.ts create mode 100644 packages/megalodon/src/mastodon/entities/report.ts create mode 100644 packages/megalodon/src/mastodon/entities/results.ts create mode 100644 packages/megalodon/src/mastodon/entities/role.ts create mode 100644 packages/megalodon/src/mastodon/entities/scheduled_status.ts create mode 100644 packages/megalodon/src/mastodon/entities/source.ts create mode 100644 packages/megalodon/src/mastodon/entities/stats.ts create mode 100644 packages/megalodon/src/mastodon/entities/status.ts create mode 100644 packages/megalodon/src/mastodon/entities/status_params.ts create mode 100644 packages/megalodon/src/mastodon/entities/status_source.ts create mode 100644 packages/megalodon/src/mastodon/entities/tag.ts create mode 100644 packages/megalodon/src/mastodon/entities/token.ts create mode 100644 packages/megalodon/src/mastodon/entities/urls.ts create mode 100644 packages/megalodon/src/mastodon/entity.ts create mode 100644 packages/megalodon/src/mastodon/notification.ts create mode 100644 packages/megalodon/src/mastodon/web_socket.ts create mode 100644 packages/megalodon/src/megalodon.ts create mode 100644 packages/megalodon/src/misskey.ts create mode 100644 packages/megalodon/src/misskey/api_client.ts create mode 100644 packages/megalodon/src/misskey/entities/GetAll.ts create mode 100644 packages/megalodon/src/misskey/entities/announcement.ts create mode 100644 packages/megalodon/src/misskey/entities/app.ts create mode 100644 packages/megalodon/src/misskey/entities/blocking.ts create mode 100644 packages/megalodon/src/misskey/entities/createdNote.ts create mode 100644 packages/megalodon/src/misskey/entities/emoji.ts create mode 100644 packages/megalodon/src/misskey/entities/favorite.ts create mode 100644 packages/megalodon/src/misskey/entities/field.ts create mode 100644 packages/megalodon/src/misskey/entities/file.ts create mode 100644 packages/megalodon/src/misskey/entities/followRequest.ts create mode 100644 packages/megalodon/src/misskey/entities/follower.ts create mode 100644 packages/megalodon/src/misskey/entities/following.ts create mode 100644 packages/megalodon/src/misskey/entities/hashtag.ts create mode 100644 packages/megalodon/src/misskey/entities/list.ts create mode 100644 packages/megalodon/src/misskey/entities/meta.ts create mode 100644 packages/megalodon/src/misskey/entities/mute.ts create mode 100644 packages/megalodon/src/misskey/entities/note.ts create mode 100644 packages/megalodon/src/misskey/entities/notification.ts create mode 100644 packages/megalodon/src/misskey/entities/poll.ts create mode 100644 packages/megalodon/src/misskey/entities/reaction.ts create mode 100644 packages/megalodon/src/misskey/entities/relation.ts create mode 100644 packages/megalodon/src/misskey/entities/session.ts create mode 100644 packages/megalodon/src/misskey/entities/stats.ts create mode 100644 packages/megalodon/src/misskey/entities/user.ts create mode 100644 packages/megalodon/src/misskey/entities/userDetail.ts create mode 100644 packages/megalodon/src/misskey/entities/userkey.ts create mode 100644 packages/megalodon/src/misskey/entity.ts create mode 100644 packages/megalodon/src/misskey/notification.ts create mode 100644 packages/megalodon/src/misskey/web_socket.ts create mode 100644 packages/megalodon/src/notification.ts create mode 100644 packages/megalodon/src/oauth.ts create mode 100644 packages/megalodon/src/parser.ts create mode 100644 packages/megalodon/src/pleroma.ts create mode 100644 packages/megalodon/src/pleroma/api_client.ts create mode 100644 packages/megalodon/src/pleroma/entities/account.ts create mode 100644 packages/megalodon/src/pleroma/entities/activity.ts create mode 100644 packages/megalodon/src/pleroma/entities/announcement.ts create mode 100644 packages/megalodon/src/pleroma/entities/application.ts create mode 100644 packages/megalodon/src/pleroma/entities/async_attachment.ts create mode 100644 packages/megalodon/src/pleroma/entities/attachment.ts create mode 100644 packages/megalodon/src/pleroma/entities/card.ts create mode 100644 packages/megalodon/src/pleroma/entities/context.ts create mode 100644 packages/megalodon/src/pleroma/entities/conversation.ts create mode 100644 packages/megalodon/src/pleroma/entities/emoji.ts create mode 100644 packages/megalodon/src/pleroma/entities/featured_tag.ts create mode 100644 packages/megalodon/src/pleroma/entities/field.ts create mode 100644 packages/megalodon/src/pleroma/entities/filter.ts create mode 100644 packages/megalodon/src/pleroma/entities/history.ts create mode 100644 packages/megalodon/src/pleroma/entities/identity_proof.ts create mode 100644 packages/megalodon/src/pleroma/entities/instance.ts create mode 100644 packages/megalodon/src/pleroma/entities/list.ts create mode 100644 packages/megalodon/src/pleroma/entities/marker.ts create mode 100644 packages/megalodon/src/pleroma/entities/mention.ts create mode 100644 packages/megalodon/src/pleroma/entities/notification.ts create mode 100644 packages/megalodon/src/pleroma/entities/poll.ts create mode 100644 packages/megalodon/src/pleroma/entities/poll_option.ts create mode 100644 packages/megalodon/src/pleroma/entities/preferences.ts create mode 100644 packages/megalodon/src/pleroma/entities/push_subscription.ts create mode 100644 packages/megalodon/src/pleroma/entities/reaction.ts create mode 100644 packages/megalodon/src/pleroma/entities/relationship.ts create mode 100644 packages/megalodon/src/pleroma/entities/report.ts create mode 100644 packages/megalodon/src/pleroma/entities/results.ts create mode 100644 packages/megalodon/src/pleroma/entities/scheduled_status.ts create mode 100644 packages/megalodon/src/pleroma/entities/source.ts create mode 100644 packages/megalodon/src/pleroma/entities/stats.ts create mode 100644 packages/megalodon/src/pleroma/entities/status.ts create mode 100644 packages/megalodon/src/pleroma/entities/status_params.ts create mode 100644 packages/megalodon/src/pleroma/entities/status_source.ts create mode 100644 packages/megalodon/src/pleroma/entities/tag.ts create mode 100644 packages/megalodon/src/pleroma/entities/token.ts create mode 100644 packages/megalodon/src/pleroma/entities/urls.ts create mode 100644 packages/megalodon/src/pleroma/entity.ts create mode 100644 packages/megalodon/src/pleroma/notification.ts create mode 100644 packages/megalodon/src/pleroma/web_socket.ts create mode 100644 packages/megalodon/src/proxy_config.ts create mode 100644 packages/megalodon/src/response.ts create mode 100644 packages/megalodon/test/integration/cancel.spec.ts create mode 100644 packages/megalodon/test/integration/cancelWorker.ts create mode 100644 packages/megalodon/test/integration/detector.spec.ts create mode 100644 packages/megalodon/test/integration/mastodon.spec.ts create mode 100644 packages/megalodon/test/integration/mastodon/api_client.spec.ts create mode 100644 packages/megalodon/test/integration/misskey.spec.ts create mode 100644 packages/megalodon/test/integration/pleroma.spec.ts create mode 100644 packages/megalodon/test/unit/mastodon.spec.ts create mode 100644 packages/megalodon/test/unit/mastodon/api_client.spec.ts create mode 100644 packages/megalodon/test/unit/misskey/api_client.spec.ts create mode 100644 packages/megalodon/test/unit/parser.spec.ts create mode 100644 packages/megalodon/test/unit/pleroma/api_client.spec.ts create mode 100644 packages/megalodon/test/unit/webo_socket.spec.ts create mode 100644 packages/megalodon/tsconfig.json create mode 100644 packages/meta.json create mode 100644 packages/misskey-bubble-game/build.js create mode 100644 packages/misskey-bubble-game/eslint.config.js create mode 100644 packages/misskey-bubble-game/package.json create mode 100644 packages/misskey-bubble-game/src/game.ts create mode 100644 packages/misskey-bubble-game/src/index.ts create mode 100644 packages/misskey-bubble-game/src/monos.ts create mode 100644 packages/misskey-bubble-game/tsconfig.json create mode 100644 packages/misskey-js/.swcrc create mode 100644 packages/misskey-js/CONTRIBUTING.md create mode 100644 packages/misskey-js/LICENSE create mode 100644 packages/misskey-js/README.md create mode 100644 packages/misskey-js/api-extractor.json create mode 100644 packages/misskey-js/build.js create mode 100644 packages/misskey-js/docs/CONTRIBUTING.en.md create mode 100644 packages/misskey-js/eslint.config.js create mode 100644 packages/misskey-js/etc/misskey-js.api.md create mode 100644 packages/misskey-js/generator/.gitignore create mode 100644 packages/misskey-js/generator/README.md create mode 100644 packages/misskey-js/generator/eslint.config.js create mode 100644 packages/misskey-js/generator/package.json create mode 100644 packages/misskey-js/generator/src/generator.ts create mode 100644 packages/misskey-js/generator/tsconfig.json create mode 100644 packages/misskey-js/jest.config.cjs create mode 100644 packages/misskey-js/package.json create mode 100644 packages/misskey-js/src/acct.ts create mode 100644 packages/misskey-js/src/api.ts create mode 100644 packages/misskey-js/src/api.types.ts create mode 100644 packages/misskey-js/src/autogen/apiClientJSDoc.ts create mode 100644 packages/misskey-js/src/autogen/endpoint.ts create mode 100644 packages/misskey-js/src/autogen/entities.ts create mode 100644 packages/misskey-js/src/autogen/models.ts create mode 100644 packages/misskey-js/src/autogen/types.ts create mode 100644 packages/misskey-js/src/consts.ts create mode 100644 packages/misskey-js/src/entities.ts create mode 100644 packages/misskey-js/src/index.ts create mode 100644 packages/misskey-js/src/note.ts create mode 100644 packages/misskey-js/src/nyaize.ts create mode 100644 packages/misskey-js/src/streaming.ts create mode 100644 packages/misskey-js/src/streaming.types.ts create mode 100644 packages/misskey-js/test-d/api.ts create mode 100644 packages/misskey-js/test-d/streaming.ts create mode 100644 packages/misskey-js/test/api.ts create mode 100644 packages/misskey-js/test/nyaize.test.ts create mode 100644 packages/misskey-js/test/streaming.ts create mode 100644 packages/misskey-js/tsconfig.json create mode 100644 packages/misskey-reversi/build.js create mode 100644 packages/misskey-reversi/eslint.config.js create mode 100644 packages/misskey-reversi/package.json create mode 100644 packages/misskey-reversi/src/game.ts create mode 100644 packages/misskey-reversi/src/index.ts create mode 100644 packages/misskey-reversi/src/maps.ts create mode 100644 packages/misskey-reversi/src/serializer.ts create mode 100644 packages/misskey-reversi/tsconfig.json create mode 100644 packages/shared/eslint.config.js create mode 100644 packages/shared/package.json create mode 100644 packages/sw/build.js create mode 100644 packages/sw/eslint.config.js create mode 100644 packages/sw/package.json create mode 100644 packages/sw/src/@types/global.d.ts create mode 100644 packages/sw/src/scripts/create-notification.ts create mode 100644 packages/sw/src/scripts/get-account-from-id.ts create mode 100644 packages/sw/src/scripts/get-user-name.ts create mode 100644 packages/sw/src/scripts/lang.ts create mode 100644 packages/sw/src/scripts/login-id.ts create mode 100644 packages/sw/src/scripts/operations.ts create mode 100644 packages/sw/src/scripts/twemoji-base.ts create mode 100644 packages/sw/src/sw.ts create mode 100644 packages/sw/src/types.ts create mode 100644 packages/sw/tsconfig.json create mode 100644 pnpm-lock.yaml create mode 100644 pnpm-workspace.yaml create mode 100644 scripts/build-assets.mjs create mode 100644 scripts/build-pre.js create mode 100644 scripts/changelog-checker/eslint.config.js create mode 100644 scripts/clean-all.js create mode 100644 scripts/clean.js create mode 100644 scripts/dev.mjs create mode 100644 scripts/tarball.mjs create mode 100644 scripts/trim-deps.mjs create mode 100644 sharkey-locales/ar-SA.yml create mode 100644 sharkey-locales/bn-BD.yml create mode 100644 sharkey-locales/ca-ES.yml create mode 100644 sharkey-locales/cs-CZ.yml create mode 100644 sharkey-locales/da-DK.yml create mode 100644 sharkey-locales/de-DE.yml create mode 100644 sharkey-locales/el-GR.yml create mode 100644 sharkey-locales/en-US.yml create mode 100644 sharkey-locales/es-ES.yml create mode 100644 sharkey-locales/fr-FR.yml create mode 100644 sharkey-locales/hr-HR.yml create mode 100644 sharkey-locales/ht-HT.yml create mode 100644 sharkey-locales/hu-HU.yml create mode 100644 sharkey-locales/id-ID.yml create mode 100644 sharkey-locales/it-IT.yml create mode 100644 sharkey-locales/ja-JP.yml create mode 100644 sharkey-locales/ja-KS.yml create mode 100644 sharkey-locales/jbo-EN.yml create mode 100644 sharkey-locales/kab-KAB.yml create mode 100644 sharkey-locales/kn-IN.yml create mode 100644 sharkey-locales/ko-GS.yml create mode 100644 sharkey-locales/ko-KR.yml create mode 100644 sharkey-locales/lo-LA.yml create mode 100644 sharkey-locales/nl-NL.yml create mode 100644 sharkey-locales/no-NO.yml create mode 100644 sharkey-locales/pl-PL.yml create mode 100644 sharkey-locales/pt-PT.yml create mode 100644 sharkey-locales/ro-RO.yml create mode 100644 sharkey-locales/ru-RU.yml create mode 100644 sharkey-locales/si-LK.yml create mode 100644 sharkey-locales/sk-SK.yml create mode 100644 sharkey-locales/sv-SE.yml create mode 100644 sharkey-locales/th-TH.yml create mode 100644 sharkey-locales/tr-TR.yml create mode 100644 sharkey-locales/ug-CN.yml create mode 100644 sharkey-locales/uk-UA.yml create mode 100644 sharkey-locales/uz-UZ.yml create mode 100644 sharkey-locales/vi-VN.yml create mode 100644 sharkey-locales/zh-CN.yml create mode 100644 sharkey-locales/zh-TW.yml diff --git a/.config/cypress-devcontainer.yml b/.config/cypress-devcontainer.yml new file mode 100644 index 0000000000..c8c4a36d8f --- /dev/null +++ b/.config/cypress-devcontainer.yml @@ -0,0 +1,242 @@ +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +# Misskey configuration +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ + +# ┌────────────────────────┐ +#───┘ Initial Setup Password └───────────────────────────────────────────────────── + +# Password to initiate setting up admin account. +# It will not be used after the initial setup is complete. +# +# Be sure to change this when you set up Misskey via the Internet. +# +# The provider of the service who sets up Misskey on behalf of the customer should +# set this value to something unique when generating the Misskey config file, +# and provide it to the customer. +setupPassword: example_password_please_change_this_or_you_will_get_hacked + +# ┌─────┐ +#───┘ URL └───────────────────────────────────────────────────── + +# Final accessible URL seen by a user. +url: 'http://misskey.local' + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# URL SETTINGS AFTER THAT! + +# ┌───────────────────────┐ +#───┘ Port and TLS settings └─────────────────────────────────── + +# +# Misskey requires a reverse proxy to support HTTPS connections. +# +# +----- https://example.tld/ ------------+ +# +------+ |+-------------+ +----------------+| +# | User | ---> || Proxy (443) | ---> | Misskey (3000) || +# +------+ |+-------------+ +----------------+| +# +---------------------------------------+ +# +# You need to set up a reverse proxy. (e.g. nginx) +# An encrypted connection with HTTPS is highly recommended +# because tokens may be transferred in GET requests. + +# The port that your Misskey server should listen on. +port: 61812 + +# ┌──────────────────────────┐ +#───┘ PostgreSQL configuration └──────────────────────────────── + +db: + host: db + port: 5432 + + # Database name + db: misskey + + # Auth + user: postgres + pass: postgres + + # Whether disable Caching queries + #disableCache: true + + # Extra Connection options + #extra: + # ssl: true + +dbReplications: false + +# You can configure any number of replicas here +#dbSlaves: +# - +# host: +# port: +# db: +# user: +# pass: +# - +# host: +# port: +# db: +# user: +# pass: + +# ┌─────────────────────┐ +#───┘ Redis configuration └───────────────────────────────────── + +redis: + host: redis + port: 6379 + #family: 0 # 0=Both, 4=IPv4, 6=IPv6 + #pass: example-pass + #prefix: example-prefix + #db: 1 + +#redisForPubsub: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForJobQueue: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForTimelines: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForReactions: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +# ┌───────────────────────────┐ +#───┘ MeiliSearch configuration └───────────────────────────── + +#meilisearch: +# host: meilisearch +# port: 7700 +# apiKey: '' +# ssl: true +# index: '' + +# ┌───────────────┐ +#───┘ ID generation └─────────────────────────────────────────── + +# You can select the ID generation method. +# You don't usually need to change this setting, but you can +# change it according to your preferences. + +# Available methods: +# aid ... Short, Millisecond accuracy +# aidx ... Millisecond accuracy +# meid ... Similar to ObjectID, Millisecond accuracy +# ulid ... Millisecond accuracy +# objectid ... This is left for backward compatibility + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# ID SETTINGS AFTER THAT! + +id: 'aidx' + +# ┌────────────────┐ +#───┘ Error tracking └────────────────────────────────────────── + +# Sentry is available for error tracking. +# See the Sentry documentation for more details on options. + +#sentryForBackend: +# enableNodeProfiling: true +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +#sentryForFrontend: +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +# ┌─────────────────────┐ +#───┘ Other configuration └───────────────────────────────────── + +# Whether disable HSTS +#disableHsts: true + +# Number of worker processes +#clusterLimit: 1 + +# Job concurrency per worker +# deliverJobConcurrency: 128 +# inboxJobConcurrency: 16 + +# Job rate limiter +# deliverJobPerSec: 128 +# inboxJobPerSec: 32 + +# Job attempts +# deliverJobMaxAttempts: 12 +# inboxJobMaxAttempts: 8 + +# IP address family used for outgoing request (ipv4, ipv6 or dual) +#outgoingAddressFamily: ipv4 + +# Amount of characters that can be used when writing notes. Longer notes will be rejected. (minimum: 1) +#maxNoteLength: 3000 +# Amount of characters that will be saved for remote notes. Longer notes will be truncated to this length. (minimum: 1) +#maxRemoteNoteLength: 100000 +# Amount of characters that can be used when writing content warnings. Longer warnings will be rejected. (minimum: 1) +#maxCwLength: 500 +# Amount of characters that will be saved for remote content warnings. Longer warnings will be truncated to this length. (minimum: 1) +#maxRemoteCwLength: 5000 +# Amount of characters that can be used when writing media descriptions (alt text). Longer descriptions will be rejected. (minimum: 1) +#maxAltTextLength: 20000 +# Amount of characters that will be saved for remote media descriptions (alt text). Longer descriptions will be truncated to this length. (minimum: 1) +#maxRemoteAltTextLength: 100000 + +# Proxy for HTTP/HTTPS +#proxy: http://127.0.0.1:3128 + +proxyBypassHosts: + - api.deepl.com + - api-free.deepl.com + - www.recaptcha.net + - hcaptcha.com + - challenges.cloudflare.com + +# Proxy for SMTP/SMTPS +#proxySmtp: http://127.0.0.1:3128 # use HTTP/1.1 CONNECT +#proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4 +#proxySmtp: socks5://127.0.0.1:1080 # use SOCKS5 + +# Media Proxy +#mediaProxy: https://example.com/proxy + +# Proxy remote files (default: true) +proxyRemoteFiles: true + +# Sign to ActivityPub GET request (default: true) +signToActivityPubGet: true + +allowedPrivateNetworks: [ + '127.0.0.1/32' +] + +# Upload or download file size limits (bytes) +#maxFileSize: 262144000 + +# CHMod-style permission bits to apply to uploaded files. +# Permission bits are specified as a base-8 string representing User/Group/Other permissions. +# This setting is only useful for custom deployments, such as using a reverse proxy to serve media. +#filePermissionBits: '644' diff --git a/.config/docker_example.env b/.config/docker_example.env new file mode 100644 index 0000000000..c61248da2e --- /dev/null +++ b/.config/docker_example.env @@ -0,0 +1,11 @@ +# misskey settings +# MISSKEY_URL=https://example.tld/ + +# db settings +POSTGRES_PASSWORD=example-misskey-pass +# DATABASE_PASSWORD=${POSTGRES_PASSWORD} +POSTGRES_USER=example-misskey-user +# DATABASE_USER=${POSTGRES_USER} +POSTGRES_DB=misskey +# DATABASE_DB=${POSTGRES_DB} +DATABASE_URL="postgres://${POSTGRES_USER}:${POSTGRES_PASSWORD}@db:5432/${POSTGRES_DB}" diff --git a/.config/docker_example.yml b/.config/docker_example.yml new file mode 100644 index 0000000000..ce2daf3aec --- /dev/null +++ b/.config/docker_example.yml @@ -0,0 +1,319 @@ +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +# Misskey configuration +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ + +# ┌──────────────────────────────┐ +#───┘ a boring but important thing └──────────────────────────── + +# +# First of all, let me tell you a story that may possibly be +# boring to you and possibly important to you. +# +# Misskey is licensed under the AGPLv3 license. This license is +# known to be often misunderstood. Please read the following +# instructions carefully and select the appropriate option so +# that you do not negligently cause a license violation. +# + +# -------- +# Option 1: If you host Misskey AS-IS (without any changes to +# the source code. forks are not included). +# +# Step 1: Congratulations! You don't need to do anything. + +# -------- +# Option 2: If you have made changes to the source code (forks +# are included) and publish a Git repository of source +# code. There should be no access restrictions on +# this repository. Strictly speaking, it doesn't have +# to be a Git repository, but you'll probably use Git! +# +# Step 1: Build and run the Misskey server first. +# Step 2: Open in +# your browser with the administrator account. +# Step 3: Enter the URL of your Git repository in the +# "Repository URL" field. + +# -------- +# Option 3: If neither of the above applies to you. +# (In this case, the source code should be published +# on the Misskey interface. IT IS NOT ENOUGH TO +# DISCLOSE THE SOURCE CODE WEHN A USER REQUESTS IT BY +# E-MAIL OR OTHER MEANS. If you are not satisfied +# with this, it is recommended that you read the +# license again carefully. Anyway, enabling this +# option will automatically generate and publish a +# tarball at build time, protecting you from +# inadvertent license violations. (There is no legal +# guarantee, of course.) The tarball will generated +# from the root directory of your codebase. So it is +# also recommended to check directory +# once after building and before activating the server +# to avoid ACCIDENTAL LEAKING OF SENSITIVE INFORMATION. +# To prevent certain files from being included in the +# tarball, add a glob pattern after line 15 in +# . DO NOT FORGET TO BUILD AFTER +# ENABLING THIS OPTION!) +# +# Step 1: Uncomment the following line. +# +# publishTarballInsteadOfProvideRepositoryUrl: true + +# ┌─────┐ +#───┘ URL └───────────────────────────────────────────────────── + +# Final accessible URL seen by a user. +# You can set url from an environment variable instead. +url: https://example.tld/ + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# URL SETTINGS AFTER THAT! + +# ┌───────────────────────┐ +#───┘ Port and TLS settings └─────────────────────────────────── + +# +# Misskey requires a reverse proxy to support HTTPS connections. +# +# +----- https://example.tld/ ------------+ +# +------+ |+-------------+ +----------------+| +# | User | ---> || Proxy (443) | ---> | Misskey (3000) || +# +------+ |+-------------+ +----------------+| +# +---------------------------------------+ +# +# You need to set up a reverse proxy. (e.g. nginx) +# An encrypted connection with HTTPS is highly recommended +# because tokens may be transferred in GET requests. + +# The port that your Misskey server should listen on. +port: 3000 + +# ┌──────────────────────────┐ +#───┘ PostgreSQL configuration └──────────────────────────────── + +db: + host: db + port: 5432 + + # Database name + # You can set db from an environment variable instead. + db: misskey + + # Auth + # You can set user and pass from environment variables instead. + user: example-misskey-user + pass: example-misskey-pass + + # Whether disable Caching queries + #disableCache: true + + # Extra Connection options + #extra: + # ssl: true + +dbReplications: false + +# You can configure any number of replicas here +#dbSlaves: +# - +# host: +# port: +# db: +# user: +# pass: +# - +# host: +# port: +# db: +# user: +# pass: + +# ┌─────────────────────┐ +#───┘ Redis configuration └───────────────────────────────────── + +redis: + host: redis + port: 6379 + #family: 0 # 0=Both, 4=IPv4, 6=IPv6 + #pass: example-pass + #prefix: example-prefix + #db: 1 + +#redisForPubsub: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForJobQueue: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForTimelines: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForReactions: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +# ┌───────────────────────────┐ +#───┘ MeiliSearch configuration └───────────────────────────── + +# You can set scope to local (default value) or global +# (include notes from remote). + +#meilisearch: +# host: meilisearch +# port: 7700 +# apiKey: '' +# ssl: true +# index: '' +# scope: global + +# ┌───────────────┐ +#───┘ ID generation └─────────────────────────────────────────── + +# You can select the ID generation method. +# You don't usually need to change this setting, but you can +# change it according to your preferences. + +# Available methods: +# aid ... Short, Millisecond accuracy +# aidx ... Millisecond accuracy +# meid ... Similar to ObjectID, Millisecond accuracy +# ulid ... Millisecond accuracy +# objectid ... This is left for backward compatibility + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# ID SETTINGS AFTER THAT! + +id: 'aidx' + +# ┌────────────────┐ +#───┘ Error tracking └────────────────────────────────────────── + +# Sentry is available for error tracking. +# See the Sentry documentation for more details on options. + +#sentryForBackend: +# enableNodeProfiling: true +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +#sentryForFrontend: +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +# ┌─────────────────────┐ +#───┘ Other configuration └───────────────────────────────────── + +# Whether disable HSTS +#disableHsts: true + +# Number of worker processes +#clusterLimit: 1 + +# Job concurrency per worker +# deliverJobConcurrency: 128 +# inboxJobConcurrency: 16 +# relationshipJobConcurrency: 16 +# What's relationshipJob?: +# Follow, unfollow, block and unblock(ings) while following-imports, etc. or account migrations. + +# Job rate limiter +# deliverJobPerSec: 128 +# inboxJobPerSec: 32 +# relationshipJobPerSec: 64 + +# Job attempts +# deliverJobMaxAttempts: 12 +# inboxJobMaxAttempts: 8 + +# Local address used for outgoing requests +#outgoingAddress: 127.0.0.1 + +# IP address family used for outgoing request (ipv4, ipv6 or dual) +#outgoingAddressFamily: ipv4 + +# Amount of characters that can be used when writing notes. Longer notes will be rejected. (minimum: 1) +#maxNoteLength: 3000 +# Amount of characters that will be saved for remote notes. Longer notes will be truncated to this length. (minimum: 1) +#maxRemoteNoteLength: 100000 +# Amount of characters that can be used when writing content warnings. Longer warnings will be rejected. (minimum: 1) +#maxCwLength: 500 +# Amount of characters that will be saved for remote content warnings. Longer warnings will be truncated to this length. (minimum: 1) +#maxRemoteCwLength: 5000 +# Amount of characters that can be used when writing media descriptions (alt text). Longer descriptions will be rejected. (minimum: 1) +#maxAltTextLength: 20000 +# Amount of characters that will be saved for remote media descriptions (alt text). Longer descriptions will be truncated to this length. (minimum: 1) +#maxRemoteAltTextLength: 100000 + +# Proxy for HTTP/HTTPS +#proxy: http://127.0.0.1:3128 + +proxyBypassHosts: + - api.deepl.com + - api-free.deepl.com + - www.recaptcha.net + - hcaptcha.com + - challenges.cloudflare.com + +# Proxy for SMTP/SMTPS +#proxySmtp: http://127.0.0.1:3128 # use HTTP/1.1 CONNECT +#proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4 +#proxySmtp: socks5://127.0.0.1:1080 # use SOCKS5 + +# Media Proxy +#mediaProxy: https://example.com/proxy + +# Proxy remote files (default: true) +# Proxy remote files by this instance or mediaProxy to prevent remote files from running in remote domains. +proxyRemoteFiles: true + +# Movie Thumbnail Generation URL +# There is no reference implementation. +# For example, Misskey will point to the following URL: +# https://example.com/thumbnail.webp?thumbnail=1&url=https%3A%2F%2Fstorage.example.com%2Fpath%2Fto%2Fvideo.mp4 +#videoThumbnailGenerator: https://example.com + +# Sign outgoing ActivityPub GET request (default: true) +signToActivityPubGet: true +# Sign outgoing ActivityPub Activities (default: true) +# Linked Data signatures are cryptographic signatures attached to each activity to provide proof of authenticity. +# When using authorized fetch, this is often undesired as any signed activity can be forwarded to a blocked instance by relays and other instances. +# This setting allows admins to disable LD signatures for increased privacy, at the expense of fewer relayed activities and additional inbound fetch (GET) requests. +attachLdSignatureForRelays: true +# check that inbound ActivityPub GET requests are signed ("authorized fetch") +checkActivityPubGetSignature: false + +# For security reasons, uploading attachments from the intranet is prohibited, +# but exceptions can be made from the following settings. Default value is "undefined". +# Read changelog to learn more (Improvements of 12.90.0 (2021/09/04)). +#allowedPrivateNetworks: [ +# '127.0.0.1/32' +#] + +#customMOTD: ['Hello World', 'The sharks rule all', 'Shonks'] + +# Upload or download file size limits (bytes) +#maxFileSize: 262144000 + +# CHMod-style permission bits to apply to uploaded files. +# Permission bits are specified as a base-8 string representing User/Group/Other permissions. +# This setting is only useful for custom deployments, such as using a reverse proxy to serve media. +#filePermissionBits: '644' diff --git a/.config/example.yml b/.config/example.yml new file mode 100644 index 0000000000..ba8e818b5d --- /dev/null +++ b/.config/example.yml @@ -0,0 +1,355 @@ +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +# Misskey configuration +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ + +# ┌──────────────────────────────┐ +#───┘ a boring but important thing └──────────────────────────── + +# +# First of all, let me tell you a story that may possibly be +# boring to you and possibly important to you. +# +# Misskey is licensed under the AGPLv3 license. This license is +# known to be often misunderstood. Please read the following +# instructions carefully and select the appropriate option so +# that you do not negligently cause a license violation. +# + +# -------- +# Option 1: If you host Misskey AS-IS (without any changes to +# the source code. forks are not included). +# +# Step 1: Congratulations! You don't need to do anything. + +# -------- +# Option 2: If you have made changes to the source code (forks +# are included) and publish a Git repository of source +# code. There should be no access restrictions on +# this repository. Strictly speaking, it doesn't have +# to be a Git repository, but you'll probably use Git! +# +# Step 1: Build and run the Misskey server first. +# Step 2: Open in +# your browser with the administrator account. +# Step 3: Enter the URL of your Git repository in the +# "Repository URL" field. + +# -------- +# Option 3: If neither of the above applies to you. +# (In this case, the source code should be published +# on the Misskey interface. IT IS NOT ENOUGH TO +# DISCLOSE THE SOURCE CODE WHEN A USER REQUESTS IT BY +# E-MAIL OR OTHER MEANS. If you are not satisfied +# with this, it is recommended that you read the +# license again carefully. Anyway, enabling this +# option will automatically generate and publish a +# tarball at build time, protecting you from +# inadvertent license violations. (There is no legal +# guarantee, of course.) The tarball will generated +# from the root directory of your codebase. So it is +# also recommended to check directory +# once after building and before activating the server +# to avoid ACCIDENTAL LEAKING OF SENSITIVE INFORMATION. +# To prevent certain files from being included in the +# tarball, add a glob pattern after line 15 in +# . DO NOT FORGET TO BUILD AFTER +# ENABLING THIS OPTION!) +# +# Step 1: Uncomment the following line. +# +# publishTarballInsteadOfProvideRepositoryUrl: true + +# ┌────────────────────────┐ +#───┘ Initial Setup Password └───────────────────────────────────────────────────── + +# Password to initiate setting up admin account. +# It will not be used after the initial setup is complete. +# +# Be sure to change this when you set up Misskey via the Internet. +# +# The provider of the service who sets up Misskey on behalf of the customer should +# set this value to something unique when generating the Misskey config file, +# and provide it to the customer. +# +# setupPassword: example_password_please_change_this_or_you_will_get_hacked + +# ┌─────┐ +#───┘ URL └───────────────────────────────────────────────────── + +# Final accessible URL seen by a user. +url: https://example.tld/ + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# URL SETTINGS AFTER THAT! + +# ┌───────────────────────┐ +#───┘ Port and TLS settings └─────────────────────────────────── + +# +# Misskey requires a reverse proxy to support HTTPS connections. +# +# +----- https://example.tld/ ------------+ +# +------+ |+-------------+ +----------------+| +# | User | ---> || Proxy (443) | ---> | Misskey (3000) || +# +------+ |+-------------+ +----------------+| +# +---------------------------------------+ +# +# You need to set up a reverse proxy. (e.g. nginx) +# An encrypted connection with HTTPS is highly recommended +# because tokens may be transferred in GET requests. + +# The port that your Misskey server should listen on. +port: 3000 + +# You can also use UNIX domain socket. +# socket: /path/to/misskey.sock +# chmodSocket: '777' + +# ┌──────────────────────────┐ +#───┘ PostgreSQL configuration └──────────────────────────────── + +db: + host: localhost + port: 5432 + + # Database name + db: sharkey + + # Auth + user: sharkey + pass: example-misskey-pass + + # Whether disable Caching queries + #disableCache: true + + # Extra Connection options + #extra: + # ssl: true + +dbReplications: false + +# You can configure any number of replicas here +#dbSlaves: +# - +# host: +# port: +# db: +# user: +# pass: +# - +# host: +# port: +# db: +# user: +# pass: + +# ┌─────────────────────┐ +#───┘ Redis configuration └───────────────────────────────────── + +redis: + host: localhost + port: 6379 + #family: 0 # 0=Both, 4=IPv4, 6=IPv6 + #pass: example-pass + #prefix: example-prefix + #db: 1 + # You can specify more ioredis options... + #username: example-username + +#redisForPubsub: +# host: localhost +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 +# # You can specify more ioredis options... +# #username: example-username + +#redisForJobQueue: +# host: localhost +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 +# # You can specify more ioredis options... +# #username: example-username + +#redisForTimelines: +# host: localhost +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 +# # You can specify more ioredis options... +# #username: example-username + +#redisForReactions: +# host: localhost +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 +# # You can specify more ioredis options... +# #username: example-username + +# ┌───────────────────────────┐ +#───┘ MeiliSearch configuration └───────────────────────────── + +# You can set scope to local (default value) or global +# (include notes from remote). + +#meilisearch: +# host: localhost +# port: 7700 +# apiKey: '' +# ssl: true +# index: '' +# scope: global + +# ┌───────────────┐ +#───┘ ID generation └─────────────────────────────────────────── + +# You can select the ID generation method. +# You don't usually need to change this setting, but you can +# change it according to your preferences. + +# Available methods: +# aid ... Short, Millisecond accuracy +# aidx ... Millisecond accuracy +# meid ... Similar to ObjectID, Millisecond accuracy +# ulid ... Millisecond accuracy +# objectid ... This is left for backward compatibility + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# ID SETTINGS AFTER THAT! + +id: 'aidx' + +# ┌────────────────┐ +#───┘ Error tracking └────────────────────────────────────────── + +# Sentry is available for error tracking. +# See the Sentry documentation for more details on options. + +#sentryForBackend: +# enableNodeProfiling: true +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +#sentryForFrontend: +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +# ┌─────────────────────┐ +#───┘ Other configuration └───────────────────────────────────── + +# Whether disable HSTS +#disableHsts: true + +# Number of worker processes +#clusterLimit: 1 + +# Job concurrency per worker +#deliverJobConcurrency: 128 +#inboxJobConcurrency: 16 +#relationshipJobConcurrency: 16 +# What's relationshipJob?: +# Follow, unfollow, block and unblock(ings) while following-imports, etc. or account migrations. + +# Job rate limiter +#deliverJobPerSec: 128 +#inboxJobPerSec: 32 +#relationshipJobPerSec: 64 + +# Job attempts +#deliverJobMaxAttempts: 12 +#inboxJobMaxAttempts: 8 + +# Local address used for outgoing requests +#outgoingAddress: 127.0.0.1 + +# IP address family used for outgoing request (ipv4, ipv6 or dual) +#outgoingAddressFamily: ipv4 + +# Amount of characters that can be used when writing notes. Longer notes will be rejected. (minimum: 1) +#maxNoteLength: 3000 +# Amount of characters that will be saved for remote notes. Longer notes will be truncated to this length. (minimum: 1) +#maxRemoteNoteLength: 100000 +# Amount of characters that can be used when writing content warnings. Longer warnings will be rejected. (minimum: 1) +#maxCwLength: 500 +# Amount of characters that will be saved for remote content warnings. Longer warnings will be truncated to this length. (minimum: 1) +#maxRemoteCwLength: 5000 +# Amount of characters that can be used when writing media descriptions (alt text). Longer descriptions will be rejected. (minimum: 1) +#maxAltTextLength: 20000 +# Amount of characters that will be saved for remote media descriptions (alt text). Longer descriptions will be truncated to this length. (minimum: 1) +#maxRemoteAltTextLength: 100000 + +# Proxy for HTTP/HTTPS +#proxy: http://127.0.0.1:3128 + +proxyBypassHosts: + - api.deepl.com + - api-free.deepl.com + - www.recaptcha.net + - hcaptcha.com + - challenges.cloudflare.com + +# Proxy for SMTP/SMTPS +#proxySmtp: http://127.0.0.1:3128 # use HTTP/1.1 CONNECT +#proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4 +#proxySmtp: socks5://127.0.0.1:1080 # use SOCKS5 + +# Media Proxy +# Reference Implementation: https://github.com/misskey-dev/media-proxy +# * Deliver a common cache between instances +# * Perform image compression (on a different server resource than the main process) +#mediaProxy: https://example.com/proxy + +# Proxy remote files (default: true) +# Proxy remote files by this instance or mediaProxy to prevent remote files from running in remote domains. +proxyRemoteFiles: true + +# Movie Thumbnail Generation URL +# There is no reference implementation. +# For example, Misskey will point to the following URL: +# https://example.com/thumbnail.webp?thumbnail=1&url=https%3A%2F%2Fstorage.example.com%2Fpath%2Fto%2Fvideo.mp4 +#videoThumbnailGenerator: https://example.com + +# Sign outgoing ActivityPub GET request (default: true) +signToActivityPubGet: true +# Sign outgoing ActivityPub Activities (default: true) +# Linked Data signatures are cryptographic signatures attached to each activity to provide proof of authenticity. +# When using authorized fetch, this is often undesired as any signed activity can be forwarded to a blocked instance by relays and other instances. +# This setting allows admins to disable LD signatures for increased privacy, at the expense of fewer relayed activities and additional inbound fetch (GET) requests. +attachLdSignatureForRelays: true +# check that inbound ActivityPub GET requests are signed ("authorized fetch") +checkActivityPubGetSignature: false + +# For security reasons, uploading attachments from the intranet is prohibited, +# but exceptions can be made from the following settings. Default value is "undefined". +# Read changelog to learn more (Improvements of 12.90.0 (2021/09/04)). +#allowedPrivateNetworks: [ +# '127.0.0.1/32' +#] + +#customMOTD: ['Hello World', 'The sharks rule all', 'Shonks'] + +# Upload or download file size limits (bytes) +#maxFileSize: 262144000 + +# timeout and maximum size for imports (e.g. note imports) +#import: +# downloadTimeout: 30 +# maxFileSize: 262144000 + +# PID File of master process +#pidFile: /tmp/misskey.pid + +# CHMod-style permission bits to apply to uploaded files. +# Permission bits are specified as a base-8 string representing User/Group/Other permissions. +# This setting is only useful for custom deployments, such as using a reverse proxy to serve media. +#filePermissionBits: '644' diff --git a/.config/test-example.yml b/.config/test-example.yml new file mode 100644 index 0000000000..713cbdb0a0 --- /dev/null +++ b/.config/test-example.yml @@ -0,0 +1,17 @@ +url: 'http://misskey.local' + +setupPassword: example_password_please_change_this_or_you_will_get_hacked + +# ローカルでテストするときにポートを被らないようにするためデフォルトのものとは変える(以下同じ) +port: 61812 + +db: + host: 127.0.0.1 + port: 5432 + db: test-misskey + user: postgres + pass: '' +redis: + host: 127.0.0.1 + port: 6379 +id: aidx diff --git a/.devcontainer/Dockerfile b/.devcontainer/Dockerfile new file mode 100644 index 0000000000..b6ebcf6ad3 --- /dev/null +++ b/.devcontainer/Dockerfile @@ -0,0 +1 @@ +FROM mcr.microsoft.com/devcontainers/javascript-node:0-18 diff --git a/.devcontainer/compose.yml b/.devcontainer/compose.yml new file mode 100644 index 0000000000..d02d2a8f4a --- /dev/null +++ b/.devcontainer/compose.yml @@ -0,0 +1,53 @@ +services: + app: + build: + context: . + dockerfile: Dockerfile + + volumes: + - ../:/workspace:cached + - node_modules:/workspace/node_modules + + command: sleep infinity + + networks: + - internal_network + - external_network + + redis: + restart: unless-stopped + image: redis:7-alpine + networks: + - internal_network + volumes: + - redis-data:/data + healthcheck: + test: "redis-cli ping" + interval: 5s + retries: 20 + + db: + restart: unless-stopped + image: postgres:15-alpine + networks: + - internal_network + environment: + POSTGRES_USER: postgres + POSTGRES_PASSWORD: postgres + POSTGRES_DB: misskey + volumes: + - postgres-data:/var/lib/postgresql/data + healthcheck: + test: "pg_isready -U $$POSTGRES_USER -d $$POSTGRES_DB" + interval: 5s + retries: 20 + +volumes: + postgres-data: + redis-data: + node_modules: + +networks: + internal_network: + internal: true + external_network: diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json new file mode 100644 index 0000000000..713c2e5fdd --- /dev/null +++ b/.devcontainer/devcontainer.json @@ -0,0 +1,26 @@ +{ + "name": "Misskey", + "dockerComposeFile": "compose.yml", + "service": "app", + "workspaceFolder": "/workspace", + "features": { + "ghcr.io/devcontainers/features/node:1": { + "version": "22.11.0" + }, + "ghcr.io/devcontainers-contrib/features/corepack:1": {} + }, + "forwardPorts": [3000], + "postCreateCommand": "/bin/bash .devcontainer/init.sh", + "customizations": { + "vscode": { + "extensions": [ + "editorconfig.editorconfig", + "dbaeumer.vscode-eslint", + "Vue.volar", + "Orta.vscode-jest", + "dbaeumer.vscode-eslint", + "mrmlnc.vscode-json5" + ] + } + } +} diff --git a/.devcontainer/devcontainer.yml b/.devcontainer/devcontainer.yml new file mode 100644 index 0000000000..3eb4fc2879 --- /dev/null +++ b/.devcontainer/devcontainer.yml @@ -0,0 +1,211 @@ +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ +# Misskey configuration +#━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ + +# ┌─────┐ +#───┘ URL └───────────────────────────────────────────────────── + +# Final accessible URL seen by a user. +url: http://127.0.0.1:3000/ + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# URL SETTINGS AFTER THAT! + +# ┌───────────────────────┐ +#───┘ Port and TLS settings └─────────────────────────────────── + +# +# Misskey requires a reverse proxy to support HTTPS connections. +# +# +----- https://example.tld/ ------------+ +# +------+ |+-------------+ +----------------+| +# | User | ---> || Proxy (443) | ---> | Misskey (3000) || +# +------+ |+-------------+ +----------------+| +# +---------------------------------------+ +# +# You need to set up a reverse proxy. (e.g. nginx) +# An encrypted connection with HTTPS is highly recommended +# because tokens may be transferred in GET requests. + +# The port that your Misskey server should listen on. +port: 3000 + +# ┌──────────────────────────┐ +#───┘ PostgreSQL configuration └──────────────────────────────── + +db: + host: db + port: 5432 + + # Database name + db: misskey + + # Auth + user: postgres + pass: postgres + + # Whether disable Caching queries + #disableCache: true + + # Extra Connection options + #extra: + # ssl: true + +dbReplications: false + +# You can configure any number of replicas here +#dbSlaves: +# - +# host: +# port: +# db: +# user: +# pass: +# - +# host: +# port: +# db: +# user: +# pass: + +# ┌─────────────────────┐ +#───┘ Redis configuration └───────────────────────────────────── + +redis: + host: redis + port: 6379 + #family: 0 # 0=Both, 4=IPv4, 6=IPv6 + #pass: example-pass + #prefix: example-prefix + #db: 1 + +#redisForPubsub: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForJobQueue: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForTimelines: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +#redisForReactions: +# host: redis +# port: 6379 +# #family: 0 # 0=Both, 4=IPv4, 6=IPv6 +# #pass: example-pass +# #prefix: example-prefix +# #db: 1 + +# ┌───────────────────────────┐ +#───┘ MeiliSearch configuration └───────────────────────────── + +#meilisearch: +# host: meilisearch +# port: 7700 +# apiKey: '' +# ssl: true +# index: '' + +# ┌───────────────┐ +#───┘ ID generation └─────────────────────────────────────────── + +# You can select the ID generation method. +# You don't usually need to change this setting, but you can +# change it according to your preferences. + +# Available methods: +# aid ... Short, Millisecond accuracy +# aidx ... Millisecond accuracy +# meid ... Similar to ObjectID, Millisecond accuracy +# ulid ... Millisecond accuracy +# objectid ... This is left for backward compatibility + +# ONCE YOU HAVE STARTED THE INSTANCE, DO NOT CHANGE THE +# ID SETTINGS AFTER THAT! + +id: 'aidx' + +# ┌────────────────┐ +#───┘ Error tracking └────────────────────────────────────────── + +# Sentry is available for error tracking. +# See the Sentry documentation for more details on options. + +#sentryForBackend: +# enableNodeProfiling: true +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +#sentryForFrontend: +# options: +# dsn: 'https://examplePublicKey@o0.ingest.sentry.io/0' + +# ┌─────────────────────┐ +#───┘ Other configuration └───────────────────────────────────── + +# Whether disable HSTS +#disableHsts: true + +# Number of worker processes +#clusterLimit: 1 + +# Job concurrency per worker +# deliverJobConcurrency: 128 +# inboxJobConcurrency: 16 + +# Job rate limiter +# deliverJobPerSec: 128 +# inboxJobPerSec: 32 + +# Job attempts +# deliverJobMaxAttempts: 12 +# inboxJobMaxAttempts: 8 + +# IP address family used for outgoing request (ipv4, ipv6 or dual) +#outgoingAddressFamily: ipv4 + +# Proxy for HTTP/HTTPS +#proxy: http://127.0.0.1:3128 + +proxyBypassHosts: + - api.deepl.com + - api-free.deepl.com + - www.recaptcha.net + - hcaptcha.com + - challenges.cloudflare.com + +# Proxy for SMTP/SMTPS +#proxySmtp: http://127.0.0.1:3128 # use HTTP/1.1 CONNECT +#proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4 +#proxySmtp: socks5://127.0.0.1:1080 # use SOCKS5 + +# Media Proxy +#mediaProxy: https://example.com/proxy + +# Proxy remote files (default: true) +proxyRemoteFiles: true + +# Sign to ActivityPub GET request (default: true) +signToActivityPubGet: true + +allowedPrivateNetworks: [ + '127.0.0.1/32' +] + +# Upload or download file size limits (bytes) +#maxFileSize: 262144000 diff --git a/.devcontainer/init.sh b/.devcontainer/init.sh new file mode 100755 index 0000000000..e02a533c15 --- /dev/null +++ b/.devcontainer/init.sh @@ -0,0 +1,17 @@ +#!/bin/bash + +set -xe + +sudo chown node node_modules +sudo apt-get update +sudo apt-get -y install libgtk2.0-0 libgtk-3-0 libgbm-dev libnotify-dev libnss3 libxss1 libasound2 libxtst6 xauth xvfb +git config --global --add safe.directory /workspace +git submodule update --init +corepack install +corepack enable +pnpm config set store-dir /home/node/.local/share/pnpm/store +pnpm install --frozen-lockfile +cp .devcontainer/devcontainer.yml .config/default.yml +pnpm build +pnpm migrate +pnpm exec cypress install diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000000..f204349160 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,30 @@ +.autogen +.github +.travis +.vscode +.config +Dockerfile +build/ +built/ +db/ +.devcontainer/compose.yml +node_modules/ +packages/*/node_modules +redis/ +files/ +fluent-emojis/ +.pnp.* + +# .yarn関連 +.yarn/* +!.yarn/patches +!.yarn/plugins +!.yarn/releases +!.yarn/sdks +!.yarn/versions + +.pnpm-store + +.idea/ +packages/*/.vscode/ +packages/backend/test/compose.yml diff --git a/.dockleignore b/.dockleignore new file mode 100644 index 0000000000..2f93266456 --- /dev/null +++ b/.dockleignore @@ -0,0 +1,3 @@ +DKL-DI-0005 +DKL-DI-0006 +DKL-LI-0003 diff --git a/.editorconfig b/.editorconfig new file mode 100644 index 0000000000..def7baa1a8 --- /dev/null +++ b/.editorconfig @@ -0,0 +1,15 @@ +root = true + +[*] +indent_style = tab +indent_size = 2 +charset = utf-8 +insert_final_newline = true +end_of_line = lf +trim_trailing_whitespace = true + +[*.md] +trim_trailing_whitespace = false + +[*.{yml,yaml}] +indent_style = space diff --git a/.gitattributes b/.gitattributes new file mode 100644 index 0000000000..246ecb0a60 --- /dev/null +++ b/.gitattributes @@ -0,0 +1,8 @@ +*.svg -diff -text +*.psd -diff -text +*.ai -diff -text +*.mqo -diff -text +*.glb -diff -text +*.blend -diff -text +*.afdesign -diff -text +* text=auto eol=lf diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000000..b07d195a3f --- /dev/null +++ b/.gitignore @@ -0,0 +1,89 @@ +# Visual Studio Code +/.vscode +!/.vscode/extensions.json + +# Intelij-IDEA +/.idea + +# Node.js +node_modules +report.*.json + +# Yarn +.yarn/* +!.yarn/patches +!.yarn/plugins +!.yarn/releases +!.yarn/sdks +!.yarn/versions +packages/frontend/.yarn/cache +packages/backend/.yarn/cache +packages/sw/.yarn/cache + +# pnpm +.pnpm-store + +# eslint +**/.eslintcache + +# Cypress +cypress/screenshots +cypress/videos + +# Coverage +coverage + +# config +/.config/* +!/.config/example.yml +!/.config/test-example.yml +!/.config/docker_example.yml +!/.config/docker_example.env +!/.config/cypress-devcontainer.yml +docker-compose.yml +./compose.yml +.devcontainer/compose.yml +!/.devcontainer/compose.yml + +# misskey +/build +built +built-test +js-built +/data +/.cache-loader +/db +/meili_data +npm-debug.log +*.pem +run.bat +api-docs.json +*.log +/redis +*.code-workspace +.DS_Store +/files +ormconfig.json +temp +/packages/frontend/src/**/*.stories.ts +tsdoc-metadata.json +misskey-assets + +# Vite temporary files +vite.config.js.timestamp-* +vite.config.ts.timestamp-* +vite.config.local-dev.js.timestamp-* +vite.config.local-dev.ts.timestamp-* + +# blender backups +*.blend1 +*.blend2 +*.blend3 +*.blend4 +*.blend5 + +# VSCode addon +.favorites.json + +# Sharkey +/packages/megalodon/lib diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml new file mode 100644 index 0000000000..4db8bda32e --- /dev/null +++ b/.gitlab-ci.yml @@ -0,0 +1,114 @@ +stages: + - test + - deploy + +testCommit: + stage: test + image: node:iron + services: + - postgres:15 + - redis + variables: + POSTGRES_PASSWORD: ci + script: + - apt-get update && apt-get install -y git wget curl build-essential python3 ffmpeg + - cp .config/ci.yml .config/default.yml + - cp .config/ci.yml .config/test.yml + - corepack enable + - corepack prepare pnpm@latest --activate + - git submodule update --init + - pnpm install --frozen-lockfile + - pnpm run build + - pnpm run migrate + - pnpm run --filter='!megalodon' test + - pnpm run --filter=backend --filter=misskey-js lint + - pnpm run --filter=frontend --filter=frontend-embed eslint + cache: + key: test + policy: pull-push + when: on_success + paths: + - node_modules/ + - packages/*/node_modules/ + only: + - develop + - merge_requests + - stable + +getImageTag: + stage: deploy + image: ubuntu:latest + script: + - apt-get update && apt-get install -y jq + - | + if test -n "$CI_COMMIT_TAG"; then + tag="$CI_COMMIT_TAG" + elif test "$CI_COMMIT_BRANCH" == "stable"; then + tag="latest" + elif test "$CI_COMMIT_BRANCH" == "develop"; then + tag="develop" + else + tag="$CI_COMMIT_BRANCH" + fi + version=$(cat package.json | jq -r '.version') + - echo "REGISTRY_PUSH_TAG=$tag" >> build.env + - echo "REGISTRY_PUSH_VERSION=$version" >> build.env + artifacts: + reports: + dotenv: build.env + only: + - stable + - develop + - tags + +buildDocker: + stage: deploy + needs: + - job: getImageTag + artifacts: true + parallel: + matrix: + - ARCH: amd64 + - ARCH: arm64 + tags: + - ${ARCH} + image: + name: gcr.io/kaniko-project/executor:debug + entrypoint: [""] + script: + - >- + /kaniko/executor + --context "${CI_PROJECT_DIR}" + --dockerfile "${CI_PROJECT_DIR}/Dockerfile" + --destination "${CI_REGISTRY_IMAGE}:${REGISTRY_PUSH_VERSION}-${ARCH}" + only: + - stable + - develop + - tags + +mergeManifests: + stage: deploy + needs: + - job: buildDocker + artifacts: false + - job: getImageTag + artifacts: true + tags: + - docker + image: + name: mplatform/manifest-tool:alpine + entrypoint: [""] + script: + - >- + manifest-tool + --username=${CI_REGISTRY_USER} + --password=${CI_REGISTRY_PASSWORD} + push from-args + --platforms linux/amd64,linux/arm64 + --tags ${REGISTRY_PUSH_VERSION} + --template ${CI_REGISTRY_IMAGE}:${REGISTRY_PUSH_VERSION}-ARCH + --target ${CI_REGISTRY_IMAGE}:${REGISTRY_PUSH_TAG} + only: + - stable + - develop + - tags diff --git a/.gitlab/issue_templates/bug.md b/.gitlab/issue_templates/bug.md new file mode 100644 index 0000000000..a909067269 --- /dev/null +++ b/.gitlab/issue_templates/bug.md @@ -0,0 +1,35 @@ + + +# **What happened?** + + +# **What did you expect to happen?** + + +# **Version** + + +# **Instance** + + +# **What type of issue is this?** + + +# **What browser are you using? (Client-side issues only)** + +# **What operating system are you using? (Client-side issues only)** + +# **How do you deploy Sharkey on your server? (Server-side issues only)** + +# **What operating system are you using? (Server-side issues only)** + +# **Relevant log output** + + +# **Contribution Guidelines** +By submitting this issue, you agree to follow our [Contribution Guidelines](https://activitypub.software/TransFem-org/Sharkey/-/blob/develop/CONTRIBUTING.md) +- [ ] I agree to follow this project's Contribution Guidelines +- [ ] I have searched the issue tracker for similar issues, and this is not a duplicate. diff --git a/.gitlab/issue_templates/feature.md b/.gitlab/issue_templates/feature.md new file mode 100644 index 0000000000..a77f9335fe --- /dev/null +++ b/.gitlab/issue_templates/feature.md @@ -0,0 +1,21 @@ + + +# **What feature would you like implemented?** + + +# **Why should we add this feature?** + + +# **Version** + + +# **Instance** + + +# **Contribution Guidelines** +By submitting this issue, you agree to follow our [Contribution Guidelines](https://activitypub.software/TransFem-org/Sharkey/-/blob/develop/CONTRIBUTING.md) +- [ ] I agree to follow this project's Contribution Guidelines +- [ ] I have searched the issue tracker for similar requests, and this is not a duplicate. diff --git a/.gitlab/merge_request_templates/default.md b/.gitlab/merge_request_templates/default.md new file mode 100644 index 0000000000..e6977def70 --- /dev/null +++ b/.gitlab/merge_request_templates/default.md @@ -0,0 +1,12 @@ + + +# **What does this MR do?** + + +# **Contribution Guidelines** +By submitting this merge request, you agree to follow our [Contribution Guidelines](https://activitypub.software/TransFem-org/Sharkey/-/blob/develop/CONTRIBUTING.md) +- [ ] I agree to follow this project's Contribution Guidelines +- [ ] I have made sure to test this merge request + + + diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 0000000000..1a68b48180 --- /dev/null +++ b/.gitmodules @@ -0,0 +1,6 @@ +[submodule "fluent-emojis"] + path = fluent-emojis + url = https://github.com/misskey-dev/emojis.git +[submodule "tossface-emojis"] + path = tossface-emojis + url = https://activitypub.software/TransFem-org/tossface-emojis.git diff --git a/.node-version b/.node-version new file mode 100644 index 0000000000..7af24b7ddb --- /dev/null +++ b/.node-version @@ -0,0 +1 @@ +22.11.0 diff --git a/.npmrc b/.npmrc new file mode 100644 index 0000000000..b949431c77 --- /dev/null +++ b/.npmrc @@ -0,0 +1,2 @@ +@transfem-org:registry=https://activitypub.software/api/v4/packages/npm/ +engine-strict = true diff --git a/.okteto/okteto-pipeline.yml b/.okteto/okteto-pipeline.yml new file mode 100644 index 0000000000..e2996fbbc9 --- /dev/null +++ b/.okteto/okteto-pipeline.yml @@ -0,0 +1,6 @@ +build: + misskey: + args: + - NODE_ENV=development +deploy: + - helm upgrade --install misskey chart --set image=${OKTETO_BUILD_MISSKEY_IMAGE} --set url="https://misskey-$(kubectl config view --minify -o jsonpath='{..namespace}').cloud.okteto.net" --set environment=development diff --git a/.vsls.json b/.vsls.json new file mode 100644 index 0000000000..3fff862442 --- /dev/null +++ b/.vsls.json @@ -0,0 +1,4 @@ +{ + "$schema": "http://json.schemastore.org/vsls", + "gitignore": "exclude" +} diff --git a/CHANGELOG.md b/CHANGELOG.md new file mode 100644 index 0000000000..2dbc457710 --- /dev/null +++ b/CHANGELOG.md @@ -0,0 +1,2824 @@ +## 2024.11.0 + +### Note +- Node.js 20.xは非推奨になりました。Node.js 22.x (LTS)の利用を推奨します。 + - なお、Node.js 23.xは対応していません。 +- DockerのNode.jsが22.11.0に更新されました + +### General +- Feat: コンテンツの表示にログインを必須にできるように +- Feat: 過去のノートを非公開化/フォロワーのみ表示可能にできるように +- Enhance: 依存関係の更新 +- Enhance: l10nの更新 +- Fix: お知らせ作成時に画像URL入力欄を空欄に変更できないのを修正 ( #14976 ) + +### Client +- Enhance: Bull DashboardでRelationship Queueの状態も確認できるように + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/751) +- Enhance: ドライブでソートができるように +- Enhance: アイコンデコレーション管理画面の改善 +- Enhance: 「単なるラッキー」の取得条件を変更 +- Enhance: 投稿フォームでEscキーを押したときIME入力中ならフォームを閉じないように( #10866 ) +- Enhance: MiAuth, OAuthの認可画面の改善 + - どのアカウントで認証しようとしているのかがわかるように + - 認証するアカウントを切り替えられるように +- Enhance: Self-XSS防止用の警告を追加 +- Enhance: カタルーニャ語 (ca-ES) に対応 +- Enhance: 個別お知らせページではMetaタグを出力するように +- Enhance: ノート詳細画面にロールのバッジを表示 +- Enhance: 過去に送信したフォローリクエストを確認できるように + (Based on https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/663) +- Enhance: サイドバーを簡単に展開・折りたたみできるように ( #14981 ) +- Enhance: リノートメニューに「リノートの詳細」を追加 +- Enhance: 非ログイン状態でMisskeyを開いた際のパフォーマンスを向上 +- Fix: 通知の範囲指定の設定項目が必要ない通知設定でも範囲指定の設定がでている問題を修正 +- Fix: Turnstileが失敗・期限切れした際にも成功扱いとなってしまう問題を修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/768) +- Fix: デッキのタイムラインカラムで「センシティブなファイルを含むノートを表示」設定が使用できなかった問題を修正 +- Fix: Encode RSS urls with escape sequences before fetching allowing query parameters to be used +- Fix: リンク切れを修正 += Fix: ノート投稿ボタンにホバー時のスタイルが適用されていないのを修正 + (Cherry-picked from https://github.com/taiyme/misskey/pull/305) +- Fix: メールアドレス登録有効化時の「完了」ダイアログボックスの表示条件を修正 +- Fix: 画面幅が狭い環境でデザインが崩れる問題を修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/815) +- Fix: TypeScriptの型チェック対象ファイルを限定してビルドを高速化するように + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/725) + +### Server +- Enhance: DockerのNode.jsを22.11.0に更新 +- Enhance: 起動前の疎通チェックで、DBとメイン以外のRedisの疎通確認も行うように + (Based on https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/588) + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/715) +- Enhance: リモートユーザーの照会をオリジナルにリダイレクトするように +- Fix: sharedInboxが無いActorに紐づくリモートユーザーを照会できない +- Fix: Aproving request from GtS appears with some delay +- Fix: フォロワーへのメッセージの絵文字をemojisに含めるように +- Fix: Nested proxy requestsを検出した際にブロックするように + [ghsa-gq5q-c77c-v236](https://github.com/misskey-dev/misskey/security/advisories/ghsa-gq5q-c77c-v236) +- Fix: 招待コードの発行可能な残り数算出に使用すべきロールポリシーの値が違う問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/706) +- Fix: 連合への配信時に、acctの大小文字が区別されてしまい正しくメンションが処理されないことがある問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/711) +- Fix: ローカルユーザーへのメンションを含むノートが連合される際に正しいURLに変換されないことがある問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/712) +- Fix: FTT無効時にユーザーリストタイムラインが使用できない問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/709) +- Fix: User Webhookテスト機能のMock Payloadを修正 +- Fix: アカウント削除のモデレーションログが動作していないのを修正 (#14996) +- Fix: リノートミュートが新規投稿通知に対して作用していなかった問題を修正 +- Fix: Inboxの処理で生じるエラーを誤ってActivityとして処理することがある問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/730) +- Fix: セキュリティに関する修正 + +### Misskey.js +- Fix: Stream初期化時、別途WebSocketを指定する場合の型定義を修正 + +## 2024.10.1 + +### Note +- スパム対策として、モデレータ権限を持つユーザのアクティビティが7日以上確認できない場合は自動的に招待制へと切り替え(コントロールパネル -> モデレーション -> "誰でも新規登録できるようにする"をオフに変更)るようになりました。 ( #13437 ) + - 切り替わった際はモデレーターへお知らせとして通知されます。登録をオープンな状態で継続したい場合は、コントロールパネルから再度設定を行ってください。 + +### General +- Feat: ユーザーの名前に禁止ワードを設定できるように + +### Client +- Enhance: タイムライン表示時のパフォーマンスを向上 +- Enhance: アーカイブした個人宛のお知らせを表示・編集できるように +- Enhance: l10nの更新 +- Fix: メールアドレス不要でCaptchaが有効な場合にアカウント登録完了後自動でのログインに失敗する問題を修正 + +### Server +- Feat: モデレータ権限を持つユーザが全員7日間活動しなかった場合は自動的に招待制へと切り替えるように ( #13437 ) +- Enhance: 個人宛のお知らせは「わかった」を押すと自動的にアーカイブされるように +- Fix: `admin/emoji/update`エンドポイントのidのみ指定した時不正なエラーが発生するバグを修正 +- Fix: RBT有効時、リノートのリアクションが反映されない問題を修正 +- Fix: キューのエラーログを簡略化するように + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/649) + +## 2024.10.0 + +### Note +- セキュリティ向上のため、サーバー初期設定時に使用する初期パスワードを設定できるようになりました。今後Misskeyサーバーを新たに設置する際には、初回の起動前にコンフィグファイルの`setupPassword`をコメントアウトし、初期パスワードを設定することをおすすめします。(すでに初期設定を完了しているサーバーについては、この変更に伴い対応する必要はありません) + - ホスティングサービスを運営している場合は、コンフィグファイルを構築する際に`setupPassword`をランダムな値に設定し、ユーザーに通知するようにシステムを更新することをおすすめします。 + - なお、初期パスワードが設定されていない場合でも初期設定を行うことが可能です(UI上で初期パスワードの入力欄を空欄にすると続行できます)。 +- ユーザーデータを読み込む際の型が一部変更されました。 + - `twoFactorEnabled`, `usePasswordLessLogin`, `securityKeys`: 自分とモデレーター以外のユーザーからは取得できなくなりました + +### General +- Feat: サーバー初期設定時に初期パスワードを設定できるように +- Feat: 通報にモデレーションノートを残せるように +- Feat: 通報の解決種別を設定できるように +- Enhance: 通報の解決と転送を個別に行えるように +- Enhance: セキュリティ向上のため、サインイン時もCAPTCHAを求めるようになりました +- Enhance: 依存関係の更新 +- Enhance: l10nの更新 +- Enhance: Playの「人気」タブで10件以上表示可能に #14399 +- Fix: 連合のホワイトリストが正常に登録されない問題を修正 + +### Client +- Enhance: デザインの調整 +- Enhance: ログイン画面の認証フローを改善 +- Fix: クライアント上での時間ベースの実績獲得動作が実績獲得後も発動していた問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/657) + +### Server +- Enhance: セキュリティ向上のため、ログイン時にメール通知を行うように +- Enhance: 自分とモデレーター以外のユーザーから二要素認証関連のデータが取得できないように +- Enhance: 通報および通報解決時に送出されるSystemWebhookにユーザ情報を含めるように ( #14697 ) +- Fix: `admin/abuse-user-reports`エンドポイントのスキーマが間違っていた問題を修正 + +## 2024.9.0 + +### General +- Feat: ノート単体・ユーザーのノート・クリップのノートの埋め込み機能 + - 埋め込みコードやウェブサイトへの実装方法の詳細は 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) +- Feat: データエクスポートが完了した際に通知を発行するように +- Enhance: ユーザーによるコンテンツインポートの可否をロールポリシーで制御できるように +- Enhance: 依存関係の更新 +- Enhance: l10nの更新 + +### Client +- Enhance: サイズ制限を超過するファイルをアップロードしようとした際にエラーを出すように +- Enhance: アイコンデコレーション管理画面にプレビューを追加 +- Enhance: コントロールパネル内のファイル一覧でセンシティブなファイルを区別しやすく +- Enhance: ScratchpadにUIインスペクターを追加 +- Enhance: Play編集画面の項目の並びを少しリデザイン +- Enhance: 各種メニューをドロワー表示するかどうか設定可能に +- Enhance: AiScriptのMk:C:containerのオプションに`borderStyle`と`borderRadius`を追加 +- Enhance: CWでも絵文字をクリックしてメニューを表示できるように +- Fix: サーバーメトリクスが2つ以上あるとリロード直後の表示がおかしくなる問題を修正 +- Fix: コントロールパネル内のAp requests内のチャートの表示がおかしかった問題を修正 +- Fix: 月の違う同じ日はセパレータが表示されないのを修正 +- Fix: タッチ画面でレンジスライダーを操作するとツールチップが複数表示される問題を修正 + (Cherry-picked from https://github.com/taiyme/misskey/pull/265) +- Fix: 縦横比が極端なカスタム絵文字を表示する際にレイアウトが崩れる箇所があるのを修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/725) +- Fix: 設定変更時のリロード確認ダイアログが複数個表示されることがある問題を修正 +- Fix: ファイルの詳細ページのファイルの説明で改行が正しく表示されない問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/commit/bde6bb0bd2e8b0d027e724d2acdb8ae0585a8110) +- Fix: 一部画面のページネーションが動作しにくくなっていたのを修正 ( #12766 , #11449 ) + +### Server +- Feat: Misskey® Reactions Boost Technology™ (RBT)により、リアクションの作成負荷を低減することが可能に +- Fix: アンテナの書き込み時にキーワードが与えられなかった場合のエラーをApiErrorとして投げるように + - この変更により、公式フロントエンドでは入力の不備が内部エラーとして報告される代わりに一般的なエラーダイアログで報告されます +- Fix: ファイルがサイズの制限を超えてアップロードされた際にエラーを返さなかった問題を修正 +- Fix: 外部ページを解析する際に、ページに紐づけられた関連リソースも読み込まれてしまう問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/commit/26e0412fbb91447c37e8fb06ffb0487346063bb8) +- Fix: Continue importing from file if single emoji import fails +- Fix: `Retry-After`ヘッダーが送信されなかった問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/commit/8a982c61c01909e7540ff1be9f019df07c3f0624) +- Fix: サーバーサイドのDOM解析完了時にリソースを開放するように + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/634) +- Fix: ``を追って照会するのはOKレスポンスが返却された場合のみに + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/633) +- Fix: メールにスタイルが適用されていなかった問題を修正 + +## 2024.8.0 + +### General +- Enhance: モデレーターはすべてのユーザーのフォロー・フォロワーの一覧を見られるように +- Enhance: アカウントの削除のモデレーションログを残すように +- Enhance: 不適切なページ、ギャラリー、Playを管理者権限で削除できるように +- Fix: リモートユーザのフォロー・フォロワーの一覧が非公開設定の場合も表示できてしまう問題を修正 + +### Client +- Enhance: 「自分のPlay」ページにおいてPlayが非公開かどうかが一目でわかるように +- Enhance: 不適切なページ、ギャラリー、Playを通報できるように +- Fix: Play編集時に公開範囲が「パブリック」にリセットされる問題を修正 +- Fix: ページ遷移に失敗することがある問題を修正 +- Fix: iOSでユーザー名などがリンクとして誤検知される現象を抑制 +- Fix: mCaptchaを使用していてもbotプロテクションに関する警告が消えないのを修正 +- Fix: ユーザーのモデレーションページにおいてユーザー名にドットが入っているとシステムアカウントとして表示されてしまう問題を修正 +- Fix: 特定の条件下でノートの削除ボタンが出ないのを修正 + +### Server +- Enhance: 照会時にURLがhtmlかつheadタグ内に`rel="alternate"`, `type="application/activity+json"`の`link`タグがある場合に追ってリンク先を照会できるように +- Enhance: 凍結されたアカウントのフォローリクエストを表示しないように +- Fix: WSの`readAllNotifications` メッセージが `body` を持たない場合に動作しない問題 #14374 + - 通知ページや通知カラム(デッキ)を開いている状態において、新たに発生した通知が既読されない問題が修正されます。 + - これにより、プッシュ通知が有効な同条件下の環境において、プッシュ通知が常に発生してしまう問題も修正されます。 +- Fix: Play各種エンドポイントの返り値に`visibility`が含まれていない問題を修正 +- Fix: サーバー情報取得の際にモデレーター限定の情報が取得できないことがあるのを修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/582) +- Fix: 公開範囲がダイレクトのノートをユーザーアクティビティのチャート生成に使用しないように + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/679) +- Fix: ActivityPubのエンティティタイプ判定で不明なタイプを受け取った場合でも処理を継続するように + - キュー処理のつまりが改善される可能性があります +- Fix: リバーシの対局設定の変更が反映されないのを修正 +- Fix: 無制限にストリーミングのチャンネルに接続できる問題を修正 +- Fix: ベースロールのポリシーを変更した際にモデログに記録されないのを修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/700) +- Fix: Prevent memory leak from memory caches (#14310) +- Fix: More reliable memory cache eviction (#14311) + +## 2024.7.0 + +### Note +- デッキUIの新着ノートをサウンドで通知する機能の追加(v2024.5.0)に伴い、以前から動作しなくなっていたクライアント設定内の「アンテナ受信」「チャンネル通知」サウンドを削除しました。 +- Streaming APIにて入力が不正な場合にはそのメッセージを無視するようになりました。 #14251 + +### General +- Feat: 通報を受けた際、または解決した際に、予め登録した宛先に通知を飛ばせるように(mail or webhook) #13705 +- Feat: ユーザーのアイコン/バナーの変更可否をロールで設定可能に + - 変更不可となっていても、設定済みのものを解除してデフォルト画像に戻すことは出来ます +- Feat: ユーザ作成時にSystemWebhookを送信可能に #14281 +- Feat: メディアサイレンスを実装 #13842 + - メディアサイレンスされたサーバーに所属するアカウントによるファイルはすべてセンシティブとして扱われ、カスタム絵文字が使用できないようになります。 +- Enhance: 管理画面でアーカイブにしたお知らせを表示・編集できるように +- Fix: 配信停止したインスタンス一覧が見れなくなる問題を修正 +- Fix: Dockerコンテナの立ち上げ時に`pnpm`のインストールで固まることがある問題 +- Fix: デフォルトテーマに無効なテーマコードを入力するとUIが使用できなくなる問題を修正 +- 翻訳の更新 +- 依存関係の更新 + +### Client +- Feat: ユーザーページから「このユーザーのノートを検索」できるように (#14128) +- Feat: 検索ページはクエリを受け付けるようになりました (#14128) +- Enhance: 検索ページのUI改善 (#14128) +- Enhance: 内蔵APIドキュメントのデザイン・パフォーマンスを改善 +- Enhance: 非ログイン時に他サーバーに遷移するアクションを追加 +- Enhance: 非ログイン時のハイライトTLのデザインを改善 +- Enhance: フロントエンドのアクセシビリティ改善 + (Based on https://github.com/taiyme/misskey/pull/226) +- Enhance: サーバー情報ページ・お問い合わせページを改善 + (Cherry-picked from https://github.com/taiyme/misskey/pull/238) +- Enhance: AiScriptを0.19.0にアップデート +- Enhance: Allow negative delay for MFM animation elements (`tada`, `jelly`, `twitch`, `shake`, `spin`, `jump`, `bounce`, `rainbow`) +- Enhance: センシティブなメディアを開く際に確認ダイアログを出せるように +- Enhance: 検索(ノート/ユーザー)で `#` から始まる文字列を入力すると、そのハッシュタグのノート/ユーザー一覧ページが表示できるように +- Enhance: 検索(ノート/ユーザー)において、入力に空白が含まれている場合は照会を行わないように +- Enhance: 検索(ノート/ユーザー)において、照会を行うかどうか、ハッシュタグのノート/ユーザー一覧ページを表示するかどうかの確認ダイアログを出すように +- Enhance: 検索(ノート/ユーザー)で `@` から始まる文字列(`@user@host`など)を入力すると、そのユーザーを照会できるように +- Enhance: ドライブのファイル・フォルダをドラッグしなくても移動できるように + (Cherry-picked from https://github.com/nafu-at/misskey/commit/b89c2af6945c6a9f9f10e83f54d2bcf0f240b0b4, https://github.com/nafu-at/misskey/commit/8a7d710c6acb83f50c83f050bd1423c764d60a99) +- Enhance: デッキのアンテナ・リスト選択画面からそれぞれを新規作成できるように +- Enhance: ブラウザのコンテキストメニューを使用できるように +- Enhance: 連合の「連合中」,「購読中」,「配信中」に対してブロックしているサーバー、配信停止しているサーバーを含めないように +- Fix: `/about#federation` ページなどで各インスタンスのチャートが表示されなくなっていた問題を修正 +- Fix: ユーザーページの追加情報のラベルを投稿者のサーバーの絵文字で表示する (#13968) +- Fix: リバーシの対局を正しく共有できないことがある問題を修正 +- Fix: コントロールパネルでベースロールのポリシーを編集してもUI上では変更が反映されない問題を修正 +- Fix: アンテナの編集画面のボタンに隙間を追加 +- Fix: テーマプレビューが見れない問題を修正 +- Fix: ショートカットキーが連打できる問題を修正 + (Cherry-picked from https://github.com/taiyme/misskey/pull/234) +- Fix: MkSignin.vueのcredentialRequestからReactivityを削除(ProxyがPasskey認証処理に渡ることを避けるため) +- Fix: 「アニメーション画像を再生しない」がオンのときでもサーバーのバナー画像・背景画像がアニメーションしてしまう問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/574) +- Fix: Twitchの埋め込みが開けない問題を修正 +- Fix: 子メニューの高さがウィンドウからはみ出ることがある問題を修正 +- Fix: 個人宛てのダイアログ形式のお知らせが即時表示されない問題を修正 +- Fix: 一部の画像がセンシティブ指定されているときに画面に何も表示されないことがあるのを修正 +- Fix: リアクションしたユーザー一覧のユーザー名がはみ出る問題を修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/672) +- Fix: `/share`ページにおいて絵文字ピッカーを開くことができない問題を修正 +- Fix: deck uiの通知音が重なる問題 (#14029) +- Fix: ダイレクト投稿の"削除して編集"において、宛先が保持されていなかった問題を修正 +- Fix: 投稿フォームへのURL貼り付けによる引用が下書きに保存されていなかった問題を修正 +- Fix: "削除して編集"や下書きにおいて、リアクションの受け入れ設定が保持/保存されていなかった問題を修正 +- Fix: 照会に `#` から始まる文字列を入力してそのハッシュタグのページを表示する際、入力が `#` のみの場合に「指定されたURLに該当するページはありませんでした。」が表示されてしまう問題を修正 +- Fix: 照会に `@` から始まる文字列を入力してユーザーを照会する際、入力が `@` のみの場合に「問題が発生しました」が表示されてしまう問題を修正 +- Fix: 投稿フォームにノートのURLを貼り付けて"引用として添付"した場合、投稿文を空にすることによるRenote化が出来なかった問題を修正 +- Fix: フォロー中のユーザーに関する"TLに他の人への返信を含める"の設定が分かりづらい問題を修正 +- Fix: タイムラインページを開いた時、`TLに他の人への返信を含める`がオフのときに`ファイル付きのみ`をオンにできない問題を修正 +- Fix: deck uiでタイムラインを切り替えた際にTLの設定項目が更新されず、`TLに他の人への返信を含める`のトグルが表示されない問題を修正 +- Fix: ウィジェットのタイムライン選択欄に無効化されたタイムラインが表示される問題を修正 +- Fix: サウンドにドライブの音声を使用している際にドライブの音声が再生できなくなると設定が変更できなくなる問題を修正 + +### Server +- Feat: レートリミット制限に引っかかったときに`Retry-After`ヘッダーを返すように (#13949) +- Enhance: エンドポイント`clips/update`の必須項目を`clipId`のみに +- Enhance: エンドポイント`admin/roles/update`の必須項目を`roleId`のみに +- Enhance: エンドポイント`pages/update`の必須項目を`pageId`のみに +- Enhance: エンドポイント`gallery/posts/update`の必須項目を`postId`のみに +- Enhance: エンドポイント`i/webhook/update`の必須項目を`webhookId`のみに +- Enhance: エンドポイント`admin/ad/update`の必須項目を`id`のみに +- Enhance: `default.yml`内の`url`, `db.db`, `db.user`, `db.pass`を環境変数から読み込めるように +- Enhance: エンドポイント`api/meta`にプロパティ`noteSearchableScope`が増え、`string`値`local`または`global`を返却します +- Fix: チャート生成時にinstance.suspensionStateに置き換えられたinstance.isSuspendedが参照されてしまう問題を修正 +- Fix: ユーザーのフィードページのMFMをHTMLに展開するように (#14006) +- Fix: アンテナ・クリップ・リスト・ウェブフックがロールポリシーの上限より一つ多く作れてしまうのを修正 (#14036) +- Fix: notRespondingSinceが実装される前に不通になったインスタンスが自動的に配信停止にならない (#14059) +- Fix: FTT有効時、タイムライン用エンドポイントで`sinceId`にキャッシュ内最古のものより古いものを指定した場合に正しく結果が返ってこない問題を修正 +- Fix: 自分以外のクリップ内のノート個数が見えることがあるのを修正 +- Fix: 空文字列のリアクションはフォールバックされるように +- Fix: リノートにリアクションできないように +- Fix: ユーザー名の前後に空白文字列がある場合は省略するように +- Fix: プロフィール編集時に名前を空白文字列のみにできる問題を修正 +- Fix: ユーザ名のサジェスト時に表示される内容と順番を調整(以下の順番になります) #14149 + 1. フォロー中かつアクティブなユーザ + 2. フォロー中かつ非アクティブなユーザ + 3. フォローしていないアクティブなユーザ + 4. フォローしていない非アクティブなユーザ + + また、自分自身のアカウントもサジェストされるようになりました。 +- Fix: 一般ユーザーから見たユーザーのバッジの一覧に公開されていないものが含まれることがある問題を修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/652) +- Fix: ユーザーのリアクション一覧でミュート/ブロックが機能していなかった問題を修正 +- Fix: FTT有効時にリモートユーザーのノートがHTLにキャッシュされる問題を修正 +- Fix: 一部の通知がローカル上のリモートユーザーに対して行われていた問題を修正 +- Fix: エラーメッセージの誤字を修正 (#14213) +- Fix: ソーシャルタイムラインにローカルタイムラインに表示される自分へのリプライが表示されない問題を修正 +- Fix: リノートのミュートが適用されるまでに時間がかかることがある問題を修正 + (Cherry-picked from https://github.com/Type4ny-Project/Type4ny/commit/e9601029b52e0ad43d9131b555b614e56c84ebc1) +- Fix: Steaming APIが不正なデータを受けた場合の動作が不安定である問題 #14251 +- Fix: `users/search`において `@` から始まる文字列が与えられた際の処理が正しくなかった問題を修正 + - 名前や自己紹介に `@` から始まる文言が含まれるユーザーも検索できるようになります +- Fix: 一部のMisskey以外のソフトウェアからファイルを受け取れない問題 + (Cherry-picked from https://github.com/Secineralyr/misskey.dream/pull/73/commits/652eaff1e8aa00b890d71d2e1e52c263c1e67c76) + - NOTE: `drive_file`の`url`, `uri`, `src`の上限が512から1024に変更されます + Migrationではカラム定義の変更のみが行われます。 + サーバー管理者は各サーバーの必要に応じ`drive_file` `("uri")`に対するインデックスを張りなおすことでより安定しDBの探索が行われる可能性があります。詳細 は [GitHub](https://github.com/misskey-dev/misskey/pull/14323#issuecomment-2257562228)で確認可能です +- Fix: 自分のフォロワー限定投稿に対するリプライがホームタイムラインで見えないことが有る問題を修正 +- Fix: フォローしていないユーザによるフォロワー限定投稿に対するリプライがソーシャルタイムラインで表示されることがある問題を修正 +- Fix: ActivityPubのエンティティタイプ判定で不明なタイプを受け取った場合でも処理を継続するように + - キュー処理のつまりが改善される可能性があります + +### Misskey.js +- Feat: `/drive/files/create` のリクエストに対応(`multipart/form-data`に対応) +- Feat: `/admin/role/create` のロールポリシーの型を修正 + +## 2024.5.0 + +### Note +- コントロールパネル内にあるサマリープロキシの設定個所がセキュリティから全般へ変更となります。 +- 悪意のある第三者がリモートユーザーになりすましたアクティビティを受け取れてしまう問題を修正しました。詳しくは[GitHub security advisory](https://github.com/misskey-dev/misskey/security/advisories/GHSA-2vxv-pv3m-3wvj)をご覧ください。 +- 管理者向け権限 `read:admin:show-users` は `read:admin:show-user` に統合されました。必要に応じてAPIトークンを再発行してください。 + +### General +- Feat: エラートラッキングにSentryを使用できるようになりました +- Enhance: URLプレビューの有効化・無効化を設定できるように #13569 +- Enhance: アンテナでBotによるノートを除外できるように + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/545) +- Enhance: クリップのノート数を表示するように +- Enhance: コンディショナルロールの条件として以下を新たに追加 (#13667) + - 猫ユーザーか + - botユーザーか + - サスペンド済みユーザーか + - 鍵アカウントユーザーか + - 「アカウントを見つけやすくする」が有効なユーザーか +- Enhance: Goneを出さずに終了したサーバーへの配信停止を自動的に行うように + - もしそのようなサーバーからから配信が届いた場合には自動的に配信を再開します +- Enhance: 配信停止の理由を表示するように +- Enhance: サーバーのお問い合わせ先URLを設定できるようになりました +- Fix: Play作成時に設定した公開範囲が機能していない問題を修正 +- Fix: 正規化されていない状態のhashtagが連合されてきたhtmlに含まれているとhashtagが正しくhashtagに復元されない問題を修正 +- Fix: みつけるのアンケート欄にてチャンネルのアンケートが含まれてしまう問題を修正 + +### Client +- Feat: アップロードするファイルの名前をランダム文字列にできるように +- Feat: 個別のお知らせにリンクで飛べるように + (Based on https://github.com/MisskeyIO/misskey/pull/639) +- Enhance: 自分のノートの添付ファイルから直接ファイルの詳細ページに飛べるように +- Enhance: 広告がMisskeyと同一ドメインの場合はRouterで遷移するように +- Enhance: リアクション・いいねの総数を表示するように +- Enhance: リアクション受け入れが「いいねのみ」の場合はリアクション絵文字一覧を表示しないように +- Enhance: 設定>プラグインのページからプラグインの簡易的なログやエラーを見られるように + - 実装の都合により、プラグインは1つエラーを起こした時に即時停止するようになりました +- Enhance: ページのデザインを変更 +- Enhance: 2要素認証(ワンタイムパスワード)の入力欄を改善 +- Enhance: 「今日誕生日のフォロー中ユーザー」ウィジェットを手動でリロードできるように +- Enhance: 映像・音声の再生にブラウザのネイティブプレイヤーを使用できるように +- Enhance: 映像・音声の再生メニューに「再生速度」「ループ再生」「ピクチャインピクチャ」を追加 +- Enhance: 映像・音声の再生にキーボードショートカットが使えるように +- Enhance: ノートについているリアクションの「もっと!」から、リアクションの一覧を表示できるように +- Enhance: リプライにて引用がある場合テキストが空でもノートできるように + - 引用したいノートのURLをコピーしリプライ投稿画面にペーストして添付することで達成できます +- Enhance: フォローするかどうかの確認ダイアログを出せるように +- Enhance: Playを手動でリロードできるように +- Enhance: 通報のコメント内のリンクをクリックした際、ウィンドウで開くように +- Enhance: `Ui:C:postForm` および `Ui:C:postFormButton` に `localOnly` と `visibility` を設定できるように +- Enhance: AiScriptを0.18.0にバージョンアップ +- Enhance: 通常のノートでも、お気に入りに登録したチャンネルにリノートできるように +- Enhance: 長いテキストをペーストした際にテキストファイルとして添付するかどうかを選択できるように +- Enhance: 新着ノートをサウンドで通知する機能をdeck UIに追加しました +- Enhance: コントロールパネルのクイックアクションからファイルを照会できるように +- Enhance: コントロールパネルのクイックアクションから通常の照会を行えるように +- Fix: 一部のページ内リンクが正しく動作しない問題を修正 +- Fix: 周年の実績が閏年を考慮しない問題を修正 +- Fix: ローカルURLのプレビューポップアップが左上に表示される +- Fix: WebGL2をサポートしないブラウザで「季節に応じた画面の演出」が有効になっているとき、Misskeyが起動できなくなる問題を修正 + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/459) +- Fix: ページタイトルでローカルユーザーとリモートユーザーの区別がつかない問題を修正 + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/528) +- Fix: コードブロックのシンタックスハイライトで使用される定義ファイルをCDNから取得するように #13177 + - CDNから取得せずMisskey本体にバンドルする場合は`pacakges/frontend/vite.config.ts`を修正してください。 +- Fix: タイムゾーンによっては、「今日誕生日のフォロー中ユーザー」ウィジェットが正しく動作しない問題を修正 +- Fix: CWのみの引用リノートが詳細ページで純粋なリノートとして誤って扱われてしまう問題を修正 +- Fix: ノート詳細ページにおいてCW付き引用リノートのCWボタンのラベルに「引用」が含まれていない問題を修正 +- Fix: ダイアログの入力で字数制限に違反していてもEnterキーが押せてしまう問題を修正 +- Fix: ダイレクト投稿の宛先が保存されない問題を修正 +- Fix: Playのページを離れたときに、Playが正常に初期化されない問題を修正 +- Fix: ページのOGP URLが間違っているのを修正 +- Fix: リバーシの対局を正しく共有できないことがある問題を修正 +- Fix: 通知をグループ化している際に、人数が正常に表示されないことがある問題を修正 +- Fix: 連合なしの状態の読み書きができない問題を修正 +- Fix: `/share` で日本語等を含むurlがurlエンコードされない問題を修正 +- Fix: ファイルを5つ以上添付してもテキストがないとノートが折りたたまれない問題を修正 + +### Server +- Enhance: エンドポイント`antennas/update`の必須項目を`antennaId`のみに +- Enhance: misskey-dev/summaly@5.1.0の取り込み(プレビュー生成処理の効率化) +- Enhance: ドライブのファイルがNSFWかどうか個別に連合されるように (#13756) + - 可能な場合、ノートの添付ファイルのセンシティブ判定がファイル単位になります +- Fix: リモートから配送されたアクティビティにJSON-LD compactionをかける +- Fix: フォローリクエストを作成する際に既存のものは削除するように + (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/440) +- Fix: エンドポイント`notes/translate`のエラーを改善 +- Fix: CleanRemoteFilesProcessorService report progress from 100% (#13632) +- Fix: 一部の音声ファイルが映像ファイルとして扱われる問題を修正 +- Fix: リプライのみの引用リノートと、CWのみの引用リノートが純粋なリノートとして誤って扱われてしまう問題を修正 +- Fix: 登録にメール認証が必須になっている場合、登録されているメールアドレスを削除できないように + (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/606) +- Fix: Add Cache-Control to Bull Board +- Fix: nginx経由で/files/にRangeリクエストされた場合に正しく応答できないのを修正 +- Fix: 一部のタイムラインのストリーミングでインスタンスミュートが効かない問題を修正 +- Fix: グローバルタイムラインで返信が表示されないことがある問題を修正 +- Fix: リノートをミュートしたユーザの投稿のリノートがミュートされる問題を修正 +- Fix: AP Link等は添付ファイル扱いしないようになど (#13754) +- Fix: FTTが有効かつsinceIdのみを指定した場合に帰って来るレスポンスが逆順である問題を修正 +- Fix: `/i/notifications`に `includeTypes`か`excludeTypes`を指定しているとき、通知が存在するのに空配列を返すことがある問題を修正 +- Fix: 複数idを指定する`users/show`が関係ないユーザを返すことがある問題を修正 +- Fix: `/tags` と `/user-tags` が検索エンジンにインデックスされないように +- Fix: もともとセンシティブではないと連合されていたファイルがセンシティブとして連合された場合にセンシティブとしてそのファイルを扱うように + - センシティブとして連合したファイルは非センシティブとして連合されてもセンシティブとして扱われます + +## 2024.3.1 + +### General +- + +### Client +- Fix: 絵文字関係の不具合を修正 (#13485) + - 履歴に残っている or ピン留めされた絵文字がコントロールパネルより削除されていた際にリアクションデッキが表示できなくなる + - Unicode絵文字が履歴に残っている or ピン留めされているとリアクションデッキが表示できなくなる +- Fix: カスタム絵文字の画像読み込みに失敗した際はテキストではなくダミー画像を表示 #13487 + +### Server +- + +## 2024.3.0 + +### General +- Enhance: 投稿者のロールに応じて、一つのノートに含むことのできるメンションとダイレクト投稿の宛先の人数に上限を設定できるように + * デフォルトのメンション上限は20アカウントに設定されます。(管理者はベースロールの設定で変更可能です。) + * 連合の問い合わせに応答しないサーバーのリモートユーザーへのメンションは、上限の人数に含めない実装になっています。 +- Enhance: 通知がミュート、凍結を考慮するようになりました +- Enhance: サーバーごとにモデレーションノートを残せるように +- Enhance: コンディショナルロールの条件に「マニュアルロールへのアサイン」を追加 +- Enhance: 通知の受信設定に「フォロー中またはフォロワー」を追加 +- Enhance: 通知の履歴をリセットできるように +- Fix: ダイレクトなノートに対してはダイレクトでしか返信できないように + +### Client +- Enhance: ノート作成画面のファイル添付メニューの区切り線の位置を調整 +- Fix: syuilo/misskeyの時代からあるインスタンスが改変されたバージョンであると誤認識される問題 +- Fix: MFMのオートコンプリートが出るべき状況で出ないことがある問題を修正 +- Fix: チャートのラベルが消えている問題を修正 +- Fix: 画面表示後最初の音声再生が爆音になることがある問題を修正 +- Fix: 設定のバックアップ作成時に名前を入力しなかった場合、ローカライゼーションがおかしくなる問題を修正 +- Fix: ページ`/admin/emojis`の絵文字編集ダイアログで「リアクションとして使えるロール」を追加する際に何も選択せずOKを押下すると画面が固まる問題を修正 +- Fix: 絵文字サジェストの順位で、絵文字自体の名前が同じものよりもタグで一致しているものが優先されてしまう問題を修正 +- Fix: ユーザの情報のポップアップが消えなくなることがある問題を修正 + +### Server +- Enhance: エンドポイント`flash/update`の`flashId`以外のパラメータは必須ではなくなりました +- Fix: nodeinfoにenableMcaptchaとenableTurnstileが無いのを修正 +- Fix: 破損した通知をクライアントに送信しないように + * 通知欄が無限にリロードされる問題が改善する可能性があります +- Fix: 禁止キーワードを含むノートがDelayed Queueに追加されて再処理される問題を修正 +- Fix: 自分がフォローしていないアカウントのフォロワー限定ノートが閲覧できることがある問題を修正 +- Fix: タイムラインのオプションで「リノートを表示」を無効にしている際、投票のみの引用リノートが流れてこない問題を修正 +- Fix: エンドポイント`admin/emoji/update`の各種修正 + - 必須パラメータを`id`または`name`のいずれかのみに + - `id`の代わりに`name`で絵文字を指定可能に(`id`・`name`両指定時は従来通り`name`を変更する挙動) + - `category`および`licence`が指定なしの時勝手にnullに上書きされる挙動を修正 +- Fix: 通知の受信設定で「相互フォロー」が正しく動作しない問題を修正 + +## 2024.2.0 + +### Note +- 外部サイトからプラグインをインストールする場合のパスが`/install-extentions`から`/install-extensions`に変わります。以前のパスからは自動でリダイレクトされるようになっていますが、新しいパスに変更することをお勧めします。 + +### General +- Feat: [mCaptcha](https://github.com/mCaptcha/mCaptcha)のサポートを追加 +- Feat: Add support for TrueMail +- Feat: AGPLv3ライセンスに誤って違反するのを防止する機能を追加 + - 管理者がrepositoryUrlを変更したり、またはソースコードを直接頒布することを選択できるようになります + - 本体のソースコードに改変を加えた際に、ライセンスに基づく適切な案内を表示します +- Enhance: モデレーターはすべてのユーザーのリアクション一覧を見られるように +- Fix: リストライムラインの「リノートを表示」が正しく機能しない問題を修正 +- Fix: リモートユーザーのリアクション一覧がすべて見えてしまうのを修正 + * すべてのリモートユーザーのリアクション一覧を見えないようにします +- Fix: 特定のキーワード及び正規表現にマッチする文字列を含むノートが投稿された際、エラーに出来るような設定項目を追加 #13207 + * デフォルトは空欄なので適用前と同等の動作になります + +### Client +- Feat: 新しいゲームを追加 +- Feat: 音声・映像プレイヤーを追加 +- Feat: 絵文字の詳細ダイアログを追加 +- Feat: 枠線をつけるMFM`$[border.width=1,style=solid,color=fff,radius=0 ...]`を追加 + - デフォルトで枠線からはみ出る部分が隠されるようにしました。初期と同じ挙動にするには`$[border.noclip`が必要です +- Feat: スワイプでタブを切り替えられるように +- Enhance: MFM等のコードブロックに全文コピー用のボタンを追加 +- Enhance: ハッシュタグ入力時に、本文の末尾の行に何も書かれていない場合は新たにスペースを追加しないように +- Enhance: チャンネルノートのピン留めをノートのメニューからできるように +- Enhance: 管理者の場合はAPI tokenの発行画面で管理機能に関する権限を付与できるように +- Enhance: AiScriptを0.17.0に更新 [CHANGELOG](https://github.com/aiscript-dev/aiscript/blob/bb89d132b633a622d3cb0eff0d0cc7e476c0cfdd/CHANGELOG.md) + - 配列の範囲外・非整数のインデックスへの代入が完全禁止になるので注意 +- Enhance: 絵文字ピッカー・オートコンプリートで、完全一致した絵文字を優先的に表示するように +- Enhance: Playの説明欄にMFMを使えるように +- Enhance: チャンネルノートの場合は詳細ページからその前後のノートを見れるように +- Enhance: 季節に応じた画面の演出を南半球でも利用できるように +- Enhance: タイムラインフィルターの設定をすべて保持できるように + - 今までの「TLに他の人への返信を含める」設定は一旦リセットされます +- Enhance: タイムラインフィルターに「センシティブなファイルを含むノートを表示」を追加 +- Enhance: ノート作成画面のファイル添付メニューから直接ファイルを削除できるように +- Enhance: MFMの属性でオートコンプリートが使用できるように #12735 +- Enhance: 絵文字編集ダイアログをモーダルではなくウィンドウで表示するように +- Enhance: リモートのユーザーはメニューから直接リモートで表示できるように +- Enhance: リモートへの引用リノートと同一のリンクにはリンクプレビューを表示しないように +- Enhance: コードのシンタックスハイライトにテーマを適用できるように +- Enhance: リアクション権限がない場合、ハートにフォールバックするのではなくリアクションピッカーなどから打てないように + - リモートのユーザーにローカルのみのカスタム絵文字をリアクションしようとした場合 + - センシティブなリアクションを認めていないユーザーにセンシティブなカスタム絵文字をリアクションしようとした場合 + - ロールが必要な絵文字をリアクションしようとした場合 +- Enhance: ページ遷移時にPlayerを閉じるように +- Enhance: 通報ページのユーザをクリックした際にユーザをウィンドウで開くように +- Enhance: ノートの通報時にリモートのノートであっても自インスタンスにおけるノートのリンクを含むように +- Enhance: オフライン表示のデザインを改善・多言語対応 +- Fix: ネイティブモードの絵文字がモノクロにならないように +- Fix: v2023.12.0で追加された「モデレーターがユーザーのアイコンもしくはバナー画像を未設定状態にできる機能」が管理画面上で正しく表示されていない問題を修正 +- Fix: AiScriptの`readline`関数が不正な値を返すことがある問題のv2023.12.0時点での修正がPlay以外に適用されていないのを修正 +- Fix: v2023.12.1で追加された`$[clickable ...]`および`onClickEv`が正しく機能していないのを修正 +- Fix: Renoteのキーボードショートカットが機能していなかった問題を修正 +- Fix: 投稿フォームでアンケートの日時指定をした状態で再読み込みをすると期日が復元されない問題を修正 +- Fix: アンケートを設定したノートを「削除して編集」をするとアンケートの期日が引き継がれず、リセットされてしまう問題を修正 +- Fix: デッキのプロファイル作成時に名前を空にできる問題を修正 +- Fix: テーマ作成時に名称が空欄でも作成できてしまう問題を修正 +- Fix: プラグインで`Plugin:register_note_post_interruptor`を使用すると、ノートが投稿できなくなる問題を修正 +- Fix: iOSで大きな画像を変換してアップロードできない問題を修正 +- Fix: 「アニメーション画像を再生しない」もしくは「データセーバー(アイコン)」を有効にしていても、アイコンデコレーションのアニメーションが停止されない問題を修正 +- Fix: 画像をクロップするとクロップ後の解像度が異様に低くなる問題の修正 +- Fix: 画像をクロップ時、正常に完了できない問題の修正 +- Fix: キャプションが空の画像をクロップするとキャプションにnullという文字列が入ってしまう問題の修正 +- Fix: プロフィールを編集してもリロードするまで反映されない問題を修正 +- Fix: エラー画像URLを設定した後解除すると,デフォルトの画像が表示されない問題の修正 +- Fix: MkCodeEditorで行がずれていってしまう問題の修正 +- Fix: Summaly proxy利用時にプレイヤーが動作しないことがあるのを修正 #13196 + +### Server +- Enhance: 連合先のレートリミットを超過した際にリトライするようになりました +- Enhance: ActivityPub Deliver queueでBodyを事前処理するように (#12916) +- Enhance: クリップをエクスポートできるように +- Enhance: `/files`のファイルに対してHTTP Rangeリクエストを行えるように +- Enhance: `api.json`のOpenAPI Specificationを3.1.0に更新 +- Enhance: 連合向けのノート配信を軽量化 #13192 +- Fix: `drive/files/update`でファイル名のバリデーションが機能していない問題を修正 +- Fix: `notes/create`で、`text`が空白文字のみで構成されているか`null`であって、かつ`text`だけであるリクエストに対するレスポンスが400になるように変更 +- Fix: `notes/create`で、`text`が空白文字のみで構成されていてかつリノート、ファイルまたは投票を含んでいるリクエストに対するレスポンスの`text`が`""`から`null`になるように変更 +- Fix: ipv4とipv6の両方が利用可能な環境でallowedPrivateNetworksが設定されていた場合プライベートipの検証ができていなかった問題を修正 +- Fix: properly handle cc followers +- Fix: ジョブに関する設定の名前を修正 relashionshipJobPerSec -> relationshipJobPerSec +- Fix: コントロールパネル->モデレーション->「誰でも新規登録できるようにする」の初期値をONからOFFに変更 #13122 +- Fix: リモートユーザーが復活してもキャッシュにより該当ユーザーのActivityが受け入れられないのを修正 #13273 + +## 2023.12.2 + +### General +- v2023.12.1でDockerを利用してサーバーを起動できない問題を修正 + +### Client +- Enhance: 検索画面においてEnterキー押下で検索できるように + +## 2023.12.1 + +### Note +- アクセストークンの権限が再整理されたため、一部のAPIが古いAPIトークンでは動作しなくなりました。\ + 権限不足になる場合には権限を再設定して再生成してください。 + +### General +- Enhance: ローカリゼーションの更新 +- Fix: 自分のdirect noteがuser list timelineに追加されない + +### Client +- Feat: AiScript専用のMFM構文`$[clickable.ev=EVENTNAME ...]`を追加。`Mk:C:mfm`のオプション`onClickEv`に関数を渡すと、クリック時に`EVENTNAME`を引数にして呼び出す +- Enhance: MFM入力補助ボタンを投稿フォームに表示できるように #12787 +- Fix: 一部のモデログ(logYellowでの表示対象)について、表示の色が変わらない問題を修正 +- Fix: `fg`/`bg`MFMに長い単語を指定すると、オーバーフローされずはみ出る問題を修正 + +### Server +- Enhance: センシティブワードの設定がハッシュタグトレンドにも適用されるようになりました +- Enhance: `oauth/token`エンドポイントのCORS対応 +- Fix: 1702718871541-ffVisibility.jsのdownが壊れている +- Fix:「非センシティブのみ(リモートはいいねのみ)」を設定していても、センシティブに設定されたカスタム絵文字をリアクションできる問題を修正 +- Fix: ロールアサイン時の通知で,ロールアイコンが縮小されずに表示される問題を修正 +- Fix: サードパーティアプリケーションがWebsocket APIに無条件にアクセスできる問題を修正 +- Fix: サードパーティアプリケーションがユーザーの許可なしに非公開の情報を見ることができる問題を修正 + +## 2023.12.0 + +### Note +- 依存関係の更新に伴い、Node.js 20.10.0が最小要件になりました +- 絵文字の追加辞書を既にインストールしている場合は、お手数ですが再インストールのほどお願いします +- 絵文字ピッカーにピン留め表示する絵文字設定が「リアクション用」と「絵文字入力用」に分かれました。以前の設定は「リアクション用」として使用されます。 + + **影響:** + それにより、投稿フォームから表示される絵文字ピッカーのピン留め絵文字がリセットされたように感じるかもしれません(新設された"ピン留め(全般)"の設定が使われるため)。 + 投稿用のピン留め絵文字をアップデート前の状態にするには、以下の手順で操作します。 + + 1. 「設定」メニューに移動し、「絵文字ピッカー」タブを選択します。 + 2. 「ピン留 (全般)」のタブを選択します。 + 3. 「リアクション設定から上書きする」ボタンを押すことで、アップデート前の状態に戻すことができます。 + +### General +- Feat: メールアドレスの認証にverifymail.ioを使えるように (cherry-pick from https://github.com/TeamNijimiss/misskey/commit/971ba07a44550f68d2ba31c62066db2d43a0caed) +- Feat: モデレーターがユーザーのアイコンもしくはバナー画像を未設定状態にできる機能を追加 (cherry-pick from https://github.com/TeamNijimiss/misskey/commit/e0eb5a752f6e5616d6312bb7c9790302f9dbff83) +- Feat: TL上からノートが見えなくなるワードミュートであるハードミュートを追加 +- Enhance: 指定したドメインのメールアドレスの登録を弾くことができるように +- Enhance: 公開ロールにアサインされたときに通知が作成されるように +- Enhance: アイコンデコレーションを複数設定できるように +- Enhance: アイコンデコレーションの位置を微調整できるように +- Enhance: つながりの公開範囲をフォロー/フォロワーで個別に設定可能に #12072 +- Enhance: ローカリゼーションの更新 +- Enhance: 依存関係の更新 +- Fix: MFM `$[unixtime ]` に不正な値を入力した際に発生する各種エラーを修正 + +### Client +- Feat: 今日誕生日のフォロー中のユーザーを一覧表示できるウィジェットを追加 +- Feat: 画面に雪を降らせられるように +- Enhance: MFMのアニメーション要素(`tada`, `jelly`, `twitch`, `shake`, `spin`, `jump`, `bounce`, `rainbow`)に `delay` オプションを追加 +- Enhance: センシティブと判断されたウェブサイトのサムネイルを非表示に + - ウェブサイトをセンシティブと判断する仕組みが動いていないため、summalyProxyを使用しないと機能しません。 +- Enhance: 投稿フォームの絵文字ピッカーをリアクション時に使用するものと同じのを使用するように #12336 #12560 +- Enhance: リアクション用ピン留め絵文字と投稿時の絵文字入力用ピン留め絵文字を分けて設定できるように #12560 +- Enhance: 絵文字のオートコンプリート機能強化 #12364 +- Enhance: ユーザーのRawデータを表示するページが復活 +- Enhance: リアクション選択時に音を鳴らせるように +- Enhance: サウンドにドライブのファイルを使用できるように +- Enhance: ナビゲーションバーに項目「キャッシュを削除」を追加 +- Enhance: Shareページで投稿を完了すると、親ウィンドウ(親フレーム)にpostMessageするように +- Enhance: チャンネル、クリップ、ページ、Play、ギャラリーにURLのコピーボタンを設置 #11305 +- Enhance: ノートプレビューに「内容を隠す」が反映されるように +- Enhance: データセーバーでコードハイライトの読み込みを削減できるように +- Enhance: データセーバーの適用範囲を個別で設定できるように + - 従来のデータセーバーの設定はリセットされます +- Enhance: タイムライン上のタブからリスト、アンテナ、チャンネルの管理ページにジャンプできるように +- Enhance: ユーザー名、プロフィール、お知らせ、ページの編集画面でMFMや絵文字のオートコンプリートが使用できるように +- Enhance: プロフィール、お知らせの編集画面でMFMのプレビューを表示できるように +- Enhance: 絵文字の詳細ページに記載される情報を追加 +- Enhance: リアクションの表示幅制限を設定可能に +- Enhance: Unicode 15.0のサポート +- Enhance: コードブロックのハイライト機能を利用するには言語を明示的に指定させるように + - MFMでコードブロックを利用する際に意図しないハイライトが起こらないようになりました + - 逆に、MFMでコードハイライトを利用したい際は言語を明示的に指定する必要があります + (例: ` ```js ` → Javascript, ` ```ais ` → AiScript) +- Enhance: 絵文字などのオートコンプリートでShift+Tabを押すと前の候補を選択できるように +- Enhance: チャンネルに新規の投稿がある場合にバッジを表示させる +- Enhance: サウンド設定に「サウンドを出力しない」と「Misskeyがアクティブな時のみサウンドを出力する」を追加 +- Enhance: 設定したタグをトレンドに表示させないようにする項目を管理画面で設定できるように +- Enhance: 絵文字ピッカーのカテゴリに「/」を入れることでフォルダ分け表示できるように +- Fix: 「設定のバックアップ」で一部の項目がバックアップに含まれていなかった問題を修正 +- Fix: ウィジェットのジョブキューにて音声の発音方法変更に追従できていなかったのを修正 #12367 +- Fix: コードエディタが正しく表示されない問題を修正 +- Fix: プロフィールの「ファイル」にセンシティブな画像がある際のデザインを修正 +- Fix: 一度に大量の通知が入った際に通知音が音割れする問題を修正 +- Fix: 共有機能をサポートしていないブラウザの場合は共有ボタンを非表示にする #11305 +- Fix: 通知のグルーピング設定を変更してもリロードされるまで表示が変わらない問題を修正 #12470 +- Fix: 長い名前のチャンネルにおける投稿フォームの表示が崩れる問題を修正 +- Fix: セキュリティ向上のためAiScriptの`Mk:apiExternal`を無効化 +- Fix: ノート中の絵文字をタップして「リアクションする」からリアクションした際にリアクションサウンドが鳴らない不具合を修正 +- Fix: ノート中のリアクションの表示を微調整 #12650 +- Fix: AiScriptの`readline`が不正な値を返すことがある問題を修正 +- Fix: 投票のみ/画像のみの引用RNが、通知欄でただのRNとして判定されるバグを修正 +- Fix: CWをつけて引用RNしても、普通のRNとして扱われてしまうバグを修正しました。 +- Fix: 「画像が1枚のみのメディアリストの高さ」を「デフォルト」以外に設定していると、CWの中などに添付された画像が見られないバグを修正 +- Fix: DeepL TranslationのPro accountトグルスイッチが表示されていなかったのを修正 +- Fix: twitterの埋め込みカード内リンクからリンク先を開けない問題を修正 +- Fix: WebKitブラウザー上でも「デバイスの画面を常にオンにする」機能が効くように +- Fix: ページ一覧ページの表示がモバイル環境において崩れているのを修正 +- Fix: MFMでルビの中のテキストがnyaizeされない問題を修正 + +### Server +- Enhance: MFM `$[ruby ]` が他ソフトウェアと連合されるように +- Enhance: Meilisearchを有効にした検索で、ユーザーのミュートやブロックを考慮するように +- Enhance: カスタム絵文字のインポート時の動作を改善 +- Enhance: json-schema(OpenAPIの戻り値として使用されるスキーマ定義)を出来る限り最新化 #12311 +- Fix: 時間経過により無効化されたアンテナを再有効化したとき、サーバ再起動までその状況が反映されないのを修正 #12303 +- Fix: ロールタイムラインが保存されない問題を修正 +- Fix: api.jsonの生成ロジックを改善 #12402 +- Fix: 招待コードが使い回せる問題を修正 +- Fix: 特定の条件下でチャンネルやユーザーのノート一覧に最新のノートが表示されなくなる問題を修正 +- Fix: 何もノートしていないユーザーのフィードにアクセスするとエラーになる問題を修正 +- Fix: リストタイムラインにてミュートが機能しないケースがある問題と、チャンネル投稿がストリーミングで流れてきてしまう問題を修正 #10443 +- Fix: 「みつける」のなかにミュートしたユーザが現れてしまう問題を修正 #12383 +- Fix: Social/Local/Home Timelineにてインスタンスミュートが効かない問題 +- Fix: ユーザのノート一覧にてインスタンスミュートが効かない問題 +- Fix: チャンネルのノート一覧にてインスタンスミュートが効かない問題 +- Fix: 「みつける」が年越し時に壊れる問題を修正 +- Fix: アカウントをブロックした際に、自身のユーザーのページでノートが相手に表示される問題を修正 +- Fix: モデレーションログがモデレーターは閲覧できないように修正 +- Fix: ハッシュタグのトレンド除外設定が即時に効果を持つように修正 +- Fix: HTTP Digestヘッダのアルゴリズム部分に大文字の"SHA-256"しか使えない + +## 2023.11.1 + +### Note +- 悪意のある第三者がリモートユーザーになりすました任意のアクティビティを受け取れてしまう問題を修正しました。詳しくは[GitHub security advisory](https://github.com/misskey-dev/misskey/security/advisories/GHSA-3f39-6537-3cgc)をご覧ください。 + +### General +- Feat: 管理者がコントロールパネルからメールアドレスの照会を行えるようになりました +- Enhance: ローカリゼーションの更新 +- Enhance: 依存関係の更新 + +### Client +- Enhance: MFMでルビを振れるように + - 例: `$[ruby 三須木 みすき]` +- Enhance: MFMでUNIX時間を指定して日時を表示できるように + - 例: `$[unixtime 1701356400]` +- Enhance: プラグインでエラーが発生した場合のハンドリングを強化 +- Enhance: 細かなUIのブラッシュアップ +- Fix: 効果音が再生されるとデバイスで再生している動画や音声が停止する問題を修正 #12339 +- Fix: デッキに表示されたチャンネルの表示先チャンネルを切り替えた際、即座に反映されない問題を修正 #12236 +- Fix: プラグインでノートの表示を書き換えられない問題を修正 +- Fix: アイコンデコレーションが見切れる場合がある問題を修正 +- Fix: 「フォロー中の人全員の返信を含める/含めないようにする」のボタンを押下した際の確認が機能していない問題を修正 +- Fix: 非ログイン時に「メモを追加」を表示しないように変更 #12309 +- Fix: 絵文字ピッカーでの検索が更新されない問題を修正 +- Fix: 特定の条件下でノートがnyaizeされない問題を修正 + +### Server +- Enhance: FTTのデータベースへのフォールバック処理を行うかどうかを設定可能に +- Fix: トークンのないプラグインをアンインストールするときにエラーが出ないように +- Fix: 投稿通知がオンでもダイレクト投稿はユーザーに通知されないようにされました +- Fix: ユーザタイムラインの「ノート」選択時にリノートが混ざり込んでしまうことがある問題の修正 #12306 +- Fix: LTLに特定条件下にてチャンネルへの投稿が混ざり込む現象を修正 +- Fix: ActivityPub: 追加情報のカスタム絵文字がユーザー情報のtagに含まれない問題を修正 +- Fix: ActivityPubに関するセキュリティの向上 +- Fix: 非公開の投稿に対して返信できないように + +## 2023.11.0 + +### Note +- iOS 16.4未満を使用している場合はiOS 16.4以上にアップデートをお願いします + +### General +- Feat: アイコンデコレーション機能 + - サーバーで用意された画像をアイコンに重ねることができます + - 画像のテンプレートはこちらです: https://misskey-hub.net/brand-assets/ + - 最大でも黄色いエリア内にデコレーションを収めることを推奨します。 + - 画像は512x512pxを推奨します。 +- Feat: チャンネル設定にリノート/引用リノートの可否を設定できる項目を追加 +- Enhance: アカウント登録時のメールアドレス認証に30分の有効期限を設定 + - 有効期限が切れた後であれば、登録時に使用した招待コードを再度利用できるように変更しました。 + - ユーザーが誤ったメールアドレスを入力した場合に招待コードが失効してしまう問題が解消されます。 +- Enhance: すでにフォローしたすべての人の返信をTLに追加できるように +- Enhance: 未読の通知数を表示できるように +- Enhance: 通知されず、確認の必要もないお知らせ(silence)を作成可能になりました +- Enhance: ローカリゼーションの更新 +- Enhance: 依存関係の更新 +- Change: CWを使用する場合、注釈を空にすることは許可されなくなりました + +### Client +- Feat: プラグイン・テーマを外部サイトから直接インストールできるようになりました + - 外部サイトでの実装が必要です。詳細は Misskey Hub をご覧ください + https://misskey-hub.net/docs/for-developers/publish-on-your-website/ +- Feat: 通知をグルーピングして表示するオプション(オプトアウト) +- Feat: Misskeyの基本的なチュートリアルを実装 +- Feat: スワイプしてタイムラインを再読込できるように + - PCの場合は右上のボタンからでも再読込できます +- Enhance: タイムラインの自動更新を無効にできるように +- Enhance: コードのシンタックスハイライトエンジンをShikiに変更 + - AiScriptのシンタックスハイライトに対応 + - MFMでAiScriptをハイライトする場合、コードブロックの開始部分を ` ```is ` もしくは ` ```aiscript ` としてください +- Enhance: データセーバー有効時はアニメーション付きのアバター画像が停止するように +- Enhance: プラグインを削除した際には、使用されていたアクセストークンも同時に削除されるようになりました +- Enhance: プラグインで`Plugin:register_note_view_interruptor`を用いてnoteの代わりにnullを返却することでノートを非表示にできるようになりました +- Enhance: AiScript関数`Mk:nyaize()`が追加されました +- Enhance: 情報→ツール はナビゲーションバーにツールとして独立した項目になりました +- Enhance: ノート内の絵文字をクリックすることで、コピーおよびリアクションができるように +- Enhance: その他細かなブラッシュアップ +- Fix: 投稿フォームでのユーザー変更がプレビューに反映されない問題を修正 +- Fix: ユーザーページの ノート > ファイル付き タブにリプライが表示されてしまう +- Fix: 「検索」MFMにおいて一部の検索キーワードが正しく認識されない問題を修正 +- Fix: 一部の言語でMisskey Webがクラッシュする問題を修正 +- Fix: チャンネルの作成・更新時に失敗した場合何も表示されない問題を修正 #11983 +- Fix: 個人カードのemojiがバッテリーになっている問題を修正 +- Fix: 標準テーマと同じIDを使用してインストールできてしまう問題を修正 +- Fix: 絵文字ピッカーでバッテリーの絵文字が複数表示される問題を修正 #12197 +- Fix: 11以上されているリアクションにおいてツールチップで示されるリアクション数が本来よりも1多い問題を修正 #12174 +- Fix: サイレンス状態で公開範囲のパブリックを選択できてしまう問題を修正 #12224 +- Fix: In deck layout, replies option is not saved after refresh +- Fix: アーカイブしたお知らせがコントロールパネルに表示される問題を修正 +- Note: アップデート後、サウンドに関する設定が初期化されます + +### Server +- Feat: Registry APIがサードパーティから利用可能になりました +- Enhance: RedisへのTLのキャッシュ(FTT)をオフにできるように +- Enhance: フォローしているチャンネルをフォロー解除した時(またはその逆)、タイムラインに反映される間隔を改善 +- Enhance: プロフィールの自己紹介欄のMFMが連合するようになりました + - 相手がMisskey v2023.11.0以降である必要があります +- Enhance: チャンネル取得時のパフォーマンスを向上 +- Enhance: AP: ApplicationタイプのアカウントをisBotとして扱うように +- Fix: リストTLに自分のフォロワー限定投稿が含まれない問題を修正 +- Fix: ローカルタイムラインに投稿者自身の投稿への返信が含まれない問題を修正 +- Fix: 自分のフォローしているユーザーの自分のフォローしていないユーザーの visibility: followers な投稿への返信がストリーミングで流れてくる問題を修正 +- Fix: RedisへのTLキャッシュが有効の場合にHTL/LTL/STLが空になることがある問題を修正 +- Fix: STLでフォローしていないチャンネルが取得される問題を修正 +- Fix: `hashtags/trend`にてRedisからトレンドの情報が取得できない際にInternal Server Errorになる問題を修正 +- Fix: HTLをリロードまたは遡行したとき、フォローしているチャンネルのノートが含まれない問題を修正 #11765 #12181 +- Fix: リノートをリノートできるのを修正 +- Fix: アクセストークンを削除すると、通知が取得できなくなる場合がある問題を修正 +- Fix: 自身の宛先なしダイレクト投稿がストリーミングで流れてこない問題を修正 +- Fix: サーバーサイドからのテスト通知を正しく行えるように修正 +- Fix: GTLの「リノートを表示」オプションが機能しないのを修正 #12233 + +## 2023.10.2 + +### General +- Feat: アンテナでローカルの投稿のみ収集できるようになりました +- Feat: サーバーサイレンス機能が追加されました +- Enhance: 新規にフォローした人の返信をデフォルトでTLに追加できるオプションを追加 +- Enhance: HTL/LTL/STLを2023.10.0アップデート以前まで遡れるように +- Enhance: フォロー/フォロー解除したときに過去分のHTLにも含まれる投稿が反映されるように +- Enhance: ローカリゼーションの更新 +- Enhance: 依存関係の更新 + +### Client +- Enhance: TLの返信表示オプションを記憶するように +- Enhance: 投稿されてから時間が経過しているノートであることを視覚的に分かりやすく + +### Server +- Enhance: タイムライン取得時のパフォーマンスを向上 +- Enhance: ストリーミングAPIのパフォーマンスを向上 +- Fix: users/notesでDBから参照した際にチャンネル投稿のみ取得される問題を修正 +- Fix: コントロールパネルの設定項目が正しく保存できない問題を修正 +- Fix: 管理者権限のロールを持っていても一部のAPIが使用できないことがある問題を修正 +- Change: ユーザーのisCatがtrueでも、サーバーではnyaizeが行われなくなりました + - isCatな場合、クライアントでnyaize処理を行うことを推奨します + +## 2023.10.1 +### General +- Enhance: ローカルタイムライン、ソーシャルタイムラインで返信を含むかどうか設定可能に + +### Client +- Fix: 絵文字ピッカーで横に長いカスタム絵文字が見切れる問題を修正 + +### Server +- Fix: フォローしているユーザーからの自分の投稿への返信がタイムラインに含まれない問題を修正 +- Fix: users/notesでセンシティブチャンネルの投稿が含まれる場合がある問題を修正 + +## 2023.10.0 +### NOTE +- 2023.9.2で導入されたノート編集機能はクオリティの高い実装が困難であることが判明したため撤回されました +- アップデートを行うと、タイムラインが一時的にリセットされます + - アンテナ内のノートも含む +- ソフトミュート設定はクライアントではなくサーバー側に保存されるようになったため、アップデートを行うとソフトミュートの設定がリセットされます + +### Changes +- API: users/notes, notes/local-timeline で fileType 指定はできなくなりました +- API: notes/featured でページネーションは他APIと同様 untilId を使って行うようになりました + +### General +- Feat: ユーザーごとに他ユーザーへの返信をタイムラインに含めるか設定可能になりました +- Feat: ユーザーリスト内のメンバーごとに他ユーザーへの返信をユーザーリストタイムラインに含めるか設定可能になりました +- Feat: ユーザーごとのハイライト +- Feat: プライバシーポリシー・運営者情報(Impressum)の指定が可能になりました + - プライバシーポリシーはサーバー登録時に同意確認が入ります +- Feat: タイムラインがリアルタイム更新中に広告を挿入できるようになりました + - デフォルトは無効 + - 頻度はコントロールパネルから設定できます。運営中のサーバーのTLの流速を見て、最適な値を指定してください。 +- Enhance: ソフトワードミュートとハードワードミュートは統合されました +- Enhance: モデレーションログ機能の強化 +- Enhance: ローカリゼーションの更新 +- Enhance: 依存関係の更新 +- Fix: ダイレクト投稿をリノートできてしまう問題を修正 +- Fix: ユーザーリストTLにチャンネル投稿が含まれる問題を修正 + +### Client +- Feat: 「ファイルの詳細」ページを追加 + - ドライブのファイルの拡大プレビューができるように + - ファイルが添付されたノートの一覧が表示できるように +- Enhance: 二要素認証のバックアップコード一覧をテキストファイルでダウンロード可能に +- Enhance: 動画再生時のデフォルトボリュームを30%に +- Fix: リアクションしたユーザ一覧のUIが稀に左上に残ってしまう不具合を修正 + +### Server +- Enhance: drive/files/attached-notes がページネーションに対応しました +- Enhance: タイムライン取得時のパフォーマンスを大幅に向上 +- Enhance: ハイライト取得時のパフォーマンスを大幅に向上 +- Enhance: トレンドハッシュタグ取得時のパフォーマンスを大幅に向上 +- Enhance: WebSocket接続が多い場合のパフォーマンスを向上 +- Enhance: 不要なPostgreSQLのインデックスを削除しパフォーマンスを向上 +- Fix: 連合なしアンケートに投票をするとUpdateがリモートに配信されてしまうのを修正 +- Fix: nodeinfoにおいてCORS用のヘッダーが設定されていないのを修正 +- Fix: 同じ種類のTLのストリーミングを複数接続できない問題を修正 +- Fix: アンテナTLを途中までしかページネーションできなくなることがある問題を修正 +- Fix: 「ファイル付きのみ」のTLでファイル無しの新着ノートが流れる問題を修正 +- Fix: プロセスが終了しない、あるいは非常に時間がかかる問題を修正 + +## 2023.9.3 +### General +- Enhance: ノートの翻訳機能の利用可否をロールで設定可能に + +### Client +- Enhance: AiScriptでホストのアドレスを参照する定数`SERVER_URL`を追加 +- Enhance: モデレーションログ機能の強化 +- Enhance: ローカリゼーションの更新 + +### Server +- Fix: Redisに古いバージョンのキャッシュが残っている場合、キャッシュが消えるまでの間通知が届かなくなる問題を修正 +- Fix: 後方互換性の修正 + +## 2023.9.2 + +### General +- Feat: ノートの編集をできるように + - ロールで編集可否を設定可能 +- Feat: 通知を種類ごとに 全員から受け取る/フォロー中のユーザーのみ受け取る/フォロワーのみ受け取る/相互のみ受け取る/指定したリストのメンバーのみ受け取る/受け取らない から選べるように +- Enhance: タイムラインからRenoteを除外するオプションを追加 +- Enhance: ユーザーページのノート一覧でRenoteを除外できるように +- Enhance: タイムラインでファイルが添付されたノートのみ表示するオプションを追加 +- Enhance: モデレーションログ機能の強化 +- Enhance: 依存関係の更新 +- Enhance: ローカリゼーションの更新 + +### Client +- Enhance: Plugin:register_post_form_actionを用いてCWを取得・変更できるように +- Enhance: admin/ad/listにて掲載中の広告が絞り込めるように +- Enhance: AiScriptにリモートサーバーのAPIを叩く用の関数を追加(`Mk:apiExternal`) + +### Server +- Enhance: MasterプロセスのPIDを書き出せるように +- Enhance: admin/ad/createにてレスポンス200、設定した広告情報を返すように + +## 2023.9.1 + +### General +- Enhance: モデレーションログ機能の強化 + +### Client +- Fix: ノートのメニューにある「詳細」ボタンの表示がログイン/ログアウト状態で統一されていない問題を修正 + +### Server +- Fix: お知らせのページネーションが機能しない +- Fix: 「ユーザーの新規投稿」の通知設定を切り替えるとサーバー内部エラーが出る + +## 2023.9.0 + +### Note +- meilisearchを使用する場合、v1.2以上が必要です + +### General +- Feat: OAuth 2.0のサポート +- Feat: お知らせ機能の強化 + - ユーザー個別のお知らせを作成可能に + - お知らせのバナー表示やダイアログ表示が可能に + - お知らせのアイコンを設定可能に +- Feat: チャンネルをセンシティブ指定できるようになりました + - センシティブチャンネルのNoteのReNoteはデフォルトでHome TLに流れるようになりました + - センシティブチャンネルのノートはユーザープロフィールに表示されません +- Feat: 二要素認証のバックアップコードが生成されるようになりました + - ref. https://github.com/MisskeyIO/misskey/pull/121 +- Feat: 二要素認証でパスキーをサポートするようになりました +- Feat: 指定したユーザーが投稿したときに通知できるようになりました +- Feat: プロフィールでのリンク検証 +- Feat: モデレーションログ機能 +- Feat: 通知をテストできるようになりました +- Feat: PWAのアイコンが設定できるようになりました +- Enhance: サーバー名の略称が設定できるようになりました +- Enhance: アンテナの受信ソースに指定したユーザを除外するものを追加 +- Enhance: 二要素認証設定時のセキュリティを強化 + - パスワード入力が必要な操作を行う際、二要素認証が有効であれば確認コードの入力も必要になりました +- Enhance: manifest.jsonをオーバーライド可能に +- Enhance: 依存関係の更新 +- Enhance: ローカリゼーションの更新 + +### Client +- Feat: 任意のユーザーリストをタイムラインページにピン留めできるように + - 設定->クライアント設定->全般 から設定可能です +- Feat: Playで直接投稿フォームを埋め込めるように(`Ui:C:postForm`) +- Feat: クライアントを起動している間、デバイスの画面が自動でオフになるのを防ぐオプションを追加 +- Feat: 新しい実績を追加 +- Enhance: ノート詳細ページでリノート一覧、リアクション一覧タブを追加 + - ノートのメニューからは当該項目は消えました +- Enhance: センシティブなメディアを目立たせる設定を追加 +- Enhance: プロフィールにその人が作ったPlayの一覧出せるように +- Enhance: メニューのスイッチの動作を改善 +- Enhance: 絵文字ピッカーの検索の表示件数を100件に増加 +- Enhance: 投稿フォームのプレビューの表示状態を記憶するように +- Enhance: ユーザーメニューでスイッチでユーザーリストに追加・削除できるように +- Enhance: 自分が押したリアクションのデザインを改善 +- Enhance: ノート検索にローカルのみ検索可能なオプションの追加 +- Enhance: Renote自体を通報できるように +- Enhance: データセーバーモードの強化 +- Enhance: Renoteを管理者権限で削除可能に +- Enhance: `$[rainbow ]`記法が、動きのあるMFMが無効になっていても使用できるようになりました +- Enhance: Playの操作を行うAPI TokenをAPIコンソールから発行できるように +- Enhance: リアクションの表示サイズをより大きくできるように +- Enhance: AiScriptを0.16.0に更新 +- Enhance: AiScriptからMisskeyサーバーAPIを呼び出す際の制限を撤廃 +- Enhance: AiScriptで`LOCALE`として現在の設定言語を取得できるように +- Enhance: Mk:apiが失敗した時にエラー型の値(AiScript 0.16.0で追加)を返すように +- Enhance: ScratchpadでAsync:系関数やボタンのコールバックなどのエラーにもダイアログを出すように(試験的なためPlayなどには未実装) +- Enhance: ノート詳細ページ読み込み時のパフォーマンスが向上しました +- Enhance: タイムラインでリスト/アンテナ選択時のパフォーマンスを改善 +- Enhance: 「Moderation note」、「Add moderation note」をローカライズできるように +- Enhance: プラグインのソースコードを確認・コピーできるように +- Enhance: 細かなデザインの調整 +- Fix: サーバー情報画面(`/instance-info/{domain}`)でブロックができないのを修正 +- Fix: 未読のお知らせの「わかった」をクリック・タップしてもその場で「わかった」が消えない問題を修正 +- Fix: iOSで画面を回転させるとテキストサイズが変わる問題を修正 +- Fix: word mute for sub note is not applied +- Fix: タイムラインを下にスクロールしてノート画面に移動して再び戻ったら以前のスクロール位置を失う問題を修正 +- Fix: Misskeyプラグインをインストールする際のAiScriptバージョンのチェックが0.14.0以降に対応していない問題を修正 +- Fix: 他のサーバーのユーザーへ「メッセージを送信」した時の初期テキストのメンションが間違っている問題を修正 +- Fix: 環境によってはMisskey Webが開けない問題を修正 +- Fix: プラグインの権限リストが見れない問題を修正 +- Fix: 複数の階層があるメニューで、短くタップすると正常に動かない場合がある問題を修正 +- Fix: アニメーションがオフのとき、スマホで子メニューの選択ができない問題を修正 +- Fix: ドロワーメニューで、親メニュー項目をマウスでホバーすると子メニューが表示されてしまう問題を修正 +- Fix: AiScriptでMk:apiが外部と通信できる問題を修正 + +### Server +- Change: cacheRemoteFilesの初期値はfalseになりました +- Enhance: ファイルアップロード時等にファイル名の拡張子を修正する関数(correctFilename)の挙動を改善 +- Enhance: Webhookのペイロードにサーバーのurlが含まれるようになりました +- Enhance: Webhook設定でsecretを空に出来るように +- Enhance: 使われていないアンテナの自動停止を設定可能に +- Enhance: nodeinfo 2.1対応 +- Enhance: 自分へのメンション一覧を取得する際のパフォーマンスを向上 +- Enhance: Docker環境でjemallocを使用することでメモリ使用量を削減 +- Enhance: ID生成方式としてaidxを追加、かつデフォルトに +- Enhance: Add address bind config option (outgoingAddress) +- Fix: MK_ONLY_SERVERオプションを指定した際にクラッシュする問題を修正 +- Fix: notes/reactionsのページネーションが機能しない問題を修正 +- Fix: ノート検索 `notes/search` にてhostを指定した際に検索結果に反映されるように +- Fix: 一部のfeatured noteを照会できない問題を修正 +- Fix: muteがapiからのuser list timeline取得で機能しない問題を修正 +- Fix: ジョブキュー管理画面の認証を回避できる問題を修正 +- Fix: 一部のサーバー内部エラーがスタックトレースを返さないように修正 +- Fix: 一部のリモートユーザーをフォローすることができない問題を修正 + +## 13.14.2 + +### Client +- リストTLで、ユーザーが追加・削除されてもTLを初期化しないように +- URL取得変数を関数に変更 CURRENT_URL -> Mk:url() +- Fix: モバイル表示のときページ下部がナビゲーションバーに隠れる問題を修正 +- Fix: 一部モーダルダイアログでスクロールできない問題を修正 +- Fix: Selecting all emojis in Custom emoji is impossible +- Fix: PhotoSwipeによるメモリリークの修正 + +### Server +- Fix: APIのオフセットが壊れていたせいで「もっと見る」でもっと見れない問題を修正 +- Fix: 外部サーバーの投稿がタイムラインに表示されないことがある問題を修正 + +## 13.14.1 + +### General +- 招待機能を改善しました + * 過去に発行した招待コードを確認できるようになりました + * ロールごとに招待コードの発行数制限と制限対象期間、有効期限を設定できるようになりました + * 招待コードを作成したユーザーと使用したユーザーを確認できるようになりました +- ユーザーにロールが期限付きでアサインされている場合、その期限をユーザーのモデレーションページで確認できるようになりました +- identicon生成を無効にしてパフォーマンスを向上させることができるようになりました +- サーバーのマシン情報の公開を無効にしてパフォーマンスを向上させることができるようになりました + +### Client +- deck UIのカラムのメニューからアンテナとリストの編集画面を開けるように +- ドライブファイルのメニューで画像をクロップできるように +- 画像を動画と同様に簡単に隠せるように +- Enhance: ノートの埋め込みが複数画像と動画を表示されるように +- オリジナル画像を保持せずにアップロードする場合webpでアップロードされるように(Safari以外) +- 見たことのあるRenoteを省略して表示をオンのときに自分のnoteのrenoteを省略するように +- フォルダーやファイルに対しても開発者モード使用時、IDをコピーできるように +- 引用対象を「もっと見る」で展開した場合、「閉じる」で畳めるように +- プロフィールURLをコピーできるボタンを追加 #11190 +- `CURRENT_URL`で現在表示中のURLを取得できるように(AiScript) +- ユーザーのContextMenuに「アンテナに追加」ボタンを追加 +- フォローやお気に入り登録をしていないチャンネルを開く時は概要ページを開くように +- 画面ビューワをタップした場合、マウスクリックと同様に画像ビューワを閉じるように +- オフライン時の画面にリロードボタンを追加 +- Renote時に公開範囲のデフォルト設定が適用されるように +- Deckで非ルートページにアクセスした際に簡易UIで表示しない設定を追加 +- ロール設定画面でロールIDを確認できるように +- コンテキストメニュー表示時のパフォーマンスを改善 +- フォロー/フォロワー非公開時の表示を改善 +- 本文にMFMが含まれている場合に自動でたたまれる機能が、返信先や引用RNにも適用されるように + - position は対象外になりました +- AiScriptを0.15.0に更新 +- Fix: サーバーメトリクスが90度傾いている +- Fix: 非ログイン時にクレデンシャルが必要なページに行くとエラーが出る問題を修正 +- Fix: sparkle内にリンクを入れるとクリック不能になる問題の修正 +- Fix: ZenUIでポップアップの表示位置がおかしい問題を修正 +- Fix: ページ遷移でスクロール位置が保持されない問題を修正 +- Fix: フォルダーのページネーションが機能しない #11180 +- Fix: 長い文章を投稿する際、プレビューが画面からはみ出る問題を修正 +- Fix: システムフォント設定が正しく反映されない問題を修正 +- Fix: アンケート終了時のプッシュ通知が正しく表示されない問題を修正 +- Fix: MasterVolumeが0の時だけでなく各通知音の音量設定が0のときも、HTMLAudioElement.playが実行されないように変更 + +### Server +- JSON.parse の回数を削減することで、ストリーミングのパフォーマンスを向上しました +- nsfwjs のモデルロードを排他することで、重複ロードによってメモリ使用量が増加しないように +- 連合の配送ジョブのパフォーマンスを向上(ロック機構の見直し、Redisキャッシュの活用) +- featuredノートのsignedGet回数を減らしました +- ActivityPubの署名用鍵長を2048bitに変更しパフォーマンスを向上(新規アカウントのみ) +- リモートサーバーのセンシティブなファイルのキャッシュだけを無効化できるオプションを追加 +- MeilisearchにIndexするノートの範囲を設定できるように +- Export notes with file detail +- Add unix socket support +- 設定ファイルでioredisの全てのオプションを指定可能に +- Fix: エクスポートしたカスタム絵文字のzipが大きいと読み込めない問題を修正 +- Fix: リモートサーバーに無意味なActivityPubの配信を行うことがあるのを修正 +- Fix: Remove Meilisearch index when notes are deleted +- Fix: 非英語環境でのPostgreSQLのエラーハンドリングを修正 +- Fix: インスタンスのアイコンがbase64の場合の挙動を修正 +- Fix: ローカルの `Person` を指す `acct` URI を解析するときのバグを修正しました +- Fix: 無効化されたアンテナが再度有効化されないことがある問題を修正 + +## 13.13.2 + +### General +- エラー時や項目が存在しないときなどのアイコン画像をサーバー管理者が設定できるように +- ロールが付与されているユーザーリストを非公開にできるように +- サーバーの負荷が非常に高いため、ユーザー統計表示機能を削除しました + +### Client +- Fix: タブがバックグラウンドでもstreamが切断されないように + +### Server +- Fix: キャッシュが溜まり続けないように + +## 13.13.1 + +### Client +- Fix: タブがアクティブな間はstreamが切断されないように + +### Server +- Fix: api/metaで`TypeError: JSON5.parse is not a function`エラーが発生する問題を修正 + +## 13.13.0 + +### General +- カスタム絵文字ごとにそれをリアクションとして使えるロールを設定できるように +- カスタム絵文字ごとに連合するかどうか設定できるように +- カスタム絵文字ごとにセンシティブフラグを設定できるように +- センシティブなカスタム絵文字のリアクションを受け入れない設定が可能に +- タイムラインにフォロイーの行った他人へのリプライを含めるかどうかの設定をアカウントに保存するのをやめるように + - 今後はAPI呼び出し時およびストリーミング接続時に設定するようになります +- リストを公開できるようになりました + +### Client +- リアクションの取り消し/変更時に確認ダイアログを出すように +- 開発者モードを追加 +- AiScriptを0.13.3に更新 +- Deck UIを使用している場合、`/`以外にアクセスした際にZen UIで表示するように + - メインカラムを設置していない場合の問題を解決 +- ハッシュタグのノート一覧ページから、そのハッシュタグで投稿するボタンを追加 +- アカウント初期設定ウィザードに戻るボタンを追加 +- アカウントの初期設定ウィザードにあとでボタンを追加 +- サーバーにカスタム絵文字の種類が多い場合のパフォーマンスの改善 +- Fix: URLプレビューで情報が取得できなかった際の挙動を修正 +- Fix: Safari、Firefoxでの新規登録時、パスワードマネージャーにメールアドレスが登録されていた挙動を修正 +- Fix: ロールタイムラインが無効でも投稿が流れてしまう問題の修正 +- Fix: ロールタイムラインにて全ての投稿が流れてしまう問題の修正 +- Fix: 「アクセストークンの管理」画面でアプリの情報が表示されない問題の修正 +- Fix: Firefoxにおける絵文字ピッカーのTabキーフォーカス問題の修正 +- Fix: フォローボタンがテーマのカラースキームによって視認性が悪くなる問題を修正 + - 新しいプロパティ `fgOnWhite` が追加されました + +### Server +- bullをbull-mqにアップグレードし、ジョブキューのパフォーマンスを改善 +- ストリーミングのパフォーマンスを改善 +- Fix: 無効化されたアンテナにアクセスがあった際に再度有効化するように +- Fix: お知らせの画像URLを空にできない問題を修正 +- Fix: i/notificationsのsinceIdが機能しない問題を修正 +- Fix: pageのピン留めを解除することができない問題を修正 + +## 13.12.2 + +## NOTE +Meilisearchの設定に`index`が必要になりました。値はMisskeyサーバーのホスト名にすることをお勧めします(アルファベット、ハイフン、アンダーバーのみ使用可能)。例: `misskey-io` +過去に作成された`notes`インデックスは、`---notes`にリネームが必要です。例: `misskey-io---notes` + +### General +- 投稿したコンテンツのAIによる学習を軽減するオプションを追加 + +### Client +- ユーザーを指定してのノート検索が可能に +- アカウント初期設定ウィザードにプライバシー設定を追加 +- リテンション率チャートに折れ線グラフを追加 +- Fix: ブラーエフェクトを有効にしている状態で高負荷になる問題を修正 +- Fix: Pageにおいて画像ブロックに画像を設定できない問題を修正 +- Fix: カラーバーがリプライには表示されないのを修正 +- Fix: チャンネル内の検索ボックスが挙動不審な問題を修正 +- Fix: リテンションチャートのレンダリングを修正 +- Fix: リアクションエフェクトのレンダリングの問題を修正 + +### Server +- センシティブワードの登録にAnd、正規表現が使用できるようになりました。 +- Fix: ひとつのMeilisearchサーバーを複数のMisskeyサーバーで使えない問題を修正 + +## 13.12.1 + +### Client +- プロフィール画面におけるモデレーションノートの表示を調整 +- Fix: 一部ダイアログが表示されない問題を修正 +- Fix: MkUserInfoのフォローボタンが変な位置にある問題を修正 + +### Server +- Fix: リモートサーバーの情報が更新できない問題を修正 +- Fix: 13.11を経験しない状態で13.12にアップデートした場合ユーザープロフィール関連の画像が消失する問題を修正 + +## 13.12.0 + +### NOTE +- Node.js 18.16.0以上が必要になりました + +### General +- アカウントの引っ越し(フォロワー引き継ぎ)に対応 +- Meilisearchを全文検索に使用できるようになりました + * 「フォロワーのみ」の投稿は検索結果に表示されません。 +- 新規登録前に簡潔なルールをユーザーに表示できる、サーバールール機能を追加 +- ユーザーへの自分用メモ機能 + * ユーザーに対して、自分だけが見られるメモを追加できるようになりました。 + (自分自身に対してもメモを追加できます。) + * ユーザーメニューから追加できます。 + (デスクトップ表示ではusernameの右側のボタンからも追加可能) +- チャンネルに色を設定できるようになりました。各ノートに設定した色のインジケーターが表示されます。 +- チャンネルをアーカイブできるようになりました。 + * アーカイブすると、チャンネル一覧や検索結果に表示されなくなり、新たな書き込みもできなくなります。 +- アンテナのエクスポート・インポートができるようになりました +- ロールタイムラインをロールごとに表示するかどうかの選択できるようになりました。 + * デフォルトがオフになるので、ロールタイムラインを表示する場合はオンにしてください。 +- ロールに強制的にNSFWを付与するポリシーを追加 + * アップロード済みのファイルはNSFWにならない為注意してください。 +- モデレーションノートがユーザーのプロフィールページからも閲覧および編集できるようになりました。 +- カスタム絵文字のライセンスを複数でセットできるようになりました。 +- 管理者が予約ユーザー名を設定できるようになりました。 +- Fix: フォローリクエストの通知が残る問題を修正 + +### Client +- アカウント作成時に初期設定ウィザードを表示するように +- チャンネル内検索ができるように +- チャンネル検索ですべてのチャンネルの取得/表示ができるように +- 通知の表示をカスタマイズできるように +- ドライブのファイル一覧から直接ノートを作成できるように +- ノートメニューからRenoteしたユーザーの一覧を見れるように +- コントロールパネルのカスタム絵文字ページおよびaboutのカスタム絵文字の検索インプットで、`:emojiname1::emojiname2:`のように検索して絵文字を検索できるように + * 絵文字ピッカーから入力可能になります +- データセーバーモードを追加 + * 画像が全て隠れた状態で表示されるようになります +- 閲覧注意設定された画像は表示した状態でもそれが閲覧注意だと分かる表示をするように +- モデレーターはノートに添付された画像上から直接NSFW設定できるように +- 1枚だけのメディアリストの画像のアスペクト比を画像に応じて縦長にするように +- プロフィール設定「追加情報」の項目の削除と並び替えができるように +- 新しい実績を追加 +- AiScriptを0.13.2に更新 +- Fix: AiScript APIのMk:dialogで何も返していなかったのをNULLを返すように修正 +- Fix: 1:1ではない画像のリアクション通知バッジが左や上に寄ってしまっていたのを中央に来るように修正 +- Fix: リアクションをホバーした時のユーザーリストで猫耳が切れてしまっていた問題を修正 +- Fix: NSFWメディアの上に表示された「もっと見る」ボタンが押しづらい問題を修正 + +### Server +- channel/searchのqueryが空の場合に全てのチャンネルを返すように変更 +- 環境変数MISSKEY_CONFIG_YMLで設定ファイルをdefault.ymlから変更可能に +- Fix: 他のサーバーの情報が取得できないことがある問題を修正 +- Fix: エクスポートデータの拡張子がunknownになる問題を修正 +- Fix: Content-Dispositionのパースでエラーが発生した場合にダウンロードが完了しない問題を修正 +- Fix: API: i/update avatarIdとbannerIdにnullを渡した時、画像がリセットされない問題を修正 +- Fix: .wav, .flacが再生できない問題を修正(新しくアップロードされたファイルのみ修正が適用されます) +- Fix: 凍結されたユーザーが一部APIのレスポンスに含まれる問題を修正 +- Fix: メモリの使用量を`used - buffers - cached`ではなく`total - available`で求めるように(環境によって正常に計測できていなかったため) + +## 13.11.3 + +### General +- 指定したロールを持つユーザーのノートのみが流れるロールタイムラインを追加 + - Deckのカラムとしても追加可能 +- カスタム絵文字関連の改善 + * ノートなどに含まれるemojis(populateEmojiの結果)は(プロキシされたURLではなく)オリジナルのURLを指すように + * MFMでx3/x4もしくはscale.x/yが2.5以上に指定されていた場合にはオリジナル品質の絵文字を使用するように +- カスタム絵文字でリアクションできないことがある問題を修正 + +### Client +- チャンネルのピン留めされたノートの順番が正しくない問題を修正 + +### Server +- フォローインポートなどでの大量のフォロー等操作をキューイングするように #10544 @nmkj-io +- Misskey Webでのサーバーサイドエラー画面を改善 +- Misskey Webでのサーバーサイドエラーのログが残るように +- ノート作成時のアンテナ追加パフォーマンスを改善 +- アンテナとロールTLのuntil/sinceプロパティが動くように + +## 13.11.2 + +### Note +- 13.11.0または13.11.1から13.11.2以降にアップデートする場合、Redisのカスタム絵文字のキャッシュを削除する必要があります(https://github.com/misskey-dev/misskey/issues/10502#issuecomment-1502790755 参照) + +### General +- チャンネルの検索用ページの追加 + +### Client +- 常に広告を見られるオプションを追加 +- ユーザーページの画像一覧が表示されない問題を修正 +- webhook, 連携アプリ一覧でコンテンツが重複して表示される問題を修正 +- iPhoneで絵文字ピッカーの表示が崩れる問題を修正 +- iPhoneでウィジェットドロワーの「ウィジェットを編集」が押しにくい問題を修正 +- 投稿フォームのデザインを調整 +- ギャラリーの人気の投稿が無限にページングされる問題を修正 + +### Server +- channels/search Endpoint APIの追加 +- APIパラメータサイズ上限を32kbから1mbに緩和 +- プッシュ通知送信時のパフォーマンスを改善 +- ローカルのカスタム絵文字のキャッシュが効いていなかった問題を修正 +- アンテナのノート、チャンネルのノート、通知が正常に作成できないことがある問題を修正 +- ストリーミングのLTLチャンネルでサーバー側にエラーログが出るのを修正 + +### Service Worker +- 「通知が既読になったらプッシュ通知を削除する」を復活 + * 「プッシュ通知が更新されました」の挙動を変えた(ホストとバージョンを表示するようにし、一定時間後の削除は行わないように) +- プッシュ通知が実績を解除 (achievementEarned) に対応 +- プッシュ通知のアクションから既存のクライアントの投稿フォームを開くことになった際の挙動を修正 +- たくさんのプッシュ通知を閉じた際、その通知の数だけnotifications/mark-all-as-readを叩くのをやめるように + +## 13.11.1 + +### General +- チャンネルの投稿を過去までさかのぼれるように + +### Client +- PWA時の絵文字ピッカーの位置をホームバーに重ならないように調整 +- リスト管理の画面でリストが無限に読み込まれる問題を修正 +- 自分のクリップが無限に読み込まれる問題を修正 +- チャンネルのお気に入りが無限に読み込まれる問題を修正 +- さがすのローカルユーザー(ピンどめ)が無限に生成される問題を修正 +- チャンネルを新規作成できない問題を修正 +- ユーザープレビューが表示されない問題を修正 + +### Server +- 通知読み込みでエラーが発生する場合がある問題を修正 +- リアクションできないことがある問題を修正 +- IDをaid以外に設定している場合の問題を修正 +- 連合しているインスタンスについて予期せず配送が全て停止されることがある問題を修正 + +## 13.11.0 + +### NOTE +- このバージョンからRedis 7.xが必要です。 +- アップデートを行うと全ての通知およびアンテナのノートはリセットされます。 + +### General +- チャンネルをお気に入りに登録できるように + - タイムラインのアンテナ選択などでは、フォローしているアンテナの代わりにお気に入りしたアンテナが表示されるようになっています。チャンネルをお気に入りに登録するには、当該チャンネルのページ→概要→⭐️のボタンを押します。 +- チャンネルにノートをピン留めできるように + +### Client +- 投稿フォームのデザインを改善 +- 検索ページでURLを入力した際に照会したときと同等の挙動をするように +- ノートのリアクションを大きく表示するオプションを追加 +- ギャラリー一覧にメディア表示と同じように NSFW 設定を反映するように(ホバーで表示) +- オブジェクトストレージの設定画面を分かりやすく +- 広告・お知らせが新規登録時に増殖しないように +- 「にゃああああああああああああああ!!!!!!!!!!!!」 (`isCat`) 有効時にアバターに表示される猫耳について挙動を変更 + - 「UIにぼかし効果を使用」 (`useBlurEffect`) で次の挙動が有効になります + - 猫耳のアバター内部部分をぼかしでマスク表示してより猫耳っぽく見えるように + - 「UIのアニメーションを減らす」 (`reduceAnimation`) で猫耳を撫でられなくなります +- Add Minimizing ("folding") of windows +- 「データセーバー」モードを追加 +- 非NSFWメディアが隠れている際にも「閲覧注意」が出てしまう問題を修正 + +### Server +- PostgreSQLのレプリケーション対応 + - 設定ファイルの `dbReplications` および `dbSlaves` にて設定できます +- イベント用Redisを別サーバーに分離できるように +- ジョブキュー用Redisを別サーバーに分離できるように +- サーバーの全体的なパフォーマンスを向上 +- ノート作成時のパフォーマンスを向上 +- アンテナのタイムライン取得時のパフォーマンスを向上 +- チャンネルのタイムライン取得時のパフォーマンスを向上 +- 通知に関する全体的なパフォーマンスを向上 +- webhookがcontent-type text/plain;charset=UTF-8 で飛んでくる問題を修正 + +## 13.10.3 + +### Changes +- オブジェクトストレージのリージョン指定が必須になりました + - リージョンの指定の無いサービスは us-east-1 を設定してください + - 値が空の場合は設定ファイルまたは環境変数の使用を試みます + - e.g. ~/aws/config, AWS_REGION + +### General +- コンディショナルロールの条件に「投稿数が~以下」「投稿数が~以上」を追加 +- リアクション非対応AP実装からのLikeアクティビティの解釈を👍から♥に + +### Client +- クリップボタンをノートアクションに追加できるように +- センシティブワードの一覧にピン留めユーザーのIDが表示される問題を修正 + +### Server +- リモートユーザーのチャート生成を無効にするオプションを追加 +- リモートサーバーのチャート生成を無効にするオプションを追加 +- ドライブのチャートはローカルユーザーのみ生成するように +- 空のアンテナが作成できるのを修正 + +## 13.10.2 + +### Server +- 絵文字を編集すると保存できないことがある問題を修正 + +### Client +- ドライブファイルのメニューが正常に動作しない問題を修正 + +## 13.10.1 + +### Client +- Misskey PlayのPlayボタンを押した時にエラーが発生する問題を修正 + +## 13.10.0 + +### General +- ユーザーごとにRenoteをミュートできるように +- ノートごとに絵文字リアクションを受け取るか設定できるように +- クリップをお気に入りに登録できるように +- ノート検索の利用可否をロールで制御可能に(デフォルトでオフ) +- ロールの並び順を設定可能に +- カスタム絵文字にライセンス情報を付与できるように +- 指定した文字列を含む投稿の公開範囲をホームにできるように +- 使われてないアンテナは自動停止されるように + +### Client +- 設定から自分のロールを確認できるように +- 広告一覧ページを追加 +- ドライブクリーナーを追加 +- DM作成時にメンションも含むように +- フォロー申請のボタンのデザインを改善 +- 付箋ウィジェットの高さを設定可能に +- APオブジェクトを入力してフェッチする機能とユーザーやノートの検索機能を分離 +- ナビゲーションバーの項目に「プロフィール」を追加できるように +- ナビゲーションバーのカスタマイズをドラッグ&ドロップで行えるように +- ジョブキューの再試行をワンクリックでできるように +- AiScriptを0.13.1に更新 +- oEmbedをサポートしているウェブサイトのプレビューができるように + - YouTubeをoEmbedでロードし、プレビューで共有ボタンを押すとOSの共有画面がでるように + - ([FirefoxでSpotifyのプレビューを開けるとフルサイズじゃなくプレビューサイズだけ再生できる問題](https://bugzilla.mozilla.org/show_bug.cgi?id=1792395)があります) + - (すでにブラウザーでキャッシュされたリンクに対しては以前のプレビュー行動が行われてます。その場合、ブラウザーのキャッシュをクリアしてまた試してください。) +- プロフィールで設定した情報が削除できない問題を修正 +- ロールで広告を無効にするとadmin/adsでプレビューがでてこない問題を修正 +- /api-consoleページにアクセスすると404が出る問題を修正 +- Safariでプラグインが複数ある場合に正常に読み込まれない問題を修正 +- Bookwyrmのユーザーのプロフィールページで「リモートで表示」をタップしても反応がない問題を修正 +- 非ログイン時の「Misskeyについて」の表示を修正 +- PC版にて「設定」「コントロールパネル」のリンクを2度以上続けてクリックした際に空白のページが表示される問題を修正 + +### Server +- OpenAPIエンドポイントを復旧 +- WebP/AVIF/JPEGのweb公開用画像は、サーバーサイドではJPEGではなくWebPに変換するように +- アニメーション画像のサムネイルを生成するように +- アクティブユーザー数チャートの記録上限値を拡張 +- Playのソースコード上限文字数を2倍に拡張 +- 配送先サーバーが410 Goneで応答してきた場合は自動で配送停止をするように +- avatarBlurHash/bannerBlurHashの型をstringに限定 +- タイムライン取得時のパフォーマンスを改善 +- SMTP Login id length is too short +- API上で`visibility`を`followers`に設定してrenoteすると連合や削除で不具合が発生する問題を修正 +- AWS S3からのファイル削除でNoSuchKeyエラーが出ると進めらない状態になる問題を修正 +- `disableCache: true`を設定している場合に絵文字管理操作でエラーが出る問題を修正 +- リテンション分析が上手く機能しないことがあるのを修正 +- 空のアンテナが作成できないように修正 +- 特定の条件で通報が見れない問題を修正 +- 絵文字の名前に任意の文字が使用できる問題を修正 + +## 13.9.2 (2023/03/06) + +### Improvements +- クリップ、チャンネルページに共有ボタンを追加 +- チャンネルでタイムライン上部に投稿フォームを表示するかどうかのオプションを追加 +- ブラウザでメディアプロキシ(/proxy)からファイルを保存した際に、なるべくオリジナルのファイル名を継承するように +- ドライブの「URLからアップロード」で、content-dispositionのfilenameがあればそれをファイル名に +- Identiconがローカルとリモートで同じになるように + - これまでのIdenticonは異なる画像になります +- サーバーのパフォーマンスを改善 + +### Bugfixes +- ロールの権限で「一般ユーザー」のロールがいきなり設定できない問題を修正 +- ユーザーページのバッジ表示を適切に折り返すように @arrow2nd +- fix(client): みつけるのロール一覧でコンディショナルロールが含まれるのを修正 +- macOSでDev Containerが動作しない問題を修正 @RyotaK + +## 13.9.1 (2023/03/03) + +### Bugfixes +- ノートに添付したファイルが表示されない場合があるのを修正 + +## 13.9.0 (2023/03/03) + +### Improvements +- 時限ロール +- アンテナでCWも検索対象にするように +- ノートの操作部をホバー時のみ表示するオプションを追加 +- サウンドを追加 +- enhance(client): MFMのx2, scale, positionが含まれていたらノートをたたむように +- サーバーのパフォーマンスを改善 + +### Bugfixes +- 外部メディアプロキシ使用時にアバタークロップができない問題を修正 +- fix(server): メールアドレス更新時にバリデーションが正しく行われていないのを修正 +- fix(server): チャンネルでミュートが正しく機能していないのを修正 +- プッシュ通知でカスタム絵文字リアクションを表示できなかった問題を修正 + +## 13.8.1 (2023/02/26) + +### Bugfixes +- モバイルでドロワーメニューが表示されない問題を修正 + +## 13.8.0 (2023/02/26) + +### Improvements +- チャンネル内ハイライト +- ホームタイムラインのパフォーマンスを改善 +- renoteした際の表示を改善 +- バックグラウンドで一定時間経過したらページネーションのアイテム更新をしない +- enhance(client): MkUrlPreviewの閉じるボタンを見やすく +- Add dialog to remove follower +- enhance(client): improve clip menu ux +- 検索画面の統合 +- enhance(client): ノートメニューからユーザーメニューを開けるように +- photoswipe 表示時に戻る操作をしても前の画面に戻らないように + +### Bugfixes +- Windows環境でswcを使うと正しくビルドできない問題の修正 +- fix(client): Android ChromeでPWAとしてインストールできない問題を修正 +- 未知のユーザーが deleteActor されたら処理をスキップする +- fix(server): notes/createで、fileIdsと見つかったファイルの数が異なる場合はエラーにする +- fix(server): notes/createのバリデーションが機能していないのを修正 +- fix(server): エラーのスタックトレースは返さないように + +## 13.7.5 (2023/02/24) + +### Note +13.7.0以前から直接このバージョンにアップデートする場合は全ての通知が削除**されません。** + +### Improvements +- 紛らわしいため公開範囲の「ローカルのみ」オプションの名称を「連合なし」に変更 +- Frontend: スマホ・タブレットの場合、チャンネルの投稿フォームに自動でフォーカスしないように + +### Bugfixes +- 全ての通知が削除されてしまうのを修正 + +## 13.7.3 (2023/02/23) + +### Note +~~13.7.0以前から直接このバージョンにアップデートする場合は全ての通知が削除**されません。**~~ + +### Improvements + +### Bugfixes +- Client: 「キャッシュを削除」した後、ローカルのカスタム絵文字が表示されなくなるされなくなる問題を修正 +- Client: 通知設定画面で以前からグループの招待を有効化していた場合、通知の表示に失敗する問題の修正 +- Client: 通知設定画面に古いトグルが残っていた問題を修正 + +## 13.7.2 (2023/02/23) + +### Note +13.7.0以前からアップデートする場合は全ての通知が削除されます。 + +### Improvements +- enhance: make pwa icon maskable +- chore(client): tweak custom emoji size + +### Bugfixes +- マイグレーションが失敗することがあるのを修正 + +## 13.7.1 (2023/02/23) + +### Improvements +- pnpm buildではswcを使うように + +### Bugfixes +- NODE_ENV=productionでビルドできないのを修正 + +## 13.7.0 (2023/02/22) + +### Changes +- チャット機能が削除されました + +### Improvements +- Server: URLプレビュー(summaly)はプロキシを通すように +- Client: 2FA設定のUIをまともにした +- セキュリティキーの名前を変更できるように +- enhance(client): add quiz preset for play +- 広告開始時期を設定できるように +- みつけるで公開ロール一覧とそのメンバーを閲覧できるように +- enhance(client): MFMのx3, x4が含まれていたらノートをたたむように +- enhance(client): make possible to reload page of window + +### Bugfixes +- ユーザー検索ダイアログでローカルユーザーを絞って検索できない問題を修正 +- fix(client): MkHeader及びデッキのカラムでチャンネル一覧を選択したとき、最大5個までしか表示されない +- 管理画面の広告を10個以上見えるように +- Moderation note が保存できない +- ユーザーのハッシュタグ検索が機能していないのを修正 + +## 13.6.1 (2023/02/12) + +### Improvements +- アニメーションを少なくする設定の時、MkPageHeaderのタブアニメーションを無効化 +- Backend: activitypub情報がcorsでブロックされないようヘッダーを追加 +- enhance: レートリミットを0%にできるように +- チャンネル内Renoteを行えるように + +### Bugfixes +- Client: ユーザーページでアクティビティを見ることができない問題を修正 + +## 13.6.0 (2023/02/11) + +### Improvements +- MkPageHeaderをごっそり変えた + * モバイルではヘッダーは上下に分割され、下段にタブが表示されるように + * iconOnlyのタブ項目がアクティブな場合にはタブのタイトルを表示するように + * メインタイムラインではタイトルを表示しない + * メインタイムラインかつモバイルで表示される左上のアバターを選択するとアカウントメニューが開くように +- ユーザーページのノート一覧をタブとして分離 +- コンディショナルロールもバッジとして表示可能に +- enhance(client): ロールをより簡単に付与できるように +- enhance(client): 一度見たノートのRenoteは省略して表示するように +- enhance(client): 迷惑になる可能性のある投稿を行う前に警告を表示 +- リアクションの数が多い場合の表示を改善 +- 一部のMFM構文をopt-outに + +### Bugfixes +- Client: ユーザーページでタブがほとんど見れないことがないように + +## 13.5.6 (2023/02/10) + +### Improvements +- 非ログイン時にMiAuthを踏んだ際にMiAuthであることを表示する +- /auth/のUIをアップデート +- 利用規約同意UIの調整 +- クロップ時の質問を分かりやすく + +### Bugfixes +- fix: prevent clipping audio plyr's tooltip + +## 13.5.4 (2023/02/09) + +### Improvements +- Server: UIのHTML(ノートなどの特別なページを除く)のキャッシュ時間を15秒から30秒に +- i/notificationsのレートリミットを緩和 + +### Bugfixes +- fix(client): validate url to improve security +- fix(client): dateの初期値が正常に入らない時がある + +## 13.5.3 (2023/02/09) + +### Improvements +- Client: デッキにチャンネルカラムを追加 + +## 13.5.2 (2023/02/08) + +### Changes +- Revert: perf(client): do not render custom emojis in user names + +### Bugfixes +- Client: register_note_view_interruptor not working +- Client: ログイントークンの再生成が出来ない + +## 13.5.0 (2023/02/08) + +### Changes +- perf(client): do not render custom emojis in user names + +### Improvements +- Client: disableShowingAnimatedImagesのデフォルト値をprefers-reduced-motionにする +- enhance(client): tweak medialist style + +### Bugfixes +- fix docker health check +- Client: MkEmojiPickerでもChromeで検索ダイアログで変換確定するとそのまま検索されてしまうのを修正 +- fix(mfm): default degree not used in rotate +- fix(server): validate urls from ap to improve security + +## 13.4.0 (2023/02/05) + +### Improvements +- ロールにアイコンを設定してユーザー名の横に表示できるように +- feat: timeline page for non-login users +- 実績の単なるラッキーの獲得確立を調整 +- Add Thai language support + +### Bugfixes +- fix(server): 自分のノートをお気に入りに登録しても実績解除される問題を修正 +- fix(server): clean up file in FileServer +- fix(server): Deny UNIX domain socket +- fix(server): validate filename and emoji name to improve security +- fix(client): validate input response in aiscript +- fix(client): add webhook delete button +- fix(client): tweak notification style +- fix(client): インラインコードを折り返して表示する + +## 13.3.3 (2023/02/04) + +### Bugfixes +- Server: improve security + +## 13.3.2 (2023/02/04) + +### Improvements +- 外部メディアプロキシへの対応を強化しました + 外部メディアプロキシのFastify実装を作りました + https://github.com/misskey-dev/media-proxy +- Server: improve performance + +### Bugfixes +- Client: validate urls to improve security + +## 13.3.1 (2023/02/04) + +### Bugfixes +- Client: カスタム絵文字にアニメーション画像を再生しない設定が適用されていない問題を修正 +- Client: オートコンプリートでUnicode絵文字がカスタム絵文字として表示されてしまうのを修正 +- Client: Fix Vue-plyr CORS issue +- Client: validate urls to improve security + +## 13.3.0 (2023/02/03) +### Changes +- twitter/github/discord連携機能が削除されました +- ハッシュタグごとのチャートが削除されました +- syslogのサポートが削除されました + +### Improvements +- ロールで広告の非表示が有効になっている場合は最初から広告を非表示にするように + +## 13.2.6 (2023/02/01) +### Changes +- docker-compose.ymlをdocker-compose.yml.exampleにしました。docker-compose.ymlとしてコピーしてから使用してください。 + +### Improvements +- 絵文字ピッカーのパフォーマンスを改善 +- AiScriptを0.12.4に更新 + +### Bugfixes +- Server: リレーと通信できない問題を修正 +- Client: classicモード使用時にwindowサイズによってdefaultに変更された後に、windowサイズが元に戻ったらclassicに戻すように修正 #9669 +- Client: Chromeで検索ダイアログで変換確定するとそのまま検索されてしまう問題を修正 + +## 13.2.4 (2023/01/27) +### Improvements +- リモートカスタム絵文字表示時のパフォーマンスを改善 +- Default to `animation: false` when prefers-reduced-motion is set +- リアクション履歴が公開なら、ログインしていなくても表示できるように +- tweak blur setting +- tweak custom emoji cache + +### Bugfixes +- fix aggregation of retention +- ダッシュボードでオンラインユーザー数が表示されない問題を修正 +- フォロー申請・フォローのボタンが、通知から消えている問題を修正 + +## 13.2.3 (2023/01/26) +### Improvements +- カスタム絵文字の更新をリアルタイムで反映するように + +### Bugfixes +- turnstile-failed: missing-input-secret + +## 13.2.2 (2023/01/25) +### Improvements +- サーバーのパフォーマンスを改善 + +### Bugfixes +- サインイン時に誤ったレートリミットがかかることがある問題を修正 +- MFMのposition、rotate、scaleで小数が使えない問題を修正 + +## 13.2.1 (2023/01/24) +### Improvements +- デザインの調整 +- サーバーのパフォーマンスを改善 + +## 13.2.0 (2023/01/23) + +### Improvements +- onlyServer / onlyQueue オプションを復活 +- 他人の実績閲覧時は獲得条件を表示しないように +- アニメーション減らすオプション有効時はリアクションのアニメーションを無効に +- カスタム絵文字一覧のパフォーマンスを改善 + +### Bugfixes +- Aiscript: button is not defined + +## 13.1.7 (2023/01/22) + +### Improvements +- 新たな実績を追加 +- MFMにscaleタグを追加 + +## 13.1.4 (2023/01/22) + +### Improvements +- 新たな実績を追加 + +### Bugfixes +- Client: ローカリゼーション更新時にリロードが繰り返されることがあるのを修正 + +## 13.1.3 (2023/01/22) + +### Bugfixes +- Client: リアクションのカスタム絵文字の表示の問題を修正 + +## 13.1.2 (2023/01/22) + +### Bugfixes +- Client: リアクションのカスタム絵文字の表示の問題を修正 + +## 13.1.1 (2023/01/22) + +### Improvements +- ローカルのカスタム絵文字を表示する際のパフォーマンスを改善 +- Client: 瞬間的に大量の実績を解除した際の挙動を改善 + +### Bugfixes +- Client: アップデート時にローカリゼーションデータが更新されないことがあるのを修正 + +## 13.1.0 (2023/01/21) + +### Improvements +- 実績機能 +- Playのプリセットを追加 +- Playのscriptの文字数制限を緩和 +- AiScript GUIの強化 +- リアクション一覧詳細ダイアログを表示できるように +- 存在しないカスタム絵文字をテキストで表示するように +- Alt text in image viewer +- ジョブキューのプロセスとWebサーバーのプロセスを分離 + +### Bugfixes +- playを削除する手段がなかったのを修正 +- The … button on notes does nothing when not logged in +- twitterと連携するときに autwh is not a function になるのを修正 + +## 13.0.0 (2023/01/16) + +### TL;DR +- New features (Role system, Misskey Play, New widgets, New charts, 🍪👈, etc) +- Rewriten backend +- Better performance (backend and frontend) +- Various usability improvements +- Various UI tweaks + +### Notable features +- ロール機能 + - 従来より柔軟にユーザーのポリシーを管理できます。例えば、「インスタンスのパトロンはアンテナを30個まで作れる」「基本的にLTLは見れないが、許可した人だけ見れる」「招待制インスタンスだけどユーザーなら誰でも他者を招待できる」のような運用はもちろん、「ローカルユーザーかつアカウント作成から1日未満のユーザーはパブリックな投稿を行えない」のように複数条件を組み合わせて、自動でロールを付与する設定も可能です。 +- Misskey Play + - 従来の動的なPagesに代わる、新しいプラットフォームです。動的なコンテンツ(アプリケーション)に特化していて、Pagesに比べてはるかに柔軟なアプリケーションを作成可能です。 + +### Changes +#### For server admins +- Node.js 18.x or later is required +- PostgreSQL 15.x is required + - Misskey not using 15 specific features at 13.0.0, but may do so in the future. + - Docker環境でPostgreSQLのアップデートを行う際のガイドはこちら: https://github.com/misskey-dev/misskey/pull/9641#issue-1536336620 +- Elasticsearchのサポートが削除されました + - 代わりに今後任意の検索プロバイダを設定できる仕組みを構想しています。その仕組みを使えば今まで通りElasticsearchも利用できます +- Yarnからpnpmに移行されました + corepackの有効化を推奨します: `sudo corepack enable` +- インスタンスブロックはサブドメインにも適用されるようになります +- ロールの導入に伴い、いくつかの機能がロールと統合されました + - モデレーターはロールに統合されました。今までのモデレーター情報は失われるため、予めモデレーター一覧を記録しておき、アップデート後にモデレーターロールを作りアサインし直してください。 + - サイレンスはロールに統合されました。今までのユーザーは恩赦されるため、予めサイレンス一覧を記録しておくのをおすすめします。 + - ユーザーごとのドライブ容量設定はロールに統合されました。 + - インスタンスデフォルトのドライブ容量設定はロールに統合されました。アップデート後、ベースロールもしくはコンディショナルロールでドライブ容量を編集してください。 + - LTL/GTLの解放状態はロールに統合されました。 +- Dockerの実行をrootで行わないようにしました。Dockerかつオブジェクトストレージを使用していない場合は`chown -hR 991.991 ./files`を実行してください。 + https://github.com/misskey-dev/misskey/pull/9560 + +#### For users +- ノートのウォッチ機能が削除されました +- アンケートに投票された際に通知が作成されなくなりました +- ノートの数式埋め込みが削除されました +- 新たに動的なPagesを作ることはできなくなりました + - 代わりにAiScriptを用いてより柔軟に動的なコンテンツを作成できるMisskey Play機能が実装されています。 +- AiScriptが0.12.2にアップデートされました + - 0.12.xの変更点についてはこちら https://github.com/syuilo/aiscript/blob/master/CHANGELOG.md#0120 + - 0.12.x未満のプラグインは読み込むことはできません +- iOS15以下のデバイスはサポートされなくなりました +- Firefox110以下はサポートされなくなりました + - 109でもContainerQueriesのフラグを有効にする事で問題なく使用できます + +#### For app developers +- API: metaのレスポンスに`emojis`プロパティが含まれなくなりました + - カスタム絵文字一覧情報を取得するには、`emojis`エンドポイントにリクエストします +- API: カスタム絵文字エンティティに`url`プロパティが含まれなくなりました + - 絵文字画像を表示するには、`/emoji/.webp`にリクエストすると画像が返ります。 + - e.g. `https://p1.a9z.dev/emoji/misskey.webp` + - remote: `https://p1.a9z.dev/emoji/syuilo_birth_present@mk.f72u.net.webp` +- API: `user`および`note`エンティティに`emojis`プロパティが含まれなくなりました +- API: `user`エンティティに`avatarColor`および`bannerColor`プロパティが含まれなくなりました +- API: `instance`エンティティに`latestStatus`、`lastCommunicatedAt`、`latestRequestSentAt`プロパティが含まれなくなりました +- API: `instance`エンティティの`caughtAt`は`firstRetrievedAt`に名前が変わりました + +### Improvements +- Role system @syuilo +- Misskey Play @syuilo +- Introduce retention-rate aggregation @syuilo +- Make possible to export favorited notes @syuilo +- Add per user pv chart @syuilo +- Push notification of Antenna note @tamaina +- AVIF support @tamaina +- Add Cloudflare Turnstile CAPTCHA support @CyberRex0 +- レートリミットをユーザーごとに調整可能に @syuilo +- 非モデレーターでも、権限を持つロールをアサインされたユーザーはインスタンスの招待コードを発行できるように @syuilo +- 非モデレーターでも、権限を持つロールをアサインされたユーザーはカスタム絵文字の追加、編集、削除を行えるように @syuilo +- クリップおよびクリップ内のノートの作成可能数を設定可能に @syuilo +- ユーザーリストおよびユーザーリスト内のユーザーの作成可能数を設定可能に @syuilo +- ハードワードミュートの最大文字数を設定可能に @syuilo +- Webhookの作成可能数を設定可能に @syuilo +- ノートをピン留めできる数を設定可能に @syuilo +- Server: signToActivityPubGet is set to true by default @syuilo +- Server: improve syslog performance @syuilo +- Server: Use undici instead of node-fetch and got @tamaina +- Server: Judge instance block by endsWith @tamaina +- Server: improve note scoring for featured notes @CyberRex0 +- Server: アンケート選択肢の文字数制限を緩和 @syuilo +- Server: プロフィールの文字数制限を緩和 @syuilo +- Server: add rate limits for some endpoints @syuilo +- Server: improve stats api performance @syuilo +- Server: improve nodeinfo performance @syuilo +- Server: delete outdated notifications regularly to improve db performance @syuilo +- Server: delete outdated hard-mutes regularly to improve db performance @syuilo +- Server: delete outdated notes of antenna regularly to improve db performance @syuilo +- Server: improve activitypub deliver performance @syuilo +- Client: use tabler-icons instead of fontawesome to better design @syuilo +- Client: Add new gabber kick sounds (thanks for noizenecio) +- Client: Add link to user RSS feed in profile menu @ssmucny +- Client: Compress non-animated PNG files @saschanaz +- Client: YouTube window player @sim1222 +- Client: show readable error when rate limit exceeded @syuilo +- Client: enhance dashboard of control panel @syuilo +- Client: Vite is upgraded to v4 @syuilo, @tamaina +- Client: HMR is available while yarn dev @tamaina +- Client: Implement the button to subscribe push notification @tamaina +- Client: Implement the toggle to or not to close push notifications when notifications or messages are read @tamaina +- Client: show Unicode emoji tooltip with its name in MkReactionsViewer.reaction @saschanaz +- Client: OpenSearch support @SoniEx2 @chaoticryptidz +- Client: Support remote objects in search @SoniEx2 +- Client: user activity page @syuilo +- Client: Make widgets of universal/classic sync between devices @tamaina +- Client: add user list widget @syuilo +- Client: Add AiScript App widget +- Client: add profile widget @syuilo +- Client: add instance info widget @syuilo +- Client: Improve RSS widget @tamaina +- Client: add heatmap of daily active users to about page @syuilo +- Client: introduce fluent emoji @syuilo +- Client: add new theme @syuilo +- Client: add new mfm function (position, fg, bg) @syuilo +- Client: show fireworks when visit user who today is birthday @syuilo +- Client: show bot warning on screen when logged in as bot account @syuilo +- Client: AiScriptからカスタム絵文字一覧を参照できるように @syuilo +- Client: improve overall performance of client @syuilo +- Client: ui tweaks @syuilo +- Client: clicker game @syuilo + +### Bugfixes +- Server: Fix @tensorflow/tfjs-core's MODULE_NOT_FOUND error @ikuradon +- Server: 引用内の文章がnyaizeされてしまう問題を修正 @kabo2468 +- Server: Bug fix for Pinned Users lookup on instance @squidicuzz +- Server: Fix peers API returning suspended instances @ineffyble +- Server: trim long text of note from ap @syuilo +- Server: Ap inboxの最大ペイロードサイズを64kbに制限 @syuilo +- Server: アンテナの作成数上限を追加 @syuilo +- Server: pages/likeのエラーIDが重複しているのを修正 @syuilo +- Server: pages/updateのパラメータによってはsummaryの値が更新されないのを修正 @syuilo +- Server: Escape SQL LIKE @mei23 +- Server: 特定のPNG画像のアップロードに失敗する問題を修正 @usbharu +- Server: 非公開のクリップのURLでOGPレンダリングされる問題を修正 @syuilo +- Server: アンテナタイムライン(ストリーミング)が、フォローしていないユーザーの鍵投稿も拾ってしまう @syuilo +- Server: follow request list api pagination @sim1222 +- Server: ドライブ容量超過時のエラーが適切にレスポンスされない問題を修正 @syuilo +- Client: パスワードマネージャーなどでユーザー名がオートコンプリートされない問題を修正 @massongit +- Client: 日付形式の文字列などがカスタム絵文字として表示されるのを修正 @syuilo +- Client: case insensitive emoji search @saschanaz +- Client: 画面の幅が狭いとウィジェットドロワーを閉じる手段がなくなるのを修正 @syuilo +- Client: InAppウィンドウが操作できなくなることがあるのを修正 @tamaina +- Client: use proxied image for instance icon @syuilo +- Client: Webhookの編集画面で、内容を保存することができない問題を修正 @m-hayabusa +- Client: Page編集でブロックの移動が行えない問題を修正 @syuilo +- Client: update emoji picker immediately on all input @saschanaz +- Client: チャートのツールチップが画面に残ることがあるのを修正 @syuilo +- Client: fix wrong link in tutorial @syuilo + +### Special thanks +- All contributors +- All who have created instances for the beta test +- All who participated in the beta test + +## 12.119.1 (2022/12/03) +### Bugfixes +- Server: Mitigate AP reference chain DoS vector @skehmatics + +## 12.119.0 (2022/09/10) + +### Improvements +- Client: Add following badge to user preview popup @nvisser +- Client: mobile twitter url can be used as widget @caipira113 +- Client: Improve clock widget @syuilo + +### Bugfixes +- マイグレーションに失敗する問題を修正 +- Server: 他人の通知を既読にできる可能性があるのを修正 @syuilo +- Client: アクセストークン管理画面、アカウント管理画面表示できないのを修正 @futchitwo + +## 12.118.1 (2022/08/08) + +### Bugfixes +- Client: can not show some setting pages @syuilo + +## 12.118.0 (2022/08/07) + +### Improvements +- Client: 設定のバックアップ/リストア機能 +- Client: Add vi-VN language support +- Client: Add unix time widget @syuilo + +### Bugfixes +- Server: リモートユーザーを正しくブロックできるように修正する @xianonn +- Client: 一度作ったwebhookの設定画面を開こうとするとページがフリーズする @syuilo +- Client: MiAuth認証ページが機能していない @syuilo +- Client: 一部のアプリからファイルを投稿フォームへドロップできない場合がある問題を修正 @m-hayabusa + +## 12.117.1 (2022/07/19) + +### Improvements +- Client: UIのブラッシュアップ @syuilo + +### Bugfixes +- Server: ファイルのアップロードに失敗することがある問題を修正 @acid-chicken +- Client: リアクションピッカーがアプリ内ウィンドウの後ろに表示されてしまう問題を修正 @syuilo +- Client: ユーザー情報の取得の再試行を修正 @xianonn +- Client: MFMチートシートの挙動を修正 @syuilo +- Client: 「インスタンスからのお知らせを受け取る」の設定を変更できない問題を修正 @syuilo + +## 12.117.0 (2022/07/18) + +### Improvements +- Client: ウィンドウを最大化できるように @syuilo +- Client: Shiftキーを押した状態でリンクをクリックするとアプリ内ウィンドウで開くように @syuilo +- Client: デッキを使用している際、Ctrlキーを押した状態でリンクをクリックするとページ遷移を強制できるように @syuilo +- Client: UIのブラッシュアップ @syuilo + +## 12.116.1 (2022/07/17) + +### Bugfixes +- Client: デッキUI時に ページで表示 ボタンが機能しない問題を修正 @syuilo +- Error During Migration Run to 12.111.x + +## 12.116.0 (2022/07/16) + +### Improvements +- Client: registry editor @syuilo +- Client: UIのブラッシュアップ @syuilo + +### Bugfixes +- Error During Migration Run to 12.111.x +- Server: TypeError: Cannot convert undefined or null to object @syuilo + +## 12.115.0 (2022/07/16) + +### Improvements +- Client: Deckのプロファイル切り替えを簡単に @syuilo +- Client: UIのブラッシュアップ @syuilo + +## 12.114.0 (2022/07/15) + +### Improvements +- RSSティッカーで表示順序をシャッフルできるように @syuilo + +### Bugfixes +- クライアントが起動しなくなることがある問題を修正 @syuilo + +## 12.113.0 (2022/07/13) + +### Improvements +- Support syntax for MFM + +### Bugfixes +- Server: Fix crash at startup if TensorFlow is not supported @mei23 +- Client: URLエンコードされたルーティングを修正 + +## 12.112.3 (2022/07/09) + +### Improvements +- Make active email validation configurable + +### Bugfixes +- Server: Fix Attempts to update all notifications @mei23 + +## 12.112.2 (2022/07/08) + +### Bugfixes +- Fix Docker doesn't work @mei23 + Still not working on arm64 environment. (See 12.112.0) + +## 12.112.1 (2022/07/07) +same as 12.112.0 + +## 12.112.0 (2022/07/07) + +### Known issues +- 現在arm64環境ではインストールに失敗します。これは次のバージョンで修正される予定です。 + +### Changes +- ハイライトがみつけるに統合されました +- カスタム絵文字ページはインスタンス情報ページに統合されました +- 連合ページはインスタンス情報ページに統合されました +- メンション一覧ページは通知一覧ページに統合されました +- ダイレクト投稿一覧ページは通知一覧ページに統合されました +- メニューからアンテナタイムラインを表示する方法は廃止され、タイムライン上部のアイコンからアクセスするようになりました +- メニューからリストタイムラインを表示する方法は廃止され、タイムライン上部のアイコンからアクセスするようになりました + +### Improvements +- Server: Allow GET method for some endpoints @syuilo +- Server: Auto NSFW detection @syuilo +- Server: Add rate limit to i/notifications @tamaina +- Client: Improve control panel @syuilo +- Client: Show warning in control panel when there is an unresolved abuse report @syuilo +- Client: Statusbars @syuilo +- Client: Add instance-cloud widget @syuilo +- Client: Add rss-ticker widget @syuilo +- Client: Removing entries from a clip @futchitwo +- Client: Poll highlights in explore page @syuilo +- Client: Improve deck UI @syuilo +- Client: Word mute also checks content warnings @Johann150 +- Client: メニューからページをリロードできるように @syuilo +- Client: Improve emoji picker performance @syuilo +- Client: For notes with specified visibility, show recipients when hovering over visibility symbol. @Johann150 +- Client: Make widgets available again on a tablet @syuilo +- ユーザーにモデレーションメモを残せる機能 @syuilo +- Make possible to delete an account by admin @syuilo +- Improve player detection in URL preview @mei23 +- Add Badge Image to Push Notification #8012 @tamaina +- Server: Improve performance +- Server: Supports IPv6 on Redis transport. @mei23 + IPv4/IPv6 is used by default. You can tune this behavior via `redis.family`. +- Server: Add possibility to log IP addresses of users @syuilo +- Add additional drive capacity change support @CyberRex0 + +### Bugfixes +- Server: Fix GenerateVideoThumbnail failed @mei23 +- Server: Ensure temp directory cleanup @Johann150 +- favicons of federated instances not showing @syuilo +- Admin: The checkbox for blocking an instance works again @Johann150 +- Client: Prevent access to user pages when not logged in @pixeldesu @Johann150 +- Client: Disable some hotkeys (e.g. for creating a post) for not logged in users @pixeldesu +- Client: Ask users that are not logged in to log in when trying to vote in a poll @Johann150 +- Instance mutes also apply in antennas etc. @Johann150 + +## 12.111.1 (2022/06/13) + +### Bugfixes +- some fixes of multiple notification read @tamaina +- some GenerateVideoThumbnail failed @Johann150 +- Client: デッキでウィジェットの情報が保存されない問題を修正 @syuilo +- Client: ギャラリーの投稿を開こうとすると編集画面が表示される @futchitwo + +## 12.111.0 (2022/06/11) +### Note +- Node.js 16.15.0 or later is required + +### Improvements +- Supports Unicode Emoji 14.0 @mei23 +- プッシュ通知を複数アカウント対応に #7667 @tamaina +- プッシュ通知にクリックやactionを設定 #7667 @tamaina +- ドライブに画像ファイルをアップロードするときオリジナル画像を破棄してwebpublicのみ保持するオプション @tamaina +- Server: always remove completed tasks of job queue @Johann150 +- Client: アバターの設定で画像をクロップできるように @syuilo +- Client: make emoji stand out more on reaction button @Johann150 +- Client: display URL of QR code for TOTP registration @tamaina +- Client: render quote renote CWs as MFM @pixeldesu +- API: notifications/readは配列でも受け付けるように #7667 @tamaina +- API: ユーザー検索で、クエリがusernameの条件を満たす場合はusernameもLIKE検索するように @tamaina +- MFM: Allow speed changes in all animated MFMs @Johann150 +- The theme color is now better validated. @Johann150 + Your own theme color may be unset if it was in an invalid format. + Admins should check their instance settings if in doubt. +- Perform port diagnosis at startup only when Listen fails @mei23 +- Rate limiting is now also usable for non-authenticated users. @Johann150 @mei23 + Admins should make sure the reverse proxy sets the `X-Forwarded-For` header to the original address. + +### Bugfixes +- Server: keep file order of note attachement @Johann150 +- Server: fix missing foreign key for reports leading to reports page being unusable @Johann150 +- Server: fix internal in-memory caching @Johann150 +- Server: prevent crash when processing certain PNGs @syuilo +- Server: Fix unable to generate video thumbnails @mei23 +- Server: Fix `Cannot find module` issue @mei23 +- Federation: Add rel attribute to host-meta @mei23 +- Federation: add id for activitypub follows @Johann150 +- Federation: use `source` instead of `_misskey_content` @Johann150 +- Federation: ensure resolver does not fetch local resources via HTTP(S) @Johann150 +- Federation: correctly render empty note text @Johann150 +- Federation: Fix quote renotes containing no text being federated correctly @Johann150 +- Federation: remove duplicate br tag/newline @Johann150 +- Federation: add missing authorization checks @Johann150 +- Client: fix profile picture height in mentions @tamaina +- Client: fix abuse reports page to be able to show all reports @Johann150 +- Client: fix settings page @tamaina +- Client: fix profile tabs @futchitwo +- Client: fix popout URL @futchitwo +- Client: correctly handle MiAuth URLs with query string @sn0w +- Client: ノート詳細ページの新しいノートを表示する機能の動作が正しくなるように修正する @xianonn +- MFM: more animated functions support `speed` parameter @futchitwo +- MFM: limit large MFM @Johann150 + +## 12.110.1 (2022/04/23) + +### Bugfixes +- Fix GOP rendering @syuilo +- Improve performance of antenna, clip, and list @xianonn + +## 12.110.0 (2022/04/11) + +### Improvements +- Improve webhook @syuilo +- Client: Show loading icon on splash screen @syuilo + +### Bugfixes +- API: parameter validation of users/show was wrong +- Federation: リモートインスタンスへのダイレクト投稿が届かない問題を修正 @syuilo + +## 12.109.2 (2022/04/03) + +### Bugfixes +- API: admin/update-meta was not working @syuilo +- Client: テーマを切り替えたり読み込んだりするとmeta[name="theme-color"]のcontentがundefinedになる問題を修正 @tamaina + +## 12.109.1 (2022/04/02) + +### Bugfixes +- API: Renoteが行えない問題を修正 + +## 12.109.0 (2022/04/02) + +### Improvements +- Webhooks @syuilo +- Bull Dashboardを組み込み、ジョブキューの確認や操作を行えるように @syuilo + - Bull Dashboardを開くには、最初だけ一旦ログアウトしてから再度管理者権限を持つアカウントでログインする必要があります +- Check that installed Node.js version fulfills version requirement @ThatOneCalculator +- Server: overall performance improvements @syuilo +- Federation: avoid duplicate activity delivery @Johann150 +- Federation: limit federation of reactions on direct notes @Johann150 +- Client: タッチパッド・タッチスクリーンでのデッキの操作性を向上 @tamaina + +### Bugfixes +- email address validation was not working @ybw2016v +- API: fix endpoint endpoint @Johann150 +- API: fix admin/meta endpoint @syuilo +- API: improved validation and documentation for endpoints that accept different variants of input @Johann150 +- API: `notes/create`: The `mediaIds` property is now deprecated. @Johann150 + - Use `fileIds` instead, it has the same behaviour. +- Client: URIエンコーディングが異常でdecodeURIComponentが失敗するとURLが表示できなくなる問題を修正 @tamaina + +## 12.108.1 (2022/03/12) + +### Bugfixes +- リレーが動作しない問題を修正 @xianonn +- ulidを使用していると動作しない問題を修正 @syuilo +- 外部からOGPが正しく取得できない問題を修正 @syuilo +- instance can not get the files from other instance when there are items in allowedPrivateNetworks in .config/default.yml @ybw2016v + +## 12.108.0 (2022/03/09) + +### NOTE +このバージョンからNode v16.14.0以降が必要です + +### Changes +- ノートの最大文字数を設定できる機能が廃止され、デフォルトで一律3000文字になりました @syuilo +- Misskey can no longer terminate HTTPS connections. @Johann150 + - If you did not use a reverse proxy (e.g. nginx) before, you will probably need to adjust + your configuration file and set up a reverse proxy. The `https` configuration key is no + longer recognized! + +### Improvements +- インスタンスデフォルトテーマを設定できるように @syuilo +- ミュートに期限を設定できるように @syuilo +- アンケートが終了したときに通知が作成されるように @syuilo +- プロフィールの追加情報を最大16まで保存できるように @syuilo +- 連合チャートにPub&Subを追加 @syuilo +- 連合チャートにActiveを追加 @syuilo +- デフォルトで10秒以上時間がかかるデータベースへのクエリは中断されるように @syuilo + - 設定ファイルの`db.extra`に`statement_timeout`を設定することでタイムアウト時間を変更できます +- Client: スプラッシュスクリーンにインスタンスのアイコンを表示するように @syuilo + +### Bugfixes +- Client: リアクションピッカーの高さが低くなったまま戻らないことがあるのを修正 @syuilo +- Client: ユーザー名オートコンプリートが正しく動作しない問題を修正 @syuilo +- Client: タッチ操作だとウィジェットの編集がしにくいのを修正 @xianonn +- Client: register_note_view_interruptor()が動かないのを修正 @syuilo +- Client: iPhone X以降(?)でページの内容が全て表示しきれないのを修正 @tamaina +- Client: fix image caption on mobile @nullobsi + +## 12.107.0 (2022/02/12) + +### Improvements +- クライアント: テーマを追加 @syuilo + +### Bugfixes +- API: stats APIで内部エラーが発生する問題を修正 @syuilo +- クライアント: ソフトミュートですべてがマッチしてしまう場合があるのを修正 @tamaina +- クライアント: デバイスのスクリーンのセーフエリアを考慮するように @syuilo +- クライアント: 一部環境でサイドバーの投稿ボタンが表示されない問題を修正 @syuilo + +## 12.106.3 (2022/02/11) + +### Improvements +- クライアント: スマートフォンでの余白を調整 @syuilo + +### Bugfixes +- クライアント: ノートの詳細が表示されない問題を修正 @syuilo + +## 12.106.2 (2022/02/11) + +### Bugfixes +- クライアント: 削除したノートがタイムラインから自動で消えない問題を修正 @syuilo +- クライアント: リアクション数が正しくないことがある問題を修正 @syuilo +- 一部環境でマイグレーションが動作しない問題を修正 @syuilo + +## 12.106.1 (2022/02/11) + +### Bugfixes +- クライアント: ワードミュートが保存できない問題を修正 @syuilo + +## 12.106.0 (2022/02/11) + +### Improvements +- Improve federation chart @syuilo +- クライアント: リアクションピッカーのサイズを設定できるように @syuilo +- クライアント: リアクションピッカーの幅、高さ制限を緩和 @syuilo +- Docker: Update to Node v16.13.2 @mei23 +- Update dependencies + +### Bugfixes +- validate regular expressions in word mutes @Johann150 + +## 12.105.0 (2022/02/09) + +### Improvements +- インスタンスのテーマカラーを設定できるように @syuilo + +### Bugfixes +- 一部環境でマイグレーションが失敗する問題を修正 @syuilo + +## 12.104.0 (2022/02/09) + +### Note +ビルドする前に`yarn clean`を実行してください。 + +このリリースはマイグレーションの規模が大きいため、インスタンスによってはマイグレーションに時間がかかる可能性があります。 +マイグレーションが終わらない場合は、チャートの情報はリセットされてしまいますが`__chart__`で始まるテーブルの**レコード**を全て削除(テーブル自体は消さないでください)してから再度試す方法もあります。 + +### Improvements +- チャートエンジンの強化 @syuilo + - テーブルサイズの削減 + - notes/instance/perUserNotesチャートに添付ファイル付きノートの数を追加 + - activeUsersチャートに新しい項目を追加 + - federationチャートに新しい項目を追加 + - apRequestチャートを追加 + - networkチャート廃止 +- クライアント: 自インスタンス情報ページでチャートを見れるように @syuilo +- クライアント: デバイスの種類を手動指定できるように @syuilo +- クライアント: UIのアイコンを更新 @syuilo +- クライアント: UIのアイコンをセルフホスティングするように @syuilo +- NodeInfo のユーザー数と投稿数の内容を見直す @xianonn + +### Bugfixes +- Client: タイムライン種別を切り替えると「新しいノートがあります」の表示が残留してしまうのを修正 @tamaina +- Client: UIのサイズがおかしくなる問題の修正 @tamaina +- Client: Setting instance information of notes to always show breaks the timeline @Johann150 +- Client: 環境に依っては返信する際のカーソル位置が正しくない問題を修正 @syuilo +- Client: コントロールパネルのユーザー、ファイルにて、インスタンスの表示範囲切り替えが機能しない問題を修正 @syuilo +- Client: アップデートお知らせダイアログが出ないのを修正 @syuilo +- Client: Follows/Followers Visibility changes won't be saved unless clicking on an other checkbox @Johann150 +- API: Fix API cast @mei23 +- add instance favicon where it's missing @solfisher +- チャートの定期resyncが動作していない問題を修正 @syuilo + +## 12.103.1 (2022/02/02) + +### Bugfixes +- クライアント: ツールチップの表示位置が正しくない問題を修正 + +## 12.103.0 (2022/02/02) + +### Improvements +- クライアント: 連合インスタンスページからインスタンス情報再取得を行えるように + +### Bugfixes +- クライアント: 投稿のNSFW画像を表示したあとにリアクションが更新されると画像が非表示になる問題を修正 +- クライアント: 「クリップ」ページが開かない問題を修正 +- クライアント: トレンドウィジェットが動作しないのを修正 +- クライアント: フェデレーションウィジェットが動作しないのを修正 +- クライアント: リアクション設定で絵文字ピッカーが開かないのを修正 +- クライアント: DMページでメンションが含まれる問題を修正 +- クライアント: 投稿フォームのハッシュタグ保持フィールドが動作しない問題を修正 +- クライアント: サイドビューが動かないのを修正 +- クライアント: ensure that specified users does not get duplicates +- Add `img-src` and `media-src` directives to `Content-Security-Policy` for + files and media proxy + +## 12.102.1 (2022/01/27) +### Bugfixes +- チャットが表示できない問題を修正 + +## 12.102.0 (2022/01/27) + +### NOTE +アップデート後、一部カスタム絵文字が表示できなくなる場合があります。その場合、一旦絵文字管理ページから絵文字を一括エクスポートし、再度コントロールパネルから一括インポートすると直ります。 +⚠ 12.102.0以前にエクスポートされたzipとは互換性がありません。アップデートしてからエクスポートを行なってください。 + +### Changes +- Room機能が削除されました + - 後日別リポジトリとして復活予定です +- リバーシ機能が削除されました + - 後日別リポジトリとして復活予定です +- Chat UIが削除されました +- ノートに添付できるファイルの数が16に増えました +- カスタム絵文字にSVGを指定した場合、PNGに変換されて表示されるようになりました + +### Improvements +- カスタム絵文字一括編集機能 +- カスタム絵文字一括インポート +- 投稿フォームで一時的に投稿するアカウントを切り替えられるように +- Unifying Misskey-specific IRIs in JSON-LD `@context` +- クライアントのパフォーマンス向上 +- セキュリティの向上 + +### Bugfixes +- アップロードエラー時の処理を修正 + +## 12.101.1 (2021/12/29) + +### Bugfixes +- SVG絵文字が表示できないのを修正 +- エクスポートした絵文字の拡張子がfalseになることがあるのを修正 + +## 12.101.0 (2021/12/29) + +### Improvements +- クライアント: ノートプレビューの精度を改善 +- クライアント: MFM sparkleエフェクトの改善 +- クライアント: デザインの調整 +- セキュリティの向上 + +### Bugfixes +- クライアント: 一部のコンポーネントが裏に隠れるのを修正 +- fix html blockquote conversion + +## 12.100.2 (2021/12/18) + +### Bugfixes +- クライアント: Deckカラムの増減がページをリロードするまで正しく反映されない問題を修正 +- クライアント: 一部のコンポーネントが裏に隠れるのを修正 +- クライアント: カスタム絵文字一覧ページの負荷が高いのを修正 + +## 12.100.1 (2021/12/17) + +### Bugfixes +- クライアント: デザインの調整 + +## 12.100.0 (2021/12/17) + +### Improvements +- クライアント: モバイルでの各種メニュー、リアクションピッカーの表示を改善 + +### Bugfixes +- クライアント: 一部のコンポーネントが裏に隠れるのを修正 + +## 12.99.3 (2021/12/14) +### Bugfixes +- クライアント: オートコンプリートがダイアログの裏に隠れる問題を修正 + +## 12.99.2 (2021/12/14) + +## 12.99.1 (2021/12/14) + +## 12.99.0 (2021/12/14) + +### Improvements +- Added a user-level instance mute in user settings +- フォローエクスポートでミュートしているユーザーを含めないオプションを追加 +- フォローエクスポートで使われていないアカウントを含めないオプションを追加 +- カスタム絵文字エクスポート機能 +- チャートのパフォーマンスの改善 +- グループから抜けられるように + +### Bugfixes +- クライアント: タッチ機能付きディスプレイを使っていてマウス操作をしている場合に一部機能が動作しない問題を修正 +- クライアント: クリップの設定を編集できない問題を修正 +- クライアント: メニューなどがウィンドウの裏に隠れる問題を修正 + +## 12.98.0 (2021/12/03) + +### Improvements +- API: /antennas/notes API で日付による絞り込みができるように +- クライアント: アンケートに投票する際に確認ダイアログを出すように +- クライアント: Renoteなノート詳細ページから元のノートページに遷移できるように +- クライアント: 画像ポップアップでクリックで閉じられるように +- クライアント: デザインの調整 +- フォロワーを解除できる機能 + +### Bugfixes +- クライアント: LTLやGTLが無効になっている場合でもUI上にタブが表示される問題を修正 +- クライアント: ログインにおいてパスワードが誤っている際のエラーメッセージが正しく表示されない問題を修正 +- クライアント: リアクションツールチップ、Renoteツールチップのユーザーの並び順を修正 +- クライアント: サウンドのマスターボリュームが正しく保存されない問題を修正 +- クライアント: 一部環境において通知が表示されると操作不能になる問題を修正 +- クライアント: モバイルでタップしたときにツールチップが表示される問題を修正 +- クライアント: リモートインスタンスのノートに返信するとき、対象のノートにそのリモートインスタンス内のユーザーへのメンションが含まれていると、返信テキスト内にローカルユーザーへのメンションとして引き継がれてしまう場合がある問題を修正 +- クライアント: 画像ビューワーで全体表示した時に上側の一部しか表示されない画像がある問題を修正 +- API: ユーザーを取得時に条件によっては内部エラーになる問題を修正 + +### Changes +- クライアント: ノートにモデレーターバッジを表示するのを廃止 + +## 12.97.0 (2021/11/19) + +### Improvements +- クライアント: 返信先やRenoteに対しても自動折りたたみされるように +- クライアント: 長いスレッドの表示を改善 +- クライアント: 翻訳にもMFMを適用し、元の文章の改行などを保持するように +- クライアント: アカウント削除に確認ダイアログを出すように + +### Bugfixes +- クライアント: ユーザー検索の「全て」が動作しない問題を修正 +- クライアント: リアクション一覧、Renote一覧ツールチップのスタイルを修正 + +## 12.96.1 (2021/11/13) +### Improvements +- npm scriptの互換性を向上 + +## 12.96.0 (2021/11/13) + +### Improvements +- フォロー/フォロワーを非公開にできるように +- インスタンスプロフィールレンダリング ready +- 通知のリアクションアイコンをホバーで拡大できるように +- RenoteボタンをホバーでRenoteしたユーザー一覧を表示するように +- 返信の際にメンションを含めるように +- 通報があったときに管理者へEメールで通知されるように +- メールアドレスのバリデーションを強化 + +### Bugfixes +- アカウント削除処理があると高負荷になる問題を修正 +- クライアント: 長いメニューが画面からはみ出す問題を修正 +- クライアント: コントロールパネルのジョブキューに個々のジョブが表示されないのを修正 +- クライアント: fix missing i18n string +- fix html conversion issue with code blocks + +### Changes +- ノートにモバイルからの投稿か否かの情報を含めないように + +## 12.95.0 (2021/10/31) + +### Improvements +- スレッドミュート機能 + +### Bugfixes +- リレー向けのActivityが一部実装で除外されてしまうことがあるのを修正 +- 削除したノートやユーザーがリモートから参照されると復活することがあるのを修正 +- クライアント: ページ編集時のドロップダウンメニューなどが動作しない問題を修正 +- クライアント: コントロールパネルのカスタム絵文字タブが切り替わらないように見える問題を修正 +- API: ユーザー情報の hasUnreadChannel が常に false になっている問題を修正 + +## 12.94.1 (2021/10/25) + +### Improvements + +### Bugfixes +- クライアント: ユーザーページのナビゲーションが失敗する問題を修正 + +## 12.94.0 (2021/10/25) + +### Improvements +- クライアント: 画像ビューアを強化 +- クライアント: メンションにユーザーのアバターを表示するように +- クライアント: デザインの調整 +- クライアント: twemojiをセルフホスティングするように + +### Bugfixes +- クライアント: CWで画像が隠されたとき、画像の高さがおかしいことになる問題を修正 + +### NOTE +- このバージョンから、iOS 15未満のサポートがされなくなります。対象のバージョンをお使いの方は、iOSのバージョンアップを行ってください。 + +## 12.93.2 (2021/10/23) + +### Bugfixes +- クライアント: ウィジェットを追加できない問題を修正 + +## 12.93.1 (2021/10/23) + +### Bugfixes +- クライアント: 通知上でローカルのリアクションが表示されないのを修正 + +## 12.93.0 (2021/10/23) + +### Improvements +- クライアント: コントロールパネルのパフォーマンスを改善 +- クライアント: 自分のリアクション一覧を見れるように + - 設定により、リアクション一覧を全員に公開することも可能 +- クライアント: ユーザー検索の精度を強化 +- クライアント: 新しいライトテーマを追加 +- クライアント: 新しいダークテーマを追加 +- API: ユーザーのリアクション一覧を取得する users/reactions を追加 +- API: users/search および users/search-by-username-and-host を強化 +- ミュート及びブロックのインポートを行えるように +- クライアント: /share のクエリでリプライやファイル等の情報を渡せるように +- チャートのsyncを毎日0時に自動で行うように + +### Bugfixes +- クライアント: テーマの管理が行えない問題を修正 +- API: アプリケーション通知が取得できない問題を修正 +- クライアント: リモートノートで意図せずローカルカスタム絵文字が使われてしまうことがあるのを修正 +- ActivityPub: not reacted な Undo.Like がinboxに滞留するのを修正 + +### Changes +- 連合の考慮に問題があることなどが分かったため、モデレーターをブロックできない仕様を廃止しました +- データベースにログを保存しないようになりました + - ログを永続化したい場合はsyslogを利用してください + +## 12.92.0 (2021/10/16) + +### Improvements +- アカウント登録にメールアドレスの設定を必須にするオプション +- クライアント: 全体的なUIのブラッシュアップ +- クライアント: MFM関数構文のサジェストを実装 +- クライアント: ノート本文を投稿フォーム内でプレビューできるように +- クライアント: 未読の通知のみ表示する機能 +- クライアント: 通知ページで通知の種類によるフィルタ +- クライアント: アニメーションを減らす設定の適用範囲を拡充 +- クライアント: 新しいダークテーマを追加 +- クライアント: テーマコンパイラに hue と saturate 関数を追加 +- ActivityPub: HTML -> MFMの変換を強化 +- API: グループから抜ける users/groups/leave エンドポイントを実装 +- API: i/notifications に unreadOnly オプションを追加 +- API: ap系のエンドポイントをログイン必須化+レートリミット追加 +- MFM: Add tag syntaxes of bold and strikethrough + +### Bugfixes +- Fix createDeleteAccountJob +- admin inbox queue does not show individual jobs +- クライアント: ヘッダーのタブが折り返される問題を修正 +- クライアント: ヘッダーにタブが表示されている状態でタイトルをクリックしたときにタブ選択が表示されるのを修正 +- クライアント: ユーザーページのタブが機能していない問題を修正 +- クライアント: ピン留めユーザーの設定項目がない問題を修正 +- クライアント: Deck UIにおいて、重ねたカラムの片方を畳んだ状態で右に出すと表示が壊れる問題を修正 +- API: 管理者およびモデレーターをブロックできてしまう問題を修正 +- MFM: Mentions in the link label are parsed as text +- MFM: Add a property to the URL node indicating whether it was enclosed in <> +- MFM: Disallows < and > in hashtags + +### Changes +- 保守性やユーザビリティの観点から、Misskeyのコマンドラインオプションが削除されました。 + - 必要であれば、代わりに環境変数で設定することができます +- MFM: パフォーマンス、保守性、構文誤認識抑制の観点から、旧関数構文のサポートが削除されました。 + - 旧構文(`[foo bar]`)を使用せず、現行の構文(`$[foo bar]`)を使用してください。 + +## 12.91.0 (2021/09/22) + +### Improvements +- ActivityPub: リモートユーザーのDeleteアクティビティに対応 +- ActivityPub: add resolver check for blocked instance +- ActivityPub: deliverキューのメモリ使用量を削減 +- API: 管理者用アカウント削除APIを実装(/admin/accounts/delete) + - リモートユーザーの削除も可能に +- アカウントが凍結された場合に、凍結された旨を表示してからログアウトするように +- 凍結されたアカウントにログインしようとしたときに、凍結されている旨を表示するように +- リスト、アンテナタイムラインを個別ページとして分割 +- UIの改善 +- MFMにsparklesエフェクトを追加 +- 非ログイン自は更新ダイアログを出さないように +- クライアント起動時、アップデートが利用可能な場合エラー表示およびダイアログ表示しないように + +### Bugfixes +- アカウントデータのエクスポート/インポート処理ができない問題を修正 +- アンテナの既読が付かない問題を修正 +- popupで設定ページを表示すると、アカウントの削除ページにアクセスすることができない問題を修正 +- "問題が発生しました"ウィンドウを開くと☓ボタンがなくて閉じれない問題を修正 + +## 12.90.1 (2021/09/05) + +### Bugfixes +- Dockerfileを修正 +- ノート翻訳時に公開範囲が考慮されていない問題を修正 + +## 12.90.0 (2021/09/04) + +### Improvements +- 藍モード、および藍ウィジェット + - クライアントに藍ちゃんを召喚することができるようになりました。 +- URLからのアップロード, APの添付ファイル, 外部ファイルのプロキシ等では、Privateアドレス等へのリクエストは拒否されるようになりました。 + - developmentで動作している場合は、この制限は適用されません。 + - Proxy使用時には、この制限は適用されません。 + Proxy使用時に同等の制限を行いたい場合は、Proxy側で設定を行う必要があります。 + - `default.yml`にて`allowedPrivateNetworks`にCIDRを追加することにより、宛先ネットワークを指定してこの制限から除外することが出来ます。 +- アップロード, ダウンロード出来るファイルサイズにハードリミットが適用されるようになりました。(約250MB) + - `default.yml`にて`maxFileSize`を変更することにより、制限値を変更することが出来ます。 + +### Bugfixes +- 管理者が最初にサインアップするページでログインされないのを修正 +- CWを維持する設定を復活 +- クライアントの表示を修正 + +## 12.89.2 (2021/08/24) + +### Bugfixes +- カスタムCSSを有効にしているとエラーになる問題を修正 + +## 12.89.1 (2021/08/24) + +### Improvements +- クライアントのデザインの調整 + +### Bugfixes +- 翻訳でDeepLのProアカウントに対応していない問題を修正 +- インスタンス設定でDeepLのAuth Keyが空で表示される問題を修正 +- セキュリティの向上 + +## 12.89.0 (2021/08/21) + +### Improvements +- アカウント削除の安定性を向上 +- 絵文字オートコンプリートの挙動を改修 +- localStorageのaccountsはindexedDBで保持するように +- ActivityPub: ジョブキューの試行タイミングを調整 (#7635) +- API: sw/unregisterを追加 +- ワードミュートのドキュメントを追加 +- クライアントのデザインの調整 +- 依存関係の更新 + +### Bugfixes +- チャンネルを作成しているとアカウントを削除できないのを修正 +- ノートの「削除して編集」をするとアンケートの選択肢が[object Object]になる問題を修正 + +## 12.88.0 (2021/08/17) + +### Features +- ノートの翻訳機能を追加 + - 有効にするには、サーバー管理者がDeepLの無料アカウントを登録し、取得した認証キーを「インスタンス設定 > その他 > DeepL Auth Key」に設定する必要があります。 +- Misskey更新時にダイアログを表示するように +- ジョブキューウィジェットに警報音を鳴らす設定を追加 + +### Improvements +- ブロックの挙動を改修 + - ブロックされたユーザーがブロックしたユーザーに対してアクション出来ないようになりました。詳細はドキュメントをご確認ください。 +- UIデザインの調整 +- データベースのインデックスを最適化 +- Proxy使用時にKeep-Aliveをサポート +- DNSキャッシュでネガティブキャッシュをサポート +- 依存関係の更新 + +### Bugfixes +- タッチ操作でウィンドウを閉じることができない問題を修正 +- Renoteされた時刻が投稿された時刻のように表示される問題を修正 +- コントロールパネルでファイルを削除した際の表示を修正 +- ActivityPub: 長いユーザーの名前や自己紹介の対応 + +## 12.87.0 (2021/08/12) + +### Improvements +- 絵文字オートコンプリートで一文字目は最近使った絵文字をサジェストするように +- 絵文字オートコンプリートのパフォーマンスを改善 +- about-misskeyページにドキュメントへのリンクを追加 +- Docker: Node.jsを16.6.2に +- 依存関係の更新 +- 翻訳の更新 + +### Bugfixes +- Misskey更新時、テーマキャッシュの影響でスタイルがおかしくなる問題を修正 + +## 12.86.0 (2021/08/11) + +### Improvements +- ドキュメントの更新 + - ドキュメントにchangelogを追加 +- ぼかし効果のオプションを追加 +- Vueを3.2.1に更新 +- UIの調整 + +### Bugfixes +- ハッシュタグ入力が空のときに#が付くのを修正 +- フォローリクエストのEメール通知を修正 diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md new file mode 100644 index 0000000000..1bbfb082af --- /dev/null +++ b/CODE_OF_CONDUCT.md @@ -0,0 +1,132 @@ +# Contributor Covenant Code of Conduct + +## Our Pledge + +We as members, contributors, and leaders pledge to make participation in our +community a harassment-free experience for everyone, regardless of age, body +size, visible or invisible disability, ethnicity, sex characteristics, gender +identity and expression, level of experience, education, socio-economic status, +nationality, personal appearance, race, caste, color, religion, or sexual +identity and orientation. + +We pledge to act and interact in ways that contribute to an open, welcoming, +diverse, inclusive, and healthy community. + +## Our Standards + +Examples of behavior that contributes to a positive environment for our +community include: + +* Demonstrating empathy and kindness toward other people +* Being respectful of differing opinions, viewpoints, and experiences +* Giving and gracefully accepting constructive feedback +* Accepting responsibility and apologizing to those affected by our mistakes, + and learning from the experience +* Focusing on what is best not just for us as individuals, but for the overall + community + +Examples of unacceptable behavior include: + +* The use of sexualized language or imagery, and sexual attention or advances of + any kind +* Trolling, insulting or derogatory comments, and personal or political attacks +* Public or private harassment +* Publishing others' private information, such as a physical or email address, + without their explicit permission +* Other conduct which could reasonably be considered inappropriate in a + professional setting + +## Enforcement Responsibilities + +Community leaders are responsible for clarifying and enforcing our standards of +acceptable behavior and will take appropriate and fair corrective action in +response to any behavior that they deem inappropriate, threatening, offensive, +or harmful. + +Community leaders have the right and responsibility to remove, edit, or reject +comments, commits, code, wiki edits, issues, and other contributions that are +not aligned to this Code of Conduct, and will communicate reasons for moderation +decisions when appropriate. + +## Scope + +This Code of Conduct applies within all community spaces, and also applies when +an individual is officially representing the community in public spaces. +Examples of representing our community include using an official e-mail address, +posting via an official social media account, or acting as an appointed +representative at an online or offline event. + +## Enforcement + +Instances of abusive, harassing, or otherwise unacceptable behavior may be +reported to the community leaders responsible for enforcement at +. +All complaints will be reviewed and investigated promptly and fairly. + +All community leaders are obligated to respect the privacy and security of the +reporter of any incident. + +## Enforcement Guidelines + +Community leaders will follow these Community Impact Guidelines in determining +the consequences for any action they deem in violation of this Code of Conduct: + +### 1. Correction + +**Community Impact**: Use of inappropriate language or other behavior deemed +unprofessional or unwelcome in the community. + +**Consequence**: A private, written warning from community leaders, providing +clarity around the nature of the violation and an explanation of why the +behavior was inappropriate. A public apology may be requested. + +### 2. Warning + +**Community Impact**: A violation through a single incident or series of +actions. + +**Consequence**: A warning with consequences for continued behavior. No +interaction with the people involved, including unsolicited interaction with +those enforcing the Code of Conduct, for a specified period of time. This +includes avoiding interactions in community spaces as well as external channels +like social media. Violating these terms may lead to a temporary or permanent +ban. + +### 3. Temporary Ban + +**Community Impact**: A serious violation of community standards, including +sustained inappropriate behavior. + +**Consequence**: A temporary ban from any sort of interaction or public +communication with the community for a specified period of time. No public or +private interaction with the people involved, including unsolicited interaction +with those enforcing the Code of Conduct, is allowed during this period. +Violating these terms may lead to a permanent ban. + +### 4. Permanent Ban + +**Community Impact**: Demonstrating a pattern of violation of community +standards, including sustained inappropriate behavior, harassment of an +individual, or aggression toward or disparagement of classes of individuals. + +**Consequence**: A permanent ban from any sort of public interaction within the +community. + +## Attribution + +This Code of Conduct is adapted from the [Contributor Covenant][homepage], +version 2.1, available at +[https://www.contributor-covenant.org/version/2/1/code_of_conduct.html][v2.1]. + +Community Impact Guidelines were inspired by +[Mozilla's code of conduct enforcement ladder][Mozilla CoC]. + +For answers to common questions about this code of conduct, see the FAQ at +[https://www.contributor-covenant.org/faq][FAQ]. Translations are available at +[https://www.contributor-covenant.org/translations][translations]. + +[homepage]: https://www.contributor-covenant.org +[v2.1]: https://www.contributor-covenant.org/version/2/1/code_of_conduct.html +[Mozilla CoC]: https://github.com/mozilla/diversity +[FAQ]: https://www.contributor-covenant.org/faq +[translations]: https://www.contributor-covenant.org/translations diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 0000000000..6b01135d11 --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,726 @@ +# Contribution guide +We're glad you're interested in contributing to Sharkey! In this document you will find the information you need to contribute to the project. + +## Roadmap +See [ROADMAP.md](./ROADMAP.md) for the upstream Misskey roadmap. + +## Issues +Before creating an issue, please check the following: +- To avoid duplication, please search for similar issues before creating a new issue. +- Do not use Issues to ask questions or troubleshooting. + - Issues should only be used to feature requests, suggestions, and bug tracking. + - Please ask questions or troubleshooting in [Discord](https://discord.gg/6VgKmEqHNk). + +> [!WARNING] +> Do not close issues that are about to be resolved. It should remain open until a commit that actually resolves it is merged. + +### Recommended discussing before implementation +We welcome your proposal. + +When you want to add a feature or fix a bug, *please open an issue*, +don't just start writing code. We may suggest different approaches, or +show that the "bug" is actually intended behaviour (and offer +work-arounds), or maybe we won't be able to merge your new feature +because it would make it too hard to incorporate future changes from +Misskey. Each of these examples have actually happened! + +On the other hand, it's very likely that we'll tell you "go +ahead!". We try our best to incorporate improvements from our users! + +Also, when you start implementation, assign yourself to the Issue (if you cannot do it yourself, ask Committer to assign you). +By expressing your intention to work on the Issue, you can prevent conflicts in the work. + +To the Committers: you should not assign someone on it before the Final Decision. + +### How issues are triaged + +The Committers may: +* close an issue that is not reproducible on latest stable release, +* merge an issue into another issue, +* split an issue into multiple issues, +* or re-open that has been closed for some reason which is not applicable anymore. + +@syuilo reserves the Final Decision rights including whether the project will implement feature and how to implement, these rights are not always exercised. + +## Well-known branches +- **`stable`** branch is tracking the latest release and used for production purposes. +- **`develop`** branch is where we work for the next release. + - When you create a PR, basically target it to this branch. + +## Creating a PR +Thank you for your PR! Before creating a PR, please check the following: +- If possible, prefix the title with a keyword that identifies the type of this PR, as shown below. + - `fix` / `refactor` / `feat` / `enhance` / `perf` / `chore` etc + - Also, make sure that the granularity of this PR is appropriate. Please do not include more than one type of change or interest in a single PR. +- If there is an Issue which will be resolved by this PR, please include a reference to the Issue in the text. +- Please add the summary of the changes to [`CHANGELOG.md`](CHANGELOG.md). However, this is not necessary for changes that do not affect the users, such as refactoring. +- Check if there are any documents that need to be created or updated due to this change. +- If you have added a feature or fixed a bug, please add a test case if possible. +- Please make sure that tests and Lint are passed in advance. + - You can run it with `pnpm test` and `pnpm lint`. [See more info](#testing) +- If this PR includes UI changes, please attach a screenshot in the text. + +Thanks for your cooperation 🤗 + +### Additional things for ActivityPub payload changes +*This section is specific to misskey-dev implementation. Other fork or implementation may take different way. A significant difference is that non-"misskey-dev" extension is not described in the misskey-hub's document.* + +If PR includes changes to ActivityPub payload, please reflect it in [misskey-hub's document](https://github.com/misskey-dev/misskey-hub-next/blob/master/content/ns.md) by sending PR. + +The name of purporsed extension property (referred as "extended property" in later) to ActivityPub shall be prefixed by `_misskey_`. (i.e. `_misskey_quote`) + +The extended property in `packages/backend/src/core/activitypub/type.ts` **must** be declared as optional because ActivityPub payloads that comes from older Misskey or other implementation may not contain it. + +The extended property must be included in the context definition. Context is defined in `packages/backend/src/core/activitypub/misc/contexts.ts`. +The key shall be same as the name of extended property, and the value shall be same as "short IRI". + +"Short IRI" is defined in misskey-hub's document, but usually takes form of `misskey:`. (i.e. `misskey:_misskey_quote`) + +One should not add property that has defined before by other implementation, or add custom variant value to "well-known" property. + +## Reviewers guide +Be willing to comment on the good points and not just the things you want fixed 💯 + +読んでおくといいやつ +- https://blog.lacolaco.net/posts/1e2cf439b3c2/ +- https://konifar-zatsu.hatenadiary.jp/entry/2024/11/05/192421 + +### Review perspective +- Scope + - Are the goals of the PR clear? + - Is the granularity of the PR appropriate? +- Security + - Does merging this PR create a vulnerability? +- Performance + - Will merging this PR cause unexpected performance degradation? + - Is there a more efficient way? +- Testing + - Does the test ensure the expected behavior? + - Are there any omissions or gaps? + - Does it check for anomalies? + +## Security Advisory +### For reporter +Thank you for your reporting! + +If you can also create a patch to fix the vulnerability, please create a PR on the private fork. + +> [!note] +> There is a GitHub bug that prevents merging if a PR not following the develop branch of upstream, so please keep follow the develop branch. + +### For misskey-dev member +修正PRがdevelopに追従されていないとマージできないので、マージできなかったら + +> Could you merge or rebase onto upstream develop branch? + +などと伝える。 + +## Deploy +The `/deploy` command by issue comment can be used to deploy the contents of a PR to the preview environment. +``` +/deploy sha= +``` +An actual domain will be assigned so you can test the federation. + +## Merge + +## Release +### Release Instructions +1. Commit version changes in the `develop` branch ([package.json](package.json)) +2. Create a release PR. + - Into `stable` from `develop` branch. + - The title must be in the format `Release: x.y.z`. + - `x.y.z` is the new version you are trying to release. +3. Deploy and perform a simple QA check. Also verify that the tests passed. +4. Merge it. (Do not squash commit) +5. Create a [release](https://activitypub.software/TransFem-org/Sharkey/-/releases) + - The target branch must be `stable` + - The tag name must be the version + +> [!NOTE] +> Why this instruction is necessary: +> - To perform final QA checks +> - To distribute responsibility +> - To check direct commits to develop +> - To celebrate the release together 🎉 + +## Localization (l10n) +Misskey uses [Crowdin](https://crowdin.com/project/misskey) for localization management. +You can improve our translations with your Crowdin account. +Your changes in Crowdin are automatically submitted as a PR (with the title "New Crowdin translations") to the repository. +The owner [@syuilo](https://github.com/syuilo) merges the PR into the develop branch before the next release. + +If your language is not listed in Crowdin, please open an issue. We will add it to Crowdin. +For newly added languages, once the translation progress per language exceeds 70%, it will be officially introduced into Misskey and made available to users. + +![Crowdin](https://d322cqt584bo4o.cloudfront.net/misskey/localized.svg) + +## Icon Font (Shark Font) +Sharkey has its own Icon Font called Shark Font which can be found at https://activitypub.software/TransFem-org/shark-font +Build Instructions can all be found over there in the `README`. + +If you have an Icon Suggestion or want to add an Icon please open an issue/merge request over at that repo. + +When Updating the Font make sure to copy **all generated files** from the `dest` folder into `packages/backend/assets/fonts/sharkey-icons` +For the CSS simply copy the file content and replace the old content in `style.css` and for the WOFF, TTF and SVG simply replace them. + +## Development +### Setup +Before developing, you have to set up environment. Misskey requires Redis, PostgreSQL, and FFmpeg. + +You would want to install Meilisearch to experiment related features. Technically, meilisearch is not strict requirement, but some features and tests require it. + +There are a few ways to proceed. + +#### Use system-wide software +You could install them in system-wide (such as from package manager). + +#### Use `docker compose` +You could obtain middleware container by typing `docker compose -f $PROJECT_ROOT/compose.local-db.yml up -d`. + +#### Use Devcontainer +Devcontainer also has necessary setting. This method can be done by connecting from VSCode. + +Instead of running `pnpm` locally, you can use Dev Container to set up your development environment. +To use Dev Container, open the project directory on VSCode with Dev Containers installed. +**Note:** If you are using Windows, please clone the repository with WSL. Using Git for Windows will result in broken files due to the difference in how newlines are handled. + +It will run the following command automatically inside the container. +``` bash +git submodule update --init +pnpm install --frozen-lockfile +cp .devcontainer/devcontainer.yml .config/default.yml +pnpm build +pnpm migrate +``` + +After finishing the migration, you can proceed. + +### Start developing +During development, it is useful to use the +``` +pnpm dev +``` +command. + +- Server-side source files and automatically builds them if they are modified. Automatically start the server process(es). +- Vite HMR (just the `vite` command) is available. The behavior may be different from production. +- Service Worker is watched by esbuild. +- The front end can be viewed by accessing `http://localhost:5173`. +- The backend listens on the port configured with `port` in .config/default.yml. +If you have not changed it from the default, it will be "http://localhost:3000". +If "port" in .config/default.yml is set to something other than 3000, you need to change the proxy settings in packages/frontend/vite.config.local-dev.ts. + +### `MK_DEV_PREFER=backend pnpm dev` +pnpm dev has another mode with `MK_DEV_PREFER=backend`. + +``` +MK_DEV_PREFER=backend pnpm dev +``` + +- This mode is closer to the production environment than the default mode. +- Vite runs behind the backend (the backend will proxy Vite at /vite). +- You can see Misskey by accessing `http://localhost:3000` (Replace `3000` with the port configured with `port` in .config/default.yml). +- To change the port of Vite, specify with `VITE_PORT` environment variable. +- HMR may not work in some environments such as Windows. + +## Testing + +You can run non-backend tests by executing following commands: +```sh +pnpm --filter frontend test +pnpm --filter misskey-js test +``` + +Backend tests require manual preparation of servers. See the next section for more on this. + +### Backend +There are three types of test codes for the backend: +- Unit tests: [`/packages/backend/test/unit`](/packages/backend/test/unit) +- Single-server E2E tests: [`/packages/backend/test/e2e`](/packages/backend/test/e2e) +- Multiple-server E2E tests: [`/packages/backend/test-federation`](/packages/backend/test-federation) + +#### Running Unit Tests or Single-server E2E Tests +1. Create a config file: +```sh +cp .config/test-example.yml .config/test.yml +``` + +2. Start DB and Redis servers for testing: +```sh +docker compose -f packages/backend/test/compose.yml up +``` +Instead, you can prepare an empty (data can be erased) DB and edit `.config/test.yml` appropriately. + +3. Run all tests: +```sh +pnpm --filter backend test # unit tests +pnpm --filter backend test:e2e # single-server E2E tests +``` +If you want to run a specific test, run as a following command: +```sh +pnpm --filter backend test -- packages/backend/test/unit/activitypub.ts +pnpm --filter backend test:e2e -- packages/backend/test/e2e/nodeinfo.ts +``` + +#### Running Multiple-server E2E Tests +See [`/packages/backend/test-federation/README.md`](/packages/backend/test-federation/README.md). + +## Environment Variable + +- `MISSKEY_CONFIG_YML`: Specify the file path of config.yml instead of default.yml (e.g. `2nd.yml`). +- `MISSKEY_WEBFINGER_USE_HTTP`: If it's set true, WebFinger requests will be http instead of https, useful for testing federation between servers in localhost. NEVER USE IN PRODUCTION. + +## Continuous integration +Sharkey uses GitLab CI for executing automated tests. +Configuration files are located in [`/.gitlab-ci.yml`](.gitlab-ci.yml). + +## Vue +Misskey uses Vue(v3) as its front-end framework. +- Use TypeScript. +- **When creating a new component, please use the Composition API (with [setup sugar](https://v3.vuejs.org/api/sfc-script-setup.html) and [ref sugar](https://github.com/vuejs/rfcs/discussions/369)) instead of the Options API.** + - Some of the existing components are implemented in the Options API, but it is an old implementation. Refactors that migrate those components to the Composition API are also welcome. + +## nirax +niraxは、Misskeyで使用しているオリジナルのフロントエンドルーティングシステムです。 +**vue-routerから影響を多大に受けているので、まずはvue-routerについて学ぶことをお勧めします。** + +### ルート定義 +ルート定義は、以下の形式のオブジェクトの配列です。 + +```ts +{ + name?: string; + path: string; + component: Component; + query?: Record; + loginRequired?: boolean; + hash?: string; + globalCacheKey?: string; + children?: RouteDef[]; +} +``` + +> [!WARNING] +> 現状、ルートは定義された順に評価されます。 +> たとえば、`/foo/:id`ルート定義の次に`/foo/bar`ルート定義がされていた場合、後者がマッチすることはありません。 + +### 複数のルーター +vue-routerとの最大の違いは、niraxは複数のルーターが存在することを許可している点です。 +これにより、アプリ内ウィンドウでブラウザとは個別にルーティングすることなどが可能になります。 + +## Storybook + +Misskey uses [Storybook](https://storybook.js.org/) for UI development. + +### Setup & Run + +#### Setup + +```bash +pnpm --filter misskey-js build +``` + +#### Run + +```bash +pnpm --filter frontend storybook-dev +``` + +### Usage + +When you create a new component (in this example, `MyComponent.vue`), the story file (`MyComponent.stories.ts`) will be automatically generated by the `.storybook/generate.js` script. +You can override the default story by creating a impl story file (`MyComponent.stories.impl.ts`). + +```ts +/* eslint-disable @typescript-eslint/explicit-function-return-type */ +import { StoryObj } from '@storybook/vue3'; +import MyComponent from './MyComponent.vue'; +export const Default = { + render(args) { + return { + components: { + MyComponent, + }, + setup() { + return { + args, + }; + }, + computed: { + props() { + return { + ...this.args, + }; + }, + }, + template: '', + }; + }, + args: { + foo: 'bar', + }, + parameters: { + layout: 'centered', + }, +} satisfies StoryObj; +``` + +If you want to opt-out from the automatic generation, create a `MyComponent.stories.impl.ts` file and add the following line to the file. + +```ts +import MyComponent from './MyComponent.vue'; +void MyComponent; +``` + +You can override the component meta by creating a meta story file (`MyComponent.stories.meta.ts`). + +```ts +export const argTypes = { + scale: { + control: { + type: 'range', + min: 1, + max: 4, + }, + }, +}; +``` + +Also, you can use msw to mock API requests in the storybook. Creating a `MyComponent.stories.msw.ts` file to define the mock handlers. + +```ts +import { HttpResponse, http } from 'msw'; +export const handlers = [ + http.post('/api/notes/timeline', ({ request }) => { + return HttpResponse.json([]); + }), +]; +``` + +Don't forget to re-run the `.storybook/generate.js` script after adding, editing, or removing the above files. + +## Nest + +### Nest Service Circular dependency / Nestでサービスの循環参照でエラーが起きた場合 + +#### forwardRef +まずは簡単に`forwardRef`を試してみる + +```typescript +export class FooService { + constructor( + @Inject(forwardRef(() => BarService)) + private barService: BarService + ) { + } +} +``` + +#### OnModuleInit +できなければ`OnModuleInit`を使う + +```typescript +import { Injectable, OnModuleInit } from '@nestjs/common'; +import { ModuleRef } from '@nestjs/core'; +import { BarService } from '@/core/BarService'; + +@Injectable() +export class FooService implements OnModuleInit { + private barService: BarService // constructorから移動してくる + + constructor( + private moduleRef: ModuleRef, + ) { + } + + async onModuleInit() { + this.barService = this.moduleRef.get(BarService.name); + } + + public async niceMethod() { + return await this.barService.incredibleMethod({ hoge: 'fuga' }); + } +} +``` + +##### Service Unit Test +テストで`onModuleInit`を呼び出す必要がある + +```typescript +// import ... + +describe('test', () => { + let app: TestingModule; + let fooService: FooService; // for test case + let barService: BarService; // for test case + + beforeEach(async () => { + app = await Test.createTestingModule({ + imports: ..., + providers: [ + FooService, + { // mockする (mockは必須ではないかもしれない) + provide: BarService, + useFactory: () => ({ + incredibleMethod: jest.fn(), + }), + }, + { // Provideにする + provide: BarService.name, + useExisting: BarService, + }, + ], + }) + .useMocker(... + .compile(); + + fooService = app.get(FooService); + barService = app.get(BarService) as jest.Mocked; + + // onModuleInitを実行する + await fooService.onModuleInit(); + }); + + test('nice', () => { + await fooService.niceMethod(); + + expect(barService.incredibleMethod).toHaveBeenCalled(); + expect(barService.incredibleMethod.mock.lastCall![0]) + .toEqual({ hoge: 'fuga' }); + }); +}) +``` + +## Notes + +### Misskeyのドメイン固有の概念は`Mi`をprefixする +例えばGoogleが自社サービスをMap、Earth、DriveではなくGoogle Map、Google Earth、Google Driveのように命名するのと同じ +コード上でMisskeyのドメイン固有の概念には`Mi`をprefixすることで、他のドメインの同様の概念と区別できるほか、名前の衝突を防ぐ。 +ただし、文脈上Misskeyのものを指すことが明らかであり、名前の衝突の恐れがない場合は、一時的なローカル変数に限って`Mi`を省略してもよい。 + +### How to resolve conflictions occurred at pnpm-lock.yaml? + +Just execute `pnpm` to fix it. + +### INSERTするときにはsaveではなくinsertを使用する +#6441 + +### placeholder +SQLをクエリビルダで組み立てる際、使用するプレースホルダは重複してはならない +例えば +``` ts +query.andWhere(new Brackets(qb => { + for (const type of ps.fileType) { + qb.orWhere(`:type = ANY(note.attachedFileTypes)`, { type: type }); + } +})); +``` +と書くと、ループ中で`type`というプレースホルダが複数回使われてしまいおかしくなる +だから次のようにする必要がある +```ts +query.andWhere(new Brackets(qb => { + for (const type of ps.fileType) { + const i = ps.fileType.indexOf(type); + qb.orWhere(`:type${i} = ANY(note.attachedFileTypes)`, { [`type${i}`]: type }); + } +})); +``` + +### Not `null` in TypeORM +```ts +const foo = await Foos.findOne({ + bar: Not(null) +}); +``` +のようなクエリ(`bar`が`null`ではない)は期待通りに動作しない。 +次のようにします: +```ts +const foo = await Foos.findOne({ + bar: Not(IsNull()) +}); +``` + +### `null` in SQL +SQLを発行する際、パラメータが`null`になる可能性のある場合はSQL文を出し分けなければならない +例えば +``` ts +query.where('file.folderId = :folderId', { folderId: ps.folderId }); +``` +という処理で、`ps.folderId`が`null`だと結果的に`file.folderId = null`のようなクエリが発行されてしまい、これは正しいSQLではないので期待した結果が得られない +だから次のようにする必要がある +``` ts +if (ps.folderId) { + query.where('file.folderId = :folderId', { folderId: ps.folderId }); +} else { + query.where('file.folderId IS NULL'); +} +``` + +### `[]` in SQL +SQLを発行する際、`IN`のパラメータが`[]`(空の配列)になる可能性のある場合はSQL文を出し分けなければならない +例えば +``` ts +const users = await Users.find({ + id: In(userIds) +}); +``` +という処理で、`userIds`が`[]`だと結果的に`user.id IN ()`のようなクエリが発行されてしまい、これは正しいSQLではないので期待した結果が得られない +だから次のようにする必要がある +``` ts +const users = userIds.length > 0 ? await Users.find({ + id: In(userIds) +}) : []; +``` + +### 配列のインデックス in SQL +SQLでは配列のインデックスは**1始まり**。 +`[a, b, c]`の `a`にアクセスしたいなら`[0]`ではなく`[1]`と書く + +### null IN +nullが含まれる可能性のあるカラムにINするときは、そのままだとおかしくなるのでORなどでnullのハンドリングをしよう。 + +### enumの削除は気をつける +enumの列挙の内容の削除は、その値をもつレコードを全て削除しないといけない + +削除が重たかったり不可能だったりする場合は、削除しないでおく + +### Migration作成方法 +packages/backendで: +```sh +pnpm run build +pnpm dlx typeorm migration:generate -d ormconfig.js -o migration/ +``` + +- 生成後、ファイルをmigration下に移してください +- 作成されたスクリプトは不必要な変更を含むため除去してください + +### JSON SchemaのobjectでanyOfを使うとき +JSON Schemaで、objectに対してanyOfを使う場合、anyOfの中でpropertiesを定義しないこと。 +バリデーションが効かないため。(SchemaTypeもそのように作られており、objectのanyOf内のpropertiesは捨てられます) +https://github.com/misskey-dev/misskey/pull/10082 + +テキストhogeおよびfugaについて、片方を必須としつつ両方の指定もありうる場合: + +```ts +export const paramDef = { + type: 'object', + properties: { + hoge: { type: 'string', minLength: 1 }, + fuga: { type: 'string', minLength: 1 }, + }, + anyOf: [ + { required: ['hoge'] }, + { required: ['fuga'] }, + ], +} as const; +``` + +### コネクションには`markRaw`せよ +**Vueのコンポーネントのdataオプションとして**misskey.jsのコネクションを設定するとき、必ず`markRaw`でラップしてください。インスタンスが不必要にリアクティブ化されることで、misskey.js内の処理で不具合が発生するとともに、パフォーマンス上の問題にも繋がる。なお、Composition APIを使う場合はこの限りではない(リアクティブ化はマニュアルなため)。 + +### JSONのimportに気を付けよう +TypeScriptでjsonをimportすると、tscでコンパイルするときにそのjsonファイルも一緒にdistディレクトリに吐き出されてしまう。この挙動により、意図せずファイルの書き換えが発生することがあるので、jsonをimportするときは書き換えられても良いものかどうか確認すること。書き換えされて欲しくない場合は、importで読み込むのではなく、`fs.readFileSync`などの関数を使って読み込むようにすればよい。 + +### コンポーネントのスタイル定義でmarginを持たせない +コンポーネント自身がmarginを設定するのは問題の元となることはよく知られている +marginはそのコンポーネントを使う側が設定する + +## その他 +### HTMLのクラス名で follow という単語は使わない +広告ブロッカーで誤ってブロックされる + +### indexというファイル名を使うな +ESMではディレクトリインポートは廃止されているのと、ディレクトリインポートせずともファイル名が index だと何故か一部のライブラリ?でディレクトリインポートだと見做されてエラーになる + +## CSS Recipe + +### Lighten CSS vars + +``` css +color: hsl(from var(--MI_THEME-accent) h s calc(l + 10)); +``` + +### Darken CSS vars + +``` css +color: hsl(from var(--MI_THEME-accent) h s calc(l - 10)); +``` + +### Add alpha to CSS vars + +``` css +color: color(from var(--MI_THEME-accent) srgb r g b / 0.5); +``` + +## Merging from Misskey into Sharkey + +Make sure you have both remotes in the same clone (`git remote add misskey +https://github.com/misskey-dev/misskey.git`), then: + + git remote update + git checkout develop # this is Sharkey's develop + git checkout -m merge/$(date +%Y-%m-%d) # or whatever + git merge --no-ff misskey/develop + +fix conflicts and *commit*! (conflicts in `pnpm-lock.yaml` can usually +be fixed by running `pnpm install`, it detects conflict markers and +seems to do a decent job) + +*after that commit*, do all the extra work, on the same branch: + +* copy all changes (commit after each step): + * in + `packages/backend/src/core/activitypub/models/ApNoteService.ts`, + from `createNote` to `updateNote` + * from `packages/backend/src/core/NoteCreateService.ts` to + `packages/backend/src/core/NoteEditService.ts` + * from `packages/backend/src/server/api/endpoints/notes/create.ts` + to `packages/backend/src/server/api/endpoints/notes/edit.ts` + * from `packages/frontend/src/components/MkNote*.vue` to + `packages/frontend/src/components/SkNote*.vue` (if sensible) + * from the global timeline to the bubble timeline + (`packages/backend/src/server/api/stream/channels/global-timeline.ts`, + `packages/backend/src/server/api/stream/channels/bubble-timeline.ts`, + `packages/frontend/src/timelines.ts`, + `packages/frontend/src/components/MkTimeline.vue`, + `packages/frontend/src/pages/timeline.vue`, + `packages/frontend/src/ui/deck/tl-column.vue`, + `packages/frontend/src/widgets/WidgetTimeline.vue`) +* if there have been any changes to the federated user data (the + `renderPerson` function in + `packages/backend/src/core/activitypub/ApRendererService.ts`), make + sure that the set of fields in `userNeedsPublishing` and + `profileNeedsPublishing` in + `packages/backend/src/server/api/endpoints/i/update.ts` are still + correct +* check the changes against our `develop` (`git diff develop`) and + against Misskey (`git diff misskey/develop`) +* re-generate `misskey-js` (`pnpm build-misskey-js-with-types`) and commit +* build the frontend: `rm -rf built/; NODE_ENV=development pnpm + --filter=frontend --filter=frontend-embed --filter=frontend-shared + build` (the `development` tells it to keep some of the original + filenames in the built files) +* make sure there aren't any new `ti-*` classes (Tabler Icons), and + replace them with appropriate `ph-*` ones (Phosphor Icons): + `grep -rP '["'\'']ti[ -](?!fw)' -- built/` should show you what to change. + NOTE: `ti-fw` is a special class that's defined by Misskey, leave it + alone + + after every change, re-build the frontend and check again, until + there are no more `ti-*` classes in the built files (you can ignore + the source maps) + + commit! +* double-check the new migration, that they won't conflict with our db + changes: `git diff develop -- packages/backend/migration/` +* `pnpm clean; pnpm build` +* run tests `pnpm --filter='!megalodon' test; pnpm --filter backend + test:e2e` (requires a test database, [see above](#testing)) and fix + as much as you can + * right now `megalodon` doesn't pass its tests, so we skip them +* run lint `pnpm --filter=backend --filter=frontend-shared lint` + + `pnpm --filter=frontend --filter=frontend-embed eslint` and fix as + much as you can + +Then push and open a Merge Request. diff --git a/COPYING b/COPYING new file mode 100644 index 0000000000..6a5f3ca1d5 --- /dev/null +++ b/COPYING @@ -0,0 +1,19 @@ +Unless otherwise stated this repository is +Copyright © 2014-2024 syuilo and contributors + +And is distributed under The GNU Affero General Public License Version 3, you should have received a copy of the license file as LICENSE. + + +Misskey includes several third-party Open-Source softwares. + +Emoji keywords for Unicode 11 and below by Mu-An Chiou +License: MIT +https://github.com/muan/emojilib/blob/master/LICENSE + +RsaSignature2017 implementation by Transmute Industries Inc +License: MIT +https://github.com/transmute-industries/RsaSignature2017/blob/master/LICENSE + +Machine learning model for sensitive images by Infinite Red, Inc. +License: MIT +https://github.com/infinitered/nsfwjs/blob/master/LICENSE diff --git a/Dockerfile b/Dockerfile new file mode 100644 index 0000000000..8f7f8c0805 --- /dev/null +++ b/Dockerfile @@ -0,0 +1,86 @@ +# syntax = docker/dockerfile:1.4 + +ARG NODE_VERSION=22.11.0-alpine3.20 + +FROM node:${NODE_VERSION} as build + +RUN apk add git linux-headers build-base + +ENV PYTHONUNBUFFERED=1 +RUN apk add --update python3 && ln -sf python3 /usr/bin/python +RUN apk add py3-pip py3-setuptools + +RUN corepack enable + +WORKDIR /sharkey + +COPY --link . ./ + +RUN git submodule update --init --recursive +RUN pnpm config set fetch-retries 5 +RUN --mount=type=cache,target=/root/.local/share/pnpm/store,sharing=locked \ + pnpm i --frozen-lockfile --aggregate-output +RUN pnpm build +RUN node scripts/trim-deps.mjs +RUN mv packages/frontend/assets sharkey-assets +RUN mv packages/frontend-embed/assets sharkey-embed-assets +RUN --mount=type=cache,target=/root/.local/share/pnpm/store,sharing=locked \ + pnpm prune +RUN rm -r node_modules packages/frontend packages/frontend-shared packages/frontend-embed packages/sw +RUN --mount=type=cache,target=/root/.local/share/pnpm/store,sharing=locked \ + pnpm i --prod --frozen-lockfile --aggregate-output +RUN rm -rf .git + +FROM node:${NODE_VERSION} + +ARG UID="991" +ARG GID="991" + +RUN apk add ffmpeg tini jemalloc \ + && corepack enable \ + && addgroup -g "${GID}" sharkey \ + && adduser -D -u "${UID}" -G sharkey -h /sharkey sharkey \ + && mkdir /sharkey/files \ + && chown sharkey:sharkey /sharkey/files \ + && find / -type d -path /sys -prune -o -type d -path /proc -prune -o -type f -perm /u+s -exec chmod u-s {} \; \ + && find / -type d -path /sys -prune -o -type d -path /proc -prune -o -type f -perm /g+s -exec chmod g-s {} \; + +USER sharkey +WORKDIR /sharkey + +# add package.json to add pnpm +COPY --chown=sharkey:sharkey ./package.json ./package.json +RUN corepack install + +COPY --chown=sharkey:sharkey --from=build /sharkey/node_modules ./node_modules +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/backend/node_modules ./packages/backend/node_modules +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/misskey-js/node_modules ./packages/misskey-js/node_modules +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/misskey-reversi/node_modules ./packages/misskey-reversi/node_modules +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/misskey-bubble-game/node_modules ./packages/misskey-bubble-game/node_modules +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/megalodon/node_modules ./packages/megalodon/node_modules +COPY --chown=sharkey:sharkey --from=build /sharkey/built ./built +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/misskey-js/built ./packages/misskey-js/built +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/misskey-reversi/built ./packages/misskey-reversi/built +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/misskey-bubble-game/built ./packages/misskey-bubble-game/built +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/backend/built ./packages/backend/built +COPY --chown=sharkey:sharkey --from=build /sharkey/packages/megalodon/lib ./packages/megalodon/lib +COPY --chown=sharkey:sharkey --from=build /sharkey/fluent-emojis ./fluent-emojis +COPY --chown=sharkey:sharkey --from=build /sharkey/tossface-emojis/dist ./tossface-emojis/dist +COPY --chown=sharkey:sharkey --from=build /sharkey/sharkey-assets ./packages/frontend/assets +COPY --chown=sharkey:sharkey --from=build /sharkey/sharkey-embed-assets ./packages/frontend-embed/assets + +COPY --chown=sharkey:sharkey pnpm-workspace.yaml ./pnpm-workspace.yaml +COPY --chown=sharkey:sharkey packages/backend/package.json ./packages/backend/package.json +COPY --chown=sharkey:sharkey packages/backend/scripts/check_connect.js ./packages/backend/scripts/check_connect.js +COPY --chown=sharkey:sharkey packages/backend/ormconfig.js ./packages/backend/ormconfig.js +COPY --chown=sharkey:sharkey packages/backend/migration ./packages/backend/migration +COPY --chown=sharkey:sharkey packages/backend/assets ./packages/backend/assets +COPY --chown=sharkey:sharkey packages/megalodon/package.json ./packages/megalodon/package.json +COPY --chown=sharkey:sharkey packages/misskey-js/package.json ./packages/misskey-js/package.json +COPY --chown=sharkey:sharkey packages/misskey-reversi/package.json ./packages/misskey-reversi/package.json +COPY --chown=sharkey:sharkey packages/misskey-bubble-game/package.json ./packages/misskey-bubble-game/package.json + +ENV LD_PRELOAD=/usr/lib/libjemalloc.so.2 +ENV NODE_ENV=production +ENTRYPOINT ["/sbin/tini", "--"] +CMD ["pnpm", "run", "migrateandstart"] diff --git a/IMPORTANT_NOTES.md b/IMPORTANT_NOTES.md new file mode 100644 index 0000000000..54d0440bea --- /dev/null +++ b/IMPORTANT_NOTES.md @@ -0,0 +1,16 @@ +# Basic Precautions + +When using a service with Sharkey, there are several important points to keep in mind. + +1. Because it is decentralized, there is no guarantee that data you upload will be deleted from all other servers even if you delete it once. (However, this applies to the internet in general.) + +2. Even for posts made in private, there is no guarantee that the recipient's server will treat them as private in the same way. Please exercise caution when posting personal or confidential information. (Again, this applies to the internet in general.) + +3. The "Drive" feature is NOT secure cloud storage. This feature exists for easier managing of your uploaded files. +Any data uploaded, whether shared via post or not, will be publicly accessible. Please use 3rd party cloud storage providers if you need to upload data with sensitive information of any kind. + +4. Account deletion can be a resource-intensive process and may take a long time. In cases with a lot of uploaded data, it may even be impossible to delete an account. + +5. Please disable ad blockers. Some servers may rely on advertising revenue to cover operating costs. Additionally, ad blockers can mistakenly block content and features unrelated to ads, potentially causing issues with the client's functionality and preventing normal use of Sharkey. Therefore, we recommend turning off ad blockers and similar features when using Sharkey. + +Please understand these points and enjoy using the service. diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000000..dba13ed2dd --- /dev/null +++ b/LICENSE @@ -0,0 +1,661 @@ + GNU AFFERO GENERAL PUBLIC LICENSE + Version 3, 19 November 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU Affero General Public License is a free, copyleft license for +software and other kinds of works, specifically designed to ensure +cooperation with the community in the case of network server software. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +our General Public Licenses are intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + Developers that use our General Public Licenses protect your rights +with two steps: (1) assert copyright on the software, and (2) offer +you this License which gives you legal permission to copy, distribute +and/or modify the software. + + A secondary benefit of defending all users' freedom is that +improvements made in alternate versions of the program, if they +receive widespread use, become available for other developers to +incorporate. Many developers of free software are heartened and +encouraged by the resulting cooperation. However, in the case of +software used on network servers, this result may fail to come about. +The GNU General Public License permits making a modified version and +letting the public access it on a server without ever releasing its +source code to the public. + + The GNU Affero General Public License is designed specifically to +ensure that, in such cases, the modified source code becomes available +to the community. It requires the operator of a network server to +provide the source code of the modified version running there to the +users of that server. Therefore, public use of a modified version, on +a publicly accessible server, gives the public access to the source +code of the modified version. + + An older license, called the Affero General Public License and +published by Affero, was designed to accomplish similar goals. This is +a different license, not a version of the Affero GPL, but Affero has +released a new version of the Affero GPL which permits relicensing under +this license. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU Affero General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Remote Network Interaction; Use with the GNU General Public License. + + Notwithstanding any other provision of this License, if you modify the +Program, your modified version must prominently offer all users +interacting with it remotely through a computer network (if your version +supports such interaction) an opportunity to receive the Corresponding +Source of your version by providing access to the Corresponding Source +from a network server at no charge, through some standard or customary +means of facilitating copying of software. This Corresponding Source +shall include the Corresponding Source for any work covered by version 3 +of the GNU General Public License that is incorporated pursuant to the +following paragraph. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the work with which it is combined will remain governed by version +3 of the GNU General Public License. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU Affero General Public License from time to time. Such new versions +will be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU Affero General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU Affero General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU Affero General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If your software can interact with users remotely through a computer +network, you should also make sure that it provides a way for users to +get its source. For example, if your program is a web application, its +interface could display a "Source" link that leads users to an archive +of the code. There are many ways you could offer source, and different +solutions will be better for different programs; see section 13 for the +specific requirements. + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU AGPL, see +. diff --git a/Procfile b/Procfile new file mode 100644 index 0000000000..fdab9a4c81 --- /dev/null +++ b/Procfile @@ -0,0 +1 @@ +web: NODE_ENV=production npm start diff --git a/README.md b/README.md new file mode 100644 index 0000000000..f9198c06c0 --- /dev/null +++ b/README.md @@ -0,0 +1,53 @@ +
+ + Sharkey logo + + +**🌎 **[Sharkey](https://joinsharkey.org/)** is an open source, decentralized social media platform that's free forever! 🚀** + +--- + + + create an instance + + + become a contributor + + + join the community + + + donate + +--- + +
+ +
+ + + +## ✨ Features +- **ActivityPub support**\ +Not on Sharkey? No problem! Not only can Sharkey instances talk to each other, but you can make friends with people on other networks like Mastodon and Pixelfed! +- **Federated Backgrounds and Music status**\ +You can add a background to your profile as well as a music status via ListenBrainz, show everyone what music you are currently listening to +- **Mastodon API**\ +Sharkey implements the Mastodon API unlike normal Misskey +- **UI/UX Improvements**\ +Sharkey makes some UI/UX improvements to make it easier to navigate +- **Sign-Up Approval**\ +With Sharkey, you can enable sign-ups, subject to manual moderator approval and mandatory user-provided reasons for joining. +- **Rich Web UI**\ + Sharkey has a rich and easy to use Web UI! + It is highly customizable, from changing the layout and adding widgets to making custom themes. + Furthermore, plugins can be created using AiScript, an original programming language. +- And much more... + +
+ +
+ +## Documentation + +Sharkey Documentation can be found at [Sharkey Documentation](https://docs.joinsharkey.org/docs/install/fresh/) diff --git a/ROADMAP.md b/ROADMAP.md new file mode 100644 index 0000000000..509ecb9fe7 --- /dev/null +++ b/ROADMAP.md @@ -0,0 +1,40 @@ +# Roadmap +The order of individual tasks is a guide only and is subject to change depending on the situation. +Also, the later tasks are more indefinite and are subject to change as development progresses. + +## (1) Improve maintainability \ +This is the phase we are at now. We need to make a high-maintenance environment that can withstand future development. + +- ~~Make the number of type errors zero (backend)~~ → Done ✔️ +- Make the number of type errors zero (frontend) +- Improve CI + - ~~Fix tests~~ → Done ✔️ + - Fix random test failures - https://github.com/misskey-dev/misskey/issues/7985 and https://github.com/misskey-dev/misskey/issues/7986 + - Add more tests + - ~~May need to implement a mechanism that allows for DI~~ → Done ✔️ + - https://github.com/misskey-dev/misskey/pull/9085 + - ~~Measure coverage~~ → Done ✔️ + - https://github.com/misskey-dev/misskey/pull/9081 +- Improve documentation +- Refactoring + - Extract the logic of each endpoint definition into a service and just call it + +## (2) Improve functionality +Once Phase 1 is complete and an environment conducive to the development of a stable system is in place, the implementation of new functions can begin gradually. + +- Improve features for moderation +- ~~OAuth2 support https://github.com/misskey-dev/misskey/issues/8262~~ → Done ✔️ +- GraphQL support? + +## (3) Improve scalability +Once the development of the feature has settled down, this may be an opportunity to make larger modifications. + +- Rewriting in Rust? + +## (4) Change the world +It is time to promote Misskey and change the world. + +- Become more major than services such as Twitter and become critical infrastructure for the world +- MiOS will be developed and integrated into various systems - What is MiOS? +- Letting Ai-chan interfere with the real world +- Make Misskey a member of GAFA; Misskey's office must be a reinforced concrete brutalist building with a courtyard. diff --git a/SECURITY.md b/SECURITY.md new file mode 100644 index 0000000000..8d3d44db41 --- /dev/null +++ b/SECURITY.md @@ -0,0 +1,16 @@ +# Reporting Security Issues + +If you discover a security issue in Sharkey, please report it by sending an +email to [admin@transfem.org](mailto:admin@transfem.org). + +This will allow us to assess the risk, and make a fix available before we add a +bug report to the GitLab repository. + +Thanks for helping make Sharkey safe for everyone. + +## When create a patch + +If you can also create a patch to fix the vulnerability, please create a PR on the private fork. + +> [!note] +> There is a GitHub bug that prevents merging if a PR not following the develop branch of upstream, so please keep follow the develop branch. diff --git a/UPGRADE_NOTES.md b/UPGRADE_NOTES.md new file mode 100644 index 0000000000..c941de6643 --- /dev/null +++ b/UPGRADE_NOTES.md @@ -0,0 +1,74 @@ +# Upgrade Notes + +## 2024.10.0 + +### Hellspawns + +Sharkey versions before 2024.10 suffered from a bug in the "Mark instance as NSFW" feature. +When a user from such an instance boosted a note, the boost would be converted to a hellspawn (pure renote with Content Warning). +Hellspawns are buggy and do not properly federate, so it may be desirable to correct any that already exist in the database. +The following script will correct any local or remote hellspawns in the database. + +```postgresql +/* Remove "instance is marked as NSFW" hellspawns */ +UPDATE "note" +SET "cw" = null +WHERE + "renoteId" IS NOT NULL + AND "text" IS NULL + AND "cw" = 'Instance is marked as NSFW' + AND "replyId" IS NULL + AND "hasPoll" = false + AND "fileIds" = '{}'; + +/* Fix legacy / user-created hellspawns */ +UPDATE "note" +SET "text" = '.' +WHERE + "renoteId" IS NOT NULL + AND "text" IS NULL + AND "cw" IS NOT NULL + AND "replyId" IS NULL + AND "hasPoll" = false + AND "fileIds" = '{}'; +``` + +## 2024.9.0 + +### Following Feed + +When upgrading an existing instance to version 2024.9.0, the Following Feed will initially be empty. +The feed will gradually fill as new posts federate, but it may be desirable to back-fill the feed with existing data. +This database script will populate the feed with the latest post of each type for all users, ensuring that data is fully populated after the update. +Run this after migrations but before starting the instance. +Warning: the script may take a long time to execute! + +```postgresql +INSERT INTO latest_note (user_id, note_id, is_public, is_reply, is_quote) +SELECT + "userId" as user_id, + id as note_id, + visibility = 'public' AS is_public, + "replyId" IS NOT NULL AS is_reply, + ( + "renoteId" IS NOT NULL + AND ( + text IS NOT NULL + OR cw IS NOT NULL + OR "replyId" IS NOT NULL + OR "hasPoll" + OR "fileIds" != '{}' + ) + ) AS is_quote +FROM note +WHERE ( -- Exclude pure renotes (boosts) + "renoteId" IS NULL + OR text IS NOT NULL + OR cw IS NOT NULL + OR "replyId" IS NOT NULL + OR "hasPoll" + OR "fileIds" != '{}' + ) +ORDER BY id DESC -- This part is very important: it ensures that we only load the *latest* notes of each type. Do not remove it! +ON CONFLICT DO NOTHING; -- Any conflicts are guaranteed to be older notes that we can ignore. +``` diff --git a/assets/about/drive.png b/assets/about/drive.png new file mode 100644 index 0000000000000000000000000000000000000000..16037aae39f0946c67190a89342ad2a01a97b47a GIT binary patch literal 96460 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%0D1W63E^%96a2Nb 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 p<6;oLG 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 KRH%|O5B^{7i->vv literal 0 HcmV?d00001 diff --git a/assets/about/post.png b/assets/about/post.png new file mode 100644 index 0000000000000000000000000000000000000000..3c55f66c5613c57bac7fb9b2aa8032938e307242 GIT binary patch literal 324167 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