Compare commits
	
		
			363 Commits
		
	
	
		
			2024.9.0-b
			...
			2025.2.0-a
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 89b461a5da | ||
|   | 40bfb1be09 | ||
|   | ba9f295ef2 | ||
|   | 77e421029c | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | f8f17a44d4 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 87b9016dbe | ||
|   | 2c3a41e4a0 | ||
|   | 6250af2a2c | ||
|   | 8232ea6956 | ||
|   | 4f31dcfed3 | ||
|   | 605756d425 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | abb1e4bead | ||
|   | 297186e492 | ||
|   | 791b4500ec | ||
|   | ef29130057 | ||
|   | f4bca4708e | ||
|   | e94c697aae | ||
|   | 8f37fb6713 | ||
|   | 35104d87d5 | ||
|   | 0a41e36b6d | ||
|   | 1cd1264ec0 | ||
|   | 26874df4b6 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 31ccefa050 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 97f0ea0c0a | ||
|   | e8b633efec | ||
|   | 68175bc38d | ||
|   | d7fdcbc733 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 9470641dcd | ||
|   | 8d7b1f285f | ||
|   | f9ad127aaf | ||
|   | b41e78090d | ||
|   | bb51574762 | ||
|   | dc48c49f95 | ||
|   | 078b7d6cc5 | ||
|   | fb2c10551d | ||
|   | 1ef62e9e33 | ||
|   | b16f5a781e | ||
|   | f01fc5af5a | ||
|   | 85be61d86e | ||
|   | a328d52008 | ||
|   | 363bdac39b | ||
|   | 6396243973 | ||
|   | 66532333cd | ||
|   | 002e939003 | ||
|   | 9760f3d7c9 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 87cdbaea4f | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 1b47e2d4f2 | ||
|   | d018fe58aa | ||
|   | f45fd01551 | ||
|   | 145c6cf2b5 | ||
|   | 319f7e6a86 | ||
|   | ed43cd87c9 | ||
|   | 40f8b5e7f5 | ||
|   | 71cecdbcf2 | ||
|   | 6a0a810243 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | b65b70d489 | ||
|   | da9e05582d | ||
|   | 9ddf7751db | ||
|   | d2e22f9050 | ||
|   | 5445b023e5 | ||
|   | 64501c69a1 | ||
|   | 7fbfc2e046 | ||
|   | dd6743dda4 | ||
|   | d082a1dd34 | ||
|   | 759b9f4cf1 | ||
|   | 6820878676 | ||
|   | b161601863 | ||
|   | d86c77260e | ||
|   | d60c307c4e | ||
|   | c4192e81ed | ||
|   | 13439e04c4 | ||
|   | bb4457266d | ||
|   | 55713fcd65 | ||
|   | c49a13de65 | ||
|   | 8652ce7cc0 | ||
|   | f6808711af | ||
|   | d7835313c3 | ||
|   | 79b851fe56 | ||
|   | bbe80af1dd | ||
|   | f7da2bad6f | ||
|   | 99ba7ebaa2 | ||
|   | 8ad97e5ede | ||
|   | 6c9eea2c0f | ||
|   | 4120c9ab10 | ||
|   | 1fbc129d7b | ||
|   | 256560e8ba | ||
|   | faea401dcc | ||
|   | 84bf90d1bd | ||
|   | 574034a2dd | ||
|   | 020882edcf | ||
|   | f4e025170e | ||
|   | 79b3d2a711 | ||
|   | 6649e58b56 | ||
|   | 62299588d8 | ||
|   | 3c81926f71 | ||
|   | f123be38b9 | ||
|   | 0804092426 | ||
|   | 3e0fcaeca8 | ||
|   | 5a2b29a3b4 | ||
|   | 234d91a884 | ||
|   | e8bf6285cb | ||
|   | 074b7b0bee | ||
|   | 020c191e2c | ||
|   | dac3b1f405 | ||
|   | fa271cf84e | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 8076f78d06 | ||
|   | dd56623cde | ||
|   | a0e91b5882 | ||
|   | eddf6a2319 | ||
|   | d176db517f | ||
|   | ae1d0b08eb | ||
|   | a77ad7a16b | ||
|   | 00301ed04f | ||
|   | d91a1be562 | ||
|   | 04b221409c | ||
|   | 0e90589290 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 872cefcfb8 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 551040ed0f | ||
|   | 71bfa85986 | ||
|   | f25fc5215b | ||
|   | 1911972ae2 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 752606fe88 | ||
|   | 7f0ae038d4 | ||
|   | 9871035597 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | a21a2c52d7 | ||
|   | c1f19fad1e | ||
|   | 3a6c2aa835 | ||
|   | 53e827b18c | ||
|   | 0f59adc436 | ||
|   | 9fdabe3666 | ||
|   | 090e9392cd | ||
|   | b9cb949eb1 | ||
|   | 5f675201f2 | ||
|   | 1c284c8154 | ||
|   | aa48a0e207 | ||
|   | f0c3a4cc0b | ||
|   | 4603ab67bb | ||
|   | 763c708253 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 6c5d3113c6 | ||
|   | 968f595606 | ||
|   | 7b9c884a5d | ||
|   | c271534aba | ||
|   | e800c0f85a | ||
|   | 81348f1277 | ||
|   | 0df6c79172 | ||
|   | eed45c7915 | ||
|   | 42f9586fc6 | ||
|   | 032dfc782d | ||
|   | 00b8d0c072 | ||
|   | 9aebf0c168 | ||
|   | a730045bdd | ||
|   | 9614f74bf8 | ||
|   | b3c2de2b26 | ||
|   | cf1b7c7064 | ||
|   | 2e0f3936a8 | ||
|   | 459449864c | ||
|   | eef0c895bc | ||
|   | d9d92bcfbf | ||
|   | ce1f84e5a3 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | cf7df05023 | ||
|   | ee2c017f48 | ||
|   | d0cdc0b7a1 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | ac3bf57644 | ||
|   | e850462b82 | ||
|   | c0d1682604 | ||
|   | e26e24b610 | ||
|   | 7f8c8f62b1 | ||
|   | 4d54101510 | ||
|   | 2305788ed9 | ||
|   | a11b77a415 | ||
|   | 1bc4f400c0 | ||
|   | 458c72c153 | ||
|   | 6bd3ed2074 | ||
|   | 31e5f0bd09 | ||
|   | e0a83e9c9e | ||
|   | 1496700b37 | ||
|   | 00cbf9fe80 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | cf09aa21f0 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 9f7d41eb47 | ||
|   | 4a62051ce7 | ||
|   | 3a421837bf | ||
|   | a4c5ce1413 | ||
|   | e75b62f3f5 | ||
|   | 5b60ae810b | ||
|   | 98b4717c45 | ||
|   | 8a4ce16e90 | ||
|   | 794cb9ffe2 | ||
|   | 0b976064ca | ||
|   | bca690f256 | ||
|   | f1eb17f66c | ||
|   | b1c82213a3 | ||
|   | a896c39dbf | ||
|   | 6718a54f6f | ||
|   | d57b8bf2e2 | ||
|   | 224bbd486f | ||
|   | 724dea8136 | ||
|   | ceb60d61b0 | ||
|   | 17d9aca5a7 | ||
|   | 7fc8a2a7b0 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | a96f09cee3 | ||
|   | f30d19051f | ||
|   | 8eb7749e44 | ||
|   | 0472d43ee9 | ||
|   | eb701f2ff4 | ||
|   | 74847bce30 | ||
|   | eecfac1dd9 | ||
|   | e927507886 | ||
|   | b1073714ba | ||
|   | 04b37a1315 | ||
|   | 93a03e6b6d | ||
|   | ec4358d1e8 | ||
|   | a6a1e3d733 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | ded6ef207b | ||
|   | db95b6b0d6 | ||
|   | eeea4ec00b | ||
|   | 07b2c3e5b2 | ||
|   | 076cc953e2 | ||
|   | 15ae1605ec | ||
|   | 48d1539f3b | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 8b6d321a76 | ||
|   | 952fec5665 | ||
|   | 70b2a8f72e | ||
|   | c4f1ca2fd9 | ||
|   | 9d0f7eeb9c | ||
|   | bc1fce9af6 | ||
|   | 5f12bc515d | ||
|   | 2f9c04b23b | ||
|   | 5c79d8db20 | ||
|   | bc0c53b92b | ||
|   | d6caa4d9c4 | ||
|   | 041c9caf31 | ||
|   | 1d106b3ae8 | ||
|   | 58419e1621 | ||
|   | 2250e521e4 | ||
|   | a3a99467f0 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | b1aac6acc3 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | d2e8dc4fe3 | ||
|   | b990ae6b23 | ||
|   | 3cea890eba | ||
|   | 21a2aa5243 | ||
|   | 825d218692 | ||
|   | b5de525548 | ||
|   | 5005cc8ae3 | ||
|   | f13c3909a0 | ||
|   | 77ebabb3dc | ||
|   | 7fd8ef344b | ||
|   | b0a251d231 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 04e74aa28c | ||
|   | 140322b8e2 | ||
|   | 3b361a9d0b | ||
|   | c46d6d8edd | ||
|   | 64bbce4cf4 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | ddca6bdc01 | ||
|   | 8b7290d6b0 | ||
|   | 521d92014d | ||
|   | 2190092de6 | ||
|   | 064d6ca56f | ||
|   | d0bb0b51f5 | ||
|   | 088e05ea66 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | fb23b24f5c | ||
|   | 33b34ad7b8 | ||
|   | 5229f5de4d | ||
|   | ff47fef572 | ||
|   | 45d42b8641 | ||
|   | c4c69cd267 | ||
|   | ee08e9f51e | ||
|   | 85bb1ff1db | ||
|   | 824c51a19f | ||
|   | ef90f83917 | ||
|   | a87a18f40d | ||
|   | 2f09d69773 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 777804605e | ||
|   | af1cbc131f | ||
|   | c397b42242 | ||
|   | a2cd6a7709 | ||
|   | 12bc671511 | ||
|   | d376aab45e | ||
|   | 1ad3148533 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 132c4ba6ce | ||
|   | 67a5fccb3b | ||
|   | 4c84842f3d | ||
|   | 54849bde6c | ||
|   | b668d161a9 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 21e51567e7 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | ebae39cba5 | ||
|   | 433732bcfc | ||
|   | a624546812 | ||
|   | 4a356f1ba7 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 0ad31bd5d4 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 6de7c27522 | ||
|   | a304185eb8 | ||
|   | c13545f965 | ||
| ![dependabot[bot]](/assets/img/avatar_default.png)  | 0da6f14b3b | ||
|   | dd39c5e059 | ||
|   | 1c99785e7e | ||
|   | d0213962bf | ||
|   | 9858e12078 | ||
|   | c14eba3e6d | ||
|   | 993d3fbe55 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 3a11d5ede6 | ||
|   | ed89b4bd94 | ||
|   | 03fb688073 | ||
|   | 8b2780c730 | ||
|   | d2f1d45ea3 | ||
|   | a594d9f26b | ||
|   | 26afe1cc96 | ||
|   | 7933b6662e | ||
|   | ddf8e2a3dc | ||
|   | ddc799fe3d | ||
|   | 057a6d731d | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 254c063455 | ||
|   | 9d026975bc | ||
|   | d8cb7305ef | ||
|   | 043fef9fdf | ||
|   | 0d7d1091c8 | ||
|   | d8bf1ff7e9 | ||
|   | 88698462a9 | ||
|   | ae3c155490 | ||
|   | fa06c59eae | ||
|   | b36d13d90c | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 3d637af65b | ||
|   | 2340de035b | ||
|   | d8f30fb793 | ||
|   | 708ffaef5c | ||
|   | 2639e92e18 | ||
|   | ea2675eaab | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 3b0b4f83dd | ||
|   | 975c2e7bc5 | ||
|   | e344650278 | ||
|   | 1aee260398 | ||
|   | 2fa805b8f7 | ||
|   | ed71b0b7d4 | ||
|   | 864327b4a7 | ||
|   | c1597be458 | ||
|   | a08a38c29a | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 650e22c90d | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | fa2558fce8 | ||
|   | 7bdc4e8509 | ||
|   | d266c3cdf4 | ||
|   | d2175a9b9f | ||
|   | 2a4ab0e187 | ||
|   | 2c1a7470d3 | ||
|   | 75ea964312 | ||
|   | a09b03ed3a | ||
|   | a722ea8ccd | ||
|   | 1e9813e19e | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | e97b7fe2a1 | ||
|   | 87617dca39 | ||
|   | 9dc058189e | ||
|   | 83db116c46 | ||
|   | d3e2b59f53 | ||
|   | 1074d625ed | ||
|   | 6dde457452 | ||
|   | a25d83f249 | ||
|   | 6fd4de246c | ||
|   | e9519b02fb | ||
|   | b6578861ac | ||
|   | ca8cc015b0 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 4f34a4e4d8 | ||
| ![misskey-release-bot[bot]](/assets/img/avatar_default.png)  | 5fc8b3bc50 | ||
| ![github-actions[bot]](/assets/img/avatar_default.png)  | 781e64aa7f | ||
| ![misskey-release-bot[bot]](/assets/img/avatar_default.png)  | 882c8b93c1 | ||
| ![misskey-release-bot[bot]](/assets/img/avatar_default.png)  | e98f66db51 | 
| @@ -2,6 +2,19 @@ | ||||
| # 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 └───────────────────────────────────────────────────── | ||||
|  | ||||
|   | ||||
| @@ -114,9 +114,27 @@ redis: | ||||
| #  #prefix: example-prefix | ||||
| #  #db: 1 | ||||
|  | ||||
| #   ┌───────────────────────────┐ | ||||
| #───┘ MeiliSearch configuration └───────────────────────────── | ||||
| #   ┌───────────────────────────────┐ | ||||
| #───┘ Fulltext search configuration └───────────────────────────── | ||||
|  | ||||
| # These are the setting items for the full-text search provider. | ||||
| fulltextSearch: | ||||
|   # You can select the ID generation method. | ||||
|   # - sqlLike (default) | ||||
|   #   Use SQL-like search. | ||||
|   #   This is a standard feature of PostgreSQL, so no special extensions are required. | ||||
|   # - sqlPgroonga | ||||
|   #   Use pgroonga. | ||||
|   #   You need to install pgroonga and configure it as a PostgreSQL extension. | ||||
|   #   In addition to the above, you need to create a pgroonga index on the text column of the note table. | ||||
|   #   see: https://pgroonga.github.io/tutorial/ | ||||
|   # - meilisearch | ||||
|   #   Use Meilisearch. | ||||
|   #   You need to install Meilisearch and configure. | ||||
|   provider: sqlLike | ||||
|  | ||||
| # For Meilisearch settings. | ||||
| # If you select "meilisearch" for "fulltextSearch.provider", it must be set. | ||||
| # You can set scope to local (default value) or global | ||||
| # (include notes from remote). | ||||
|  | ||||
| @@ -219,3 +237,13 @@ signToActivityPubGet: true | ||||
|  | ||||
| # Upload or download file size limits (bytes) | ||||
| #maxFileSize: 262144000 | ||||
|  | ||||
| # Log settings | ||||
| # logging: | ||||
| #   sql: | ||||
| #     # Outputs query parameters during SQL execution to the log. | ||||
| #     # default: false | ||||
| #     enableQueryParamLogging: false | ||||
| #     # Disable query truncation. If set to true, the full text of the query will be output to the log. | ||||
| #     # default: false | ||||
| #     disableQueryTruncation: false | ||||
|   | ||||
| @@ -59,6 +59,20 @@ | ||||
| # | ||||
| # 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 └───────────────────────────────────────────────────── | ||||
|  | ||||
| @@ -182,9 +196,27 @@ redis: | ||||
| #  # You can specify more ioredis options... | ||||
| #  #username: example-username | ||||
|  | ||||
| #   ┌───────────────────────────┐ | ||||
| #───┘ MeiliSearch configuration └───────────────────────────── | ||||
| #   ┌───────────────────────────────┐ | ||||
| #───┘ Fulltext search configuration └───────────────────────────── | ||||
|  | ||||
| # These are the setting items for the full-text search provider. | ||||
| fulltextSearch: | ||||
|   # You can select the ID generation method. | ||||
|   # - sqlLike (default) | ||||
|   #   Use SQL-like search. | ||||
|   #   This is a standard feature of PostgreSQL, so no special extensions are required. | ||||
|   # - sqlPgroonga | ||||
|   #   Use pgroonga. | ||||
|   #   You need to install pgroonga and configure it as a PostgreSQL extension. | ||||
|   #   In addition to the above, you need to create a pgroonga index on the text column of the note table. | ||||
|   #   see: https://pgroonga.github.io/tutorial/ | ||||
|   # - meilisearch | ||||
|   #   Use Meilisearch. | ||||
|   #   You need to install Meilisearch and configure. | ||||
|   provider: sqlLike | ||||
|  | ||||
| # For Meilisearch settings. | ||||
| # If you select "meilisearch" for "fulltextSearch.provider", it must be set. | ||||
| # You can set scope to local (default value) or global | ||||
| # (include notes from remote). | ||||
|  | ||||
| @@ -307,3 +339,13 @@ signToActivityPubGet: true | ||||
|  | ||||
| # PID File of master process | ||||
| #pidFile: /tmp/misskey.pid | ||||
|  | ||||
| # Log settings | ||||
| # logging: | ||||
| #   sql: | ||||
| #     # Outputs query parameters during SQL execution to the log. | ||||
| #     # default: false | ||||
| #     enableQueryParamLogging: false | ||||
| #     # Disable query truncation. If set to true, the full text of the query will be output to the log. | ||||
| #     # default: false | ||||
| #     disableQueryTruncation: false | ||||
|   | ||||
| @@ -5,7 +5,7 @@ | ||||
| 	"workspaceFolder": "/workspace", | ||||
| 	"features": { | ||||
| 		"ghcr.io/devcontainers/features/node:1": { | ||||
| 			"version": "20.16.0" | ||||
| 			"version": "22.11.0" | ||||
| 		}, | ||||
| 		"ghcr.io/devcontainers-contrib/features/corepack:1": {} | ||||
| 	}, | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/ISSUE_TEMPLATE/01_bug-report.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/ISSUE_TEMPLATE/01_bug-report.yml
									
									
									
									
										vendored
									
									
								
							| @@ -54,7 +54,7 @@ body: | ||||
|           * Model and OS of the device(s): MacBook Pro (14inch, 2021), macOS Ventura 13.4 | ||||
|           * Browser: Chrome 113.0.5672.126 | ||||
|           * Server URL: misskey.example.com | ||||
|           * Misskey: 2024.x.x | ||||
|           * Misskey: 2025.x.x | ||||
|       value: | | ||||
|         * Model and OS of the device(s): | ||||
|         * Browser: | ||||
| @@ -74,7 +74,7 @@ body: | ||||
|  | ||||
|         Examples: | ||||
|           * Installation Method or Hosting Service: docker compose, k8s/docker, systemd, "Misskey install shell script", development environment | ||||
|           * Misskey: 2024.x.x | ||||
|           * Misskey: 2025.x.x | ||||
|           * Node: 20.x.x | ||||
|           * PostgreSQL: 15.x.x | ||||
|           * Redis: 7.x.x | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/labeler.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/labeler.yml
									
									
									
									
										vendored
									
									
								
							| @@ -6,7 +6,7 @@ | ||||
| 'packages/backend:test': | ||||
| - any: | ||||
|   - changed-files: | ||||
|     - any-glob-to-any-file: ['packages/backend/test/**/*'] | ||||
|     - any-glob-to-any-file: ['packages/backend/test/**/*', 'packages/backend/test-federation/**/*'] | ||||
|  | ||||
| 'packages/frontend': | ||||
| - any: | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/misskey/test.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/misskey/test.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,7 @@ | ||||
| url: 'http://misskey.local' | ||||
|  | ||||
| setupPassword: example_password_please_change_this_or_you_will_get_hacked | ||||
|  | ||||
| # ローカルでテストするときにポートを被らないようにするためデフォルトのものとは変える(以下同じ) | ||||
| port: 61812 | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/api-misskey-js.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/api-misskey-js.yml
									
									
									
									
										vendored
									
									
								
							| @@ -21,7 +21,7 @@ jobs: | ||||
|       - run: corepack enable | ||||
|  | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4.0.4 | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version-file: '.node-version' | ||||
|           cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/changelog-check.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/changelog-check.yml
									
									
									
									
										vendored
									
									
								
							| @@ -14,7 +14,7 @@ jobs: | ||||
|       - name: Checkout head | ||||
|         uses: actions/checkout@v4.1.1 | ||||
|       - name: Setup Node.js | ||||
|         uses: actions/setup-node@v4.0.4 | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version-file: '.node-version' | ||||
|  | ||||
|   | ||||
							
								
								
									
										10
									
								
								.github/workflows/check-misskey-js-autogen.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										10
									
								
								.github/workflows/check-misskey-js-autogen.yml
									
									
									
									
										vendored
									
									
								
							| @@ -21,6 +21,7 @@ jobs: | ||||
|         uses: actions/checkout@v4.1.1 | ||||
|         with: | ||||
|           submodules: true | ||||
|           persist-credentials: false | ||||
|           ref: refs/pull/${{ github.event.pull_request.number }}/merge | ||||
|  | ||||
|       - name: setup pnpm | ||||
| @@ -28,7 +29,7 @@ jobs: | ||||
|  | ||||
|       - name: setup node | ||||
|         id: setup-node | ||||
|         uses: actions/setup-node@v4.0.4 | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version-file: '.node-version' | ||||
|           cache: pnpm | ||||
| @@ -57,7 +58,7 @@ jobs: | ||||
|           name: generated-misskey-js | ||||
|           path: packages/misskey-js/generator/built/autogen | ||||
|  | ||||
|   # pull_request_target safety: permissions: read-all, and there are no secrets used in this job | ||||
|   # pull_request_target safety: permissions: read-all, and no user codes are executed | ||||
|   get-actual-misskey-js: | ||||
|     runs-on: ubuntu-latest | ||||
|     permissions: | ||||
| @@ -68,6 +69,7 @@ jobs: | ||||
|         uses: actions/checkout@v4.1.1 | ||||
|         with: | ||||
|           submodules: true | ||||
|           persist-credentials: false | ||||
|           ref: refs/pull/${{ github.event.pull_request.number }}/merge | ||||
|  | ||||
|       - name: Upload From Merged | ||||
| @@ -131,3 +133,7 @@ jobs: | ||||
|           mode: delete | ||||
|           message: "Thank you!" | ||||
|           create_if_not_exists: false | ||||
|  | ||||
|       - name: Make failure if changes are detected | ||||
|         if: steps.check-changes.outputs.changes == 'true' | ||||
|         run: exit 1 | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/get-api-diff.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/get-api-diff.yml
									
									
									
									
										vendored
									
									
								
							| @@ -17,7 +17,7 @@ jobs: | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|         api-json-name: [api-base.json, api-head.json] | ||||
|         include: | ||||
|           - api-json-name: api-base.json | ||||
| @@ -33,7 +33,7 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										8
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								.github/workflows/lint.yml
									
									
									
									
										vendored
									
									
								
							| @@ -37,7 +37,7 @@ jobs: | ||||
|         fetch-depth: 0 | ||||
|         submodules: true | ||||
|     - uses: pnpm/action-setup@v4 | ||||
|     - uses: actions/setup-node@v4.0.4 | ||||
|     - uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version-file: '.node-version' | ||||
|         cache: 'pnpm' | ||||
| @@ -68,14 +68,14 @@ jobs: | ||||
|         fetch-depth: 0 | ||||
|         submodules: true | ||||
|     - uses: pnpm/action-setup@v4 | ||||
|     - uses: actions/setup-node@v4.0.4 | ||||
|     - uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version-file: '.node-version' | ||||
|         cache: 'pnpm' | ||||
|     - run: corepack enable | ||||
|     - run: pnpm i --frozen-lockfile | ||||
|     - name: Restore eslint cache | ||||
|       uses: actions/cache@v4.0.2 | ||||
|       uses: actions/cache@v4.2.0 | ||||
|       with: | ||||
|         path: ${{ env.eslint-cache-path }} | ||||
|         key: eslint-${{ env.eslint-cache-version }}-${{ matrix.workspace }}-${{ hashFiles('**/pnpm-lock.yaml') }}-${{ github.ref_name }}-${{ github.sha }} | ||||
| @@ -98,7 +98,7 @@ jobs: | ||||
|         fetch-depth: 0 | ||||
|         submodules: true | ||||
|     - uses: pnpm/action-setup@v4 | ||||
|     - uses: actions/setup-node@v4.0.4 | ||||
|     - uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version-file: '.node-version' | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/workflows/locale.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/workflows/locale.yml
									
									
									
									
										vendored
									
									
								
							| @@ -19,7 +19,7 @@ jobs: | ||||
|         fetch-depth: 0 | ||||
|         submodules: true | ||||
|     - uses: pnpm/action-setup@v4 | ||||
|     - uses: actions/setup-node@v4.0.4 | ||||
|     - uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version-file: '.node-version' | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										4
									
								
								.github/workflows/on-release-created.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/on-release-created.yml
									
									
									
									
										vendored
									
									
								
							| @@ -17,7 +17,7 @@ jobs: | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|  | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4.1.1 | ||||
| @@ -26,7 +26,7 @@ jobs: | ||||
|       - name: Install pnpm | ||||
|         uses: pnpm/action-setup@v4 | ||||
|       - name: Use Node.js ${{ matrix.node-version }} | ||||
|         uses: actions/setup-node@v4.0.4 | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version: ${{ matrix.node-version }} | ||||
|           cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										7
									
								
								.github/workflows/release-with-dispatch.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/workflows/release-with-dispatch.yml
									
									
									
									
										vendored
									
									
								
							| @@ -60,13 +60,13 @@ jobs: | ||||
|  | ||||
|         ### General | ||||
|         - | ||||
|          | ||||
|  | ||||
|         ### Client | ||||
|         - | ||||
|          | ||||
|  | ||||
|         ### Server | ||||
|         - | ||||
|          | ||||
|  | ||||
|       use_external_app_to_release: ${{ vars.USE_RELEASE_APP == 'true' }} | ||||
|       indent: ${{ vars.INDENT }} | ||||
|     secrets: | ||||
| @@ -86,6 +86,7 @@ jobs: | ||||
|       draft_prerelease_channel: alpha | ||||
|       ready_start_prerelease_channel: beta | ||||
|       prerelease_channel: ${{ inputs.start-rc && 'rc' || '' }} | ||||
|       reset_number_on_channel_change: true | ||||
|     secrets: | ||||
|       RELEASE_APP_ID: ${{ secrets.RELEASE_APP_ID }} | ||||
|       RELEASE_APP_PRIVATE_KEY: ${{ secrets.RELEASE_APP_PRIVATE_KEY }} | ||||
|   | ||||
							
								
								
									
										46
									
								
								.github/workflows/release-with-ready.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										46
									
								
								.github/workflows/release-with-ready.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,46 +0,0 @@ | ||||
| name: "Release Manager: release RC when ready for review" | ||||
|  | ||||
| on: | ||||
|   pull_request: | ||||
|     types: [ready_for_review] | ||||
|  | ||||
| env: | ||||
|   GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
| permissions: | ||||
|   contents: write | ||||
|   issues: write | ||||
|   pull-requests: write | ||||
|  | ||||
| jobs: | ||||
|   check: | ||||
|     runs-on: ubuntu-latest | ||||
|     outputs: | ||||
|       head: ${{ steps.get_pr.outputs.head }} | ||||
|       base: ${{ steps.get_pr.outputs.base }} | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|       # PR情報を取得 | ||||
|       - name: Get PR | ||||
|         run: | | ||||
|           pr_json=$(gh pr view "$PR_NUMBER" --json isDraft,headRefName,baseRefName) | ||||
|           echo "head=$(echo $pr_json | jq -r '.headRefName')" >> $GITHUB_OUTPUT | ||||
|           echo "base=$(echo $pr_json | jq -r '.baseRefName')" >> $GITHUB_OUTPUT | ||||
|         id: get_pr | ||||
|         env: | ||||
|           PR_NUMBER: ${{ github.event.pull_request.number }} | ||||
|   release: | ||||
|     uses: misskey-dev/release-manager-actions/.github/workflows/create-prerelease.yml@v2 | ||||
|     needs: check | ||||
|     if: needs.check.outputs.head == github.event.repository.default_branch && needs.check.outputs.base == vars.STABLE_BRANCH | ||||
|     with: | ||||
|       pr_number: ${{ github.event.pull_request.number }} | ||||
|       user: 'github-actions[bot]' | ||||
|       package_jsons_to_rewrite: ${{ vars.PACKAGE_JSONS_TO_REWRITE }} | ||||
|       use_external_app_to_release: ${{ vars.USE_RELEASE_APP == 'true' }} | ||||
|       indent: ${{ vars.INDENT }} | ||||
|       draft_prerelease_channel: alpha | ||||
|       ready_start_prerelease_channel: beta | ||||
|     secrets: | ||||
|       RELEASE_APP_ID: ${{ secrets.RELEASE_APP_ID }} | ||||
|       RELEASE_APP_PRIVATE_KEY: ${{ secrets.RELEASE_APP_PRIVATE_KEY }} | ||||
							
								
								
									
										4
									
								
								.github/workflows/storybook.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/storybook.yml
									
									
									
									
										vendored
									
									
								
							| @@ -15,6 +15,8 @@ on: | ||||
|  | ||||
| jobs: | ||||
|   build: | ||||
|     # chromatic is not likely to be available for fork repositories, so we disable for fork repositories. | ||||
|     if: github.repository == 'misskey-dev/misskey' | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     env: | ||||
| @@ -41,7 +43,7 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Use Node.js 20.x | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version-file: '.node-version' | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										31
									
								
								.github/workflows/test-backend.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										31
									
								
								.github/workflows/test-backend.yml
									
									
									
									
										vendored
									
									
								
							| @@ -10,19 +10,22 @@ on: | ||||
|       # for permissions | ||||
|       - packages/misskey-js/** | ||||
|       - .github/workflows/test-backend.yml | ||||
|       - .github/misskey/test.yml | ||||
|   pull_request: | ||||
|     paths: | ||||
|       - packages/backend/** | ||||
|       # for permissions | ||||
|       - packages/misskey-js/** | ||||
|       - .github/workflows/test-backend.yml | ||||
|       - .github/misskey/test.yml | ||||
| jobs: | ||||
|   unit: | ||||
|     name: Unit tests (backend) | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|  | ||||
|     services: | ||||
|       postgres: | ||||
| @@ -44,9 +47,22 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Install FFmpeg | ||||
|       uses: FedericoCarboni/setup-ffmpeg@v3 | ||||
|       run: | | ||||
|         for i in {1..3}; do | ||||
|           echo "Attempt $i: Installing FFmpeg..." | ||||
|           curl -s -L https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-amd64-static.tar.xz -o ffmpeg.tar.xz && \ | ||||
|           tar -xf ffmpeg.tar.xz && \ | ||||
|           mv ffmpeg-*-static/ffmpeg /usr/local/bin/ && \ | ||||
|           mv ffmpeg-*-static/ffprobe /usr/local/bin/ && \ | ||||
|           rm -rf ffmpeg.tar.xz ffmpeg-*-static/ && \ | ||||
|           break || sleep 10 | ||||
|           if [ $i -eq 3 ]; then | ||||
|             echo "Failed to install FFmpeg after 3 attempts" | ||||
|             exit 1 | ||||
|           fi | ||||
|         done | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'pnpm' | ||||
| @@ -61,17 +77,18 @@ jobs: | ||||
|     - name: Test | ||||
|       run: pnpm --filter backend test-and-coverage | ||||
|     - name: Upload to Codecov | ||||
|       uses: codecov/codecov-action@v4 | ||||
|       uses: codecov/codecov-action@v5 | ||||
|       with: | ||||
|         token: ${{ secrets.CODECOV_TOKEN }} | ||||
|         files: ./packages/backend/coverage/coverage-final.json | ||||
|  | ||||
|   e2e: | ||||
|     name: E2E tests (backend) | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|  | ||||
|     services: | ||||
|       postgres: | ||||
| @@ -93,7 +110,7 @@ jobs: | ||||
|       - name: Install pnpm | ||||
|         uses: pnpm/action-setup@v4 | ||||
|       - name: Use Node.js ${{ matrix.node-version }} | ||||
|         uses: actions/setup-node@v4.0.4 | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version: ${{ matrix.node-version }} | ||||
|           cache: 'pnpm' | ||||
| @@ -108,7 +125,7 @@ jobs: | ||||
|       - name: Test | ||||
|         run: pnpm --filter backend test-and-coverage:e2e | ||||
|       - name: Upload to Codecov | ||||
|         uses: codecov/codecov-action@v4 | ||||
|         uses: codecov/codecov-action@v5 | ||||
|         with: | ||||
|           token: ${{ secrets.CODECOV_TOKEN }} | ||||
|           files: ./packages/backend/coverage/coverage-final.json | ||||
|   | ||||
							
								
								
									
										73
									
								
								.github/workflows/test-federation.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								.github/workflows/test-federation.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,73 @@ | ||||
| name: Test (federation) | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: | ||||
|       - master | ||||
|       - develop | ||||
|     paths: | ||||
|       - packages/backend/** | ||||
|       - packages/misskey-js/** | ||||
|       - .github/workflows/test-federation.yml | ||||
|   pull_request: | ||||
|     paths: | ||||
|       - packages/backend/** | ||||
|       - packages/misskey-js/** | ||||
|       - .github/workflows/test-federation.yml | ||||
|  | ||||
| jobs: | ||||
|   test: | ||||
|     name: Federation test | ||||
|     runs-on: ubuntu-latest | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [22.11.0] | ||||
|     steps: | ||||
|       - uses: actions/checkout@v4 | ||||
|         with: | ||||
|           submodules: true | ||||
|       - name: Install pnpm | ||||
|         uses: pnpm/action-setup@v4 | ||||
|       - name: Install FFmpeg | ||||
|         run: | | ||||
|           for i in {1..3}; do | ||||
|             echo "Attempt $i: Installing FFmpeg..." | ||||
|             curl -s -L https://johnvansickle.com/ffmpeg/releases/ffmpeg-release-amd64-static.tar.xz -o ffmpeg.tar.xz && \ | ||||
|             tar -xf ffmpeg.tar.xz && \ | ||||
|             mv ffmpeg-*-static/ffmpeg /usr/local/bin/ && \ | ||||
|             mv ffmpeg-*-static/ffprobe /usr/local/bin/ && \ | ||||
|             rm -rf ffmpeg.tar.xz ffmpeg-*-static/ && \ | ||||
|             break || sleep 10 | ||||
|             if [ $i -eq 3 ]; then | ||||
|               echo "Failed to install FFmpeg after 3 attempts" | ||||
|               exit 1 | ||||
|             fi | ||||
|           done | ||||
|       - name: Use Node.js ${{ matrix.node-version }} | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version: ${{ matrix.node-version }} | ||||
|           cache: 'pnpm' | ||||
|       - name: Build Misskey | ||||
|         run: | | ||||
|           corepack enable && corepack prepare | ||||
|           pnpm i --frozen-lockfile | ||||
|           pnpm build | ||||
|       - name: Setup | ||||
|         run: | | ||||
|           cd packages/backend/test-federation | ||||
|           bash ./setup.sh | ||||
|           sudo chmod 644 ./certificates/*.test.key | ||||
|       - name: Start servers | ||||
|         # https://github.com/docker/compose/issues/1294#issuecomment-374847206 | ||||
|         run: | | ||||
|           cd packages/backend/test-federation | ||||
|           docker compose up -d --scale tester=0 | ||||
|       - name: Test | ||||
|         run: | | ||||
|           cd packages/backend/test-federation | ||||
|           docker compose run --no-deps tester | ||||
|       - name: Stop servers | ||||
|         run: | | ||||
|           cd packages/backend/test-federation | ||||
|           docker compose down | ||||
							
								
								
									
										14
									
								
								.github/workflows/test-frontend.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										14
									
								
								.github/workflows/test-frontend.yml
									
									
									
									
										vendored
									
									
								
							| @@ -12,6 +12,7 @@ on: | ||||
|       # for e2e | ||||
|       - packages/backend/** | ||||
|       - .github/workflows/test-frontend.yml | ||||
|       - .github/misskey/test.yml | ||||
|   pull_request: | ||||
|     paths: | ||||
|       - packages/frontend/** | ||||
| @@ -20,13 +21,15 @@ on: | ||||
|       # for e2e | ||||
|       - packages/backend/** | ||||
|       - .github/workflows/test-frontend.yml | ||||
|       - .github/misskey/test.yml | ||||
| jobs: | ||||
|   vitest: | ||||
|     name: Unit tests (frontend) | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v4.1.1 | ||||
| @@ -35,7 +38,7 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'pnpm' | ||||
| @@ -50,18 +53,19 @@ jobs: | ||||
|     - name: Test | ||||
|       run: pnpm --filter frontend test-and-coverage | ||||
|     - name: Upload Coverage | ||||
|       uses: codecov/codecov-action@v4 | ||||
|       uses: codecov/codecov-action@v5 | ||||
|       with: | ||||
|         token: ${{ secrets.CODECOV_TOKEN }} | ||||
|         files: ./packages/frontend/coverage/coverage-final.json | ||||
|  | ||||
|   e2e: | ||||
|     name: E2E tests (frontend) | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       fail-fast: false | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|         browser: [chrome] | ||||
|  | ||||
|     services: | ||||
| @@ -90,7 +94,7 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										7
									
								
								.github/workflows/test-misskey-js.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.github/workflows/test-misskey-js.yml
									
									
									
									
										vendored
									
									
								
							| @@ -16,12 +16,13 @@ on: | ||||
|       - .github/workflows/test-misskey-js.yml | ||||
| jobs: | ||||
|   test: | ||||
|     name: Unit tests (misskey.js) | ||||
|  | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|         # See supported Node.js release schedule at https://nodejs.org/en/about/releases/ | ||||
|  | ||||
|     steps: | ||||
| @@ -31,7 +32,7 @@ jobs: | ||||
|       - run: corepack enable | ||||
|  | ||||
|       - name: Setup Node.js ${{ matrix.node-version }} | ||||
|         uses: actions/setup-node@v4.0.4 | ||||
|         uses: actions/setup-node@v4.1.0 | ||||
|         with: | ||||
|           node-version: ${{ matrix.node-version }} | ||||
|           cache: 'pnpm' | ||||
| @@ -51,7 +52,7 @@ jobs: | ||||
|           CI: true | ||||
|  | ||||
|       - name: Upload Coverage | ||||
|         uses: codecov/codecov-action@v4 | ||||
|         uses: codecov/codecov-action@v5 | ||||
|         with: | ||||
|           token: ${{ secrets.CODECOV_TOKEN }} | ||||
|           files: ./packages/misskey-js/coverage/coverage-final.json | ||||
|   | ||||
							
								
								
									
										5
									
								
								.github/workflows/test-production.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								.github/workflows/test-production.yml
									
									
									
									
										vendored
									
									
								
							| @@ -12,11 +12,12 @@ env: | ||||
|  | ||||
| jobs: | ||||
|   production: | ||||
|     name: Production build | ||||
|     runs-on: ubuntu-latest | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v4.1.1 | ||||
| @@ -25,7 +26,7 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										6
									
								
								.github/workflows/validate-api-json.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/workflows/validate-api-json.yml
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| name: Test (backend) | ||||
| name: api.json validation | ||||
|  | ||||
| on: | ||||
|   push: | ||||
| @@ -18,7 +18,7 @@ jobs: | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         node-version: [20.16.0] | ||||
|         node-version: [22.11.0] | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v4.1.1 | ||||
| @@ -27,7 +27,7 @@ jobs: | ||||
|     - name: Install pnpm | ||||
|       uses: pnpm/action-setup@v4 | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v4.0.4 | ||||
|       uses: actions/setup-node@v4.1.0 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'pnpm' | ||||
|   | ||||
							
								
								
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -37,7 +37,7 @@ coverage | ||||
| !/.config/docker_example.env | ||||
| !/.config/cypress-devcontainer.yml | ||||
| docker-compose.yml | ||||
| compose.yml | ||||
| ./compose.yml | ||||
| .devcontainer/compose.yml | ||||
| !/.devcontainer/compose.yml | ||||
|  | ||||
| @@ -68,6 +68,8 @@ 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 | ||||
|   | ||||
| @@ -1 +1 @@ | ||||
| 20.16.0 | ||||
| 22.11.0 | ||||
|   | ||||
							
								
								
									
										222
									
								
								CHANGELOG.md
									
									
									
									
									
								
							
							
						
						
									
										222
									
								
								CHANGELOG.md
									
									
									
									
									
								
							| @@ -1,3 +1,225 @@ | ||||
| ## 2025.2.0 | ||||
|  | ||||
| ### General | ||||
| - | ||||
|  | ||||
| ### Client | ||||
| - | ||||
|  | ||||
| ### Server | ||||
| - Fix: 個別お知らせページのmetaタグ出力の条件が間違っていたのを修正 | ||||
|  | ||||
|  | ||||
| ## 2025.1.0 | ||||
|  | ||||
| ### Note | ||||
| - [重要] ノート検索プロバイダの追加に伴い、configファイル(default.ymlなど)の構成が少し変わります. | ||||
|   - 新しい設定項目"fulltextSearch.provider"が追加されました. sqlLike, sqlPgroonga, meilisearchのいずれかを設定出来ます. | ||||
|   - すでにMeilisearchをお使いの場合、 **"fulltextSearch.provider"を"meilisearch"に設定する必要** があります. | ||||
|   - 詳細は #14730 および `.config/example.yml` または `.config/docker_example.yml`の'Fulltext search configuration'をご参照願います. | ||||
| - 【開発者向け】従来の開発モードでHMRが機能しない問題が修正されたため、バックエンド・フロントエンド分離型の開発モードが削除されました。開発環境においてconfigの変更が必要となる可能性があります。 | ||||
|  | ||||
| ### General | ||||
| - Feat: カスタム絵文字管理画面をリニューアル #10996 | ||||
| 	* β版として公開のため、旧画面も引き続き利用可能です | ||||
|  | ||||
| ### Client | ||||
| - Enhance: PC画面でチャンネルが複数列で表示されるように   | ||||
|   (Cherry-picked from https://github.com/Otaku-Social/maniakey/pull/13) | ||||
| - Enhance: 照会に失敗した場合、その理由を表示するように | ||||
| - Enhance: ワードミュートで検知されたワードを表示できるように | ||||
| - Enhance: リモートのノートのリンクをコピーできるように | ||||
| - Enhance: 連合がホワイトリスト化・無効化されているサーバー向けのデザイン修正 | ||||
| - Enhance: AiScriptのセーブデータを明示的に削除する関数`Mk:remove`を追加 | ||||
| - Enhance: ノートの添付ファイルを一覧で遡れる「ファイル」タブを追加   | ||||
|   (Based on https://github.com/Otaku-Social/maniakey/pull/14) | ||||
| - Enhance: AiScriptの拡張API関数において引数の型チェックをより厳格に | ||||
| - Enhance: クエリパラメータでuiを一時的に変更できるように #15240 | ||||
| - Enhance: リモート絵文字のインポート時に詳細を確認できるように #15336 | ||||
| - Fix: 画面サイズが変わった際にナビゲーションバーが自動で折りたたまれない問題を修正 | ||||
| - Fix: サーバー情報メニューに区切り線が不足していたのを修正 | ||||
| - Fix: ノートがログインしているユーザーしか見れない場合にログインダイアログを閉じるとその後の動線がなくなる問題を修正 | ||||
| - Fix: 公開範囲がホームのノートの埋め込みウィジェットが読み込まれない問題を修正   | ||||
|   (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/803) | ||||
| - Fix: 絵文字管理画面で一部の絵文字が表示されない問題を修正 | ||||
| - Fix: プラグイン `register_note_view_interruptor` でノートのサーバー情報の書き換えができない問題を修正 | ||||
| - Fix: Botプロテクションの設定変更時は実際に検証を通過しないと保存できないように( #15137 ) | ||||
| - Fix: ノート検索が使用できない場合でもチャンネルのノート検索欄がでていた問題を修正 | ||||
| - Fix: `Ui:C:select`で値の変更が画面に反映されない問題を修正 | ||||
| - Fix: MiAuth認可画面で、認可処理に失敗した場合でもコールバックURLに遷移してしまう問題を修正   | ||||
|   (Cherry-picked from https://github.com/TeamNijimiss/misskey/commit/800359623e41a662551d774de15b0437b6849bb4) | ||||
| - Fix: ノート作成画面でファイルの添付可能個数を超えてもノートボタンが押せていた問題を修正 | ||||
| - Fix: 「アカウントを管理」画面で、ユーザー情報の取得に失敗したアカウント(削除されたアカウントなど)が表示されない問題を修正 | ||||
| - Fix: MacOSでChrome系ブラウザを使用している場合に、Misskeyを閉じた際に他のタブのオーディオ機能と干渉する問題を修正 | ||||
| - Fix: 言語データのキャッシュ状況によっては、埋め込みウィジェットが正しく起動しない問題を修正 | ||||
| - Fix: 「削除して編集」でノートの引用を解除出来なかった問題を修正( #14476 ) | ||||
| - Fix: RSSウィジェットが正しく表示されない問題を修正   | ||||
|   (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/857) | ||||
| - Fix: ワードミュートの保存失敗時にAPIエラーが握りつぶされる事があるのを修正 | ||||
| - Fix: アンケートでリモートの絵文字が正しく描画できない問題の修正 | ||||
|   (Cherry-picked from https://github.com/yojo-art/cherrypick/pull/153) | ||||
| - Fix: 非ログイン時のサーバー概要画面のメニューボタンが押せないことがあるのを修正   | ||||
|   (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/656) | ||||
| - Fix: URLにはじめから`#pswp`が含まれている場合に画像ビューワーがブラウザの戻るボタンで閉じられない問題を修正 | ||||
| - Fix: ロール作成画面で設定できるアイコンデコレーションの最大取付個数を16に制限 | ||||
| - Fix: Firefox Nightlyなどでアイコンが読み込めない問題を修正 | ||||
|  | ||||
| ### Server | ||||
| - Enhance: pg_bigmが利用できるよう、ノートの検索をILIKE演算子でなくLIKE演算子でLOWER()をかけたテキストに対して行うように | ||||
| - Enhance: ノート検索の選択肢としてpgroongaに対応 ( #14730 ) | ||||
| - Enhance: チャート更新時にDBに同時接続しないように   | ||||
|   (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/830) | ||||
| - Enhance: config(default.yml)からSQLログ全文を出力するか否かを設定可能に ( #15266 ) | ||||
| - Fix: ユーザーのプロフィール画面をアドレス入力などで直接表示した際に概要タブの描画に失敗する問題の修正( #15032 ) | ||||
| - Fix: 起動前の疎通チェックが機能しなくなっていた問題を修正   | ||||
|   (Cherry-picked from https://activitypub.software/TransFem-org/Sharkey/-/merge_requests/737) | ||||
| - Fix: ノートの閲覧にログイン必須にしてもFeedでノートが表示されてしまう問題を修正 | ||||
| - Fix: 絵文字の連合でライセンス欄を相互にやり取りするように ( #10859, #14109 ) | ||||
| - Fix: ロックダウンされた期間指定のノートがStreaming経由でLTLに出現するのを修正 ( #15200 ) | ||||
| - Fix: disableClustering設定時の初期化ロジックを調整( #15223 ) | ||||
| - Fix: URLとURIが異なるエンティティの照会に失敗する問題を修正( #15039 ) | ||||
| - Fix: ActivityPubリクエストかどうかの判定が正しくない問題を修正   | ||||
|   (Cherry-picked from https://github.com/MisskeyIO/misskey/pull/869) | ||||
| - Fix: `/api/pages/update`にて`name`を指定せずにリクエストするとエラーが発生する問題を修正 | ||||
| - Fix: AIセンシティブ判定が arm64 環境で動作しない問題を修正 | ||||
| - Fix: 非Misskey系のソフトウェアからHTML`<ruby>`タグを含むノートを受信した場合、MFMの読み仮名(ルビ)文法に変換して表示 | ||||
| - Fix: 連合OFFで投稿されたノートに対する冗長な処理を抑止 ( #15018 ) | ||||
| - Fix: `/api.json`のレスポンスが2回目のリクエスト以降おかしくなる問題を修正 | ||||
|  | ||||
| ### Misskey.js | ||||
| - Feat: allow setting `binaryType` of WebSocket connection | ||||
|  | ||||
| ## 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 | ||||
|   | ||||
							
								
								
									
										115
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						
									
										115
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							| @@ -64,9 +64,29 @@ Thank you for your PR! Before creating a PR, please check the following: | ||||
|  | ||||
| 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:<name of extended property>`. (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? | ||||
| @@ -81,6 +101,22 @@ Be willing to comment on the good points and not just the things you want fixed | ||||
| 	- 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. | ||||
| ``` | ||||
| @@ -116,7 +152,8 @@ 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. | ||||
| 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. | ||||
|  | ||||
|  | ||||
|  | ||||
| @@ -160,52 +197,51 @@ 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). | ||||
| - Vite HMR (just the `vite` command) is available. The behavior may be different from production. | ||||
| - Vite runs behind the backend (the backend will proxy Vite at /vite and /embed_vite except for websocket used for HMR). | ||||
| - 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 | ||||
| - Test codes are located in [`/packages/backend/test`](/packages/backend/test). | ||||
|  | ||||
| ### Run test | ||||
| Create a config file. | ||||
| 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 .github/misskey/test.yml .config/ | ||||
| ``` | ||||
| Prepare DB/Redis for testing. | ||||
| ``` | ||||
|  | ||||
| 2. Start DB and Redis servers for testing: | ||||
| ```sh | ||||
| docker compose -f packages/backend/test/compose.yml up | ||||
| ``` | ||||
| Alternatively, prepare an empty (data can be erased) DB and edit `.config/test.yml`. | ||||
| Instead, you can prepare an empty (data can be erased) DB and edit `.config/test.yml` appropriately. | ||||
|  | ||||
| Run all test. | ||||
| 3. Run all tests: | ||||
| ```sh | ||||
| pnpm --filter backend test     # unit tests | ||||
| pnpm --filter backend test:e2e # single-server E2E tests | ||||
| ``` | ||||
| pnpm test | ||||
| 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 | ||||
| ``` | ||||
|  | ||||
| #### Run specify test | ||||
| ``` | ||||
| pnpm jest -- foo.ts | ||||
| ``` | ||||
|  | ||||
| ### e2e tests | ||||
| TODO | ||||
| #### Running Multiple-server E2E Tests | ||||
| See [`/packages/backend/test-federation/README.md`](/packages/backend/test-federation/README.md). | ||||
|  | ||||
| ## Environment Variable | ||||
|  | ||||
| @@ -440,6 +476,11 @@ describe('test', () => { | ||||
| コード上でMisskeyのドメイン固有の概念には`Mi`をprefixすることで、他のドメインの同様の概念と区別できるほか、名前の衝突を防ぐ。 | ||||
| ただし、文脈上Misskeyのものを指すことが明らかであり、名前の衝突の恐れがない場合は、一時的なローカル変数に限って`Mi`を省略してもよい。 | ||||
|  | ||||
| ### Misskey.jsの型生成 | ||||
| ```bash | ||||
| pnpm build-misskey-js-with-types | ||||
| ``` | ||||
|  | ||||
| ### How to resolve conflictions occurred at pnpm-lock.yaml? | ||||
|  | ||||
| Just execute `pnpm` to fix it. | ||||
| @@ -578,18 +619,18 @@ ESMではディレクトリインポートは廃止されているのと、デ | ||||
| ### Lighten CSS vars | ||||
|  | ||||
| ``` css | ||||
| color: hsl(from var(--accent) h s calc(l + 10)); | ||||
| color: hsl(from var(--MI_THEME-accent) h s calc(l + 10)); | ||||
| ``` | ||||
|  | ||||
| ### Darken CSS vars | ||||
|  | ||||
| ``` css | ||||
| color: hsl(from var(--accent) h s calc(l - 10)); | ||||
| color: hsl(from var(--MI_THEME-accent) h s calc(l - 10)); | ||||
| ``` | ||||
|  | ||||
| ### Add alpha to CSS vars | ||||
|  | ||||
| ``` css | ||||
| color: color(from var(--accent) srgb r g b / 0.5); | ||||
| color: color(from var(--MI_THEME-accent) srgb r g b / 0.5); | ||||
| ``` | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								COPYING
									
									
									
									
									
								
							| @@ -1,5 +1,5 @@ | ||||
| Unless otherwise stated this repository is | ||||
| Copyright © 2014-2024 syuilo and contributors | ||||
| Copyright © 2014-2025 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. | ||||
|  | ||||
|   | ||||
| @@ -1,6 +1,6 @@ | ||||
| # syntax = docker/dockerfile:1.4 | ||||
|  | ||||
| ARG NODE_VERSION=20.16.0-bullseye | ||||
| ARG NODE_VERSION=22.11.0-bookworm | ||||
|  | ||||
| # build assets & compile TypeScript | ||||
|  | ||||
|   | ||||
| @@ -6,3 +6,10 @@ This will allow us to assess the risk, and make a fix available before we add a | ||||
| bug report to the GitHub repository. | ||||
|  | ||||
| Thanks for helping make Misskey 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. | ||||
|   | ||||
| @@ -23,6 +23,7 @@ describe('Before setup instance', () => { | ||||
|  | ||||
| 		cy.intercept('POST', '/api/admin/accounts/create').as('signup'); | ||||
|  | ||||
| 		cy.get('[data-cy-admin-initial-password] input').type('example_password_please_change_this_or_you_will_get_hacked'); | ||||
| 		cy.get('[data-cy-admin-username] input').type('admin'); | ||||
| 		cy.get('[data-cy-admin-password] input').type('admin1234'); | ||||
| 		cy.get('[data-cy-admin-ok]').click(); | ||||
| @@ -119,11 +120,16 @@ describe('After user signup', () => { | ||||
| 	it('signin', () => { | ||||
| 		cy.visitHome(); | ||||
|  | ||||
| 		cy.intercept('POST', '/api/signin').as('signin'); | ||||
| 		cy.intercept('POST', '/api/signin-flow').as('signin'); | ||||
|  | ||||
| 		cy.get('[data-cy-signin]').click(); | ||||
| 		cy.get('[data-cy-signin-username] input').type('alice'); | ||||
| 		// Enterキーでサインインできるかの確認も兼ねる | ||||
|  | ||||
| 		cy.get('[data-cy-signin-page-input]').should('be.visible', { timeout: 1000 }); | ||||
| 		// Enterキーで続行できるかの確認も兼ねる | ||||
| 		cy.get('[data-cy-signin-username] input').type('alice{enter}'); | ||||
|  | ||||
| 		cy.get('[data-cy-signin-page-password]').should('be.visible', { timeout: 10000 }); | ||||
| 		// Enterキーで続行できるかの確認も兼ねる | ||||
| 		cy.get('[data-cy-signin-password] input').type('alice1234{enter}'); | ||||
|  | ||||
| 		cy.wait('@signin'); | ||||
| @@ -138,8 +144,9 @@ describe('After user signup', () => { | ||||
| 		cy.visitHome(); | ||||
|  | ||||
| 		cy.get('[data-cy-signin]').click(); | ||||
| 		cy.get('[data-cy-signin-username] input').type('alice'); | ||||
| 		cy.get('[data-cy-signin-password] input').type('alice1234{enter}'); | ||||
|  | ||||
| 		cy.get('[data-cy-signin-page-input]').should('be.visible', { timeout: 1000 }); | ||||
| 		cy.get('[data-cy-signin-username] input').type('alice{enter}'); | ||||
|  | ||||
| 		// TODO: cypressにブラウザの言語指定できる機能が実装され次第英語のみテストするようにする | ||||
| 		cy.contains(/アカウントが凍結されています|This account has been suspended due to/gi); | ||||
|   | ||||
| @@ -48,16 +48,19 @@ Cypress.Commands.add('registerUser', (username, password, isAdmin = false) => { | ||||
| 	cy.request('POST', route, { | ||||
| 		username: username, | ||||
| 		password: password, | ||||
| 		...(isAdmin ? { setupPassword: 'example_password_please_change_this_or_you_will_get_hacked' } : {}), | ||||
| 	}).its('body').as(username); | ||||
| }); | ||||
|  | ||||
| Cypress.Commands.add('login', (username, password) => { | ||||
| 	cy.visitHome(); | ||||
|  | ||||
| 	cy.intercept('POST', '/api/signin').as('signin'); | ||||
| 	cy.intercept('POST', '/api/signin-flow').as('signin'); | ||||
|  | ||||
| 	cy.get('[data-cy-signin]').click(); | ||||
| 	cy.get('[data-cy-signin-username] input').type(username); | ||||
| 	cy.get('[data-cy-signin-page-input]').should('be.visible', { timeout: 1000 }); | ||||
| 	cy.get('[data-cy-signin-username] input').type(`${username}{enter}`); | ||||
| 	cy.get('[data-cy-signin-page-password]').should('be.visible', { timeout: 10000 }); | ||||
| 	cy.get('[data-cy-signin-password] input').type(`${password}{enter}`); | ||||
|  | ||||
| 	cy.wait('@signin').as('signedIn'); | ||||
|   | ||||
| @@ -7,8 +7,8 @@ | ||||
| import { action } from '@storybook/addon-actions'; | ||||
| import { StoryObj } from '@storybook/vue3'; | ||||
| import { HttpResponse, http } from 'msw'; | ||||
| import { abuseUserReport } from '../../.storybook/fakes.js'; | ||||
| import { commonHandlers } from '../../.storybook/mocks.js'; | ||||
| import { abuseUserReport } from '../packages/frontend/.storybook/fakes.js'; | ||||
| import { commonHandlers } from '../packages/frontend/.storybook/mocks.js'; | ||||
| import MkAbuseReport from './MkAbuseReport.vue'; | ||||
| export const Default = { | ||||
| 	render(args) { | ||||
| @@ -34,7 +34,7 @@ defineProps<{ | ||||
| 	width: 100%; | ||||
| 	height: 100%; | ||||
| 	cursor: not-allowed; | ||||
| 	--color: color(from var(--error) srgb r g b / 0.25); | ||||
| 	--color: color(from var(--MI_THEME-error) srgb r g b / 0.25); | ||||
| 	background-size: auto auto; | ||||
| 	background-image: repeating-linear-gradient(135deg, transparent, transparent 10px, var(--color) 4px, var(--color) 14px); | ||||
| } | ||||
|   | ||||
| @@ -343,7 +343,6 @@ enableLocalTimeline: "تفعيل الخيط المحلي" | ||||
| enableGlobalTimeline: "تفعيل الخيط الزمني الشامل" | ||||
| disablingTimelinesInfo: "سيتمكن المديرون والمشرفون من الوصول إلى كل الخيوط الزمنية حتى وإن لم تفعّل." | ||||
| registration: "إنشاء حساب" | ||||
| enableRegistration: "تفعيل إنشاء الحسابات الجديدة" | ||||
| invite: "دعوة" | ||||
| driveCapacityPerLocalAccount: "حصة التخزين لكل مستخدم محلي" | ||||
| driveCapacityPerRemoteAccount: "حصة التخزين لكل مستخدم بعيد" | ||||
| @@ -626,10 +625,7 @@ abuseReported: "أُرسل البلاغ، شكرًا لك" | ||||
| reporter: "المُبلّغ" | ||||
| reporteeOrigin: "أصل البلاغ" | ||||
| reporterOrigin: "أصل المُبلّغ" | ||||
| forwardReport: "وجّه البلاغ إلى المثيل البعيد" | ||||
| forwardReportIsAnonymous: "في المثيل البعيد سيظهر المبلّغ كحساب مجهول." | ||||
| send: "أرسل" | ||||
| abuseMarkAsResolved: "علّم البلاغ كمحلول" | ||||
| openInNewTab: "افتح في لسان جديد" | ||||
| defaultNavigationBehaviour: "سلوك الملاحة الافتراضي" | ||||
| editTheseSettingsMayBreakAccount: "تعديل هذه الإعدادات قد يسبب عطبًا لحسابك" | ||||
| @@ -1255,7 +1251,6 @@ _theme: | ||||
|     buttonBg: "خلفية الأزرار" | ||||
|     buttonHoverBg: "خلفية الأزرار (عند التمرير فوقها)" | ||||
|     inputBorder: "حواف حقل الإدخال" | ||||
|     listItemHoverBg: "خلفية عناصر القائمة (عند التمرير فوقها)" | ||||
|     driveFolderBg: "خلفية مجلد قرص التخزين" | ||||
|     messageBg: "خلفية المحادثة" | ||||
| _sfx: | ||||
| @@ -1533,6 +1528,7 @@ _notification: | ||||
|     reaction: "التفاعل" | ||||
|     receiveFollowRequest: "طلبات المتابعة" | ||||
|     followRequestAccepted: "طلبات المتابعة المقبولة" | ||||
|     login: "لِج" | ||||
|     app: "إشعارات التطبيقات المرتبطة" | ||||
|   _actions: | ||||
|     followBack: "تابعك بالمثل" | ||||
| @@ -1588,3 +1584,6 @@ _reversi: | ||||
| _offlineScreen: | ||||
|   title: "غير متصل - يتعذر الاتصال بالخادم" | ||||
|   header: "يتعذر الاتصال بالخادم" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "غير موجود" | ||||
|   | ||||
| @@ -339,7 +339,6 @@ enableLocalTimeline: "স্থানীয় টাইমলাইন চাল | ||||
| enableGlobalTimeline: "গ্লোবাল টাইমলাইন চালু করুন" | ||||
| disablingTimelinesInfo: "আপনি এই টাইমলাইনগুলি বন্ধ করলেও প্রশাসক এবং মডারেটররা এই টাইমলাইনগুলি ব্যাবহার করতে পারবে" | ||||
| registration: "নিবন্ধন" | ||||
| enableRegistration: "নতুন ব্যাবহারকারী নিবন্ধন চালু করুন" | ||||
| invite: "আমন্ত্রণ" | ||||
| driveCapacityPerLocalAccount: "প্রত্যেক স্থানীয় ব্যাবহারকারীর জন্য ড্রাইভের জায়গা" | ||||
| driveCapacityPerRemoteAccount: "প্রত্যেক রিমোট ব্যাবহারকারীর জন্য ড্রাইভের জায়গা" | ||||
| @@ -624,10 +623,7 @@ abuseReported: "আপনার অভিযোগটি দাখিল কর | ||||
| reporter: "অভিযোগকারী" | ||||
| reporteeOrigin: "অভিযোগটির উৎস" | ||||
| reporterOrigin: "অভিযোগকারীর উৎস" | ||||
| forwardReport: "রিমোট ইন্সত্যান্সে অভিযোগটি পাঠান" | ||||
| forwardReportIsAnonymous: "আপনার তথ্য রিমোট ইন্সত্যান্সে পাঠানো হবে না এবং একটি বেনামী সিস্টেম অ্যাকাউন্ট হিসাবে প্রদর্শিত হবে।" | ||||
| send: "পাঠান" | ||||
| abuseMarkAsResolved: "অভিযোগটিকে সমাধাকৃত হিসাবে চিহ্নিত করুন" | ||||
| openInNewTab: "নতুন ট্যাবে খুলুন" | ||||
| openInSideView: "সাইড ভিউতে খুলুন" | ||||
| defaultNavigationBehaviour: "ডিফল্ট নেভিগেশন" | ||||
| @@ -1020,7 +1016,6 @@ _theme: | ||||
|     buttonBg: "বাটনের পটভূমি" | ||||
|     buttonHoverBg: "বাটনের পটভূমি (হভার)" | ||||
|     inputBorder: "ইনপুট ফিল্ডের বর্ডার" | ||||
|     listItemHoverBg: "লিস্ট আইটেমের পটভূমি (হোভার)" | ||||
|     driveFolderBg: "ড্রাইভ ফোল্ডারের পটভূমি" | ||||
|     wallpaperOverlay: "ওয়ালপেপার ওভারলে" | ||||
|     badge: "ব্যাজ" | ||||
| @@ -1313,6 +1308,7 @@ _notification: | ||||
|     pollEnded: "পোল শেষ" | ||||
|     receiveFollowRequest: "প্রাপ্ত অনুসরণের অনুরোধসমূহ" | ||||
|     followRequestAccepted: "গৃহীত অনুসরণের অনুরোধসমূহ" | ||||
|     login: "প্রবেশ করুন" | ||||
|     app: "লিঙ্ক করা অ্যাপ থেকে বিজ্ঞপ্তি" | ||||
|   _actions: | ||||
|     followBack: "ফলো ব্যাক করেছে" | ||||
| @@ -1352,3 +1348,6 @@ _moderationLogTypes: | ||||
|   resetPassword: "পাসওয়ার্ড রিসেট করুন" | ||||
| _reversi: | ||||
|   total: "মোট" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "পাওয়া যায়নি" | ||||
|   | ||||
| @@ -2,71 +2,76 @@ | ||||
| _lang_: "Català" | ||||
| headlineMisskey: "Una xarxa connectada per notes" | ||||
| introMisskey: "Benvingut! Misskey és un servei de microblogging descentralitzat de codi obert.\nCrea \"notes\" per compartir els teus pensaments amb tots els que t'envolten. 📡\nAmb \"reaccions\", també pots expressar ràpidament els teus sentiments sobre les notes de tothom. 👍\nExplorem un món nou! 🚀" | ||||
| poweredByMisskeyDescription: "{name} És un del serveis (anomenats instàncies de Misskey) que utilitzen la plataforma de codi obert <b>Misskey</b>." | ||||
| poweredByMisskeyDescription: "{name} És un dels serveis (anomenats instàncies de Misskey) que utilitzen la plataforma de codi obert <b>Misskey</b>." | ||||
| monthAndDay: "{day}/{month}" | ||||
| search: "Cercar" | ||||
| reset: "Reiniciar" | ||||
| notifications: "Notificacions" | ||||
| username: "Nom d'usuari" | ||||
| password: "Contrasenya" | ||||
| forgotPassword: "Contrasenya oblidada" | ||||
| fetchingAsApObject: "Cercant en el Fediverse..." | ||||
| initialPasswordForSetup: "Contrasenya inicial per fer la primera configuració " | ||||
| initialPasswordIsIncorrect: "La contrasenya no és correcta." | ||||
| initialPasswordForSetupDescription: "Fes servir la contrasenya que has fet servir al fitxer de configuració, si tu mateix has instal·lat Misskey.\nSi fas servir una empresa d'allotjament de Misskey, fes servir la contrasenya que t'han donat.\nSi no has posat cap contrasenya deixar l'espai en blanc." | ||||
| forgotPassword: "Restableix la contrasenya " | ||||
| fetchingAsApObject: "Cercant al Fediverse..." | ||||
| ok: "OK" | ||||
| gotIt: "Ho he entès!" | ||||
| gotIt: "D'acord " | ||||
| cancel: "Cancel·lar" | ||||
| noThankYou: "No, gràcies" | ||||
| enterUsername: "Introdueix el teu nom d'usuari" | ||||
| renotedBy: "Impulsat per {usuari}" | ||||
| renotedBy: "Impulsat per {user}" | ||||
| noNotes: "Cap nota" | ||||
| noNotifications: "Cap notificació" | ||||
| instance: "Servidor" | ||||
| instance: "Instància " | ||||
| settings: "Preferències" | ||||
| notificationSettings: "Paràmetres de notificacions" | ||||
| notificationSettings: "Configurar les notificacions" | ||||
| basicSettings: "Configuració bàsica" | ||||
| otherSettings: "Configuració avançada" | ||||
| openInWindow: "Obrir en una nova finestra" | ||||
| otherSettings: "Altres configuracions" | ||||
| openInWindow: "Obrir en una finestra nova" | ||||
| profile: "Perfil" | ||||
| timeline: "Línia de temps" | ||||
| noAccountDescription: "Aquest usuari encara no ha escrit la seva biografia." | ||||
| login: "Iniciar sessió" | ||||
| loggingIn: "Identificant-se" | ||||
| loggingIn: "Iniciar la sessió " | ||||
| logout: "Tancar la sessió" | ||||
| signup: "Registrar-se" | ||||
| uploading: "Pujant..." | ||||
| save: "Desa" | ||||
| users: "Usuaris" | ||||
| addUser: "Afegir un usuari" | ||||
| favorite: "Afegir a preferits" | ||||
| favorite: "Afegeix als preferits" | ||||
| favorites: "Favorits" | ||||
| unfavorite: "Eliminar dels preferits" | ||||
| favorited: "Afegit als preferits." | ||||
| alreadyFavorited: "Ja s'ha afegit als preferits." | ||||
| cantFavorite: "No s'ha pogut afegir als preferits." | ||||
| pin: "Fixar al perfil" | ||||
| cantFavorite: "No es pot afegir als preferits." | ||||
| pin: "Fixa al perfil" | ||||
| unpin: "Para de fixar del perfil" | ||||
| copyContent: "Copiar el contingut" | ||||
| copyLink: "Copiar l'enllaç" | ||||
| copyContent: "Copia el contingut" | ||||
| copyLink: "Copia l'enllaç" | ||||
| copyRemoteLink: "Copiar l'enllaç remot" | ||||
| copyLinkRenote: "Copiar l'enllaç de la renota" | ||||
| delete: "Elimina" | ||||
| deleteAndEdit: "Elimina i edita" | ||||
| deleteAndEdit: "Eliminar i editar" | ||||
| deleteAndEditConfirm: "Segur que vols eliminar aquesta publicació i editar-la? Perdràs totes les reaccions, impulsos i respostes." | ||||
| addToList: "Afegir a una llista" | ||||
| addToAntenna: "Afegir a l'antena" | ||||
| addToAntenna: "Afegir a una antena" | ||||
| sendMessage: "Enviar un missatge" | ||||
| copyRSS: "Copiar RSS" | ||||
| copyUsername: "Copiar nom d'usuari" | ||||
| copyUserId: "Copiar ID d'usuari" | ||||
| copyNoteId: "Copiar ID de nota" | ||||
| copyFileId: "Copiar ID d'arxiu" | ||||
| copyFolderId: "Copiar ID de carpeta" | ||||
| copyProfileUrl: "Copiar URL del perfil" | ||||
| copyNoteId: "Copiar ID de la nota" | ||||
| copyFileId: "Copiar ID de l'arxiu" | ||||
| copyFolderId: "Copiar ID de la carpeta" | ||||
| copyProfileUrl: "Copiar adreça URL del perfil" | ||||
| searchUser: "Cercar un usuari" | ||||
| searchThisUsersNotes: "Cerca les publicacions de l'usuari" | ||||
| reply: "Respondre" | ||||
| searchThisUsersNotes: "Cercar les publicacions de l'usuari" | ||||
| reply: "Respon" | ||||
| loadMore: "Carregar més" | ||||
| showMore: "Veure més" | ||||
| showLess: "Mostra menys" | ||||
| showLess: "Mostrar menys" | ||||
| youGotNewFollower: "t'ha seguit" | ||||
| receiveFollowRequest: "Sol·licitud de seguiment rebuda" | ||||
| receiveFollowRequest: "Has rebut una sol·licitud de seguiment" | ||||
| followRequestAccepted: "Sol·licitud de seguiment acceptada" | ||||
| mention: "Menció" | ||||
| mentions: "Mencions" | ||||
| @@ -75,78 +80,78 @@ importAndExport: "Importar / Exportar" | ||||
| import: "Importar" | ||||
| export: "Exporta" | ||||
| files: "Fitxers" | ||||
| download: "Baixar" | ||||
| driveFileDeleteConfirm: "Estàs segur que vols suprimir el fitxer \"{name}\"? Les notes associades a aquest fitxer adjunt també se suprimiran." | ||||
| unfollowConfirm: "Estàs segur que vols deixar de seguir {name}?" | ||||
| exportRequested: "Has sol·licitat una exportació. Això pot trigar una estona. S'afegirà a la teva unitat un cop completat." | ||||
| importRequested: "Has sol·licitat una importació. Això pot trigar una estona." | ||||
| download: "Descarregar" | ||||
| driveFileDeleteConfirm: "Estàs segur que vols suprimir el fitxer \"{name}\"? Les notes associades a aquest fitxer també seran esborrades." | ||||
| unfollowConfirm: "Segur que vols deixar de seguir a {name}?" | ||||
| exportRequested: "Has sol·licitat una exportació de dades. Això pot trigar una estona. S'afegirà a la teva unitat de disc un cop estigui completada." | ||||
| importRequested: "Has sol·licitat una importació de dades. Això pot trigar una estona." | ||||
| lists: "Llistes" | ||||
| noLists: "No tens cap llista" | ||||
| note: "Nota" | ||||
| notes: "Notes" | ||||
| following: "Seguint" | ||||
| following: "Segueixes " | ||||
| followers: "Seguidors" | ||||
| followsYou: "Et segueix" | ||||
| createList: "Crear llista" | ||||
| manageLists: "Gestionar les llistes" | ||||
| error: "Error" | ||||
| somethingHappened: "S'ha produït un error" | ||||
| retry: "Torna-ho a intentar" | ||||
| retry: "Torna-ho a provar" | ||||
| pageLoadError: "S'ha produït un error en carregar la pàgina" | ||||
| pageLoadErrorDescription: "Això normalment es deu a errors de xarxa o a la memòria cau del navegador. Prova d'esborrar la memòria cau i torna-ho a provar després d'esperar una estona." | ||||
| pageLoadErrorDescription: "Això normalment és a causa d'errors a la xarxa o a la memòria cau del navegador. Prova d'esborrar la memòria cau i torna-ho a provar després d'esperar un temps." | ||||
| serverIsDead: "Aquest servidor no respon. Espera una estona i torna-ho a provar." | ||||
| youShouldUpgradeClient: "Per veure aquesta pàgina, actualitzeu-la per actualitzar el vostre client." | ||||
| enterListName: "Introdueix un nom per a la llista" | ||||
| privacy: "Privadesa" | ||||
| makeFollowManuallyApprove: "Les sol·licituds de seguiment requereixen aprovació" | ||||
| defaultNoteVisibility: "Visibilitat per defecte" | ||||
| follow: "Seguint" | ||||
| followRequest: "Enviar la sol·licitud de seguiment" | ||||
| followRequests: "Sol·licituds de seguiment" | ||||
| follow: "Segueix" | ||||
| followRequest: "Enviar sol·licitud de seguiment" | ||||
| followRequests: "Peticions de seguiment" | ||||
| unfollow: "Deixar de seguir" | ||||
| followRequestPending: "Sol·licituds de seguiment pendents" | ||||
| enterEmoji: "Introduir un emoji" | ||||
| renote: "Impulsa" | ||||
| renote: "Impulsar " | ||||
| unrenote: "Anul·la l'impuls" | ||||
| renoted: "S'ha impulsat" | ||||
| renotedToX: "Impulsat per {name}." | ||||
| cantRenote: "No es pot impulsar aquesta publicació" | ||||
| cantReRenote: "No es pot impulsar l'impuls." | ||||
| cantReRenote: "No es pot impulsar un impuls." | ||||
| quote: "Cita" | ||||
| inChannelRenote: "Renotar només al Canal" | ||||
| inChannelQuote: "Citar només al Canal" | ||||
| renoteToChannel: "Impulsa a un canal" | ||||
| renoteToOtherChannel: "Impulsa a un altre canal" | ||||
| inChannelRenote: "Impulsar només a un canal" | ||||
| inChannelQuote: "Citar només a un canal" | ||||
| renoteToChannel: "Impulsar a un canal" | ||||
| renoteToOtherChannel: "Impulsar a un altre canal" | ||||
| pinnedNote: "Nota fixada" | ||||
| pinned: "Fixar al perfil" | ||||
| you: "Tu" | ||||
| clickToShow: "Fes clic per mostrar" | ||||
| sensitive: "NSFW" | ||||
| sensitive: "Sensible" | ||||
| add: "Afegir" | ||||
| reaction: "Reaccions" | ||||
| reaction: "Reacció " | ||||
| reactions: "Reaccions" | ||||
| emojiPicker: "Selecció d'emojis" | ||||
| pinnedEmojisForReactionSettingDescription: "Selecciona l'emoji amb el qual reaccionar" | ||||
| pinnedEmojisSettingDescription: "Selecciona l'emoji amb el qual reaccionar" | ||||
| emojiPickerDisplay: "Visualitza el selector d'emojis" | ||||
| emojiPicker: "Selector d'emojis" | ||||
| pinnedEmojisForReactionSettingDescription: "Selecciona l'emoji amb qui vols reaccionar" | ||||
| pinnedEmojisSettingDescription: "Selecciona quins emojis vols deixar fixats i es mostrin en obrir el selector d'emojis" | ||||
| emojiPickerDisplay: "Mostrar el selector d'emojis" | ||||
| overwriteFromPinnedEmojisForReaction: "Reemplaça els emojis de la reacció" | ||||
| overwriteFromPinnedEmojis: "Sobreescriu des dels emojis fixats" | ||||
| overwriteFromPinnedEmojis: "Sobreescriu els emojis fixats al panel de reaccions" | ||||
| reactionSettingDescription2: "Arrossega per reordenar, fes clic per suprimir, prem \"+\" per afegir." | ||||
| rememberNoteVisibility: "Recorda la configuració de visibilitat de les notes" | ||||
| attachCancel: "Eliminar el fitxer adjunt" | ||||
| deleteFile: "Esborrar l'arxiu " | ||||
| markAsSensitive: "Marcar com a NSFW" | ||||
| markAsSensitive: "Marcar com a sensible" | ||||
| unmarkAsSensitive: "Deixar de marcar com a sensible" | ||||
| enterFileName: "Defineix nom del fitxer" | ||||
| mute: "Silencia" | ||||
| unmute: "Deixa de silenciar" | ||||
| renoteMute: "Silenciar Renotes" | ||||
| renoteUnmute: "Treure el silenci de les renotes" | ||||
| renoteMute: "Silenciar impulsos" | ||||
| renoteUnmute: "Treure el silenci dels impulsos" | ||||
| block: "Bloqueja" | ||||
| unblock: "Desbloqueja" | ||||
| suspend: "Suspèn" | ||||
| unsuspend: "Deixa de suspendre" | ||||
| blockConfirm: "Vols bloquejar?" | ||||
| blockConfirm: "Vols bloquejar-lo?" | ||||
| unblockConfirm: "Vols desbloquejar-lo?" | ||||
| suspendConfirm: "Estàs segur que vols suspendre aquest compte?" | ||||
| unsuspendConfirm: "Estàs segur que vols treure la suspensió d'aquest compte?" | ||||
| @@ -172,11 +177,11 @@ youCanCleanRemoteFilesCache: "Pots netejar la memòria cau fent clic al botó de | ||||
| cacheRemoteSensitiveFiles: "Posar a la memòria cau arxius remots sensibles" | ||||
| cacheRemoteSensitiveFilesDescription: "Quan aquesta opció és desactiva, els arxius remots sensibles es carregant directament del servidor d'origen sense que es guardin a la memòria cau." | ||||
| flagAsBot: "Marca aquest compte com a bot" | ||||
| flagAsBotDescription: "Marca aquest compte com a bot" | ||||
| flagAsBotDescription: "Activa aquesta opció si el compte el controla un programa. Si s'activa, actuarà com un senyal per altres desenvolupadors per prevenir cadenes d'interacció sense fi i ajustar els paràmetres interns de Misskey pe tractar el compte com un bot." | ||||
| flagAsCat: "Marca aquest compte com a gat" | ||||
| flagAsCatDescription: "Activeu aquesta opció per marcar aquest compte com a gat." | ||||
| flagShowTimelineReplies: "Mostra les respostes a la línia de temps" | ||||
| flagShowTimelineRepliesDescription: "Mostra les respostes a la línia de temps" | ||||
| flagShowTimelineRepliesDescription: "Mostra les respostes dels usuaris a les notes d'altres usuaris a la línia de temps." | ||||
| autoAcceptFollowed: "Aprova automàticament les sol·licituds de seguiment dels usuaris que segueixes" | ||||
| addAccount: "Afegeix un compte" | ||||
| reloadAccountsList: "Recarregar la llista de contactes" | ||||
| @@ -192,7 +197,7 @@ setWallpaper: "Defineix el fons de pantalla" | ||||
| removeWallpaper: "Elimina el fons de pantalla" | ||||
| searchWith: "Cerca: {q}" | ||||
| youHaveNoLists: "No tens cap llista" | ||||
| followConfirm: "Estàs segur que vols deixar de seguir {name}?" | ||||
| followConfirm: "Segur que vols seguir a {name}?" | ||||
| proxyAccount: "Compte de proxy" | ||||
| proxyAccountDescription: "Un compte proxy és un compte que actua com a seguidor remot per als usuaris en determinades condicions. Per exemple, quan un usuari afegeix un usuari remot a la llista, l'activitat de l'usuari remot no es lliurarà al servidor si cap usuari local segueix aquest usuari, de manera que el compte proxy el seguirà." | ||||
| host: "Amfitrió" | ||||
| @@ -201,7 +206,7 @@ selectUser: "Selecciona usuari/a" | ||||
| recipient: "Destinatari" | ||||
| annotation: "Comentaris" | ||||
| federation: "Federació" | ||||
| instances: "Servidors" | ||||
| instances: "Instàncies " | ||||
| registeredAt: "Registrat a" | ||||
| latestRequestReceivedAt: "Última petició rebuda" | ||||
| latestStatus: "Últim estat" | ||||
| @@ -210,7 +215,7 @@ charts: "Gràfics" | ||||
| perHour: "Per hora" | ||||
| perDay: "Per dia" | ||||
| stopActivityDelivery: "Deixa d'enviar activitats" | ||||
| blockThisInstance: "Deixa d'enviar activitats" | ||||
| blockThisInstance: "Bloca aquesta instància " | ||||
| silenceThisInstance: "Silencia aquesta instància " | ||||
| mediaSilenceThisInstance: "Silenciar els arxius d'aquesta instància " | ||||
| operations: "Accions" | ||||
| @@ -219,13 +224,13 @@ version: "Versió" | ||||
| metadata: "Metadades" | ||||
| withNFiles: "{n} fitxer(s)" | ||||
| monitor: "Monitor" | ||||
| jobQueue: "Cua de tasques" | ||||
| jobQueue: "Cua de feines" | ||||
| cpuAndMemory: "CPU i memòria" | ||||
| network: "Xarxa" | ||||
| disk: "Disc" | ||||
| instanceInfo: "Informació del fitxer d'instal·lació" | ||||
| statistics: "Estadístiques" | ||||
| clearQueue: "Esborrar la cua" | ||||
| clearQueue: "Esborra la cua de feina" | ||||
| clearQueueConfirmTitle: "Esteu segur que voleu esborrar la cua?" | ||||
| clearQueueConfirmText: "Les notes no lliurades que quedin a la cua no es federaran. Normalment aquesta operació no és necessària." | ||||
| clearCachedFiles: "Esborra la memòria cau" | ||||
| @@ -236,6 +241,8 @@ silencedInstances: "Instàncies silenciades" | ||||
| silencedInstancesDescription: "Llista els enllaços d'amfitrió de les instàncies que vols silenciar. Tots els comptes de les instàncies llistades s'establiran com silenciades i només podran fer sol·licitacions de seguiment, i no podran mencionar als comptes locals si no els segueixen. Això no afectarà les instàncies bloquejades." | ||||
| mediaSilencedInstances: "Instàncies amb els arxius silenciats" | ||||
| mediaSilencedInstancesDescription: "Llista els noms dels servidors que vulguis silenciar els arxius, un servidor per línia. Tots els comptes que pertanyin als servidors llistats seran tractats com sensibles i no podran fer servir emojis personalitzats. Això no tindrà efecte sobre els servidors blocats." | ||||
| federationAllowedHosts: "Llista de servidors federats" | ||||
| federationAllowedHostsDescription: "Llista dels servidors amb els quals es federa." | ||||
| muteAndBlock: "Silencia i bloca" | ||||
| mutedUsers: "Usuaris silenciats" | ||||
| blockedUsers: "Usuaris bloquejats" | ||||
| @@ -249,7 +256,7 @@ processing: "S'està processant..." | ||||
| preview: "Vista prèvia" | ||||
| default: "Per defecte" | ||||
| defaultValueIs: "Per defecte: {value}" | ||||
| noCustomEmojis: "Cap emoji personalitzat" | ||||
| noCustomEmojis: "No hi ha emojis personalitzats" | ||||
| noJobs: "No hi ha feines" | ||||
| federating: "Federant" | ||||
| blocked: "Bloquejat" | ||||
| @@ -263,11 +270,11 @@ instanceFollowers: "Seguidors del servidor" | ||||
| instanceUsers: "Usuaris del servidor" | ||||
| changePassword: "Canvia la contrasenya" | ||||
| security: "Seguretat" | ||||
| retypedNotMatch: "L'entrada no coincideix" | ||||
| retypedNotMatch: "Les entrades no coincideix" | ||||
| currentPassword: "Contrasenya actual" | ||||
| newPassword: "Contrasenya nova" | ||||
| newPasswordRetype: "Contrasenya nou (repeteix-la)" | ||||
| attachFile: "Adjunta fitxers" | ||||
| newPasswordRetype: "Contrasenya nova (repeteix-la)" | ||||
| attachFile: "Afegeix un arxiu" | ||||
| more: "Més" | ||||
| featured: "Destacat" | ||||
| usernameOrUserId: "Nom o ID d'usuari" | ||||
| @@ -277,25 +284,25 @@ announcements: "Anuncis" | ||||
| imageUrl: "URL de la imatge" | ||||
| remove: "Eliminar" | ||||
| removed: "Eliminat" | ||||
| removeAreYouSure: "Segur que voleu retirar «{x}»?" | ||||
| deleteAreYouSure: "Segur que voleu retirar «{x}»?" | ||||
| resetAreYouSure: "Segur que voleu restablir-ho?" | ||||
| areYouSure: "Està segur?" | ||||
| removeAreYouSure: "Segur que vols esborrar «{x}»?" | ||||
| deleteAreYouSure: "Segur que vols esborrar «{x}»?" | ||||
| resetAreYouSure: "Segur que vols restablir-ho?" | ||||
| areYouSure: "Estàs segur?" | ||||
| saved: "S'ha desat" | ||||
| messaging: "Xat" | ||||
| upload: "Puja" | ||||
| keepOriginalUploading: "Guarda la imatge original" | ||||
| keepOriginalUploadingDescription: "Guarda la imatge pujada com hi és. Si està apagat, una versió per a la visualització a la xarxa serà generada quan sigui pujada." | ||||
| fromDrive: "Des de la unitat" | ||||
| keepOriginalUploadingDescription: "Guarda la imatge pujada sense modificar. Si està desactivat, es generarà una versió per visualitzar a la web en pujar la imatge." | ||||
| fromDrive: "Des del Disc" | ||||
| fromUrl: "Des d'un enllaç" | ||||
| uploadFromUrl: "Carrega des d'un enllaç" | ||||
| uploadFromUrlDescription: "Enllaç del fitxer que vols carregar" | ||||
| uploadFromUrlRequested: "Càrrega sol·licitada" | ||||
| uploadFromUrlMayTakeTime: "La càrrega des de l'enllaç pot prendre un temps" | ||||
| uploadFromUrlMayTakeTime: "La càrrega des de l'enllaç pot trigar un temps" | ||||
| explore: "Explora" | ||||
| messageRead: "Vist" | ||||
| noMoreHistory: "No hi resta més per veure" | ||||
| startMessaging: "Començar a xatejar" | ||||
| noMoreHistory: "No hi ha res més per veure" | ||||
| startMessaging: "Comença a xatejar" | ||||
| nUsersRead: "Vist per {n}" | ||||
| agreeTo: "Accepto que {0}" | ||||
| agree: "Hi estic d'acord" | ||||
| @@ -307,7 +314,7 @@ home: "Inici" | ||||
| remoteUserCaution: "Ja que aquest usuari resideix a una instància remota, la informació mostrada es podria trobar incompleta." | ||||
| activity: "Activitat" | ||||
| images: "Imatges" | ||||
| image: "Imatges" | ||||
| image: "Imatge" | ||||
| birthday: "Aniversari" | ||||
| yearsOld: "{age} anys" | ||||
| registeredDate: "Data de registre" | ||||
| @@ -320,12 +327,12 @@ dark: "Fosc" | ||||
| lightThemes: "Temes clars" | ||||
| darkThemes: "Temes foscos" | ||||
| syncDeviceDarkMode: "Sincronitza el mode fosc amb la configuració del dispositiu" | ||||
| drive: "Unitat" | ||||
| drive: "Disc" | ||||
| fileName: "Nom del Fitxer" | ||||
| selectFile: "Selecciona fitxers" | ||||
| selectFile: "Selecciona un fitxer" | ||||
| selectFiles: "Selecciona fitxers" | ||||
| selectFolder: "Selecció de carpeta" | ||||
| selectFolders: "Selecció de carpeta" | ||||
| selectFolders: "Selecció de carpetes" | ||||
| fileNotSelected: "Cap fitxer seleccionat" | ||||
| renameFile: "Canvia el nom del fitxer" | ||||
| folderName: "Nom de la carpeta" | ||||
| @@ -334,11 +341,12 @@ renameFolder: "Canvia el nom de la carpeta" | ||||
| deleteFolder: "Elimina la carpeta" | ||||
| folder: "Carpeta " | ||||
| addFile: "Afegeix un fitxer" | ||||
| emptyDrive: "La teva unitat és buida" | ||||
| showFile: "Mostrar fitxer" | ||||
| emptyDrive: "El teu Disc és buit" | ||||
| emptyFolder: "La carpeta està buida" | ||||
| unableToDelete: "No es pot eliminar" | ||||
| inputNewFileName: "Introduïu el nom de fitxer nou" | ||||
| inputNewDescription: "Inserta una nova llegenda" | ||||
| inputNewDescription: "Escriu el peu de foto." | ||||
| inputNewFolderName: "Introduïu el nom de la carpeta nova" | ||||
| circularReferenceFolder: "La carpeta destinatària és una subcarpeta de la carpeta a la qual la desitges moure" | ||||
| hasChildFilesOrFolders: "No és possible esborrar aquesta carpeta ja que no és buida" | ||||
| @@ -353,9 +361,9 @@ reload: "Actualitza" | ||||
| doNothing: "Ignora" | ||||
| reloadConfirm: "Vols recarregar?" | ||||
| watch: "Veure" | ||||
| unwatch: "Deixar de veure" | ||||
| unwatch: "Deixa de veure" | ||||
| accept: "Acceptar" | ||||
| reject: "Denegar" | ||||
| reject: "Denega" | ||||
| normal: "Normal" | ||||
| instanceName: "Nom del servidor" | ||||
| instanceDescription: "Descripció del servidor" | ||||
| @@ -376,7 +384,6 @@ enableLocalTimeline: "Activa la línia de temps local" | ||||
| enableGlobalTimeline: "Activa la línia de temps global" | ||||
| disablingTimelinesInfo: "Fins i tot si aquestes línies de temps són desactivades, els administradors i els moderadors poden continuar visualitzant per conveniència." | ||||
| registration: "Registre" | ||||
| enableRegistration: "Permet els registres d'usuaris" | ||||
| invite: "Convida" | ||||
| driveCapacityPerLocalAccount: "Capacitat del disc per usuaris locals" | ||||
| driveCapacityPerRemoteAccount: "Capacitat del disc per usuaris remots" | ||||
| @@ -387,20 +394,20 @@ basicInfo: "Informació bàsica" | ||||
| pinnedUsers: "Usuaris fixats" | ||||
| pinnedUsersDescription: "Llista d'usuaris, separats per salts de línia, que seran fixats a la pestanya \"Explorar\"." | ||||
| pinnedPages: "Pàgines fixades" | ||||
| pinnedPagesDescription: "Escriu els camins de les pàgines que vols fixar a la pàgina d'inici d'aquesta instància. Separades per salts de línia." | ||||
| pinnedPagesDescription: "Escriu les adreces de les pàgines que vols fixar a la pàgina d'inici d'aquesta instància. Separades per salts de línia." | ||||
| pinnedClipId: "ID del retall fixat" | ||||
| pinnedNotes: "Nota fixada" | ||||
| hcaptcha: "hCaptcha" | ||||
| enableHcaptcha: "Activar hCaptcha" | ||||
| enableHcaptcha: "Activa hCaptcha" | ||||
| hcaptchaSiteKey: "Clau del lloc" | ||||
| hcaptchaSecretKey: "Clau secreta" | ||||
| mcaptcha: "mCaptcha" | ||||
| enableMcaptcha: "Activar mCaptcha" | ||||
| enableMcaptcha: "Activa mCaptcha" | ||||
| mcaptchaSiteKey: "Clau del lloc" | ||||
| mcaptchaSecretKey: "Clau secreta" | ||||
| mcaptchaInstanceUrl: "Adreça URL del servidor mCaptcha" | ||||
| recaptcha: "reCAPTCHA" | ||||
| enableRecaptcha: "Activar reCAPTCHA" | ||||
| enableRecaptcha: "Activa reCAPTCHA" | ||||
| recaptchaSiteKey: "Clau del lloc" | ||||
| recaptchaSecretKey: "Clau secreta" | ||||
| turnstile: "Turnstile" | ||||
| @@ -442,13 +449,14 @@ aboutMisskey: "Quant a Misskey" | ||||
| administrator: "Administrador/a" | ||||
| token: "Codi de verificació" | ||||
| 2fa: "Autenticació de doble factor" | ||||
| setupOf2fa: "Configurar l'autenticació de doble factor" | ||||
| setupOf2fa: "Configura l'autenticació de doble factor" | ||||
| totp: "Aplicació d'autenticació" | ||||
| totpDescription: "Escriu una contrasenya d'un sol us fent servir l'aplicació d'autenticació" | ||||
| moderator: "Moderador/a" | ||||
| moderation: "Moderació" | ||||
| moderationNote: "Nota de moderació " | ||||
| addModerationNote: "Afegir una nota de moderació " | ||||
| moderationNoteDescription: "Pots escriure notes que es compartiran entre els moderadors." | ||||
| addModerationNote: "Afegeix una nota de moderació " | ||||
| moderationLogs: "Registre de moderació " | ||||
| nUsersMentioned: "{n} usuaris mencionats" | ||||
| securityKeyAndPasskey: "Clau de seguretat / Clau de pas" | ||||
| @@ -464,13 +472,13 @@ reduceUiAnimation: "Redueix les animacions de la interfície" | ||||
| share: "Comparteix" | ||||
| notFound: "No s'ha trobat" | ||||
| notFoundDescription: "No es troba cap pàgina que correspongui a aquesta adreça" | ||||
| uploadFolder: "Carpeta per defecte per pujades" | ||||
| uploadFolder: "Carpeta per defecte on desar els arxius pujats" | ||||
| markAsReadAllNotifications: "Marca totes les notificacions com a llegides" | ||||
| markAsReadAllUnreadNotes: "Marca-ho tot com a llegit" | ||||
| markAsReadAllTalkMessages: "Marcar tots els missatges com llegits" | ||||
| help: "Ajuda" | ||||
| inputMessageHere: "Escriu aquí el teu missatge " | ||||
| close: "Tancar" | ||||
| close: "Tanca" | ||||
| invites: "Convida" | ||||
| members: "Membres" | ||||
| transfer: "Transferir" | ||||
| @@ -501,7 +509,7 @@ normalPassword: "Bona contrasenya" | ||||
| strongPassword: "Contrasenya segura" | ||||
| passwordMatched: "Correcte!" | ||||
| passwordNotMatched: "No coincideix" | ||||
| signinWith: "Inicia sessió amb amb {x}" | ||||
| signinWith: "Inicia sessió amb {x}" | ||||
| signinFailed: "Autenticació sense èxit. Intenta-ho un altre cop utilitzant la contrasenya i el nom correctes." | ||||
| or: "O" | ||||
| language: "Idioma" | ||||
| @@ -509,6 +517,10 @@ uiLanguage: "Idioma de l'interfície" | ||||
| aboutX: "Respecte a {x}" | ||||
| emojiStyle: "Estil d'emoji" | ||||
| native: "Nadiu" | ||||
| menuStyle: "Estil de menú" | ||||
| style: "Estil" | ||||
| drawer: "Calaix" | ||||
| popup: "Emergent" | ||||
| showNoteActionsOnlyHover: "Només mostra accions de la nota en passar amb el cursor" | ||||
| showReactionsCount: "Mostra el nombre de reaccions a les publicacions" | ||||
| noHistory: "No hi ha un registre previ" | ||||
| @@ -527,7 +539,7 @@ mediaListWithOneImageAppearance: "Altura de la llista de fitxers amb una única | ||||
| limitTo: "Limita a {x}" | ||||
| noFollowRequests: "No tens sol·licituds de seguiment" | ||||
| openImageInNewTab: "Obre imatges a una nova pestanya" | ||||
| dashboard: "Panell de control" | ||||
| dashboard: "Taulell de control" | ||||
| local: "Local" | ||||
| remote: "Remot" | ||||
| total: "Total" | ||||
| @@ -563,7 +575,7 @@ serverLogs: "Registres del servidor" | ||||
| deleteAll: "Elimina-ho tot" | ||||
| showFixedPostForm: "Mostrar el formulari per escriure a l'inici de la línia de temps" | ||||
| showFixedPostFormInChannel: "Mostrar el formulari d'escriptura al principi de la línia de temps (Canals)" | ||||
| withRepliesByDefaultForNewlyFollowed: "Inclou les respostes d'usuaris nous seguits a la línia de temps per defecte." | ||||
| withRepliesByDefaultForNewlyFollowed: "Inclou les respostes d'usuaris nous que segueixes a la línia de temps per defecte." | ||||
| newNoteRecived: "Hi ha publicacions noves" | ||||
| sounds: "Sons" | ||||
| sound: "So" | ||||
| @@ -576,11 +588,12 @@ masterVolume: "Volum principal" | ||||
| notUseSound: "Sense so" | ||||
| useSoundOnlyWhenActive: "Reproduir sons només quan Misskey estigui actiu" | ||||
| details: "Detalls" | ||||
| renoteDetails: "Més informació sobre l'impuls " | ||||
| chooseEmoji: "Tria un emoji" | ||||
| unableToProcess: "L'operació no pot ser completada " | ||||
| recentUsed: "Utilitzat recentment" | ||||
| install: "Instal·lació " | ||||
| uninstall: "Desinstal·lar " | ||||
| uninstall: "Desinstal·la" | ||||
| installedApps: "Aplicacions autoritzades " | ||||
| nothing: "No hi ha res per veure aquí " | ||||
| installedDate: "Data d'instal·lació" | ||||
| @@ -597,13 +610,13 @@ output: "Sortida" | ||||
| script: "Script" | ||||
| disablePagesScript: "Desactivar AiScript a les pàgines " | ||||
| updateRemoteUser: "Actualitzar la informació de l'usuari remot" | ||||
| unsetUserAvatar: "Desactivar l'avatar " | ||||
| unsetUserAvatar: "Desactiva l'avatar " | ||||
| unsetUserAvatarConfirm: "Segur que vols desactivar l'avatar?" | ||||
| unsetUserBanner: "Desactivar el bàner " | ||||
| unsetUserBanner: "Desactiva el bàner " | ||||
| unsetUserBannerConfirm: "Segur que vols desactivar el bàner?" | ||||
| deleteAllFiles: "Esborrar tots els arxius" | ||||
| deleteAllFiles: "Esborra tots els arxius" | ||||
| deleteAllFilesConfirm: "Segur que vols esborrar tots els arxius?" | ||||
| removeAllFollowing: "Deixar de seguir tots els usuaris seguits" | ||||
| removeAllFollowing: "Deixa de seguir tots els usuaris que segueixes" | ||||
| removeAllFollowingDescription: "El fet d'executar això, et farà deixar de seguir a tots els usuaris de {host}. Si us plau, executa això si l'amfitrió, per exemple, ja no existeix." | ||||
| userSuspended: "Aquest usuari ha sigut suspès" | ||||
| userSilenced: "Aquest usuari està sent silenciat" | ||||
| @@ -634,7 +647,7 @@ expandTweet: "Expandir post" | ||||
| themeEditor: "Editor de temes" | ||||
| description: "Descripció" | ||||
| describeFile: "Afegir subtitulació" | ||||
| enterFileDescription: "Afegeix un títol" | ||||
| enterFileDescription: "Escriu un peu de foto" | ||||
| author: "Autor" | ||||
| leaveConfirm: "Hi ha canvis sense guardar. Els vols descartar?" | ||||
| manage: "Administració" | ||||
| @@ -673,11 +686,15 @@ smtpSecure: "Fes servir SSL/TLS per connexions SMTP" | ||||
| smtpSecureInfo: "Desactiva això quan facis servir connexions STARTTLS" | ||||
| testEmail: "Prova l'enviament de correu " | ||||
| wordMute: "Silenciar paraules " | ||||
| wordMuteDescription: "Minimitza les notes que contenen la paraula o frase especificada. Les notes minimitzades poden visualitzar-se fent clic sobre elles." | ||||
| hardWordMute: "Silenciar paraules fortes" | ||||
| showMutedWord: "Mostrar paraules silenciades" | ||||
| hardWordMuteDescription: "Oculta les notes que contenen la paraula o frase especificada. A diferència de Silenciar paraula, la nota quedarà completament oculta a la vista." | ||||
| regexpError: "Error de l'expressió regular " | ||||
| regexpErrorDescription: "S'ha produït un error a l'expressió regular a la línia {line} de les paraules silenciades {tab}:" | ||||
| instanceMute: "Silenciar servidor" | ||||
| userSaysSomething: "{name} n'ha dit alguna cosa" | ||||
| userSaysSomethingAbout: "{name} està parlant sobre \"{word}\"" | ||||
| makeActive: "Activar" | ||||
| display: "Veure" | ||||
| copy: "Copiar" | ||||
| @@ -709,10 +726,7 @@ abuseReported: "La teva denúncia s'ha enviat. Moltes gràcies." | ||||
| reporter: "Denunciant " | ||||
| reporteeOrigin: "Origen de la denúncia " | ||||
| reporterOrigin: "Origen del denunciant" | ||||
| forwardReport: "Transferir la denúncia a una instància remota" | ||||
| forwardReportIsAnonymous: "En lloc del teu compte, es farà servir un compte anònim com a denunciant al servidor remot." | ||||
| send: "Envia" | ||||
| abuseMarkAsResolved: "Marca la denúncia com a resolta" | ||||
| openInNewTab: "Obre a una pestanya nova" | ||||
| openInSideView: "Obre a una vista lateral" | ||||
| defaultNavigationBehaviour: "Navegació per defecte" | ||||
| @@ -721,7 +735,7 @@ instanceTicker: "Informació de notes de la instància " | ||||
| waitingFor: "Esperant {x}" | ||||
| random: "Aleatori " | ||||
| system: "Sistema" | ||||
| switchUi: "Canviar interfície d'usuari " | ||||
| switchUi: "Canviar la interfície" | ||||
| desktop: "Escriptori" | ||||
| clip: "Retalls" | ||||
| createNew: "Crear" | ||||
| @@ -739,7 +753,7 @@ repliesCount: "Nombre de respostes" | ||||
| renotesCount: "Impulsos fets" | ||||
| repliedCount: "Nombre de respostes rebudes" | ||||
| renotedCount: "Impulsos rebuts" | ||||
| followingCount: "Nombre de comptes seguits" | ||||
| followingCount: "Nombre de comptes que segueixes" | ||||
| followersCount: "Nombre de seguidors" | ||||
| sentReactionsCount: "Nombre de reaccions enviades" | ||||
| receivedReactionsCount: "Nombre de reaccions rebudes" | ||||
| @@ -771,7 +785,7 @@ thisIsExperimentalFeature: "Aquesta és una característica experimental. La sev | ||||
| developer: "Programador" | ||||
| makeExplorable: "Fes que el compte sigui visible a la secció \"Explorar\"" | ||||
| makeExplorableDescription: "Si desactives aquesta opció, el teu compte no sortirà a la secció \"Explorar\"" | ||||
| showGapBetweenNotesInTimeline: "Mostra una separació entre els articles a la línia de temps" | ||||
| showGapBetweenNotesInTimeline: "Notes separades a la línia de temps" | ||||
| duplicate: "Duplicat" | ||||
| left: "Esquerra" | ||||
| center: "Centre" | ||||
| @@ -902,7 +916,7 @@ off: "Desactivar" | ||||
| emailRequiredForSignup: "Demanar correu electrònic per registrar-se " | ||||
| unread: "Sense llegir" | ||||
| filter: "Filtrar" | ||||
| controlPanel: "Panel de control" | ||||
| controlPanel: "Taulell de control" | ||||
| manageAccounts: "Gestionar comptes" | ||||
| makeReactionsPublic: "Reaccions públiques " | ||||
| makeReactionsPublicDescription: "Això fa que totes les teves reaccions siguin visibles públicament " | ||||
| @@ -914,13 +928,14 @@ followersVisibility: "Visibilitat dels seguidors" | ||||
| continueThread: "Veure la continuació del fil" | ||||
| deleteAccountConfirm: "Això eliminarà el teu compte irreversiblement. Procedir?" | ||||
| incorrectPassword: "Contrasenya incorrecta." | ||||
| incorrectTotp: "La contrasenya no és correcta, o ha caducat." | ||||
| voteConfirm: "Confirma el teu vot \"{choice}\"" | ||||
| hide: "Amagar" | ||||
| useDrawerReactionPickerForMobile: "Mostrar el selector de reaccions com un calaix al mòbil " | ||||
| welcomeBackWithName: "Benvingut de nou, {name}" | ||||
| clickToFinishEmailVerification: "Si us plau, fes clic a [{ok}] per completar la verificació per correu electrònic " | ||||
| overridedDeviceKind: "Tipus de dispositiu" | ||||
| smartphone: "Telèfon intel·ligent" | ||||
| smartphone: "Mòbil " | ||||
| tablet: "Tauleta" | ||||
| auto: "Automàtic " | ||||
| themeColor: "Color del tema" | ||||
| @@ -938,6 +953,9 @@ oneHour: "1 hora" | ||||
| oneDay: "Un dia" | ||||
| oneWeek: "Una setmana" | ||||
| oneMonth: "Un mes" | ||||
| threeMonths: "3 mesos" | ||||
| oneYear: "1 any" | ||||
| threeDays: "3 dies" | ||||
| reflectMayTakeTime: "Això pot trigar una estona a tenir efecte" | ||||
| failedToFetchAccountInformation: "No es pot obtenir la informació del compte" | ||||
| rateLimitExceeded: "S'ha arribat al màxim de peticions" | ||||
| @@ -998,7 +1016,7 @@ sendPushNotificationReadMessageCaption: "Això pot fer que el teu dispositiu con | ||||
| windowMaximize: "Maximitzar " | ||||
| windowMinimize: "Minimitzar" | ||||
| windowRestore: "Restaurar" | ||||
| caption: "Llegenda" | ||||
| caption: "Peu de foto" | ||||
| loggedInAsBot: "Identificat com a bot" | ||||
| tools: "Eines" | ||||
| cannotLoad: "No es pot carregar" | ||||
| @@ -1078,6 +1096,7 @@ retryAllQueuesConfirmTitle: "Tornar a intentar-ho tot?" | ||||
| retryAllQueuesConfirmText: "Això farà que la càrrega del servidor augmenti temporalment." | ||||
| enableChartsForRemoteUser: "Generar gràfiques d'usuaris remots" | ||||
| enableChartsForFederatedInstances: "Generar gràfiques d'instàncies remotes" | ||||
| enableStatsForFederatedInstances: "Activa les estadístiques de les instàncies remotes federades" | ||||
| showClipButtonInNoteFooter: "Afegir \"Retall\" al menú d'acció de la nota" | ||||
| reactionsDisplaySize: "Mida de les reaccions" | ||||
| limitWidthOfReaction: "Limitar l'amplada màxima de la reacció i mostrar-les en una mida reduïda " | ||||
| @@ -1120,7 +1139,7 @@ channelArchiveConfirmDescription: "Un Canal arxivat no apareixerà a la llista d | ||||
| thisChannelArchived: "Aquest Canal ha sigut arxivat." | ||||
| displayOfNote: "Mostrar notes" | ||||
| initialAccountSetting: "Configuració del perfil" | ||||
| youFollowing: "Seguit" | ||||
| youFollowing: "Seguint" | ||||
| preventAiLearning: "Descartar l'ús d'aprenentatge automàtic (IA Generativa)" | ||||
| preventAiLearningDescription: "Demanar els indexadors no fer servir els texts, imatges, etc. en cap conjunt de dades per alimentar l'aprenentatge automàtic (IA Predictiva/ Generativa). Això s'aconsegueix afegint la etiqueta \"noai\" com a resposta HTML al contingut corresponent. Prevenir aquest ús totalment pot ser que no sigui aconseguit, ja que molts indexadors poden obviar aquesta etiqueta." | ||||
| options: "Opcions" | ||||
| @@ -1170,8 +1189,8 @@ currentAnnouncements: "Informes actuals" | ||||
| pastAnnouncements: "Informes passats" | ||||
| youHaveUnreadAnnouncements: "Tens informes per llegir." | ||||
| useSecurityKey: "Segueix les instruccions del teu navegador O dispositiu per fer servir el teu passkey." | ||||
| replies: "Respondre" | ||||
| renotes: "Impulsa" | ||||
| replies: "Respon" | ||||
| renotes: "Impulsar " | ||||
| loadReplies: "Mostrar les respostes" | ||||
| loadConversation: "Mostrar la conversació " | ||||
| pinnedList: "Llista fixada" | ||||
| @@ -1186,7 +1205,7 @@ showRenotes: "Mostrar impulsos" | ||||
| edited: "Editat" | ||||
| notificationRecieveConfig: "Paràmetres de notificacions" | ||||
| mutualFollow: "Seguidor mutu" | ||||
| followingOrFollower: "Seguit o seguidor" | ||||
| followingOrFollower: "Seguint o seguidor" | ||||
| fileAttachedOnly: "Només notes amb adjunts" | ||||
| showRepliesToOthersInTimeline: "Mostrar les respostes a altres a la línia de temps" | ||||
| hideRepliesToOthersInTimeline: "Amagar les respostes a altres a la línia de temps" | ||||
| @@ -1268,6 +1287,47 @@ fromX: "De {x}" | ||||
| genEmbedCode: "Obtenir el codi per incrustar" | ||||
| noteOfThisUser: "Notes d'aquest usuari" | ||||
| clipNoteLimitExceeded: "No es poden afegir més notes a aquest clip." | ||||
| performance: "Rendiment" | ||||
| modified: "Modificat" | ||||
| discard: "Descarta" | ||||
| thereAreNChanges: "Hi ha(n) {n} canvi(s)" | ||||
| signinWithPasskey: "Inicia sessió amb Passkey" | ||||
| unknownWebAuthnKey: "Passkey desconeguda" | ||||
| passkeyVerificationFailed: "La verificació a fallat" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "La verificació de la passkey a estat correcta, però s'ha deshabilitat l'inici de sessió sense contrasenya." | ||||
| messageToFollower: "Missatge als meus seguidors" | ||||
| target: "Assumpte " | ||||
| testCaptchaWarning: "És una característica dissenyada per a la prova de CAPTCHA. <strong>No l'utilitzes en l'entorn real.</strong>" | ||||
| prohibitedWordsForNameOfUser: "Noms prohibits per escollir noms d'usuari " | ||||
| prohibitedWordsForNameOfUserDescription: "Si qualsevol d'aquestes paraules es troben a un nom d'usuari la creació de l'usuari no es durà a terme. Als moderadors no els afecta aquesta restricció." | ||||
| yourNameContainsProhibitedWords: "El nom conté paraules prohibides " | ||||
| yourNameContainsProhibitedWordsDescription: "Si de veritat vols fer servir aquest nom posat en contacte amb l'administrador." | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "L'autor requereix l'inici de sessió per poder veure" | ||||
| lockdown: "Bloquejat" | ||||
| pleaseSelectAccount: "Seleccionar un compte" | ||||
| availableRoles: "Roles disponibles " | ||||
| acknowledgeNotesAndEnable: "Activa'l després de comprendre els possibles perills." | ||||
| federationSpecified: "Aquest servidor treballa amb una federació de llistes blanques. No pot interactuar amb altres servidors que no siguin els especificats per l'administrador." | ||||
| federationDisabled: "La unió es troba deshabilitada en aquest servidor. No es pot interactuar amb usuaris d'altres servidors." | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "És obligatori l'inici de sessió per poder veure el contingut" | ||||
|   requireSigninToViewContentsDescription1: "Es requereix l'inici de sessió per poder veure totes les notes i el contingut que has creat. Amb això esperem evitar que els rastrejadors recopilin informació." | ||||
|   requireSigninToViewContentsDescription2: "També es desactivaran les vistes prèvies d'URLS (OGP), la incrustació a pàgines web i la visualització des de servidors que no admetin la citació de notes." | ||||
|   requireSigninToViewContentsDescription3: "Aquestes restriccions pot ser que no s'apliquin als continguts federats en servidors remots." | ||||
|   makeNotesFollowersOnlyBefore: "Permetre que les notes antigues només es mostrin als seguidors." | ||||
|   makeNotesFollowersOnlyBeforeDescription: "Mentre aquesta funció estigui activada, les notes que hagin passat la data i hora fixada o hagi passat els temps establert seran visibles només per als teus seguidors. Quan es desactivi, també es restableix l'estat públic de la nota." | ||||
|   makeNotesHiddenBefore: "Fes que les notes antigues siguin privades" | ||||
|   makeNotesHiddenBeforeDescription: "Mentres aquesta funció estigui activada les notes que hagin superat una data i hora fixada o hagi passat el temps establert només seran visibles per a tu. Si la desactives es restablirà també l'estat públic de les notes." | ||||
|   mayNotEffectForFederatedNotes: "Això pot ser que no afecti les notes federades." | ||||
|   notesHavePassedSpecifiedPeriod: "Notes publicades durant un període de temps especificat." | ||||
|   notesOlderThanSpecifiedDateAndTime: "Notes més antigues de la data i temps especificat " | ||||
| _abuseUserReport: | ||||
|   forward: "Reenviar " | ||||
|   forwardDescription: "Reenvia l'informe a una altra instància com un compte del sistema anònima." | ||||
|   resolve: "Solució " | ||||
|   accept: "Acceptar " | ||||
|   reject: "Rebutjar" | ||||
|   resolveTutorial: "Si l'informe és legítim selecciona \"Acceptar\" per resoldre'l positivament. Però si l'informe no és legítim selecciona \"Rebutjar\" per resoldre'l negativament." | ||||
| _delivery: | ||||
|   status: "Estat d'entrega " | ||||
|   stop: "Suspés" | ||||
| @@ -1405,6 +1465,9 @@ _serverSettings: | ||||
|   reactionsBufferingDescription: "Quan s'activa aquesta opció millora bastant el rendiment en recuperar les línies de temps reduint la càrrega de la base. Com a contrapunt, augmentarà  l'ús de memòria de Redís. Desactiva aquesta opció en cas de tenir un servidor amb poca memòria o si tens problemes d'inestabilitat." | ||||
|   inquiryUrl: "URL de consulta " | ||||
|   inquiryUrlDescription: "Escriu adreça URL per al formulari de consulta per al mantenidor del servidor o una pàgina web amb el contacte d'informació." | ||||
|   openRegistration: "Registres oberts" | ||||
|   openRegistrationWarning: "Obrir els registres és arriscat. Es recomana obrir-los només si el servidor és monitorat constantment i per respondre immediatament davant qualsevol problema." | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "Si no es detecta activitat per part del moderador durant un període de temps, aquesta opció es desactiva automàticament per evitar el correu brossa." | ||||
| _accountMigration: | ||||
|   moveFrom: "Migrar un altre compte a aquest" | ||||
|   moveFromSub: "Crear un àlies per un altre compte" | ||||
| @@ -1418,7 +1481,7 @@ _accountMigration: | ||||
|   startMigration: "Migrar" | ||||
|   migrationConfirm: "Vols migrar aquest compte a {account}? Una vegada comenci la migració no es podrà parar O fer marxa enrere i no podràs tornar a fer servir aquest compte mai més." | ||||
|   movedAndCannotBeUndone: "Aquest compte ha migrat.\nLes migracions no es poden desfer." | ||||
|   postMigrationNote: "Aquest compte deixarà de seguir tots els comptes que segueix 24 hores després de germinar la migració.\nEl nombre de seguidors i seguits passarà a ser de zero. Per evitar que els teus seguidors no puguin veure les publicacions marcades com a només seguidors continuaren seguint aquest compte." | ||||
|   postMigrationNote: "Aquest compte deixarà de seguir tots els comptes que segueix 24 hores després de terminar la migració.\nEl nombre de seguidors i seguits passarà a ser de zero. Per evitar que els teus seguidors no puguin veure les publicacions marcades com a només seguidors continuaren seguint aquest compte." | ||||
|   movedTo: "Nou compte:" | ||||
| _achievements: | ||||
|   earnedAt: "Desbloquejat el" | ||||
| @@ -1777,7 +1840,7 @@ _emailUnavailable: | ||||
|   smtp: "Aquest servidor de correu electrònic no respon" | ||||
|   banned: "No pots registrar-te amb aquesta adreça de correu electrònic " | ||||
| _ffVisibility: | ||||
|   public: "Publicar" | ||||
|   public: "Públic " | ||||
|   followers: "Visible només per a seguidors " | ||||
|   private: "Privat" | ||||
| _signup: | ||||
| @@ -1811,7 +1874,7 @@ _gallery: | ||||
|   unlike: "Ja no m'agrada" | ||||
| _email: | ||||
|   _follow: | ||||
|     title: "t'ha seguit" | ||||
|     title: "Tens un nou seguidor" | ||||
|   _receiveFollowRequest: | ||||
|     title: "Has rebut una sol·licitud  de seguiment" | ||||
| _plugin: | ||||
| @@ -1845,7 +1908,7 @@ _registry: | ||||
|   domain: "Domini" | ||||
|   createKey: "Crear una clau" | ||||
| _aboutMisskey: | ||||
|   about: "Misskey és un programa de codi obert desenvolupar per syuilo des de 2014" | ||||
|   about: "Misskey és un programa de codi obert desenvolupat des del 2014 per syuilo" | ||||
|   contributors: "Col·laboradors principals" | ||||
|   allContributors: "Tots els col·laboradors " | ||||
|   source: "Codi font" | ||||
| @@ -1958,7 +2021,6 @@ _theme: | ||||
|     buttonBg: "Fons botó " | ||||
|     buttonHoverBg: "Fons botó (en passar-hi per sobre)" | ||||
|     inputBorder: "Contorn del cap d'introducció " | ||||
|     listItemHoverBg: "Fons dels elements d'una llista" | ||||
|     driveFolderBg: "Fons de la carpeta Disc" | ||||
|     wallpaperOverlay: "Superposició del fons de pantalla " | ||||
|     badge: "Insígnia " | ||||
| @@ -2125,8 +2187,11 @@ _auth: | ||||
|   permissionAsk: "Aquesta aplicació demana els següents permisos" | ||||
|   pleaseGoBack: "Si us plau, torna a l'aplicació" | ||||
|   callback: "Tornant a l'aplicació" | ||||
|   accepted: "Accés garantit" | ||||
|   denied: "Accés denegat" | ||||
|   scopeUser: "Opera com si fossis aquest usuari" | ||||
|   pleaseLogin: "Si us plau, identificat per autoritzar l'aplicació." | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "Si es garanteix l'accés, seràs redirigit automàticament a la següent adreça URL" | ||||
| _antennaSources: | ||||
|   all: "Totes les publicacions" | ||||
|   homeTimeline: "Publicacions dels usuaris seguits" | ||||
| @@ -2162,7 +2227,7 @@ _widgets: | ||||
|   slideshow: "Presentació" | ||||
|   button: "Botó " | ||||
|   onlineUsers: "Usuaris actius" | ||||
|   jobQueue: "Cua de tasques" | ||||
|   jobQueue: "Cua de feines" | ||||
|   serverMetric: "Mètriques del servidor" | ||||
|   aiscript: "Consola AiScript" | ||||
|   aiscriptApp: "Aplicació AiScript" | ||||
| @@ -2235,11 +2300,14 @@ _profile: | ||||
|   changeBanner: "Canviar el bàner " | ||||
|   verifiedLinkDescription: "Escrivint una adreça URL que enllaci a aquest perfil, una icona de propietat verificada es mostrarà al costat del camp." | ||||
|   avatarDecorationMax: "Pot afegir un màxim de {max} decoracions." | ||||
|   followedMessage: "Missatge als nous seguidors" | ||||
|   followedMessageDescription: "Es pot configurar un missatge curt que es mostra a l'altra persona quan comença a seguir-te." | ||||
|   followedMessageDescriptionForLockedAccount: "Si comencen a seguir-te es mostra un missatge de quan es permet aquesta sol·licitud. " | ||||
| _exportOrImport: | ||||
|   allNotes: "Totes les publicacions" | ||||
|   favoritedNotes: "Notes preferides" | ||||
|   clips: "Retalls" | ||||
|   followingList: "Seguint" | ||||
|   followingList: "Seguint " | ||||
|   muteList: "Silencia" | ||||
|   blockingList: "Bloqueja" | ||||
|   userLists: "Llistes" | ||||
| @@ -2373,10 +2441,12 @@ _notification: | ||||
|   renotedBySomeUsers: "L'han impulsat {n} usuaris" | ||||
|   followedBySomeUsers: "Et segueixen {n} usuaris" | ||||
|   flushNotification: "Netejar notificacions" | ||||
|   exportOfXCompleted: "Completada l'exportació de {x}" | ||||
|   login: "Algú ha iniciat sessió " | ||||
|   _types: | ||||
|     all: "Tots" | ||||
|     note: "Notes noves" | ||||
|     follow: "Seguint" | ||||
|     follow: "Segueix-me" | ||||
|     mention: "Menció" | ||||
|     reply: "Respostes" | ||||
|     renote: "Renotar" | ||||
| @@ -2387,9 +2457,12 @@ _notification: | ||||
|     followRequestAccepted: "Petició de seguiment acceptada" | ||||
|     roleAssigned: "Rol donat" | ||||
|     achievementEarned: "Assoliment desbloquejat" | ||||
|     exportCompleted: "Exportació completada" | ||||
|     login: "Iniciar sessió" | ||||
|     test: "Prova la notificació" | ||||
|     app: "Notificacions d'aplicacions" | ||||
|   _actions: | ||||
|     followBack: "t'ha seguit també" | ||||
|     followBack: "També et segueix" | ||||
|     reply: "Respondre" | ||||
|     renote: "Renotar" | ||||
| _deck: | ||||
| @@ -2452,6 +2525,8 @@ _webhookSettings: | ||||
|     abuseReport: "Quan reps un nou informe de moderació " | ||||
|     abuseReportResolved: "Quan resols un informe de moderació " | ||||
|     userCreated: "Quan es crea un usuari" | ||||
|     inactiveModeratorsWarning: "Quan el compte d'un moderador no té activitat durant un temps" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "Quan el compte d'un moderador no té activitat durant un temps, i el servidor es canvia a registre per invitacions" | ||||
|   deleteConfirm: "Segur que vols esborrar el webhook?" | ||||
|   testRemarks: "Si feu clic al botó a la dreta de l'interruptor, podeu enviar un webhook de prova amb dades dummy." | ||||
| _abuseReport: | ||||
| @@ -2497,6 +2572,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "Fitxer marcat com a sensible" | ||||
|   unmarkSensitiveDriveFile: "S'ha tret la marca de sensible del fitxer" | ||||
|   resolveAbuseReport: "Informe resolt" | ||||
|   forwardAbuseReport: "Informe reenviat" | ||||
|   updateAbuseReportNote: "Nota de moderació d'un informe actualitzat" | ||||
|   createInvitation: "Crear codi d'invitació " | ||||
|   createAd: "Anunci creat" | ||||
|   deleteAd: "Anunci esborrat" | ||||
| @@ -2577,8 +2654,141 @@ _dataSaver: | ||||
|     description: "Les imatges en miniatura que serveixen com a vista prèvia de les URLs no es tornaran a carregar." | ||||
|   _code: | ||||
|     title: "Ressaltat del codi " | ||||
|     description: "Quan s'utilitza codi MFM, no es llegeix fins que es copiï. En els punts destacats del codi s'han de llegir els fitxers definits per a cada llengua que resulti alt, però no es poden llegir automàticament, per la qual cosa es poden reduir les quantitats de comunicació." | ||||
| _hemisphere: | ||||
|   N: "Hemisferi Nord " | ||||
|   S: "Hemisferi Sud" | ||||
|   caption: "El fan servir alguns clients per determinar l'estació de l'any." | ||||
| _reversi: | ||||
|   reversi: "Reversi" | ||||
|   gameSettings: "Opcions del joc" | ||||
|   chooseBoard: "Escull un taulell" | ||||
|   blackOrWhite: "Negres/Blanques" | ||||
|   blackIs: "{name} juga amb negres " | ||||
|   rules: "Regles" | ||||
|   thisGameIsStartedSoon: "El joc començarà en breu" | ||||
|   waitingForOther: "Esperant la tirada de l'oponent " | ||||
|   waitingForMe: "Esperant el teu torn" | ||||
|   waitingBoth: "Prepara't " | ||||
|   ready: "Preparat " | ||||
|   cancelReady: " No preparat " | ||||
|   opponentTurn: "Torn de l'oponent " | ||||
|   myTurn: "El teu torn" | ||||
|   turnOf: "Li toca a {name}" | ||||
|   pastTurnOf: "Torn de {name}" | ||||
|   surrender: "Rendeix-te" | ||||
|   surrendered: "T'has rendit" | ||||
|   timeout: "Temps esgotat" | ||||
|   drawn: "Empat" | ||||
|   won: "{name} ha guanyat" | ||||
|   black: "Negres" | ||||
|   white: "Blanques" | ||||
|   total: "Total" | ||||
|   turnCount: "Torn {count}" | ||||
|   myGames: "Jugades" | ||||
|   allGames: "Totes les jugades" | ||||
|   ended: "Acabat" | ||||
|   playing: "Jugant" | ||||
|   isLlotheo: "Qui tingui menys pedres guanya (Llotheo)" | ||||
|   loopedMap: "Mapa de recursiu" | ||||
|   canPutEverywhere: "Les fitxes es poden posar a qualsevol lloc" | ||||
|   timeLimitForEachTurn: "Temps límit per jugada" | ||||
|   freeMatch: "Partida lliure" | ||||
|   lookingForPlayer: "Buscant contrincant..." | ||||
|   gameCanceled: "La partida s'ha cancel·lat " | ||||
|   shareToTlTheGameWhenStart: "Compartir la partida a la línia de temps quan comenci" | ||||
|   iStartedAGame: "La partida ha començat! #MisskeyReversi" | ||||
|   opponentHasSettingsChanged: "L'oponent h canviat la seva configuració " | ||||
|   allowIrregularRules: "Regles irregulars (totalment lliure)" | ||||
|   disallowIrregularRules: "Sense regles irregulars" | ||||
|   showBoardLabels: "Mostrar el número de línia i columna al tauler de joc" | ||||
|   useAvatarAsStone: "Fer servir els avatars dels usuaris com a fitxes" | ||||
| _offlineScreen: | ||||
|   title: "Fora de línia - No es pot connectar amb el servidor" | ||||
|   header: "Impossible connectar amb el servidor" | ||||
| _urlPreviewSetting: | ||||
|   title: "Configuració per a la previsualització de l'URL" | ||||
|   enable: "Activa la previsualització de l'URL" | ||||
|   timeout: "Temps màxim per carregar la previsualització de l'URL (ms)" | ||||
|   timeoutDescription: "Si l'obtenció de la previsualització triga més que el temps establert, no es generarà la vista prèvia." | ||||
|   maximumContentLength: "Longitud màxima del contingut (bytes)" | ||||
|   maximumContentLengthDescription: "Si la màxima longitud és més gran que aquest valor, la previsualització no es generarà." | ||||
|   requireContentLength: "Generar la previsualització només si es pot obtenir la longitud màxima " | ||||
|   requireContentLengthDescription: "Si l'altre servidor no proporciona la longitud màxima, la previsualització no es generarà." | ||||
|   userAgent: "User-Agent" | ||||
|   userAgentDescription: "Estableix l'User-Agent que és farà servir per a la recuperació de la vista prèvia. Si és deixa en blanc es farà servir l'User-Agent per defecte." | ||||
|   summaryProxy: "Proxy endpoints per generar vistes prèvies" | ||||
|   summaryProxyDescription: "La vista prèvia es genera fent servir Summaly proxy, no la genera el mateix Misskey." | ||||
|   summaryProxyDescription2: "Els següents paràmetres són passats al proxy com cadenes de consulta. Si el proxy no els admet, s'ignoren els valors configurats." | ||||
| _mediaControls: | ||||
|   pip: "Imatge sobre impressionada " | ||||
|   playbackRate: "Velocitat de reproducció " | ||||
|   loop: "Reproducció en bucle" | ||||
| _contextMenu: | ||||
|   title: "Menú contextual" | ||||
|   app: "Aplicació " | ||||
|   appWithShift: "Aplicació amb la tecla shift" | ||||
|   native: "Interfície del navegador" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "Aquest camp és obligatori" | ||||
|     columnTypeNotSupport: "La validació d'expressions regulars només s'admet per columnes de tipus text." | ||||
|     patternNotMatch: "Aquest valor no coincideix amb {pattern}" | ||||
|     notUnique: "Aquest valor ha de ser únic " | ||||
| _roleSelectDialog: | ||||
|   notSelected: "No seleccionat" | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "Copiar línies seleccionades " | ||||
|     copySelectionRanges: "Copiar selecció " | ||||
|     deleteSelectionRows: "Esborrar línies seleccionades" | ||||
|     deleteSelectionRanges: "Esborrar files de la selecció " | ||||
|     searchSettings: "Configuració del cercador" | ||||
|     searchSettingCaption: "Defineix criteris de cerca detallats." | ||||
|     searchLimit: "Nombre de pantalles" | ||||
|     sortOrder: "Ordenar" | ||||
|     registrationLogs: "Registres d'inscripcions " | ||||
|     registrationLogsCaption: "Quan s'actualitzin o s'esborrin emojis es mostrarà un registre. Desapareixeran quan s'actualitzin, s'esborrin, visitis una nova pàgina o la recarreguis." | ||||
|     alertEmojisRegisterFailedDescription: "No s'ha pogut actualitzar o esborrar l'emoji. Si us plau, dona una ullada al registre per més detalls." | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "Mostrar el registre d'èxit " | ||||
|     failureLogNothing: "No hi ha registres de fallades." | ||||
|     logNothing: "No hi ha registres." | ||||
|   _remote: | ||||
|     selectionRowDetail: "Detall de la línia seleccionada" | ||||
|     importSelectionRows: "Importar les files seleccionades" | ||||
|     importSelectionRangesRows: "Importar les files de la selecció " | ||||
|     importEmojisButton: "Importar els Emojis marcats" | ||||
|     confirmImportEmojisTitle: "Importar Emojis" | ||||
|     confirmImportEmojisDescription: "Importar {count} Emojis d'una adreça remota. Tingues cura de les llicències dels Emojis. Vols importar-los?" | ||||
|   _local: | ||||
|     tabTitleList: "Llistar els Emojis registrats" | ||||
|     tabTitleRegister: "Registre d'Emojis" | ||||
|     _list: | ||||
|       emojisNothing: "No hi ha Emojis registrats" | ||||
|       markAsDeleteTargetRows: "Files seleccionades que s'han d'esborrar " | ||||
|       markAsDeleteTargetRanges: "Selecció de files per la seva eliminació " | ||||
|       alertUpdateEmojisNothingDescription: "No hi ha Emojis actualitzats." | ||||
|       alertDeleteEmojisNothingDescription: "No hi ha Emoji per esborrar." | ||||
|       confirmMovePage: "Vols canviar de pàgina?" | ||||
|       confirmChangeView: "Vols canviar la pantalla?" | ||||
|       confirmUpdateEmojisDescription: "Actualitzar {count} Emojis. Vols executar-ho?" | ||||
|       confirmDeleteEmojisDescription: "Esborrar {count} Emojis marcats. Vols continuar?" | ||||
|       confirmResetDescription: "Es restabliran tots els canvis fets fins ara." | ||||
|       confirmMovePageDesciption: "S'han fet canvis als Emojis d'aquesta pàgina. Si continues navegant sense guardar els canvis, es perdran tots els canvis fets en aquesta pàgina." | ||||
|       dialogSelectRoleTitle: "Buscar Emojis per rol" | ||||
|     _register: | ||||
|       uploadSettingTitle: "Actualitza la configuració " | ||||
|       uploadSettingDescription: "En aquesta pantalla pots configurar el que s'ha de fer quan es puja un Emoji." | ||||
|       directoryToCategoryLabel: "Escriu el nom del directori al camp de \"categoria\"" | ||||
|       directoryToCategoryCaption: "Quan arrossegues un directori, escriu el nom del directori al camp categoria." | ||||
|       emojiInputAreaCaption: "Selecciona els Emojis que vols registrar gent servir un dels mètodes." | ||||
|       emojiInputAreaList1: "Arrossega i deixar anar fitxers o directoris dintre del quadrat." | ||||
|       emojiInputAreaList2: "Clica l'enllaç per seleccionar un fitxer des del teu ordinador." | ||||
|       emojiInputAreaList3: "Clica aquest enllaç per seleccionar del Disc" | ||||
|       confirmRegisterEmojisDescription: "Registrar els Emojis de la llista com a nous Emojis personalitzats. Vols continuar? (Per evitar una sobrecàrrega només {count} Emojis es poden registrar d'una sola vegada)" | ||||
|       confirmClearEmojisDescription: "Descartar els canvis i esborrar els Emojis de la llista. Vols continuar?" | ||||
|       confirmUploadEmojisDescription: "Pujar els {count} fitxers que has arrossegat al disc. Vols continuar?" | ||||
| _embedCodeGen: | ||||
|   title: "Personalitza el codi per incrustar" | ||||
|   header: "Mostrar la capçalera" | ||||
| @@ -2593,3 +2803,43 @@ _embedCodeGen: | ||||
|   generateCode: "Crea el codi per incrustar" | ||||
|   codeGenerated: "Codi generat" | ||||
|   codeGeneratedDescription: "Si us plau, enganxeu el codi generat al lloc web." | ||||
| _selfXssPrevention: | ||||
|   warning: "Advertència " | ||||
|   title: "\"Enganxa qualsevol cosa en aquesta finestra\"  És tot un engany." | ||||
|   description1: "Si posa alguna cosa al seu compte, un usuari malintencionat podria segrestar-la o robar-li les dades." | ||||
|   description2: "Si no entens que estàs fent %cpara ara mateix i tanca la finestra." | ||||
|   description3: "Per obtenir més informació. {link}" | ||||
| _followRequest: | ||||
|   recieved: "Sol·licituds rebudes" | ||||
|   sent: "Sol·licituds enviades" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "No es pot establir connexió amb aquest servidor" | ||||
|     description: "És possible que s'hagi desactivat la comunicació amb aquest servidor o que hagi estat bloquejat.\nPosa't en contacte amb l'administrador del servidor." | ||||
|   _uriInvalid: | ||||
|     title: "L'adreça és incorrecte" | ||||
|     description: "Hi ha un problema amb l'adreça introduïda; comprova que no hagis escrit caràcters que no es puguin fer servir." | ||||
|   _requestFailed: | ||||
|     title: "La sol·licitud a fallat" | ||||
|     description: "La comunicació amb aquest servidor a fallat. És possible que l'altre servidor no funcioni. Comprova també que no has posat una adreça no vàlida o inexistent." | ||||
|   _responseInvalid: | ||||
|     title: "La resposta no és correcta " | ||||
|     description: "Hem pogut comunicar-nos amb aquest servidor, però les dades rebudes no són correctes." | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "El domini de l'adreça introduïda no és el mateix que el domini de l'adreça final obtinguda. Si estàs consultant continguts remots mitjançant servidors tercers, torna a fer la consulta fent servir l'adreça que es pot obtenir en el servidor origen." | ||||
|   _noSuchObject: | ||||
|     title: "No s'ha trobat" | ||||
|     description: "No es pot trobar el recurs sol·licitat, si us plau comprova l'adreça una altra vegada." | ||||
| _captcha: | ||||
|   verify: "Passar pel CAPTCHA" | ||||
|   testSiteKeyMessage: "Pots comprovar una vista prèvia introduïnt valors de prova per la clau del lloc i la clau secreta. Si vols més informació consulteu la següent pàgina." | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "Ha fallat la sol·licitud del CAPTCHA" | ||||
|       text: "Si us plau, torna a intentar-ho d'aquí una estona o comprova els ajustos de nou." | ||||
|     _verificationFailed: | ||||
|       title: "Ha fallat la validació CAPTCHA" | ||||
|       text: "Comprova que els ajustos són els correctes." | ||||
|     _unknown: | ||||
|       title: "Error CAPTCHA" | ||||
|       text: "S'ha produït un error inesperat." | ||||
|   | ||||
| @@ -348,7 +348,6 @@ enableLocalTimeline: "Povolit lokální čas" | ||||
| enableGlobalTimeline: "Povolit globální čas" | ||||
| disablingTimelinesInfo: "Administrátoři a Moderátoři budou mít stálý přístup ke všem časovým osám i přes to že nejsou zapnuté." | ||||
| registration: "Registrace" | ||||
| enableRegistration: "Povolit registraci novým uživatelům" | ||||
| invite: "Pozvat" | ||||
| driveCapacityPerLocalAccount: "Kapacita disku na lokálního uživatele" | ||||
| driveCapacityPerRemoteAccount: "Kapacita disku na vzdáleného uživatele" | ||||
| @@ -657,10 +656,7 @@ abuseReported: "Nahlášení bylo odesláno. Děkujeme převelice." | ||||
| reporter: "Nahlásil" | ||||
| reporteeOrigin: "Původ nahlášení" | ||||
| reporterOrigin: "Původ nahlasovače" | ||||
| forwardReport: "Přeposlat nahlášení do vzdálené instance" | ||||
| forwardReportIsAnonymous: "Místo vašeho účtu se ve vzdálené instanci zobrazí anonymní systémový účet jako nahlašovač." | ||||
| send: "Odeslat" | ||||
| abuseMarkAsResolved: "Označit nahlášení jako vyřešené" | ||||
| openInNewTab: "Otevřít v nové kartě" | ||||
| openInSideView: "Otevřít v bočním panelu" | ||||
| defaultNavigationBehaviour: "Výchozí chování navigace" | ||||
| @@ -1632,7 +1628,6 @@ _theme: | ||||
|     buttonBg: "Pozadí tlačítka" | ||||
|     buttonHoverBg: "Pozadí tlačítka (Hover)" | ||||
|     inputBorder: "Ohraničení vstupního pole" | ||||
|     listItemHoverBg: "Pozadí položky seznamu (Hover)" | ||||
|     driveFolderBg: "Pozadí složky disku" | ||||
|     wallpaperOverlay: "Překrytí tapety" | ||||
|     badge: "Odznak" | ||||
| @@ -1962,6 +1957,7 @@ _notification: | ||||
|     receiveFollowRequest: "Obdržené žádosti o sledování" | ||||
|     followRequestAccepted: "Přijaté žádosti o sledování" | ||||
|     achievementEarned: "Úspěch odemčen" | ||||
|     login: "Přihlásit se" | ||||
|     app: "Oznámení z propojených aplikací" | ||||
|   _actions: | ||||
|     followBack: "vás začal sledovat zpět" | ||||
| @@ -2028,3 +2024,6 @@ _moderationLogTypes: | ||||
|   createInvitation: "Vygenerovat pozvánku" | ||||
| _reversi: | ||||
|   total: "Celkem" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Nenalezeno" | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "Suchen" | ||||
| notifications: "Benachrichtigungen" | ||||
| username: "Benutzername" | ||||
| password: "Passwort" | ||||
| initialPasswordForSetup: "Initiales Passwort für die Einrichtung" | ||||
| initialPasswordIsIncorrect: "Das initiale Passwort für die Einrichtung ist falsch" | ||||
| initialPasswordForSetupDescription: "Verwende das in der Konfigurationsdatei angegebene Passwort, wenn du Misskey selbst installiert hast.\nWenn du einen Misskey-Hostingdienst o.ä. nutzt, verwende das dort angegebene Kennwort.\nWenn du kein Passwort festgelegt hast, lasse es leer, um fortzufahren." | ||||
| forgotPassword: "Passwort vergessen" | ||||
| fetchingAsApObject: "Wird aus dem Fediverse angefragt …" | ||||
| ok: "OK" | ||||
| @@ -60,6 +63,7 @@ copyFileId: "Datei-ID kopieren" | ||||
| copyFolderId: "Ordner-ID kopieren" | ||||
| copyProfileUrl: "Profil-URL kopieren" | ||||
| searchUser: "Nach einem Benutzer suchen" | ||||
| searchThisUsersNotes: "Notizen dieses Benutzers suchen" | ||||
| reply: "Antworten" | ||||
| loadMore: "Mehr laden" | ||||
| showMore: "Mehr anzeigen" | ||||
| @@ -108,11 +112,14 @@ enterEmoji: "Gib ein Emoji ein" | ||||
| renote: "Renote" | ||||
| unrenote: "Renote zurücknehmen" | ||||
| renoted: "Renote getätigt." | ||||
| renotedToX: "Renoted zu {name}." | ||||
| cantRenote: "Renote dieses Beitrags nicht möglich." | ||||
| cantReRenote: "Renote einer Renote nicht möglich." | ||||
| quote: "Zitieren" | ||||
| inChannelRenote: "Kanal-interner Renote" | ||||
| inChannelQuote: "Kanal-internes Zitat" | ||||
| renoteToChannel: "Renote zu Kanal" | ||||
| renoteToOtherChannel: "Renote zu anderem Kanal" | ||||
| pinnedNote: "Angeheftete Notiz" | ||||
| pinned: "Angeheftet" | ||||
| you: "Du" | ||||
| @@ -124,12 +131,13 @@ reactions: "Reaktionen" | ||||
| emojiPicker: "Emoji auswählen" | ||||
| pinnedEmojisForReactionSettingDescription: "Lege Emojis fest, die angepinnt werden sollen, um sie beim Reagieren als Erstes anzuzeigen." | ||||
| pinnedEmojisSettingDescription: "Lege Emojis fest, die angepinnt werden sollen, um sie in der Emoji-Auswahl als Erstes anzuzeigen" | ||||
| emojiPickerDisplay: "Anzeige der Emoji-Auswahl" | ||||
| overwriteFromPinnedEmojisForReaction: "Überschreiben mit den Reaktions-Einstellungen" | ||||
| overwriteFromPinnedEmojis: "Überschreiben mit den allgemeinen Einstellungen" | ||||
| reactionSettingDescription2: "Ziehe um Anzuordnen, klicke um zu löschen, drücke „+“ um hinzuzufügen" | ||||
| rememberNoteVisibility: "Notizsichtbarkeit merken" | ||||
| attachCancel: "Anhang entfernen" | ||||
| deleteFile: "Datei gelöscht" | ||||
| deleteFile: "Datei löschen" | ||||
| markAsSensitive: "Als sensibel markieren" | ||||
| unmarkAsSensitive: "Als nicht sensibel markieren" | ||||
| enterFileName: "Dateinamen eingeben" | ||||
| @@ -150,6 +158,7 @@ editList: "Liste bearbeiten" | ||||
| selectChannel: "Kanal auswählen" | ||||
| selectAntenna: "Antenne auswählen" | ||||
| editAntenna: "Antenne bearbeiten" | ||||
| createAntenna: "Erstelle eine Antenne" | ||||
| selectWidget: "Widget auswählen" | ||||
| editWidgets: "Widgets bearbeiten" | ||||
| editWidgetsExit: "Fertig" | ||||
| @@ -176,6 +185,10 @@ addAccount: "Benutzerkonto hinzufügen" | ||||
| reloadAccountsList: "Benutzerkontoliste aktualisieren" | ||||
| loginFailed: "Anmeldung fehlgeschlagen" | ||||
| showOnRemote: "Auf Ursprungsinstanz ansehen" | ||||
| continueOnRemote: "Weiter auf Remote-Server" | ||||
| chooseServerOnMisskeyHub: "Wähle einen Server aus dem Misskey Hub" | ||||
| specifyServerHost: "Server-Host auswählen" | ||||
| inputHostName: "Gib die Domain an" | ||||
| general: "Allgemein" | ||||
| wallpaper: "Hintergrund" | ||||
| setWallpaper: "Hintergrund festlegen" | ||||
| @@ -186,6 +199,7 @@ followConfirm: "Möchtest du {name} wirklich folgen?" | ||||
| proxyAccount: "Proxy-Benutzerkonto" | ||||
| proxyAccountDescription: "Ein Proxy-Konto ist ein Benutzerkonto, das unter bestimmten Bedingungen als Follower für Benutzer fremder Instanzen fungiert. Wenn zum Beispiel ein Benutzer einen Benutzer einer fremden Instanz zu einer Liste hinzufügt, werden die Aktivitäten des entfernten Benutzers nicht an die Instanz übermittelt, wenn kein lokaler Benutzer diesem Benutzer folgt; stattdessen folgt das Proxy-Konto." | ||||
| host: "Hostname" | ||||
| selectSelf: "Mich auswählen" | ||||
| selectUser: "Benutzer auswählen" | ||||
| recipient: "Empfänger" | ||||
| annotation: "Anmerkung" | ||||
| @@ -201,6 +215,7 @@ perDay: "Pro Tag" | ||||
| stopActivityDelivery: "Senden von Aktivitäten einstellen" | ||||
| blockThisInstance: "Diese Instanz blockieren" | ||||
| silenceThisInstance: "Instanz stummschalten" | ||||
| mediaSilenceThisInstance: "Medien dieses Servers stummschalten" | ||||
| operations: "Aktionen" | ||||
| software: "Software" | ||||
| version: "Version" | ||||
| @@ -222,6 +237,10 @@ blockedInstances: "Blockierte Instanzen" | ||||
| blockedInstancesDescription: "Gib die Hostnamen der Instanzen, welche blockiert werden sollen, durch Zeilenumbrüche getrennt an. Blockierte Instanzen können mit dieser instanz nicht mehr kommunizieren." | ||||
| silencedInstances: "Stummgeschaltete Instanzen" | ||||
| silencedInstancesDescription: "Gib die Hostnamen der Instanzen, welche stummgeschaltet werden sollen, durch Zeilenumbrüche getrennt an. Alle Konten dieser Instanzen werden als stummgeschaltet behandelt, können nur noch Follow-Anfragen stellen und wenn nicht gefolgt keine lokalen Konten erwähnen. Blockierte Instanzen sind davon nicht betroffen." | ||||
| mediaSilencedInstances: "Medien-stummgeschaltete Server" | ||||
| mediaSilencedInstancesDescription: "Gib pro Zeile die Hostnamen der Server ein, dessen Medien du stummschalten möchtest. Alle Benutzerkonten der aufgeführten Server werden als sensibel behandelt und können keine benutzerdefinierten Emojis verwenden. Gesperrte Server sind davon nicht betroffen." | ||||
| federationAllowedHosts: "Föderierte Instanzen" | ||||
| federationAllowedHostsDescription: "Trage die Hostnamen ein mit den du eine Föderation eingehen möchtest. Trenne mit Zeilenumbruch." | ||||
| muteAndBlock: "Stummschaltungen und Blockierungen" | ||||
| mutedUsers: "Stummgeschaltete Benutzer" | ||||
| blockedUsers: "Blockierte Benutzer" | ||||
| @@ -312,6 +331,7 @@ selectFile: "Datei auswählen" | ||||
| selectFiles: "Dateien auswählen" | ||||
| selectFolder: "Ordner auswählen" | ||||
| selectFolders: "Ordner auswählen" | ||||
| fileNotSelected: "Keine Datei ausgewählt" | ||||
| renameFile: "Datei umbenennen" | ||||
| folderName: "Ordnername" | ||||
| createFolder: "Ordner erstellen" | ||||
| @@ -319,6 +339,7 @@ renameFolder: "Ordner umbenennen" | ||||
| deleteFolder: "Ordner löschen" | ||||
| folder: "Ordner" | ||||
| addFile: "Datei hinzufügen" | ||||
| showFile: "Datei anzeigen" | ||||
| emptyDrive: "Deine Drive ist leer" | ||||
| emptyFolder: "Dieser Ordner ist leer" | ||||
| unableToDelete: "Nicht löschbar" | ||||
| @@ -361,7 +382,6 @@ enableLocalTimeline: "Lokale Chronik aktivieren" | ||||
| enableGlobalTimeline: "Globale Chronik aktivieren" | ||||
| disablingTimelinesInfo: "Administratoren und Moderatoren haben immer Zugriff auf alle Chroniken, auch wenn diese deaktiviert sind." | ||||
| registration: "Registrieren" | ||||
| enableRegistration: "Registrierung neuer Benutzer erlauben" | ||||
| invite: "Einladen" | ||||
| driveCapacityPerLocalAccount: "Drive-Kapazität pro lokalem Benutzerkonto" | ||||
| driveCapacityPerRemoteAccount: "Drive-Kapazität pro Benutzer fremder Instanzen" | ||||
| @@ -399,6 +419,7 @@ name: "Name" | ||||
| antennaSource: "Antennenquelle" | ||||
| antennaKeywords: "Zu beobachtende Schlüsselwörter" | ||||
| antennaExcludeKeywords: "Zu ignorierende Schlüsselwörter" | ||||
| antennaExcludeBots: "Bot-Accounts ausschließen" | ||||
| antennaKeywordsDescription: "Zum Nutzen einer \"UND\"-Verknüpfung Einträge mit Leerzeichen trennen, zum Nutzen einer \"ODER\"-Verknüpfung Einträge mit einem Zeilenumbruch trennen" | ||||
| notifyAntenna: "Über neue Notizen benachrichtigen" | ||||
| withFileAntenna: "Nur Notizen mit Dateien" | ||||
| @@ -432,6 +453,7 @@ totpDescription: "Logge dich via Authentifizierungs-App mit Einmalpasswort ein" | ||||
| moderator: "Moderator" | ||||
| moderation: "Moderation" | ||||
| moderationNote: "Moderationsnotiz" | ||||
| moderationNoteDescription: "Trage hier Notizen ein. Diese sind nur für die Moderatoren sichtbar." | ||||
| addModerationNote: "Moderationsnotiz hinzufügen" | ||||
| moderationLogs: "Moderationsprotokolle" | ||||
| nUsersMentioned: "Von {n} Benutzern erwähnt" | ||||
| @@ -466,10 +488,12 @@ retype: "Erneut eingeben" | ||||
| noteOf: "Notiz von {user}" | ||||
| quoteAttached: "Zitat" | ||||
| quoteQuestion: "Als Zitat anhängen?" | ||||
| attachAsFileQuestion: "Der Text in der Zwischenablage ist lang. Möchtest du ihn als Textdatei anhängen?" | ||||
| noMessagesYet: "Noch keine Nachrichten vorhanden" | ||||
| newMessageExists: "Du hast eine neue Nachricht" | ||||
| onlyOneFileCanBeAttached: "Es kann pro Nachricht nur eine Datei angehängt werden" | ||||
| signinRequired: "Bitte registriere oder melde dich an, um fortzufahren" | ||||
| signinOrContinueOnRemote: "Um fortzufahren, gehe zu deiner Instanz oder registriere bzw. melde dich an dieser Instanz an. " | ||||
| invitations: "Einladungen" | ||||
| invitationCode: "Einladungscode" | ||||
| checking: "Wird überprüft …" | ||||
| @@ -491,7 +515,11 @@ uiLanguage: "Sprache der Benutzeroberfläche" | ||||
| aboutX: "Über {x}" | ||||
| emojiStyle: "Emoji-Stil" | ||||
| native: "Nativ" | ||||
| menuStyle: "Menü Stil" | ||||
| style: "Stil" | ||||
| popup: "Pop-up" | ||||
| showNoteActionsOnlyHover: "Notizmenü nur bei Mouseover anzeigen" | ||||
| showReactionsCount: "Zeige die Anzahl der Reaktionen auf Notizen an" | ||||
| noHistory: "Kein Verlauf gefunden" | ||||
| signinHistory: "Anmeldungsverlauf" | ||||
| enableAdvancedMfm: "Erweitertes MFM aktivieren" | ||||
| @@ -557,6 +585,7 @@ masterVolume: "Gesamtlautstärke" | ||||
| notUseSound: "Gebe kein Ton aus" | ||||
| useSoundOnlyWhenActive: "Gebe nur Ton aus, wenn Misskey aktiv ist" | ||||
| details: "Details" | ||||
| renoteDetails: "Renote Details" | ||||
| chooseEmoji: "Emoji auswählen" | ||||
| unableToProcess: "Der Vorgang konnte nicht abgeschlossen werden" | ||||
| recentUsed: "Vor kurzem verwendet" | ||||
| @@ -572,6 +601,8 @@ ascendingOrder: "Aufsteigende Reihenfolge" | ||||
| descendingOrder: "Absteigende Reihenfolge" | ||||
| scratchpad: "Testumgebung" | ||||
| scratchpadDescription: "Die Testumgebung bietet einen Bereich für AiScript-Experimente. Dort kannst du AiScript schreiben, ausführen sowie dessen Auswirkungen auf Misskey überprüfen." | ||||
| uiInspector: "UI-Inspektor" | ||||
| uiInspectorDescription: "Die Liste der UI-Komponenten-Server können im Zwischenspeicher angesehen werden. Die UI-Komponente wird von der Funktion Ui:C: generiert." | ||||
| output: "Ausgabe" | ||||
| script: "Skript" | ||||
| disablePagesScript: "AiScript auf Seiten deaktivieren" | ||||
| @@ -652,6 +683,10 @@ smtpSecure: "Für SMTP-Verbindungen implizit SSL/TLS verwenden" | ||||
| smtpSecureInfo: "Schalte dies aus, falls du STARTTLS verwendest." | ||||
| testEmail: "Emailversand testen" | ||||
| wordMute: "Wortstummschaltung" | ||||
| wordMuteDescription: "Minimiert Notizen, die das angegebene Wort oder den angegebenen Ausdruck enthalten. Minimierte Notizen können angezeigt werden, indem du auf sie klickst." | ||||
| hardWordMute: "Harte Wortstummschaltung" | ||||
| showMutedWord: "Stummgeschaltete Wörter anzeigen" | ||||
| hardWordMuteDescription: "Blendet Notizen aus, die das angegebene Wort oder die angegebene Phrase enthalten. Im Gegensatz zur Wortstummschaltung wird die Notiz vollständig ausgeblendet." | ||||
| regexpError: "Fehler in einem regulären Ausdruck" | ||||
| regexpErrorDescription: "Im regulären Ausdruck deiner in Zeile {line} von {tab}en Wortstummschaltungen ist ein Fehler aufgetreten:" | ||||
| instanceMute: "Instanzstummschaltungen" | ||||
| @@ -673,6 +708,7 @@ useGlobalSettingDesc: "Ist diese Option aktiviert, werden die Benachrichtigungse | ||||
| other: "Anderes" | ||||
| regenerateLoginToken: "Anmeldetoken regenerieren" | ||||
| regenerateLoginTokenDescription: "Den zur Anmeldung intern verwendeten Token regenerieren. Normalerweise wird dies nicht benötigt. Bei Regeneration werden alle Geräte ausgeloggt." | ||||
| theKeywordWhenSearchingForCustomEmoji: "Das ist das Schlagwort beim Suchen von benutzerdefinierten Emojis." | ||||
| setMultipleBySeparatingWithSpace: "Trenne Elemente durch ein Leerzeichen um mehrere Einstellungen zu kofigurieren." | ||||
| fileIdOrUrl: "Datei-ID oder URL" | ||||
| behavior: "Verhalten" | ||||
| @@ -686,10 +722,7 @@ abuseReported: "Deine Meldung wurde versendet. Vielen Dank." | ||||
| reporter: "Melder" | ||||
| reporteeOrigin: "Herkunft des Gemeldeten" | ||||
| reporterOrigin: "Herkunft des Meldenden" | ||||
| forwardReport: "Meldung an fremde Instanz weiterleiten" | ||||
| forwardReportIsAnonymous: "Anstatt deines Benutzerkontos wird bei der fremden Instanz ein anonymes Systemkonto als Melder angezeigt." | ||||
| send: "Senden" | ||||
| abuseMarkAsResolved: "Meldung als gelöst markieren" | ||||
| openInNewTab: "In neuem Tab öffnen" | ||||
| openInSideView: "In Seitenansicht öffnen" | ||||
| defaultNavigationBehaviour: "Standardnavigationsverhalten" | ||||
| @@ -885,9 +918,12 @@ makeReactionsPublicDescription: "Jeder wird die Liste deiner gesendeten Reaktion | ||||
| classic: "Classic" | ||||
| muteThread: "Thread stummschalten" | ||||
| unmuteThread: "Threadstummschaltung aufheben" | ||||
| followingVisibility: "Sichtbarkeit der Gefolgten" | ||||
| followersVisibility: "Sichtbarkeit der Folgenden" | ||||
| continueThread: "Weiteren Threadverlauf anzeigen" | ||||
| deleteAccountConfirm: "Dein Benutzerkonto wird unwiderruflich gelöscht. Trotzdem fortfahren?" | ||||
| incorrectPassword: "Falsches Passwort." | ||||
| incorrectTotp: "Das Einmalpasswort ist falsch oder abgelaufen." | ||||
| voteConfirm: "Wirklich für „{choice}“ abstimmen?" | ||||
| hide: "Inhalt verbergen" | ||||
| useDrawerReactionPickerForMobile: "Auf mobilen Geräten ausfahrbare Reaktionsauswahl anzeigen" | ||||
| @@ -912,6 +948,9 @@ oneHour: "Eine Stunde" | ||||
| oneDay: "Einen Tag" | ||||
| oneWeek: "Eine Woche" | ||||
| oneMonth: "1 Monat" | ||||
| threeMonths: "3 Monate" | ||||
| oneYear: "1 Jahr" | ||||
| threeDays: "3 Tage" | ||||
| reflectMayTakeTime: "Es kann etwas dauern, bis sich dies widerspiegelt." | ||||
| failedToFetchAccountInformation: "Benutzerkontoinformationen konnten nicht abgefragt werden" | ||||
| rateLimitExceeded: "Versuchsanzahl überschritten" | ||||
| @@ -985,6 +1024,7 @@ neverShow: "Nicht wieder anzeigen" | ||||
| remindMeLater: "Vielleicht später" | ||||
| didYouLikeMisskey: "Gefällt dir Misskey?" | ||||
| pleaseDonate: "Misskey ist die kostenlose Software, die von {host} verwendet wird. Wir würden uns über Spenden freuen, damit dessen Entwicklung weitergeführt werden kann!" | ||||
| correspondingSourceIsAvailable: "Der entsprechende Quellcode ist verfügbar unter {anchor}" | ||||
| roles: "Rollen" | ||||
| role: "Rolle" | ||||
| noRole: "Rolle nicht gefunden" | ||||
| @@ -1012,6 +1052,7 @@ thisPostMayBeAnnoyingHome: "Zur Startseite schicken" | ||||
| thisPostMayBeAnnoyingCancel: "Abbrechen" | ||||
| thisPostMayBeAnnoyingIgnore: "Trotzdem schicken" | ||||
| collapseRenotes: "Bereits gesehene Renotes verkürzt anzeigen" | ||||
| collapseRenotesDescription: "Klappe Notizen ein, auf die du bereits reagiert oder die du renoted hast." | ||||
| internalServerError: "Serverinterner Fehler" | ||||
| internalServerErrorDescription: "Im Server ist ein unerwarteter Fehler aufgetreten." | ||||
| copyErrorInfo: "Fehlerdetails kopieren" | ||||
| @@ -1035,6 +1076,8 @@ resetPasswordConfirm: "Wirklich Passwort zurücksetzen?" | ||||
| sensitiveWords: "Sensible Wörter" | ||||
| sensitiveWordsDescription: "Die Notizsichtbarkeit aller Notizen, die diese Wörter enthalten, wird automatisch auf \"Startseite\" gesetzt. Durch Zeilenumbrüche können mehrere konfiguriert werden." | ||||
| sensitiveWordsDescription2: "Durch die Verwendung von Leerzeichen können AND-Verknüpfungen angegeben werden und durch das Umgeben von Schrägstrichen können reguläre Ausdrücke verwendet werden." | ||||
| prohibitedWords: "Verbotene Wörter" | ||||
| prohibitedWordsDescription: "Aktiviert eine Fehlermeldung, wenn versucht wird, eine Notiz zu veröffentlichen, die das/die eingestellte(n) Wort(e) enthält. Mehrere Begriffe können durch Zeilenumbrüche getrennt festgelegt werden." | ||||
| prohibitedWordsDescription2: "Durch die Verwendung von Leerzeichen können AND-Verknüpfungen angegeben werden und durch das Umgeben von Schrägstrichen können reguläre Ausdrücke verwendet werden." | ||||
| hiddenTags: "Ausgeblendete Hashtags" | ||||
| hiddenTagsDescription: "Die hier eingestellten Tags werden nicht mehr in den Trends angezeigt. Mit der Umschalttaste können mehrere ausgewählt werden." | ||||
| @@ -1054,6 +1097,8 @@ limitWidthOfReaction: "Begrenze die Breite der Reaktion und zeige sie verkleiner | ||||
| noteIdOrUrl: "Notiz-ID oder URL" | ||||
| video: "Video" | ||||
| videos: "Videos" | ||||
| audio: "Audio" | ||||
| audioFiles: "Audio" | ||||
| dataSaver: "Datensparmodus" | ||||
| accountMigration: "Kontomigration" | ||||
| accountMoved: "Dieser Benutzer ist zu einem neuen Konto migriert:" | ||||
| @@ -1081,6 +1126,8 @@ preservedUsernames: "Reservierte Benutzernamen" | ||||
| preservedUsernamesDescription: "Gib zu reservierende Benutzernamen durch Zeilenumbrüche getrennt an. Diese werden für die Registrierung gesperrt, können aber von Administratoren zur manuellen Erstellung von Konten verwendet werden. Existierende Konten, die diese Namen bereits verwenden, werden nicht beeinträchtigt." | ||||
| createNoteFromTheFile: "Notiz für diese Datei schreiben" | ||||
| archive: "Archivieren" | ||||
| archived: "Archiviert" | ||||
| unarchive: "Dearchivieren" | ||||
| channelArchiveConfirmTitle: "{name} wirklich archivieren?" | ||||
| channelArchiveConfirmDescription: "Ein archivierter Kanal taucht nicht mehr in der Kanalliste oder in Suchergebnissen auf. Zudem können ihm keine Beiträge mehr hinzugefügt werden." | ||||
| thisChannelArchived: "Dieser Kanal wurde archiviert." | ||||
| @@ -1091,6 +1138,7 @@ preventAiLearning: "Verwendung in machinellem Lernen (Generative bzw. Prediktive | ||||
| preventAiLearningDescription: "Fordert Crawler auf, gepostetes Text- oder Bildmaterial usw. nicht in Datensätzen für maschinelles Lernen (Generative bzw. Prediktive AI/KI) zu verwenden. Dies wird durch das Hinzufügen einer \"noai\"-Flag in der HTML-Antwort des jeweiligen Inhalts erreicht. Da diese Flag jedoch ignoriert werden kann, ist eine vollständige Verhinderung hierdurch nicht möglich." | ||||
| options: "Optionen" | ||||
| specifyUser: "Spezifischer Benutzer" | ||||
| lookupConfirm: "Zustimmen?" | ||||
| failedToPreviewUrl: "Vorschau nicht anzeigbar" | ||||
| update: "Aktualisieren" | ||||
| rolesThatCanBeUsedThisEmojiAsReaction: "Rollen, die dieses Emoji als Reaktion verwenden können" | ||||
| @@ -1158,6 +1206,12 @@ confirmShowRepliesAll: "Dies ist eine unwiderrufliche Aktion. Wirklich Antworten | ||||
| confirmHideRepliesAll: "Dies ist eine unwiderrufliche Aktion. Wirklich Antworten von allen momentan gefolgten Benutzern nicht in der Chronik anzeigen?" | ||||
| externalServices: "Externe Dienste" | ||||
| sourceCode: "Quellcode" | ||||
| sourceCodeIsNotYetProvided: "Der Quellcode ist noch nicht verfügbar. Kontaktiere den Administrator, um das Problem zu lösen." | ||||
| repositoryUrl: "Repository URL" | ||||
| repositoryUrlDescription: "Solltest du Misskey so wie es ist verwenden (im unveränderten Quellcode), gebe Folgendes an:\nhttps://github.com/misskey-dev/misskey" | ||||
| repositoryUrlOrTarballRequired: "Wenn du kein Repository veröffentlicht hast, musst du stattdessen einen Tarball bereitstellen. Siehe .config/example.yml für weitere Informationen." | ||||
| feedback: "Feedback" | ||||
| feedbackUrl: "Feedback-Website" | ||||
| impressum: "Impressum" | ||||
| impressumUrl: "Impressums-URL" | ||||
| impressumDescription: "In manchen Ländern, wie Deutschland und dessen Umgebung, ist die Angabe von Betreiberinformationen (ein Impressum) bei kommerziellem Betrieb zwingend." | ||||
| @@ -1167,6 +1221,7 @@ tosAndPrivacyPolicy: "Nutzungsbedingungen und Datenschutzerklärung" | ||||
| avatarDecorations: "Profilbilddekoration" | ||||
| attach: "Anbringen" | ||||
| detach: "Entfernen" | ||||
| detachAll: "Alles Entfernen" | ||||
| angle: "Winkel" | ||||
| flip: "Umdrehen" | ||||
| showAvatarDecorations: "Profilbilddekoration anzeigen" | ||||
| @@ -1179,15 +1234,105 @@ signupPendingError: "Beim Überprüfen der Mailadresse ist etwas schiefgelaufen. | ||||
| cwNotationRequired: "Ist \"Inhaltswarnung verwenden\" aktiviert, muss eine Beschreibung gegeben werden." | ||||
| doReaction: "Reagieren" | ||||
| code: "Code" | ||||
| reloadRequiredToApplySettings: "Eine Aktualisierung ist erforderlich, um die Einstellungen zu übernehmen." | ||||
| remainingN: "Verbleibend: {n}" | ||||
| overwriteContentConfirm: "Bist du sicher, dass du den aktuellen Inhalt überschreiben willst?" | ||||
| seasonalScreenEffect: "Saisonaler Bildschirmeffekt" | ||||
| decorate: "Dekorieren" | ||||
| addMfmFunction: "MFM hinzufügen" | ||||
| enableQuickAddMfmFunction: "Erweiterte MFM-Auswahl anzeigen" | ||||
| bubbleGame: "Bubble Game" | ||||
| sfx: "Soundeffekte" | ||||
| soundWillBePlayed: "Es wird Ton wiedergegeben" | ||||
| showReplay: "Wiederholung anzeigen" | ||||
| replay: "Aufzeichnen" | ||||
| replaying: "Aufzeichnung" | ||||
| endReplay: "Aufzeichnung verlassen" | ||||
| copyReplayData: "Aufzeichnung kopieren" | ||||
| ranking: "Rangliste" | ||||
| lastNDays: "Letzten {n} Tage" | ||||
| backToTitle: "Zurück zum Startbildschirm" | ||||
| hemisphere: "Hemisphäre" | ||||
| withSensitive: "Zeige \"sensitive Inhalte\" an" | ||||
| userSaysSomethingSensitive: "{name} sagt etwas mit sensiblem Inhalt." | ||||
| enableHorizontalSwipe: "Wischen, um zwischen Tabs zu wechseln" | ||||
| loading: "Laden" | ||||
| surrender: "Abbrechen" | ||||
| gameRetry: "Erneut versuchen" | ||||
| notUsePleaseLeaveBlank: "Leer lassen, wenn nicht verwendet" | ||||
| useTotp: "Gib das Einmalpasswort ein" | ||||
| useBackupCode: "Verwende die Backup-Codes" | ||||
| launchApp: "Starte die App" | ||||
| useNativeUIForVideoAudioPlayer: "Browser-Benutzeroberfläche für die Video- und Audiowiedergabe verwenden" | ||||
| keepOriginalFilename: "Ursprünglichen Dateinamen beibehalten" | ||||
| keepOriginalFilenameDescription: "Wenn diese Einstellung deaktiviert ist, wird der Dateiname beim Hochladen automatisch durch eine zufällige Zeichenfolge ersetzt." | ||||
| noDescription: "Keine Beschreibung vorhanden" | ||||
| alwaysConfirmFollow: "Folgen immer bestätigen" | ||||
| inquiry: "Kontakt" | ||||
| tryAgain: "Bitte später erneut versuchen" | ||||
| confirmWhenRevealingSensitiveMedia: "Das Anzeigen von sensiblen Medien bestätigen" | ||||
| sensitiveMediaRevealConfirm: "Es könnte sich um sensible Medien handeln. Möchtest du sie anzeigen?" | ||||
| createdLists: "Erstellte Listen" | ||||
| createdAntennas: "Erstellte Antennen" | ||||
| fromX: "Von {x}" | ||||
| genEmbedCode: "Einbettungscode generieren" | ||||
| noteOfThisUser: "Notizen dieses Benutzers" | ||||
| clipNoteLimitExceeded: "Zu diesem Clip können keine weiteren Notizen hinzugefügt werden." | ||||
| performance: "Leistung" | ||||
| modified: "Bearbeitet" | ||||
| discard: "Verwerfen" | ||||
| thereAreNChanges: "Es gibt {n} Änderung(en)" | ||||
| signinWithPasskey: "Mit Passkey anmelden" | ||||
| unknownWebAuthnKey: "Unbekannter Passkey" | ||||
| passkeyVerificationFailed: "Die Passkey-Verifizierung ist fehlgeschlagen." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "Die Verifizierung des Passkeys war erfolgreich, aber die passwortlose Anmeldung ist deaktiviert." | ||||
| messageToFollower: "Nachricht an die Follower" | ||||
| target: "Speicherort" | ||||
| testCaptchaWarning: "Diese Funktion ist für CAPTCHA-Testzwecke gedacht.\n<strong>Nicht in einer Produktivumgebung verwenden.</strong>" | ||||
| prohibitedWordsForNameOfUser: "Verbotene Begriffe für Benutzernamen" | ||||
| prohibitedWordsForNameOfUserDescription: "Wenn eine Zeichenfolge aus dieser Liste im Namen eines Benutzers enthalten ist, wird der Benutzername abgelehnt. Benutzer mit Moderatorenrechten sind von dieser Einschränkung nicht betroffen." | ||||
| yourNameContainsProhibitedWords: "Dein Name enthält einen verbotenen Begriff" | ||||
| yourNameContainsProhibitedWordsDescription: "Der Name enthält eine verbotene Zeichenfolge. Wende dich an deinen Serveradministrator, wenn du diesen Namen verwenden möchtest." | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "Logge dich ein, um weitere Inhalte von diesem Nutzer zu sehen." | ||||
| lockdown: "Sperren" | ||||
| pleaseSelectAccount: "Bitte Konto auswählen" | ||||
| availableRoles: "Verfügbare Rollen" | ||||
| federationSpecified: "Dieser Server arbeitet mit Whitelist-Föderation. Er kann nicht mit anderen als den vom Administrator angegebenen Servern interagieren." | ||||
| federationDisabled: "Föderation ist auf diesem Server deaktiviert. Es ist nicht möglich, mit Benutzern auf anderen Servern zu interagieren." | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "Anmeldung erfordern, um Inhalte anzuzeigen" | ||||
|   requireSigninToViewContentsDescription1: "Erfordere eine Anmeldung, um alle Notizen und andere Inhalte anzuzeigen, die du erstellt hast. Dadurch wird verhindert, dass Crawler deine Informationen sammeln." | ||||
|   requireSigninToViewContentsDescription2: "Der Inhalt wird nicht in URL-Vorschauen (OGP), eingebettet in Webseiten oder auf Servern, die keine Zitate unterstützen, angezeigt." | ||||
|   requireSigninToViewContentsDescription3: "Diese Einschränkungen gelten möglicherweise nicht für föderierte Inhalte von anderen Servern." | ||||
|   makeNotesFollowersOnlyBefore: "Macht frühere Notizen nur für Follower sichtbar" | ||||
|   makeNotesHiddenBefore: "Frühere Notizen privat machen" | ||||
|   makeNotesHiddenBeforeDescription: "" | ||||
|   mayNotEffectForFederatedNotes: "Dies hat möglicherweise keine Auswirkungen auf Notizen, die an andere Server föderiert werden." | ||||
|   notesOlderThanSpecifiedDateAndTime: "Notizen vor einem bestimmtem Datum und Uhrzeit" | ||||
| _abuseUserReport: | ||||
|   forward: "Weiterleiten" | ||||
|   forwardDescription: "Leite die Meldung an einen entfernten Server als anonymes Systemkonto weiter." | ||||
|   resolve: "lösen" | ||||
|   accept: "Akzeptieren" | ||||
|   reject: "Ablehnen" | ||||
| _delivery: | ||||
|   stop: "Gesperrt" | ||||
|   _type: | ||||
|     none: "Wird veröffentlicht" | ||||
|     manuallySuspended: "Manuell gesperrt" | ||||
| _bubbleGame: | ||||
|   howToPlay: "Wie man spielt" | ||||
|   hold: "Halten" | ||||
|   _score: | ||||
|     score: "Spielstand" | ||||
|     scoreYen: "Verdienter Geldbetrag" | ||||
|     highScore: "Höchstpunktzahl" | ||||
|     maxChain: "Maximale Anzahl an Verkettungen" | ||||
|     yen: "{yen} Yen" | ||||
|   _howToPlay: | ||||
|     section1: "Passe die Position an und lasse das Objekt in das Spielfeld fallen." | ||||
|     section2: "Wenn sich zwei Objekte der gleichen Art berühren, verwandeln sie sich in ein anderes Objekt und du bekommst Punkte." | ||||
|     section3: "Das Spiel ist vorbei, wenn die Objekte aus dem Spielfeld herausragen. Versuche eine hohe Punktzahl zu erreichen, indem du die Objekte miteinander verschmelzt, ohne dass das Spielfeld überläuft!" | ||||
| _announcement: | ||||
|   forExistingUsers: "Nur für existierende Nutzer" | ||||
|   forExistingUsersDescription: "Ist diese Option aktiviert, wird diese Ankündigung nur Nutzern angezeigt, die zum Zeitpunkt der Ankündigung bereits registriert sind. Ist sie deaktiviert, wird sie auch Nutzern, die sich nach dessen Veröffentlichung registrieren, angezeigt." | ||||
| @@ -1231,8 +1376,18 @@ _initialTutorial: | ||||
|     reply: "Klicke auf diesen Button, um auf eine Nachricht zu antworten. Es ist auch möglich, auf Antworten zu antworten und die Unterhaltung wie einen Thread fortzusetzen." | ||||
|   _reaction: | ||||
|     title: "Was sind Reaktionen?" | ||||
|     description: "Auf Notizen kann mit verschiedenen Emojis reagiert werden. Reaktionen ermöglichen es dir, Nuancen auszudrücken, die mit einem einfachen „Gefällt mir“ vielleicht nicht ausgedrückt werden können." | ||||
|     letsTryReacting: "Reaktionen können durch Klicken auf die Schaltfläche „+“ in der Notiz hinzugefügt werden. Versuche, auf diese Beispielnotiz zu reagieren!" | ||||
|     reactToContinue: "Füge eine Reaktion hinzu, um fortzufahren." | ||||
|     reactNotification: "Du erhältst Echtzeit-Benachrichtigungen, wenn jemand auf deine Notiz reagiert." | ||||
|     reactDone: "Du kannst eine Reaktion zurücknehmen, indem du auf den '-' Button drückst." | ||||
|   _timeline: | ||||
|     title: "So funktionieren die Chroniken" | ||||
|     home: "Du kannst Beiträge von den Konten sehen, denen du folgst." | ||||
|     local: "Du kannst Beiträge aller Benutzer auf diesem Server sehen." | ||||
|     social: "Notizen von der Startseite und der lokalen Chronik werden angezeigt." | ||||
|     global: "Du kannst Notizen von allen föderierten Servern sehen." | ||||
|     description2: "Du kannst jederzeit am oberen Rand des Bildschirms zwischen den jeweiligen Chroniken wechseln." | ||||
|   _postNote: | ||||
|     _visibility: | ||||
|       description: "Du kannst einschränken, wer deine Notiz sehen kann." | ||||
| @@ -1240,8 +1395,16 @@ _initialTutorial: | ||||
|       doNotSendConfidencialOnDirect1: "Sei vorsichtig, wenn du sensible Informationen verschickst!" | ||||
|     _cw: | ||||
|       title: "Inhaltswarnung" | ||||
|       _exampleNote: | ||||
|         note: "Ich hatte gerade einen Donut mit Schokoladenüberzug 🍩😋" | ||||
|   _howToMakeAttachmentsSensitive: | ||||
|     tryThisFile: "Versuche, das angehängte Bild als sensibel zu markieren!" | ||||
|     method: "Um einen Anhang als sensibel zu kennzeichnen, klicke auf das Vorschaubild der Datei, um das Menü zu öffnen, und klicke auf „Als sensibel markieren“." | ||||
|     sensitiveSucceeded: "Wenn du Dateien anhängst, stelle bitte die Sensibilität entsprechend der Serverrichtlinien ein." | ||||
|     doItToContinue: "Markiere die angehängte Datei als sensibel, um fortzufahren." | ||||
|   _done: | ||||
|     title: "Du hast das Tutorial abgeschlossen! 🎉" | ||||
|     description: "Die hier beschriebenen Funktionen sind nur ein kleiner Teil dessen, was Misskey zu bieten hat; um mehr darüber zu erfahren, wie du Misskey benutzen kannst, besuche bitte {link}." | ||||
| _timelineDescription: | ||||
|   local: "In der lokalen Chronik siehst du Notizen von allen Benutzern auf diesem Server." | ||||
|   global: "In der globalen Chronik siehst du Notizen von allen föderierten Servern." | ||||
| @@ -1259,6 +1422,8 @@ _serverSettings: | ||||
|   fanoutTimelineDescription: "Ist diese Option aktiviert, kann eine erhebliche Verbesserung im Abrufen von Chroniken und eine Reduzierung der Datenbankbelastung erzielt werden, im Gegenzug zu einer Steigerung in der Speichernutzung von Redis. Bei geringem Serverspeicher oder Serverinstabilität kann diese Option deaktiviert werden." | ||||
|   fanoutTimelineDbFallback: "Auf die Datenbank zurückfallen" | ||||
|   fanoutTimelineDbFallbackDescription: "Ist diese Option aktiviert, wird die Chronik auf zusätzliche Abfragen in der Datenbank zurückgreifen, wenn sich die Chronik nicht im Cache befindet. Eine Deaktivierung führt zu geringerer Serverlast, aber schränkt den Zeitraum der abrufbaren Chronik ein. " | ||||
|   openRegistrationWarning: "Das Aktivieren von Registrierungen ist riskant. Es wird empfohlen, sie nur dann zu aktivieren, wenn der Server ständig überwacht wird und im Falle eines Problems sofort reagiert werden kann." | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "Wenn über einen bestimmten Zeitraum keine Moderatorenaktivität festgestellt wird, wird diese Einstellung automatisch deaktiviert, um Spam zu verhindern." | ||||
| _accountMigration: | ||||
|   moveFrom: "Von einem anderen Konto zu diesem migrieren" | ||||
|   moveFromSub: "Alias für ein anderes Konto erstellen" | ||||
| @@ -1517,7 +1682,12 @@ _achievements: | ||||
|       title: "Testüberfluss" | ||||
|       description: "Betätige den Benachrichtigungstest mehrfach innerhalb einer extrem kurzen Zeitspanne" | ||||
|     _tutorialCompleted: | ||||
|       title: "Misskey Grundkurs-Diplom" | ||||
|       description: "Tutorial abgeschlossen" | ||||
|     _bubbleGameExplodingHead: | ||||
|       title: "🤯" | ||||
|     _bubbleGameDoubleExplodingHead: | ||||
|       title: "Doppel🤯" | ||||
| _role: | ||||
|   new: "Rolle erstellen" | ||||
|   edit: "Rolle bearbeiten" | ||||
| @@ -1558,6 +1728,7 @@ _role: | ||||
|     gtlAvailable: "Kann auf die globale Chronik zugreifen" | ||||
|     ltlAvailable: "Kann auf die lokale Chronik zugreifen" | ||||
|     canPublicNote: "Kann öffentliche Notizen erstellen" | ||||
|     mentionMax: "Maximale Anzahl von Erwähnungen in einer Notiz" | ||||
|     canInvite: "Erstellung von Einladungscodes für diese Instanz" | ||||
|     inviteLimit: "Maximalanzahl an Einladungen" | ||||
|     inviteLimitCycle: "Zyklus des Einladungslimits" | ||||
| @@ -1580,9 +1751,12 @@ _role: | ||||
|     canSearchNotes: "Nutzung der Notizsuchfunktion" | ||||
|     canUseTranslator: "Verwendung des Übersetzers" | ||||
|     avatarDecorationLimit: "Maximale Anzahl an Profilbilddekorationen, die angebracht werden können" | ||||
|     canImportAntennas: "Importieren von Antennen erlauben" | ||||
|   _condition: | ||||
|     isLocal: "Lokaler Benutzer" | ||||
|     isRemote: "Benutzer fremder Instanz" | ||||
|     isCat: "Katzen-Benutzer" | ||||
|     isBot: "Bot-Benutzer" | ||||
|     createdLessThan: "Kontoerstellung liegt weniger als X zurück" | ||||
|     createdMoreThan: "Kontoerstellung liegt mehr als X zurück" | ||||
|     followersLessThanOrEq: "Hat X oder weniger Follower" | ||||
| @@ -1710,6 +1884,7 @@ _channel: | ||||
|   notesCount: "{n} Notizen" | ||||
|   nameAndDescription: "Name und Beschreibung" | ||||
|   nameOnly: "Nur Name" | ||||
|   allowRenoteToExternal: "Renotes und Zitierungen außerhalb des Kanals erlauben" | ||||
| _menuDisplay: | ||||
|   sideFull: "Seitlich" | ||||
|   sideIcon: "Seitlich (Icons)" | ||||
| @@ -1787,7 +1962,6 @@ _theme: | ||||
|     buttonBg: "Hintergrund von Schaltflächen" | ||||
|     buttonHoverBg: "Hintergrund von Schaltflächen (Mouseover)" | ||||
|     inputBorder: "Rahmen von Eingabefeldern" | ||||
|     listItemHoverBg: "Hintergrund von Listeneinträgen (Mouseover)" | ||||
|     driveFolderBg: "Hintergrund von Drive-Ordnern" | ||||
|     wallpaperOverlay: "Hintergrundbild-Overlay" | ||||
|     badge: "Wappen" | ||||
| @@ -1799,6 +1973,13 @@ _sfx: | ||||
|   note: "Notizen" | ||||
|   noteMy: "Meine Notizen" | ||||
|   notification: "Benachrichtigungen" | ||||
|   reaction: "Auswählen einer Reaktion" | ||||
| _soundSettings: | ||||
|   driveFile: "Audiodatei aus dem Drive verwenden" | ||||
|   driveFileWarn: "Wähle eine Audiodatei aus dem Drive" | ||||
|   driveFileTypeWarn: "Diese Datei wird nicht unterstützt" | ||||
|   driveFileTypeWarnDescription: "Bitte wähle eine Audiodatei" | ||||
|   driveFileDurationWarn: "Audio zu lang." | ||||
| _ago: | ||||
|   future: "Zukunft" | ||||
|   justNow: "Gerade eben" | ||||
| @@ -1880,6 +2061,33 @@ _permissions: | ||||
|   "write:flash": "Deine Plays bearbeiten oder löschen" | ||||
|   "read:flash-likes": "Liste der Plays, die mir gefallen, lesen" | ||||
|   "write:flash-likes": "Liste der Plays, die mir gefallen, bearbeiten" | ||||
|   "write:admin:delete-account": "Benutzerkonto löschen" | ||||
|   "write:admin:delete-all-files-of-a-user": "Alle Dateien eines Benutzers löschen" | ||||
|   "read:admin:index-stats": "Statistiken zu Datenbankindizes einsehen" | ||||
|   "read:admin:table-stats": "Statistiken zu Datenbanktabellen einsehen" | ||||
|   "read:admin:user-ips": "IP-Adressen von Benutzern anzeigen" | ||||
|   "read:admin:meta": "Metadaten der Instanz einsehen" | ||||
|   "write:admin:reset-password": "Benutzerpasswort zurücksetzen" | ||||
|   "write:admin:send-email": "E-Mail versenden" | ||||
|   "read:admin:server-info": "Serverinformationen anzeigen" | ||||
|   "read:admin:show-moderation-log": "Moderationsprotokoll einsehen" | ||||
|   "read:admin:show-user": "Private Benutzerinformationen einsehen" | ||||
|   "write:admin:roles": "Rollen verwalten" | ||||
|   "read:admin:roles": "Rollen anzeigen" | ||||
|   "write:admin:relays": "Relays verwalten" | ||||
|   "read:admin:relays": "Relays anzeigen" | ||||
|   "write:admin:invite-codes": "Einladungscodes verwalten" | ||||
|   "read:admin:invite-codes": "Einladungscodes anzeigen" | ||||
|   "write:admin:announcements": "Ankündigungen verwalten" | ||||
|   "read:admin:announcements": "Ankündigungen einsehen" | ||||
|   "write:admin:avatar-decorations": "Kann Avatar-Dekorationen verwalten" | ||||
|   "read:admin:avatar-decorations": "Avatar-Dekorationen ansehen" | ||||
|   "write:admin:account": "Benutzerkonten verwalten" | ||||
|   "read:admin:account": "Benutzerkonten anzeigen" | ||||
|   "write:admin:emoji": "Emojis verwalten" | ||||
|   "read:admin:emoji": "Emojis anzeigen" | ||||
|   "write:admin:queue": "Job-Warteschlange verwalten" | ||||
|   "read:admin:queue": "Job-Warteschlange anzeigen" | ||||
| _auth: | ||||
|   shareAccessTitle: "Verteilung von App-Berechtigungen" | ||||
|   shareAccess: "Möchtest du „{name}“ authorisieren, auf dieses Benutzerkonto zugreifen zu können?" | ||||
| @@ -1997,6 +2205,8 @@ _profile: | ||||
|   changeAvatar: "Profilbild ändern" | ||||
|   changeBanner: "Banner ändern" | ||||
|   verifiedLinkDescription: "Gibst du hier eine URL ein, die einen Link zu deinem Profile enthält, wird neben diesem Feld ein Icon zur Besitzbestätigung angezeigt." | ||||
|   avatarDecorationMax: "Du kannst bis zu {max} Dekorationen hinzufügen." | ||||
|   followedMessageDescription: "Du kannst eine kurze Nachricht festlegen, die dem Empfänger angezeigt wird, wenn er dir folgt." | ||||
| _exportOrImport: | ||||
|   allNotes: "Alle Notizen" | ||||
|   favoritedNotes: "Als Favorit markierte Notizen" | ||||
| @@ -2119,6 +2329,7 @@ _notification: | ||||
|   pollEnded: "Umfrageergebnisse sind verfügbar" | ||||
|   newNote: "Neue Notiz" | ||||
|   unreadAntennaNote: "Antenne {name}" | ||||
|   roleAssigned: "Rolle zugewiesen" | ||||
|   emptyPushNotificationMessage: "Push-Benachrichtigungen wurden aktualisiert" | ||||
|   achievementEarned: "Errungenschaft freigeschaltet" | ||||
|   testNotification: "Testbenachrichtigung" | ||||
| @@ -2128,6 +2339,7 @@ _notification: | ||||
|   reactedBySomeUsers: "{n} Benutzer haben eine Reaktion geschickt" | ||||
|   renotedBySomeUsers: "Renote von {n} Benutzern" | ||||
|   followedBySomeUsers: "Von {n} Benutzern gefolgt" | ||||
|   login: "Neue Anmeldung erfolgt" | ||||
|   _types: | ||||
|     all: "Alle" | ||||
|     note: "Neue Notizen" | ||||
| @@ -2140,7 +2352,9 @@ _notification: | ||||
|     pollEnded: "Ende von Umfragen" | ||||
|     receiveFollowRequest: "Erhaltene Follow-Anfragen" | ||||
|     followRequestAccepted: "Akzeptierte Follow-Anfragen" | ||||
|     roleAssigned: "Rolle zugewiesen" | ||||
|     achievementEarned: "Errungenschaft freigeschaltet" | ||||
|     login: "Anmelden" | ||||
|     app: "Benachrichtigungen von Apps" | ||||
|   _actions: | ||||
|     followBack: "folgt dir nun auch" | ||||
| @@ -2190,6 +2404,7 @@ _webhookSettings: | ||||
|   createWebhook: "Webhook erstellen" | ||||
|   name: "Name" | ||||
|   secret: "Secret" | ||||
|   trigger: "Auslöser" | ||||
|   active: "Aktiviert" | ||||
|   _events: | ||||
|     follow: "Wenn du jemandem folgst" | ||||
| @@ -2201,8 +2416,10 @@ _webhookSettings: | ||||
|     mention: "Wenn du erwähnt wirst" | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     createRecipient: "Meldungsempfänger hinzufügen" | ||||
|     _recipientType: | ||||
|       mail: "Email" | ||||
|     keywords: "Schlüsselwort" | ||||
| _moderationLogTypes: | ||||
|   createRole: "Rolle erstellt" | ||||
|   deleteRole: "Rolle gelöscht" | ||||
| @@ -2237,6 +2454,13 @@ _moderationLogTypes: | ||||
|   createAvatarDecoration: "Profilbilddekoration erstellt" | ||||
|   updateAvatarDecoration: "Profilbilddekoration aktualisiert" | ||||
|   deleteAvatarDecoration: "Profilbilddekoration gelöscht" | ||||
|   unsetUserAvatar: "Profilbild zurückgesetzt" | ||||
|   unsetUserBanner: "Profilbanner zurückgesetzt" | ||||
|   createSystemWebhook: "System-Webhook erstellt" | ||||
|   updateSystemWebhook: "System-Webhook aktualisiert" | ||||
|   deleteSystemWebhook: "System-Webhook gelöscht" | ||||
|   deletePage: "Seite gelöscht" | ||||
|   deleteGalleryPost: "Galeriebeitrag gelöscht" | ||||
| _fileViewer: | ||||
|   title: "Dateiinformationen" | ||||
|   type: "Dateityp" | ||||
| @@ -2286,9 +2510,60 @@ _externalResourceInstaller: | ||||
|     _themeInstallFailed: | ||||
|       title: "Das Farbschema konnte nicht installiert werden" | ||||
|       description: "Während der Installation des Farbschemas ist ein Problem aufgetreten. Bitte versuche es erneut. Detaillierte Fehlerinformationen können über die Javascript-Konsole abgerufen werden." | ||||
| _hemisphere: | ||||
|   N: "Nördliche Erdhalbkugel" | ||||
|   S: "Südliche Erdhalbkugel" | ||||
|   caption: "Wird in einigen Client-Einstellungen zur Bestimmung der Jahreszeit verwendet." | ||||
| _reversi: | ||||
|   blackOrWhite: "Schwarz/Weiß" | ||||
|   rules: "Regeln" | ||||
|   black: "Schwarz" | ||||
|   white: "Weiß" | ||||
|   total: "Gesamt" | ||||
| _offlineScreen: | ||||
|   title: "Offline - keine Verbindung zum Server möglich" | ||||
|   header: "Verbindung zum Server nicht möglich" | ||||
| _urlPreviewSetting: | ||||
|   title: "Einstellungen der URL-Vorschau" | ||||
|   enable: "URL-Vorschau aktivieren" | ||||
|   timeout: "Zeitüberschreitung beim Abrufen der Vorschau (ms)" | ||||
|   timeoutDescription: "Übersteigt die für die Vorschau benötigte Zeit diesen Wert, wird keine Vorschau generiert." | ||||
|   maximumContentLength: "Maximale Content-Length (Bytes)" | ||||
|   maximumContentLengthDescription: "Wenn die Content-Length diesen Wert überschreitet, wird keine Vorschau erzeugt." | ||||
|   requireContentLength: "Vorschau nur generieren, wenn Content-Length verfügbar ist" | ||||
|   requireContentLengthDescription: "Wenn der Server keine Content-Length zurückgibt, wird keine Vorschau erzeugt." | ||||
|   userAgent: "User-Agent" | ||||
| _mediaControls: | ||||
|   playbackRate: "Wiedergabegeschwindigkeit" | ||||
| _contextMenu: | ||||
|   title: "Kontextmenü" | ||||
|   app: "Anwendung" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "Dieser Wert ist ein Pflichtfeld" | ||||
| _embedCodeGen: | ||||
|   title: "Einbettungscode anpassen" | ||||
|   header: "Kopfzeile anzeigen" | ||||
|   autoload: "Automatisch mehr laden (veraltet)" | ||||
|   maxHeight: "Maximale Höhe" | ||||
|   maxHeightDescription: "Der Wert 0 deaktiviert die Einstellung der maximalen Höhe. Gib einen Wert an, um zu verhindern, dass das Widget weiterhin vertikal vergrößert wird." | ||||
|   maxHeightWarn: "Die Begrenzung der maximalen Höhe ist deaktiviert (0). Wenn dies nicht beabsichtigt war, setze die maximale Höhe auf einen Wert fest." | ||||
|   applyToPreview: "Auf die Vorschau anwenden" | ||||
|   generateCode: "Einbettungscode generieren" | ||||
|   codeGenerated: "Der Code wurde generiert" | ||||
|   codeGeneratedDescription: "Füge den generierten Code in deine Website ein, um den Inhalt einzubetten." | ||||
| _selfXssPrevention: | ||||
|   warning: "WARNUNG" | ||||
|   title: "„Füge in diesen Bereich etwas ein“ ist eine Betrugsmasche." | ||||
|   description1: "Wenn du hier etwas einfügst, könnte ein böswilliger Benutzer dein Konto übernehmen oder deine persönlichen Daten stehlen." | ||||
|   description3: "Weitere Informationen findest du hier. {link}" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "Kommunikation mit diesem Server nicht möglich" | ||||
|     description: "Möglicherweise wurde die Kommunikation mit diesem Server deaktiviert oder dieser Server ist blockiert.\nWende dich bitte an den Serveradministrator." | ||||
|   _uriInvalid: | ||||
|     title: "URI ist fehlerhaft" | ||||
|     description: "Es gibt ein Problem mit der von dir eingegebenen URI. Bitte prüfe, ob du Zeichen eingegeben hast, die in der URI nicht verwendet werden können." | ||||
|   _noSuchObject: | ||||
|     title: "Nicht gefunden" | ||||
|     description: "Die angeforderte Ressource konnte nicht gefunden werden, bitte überprüfe die URI erneut." | ||||
|   | ||||
| @@ -378,6 +378,7 @@ _notification: | ||||
|     renote: "Κοινοποίηση σημειώματος" | ||||
|     quote: "Παράθεση" | ||||
|     reaction: "Αντιδράσεις" | ||||
|     login: "Σύνδεση" | ||||
|   _actions: | ||||
|     reply: "Απάντηση" | ||||
|     renote: "Κοινοποίηση σημειώματος" | ||||
|   | ||||
| @@ -5,9 +5,13 @@ introMisskey: "Welcome! Misskey is an open source, decentralized microblogging s | ||||
| poweredByMisskeyDescription: "{name} is one of the services powered by the open source platform <b>Misskey</b> (referred to as a \"Misskey instance\")." | ||||
| monthAndDay: "{month}/{day}" | ||||
| search: "Search" | ||||
| reset: "Reset" | ||||
| notifications: "Notifications" | ||||
| username: "Username" | ||||
| password: "Password" | ||||
| initialPasswordForSetup: "Initial password for setup" | ||||
| initialPasswordIsIncorrect: "Initial password for setup is incorrect" | ||||
| initialPasswordForSetupDescription: "Use the password you entered in the configuration file if you installed Misskey yourself.\n If you are using a Misskey hosting service, use the password provided.\n If you have not set a password, leave it blank to continue." | ||||
| forgotPassword: "Forgot password" | ||||
| fetchingAsApObject: "Fetching from the Fediverse..." | ||||
| ok: "OK" | ||||
| @@ -45,6 +49,7 @@ pin: "Pin to profile" | ||||
| unpin: "Unpin from profile" | ||||
| copyContent: "Copy contents" | ||||
| copyLink: "Copy link" | ||||
| copyRemoteLink: "Copy remote link" | ||||
| copyLinkRenote: "Copy renote link" | ||||
| delete: "Delete" | ||||
| deleteAndEdit: "Delete and edit" | ||||
| @@ -109,7 +114,7 @@ enterEmoji: "Enter an emoji" | ||||
| renote: "Renote" | ||||
| unrenote: "Remove renote" | ||||
| renoted: "Renoted." | ||||
| renotedToX: "Renote to {name}." | ||||
| renotedToX: "Renoted to {name}." | ||||
| cantRenote: "This post can't be renoted." | ||||
| cantReRenote: "A renote can't be renoted." | ||||
| quote: "Quote" | ||||
| @@ -236,6 +241,8 @@ silencedInstances: "Silenced instances" | ||||
| silencedInstancesDescription: "List the host names of the servers that you want to silence, separated by a new line. All accounts belonging to the listed servers will be treated as silenced, and can only make follow requests, and cannot mention local accounts if not followed. This will not affect the blocked servers." | ||||
| mediaSilencedInstances: "Media-silenced servers" | ||||
| mediaSilencedInstancesDescription: "List the host names of the servers that you want to media-silence, separated by a new line. All accounts belonging to the listed servers will be treated as sensitive, and can't use custom emojis. This will not affect the blocked servers." | ||||
| federationAllowedHosts: "Federation allowed servers" | ||||
| federationAllowedHostsDescription: "Specify the hostnames of the servers you want to allow federation separated by line breaks." | ||||
| muteAndBlock: "Mutes and Blocks" | ||||
| mutedUsers: "Muted users" | ||||
| blockedUsers: "Blocked users" | ||||
| @@ -326,7 +333,7 @@ selectFile: "Select a file" | ||||
| selectFiles: "Select files" | ||||
| selectFolder: "Select a folder" | ||||
| selectFolders: "Select folders" | ||||
| fileNotSelected: "" | ||||
| fileNotSelected: "No file selected" | ||||
| renameFile: "Rename file" | ||||
| folderName: "Folder name" | ||||
| createFolder: "Create a folder" | ||||
| @@ -334,6 +341,7 @@ renameFolder: "Rename this folder" | ||||
| deleteFolder: "Delete this folder" | ||||
| folder: "Folder" | ||||
| addFile: "Add a file" | ||||
| showFile: "Show files" | ||||
| emptyDrive: "Your Drive is empty" | ||||
| emptyFolder: "This folder is empty" | ||||
| unableToDelete: "Unable to delete" | ||||
| @@ -376,7 +384,6 @@ enableLocalTimeline: "Enable local timeline" | ||||
| enableGlobalTimeline: "Enable global timeline" | ||||
| disablingTimelinesInfo: "Adminstrators and Moderators will always have access to all timelines, even if they are not enabled." | ||||
| registration: "Register" | ||||
| enableRegistration: "Enable new user registration" | ||||
| invite: "Invite" | ||||
| driveCapacityPerLocalAccount: "Drive capacity per local user" | ||||
| driveCapacityPerRemoteAccount: "Drive capacity per remote user" | ||||
| @@ -448,6 +455,7 @@ totpDescription: "Use an authenticator app to enter one-time passwords" | ||||
| moderator: "Moderator" | ||||
| moderation: "Moderation" | ||||
| moderationNote: "Moderation note" | ||||
| moderationNoteDescription: "You can fill in notes that will be shared only among moderators." | ||||
| addModerationNote: "Add moderation note" | ||||
| moderationLogs: "Moderation logs" | ||||
| nUsersMentioned: "Mentioned by {n} users" | ||||
| @@ -509,6 +517,10 @@ uiLanguage: "User interface language" | ||||
| aboutX: "About {x}" | ||||
| emojiStyle: "Emoji style" | ||||
| native: "Native" | ||||
| menuStyle: "Menu style" | ||||
| style: "Style" | ||||
| drawer: "Drawer" | ||||
| popup: "Pop up" | ||||
| showNoteActionsOnlyHover: "Only show note actions on hover" | ||||
| showReactionsCount: "See the number of reactions in notes" | ||||
| noHistory: "No history available" | ||||
| @@ -576,6 +588,7 @@ masterVolume: "Master volume" | ||||
| notUseSound: "Disable sound" | ||||
| useSoundOnlyWhenActive: "Output sounds only if Misskey is active." | ||||
| details: "Details" | ||||
| renoteDetails: "Renote details" | ||||
| chooseEmoji: "Select an emoji" | ||||
| unableToProcess: "The operation could not be completed" | ||||
| recentUsed: "Recently used" | ||||
| @@ -591,6 +604,8 @@ ascendingOrder: "Ascending" | ||||
| descendingOrder: "Descending" | ||||
| scratchpad: "Scratchpad" | ||||
| scratchpadDescription: "The Scratchpad provides an environment for AiScript experiments. You can write, execute, and check the results of it interacting with Misskey in it." | ||||
| uiInspector: "UI inspector" | ||||
| uiInspectorDescription: "You can see the UI component server list on memory. UI component will be generated by Ui:C: function." | ||||
| output: "Output" | ||||
| script: "Script" | ||||
| disablePagesScript: "Disable AiScript on Pages" | ||||
| @@ -671,11 +686,15 @@ smtpSecure: "Use implicit SSL/TLS for SMTP connections" | ||||
| smtpSecureInfo: "Turn this off when using STARTTLS" | ||||
| testEmail: "Test email delivery" | ||||
| wordMute: "Word mute" | ||||
| wordMuteDescription: "Minimize notes that contain the specified word or phrase. Minimized notes can be displayed by clicking on them." | ||||
| hardWordMute: "Hard word mute" | ||||
| showMutedWord: "Show muted words" | ||||
| hardWordMuteDescription: "Hide notes that contain the specified word or phrase. Unlike word mute, the note will be completely hidden from view." | ||||
| regexpError: "Regular Expression error" | ||||
| regexpErrorDescription: "An error occurred in the regular expression on line {line} of your {tab} word mutes:" | ||||
| instanceMute: "Instance Mutes" | ||||
| userSaysSomething: "{name} said something" | ||||
| userSaysSomethingAbout: "{name} said something about \"{word}\"" | ||||
| makeActive: "Activate" | ||||
| display: "Display" | ||||
| copy: "Copy" | ||||
| @@ -707,10 +726,7 @@ abuseReported: "Your report has been sent. Thank you very much." | ||||
| reporter: "Reporter" | ||||
| reporteeOrigin: "Reportee Origin" | ||||
| reporterOrigin: "Reporter Origin" | ||||
| forwardReport: "Forward report to remote instance" | ||||
| forwardReportIsAnonymous: "Instead of your account, an anonymous system account will be displayed as reporter at the remote instance." | ||||
| send: "Send" | ||||
| abuseMarkAsResolved: "Mark report as resolved" | ||||
| openInNewTab: "Open in new tab" | ||||
| openInSideView: "Open in side view" | ||||
| defaultNavigationBehaviour: "Default navigation behavior" | ||||
| @@ -912,6 +928,7 @@ followersVisibility: "Visibility of followers" | ||||
| continueThread: "View thread continuation" | ||||
| deleteAccountConfirm: "This will irreversibly delete your account. Proceed?" | ||||
| incorrectPassword: "Incorrect password." | ||||
| incorrectTotp: "The one-time password is incorrect or has expired." | ||||
| voteConfirm: "Confirm your vote for \"{choice}\"?" | ||||
| hide: "Hide" | ||||
| useDrawerReactionPickerForMobile: "Display reaction picker as drawer on mobile" | ||||
| @@ -936,6 +953,9 @@ oneHour: "One hour" | ||||
| oneDay: "One day" | ||||
| oneWeek: "One week" | ||||
| oneMonth: "One month" | ||||
| threeMonths: "3 months" | ||||
| oneYear: "1 year" | ||||
| threeDays: "3 days" | ||||
| reflectMayTakeTime: "It may take some time for this to be reflected." | ||||
| failedToFetchAccountInformation: "Could not fetch account information" | ||||
| rateLimitExceeded: "Rate limit exceeded" | ||||
| @@ -1076,6 +1096,7 @@ retryAllQueuesConfirmTitle: "Really retry all?" | ||||
| retryAllQueuesConfirmText: "This will temporarily increase the server load." | ||||
| enableChartsForRemoteUser: "Generate remote user data charts" | ||||
| enableChartsForFederatedInstances: "Generate remote instance data charts" | ||||
| enableStatsForFederatedInstances: "Receive remote server stats" | ||||
| showClipButtonInNoteFooter: "Add \"Clip\" to note action menu" | ||||
| reactionsDisplaySize: "Reaction display size" | ||||
| limitWidthOfReaction: "Limit the maximum width of reactions and display them in reduced size." | ||||
| @@ -1125,7 +1146,7 @@ options: "Options" | ||||
| specifyUser: "Specific user" | ||||
| lookupConfirm: "Do you want to look up?" | ||||
| openTagPageConfirm: "Do you want to open a hashtag page?" | ||||
| specifyHost: "Specify a host" | ||||
| specifyHost: "Specific host" | ||||
| failedToPreviewUrl: "Could not preview" | ||||
| update: "Update" | ||||
| rolesThatCanBeUsedThisEmojiAsReaction: "Roles that can use this emoji as reaction" | ||||
| @@ -1266,6 +1287,47 @@ fromX: "From {x}" | ||||
| genEmbedCode: "Generate embed code" | ||||
| noteOfThisUser: "Notes by this user" | ||||
| clipNoteLimitExceeded: "No more notes can be added to this clip." | ||||
| performance: "Performance" | ||||
| modified: "Modified" | ||||
| discard: "Discard" | ||||
| thereAreNChanges: "There are {n} change(s)" | ||||
| signinWithPasskey: "Sign in with Passkey" | ||||
| unknownWebAuthnKey: "Unknown Passkey" | ||||
| passkeyVerificationFailed: "Passkey verification has failed." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "Passkey verification has succeeded but password-less login is disabled." | ||||
| messageToFollower: "Message to followers" | ||||
| target: "Target" | ||||
| testCaptchaWarning: "This function is intended for CAPTCHA testing purposes.\n<strong>Do not use in a production environment.</strong>" | ||||
| prohibitedWordsForNameOfUser: "Prohibited words for user names" | ||||
| prohibitedWordsForNameOfUserDescription: "If any of the strings in this list are included in the user's name, the name will be denied. Users with moderator privileges are not affected by this restriction." | ||||
| yourNameContainsProhibitedWords: "Your name contains prohibited words" | ||||
| yourNameContainsProhibitedWordsDescription: "If you wish to use this name, please contact your server administrator." | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "Set by the author to require login to view" | ||||
| lockdown: "Lockdown" | ||||
| pleaseSelectAccount: "Select an account" | ||||
| availableRoles: "Available roles" | ||||
| acknowledgeNotesAndEnable: "Turn on after understanding the precautions." | ||||
| federationSpecified: "This server is operated in a whitelist federation. Interacting with servers other than those designated by the administrator is not allowed." | ||||
| federationDisabled: "Federation is disabled on this server. You cannot interact with users on other servers." | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "Require sign-in to view contents" | ||||
|   requireSigninToViewContentsDescription1: "Require login to view all notes and other content you have created. This will have the effect of preventing crawlers from collecting your information." | ||||
|   requireSigninToViewContentsDescription2: "Content will not be displayed in URL previews (OGP), embedded in web pages, or on servers that don't support note quotes." | ||||
|   requireSigninToViewContentsDescription3: "These restrictions may not apply to federated content from other remote servers." | ||||
|   makeNotesFollowersOnlyBefore: "Make past notes to be displayed only to followers" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "While this feature is enabled, only followers can see notes past the set date and time or have been visible for a set time. When it is deactivated, the note publication status will also be restored." | ||||
|   makeNotesHiddenBefore: "Make past notes private" | ||||
|   makeNotesHiddenBeforeDescription: "While this feature is enabled, notes that are past the set date and time or have been visible only to you. When it is deactivated, the note publication status will also be restored." | ||||
|   mayNotEffectForFederatedNotes: "Notes federated to a remote server may not be affected." | ||||
|   notesHavePassedSpecifiedPeriod: "Note that the specified time has passed" | ||||
|   notesOlderThanSpecifiedDateAndTime: "Notes before the specified date and time" | ||||
| _abuseUserReport: | ||||
|   forward: "Forward" | ||||
|   forwardDescription: "Forward the report to a remote server as an anonymous system account." | ||||
|   resolve: "Resolve" | ||||
|   accept: "Accept" | ||||
|   reject: "Reject" | ||||
|   resolveTutorial: "If the report is legitimate in content, select \"Accept\" to mark the case as resolved in the affirmative.\nIf the content of the report is not legitimate, select \"Reject\" to mark the case as resolved in the negative." | ||||
| _delivery: | ||||
|   status: "Delivery status" | ||||
|   stop: "Suspended" | ||||
| @@ -1400,8 +1462,12 @@ _serverSettings: | ||||
|   fanoutTimelineDescription: "Greatly increases performance of timeline retrieval and reduces load on the database when enabled. In exchange, memory usage of Redis will increase. Consider disabling this in case of low server memory or server instability." | ||||
|   fanoutTimelineDbFallback: "Fallback to database" | ||||
|   fanoutTimelineDbFallbackDescription: "When enabled, the timeline will fall back to the database for additional queries if the timeline is not cached. Disabling it further reduces the server load by eliminating the fallback process, but limits the range of timelines that can be retrieved." | ||||
|   reactionsBufferingDescription: "When enabled, performance during reaction creation will be greatly improved, reducing the load on the database. However, Redis memory usage will increase." | ||||
|   inquiryUrl: "Inquiry URL" | ||||
|   inquiryUrlDescription: "Specify a URL for the inquiry form to the server maintainer or a web page for the contact information." | ||||
|   openRegistration: "Make the account creation open" | ||||
|   openRegistrationWarning: "Opening registration carries risks. It is recommended to only enable it if you have a system in place to continuously monitor the server and respond immediately in case of any issues." | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "If no moderator activity is detected for a while, this setting will be automatically turned off to prevent spam." | ||||
| _accountMigration: | ||||
|   moveFrom: "Migrate another account to this one" | ||||
|   moveFromSub: "Create alias to another account" | ||||
| @@ -1718,7 +1784,7 @@ _role: | ||||
|     canManageAvatarDecorations: "Manage avatar decorations" | ||||
|     driveCapacity: "Drive capacity" | ||||
|     alwaysMarkNsfw: "Always mark files as NSFW" | ||||
|     canUpdateBioMedia: "Allow to edit an icon or a banner image" | ||||
|     canUpdateBioMedia: "Can edit an icon or a banner image" | ||||
|     pinMax: "Maximum number of pinned notes" | ||||
|     antennaMax: "Maximum number of antennas" | ||||
|     wordMuteMax: "Maximum number of characters allowed in word mutes" | ||||
| @@ -1733,6 +1799,11 @@ _role: | ||||
|     canSearchNotes: "Usage of note search" | ||||
|     canUseTranslator: "Translator usage" | ||||
|     avatarDecorationLimit: "Maximum number of avatar decorations that can be applied" | ||||
|     canImportAntennas: "Allow importing antennas" | ||||
|     canImportBlocking: "Allow importing blocking" | ||||
|     canImportFollowing: "Allow importing following" | ||||
|     canImportMuting: "Allow importing muting" | ||||
|     canImportUserLists: "Allow importing lists" | ||||
|   _condition: | ||||
|     roleAssignedTo: "Assigned to manual roles" | ||||
|     isLocal: "Local user" | ||||
| @@ -1950,7 +2021,6 @@ _theme: | ||||
|     buttonBg: "Button background" | ||||
|     buttonHoverBg: "Button background (Hover)" | ||||
|     inputBorder: "Input field border" | ||||
|     listItemHoverBg: "List item background (Hover)" | ||||
|     driveFolderBg: "Drive folder background" | ||||
|     wallpaperOverlay: "Wallpaper overlay" | ||||
|     badge: "Badge" | ||||
| @@ -2117,8 +2187,11 @@ _auth: | ||||
|   permissionAsk: "This application requests the following permissions" | ||||
|   pleaseGoBack: "Please go back to the application" | ||||
|   callback: "Returning to the application" | ||||
|   accepted: "Access granted" | ||||
|   denied: "Access denied" | ||||
|   scopeUser: "Operate as the following user" | ||||
|   pleaseLogin: "Please log in to authorize applications." | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "When access is granted, you will automatically be redirected to the following URL" | ||||
| _antennaSources: | ||||
|   all: "All notes" | ||||
|   homeTimeline: "Notes from followed users" | ||||
| @@ -2163,7 +2236,7 @@ _widgets: | ||||
|   _userList: | ||||
|     chooseList: "Select a list" | ||||
|   clicker: "Clicker" | ||||
|   birthdayFollowings: "Users who celebrate their birthday today" | ||||
|   birthdayFollowings: "Today's Birthdays" | ||||
| _cw: | ||||
|   hide: "Hide" | ||||
|   show: "Show content" | ||||
| @@ -2227,6 +2300,9 @@ _profile: | ||||
|   changeBanner: "Change banner" | ||||
|   verifiedLinkDescription: "By entering an URL that contains a link to your profile here, an ownership verification icon can be displayed next to the field." | ||||
|   avatarDecorationMax: "You can add up to {max} decorations." | ||||
|   followedMessage: "Message when you are followed" | ||||
|   followedMessageDescription: "You can set a short message to be displayed to the recipient when they follow you." | ||||
|   followedMessageDescriptionForLockedAccount: "If you have set up that follow requests require approval, this will be displayed when you grant a follow request." | ||||
| _exportOrImport: | ||||
|   allNotes: "All notes" | ||||
|   favoritedNotes: "Favorite notes" | ||||
| @@ -2365,6 +2441,8 @@ _notification: | ||||
|   renotedBySomeUsers: "Renote from {n} users" | ||||
|   followedBySomeUsers: "Followed by {n} users" | ||||
|   flushNotification: "Clear notifications" | ||||
|   exportOfXCompleted: "Export of {x} has been completed" | ||||
|   login: "Someone logged in" | ||||
|   _types: | ||||
|     all: "All" | ||||
|     note: "New notes" | ||||
| @@ -2379,6 +2457,9 @@ _notification: | ||||
|     followRequestAccepted: "Accepted follow requests" | ||||
|     roleAssigned: "Role given" | ||||
|     achievementEarned: "Achievement unlocked" | ||||
|     exportCompleted: "The export has been completed" | ||||
|     login: "Sign In" | ||||
|     test: "Notification test" | ||||
|     app: "Notifications from linked apps" | ||||
|   _actions: | ||||
|     followBack: "followed you back" | ||||
| @@ -2441,21 +2522,24 @@ _webhookSettings: | ||||
|     reaction: "When receiving a reaction" | ||||
|     mention: "When being mentioned" | ||||
|   _systemEvents: | ||||
|     abuseReport: "When received a new abuse report" | ||||
|     abuseReportResolved: "When resolved abuse report" | ||||
|     abuseReport: "When received a new report" | ||||
|     abuseReportResolved: "When resolved report" | ||||
|     userCreated: "When user is created" | ||||
|     inactiveModeratorsWarning: "When moderators have been inactive for a while" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "When a moderator has been inactive for a while, and the server is changed to invitation-only" | ||||
|   deleteConfirm: "Are you sure you want to delete the Webhook?" | ||||
|   testRemarks: "Click the button to the right of the switch to send a test Webhook with dummy data." | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     createRecipient: "Add a recipient for abuse reports" | ||||
|     modifyRecipient: "Edit a recipient for abuse reports" | ||||
|     createRecipient: "Add a recipient for reports" | ||||
|     modifyRecipient: "Edit a recipient for reports" | ||||
|     recipientType: "Notification type" | ||||
|     _recipientType: | ||||
|       mail: "Email" | ||||
|       webhook: "Webhook" | ||||
|       _captions: | ||||
|         mail: "Send the email to moderators' email addresses when you receive abuse." | ||||
|         webhook: "Send a notification to SystemWebhook when you receive or resolve abuse." | ||||
|         mail: "Send the email to moderators' email addresses when you receive reports." | ||||
|         webhook: "Send a notification to System Webhook when you receive or resolve reports." | ||||
|     keywords: "Keywords" | ||||
|     notifiedUser: "Users to notify" | ||||
|     notifiedWebhook: "Webhook to use" | ||||
| @@ -2488,6 +2572,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "File marked as sensitive" | ||||
|   unmarkSensitiveDriveFile: "File unmarked as sensitive" | ||||
|   resolveAbuseReport: "Report resolved" | ||||
|   forwardAbuseReport: "Report forwarded" | ||||
|   updateAbuseReportNote: "Moderation note of a report updated" | ||||
|   createInvitation: "Invite generated" | ||||
|   createAd: "Ad created" | ||||
|   deleteAd: "Ad deleted" | ||||
| @@ -2495,18 +2581,18 @@ _moderationLogTypes: | ||||
|   createAvatarDecoration: "Avatar decoration created" | ||||
|   updateAvatarDecoration: "Avatar decoration updated" | ||||
|   deleteAvatarDecoration: "Avatar decoration deleted" | ||||
|   unsetUserAvatar: "Unset this user's avatar" | ||||
|   unsetUserBanner: "Unset this user's banner" | ||||
|   createSystemWebhook: "Create SystemWebhook" | ||||
|   updateSystemWebhook: "Update SystemWebhook" | ||||
|   deleteSystemWebhook: "Delete SystemWebhook" | ||||
|   createAbuseReportNotificationRecipient: "Create a recipient for abuse reports" | ||||
|   updateAbuseReportNotificationRecipient: "Update recipients for abuse reports" | ||||
|   deleteAbuseReportNotificationRecipient: "Delete a recipient for abuse reports" | ||||
|   deleteAccount: "Delete the account" | ||||
|   deletePage: "Delete the page" | ||||
|   deleteFlash: "Delete Play" | ||||
|   deleteGalleryPost: "Delete the gallery post" | ||||
|   unsetUserAvatar: "User avatar unset" | ||||
|   unsetUserBanner: "User banner unset" | ||||
|   createSystemWebhook: "System Webhook created" | ||||
|   updateSystemWebhook: "System Webhook updated" | ||||
|   deleteSystemWebhook: "System Webhook deleted" | ||||
|   createAbuseReportNotificationRecipient: "Recipient for reports created" | ||||
|   updateAbuseReportNotificationRecipient: "Recipient for reports updated" | ||||
|   deleteAbuseReportNotificationRecipient: "Recipient for reports deleted" | ||||
|   deleteAccount: "Account deleted" | ||||
|   deletePage: "Page deleted" | ||||
|   deleteFlash: "Play deleted" | ||||
|   deleteGalleryPost: "Gallery post deleted" | ||||
| _fileViewer: | ||||
|   title: "File details" | ||||
|   type: "File type" | ||||
| @@ -2643,6 +2729,61 @@ _contextMenu: | ||||
|   app: "Application" | ||||
|   appWithShift: "Application with shift key" | ||||
|   native: "Native" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "This value is required" | ||||
|     columnTypeNotSupport: "Validation with regular expression is supported only for type:text columns." | ||||
|     patternNotMatch: "This value doesn't match the pattern in {pattern}" | ||||
|     notUnique: "This value must be unique" | ||||
| _roleSelectDialog: | ||||
|   notSelected: "Not selected" | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "Copy selected rows" | ||||
|     copySelectionRanges: "Copy selected ranges" | ||||
|     deleteSelectionRows: "Delete selected rows" | ||||
|     deleteSelectionRanges: "Delete rows in the selection" | ||||
|     searchSettings: "Search settings" | ||||
|     searchSettingCaption: "Set detailed search criteria." | ||||
|     sortOrder: "Sort order" | ||||
|     registrationLogs: "Registration log" | ||||
|     registrationLogsCaption: "Logs will be displayed when updating or deleting Emojis. They will disappear after updating or deleting them, moving to a new page, or reloading." | ||||
|     alertEmojisRegisterFailedDescription: "Failed to update or delete Emojis. Please check the registration log for details." | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "Show success log" | ||||
|     failureLogNothing: "There is no failure log." | ||||
|     logNothing: "There is no log." | ||||
|   _remote: | ||||
|     selectionRowDetail: "Selected row's detail" | ||||
|     importSelectionRows: "Import selected rows" | ||||
|     importSelectionRangesRows: "Import rows in the selection" | ||||
|     importEmojisButton: "Import checked Emojis" | ||||
|     confirmImportEmojisTitle: "Import Emojis" | ||||
|     confirmImportEmojisDescription: "Import {count} Emoji(s) received from the remote server. Please pay close attention to the license of the Emoji. Are you sure to continue?" | ||||
|   _local: | ||||
|     tabTitleList: "List of registered Emojis" | ||||
|     tabTitleRegister: "Emoji registration" | ||||
|     _list: | ||||
|       emojisNothing: "There are no registered Emojis." | ||||
|       markAsDeleteTargetRows: "Mark selected rows as a target to delete" | ||||
|       markAsDeleteTargetRanges: "Mark rows in the selection as a target to delete" | ||||
|       alertUpdateEmojisNothingDescription: "There are no updated Emojis." | ||||
|       alertDeleteEmojisNothingDescription: "There are no Emojis to be deleted." | ||||
|       confirmUpdateEmojisDescription: "Update {count} Emoji(s). Are you sure to continue?" | ||||
|       confirmDeleteEmojisDescription: "Delete checked {count} Emoji(s). Are you sure to continue?" | ||||
|       dialogSelectRoleTitle: "Search by roll set in Emojis" | ||||
|     _register: | ||||
|       uploadSettingTitle: "Upload settings" | ||||
|       uploadSettingDescription: "On this screen, you can configure the behavior when uploading Emojis." | ||||
|       directoryToCategoryLabel: "Enter the directory name in the \"category\" field" | ||||
|       directoryToCategoryCaption: "When you drag and drop a directory, enter the directory name in the \"category\" field." | ||||
|       emojiInputAreaCaption: "Select the Emojis you wish to register using one of the methods." | ||||
|       emojiInputAreaList1: "Drag and drop image files or a directory into this frame" | ||||
|       emojiInputAreaList2: "Click this link to select from your computer" | ||||
|       emojiInputAreaList3: "Click this link to select from the drive" | ||||
|       confirmRegisterEmojisDescription: "Register the Emojis from the list as new custom Emojis. Are you sure to continue? (To avoid overload, only {count} Emoji(s) can be registered in a single operation)" | ||||
|       confirmClearEmojisDescription: "Discard the edits and clear the Emojis from the list. Are you sure to continue?" | ||||
|       confirmUploadEmojisDescription: "Upload the dragged and dropped {count} file(s) to the drive. Are you sure to continue?" | ||||
| _embedCodeGen: | ||||
|   title: "Customize embed code" | ||||
|   header: "Show header" | ||||
| @@ -2657,3 +2798,43 @@ _embedCodeGen: | ||||
|   generateCode: "Generate embed code" | ||||
|   codeGenerated: "The code has been generated" | ||||
|   codeGeneratedDescription: "Paste the generated code into your website to embed the content." | ||||
| _selfXssPrevention: | ||||
|   warning: "WARNING" | ||||
|   title: "\"Paste something on this screen\" is all a scam." | ||||
|   description1: "If you paste something here, a malicious user could hijack your account or steal your personal information." | ||||
|   description2: "If you do not understand exactly what you are trying to paste, %cstop working right now and close this window." | ||||
|   description3: "For more information, please refer to this. {link}" | ||||
| _followRequest: | ||||
|   recieved: "Received application" | ||||
|   sent: "Sent application" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "Unable to communicate with this server" | ||||
|     description: "Communication with this server may have been disabled or this server may be blocked.\nPlease contact the server administrator." | ||||
|   _uriInvalid: | ||||
|     title: "URI is invalid" | ||||
|     description: "There is a problem with the URI you entered. Please check if you entered characters that cannot be used in the URI." | ||||
|   _requestFailed: | ||||
|     title: "Request failed" | ||||
|     description: "Communication with this server failed. The server may be down. Also, please make sure that you have not entered an invalid or nonexistent URI." | ||||
|   _responseInvalid: | ||||
|     title: "Response is invalid" | ||||
|     description: "It could communicate with this server, but the data obtained was incorrect." | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "The domain of the entered URI differs from the domain of the final obtained URI. If you are looking up remote content through a third-party server, please look up again using a URI that can be obtained from the origin server." | ||||
|   _noSuchObject: | ||||
|     title: "Not found" | ||||
|     description: "The requested resource was not found, please recheck the URI." | ||||
| _captcha: | ||||
|   verify: "Please verify the CAPTCHA" | ||||
|   testSiteKeyMessage: "You can check the preview by entering the test values for the site and secret keys.\nPlease see the following page for details." | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "Failed to request CAPTCHA" | ||||
|       text: "Please run it after a while or check the settings again." | ||||
|     _verificationFailed: | ||||
|       title: "Failed to validate CAPTCHA" | ||||
|       text: "Please check again if the settings are correct." | ||||
|     _unknown: | ||||
|       title: "CAPTCHA error" | ||||
|       text: "An unexpected error occurred." | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "Buscar" | ||||
| notifications: "Notificaciones" | ||||
| username: "Nombre de usuario" | ||||
| password: "Contraseña" | ||||
| initialPasswordForSetup: "Contraseña para iniciar la inicialización" | ||||
| initialPasswordIsIncorrect: "La contraseña para iniciar la configuración inicial es incorrecta." | ||||
| initialPasswordForSetupDescription: "Si ha instalado Misskey usted mismo, utilice la contraseña introducida en el archivo de configuración.\nSi utiliza un servicio de alojamiento de Misskey o similar, utilice la contraseña proporcionada.\nSi no ha establecido una contraseña, déjela en blanco para continuar." | ||||
| forgotPassword: "Olvidé mi contraseña" | ||||
| fetchingAsApObject: "Buscando en el fediverso" | ||||
| ok: "OK" | ||||
| @@ -45,6 +48,7 @@ pin: "Fijar al perfil" | ||||
| unpin: "Desfijar" | ||||
| copyContent: "Copiar contenido" | ||||
| copyLink: "Copiar enlace" | ||||
| copyRemoteLink: "Copiar enlace remoto" | ||||
| copyLinkRenote: "Copiar enlace de renota" | ||||
| delete: "Borrar" | ||||
| deleteAndEdit: "Borrar y editar" | ||||
| @@ -196,6 +200,7 @@ followConfirm: "¿Desea seguir a {name}?" | ||||
| proxyAccount: "Cuenta proxy" | ||||
| proxyAccountDescription: "Una cuenta proxy es una cuenta que actúa como un seguidor remoto de un usuario bajo ciertas condiciones. Por ejemplo, cuando un usuario añade un usuario remoto a una lista, si ningún usuario local sigue al usuario agregado a la lista, la instancia no puede obtener su actividad. Así que la cuenta proxy sigue al usuario añadido a la lista" | ||||
| host: "Host" | ||||
| selectSelf: "Elígete a ti mismo" | ||||
| selectUser: "Elegir usuario" | ||||
| recipient: "Recipiente" | ||||
| annotation: "Anotación" | ||||
| @@ -211,6 +216,7 @@ perDay: "por día" | ||||
| stopActivityDelivery: "Dejar de enviar actividades" | ||||
| blockThisInstance: "Bloquear instancia" | ||||
| silenceThisInstance: "Silenciar esta instancia" | ||||
| mediaSilenceThisInstance: "Silencia la Multimedia(Imágenes,videos...) para este servidor" | ||||
| operations: "Operaciones" | ||||
| software: "Software" | ||||
| version: "Versión" | ||||
| @@ -232,6 +238,10 @@ blockedInstances: "Instancias bloqueadas" | ||||
| blockedInstancesDescription: "Seleccione los hosts de las instancias que desea bloquear, separadas por una linea nueva. Las instancias bloqueadas no podrán comunicarse con esta instancia." | ||||
| silencedInstances: "Instancias silenciadas" | ||||
| silencedInstancesDescription: "Listar los hostname de las instancias que quieres silenciar. Todas las cuentas de las instancias listadas serán tratadas como silenciadas, solo podrán hacer peticiones de seguimiento, y no podrán mencionar cuentas locales si no las siguen. Esto no afecta a las instancias bloqueadas." | ||||
| mediaSilencedInstances: "Servidores silenciados (Multimedia)" | ||||
| mediaSilencedInstancesDescription: "Listar las instancias que quieres silenciar. Todas las cuentas de las instancias listadas serán tratadas como silenciadas, solo podrán hacer peticiones de seguimiento, y no podrán mencionar cuentas locales si no las siguen. Esto no afecta a las instancias bloqueadas." | ||||
| federationAllowedHosts: "Servidores federados" | ||||
| federationAllowedHostsDescription: "Establezca los nombres  de los servidores que pueden federarse, separados por una nueva línea." | ||||
| muteAndBlock: "Silenciar y bloquear" | ||||
| mutedUsers: "Usuarios silenciados" | ||||
| blockedUsers: "Usuarios bloqueados" | ||||
| @@ -322,6 +332,7 @@ selectFile: "Elegir archivo" | ||||
| selectFiles: "Elegir archivos" | ||||
| selectFolder: "Seleccione una carpeta" | ||||
| selectFolders: "Seleccione carpetas" | ||||
| fileNotSelected: "Archivo no seleccionado." | ||||
| renameFile: "Renombrar archivo" | ||||
| folderName: "Nombre de la carpeta" | ||||
| createFolder: "Crear carpeta" | ||||
| @@ -329,6 +340,7 @@ renameFolder: "Renombrar carpeta" | ||||
| deleteFolder: "Borrar carpeta" | ||||
| folder: "Carpeta" | ||||
| addFile: "Agregar archivo" | ||||
| showFile: "Examinar archivos" | ||||
| emptyDrive: "El drive está vacío" | ||||
| emptyFolder: "La carpeta está vacía" | ||||
| unableToDelete: "No se puede borrar" | ||||
| @@ -371,7 +383,6 @@ enableLocalTimeline: "Habilitar linea de tiempo local" | ||||
| enableGlobalTimeline: "Habilitar linea de tiempo global" | ||||
| disablingTimelinesInfo: "Aunque se desactiven estas lineas de tiempo, por conveniencia el administrador y los moderadores pueden seguir usándolos" | ||||
| registration: "Registro" | ||||
| enableRegistration: "Permitir nuevos registros" | ||||
| invite: "Invitar" | ||||
| driveCapacityPerLocalAccount: "Capacidad del drive por usuario local" | ||||
| driveCapacityPerRemoteAccount: "Capacidad del drive por usuario remoto" | ||||
| @@ -443,6 +454,7 @@ totpDescription: "Ingresa una contaseña de un sólo uso usando la aplicación a | ||||
| moderator: "Moderador" | ||||
| moderation: "Moderación" | ||||
| moderationNote: "Nota de moderación" | ||||
| moderationNoteDescription: "Puedes rellenar notas que solo se comparten entre moderadores." | ||||
| addModerationNote: "Añadir nota de moderación" | ||||
| moderationLogs: "Log de moderación" | ||||
| nUsersMentioned: "{n} usuarios mencionados" | ||||
| @@ -477,10 +489,12 @@ retype: "Ingrese de nuevo" | ||||
| noteOf: "Notas de {user}" | ||||
| quoteAttached: "Cita añadida" | ||||
| quoteQuestion: "¿Quiere añadir una cita?" | ||||
| attachAsFileQuestion: "El texto del portapapeles es demasiado grande ¿Desea adjuntarlo como archivo de texto?" | ||||
| noMessagesYet: "Aún no hay chat" | ||||
| newMessageExists: "Tienes un mensaje nuevo" | ||||
| onlyOneFileCanBeAttached: "Solo se puede añadir un archivo al mensaje" | ||||
| signinRequired: "Iniciar sesión" | ||||
| signinOrContinueOnRemote: "Para continuar, tendrá que ir a su servidor o registrarse e iniciar sesión en este servidor" | ||||
| invitations: "Invitar" | ||||
| invitationCode: "Código de invitación" | ||||
| checking: "Comprobando" | ||||
| @@ -502,6 +516,9 @@ uiLanguage: "Idioma de visualización de la interfaz" | ||||
| aboutX: "Acerca de {x}" | ||||
| emojiStyle: "Estilo de emoji" | ||||
| native: "Nativo" | ||||
| menuStyle: "Diseño del menú" | ||||
| style: "Diseño" | ||||
| popup: "Ventana emergente" | ||||
| showNoteActionsOnlyHover: "Mostrar acciones de la nota sólo al pasar el cursor" | ||||
| showReactionsCount: "Mostrar el número de reacciones en las notas" | ||||
| noHistory: "No hay datos en el historial" | ||||
| @@ -569,6 +586,7 @@ masterVolume: "Volumen principal" | ||||
| notUseSound: "Sin sonido" | ||||
| useSoundOnlyWhenActive: "Sonar solo cuando Misskey esté activo" | ||||
| details: "Detalles" | ||||
| renoteDetails: "Detalles(Renota)" | ||||
| chooseEmoji: "Elije un emoji" | ||||
| unableToProcess: "La operación no se puede llevar a cabo" | ||||
| recentUsed: "Usado recientemente" | ||||
| @@ -584,6 +602,7 @@ ascendingOrder: "Ascendente" | ||||
| descendingOrder: "Descendente" | ||||
| scratchpad: "Scratch pad" | ||||
| scratchpadDescription: "Scratchpad proporciona un entorno experimental para AiScript. Puede escribir, ejecutar y verificar los resultados que interactúan con Misskey." | ||||
| uiInspector: "Inspector de UI" | ||||
| output: "Salida" | ||||
| script: "Script" | ||||
| disablePagesScript: "Deshabilitar AiScript en Páginas" | ||||
| @@ -700,10 +719,7 @@ abuseReported: "Se ha enviado el reporte. Muchas gracias." | ||||
| reporter: "Reportador" | ||||
| reporteeOrigin: "Reportar a" | ||||
| reporterOrigin: "Origen del reporte" | ||||
| forwardReport: "Transferir un informe a una instancia remota" | ||||
| forwardReportIsAnonymous: "No puede ver su información de la instancia remota y aparecerá como una cuenta anónima del sistema" | ||||
| send: "Enviar" | ||||
| abuseMarkAsResolved: "Marcar reporte como resuelto" | ||||
| openInNewTab: "Abrir en una Nueva Pestaña" | ||||
| openInSideView: "Abrir en una vista al costado" | ||||
| defaultNavigationBehaviour: "Navegación por defecto" | ||||
| @@ -928,6 +944,9 @@ oneHour: "1 hora" | ||||
| oneDay: "1 día" | ||||
| oneWeek: "1 semana" | ||||
| oneMonth: "1 mes" | ||||
| threeMonths: "Tres meses" | ||||
| oneYear: "Un año" | ||||
| threeDays: "Tres días" | ||||
| reflectMayTakeTime: "Puede pasar un tiempo hasta que se reflejen los cambios" | ||||
| failedToFetchAccountInformation: "No se pudo obtener información de la cuenta" | ||||
| rateLimitExceeded: "Se excedió el límite de peticiones" | ||||
| @@ -1114,6 +1133,7 @@ preventAiLearning: "Rechazar el uso en el Aprendizaje de Máquinas. (IA Generati | ||||
| preventAiLearningDescription: "Pedirle a las arañas (crawlers) no usar los textos publicados o imágenes en el aprendizaje automático (IA Predictiva / Generativa). Ésto se logra añadiendo una marca respuesta HTML con la cadena \"noai\" al cantenido. Una prevención total no podría lograrse sólo usando ésta marca, ya que puede ser simplemente ignorada." | ||||
| options: "Opción" | ||||
| specifyUser: "Especificar usuario" | ||||
| lookupConfirm: "¿Quiere informarse?" | ||||
| failedToPreviewUrl: "No se pudo generar la vista previa" | ||||
| update: "Actualizar" | ||||
| rolesThatCanBeUsedThisEmojiAsReaction: "Roles que pueden usar este emoji como reacción" | ||||
| @@ -1243,6 +1263,19 @@ useNativeUIForVideoAudioPlayer: "Usar la interfaz del navegador cuando se reprod | ||||
| keepOriginalFilename: "Mantener el nombre original del archivo" | ||||
| noDescription: "No hay descripción" | ||||
| alwaysConfirmFollow: "Confirmar siempre cuando se sigue a alguien" | ||||
| inquiry: "Contacto" | ||||
| tryAgain: "Por favor , inténtalo de nuevo" | ||||
| performance: "Rendimiento" | ||||
| unknownWebAuthnKey: "Esto no se ha registrado llave maestra." | ||||
| messageToFollower: "Mensaje a seguidores" | ||||
| federationSpecified: "Este servidor opera en una federación de listas blancas. No puede interactuar con otros servidores que no sean los especificados por el administrador." | ||||
| federationDisabled: "La federación está desactivada en este servidor. No puede interactuar con usuarios de otros servidores" | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "Se requiere iniciar sesión para ver el contenido" | ||||
|   requireSigninToViewContentsDescription1: "Requiere iniciar sesión para ver todas las notas y otros contenidos que hayas creado. Se espera que esto evite que los rastreadores recopilen información." | ||||
| _abuseUserReport: | ||||
|   accept: "Acepte" | ||||
|   reject: "repudio" | ||||
| _delivery: | ||||
|   stop: "Suspendido" | ||||
|   _type: | ||||
| @@ -1918,7 +1951,6 @@ _theme: | ||||
|     buttonBg: "Fondo de botón" | ||||
|     buttonHoverBg: "Fondo de botón (hover)" | ||||
|     inputBorder: "Borde de los campos de entrada" | ||||
|     listItemHoverBg: "Fondo de elemento de listas (hover)" | ||||
|     driveFolderBg: "Fondo de capeta del drive" | ||||
|     wallpaperOverlay: "Transparencia del fondo de pantalla" | ||||
|     badge: "Medalla" | ||||
| @@ -2343,6 +2375,8 @@ _notification: | ||||
|     followRequestAccepted: "El seguimiento fue aceptado" | ||||
|     roleAssigned: "Rol asignado" | ||||
|     achievementEarned: "Logro desbloqueado" | ||||
|     login: "Iniciar sesión" | ||||
|     test: "Pruebas de nofiticaciones" | ||||
|     app: "Notificaciones desde aplicaciones" | ||||
|   _actions: | ||||
|     followBack: "Te sigue de vuelta" | ||||
| @@ -2401,6 +2435,8 @@ _webhookSettings: | ||||
|     renote: "Cuando reciba un \"re-note\"" | ||||
|     reaction: "Cuando se recibe una reacción" | ||||
|     mention: "Cuando hay una mención" | ||||
|   _systemEvents: | ||||
|     userCreated: "Cuando se crea el usuario." | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     _recipientType: | ||||
| @@ -2521,3 +2557,6 @@ _mediaControls: | ||||
|   pip: "Picture in Picture" | ||||
|   playbackRate: "Velocidad de reproducción" | ||||
|   loop: "Reproducción en bucle" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "No se encuentra" | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "Rechercher" | ||||
| notifications: "Notifications" | ||||
| username: "Nom d’utilisateur·rice" | ||||
| password: "Mot de passe" | ||||
| initialPasswordForSetup: "Mot de passe initial pour la configuration" | ||||
| initialPasswordIsIncorrect: "Mot de passe initial pour la configuration est incorrecte" | ||||
| initialPasswordForSetupDescription: "Utilisez le mot de passe que vous avez entré pour le fichier de configuration si vous avez installé Misskey vous-même.\nSi vous utilisez un service d'hébergement Misskey, utilisez le mot de passe fourni.\nSi vous n'avez pas défini de mot de passe, laissez le champ vide pour continuer." | ||||
| forgotPassword: "Mot de passe oublié" | ||||
| fetchingAsApObject: "Récupération depuis le fédiverse …" | ||||
| ok: "OK" | ||||
| @@ -60,6 +63,7 @@ copyFileId: "Copier l'identifiant du fichier" | ||||
| copyFolderId: "Copier l'identifiant du dossier" | ||||
| copyProfileUrl: "Copier l'URL du profil" | ||||
| searchUser: "Chercher un·e utilisateur·rice" | ||||
| searchThisUsersNotes: "Cherchez les notes de cet·te utilisateur·rice" | ||||
| reply: "Répondre" | ||||
| loadMore: "Afficher plus …" | ||||
| showMore: "Voir plus" | ||||
| @@ -108,6 +112,7 @@ enterEmoji: "Insérer un émoji" | ||||
| renote: "Renoter" | ||||
| unrenote: "Annuler la Renote" | ||||
| renoted: "Renoté !" | ||||
| renotedToX: "Renoté en {name}" | ||||
| cantRenote: "Ce message ne peut pas être renoté." | ||||
| cantReRenote: "Impossible de renoter une Renote." | ||||
| quote: "Citer" | ||||
| @@ -151,6 +156,7 @@ editList: "Modifier la liste" | ||||
| selectChannel: "Sélectionner un canal" | ||||
| selectAntenna: "Sélectionner une antenne" | ||||
| editAntenna: "Modifier l'antenne" | ||||
| createAntenna: "Créer une antenne" | ||||
| selectWidget: "Sélectionner un widget" | ||||
| editWidgets: "Modifier les widgets" | ||||
| editWidgetsExit: "Valider les modifications" | ||||
| @@ -177,6 +183,7 @@ addAccount: "Ajouter un compte" | ||||
| reloadAccountsList: "Rafraichir la liste des comptes" | ||||
| loginFailed: "Échec de la connexion" | ||||
| showOnRemote: "Voir sur l’instance distante" | ||||
| continueOnRemote: "Continuer sur l'instance distante" | ||||
| general: "Général" | ||||
| wallpaper: "Fond d’écran" | ||||
| setWallpaper: "Définir le fond d’écran" | ||||
| @@ -187,6 +194,7 @@ followConfirm: "Êtes-vous sûr·e de vouloir suivre {name} ?" | ||||
| proxyAccount: "Compte proxy" | ||||
| proxyAccountDescription: "Un compte proxy se comporte, dans certaines conditions, comme un·e abonné·e distant·e pour les utilisateurs d'autres instances. Par exemple, quand un·e utilisateur·rice ajoute un·e utilisateur·rice distant·e à une liste, ses notes ne seront pas visibles sur l'instance si personne ne suit cet·te utilisateur·rice. Le compte proxy va donc suivre cet·te utilisateur·rice pour que ses notes soient acheminées." | ||||
| host: "Serveur distant" | ||||
| selectSelf: "Sélectionner manuellement" | ||||
| selectUser: "Sélectionner un·e utilisateur·rice" | ||||
| recipient: "Destinataire" | ||||
| annotation: "Commentaires" | ||||
| @@ -320,6 +328,7 @@ renameFolder: "Renommer le dossier" | ||||
| deleteFolder: "Supprimer le dossier" | ||||
| folder: "Dossier" | ||||
| addFile: "Ajouter un fichier" | ||||
| showFile: "Voir les fichiers" | ||||
| emptyDrive: "Le Disque est vide" | ||||
| emptyFolder: "Le dossier est vide" | ||||
| unableToDelete: "Suppression impossible" | ||||
| @@ -362,7 +371,6 @@ enableLocalTimeline: "Activer le fil local" | ||||
| enableGlobalTimeline: "Activer le fil global" | ||||
| disablingTimelinesInfo: "Même si vous désactivez ces fils, les administrateur·rice·s et les modérateur·rice·s pourront toujours y accéder." | ||||
| registration: "S’inscrire" | ||||
| enableRegistration: "Autoriser les nouvelles inscriptions" | ||||
| invite: "Inviter" | ||||
| driveCapacityPerLocalAccount: "Capacité de stockage du Disque par utilisateur local" | ||||
| driveCapacityPerRemoteAccount: "Capacité de stockage du Disque par utilisateur distant" | ||||
| @@ -430,10 +438,11 @@ token: "Jeton" | ||||
| 2fa: "Authentification à deux facteurs" | ||||
| setupOf2fa: "Configuration de l’authentification à deux facteurs" | ||||
| totp: "Application d'authentification" | ||||
| totpDescription: "Entrez un mot de passe à usage unique à l'aide d'une application d'authentification" | ||||
| totpDescription: "Entrer un mot de passe à usage unique à l'aide d'une application d'authentification" | ||||
| moderator: "Modérateur·rice·s" | ||||
| moderation: "Modérations" | ||||
| moderationNote: "Note de modération" | ||||
| moderationNoteDescription: "Vous pouvez remplir des notes qui seront partagés seulement entre modérateurs." | ||||
| addModerationNote: "Ajouter une note de modération" | ||||
| moderationLogs: "Journal de modération" | ||||
| nUsersMentioned: "{n} utilisateur·rice·s mentionné·e·s" | ||||
| @@ -493,6 +502,10 @@ uiLanguage: "Langue d’affichage de l’interface" | ||||
| aboutX: "À propos de {x}" | ||||
| emojiStyle: "Style des émojis" | ||||
| native: "Natif" | ||||
| menuStyle: "Style du menu" | ||||
| style: "Style" | ||||
| drawer: "Sélecteur" | ||||
| popup: "Pop-up" | ||||
| showNoteActionsOnlyHover: "Afficher les actions de note uniquement au survol" | ||||
| showReactionsCount: "Afficher le nombre de réactions des notes" | ||||
| noHistory: "Pas d'historique" | ||||
| @@ -575,6 +588,7 @@ ascendingOrder: "Ascendant" | ||||
| descendingOrder: "Descendant" | ||||
| scratchpad: "ScratchPad" | ||||
| scratchpadDescription: "ScratchPad fournit un environnement expérimental pour AiScript. Vous pouvez vérifier la rédaction de votre code, sa bonne exécution et le résultat de son interaction avec Misskey." | ||||
| uiInspector: "Inspecteur UI" | ||||
| output: "Sortie" | ||||
| script: "Script" | ||||
| disablePagesScript: "Désactiver AiScript sur les Pages" | ||||
| @@ -618,7 +632,7 @@ description: "Description" | ||||
| describeFile: "Ajouter une description d'image" | ||||
| enterFileDescription: "Saisissez une description" | ||||
| author: "Auteur·rice" | ||||
| leaveConfirm: "Vous avez des modifications non-sauvegardées. Voulez-vous les ignorer ?" | ||||
| leaveConfirm: "Vous avez des modifications non sauvegardées. Voulez-vous les ignorer ?" | ||||
| manage: "Gestion" | ||||
| plugins: "Extensions" | ||||
| preferencesBackups: "Sauvegarder les paramètres" | ||||
| @@ -691,10 +705,7 @@ abuseReported: "Le rapport est envoyé. Merci." | ||||
| reporter: "Signalé par" | ||||
| reporteeOrigin: "Origine du signalement" | ||||
| reporterOrigin: "Signalé par" | ||||
| forwardReport: "Transférer le signalement à l’instance distante" | ||||
| forwardReportIsAnonymous: "L'instance distante ne sera pas en mesure de voir vos informations et apparaîtra comme un compte anonyme du système." | ||||
| send: "Envoyer" | ||||
| abuseMarkAsResolved: "Marquer le signalement comme résolu" | ||||
| openInNewTab: "Ouvrir dans un nouvel onglet" | ||||
| openInSideView: "Ouvrir en vue latérale" | ||||
| defaultNavigationBehaviour: "Navigation par défaut" | ||||
| @@ -831,6 +842,7 @@ administration: "Gestion" | ||||
| accounts: "Comptes" | ||||
| switch: "Remplacer" | ||||
| noMaintainerInformationWarning: "Informations administrateur non configurées." | ||||
| noInquiryUrlWarning: "L'URL demandé n'est pas définie" | ||||
| noBotProtectionWarning: "La protection contre les bots n'est pas configurée." | ||||
| configure: "Configurer" | ||||
| postToGallery: "Publier dans la galerie" | ||||
| @@ -895,6 +907,7 @@ followersVisibility: "Visibilité des abonnés" | ||||
| continueThread: "Afficher la suite du fil" | ||||
| deleteAccountConfirm: "Votre compte sera supprimé. Êtes vous certain ?" | ||||
| incorrectPassword: "Le mot de passe est incorrect." | ||||
| incorrectTotp: "Le mot de passe à usage unique est incorrect ou a expiré." | ||||
| voteConfirm: "Confirmez-vous votre vote pour « {choice} » ?" | ||||
| hide: "Masquer" | ||||
| useDrawerReactionPickerForMobile: "Afficher le sélecteur de réactions en tant que panneau sur mobile" | ||||
| @@ -919,6 +932,9 @@ oneHour: "1 heure" | ||||
| oneDay: "1 jour" | ||||
| oneWeek: "1 semaine" | ||||
| oneMonth: "Un mois" | ||||
| threeMonths: "3 mois" | ||||
| oneYear: "1 an" | ||||
| threeDays: "3 jours" | ||||
| reflectMayTakeTime: "Cela peut prendre un certain temps avant que cela ne se termine." | ||||
| failedToFetchAccountInformation: "Impossible de récupérer les informations du compte." | ||||
| rateLimitExceeded: "Limite de taux dépassée" | ||||
| @@ -926,7 +942,7 @@ cropImage: "Recadrer l'image" | ||||
| cropImageAsk: "Voulez-vous recadrer cette image ?" | ||||
| cropYes: "Rogner" | ||||
| cropNo: "Utiliser en l'état" | ||||
| file: "Fichiers" | ||||
| file: "Fichier" | ||||
| recentNHours: "Dernières {n} heures" | ||||
| recentNDays: "Derniers {n} jours" | ||||
| noEmailServerWarning: "Serveur de courrier non configuré." | ||||
| @@ -1058,6 +1074,7 @@ retryAllQueuesConfirmTitle: "Vraiment réessayer ?" | ||||
| retryAllQueuesConfirmText: "Cela peut augmenter temporairement la charge du serveur." | ||||
| enableChartsForRemoteUser: "Générer les graphiques pour les utilisateurs distants" | ||||
| enableChartsForFederatedInstances: "Générer les graphiques pour les instances distantes" | ||||
| enableStatsForFederatedInstances: "Recevoir les statistiques des instances distantes" | ||||
| showClipButtonInNoteFooter: "Ajouter « Clip » au menu d'action de la note" | ||||
| reactionsDisplaySize: "Taille de l'affichage des réactions" | ||||
| limitWidthOfReaction: "Limiter la largeur maximale des réactions et les afficher en taille réduite" | ||||
| @@ -1105,6 +1122,8 @@ preventAiLearning: "Refuser l'usage dans l'apprentissage automatique d'IA géné | ||||
| preventAiLearningDescription: "Demander aux robots d'indexation de ne pas utiliser le contenu publié, tel que les notes et les images, dans l'apprentissage automatique d'IA générative. Cela est réalisé en incluant le drapeau « noai » dans la réponse HTML. Une prévention complète n'est toutefois pas possible, car il est au robot d'indexation de respecter cette demande." | ||||
| options: "Options" | ||||
| specifyUser: "Spécifier l'utilisateur·rice" | ||||
| openTagPageConfirm: "Ouvrir une page d'hashtags ?" | ||||
| specifyHost: "Spécifier un serveur distant" | ||||
| failedToPreviewUrl: "Aperçu d'URL échoué" | ||||
| update: "Mettre à jour" | ||||
| rolesThatCanBeUsedThisEmojiAsReaction: "Rôles qui peuvent utiliser cet émoji comme réaction" | ||||
| @@ -1225,13 +1244,55 @@ enableHorizontalSwipe: "Glisser pour changer d'onglet" | ||||
| loading: "Chargement en cours" | ||||
| surrender: "Annuler" | ||||
| gameRetry: "Réessayer" | ||||
| notUsePleaseLeaveBlank: "Laisser vide si non utilisé" | ||||
| useTotp: "Entrer un mot de passe à usage unique" | ||||
| useBackupCode: "Utiliser le codes de secours" | ||||
| launchApp: "Lancer l'app" | ||||
| useNativeUIForVideoAudioPlayer: "Lire les vidéos et audios en utilisant l'UI du navigateur" | ||||
| keepOriginalFilename: "Garder le nom original du fichier" | ||||
| keepOriginalFilenameDescription: "Si vous désactivez ce paramètre, les noms de fichiers seront automatiquement remplacés par des noms aléatoires lorsque vous téléchargerez des fichiers." | ||||
| noDescription: "Il n'y a pas de description" | ||||
| alwaysConfirmFollow: "Confirmer lors d'un abonnement" | ||||
| inquiry: "Contact" | ||||
| tryAgain: "Veuillez réessayer plus tard" | ||||
| confirmWhenRevealingSensitiveMedia: "Confirmer pour révéler du contenu sensible" | ||||
| sensitiveMediaRevealConfirm: "Ceci pourrait être du contenu sensible. Voulez-vous l'afficher ?" | ||||
| createdLists: "Listes créées" | ||||
| createdAntennas: "Antennes créées" | ||||
| fromX: "De {x}" | ||||
| genEmbedCode: "Générer le code d'intégration" | ||||
| noteOfThisUser: "Notes de cet·te utilisateur·rice" | ||||
| clipNoteLimitExceeded: "Aucune note supplémentaire ne peut être ajoutée à ce clip." | ||||
| performance: "Performance" | ||||
| modified: "Modifié" | ||||
| discard: "Annuler" | ||||
| thereAreNChanges: "Il y a {n} modification(s)" | ||||
| signinWithPasskey: "Se connecter avec une clé d'accès" | ||||
| unknownWebAuthnKey: "Clé d'accès inconnue." | ||||
| passkeyVerificationFailed: "La vérification de la clé d'accès a échoué." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "La vérification de la clé d'accès a réussi, mais la connexion sans mot de passe est désactivée." | ||||
| messageToFollower: "Message aux abonné·es" | ||||
| target: "Destinataire" | ||||
| prohibitedWordsForNameOfUser: "Mots interdits pour les noms d'utilisateur·rices" | ||||
| lockdown: "Verrouiller" | ||||
| pleaseSelectAccount: "Sélectionner un compte" | ||||
| availableRoles: "Rôles disponibles" | ||||
| _abuseUserReport: | ||||
|   forward: "Transférer" | ||||
|   forwardDescription: "Transférer le signalement vers une instance distante en tant qu'anonyme." | ||||
|   resolve: "Résoudre" | ||||
|   accept: "Accepter" | ||||
|   reject: "Rejeter" | ||||
|   resolveTutorial: "Si le signalement est légitime dans son contenu, sélectionnez « Accepter » pour marquer le cas comme résolu par l'affirmative.\nSi le contenu du rapport n'est pas légitime, sélectionnez « Rejeter » pour marquer le cas comme résolu par la négative." | ||||
| _delivery: | ||||
|   status: "Statut de la diffusion" | ||||
|   stop: "Suspendu·e" | ||||
|   resume: "Reprendre" | ||||
|   _type: | ||||
|     none: "Publié" | ||||
|     manuallySuspended: "Suspendre manuellement" | ||||
|     goneSuspended: "L'instance est suspendue en raison de la suppression de ce dernier" | ||||
|     autoSuspendedForNotResponding: "L'instance est suspendue car elle ne répond pas" | ||||
| _bubbleGame: | ||||
|   howToPlay: "Comment jouer" | ||||
|   hold: "Réserver" | ||||
| @@ -1242,6 +1303,7 @@ _bubbleGame: | ||||
|     maxChain: "Nombre maximum de chaînes" | ||||
|     yen: "{yen} yens" | ||||
|     estimatedQty: "{qty} pièces" | ||||
|     scoreSweets: "{onigiriQtyWithUnit} Onigiri(s)" | ||||
| _announcement: | ||||
|   forExistingUsers: "Pour les utilisateurs existants seulement" | ||||
|   needConfirmationToRead: "Exiger la confirmation de la lecture" | ||||
| @@ -1261,6 +1323,7 @@ _initialAccountSetting: | ||||
|   profileSetting: "Paramètres du profil" | ||||
|   privacySetting: "Paramètres de confidentialité" | ||||
|   initialAccountSettingCompleted: "Configuration du profil terminée avec succès !" | ||||
|   haveFun: "Profitez de {name} !" | ||||
|   youCanContinueTutorial: "Vous pouvez procéder au tutoriel sur l'utilisation de {name}(Misskey) ou vous arrêter ici et commencer à l'utiliser immédiatement." | ||||
|   startTutorial: "Démarrer le tutoriel" | ||||
|   skipAreYouSure: "Désirez-vous ignorer la configuration du profil ?" | ||||
| @@ -1354,18 +1417,60 @@ _achievements: | ||||
|       flavor: "Passez un bon moment avec Misskey !" | ||||
|     _notes10: | ||||
|       title: "Quelques notes" | ||||
|       description: "Poster 10 notes" | ||||
|     _notes100: | ||||
|       title: "Beaucoup de notes" | ||||
|       description: "Poster 100 notes" | ||||
|     _notes500: | ||||
|       title: "Couvert de notes" | ||||
|       description: "Poster 500 notes" | ||||
|     _notes1000: | ||||
|       title: "Une montagne de notes" | ||||
|       description: "Poster 1000 notes" | ||||
|     _notes5000: | ||||
|       title: "Débordement de notes" | ||||
|       description: "Poster 5 000 notes" | ||||
|     _notes10000: | ||||
|       title: "Super note" | ||||
|       description: "Poster 10 000 notes" | ||||
|     _notes20000: | ||||
|       title: "Encore... plus... de... notes..." | ||||
|       description: "Poster 20 000 notes" | ||||
|     _notes30000: | ||||
|       title: "Notes notes notes !" | ||||
|       description: "Poster 30 000 notes" | ||||
|     _notes40000: | ||||
|       title: "Usine de notes" | ||||
|       description: "Poster 40 000 notes" | ||||
|     _notes50000: | ||||
|       title: "Planète des notes" | ||||
|       description: "Poster 50 000 notes" | ||||
|     _notes60000: | ||||
|       title: "Quasar de note" | ||||
|       description: "Poster 50 000 notes" | ||||
|     _notes70000: | ||||
|       title: "Trou noir de notes" | ||||
|       description: "Poster 70 000 notes" | ||||
|     _notes80000: | ||||
|       title: "Galaxie de notes" | ||||
|       description: "Poster 80 000 notes" | ||||
|     _notes90000: | ||||
|       title: "Univers de notes" | ||||
|       description: "Poster 90 000 notes" | ||||
|     _notes100000: | ||||
|       title: "ALL YOUR NOTE ARE BELONG TO US" | ||||
|       description: "Poster 100 000 notes" | ||||
|       flavor: "Avez-vous tant de choses à dire ?" | ||||
|     _login3: | ||||
|       title: "Débutant Ⅰ" | ||||
|       title: "Débutant I" | ||||
|       description: "Se connecter pour un total de 3 jours" | ||||
|       flavor: "Dès maintenant, appelez-moi Misskeynaute" | ||||
|     _login7: | ||||
|       title: "Débutant Ⅱ" | ||||
|       title: "Débutant II" | ||||
|       description: "Se connecter pour un total de 7 jours" | ||||
|       flavor: "On s'habitue ?" | ||||
|     _login15: | ||||
|       title: "Débutant Ⅲ" | ||||
|       title: "Débutant III" | ||||
|       description: "Se connecter pour un total de 15 jours" | ||||
|     _login30: | ||||
|       title: "Misskeynaute I" | ||||
| @@ -1389,6 +1494,7 @@ _achievements: | ||||
|     _login500: | ||||
|       title: "Expert I" | ||||
|       description: "Se connecter pour un total de 500 jours" | ||||
|       flavor: "Non, mes amis, j'aime les notes" | ||||
|     _login600: | ||||
|       title: "Expert II" | ||||
|       description: "Se connecter pour un total de 600 jours" | ||||
| @@ -1396,11 +1502,18 @@ _achievements: | ||||
|       title: "Expert III" | ||||
|       description: "Se connecter pour un total de 700 jours" | ||||
|     _login800: | ||||
|       title: "Maître des notes I" | ||||
|       description: "Se connecter pour un total de 800 jours" | ||||
|     _login900: | ||||
|       title: "Maître des notes II" | ||||
|       description: "Se connecter pour un total de 900 jours" | ||||
|     _login1000: | ||||
|       title: "Maître des notes III" | ||||
|       description: "Se connecter pour un total de 1 000 jours" | ||||
|       flavor: "Merci d'utiliser Misskey !" | ||||
|     _noteClipped1: | ||||
|       title: "Je... dois... clip..." | ||||
|       description: "Ajouter sa première note aux clips" | ||||
|     _profileFilled: | ||||
|       title: "Bien préparé" | ||||
|       description: "Configuration de votre profil" | ||||
| @@ -1459,21 +1572,31 @@ _achievements: | ||||
|     _driveFolderCircularReference: | ||||
|       title: "Référence circulaire" | ||||
|     _setNameToSyuilo: | ||||
|       title: "Complexe de dieu" | ||||
|       description: "Vous avez spécifié « syuilo » comme nom" | ||||
|     _passedSinceAccountCreated1: | ||||
|       title: "Premier anniversaire" | ||||
|       description: "Un an est passé depuis la création du compte" | ||||
|     _passedSinceAccountCreated2: | ||||
|       title: "Second anniversaire" | ||||
|       description: "Deux ans sont passés depuis la création du compte" | ||||
|     _passedSinceAccountCreated3: | ||||
|       title: "3ème anniversaire" | ||||
|       description: "Trois ans sont passés depuis la création du compte" | ||||
|     _loggedInOnBirthday: | ||||
|       title: "Joyeux Anniversaire !" | ||||
|       description: "Vous vous êtes connecté à la date de votre anniversaire" | ||||
|     _loggedInOnNewYearsDay: | ||||
|       title: "Bonne année !" | ||||
|       description: "Vous vous êtes connecté le premier jour de l'année" | ||||
|       flavor: "Merci pour le soutient continue sur cette instance." | ||||
|     _cookieClicked: | ||||
|       title: "Jeu de clic sur des cookies" | ||||
|       description: "Cliqué sur un cookie" | ||||
|       flavor: "Attendez une minute, vous êtes sur le mauvais site web ?" | ||||
|     _brainDiver: | ||||
|       title: "Brain Diver" | ||||
|       description: "Poster le lien sur Brain Diver" | ||||
|       flavor: "Misskey-Misskey La-Tu-Ma" | ||||
|     _smashTestNotificationButton: | ||||
|       title: "Débordement de tests" | ||||
| @@ -1481,6 +1604,11 @@ _achievements: | ||||
|     _tutorialCompleted: | ||||
|       title: "Diplôme de la course élémentaire de Misskey" | ||||
|       description: "Terminer le tutoriel" | ||||
|     _bubbleGameExplodingHead: | ||||
|       title: "🤯" | ||||
|       description: "Le plus gros objet du jeu de bulles" | ||||
|     _bubbleGameDoubleExplodingHead: | ||||
|       title: "Double🤯" | ||||
| _role: | ||||
|   new: "Nouveau rôle" | ||||
|   edit: "Modifier le rôle" | ||||
| @@ -1511,9 +1639,11 @@ _role: | ||||
|     canManageCustomEmojis: "Gestion des émojis personnalisés" | ||||
|     canManageAvatarDecorations: "Gestion des décorations d'avatar" | ||||
|     driveCapacity: "Capacité de stockage du Disque" | ||||
|     antennaMax: "Nombre maximum d'antennes" | ||||
|     wordMuteMax: "Nombre maximal de caractères dans le filtre de mots" | ||||
|     canUseTranslator: "Usage de la fonctionnalité de traduction" | ||||
|     avatarDecorationLimit: "Nombre maximal de décorations d'avatar" | ||||
|     canImportAntennas: "Autoriser l'importation d'antennes" | ||||
| _sensitiveMediaDetection: | ||||
|   description: "L'apprentissage automatique peut être utilisé pour détecter automatiquement les médias sensibles à modérer. La sollicitation des serveurs augmente légèrement." | ||||
|   sensitivity: "Sensibilité de la détection" | ||||
| @@ -1704,7 +1834,6 @@ _theme: | ||||
|     buttonBg: "Arrière-plan du bouton" | ||||
|     buttonHoverBg: "Arrière-plan du bouton (survolé)" | ||||
|     inputBorder: "Cadre de la zone de texte" | ||||
|     listItemHoverBg: "Arrière-plan d'item de liste (survolé)" | ||||
|     driveFolderBg: "Arrière-plan du dossier de disque" | ||||
|     wallpaperOverlay: "Superposition de fond d'écran" | ||||
|     badge: "Badge" | ||||
| @@ -1797,6 +1926,29 @@ _permissions: | ||||
|   "write:gallery": "Éditer la galerie" | ||||
|   "read:gallery-likes": "Voir les mentions « J'aime » dans la galerie" | ||||
|   "write:gallery-likes": "Gérer les mentions « J'aime » dans la galerie" | ||||
|   "read:flash": "Voir le Play" | ||||
|   "write:flash": "Modifier le Play" | ||||
|   "read:flash-likes": "Lire vos mentions j'aime des Play" | ||||
|   "write:flash-likes": "Modifier vos mentions j'aime des Play" | ||||
|   "read:admin:abuse-user-reports": "Voir les utilisateurs signalés" | ||||
|   "write:admin:delete-account": "Supprimer le compte d'utilisateur" | ||||
|   "write:admin:delete-all-files-of-a-user": "Supprimer tous les fichiers d'un utilisateur" | ||||
|   "read:admin:index-stats": "Voir les statistiques sur les index de base de données" | ||||
|   "read:admin:table-stats": "Voir les statistiques sur les index de base de données" | ||||
|   "read:admin:user-ips": "Voir l'adresse IP de l'utilisateur" | ||||
|   "read:admin:meta": "Voir les métadonnées de l'instance" | ||||
|   "write:admin:reset-password": "Réinitialiser le mot de passe de l'utilisateur" | ||||
|   "write:admin:resolve-abuse-user-report": "Résoudre le signalement d'un utilisateur" | ||||
|   "write:admin:send-email": "Envoyer un mail" | ||||
|   "read:admin:server-info": "Voir les informations de l'instance" | ||||
|   "read:admin:show-moderation-log": "Voir les logs de modération" | ||||
|   "read:admin:show-user": "Voir les informations privées de l'utilisateur" | ||||
|   "write:admin:suspend-user": "Suspendre l'utilisateur" | ||||
|   "write:admin:unset-user-avatar": "Retirer l'avatar de l'utilisateur" | ||||
|   "write:admin:unset-user-banner": "Retirer la bannière de l'utilisateur" | ||||
|   "write:admin:unsuspend-user": "Lever la suspension d'un utilisateur" | ||||
|   "write:admin:meta": "Gérer les métadonnées de l'instance" | ||||
|   "write:admin:roles": "Gérer les rôles" | ||||
| _auth: | ||||
|   shareAccess: "Autoriser \"{name}\" à accéder à votre compte ?" | ||||
|   shareAccessAsk: "Voulez-vous vraiment autoriser cette application à accéder à votre compte?" | ||||
| @@ -1948,7 +2100,16 @@ _timelines: | ||||
|   social: "Social" | ||||
|   global: "Global" | ||||
| _play: | ||||
|   new: "Créer un Play" | ||||
|   edit: "Modifier un Play" | ||||
|   created: "Play créé" | ||||
|   updated: "Play édité" | ||||
|   deleted: "Play supprimé" | ||||
|   pageSetting: "Configuration du Play" | ||||
|   editThisPage: "Modifier ce Play" | ||||
|   viewSource: "Afficher la source" | ||||
|   my: "Mes Play" | ||||
|   liked: "Play aimés" | ||||
|   featured: "Populaire" | ||||
|   title: "Titre" | ||||
|   script: "Script" | ||||
| @@ -2022,10 +2183,13 @@ _notification: | ||||
|   achievementEarned: "Accomplissement déverrouillé" | ||||
|   testNotification: "Tester la notification" | ||||
|   reactedBySomeUsers: "{n} utilisateur·rice·s ont réagi" | ||||
|   likedBySomeUsers: "{n} utilisateurs ont aimé votre note" | ||||
|   renotedBySomeUsers: "{n} utilisateur·rice·s ont renoté" | ||||
|   followedBySomeUsers: "{n} utilisateur·rice·s se sont abonné·e·s à vous" | ||||
|   login: "Quelqu'un s'est connecté" | ||||
|   _types: | ||||
|     all: "Toutes" | ||||
|     note: "Nouvelles notes" | ||||
|     follow: "Nouvel·le abonné·e" | ||||
|     mention: "Mentions" | ||||
|     reply: "Réponses" | ||||
| @@ -2037,6 +2201,7 @@ _notification: | ||||
|     followRequestAccepted: "Demande d'abonnement acceptée" | ||||
|     roleAssigned: "Rôle reçu" | ||||
|     achievementEarned: "Déverrouillage d'accomplissement" | ||||
|     login: "Se connecter" | ||||
|     app: "Notifications provenant des apps" | ||||
|   _actions: | ||||
|     followBack: "Suivre" | ||||
| @@ -2074,11 +2239,14 @@ _drivecleaner: | ||||
|   orderByCreatedAtAsc: "Date d'ajout ascendante" | ||||
| _webhookSettings: | ||||
|   name: "Nom" | ||||
|   secret: "Secret" | ||||
|   trigger: "Activateur" | ||||
|   active: "Activé" | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     _recipientType: | ||||
|       mail: "E-mail " | ||||
|     keywords: "Mots clés " | ||||
| _moderationLogTypes: | ||||
|   createRole: "Rôle créé" | ||||
|   deleteRole: "Rôle supprimé" | ||||
| @@ -2115,6 +2283,7 @@ _moderationLogTypes: | ||||
|   deleteAvatarDecoration: "Décoration d'avatar supprimée" | ||||
|   unsetUserAvatar: "Supprimer l'avatar de l'utilisateur·rice" | ||||
|   unsetUserBanner: "Supprimer la bannière de l'utilisateur·rice" | ||||
|   deleteFlash: "Supprimer le Play" | ||||
| _fileViewer: | ||||
|   title: "Détails du fichier" | ||||
|   type: "Type du fichier" | ||||
| @@ -2178,5 +2347,23 @@ _dataSaver: | ||||
|     title: "Mise en évidence du code" | ||||
|     description: "Si la notation de mise en évidence du code est utilisée, par exemple dans la MFM, elle ne sera pas chargée tant qu'elle n'aura pas été tapée. La mise en évidence du code nécessite le chargement du fichier de définition de chaque langue à mettre en évidence, mais comme ces fichiers ne sont plus chargés automatiquement, on peut s'attendre à une réduction du trafic de données." | ||||
| _reversi: | ||||
|   reversi: "Reversi" | ||||
|   blackIs: "{name} joue les noirs" | ||||
|   rules: "Règles" | ||||
|   waitingBoth: "Préparez-vous" | ||||
|   myTurn: "C’est votre tour" | ||||
|   turnOf: "C'est le tour de {name}" | ||||
|   pastTurnOf: "Tour de {name}" | ||||
|   surrender: "Se rendre" | ||||
|   surrendered: "Par abandon" | ||||
|   total: "Total" | ||||
|   playing: "En cours" | ||||
|   lookingForPlayer: "Recherche d'adversaire" | ||||
| _mediaControls: | ||||
|   playbackRate: "Vitesse de lecture" | ||||
| _embedCodeGen: | ||||
|   title: "Personnaliser le code d'intégration" | ||||
|   generateCode: "Générer le code d'intégration" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Non trouvé" | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| --- | ||||
| _lang_: "Japán" | ||||
| _lang_: "Magyar" | ||||
| monthAndDay: "{month}.{day}." | ||||
| search: "Keresés" | ||||
| notifications: "Értesítések" | ||||
| @@ -96,6 +96,7 @@ _notification: | ||||
|     renote: "Renote" | ||||
|     quote: "Idézet" | ||||
|     reaction: "Reakciók" | ||||
|     login: "Bejelentkezés" | ||||
|   _actions: | ||||
|     renote: "Renote" | ||||
| _deck: | ||||
|   | ||||
| @@ -196,6 +196,7 @@ followConfirm: "Apakah kamu yakin ingin mengikuti {name}?" | ||||
| proxyAccount: "Akun proksi" | ||||
| proxyAccountDescription: "Akun proksi merupakan sebuah akun yang bertindak sebagai pengikut instansi luar untuk pengguna dalam kondisi tertentu. Sebagai contoh, ketika pengguna menambahkan seorang pengguna instansi luar ke dalam daftar, aktivitas dari pengguna instansi luar tidak akan disampaikan ke instansi apabila tidak ada pengguna lokal yang mengikuti pengguna tersebut, dengan begitu akun proksilah yang akan mengikutinya." | ||||
| host: "Host" | ||||
| selectSelf: "Pilih diri sendiri" | ||||
| selectUser: "Pilih pengguna" | ||||
| recipient: "Penerima" | ||||
| annotation: "Keterangan konten" | ||||
| @@ -232,6 +233,7 @@ blockedInstances: "Instansi terblokir" | ||||
| blockedInstancesDescription: "Daftar nama host dari instansi yang diperlukan untuk diblokir. Instansi yang didaftarkan tidak akan dapat berkomunikasi dengan instansi ini." | ||||
| silencedInstances: "Instansi yang disenyapkan" | ||||
| silencedInstancesDescription: "Daftar nama host dari instansi yang ingin kamu senyapkan. Semua akun dari instansi yang terdaftar akan diperlakukan sebagai disenyapkan. Hal ini membuat akun hanya dapat membuat permintaan mengikuti, dan tidak dapat menyebutkan akun lokal apabila tidak mengikuti. Hal ini tidak akan mempengaruhi instansi yang diblokir." | ||||
| federationAllowedHosts: "Server yang membolehkan federasi" | ||||
| muteAndBlock: "Bisukan / Blokir" | ||||
| mutedUsers: "Pengguna yang dibisukan" | ||||
| blockedUsers: "Pengguna yang diblokir" | ||||
| @@ -330,6 +332,7 @@ renameFolder: "Ubah nama folder" | ||||
| deleteFolder: "Hapus folder" | ||||
| folder: "Folder" | ||||
| addFile: "Tambahkan berkas" | ||||
| showFile: "Tampilkan berkas" | ||||
| emptyDrive: "Drive kosong" | ||||
| emptyFolder: "Folder kosong" | ||||
| unableToDelete: "Tidak dapat menghapus" | ||||
| @@ -372,7 +375,6 @@ enableLocalTimeline: "Nyalakan lini masa lokal" | ||||
| enableGlobalTimeline: "Nyalakan lini masa global" | ||||
| disablingTimelinesInfo: "Admin dan Moderator akan selalu memiliki akses ke semua lini masa meskipun lini masa tersebut tidak diaktifkan." | ||||
| registration: "Pendaftaran" | ||||
| enableRegistration: "Nyalakan pendaftaran pengguna baru" | ||||
| invite: "Undang" | ||||
| driveCapacityPerLocalAccount: "Kapasitas drive per pengguna lokal" | ||||
| driveCapacityPerRemoteAccount: "Kapasitas drive per pengguna remote" | ||||
| @@ -504,6 +506,8 @@ uiLanguage: "Bahasa antarmuka pengguna" | ||||
| aboutX: "Tentang {x}" | ||||
| emojiStyle: "Gaya emoji" | ||||
| native: "Native" | ||||
| menuStyle: "Gaya menu" | ||||
| style: "Gaya" | ||||
| showNoteActionsOnlyHover: "Hanya tampilkan aksi catatan saat ditunjuk" | ||||
| showReactionsCount: "Lihat jumlah reaksi dalam catatan" | ||||
| noHistory: "Tidak ada riwayat" | ||||
| @@ -702,10 +706,7 @@ abuseReported: "Laporan kamu telah dikirimkan. Terima kasih." | ||||
| reporter: "Pelapor" | ||||
| reporteeOrigin: "Yang dilaporkan" | ||||
| reporterOrigin: "Pelapor" | ||||
| forwardReport: "Teruskan laporan ke instansi luar" | ||||
| forwardReportIsAnonymous: "Untuk melindungi privasi akun kamu, akun anonim dari sistem akan digunakan sebagai pelapor pada instansi luar." | ||||
| send: "Kirim" | ||||
| abuseMarkAsResolved: "Tandai laporan sebagai selesai" | ||||
| openInNewTab: "Buka di tab baru" | ||||
| openInSideView: "Buka di tampilan samping" | ||||
| defaultNavigationBehaviour: "Navigasi bawaan" | ||||
| @@ -930,6 +931,9 @@ oneHour: "1 Jam" | ||||
| oneDay: "1 Hari" | ||||
| oneWeek: "1 Bulan" | ||||
| oneMonth: "satu bulan" | ||||
| threeMonths: "3 bulan" | ||||
| oneYear: "1 tahun" | ||||
| threeDays: "3 hari" | ||||
| reflectMayTakeTime: "Mungkin perlu beberapa saat untuk dicerminkan." | ||||
| failedToFetchAccountInformation: "Gagal untuk mendapatkan informasi akun" | ||||
| rateLimitExceeded: "Batas sudah terlampaui" | ||||
| @@ -1104,6 +1108,7 @@ preservedUsernames: "Nama pengguna tercadangkan" | ||||
| preservedUsernamesDescription: "Daftar nama pengguna yang dicadangkan dipisah dengan baris baru. Nama pengguna berikut akan tidak dapat dipakai pada pembuatan akun normal, namun dapat digunakan oleh admin untuk membuat akun baru. Akun yang sudah ada dengan menggunakan nama pengguna ini tidak akan terpengaruh." | ||||
| createNoteFromTheFile: "Buat catatan dari berkas ini" | ||||
| archive: "Arsipkan" | ||||
| archived: "Diarsipkan" | ||||
| channelArchiveConfirmTitle: "Yakin untuk mengarsipkan {name}?" | ||||
| channelArchiveConfirmDescription: "Kanal yang diarsipkan tidak akan muncul pada daftar kanal atau hasil pencarian. Postingan baru juga tidak dapat ditambahkan lagi." | ||||
| thisChannelArchived: "Kanal ini telah diarsipkan." | ||||
| @@ -1114,6 +1119,7 @@ preventAiLearning: "Tolak penggunaan Pembelajaran Mesin (AI Generatif)" | ||||
| preventAiLearningDescription: "Minta perayap web untuk tidak menggunakan materi teks atau gambar yang telah diposting ke dalam set data Pembelajaran Mesin (Prediktif / Generatif). Hal ini dicapai dengan menambahkan flag HTML-Response \"noai\" ke masing-masing konten. Pencegahan penuh mungkin tidak dapat dicapai dengan flag ini, karena juga dapat diabaikan begitu saja." | ||||
| options: "Opsi peran" | ||||
| specifyUser: "Pengguna spesifik" | ||||
| openTagPageConfirm: "Apakah ingin membuka laman tagar?" | ||||
| failedToPreviewUrl: "Tidak dapat dipratinjau" | ||||
| update: "Perbarui" | ||||
| rolesThatCanBeUsedThisEmojiAsReaction: "Peran yang dapat menggunakan emoji ini sebagai reaksi" | ||||
| @@ -1246,6 +1252,18 @@ noDescription: "Tidak ada deskripsi" | ||||
| alwaysConfirmFollow: "Selalu konfirmasi ketika mengikuti" | ||||
| inquiry: "Hubungi kami" | ||||
| tryAgain: "Silahkan coba lagi." | ||||
| createdLists: "Senarai yang dibuat" | ||||
| createdAntennas: "Antena yang dibuat" | ||||
| fromX: "Dari {x}" | ||||
| noteOfThisUser: "Catatan oleh pengguna ini" | ||||
| clipNoteLimitExceeded: "Klip ini tak bisa ditambahi lagi catatan." | ||||
| performance: "Kinerja" | ||||
| modified: "Diubah" | ||||
| thereAreNChanges: "Ada {n} perubahan" | ||||
| prohibitedWordsForNameOfUser: "Kata yang dilarang untuk nama pengguna" | ||||
| _abuseUserReport: | ||||
|   accept: "Setuju" | ||||
|   reject: "Tolak" | ||||
| _delivery: | ||||
|   status: "Status pengiriman" | ||||
|   stop: "Ditangguhkan" | ||||
| @@ -1710,6 +1728,8 @@ _role: | ||||
|     canSearchNotes: "Penggunaan pencarian catatan" | ||||
|     canUseTranslator: "Penggunaan penerjemah" | ||||
|     avatarDecorationLimit: "Jumlah maksimum dekorasi avatar yang dapat diterapkan" | ||||
|     canImportAntennas: "Izinkan mengimpor antena" | ||||
|     canImportUserLists: "Izinkan mengimpor senarai" | ||||
|   _condition: | ||||
|     roleAssignedTo: "Ditugaskan ke peran manual" | ||||
|     isLocal: "Pengguna lokal" | ||||
| @@ -1927,7 +1947,6 @@ _theme: | ||||
|     buttonBg: "Latar belakang tombol" | ||||
|     buttonHoverBg: "Latar belakang tombol (Mengambang)" | ||||
|     inputBorder: "Batas bidang masukan" | ||||
|     listItemHoverBg: "Latar belakang daftar item (Mengambang)" | ||||
|     driveFolderBg: "Latar belakang folder drive" | ||||
|     wallpaperOverlay: "Lapisan wallpaper" | ||||
|     badge: "Lencana" | ||||
| @@ -1947,6 +1966,7 @@ _soundSettings: | ||||
|   driveFileTypeWarnDescription: "Pilih berkas audio" | ||||
|   driveFileDurationWarn: "Audio ini terlalu panjang" | ||||
|   driveFileDurationWarnDescription: "Audio panjang dapat mengganggu penggunaan Misskey. Masih ingin melanjutkan?" | ||||
|   driveFileError: "Tak bisa memuat audio. Mohon ubah pengaturan" | ||||
| _ago: | ||||
|   future: "Masa depan" | ||||
|   justNow: "Baru saja" | ||||
| @@ -2354,6 +2374,7 @@ _notification: | ||||
|     followRequestAccepted: "Permintaan mengikuti disetujui" | ||||
|     roleAssigned: "Peran Diberikan" | ||||
|     achievementEarned: "Pencapaian didapatkan" | ||||
|     login: "Masuk" | ||||
|     app: "Notifikasi dari aplikasi tertaut" | ||||
|   _actions: | ||||
|     followBack: "Ikuti Kembali" | ||||
| @@ -2418,6 +2439,8 @@ _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     _recipientType: | ||||
|       mail: "Surel" | ||||
|       webhook: "Webhook" | ||||
|     keywords: "Kata kunci" | ||||
| _moderationLogTypes: | ||||
|   createRole: "Peran telah dibuat" | ||||
|   deleteRole: "Peran telah dihapus" | ||||
| @@ -2455,6 +2478,7 @@ _moderationLogTypes: | ||||
|   deleteAvatarDecoration: "Hapus dekorasi avatar" | ||||
|   unsetUserAvatar: "Hapus avatar pengguna" | ||||
|   unsetUserBanner: "Hapus banner pengguna" | ||||
|   deleteAccount: "Akun dihapus" | ||||
| _fileViewer: | ||||
|   title: "Rincian berkas" | ||||
|   type: "Jenis berkas" | ||||
| @@ -2586,3 +2610,6 @@ _mediaControls: | ||||
|   pip: "Gambar dalam Gambar" | ||||
|   playbackRate: "Kecepatan Pemutaran" | ||||
|   loop: "Ulangi Pemutaran" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Tidak dapat ditemukan" | ||||
|   | ||||
							
								
								
									
										624
									
								
								locales/index.d.ts
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										624
									
								
								locales/index.d.ts
									
									
									
									
										vendored
									
									
								
							| @@ -36,6 +36,10 @@ export interface Locale extends ILocale { | ||||
|      * 検索 | ||||
|      */ | ||||
|     "search": string; | ||||
|     /** | ||||
|      * リセット | ||||
|      */ | ||||
|     "reset": string; | ||||
|     /** | ||||
|      * 通知 | ||||
|      */ | ||||
| @@ -48,6 +52,20 @@ export interface Locale extends ILocale { | ||||
|      * パスワード | ||||
|      */ | ||||
|     "password": string; | ||||
|     /** | ||||
|      * 初期設定開始用パスワード | ||||
|      */ | ||||
|     "initialPasswordForSetup": string; | ||||
|     /** | ||||
|      * 初期設定開始用のパスワードが違います。 | ||||
|      */ | ||||
|     "initialPasswordIsIncorrect": string; | ||||
|     /** | ||||
|      * Misskeyを自分でインストールした場合は、設定ファイルに入力したパスワードを使用してください。 | ||||
|      * Misskeyのホスティングサービスなどを使用している場合は、提供されたパスワードを使用してください。 | ||||
|      * パスワードを設定していない場合は、空欄にしたまま続行してください。 | ||||
|      */ | ||||
|     "initialPasswordForSetupDescription": string; | ||||
|     /** | ||||
|      * パスワードを忘れた | ||||
|      */ | ||||
| @@ -196,6 +214,10 @@ export interface Locale extends ILocale { | ||||
|      * リンクをコピー | ||||
|      */ | ||||
|     "copyLink": string; | ||||
|     /** | ||||
|      * リモートのリンクをコピー | ||||
|      */ | ||||
|     "copyRemoteLink": string; | ||||
|     /** | ||||
|      * リノートのリンクをコピー | ||||
|      */ | ||||
| @@ -1532,10 +1554,6 @@ export interface Locale extends ILocale { | ||||
|      * 登録 | ||||
|      */ | ||||
|     "registration": string; | ||||
|     /** | ||||
|      * 誰でも新規登録できるようにする | ||||
|      */ | ||||
|     "enableRegistration": string; | ||||
|     /** | ||||
|      * 招待 | ||||
|      */ | ||||
| @@ -1820,6 +1838,10 @@ export interface Locale extends ILocale { | ||||
|      * モデレーションノート | ||||
|      */ | ||||
|     "moderationNote": string; | ||||
|     /** | ||||
|      * モデレーター間でだけ共有されるメモを記入することができます。 | ||||
|      */ | ||||
|     "moderationNoteDescription": string; | ||||
|     /** | ||||
|      * モデレーションノートを追加する | ||||
|      */ | ||||
| @@ -2348,6 +2370,10 @@ export interface Locale extends ILocale { | ||||
|      * 詳細 | ||||
|      */ | ||||
|     "details": string; | ||||
|     /** | ||||
|      * リノートの詳細 | ||||
|      */ | ||||
|     "renoteDetails": string; | ||||
|     /** | ||||
|      * 絵文字を選択 | ||||
|      */ | ||||
| @@ -2736,10 +2762,22 @@ export interface Locale extends ILocale { | ||||
|      * ワードミュート | ||||
|      */ | ||||
|     "wordMute": string; | ||||
|     /** | ||||
|      * 指定した語句を含むノートを最小化します。最小化されたノートをクリックすることで表示することができます。 | ||||
|      */ | ||||
|     "wordMuteDescription": string; | ||||
|     /** | ||||
|      * ハードワードミュート | ||||
|      */ | ||||
|     "hardWordMute": string; | ||||
|     /** | ||||
|      * ミュートされたワードを表示 | ||||
|      */ | ||||
|     "showMutedWord": string; | ||||
|     /** | ||||
|      * 指定した語句を含むノートを隠します。ワードミュートとは異なり、ノートは完全に表示されなくなります。 | ||||
|      */ | ||||
|     "hardWordMuteDescription": string; | ||||
|     /** | ||||
|      * 正規表現エラー | ||||
|      */ | ||||
| @@ -2756,6 +2794,10 @@ export interface Locale extends ILocale { | ||||
|      * {name}が何かを言いました | ||||
|      */ | ||||
|     "userSaysSomething": ParameterizedString<"name">; | ||||
|     /** | ||||
|      * {name}が「{word}」について何かを言いました | ||||
|      */ | ||||
|     "userSaysSomethingAbout": ParameterizedString<"name" | "word">; | ||||
|     /** | ||||
|      * アクティブにする | ||||
|      */ | ||||
| @@ -2880,22 +2922,10 @@ export interface Locale extends ILocale { | ||||
|      * 通報元 | ||||
|      */ | ||||
|     "reporterOrigin": string; | ||||
|     /** | ||||
|      * リモートサーバーに通報を転送する | ||||
|      */ | ||||
|     "forwardReport": string; | ||||
|     /** | ||||
|      * リモートサーバーからはあなたの情報は見れず、匿名のシステムアカウントとして表示されます。 | ||||
|      */ | ||||
|     "forwardReportIsAnonymous": string; | ||||
|     /** | ||||
|      * 送信 | ||||
|      */ | ||||
|     "send": string; | ||||
|     /** | ||||
|      * 対応済みにする | ||||
|      */ | ||||
|     "abuseMarkAsResolved": string; | ||||
|     /** | ||||
|      * 新しいタブで開く | ||||
|      */ | ||||
| @@ -3700,6 +3730,10 @@ export interface Locale extends ILocale { | ||||
|      * パスワードが間違っています。 | ||||
|      */ | ||||
|     "incorrectPassword": string; | ||||
|     /** | ||||
|      * ワンタイムパスワードが間違っているか、期限切れになっています。 | ||||
|      */ | ||||
|     "incorrectTotp": string; | ||||
|     /** | ||||
|      * 「{choice}」に投票しますか? | ||||
|      */ | ||||
| @@ -3796,6 +3830,18 @@ export interface Locale extends ILocale { | ||||
|      * 1ヶ月 | ||||
|      */ | ||||
|     "oneMonth": string; | ||||
|     /** | ||||
|      * 3ヶ月 | ||||
|      */ | ||||
|     "threeMonths": string; | ||||
|     /** | ||||
|      * 1年 | ||||
|      */ | ||||
|     "oneYear": string; | ||||
|     /** | ||||
|      * 3日 | ||||
|      */ | ||||
|     "threeDays": string; | ||||
|     /** | ||||
|      * 反映されるまで時間がかかる場合があります。 | ||||
|      */ | ||||
| @@ -4356,6 +4402,10 @@ export interface Locale extends ILocale { | ||||
|      * リモートサーバーのチャートを生成 | ||||
|      */ | ||||
|     "enableChartsForFederatedInstances": string; | ||||
|     /** | ||||
|      * リモートサーバーの情報を取得 | ||||
|      */ | ||||
|     "enableStatsForFederatedInstances": string; | ||||
|     /** | ||||
|      * ノートのアクションにクリップを追加 | ||||
|      */ | ||||
| @@ -5148,6 +5198,135 @@ export interface Locale extends ILocale { | ||||
|      * パスキーの検証に成功しましたが、パスワードレスログインが無効になっています。 | ||||
|      */ | ||||
|     "passkeyVerificationSucceededButPasswordlessLoginDisabled": string; | ||||
|     /** | ||||
|      * フォロワーへのメッセージ | ||||
|      */ | ||||
|     "messageToFollower": string; | ||||
|     /** | ||||
|      * 対象 | ||||
|      */ | ||||
|     "target": string; | ||||
|     /** | ||||
|      * CAPTCHAのテストを目的とした機能です。<strong>本番環境で使用しないでください。</strong> | ||||
|      */ | ||||
|     "testCaptchaWarning": string; | ||||
|     /** | ||||
|      * 禁止ワード(ユーザーの名前) | ||||
|      */ | ||||
|     "prohibitedWordsForNameOfUser": string; | ||||
|     /** | ||||
|      * このリストに含まれる文字列がユーザーの名前に含まれる場合、ユーザーの名前の変更を拒否します。モデレーター権限を持つユーザーはこの制限の影響を受けません。 | ||||
|      */ | ||||
|     "prohibitedWordsForNameOfUserDescription": string; | ||||
|     /** | ||||
|      * 変更しようとした名前に禁止された文字列が含まれています | ||||
|      */ | ||||
|     "yourNameContainsProhibitedWords": string; | ||||
|     /** | ||||
|      * 名前に禁止されている文字列が含まれています。この名前を使用したい場合は、サーバー管理者にお問い合わせください。 | ||||
|      */ | ||||
|     "yourNameContainsProhibitedWordsDescription": string; | ||||
|     /** | ||||
|      * 投稿者により、表示にはログインが必要と設定されています | ||||
|      */ | ||||
|     "thisContentsAreMarkedAsSigninRequiredByAuthor": string; | ||||
|     /** | ||||
|      * ロックダウン | ||||
|      */ | ||||
|     "lockdown": string; | ||||
|     /** | ||||
|      * アカウントを選択してください | ||||
|      */ | ||||
|     "pleaseSelectAccount": string; | ||||
|     /** | ||||
|      * 利用可能なロール | ||||
|      */ | ||||
|     "availableRoles": string; | ||||
|     /** | ||||
|      * 注意事項を理解した上でオンにします。 | ||||
|      */ | ||||
|     "acknowledgeNotesAndEnable": string; | ||||
|     /** | ||||
|      * このサーバーはホワイトリスト連合で運用されています。管理者が指定したサーバー以外とやり取りすることはできません。 | ||||
|      */ | ||||
|     "federationSpecified": string; | ||||
|     /** | ||||
|      * このサーバーは連合が無効化されています。他のサーバーのユーザーとやり取りすることはできません。 | ||||
|      */ | ||||
|     "federationDisabled": string; | ||||
|     "_accountSettings": { | ||||
|         /** | ||||
|          * コンテンツの表示にログインを必須にする | ||||
|          */ | ||||
|         "requireSigninToViewContents": string; | ||||
|         /** | ||||
|          * あなたが作成した全てのノートなどのコンテンツを表示するのにログインを必須にします。クローラーに情報が収集されるのを防ぐ効果が期待できます。 | ||||
|          */ | ||||
|         "requireSigninToViewContentsDescription1": string; | ||||
|         /** | ||||
|          * URLプレビュー(OGP)、Webページへの埋め込み、ノートの引用に対応していないサーバーからの表示も不可になります。 | ||||
|          */ | ||||
|         "requireSigninToViewContentsDescription2": string; | ||||
|         /** | ||||
|          * リモートサーバーに連合されたコンテンツでは、これらの制限が適用されない場合があります。 | ||||
|          */ | ||||
|         "requireSigninToViewContentsDescription3": string; | ||||
|         /** | ||||
|          * 過去のノートをフォロワーのみ表示可能にする | ||||
|          */ | ||||
|         "makeNotesFollowersOnlyBefore": string; | ||||
|         /** | ||||
|          * この機能が有効になっている間、設定された日時より過去、または設定された時間を経過しているノートがフォロワーのみ表示可能になります。無効に戻すと、ノートの公開状態も元に戻ります。 | ||||
|          */ | ||||
|         "makeNotesFollowersOnlyBeforeDescription": string; | ||||
|         /** | ||||
|          * 過去のノートを非公開化する | ||||
|          */ | ||||
|         "makeNotesHiddenBefore": string; | ||||
|         /** | ||||
|          * この機能が有効になっている間、設定された日時より過去、または設定された時間を経過しているノートが自分のみ表示可能(非公開化)になります。無効に戻すと、ノートの公開状態も元に戻ります。 | ||||
|          */ | ||||
|         "makeNotesHiddenBeforeDescription": string; | ||||
|         /** | ||||
|          * リモートサーバーに連合されたノートには効果が及ばない場合があります。 | ||||
|          */ | ||||
|         "mayNotEffectForFederatedNotes": string; | ||||
|         /** | ||||
|          * 指定した時間を経過しているノート | ||||
|          */ | ||||
|         "notesHavePassedSpecifiedPeriod": string; | ||||
|         /** | ||||
|          * 指定した日時より前のノート | ||||
|          */ | ||||
|         "notesOlderThanSpecifiedDateAndTime": string; | ||||
|     }; | ||||
|     "_abuseUserReport": { | ||||
|         /** | ||||
|          * 転送 | ||||
|          */ | ||||
|         "forward": string; | ||||
|         /** | ||||
|          * 匿名のシステムアカウントとして、リモートサーバーに通報を転送します。 | ||||
|          */ | ||||
|         "forwardDescription": string; | ||||
|         /** | ||||
|          * 解決 | ||||
|          */ | ||||
|         "resolve": string; | ||||
|         /** | ||||
|          * 是認 | ||||
|          */ | ||||
|         "accept": string; | ||||
|         /** | ||||
|          * 否認 | ||||
|          */ | ||||
|         "reject": string; | ||||
|         /** | ||||
|          * 内容が正当である通報に対応した場合は「是認」を選択し、肯定的にケースが解決されたことをマークします。 | ||||
|          * 内容が正当でない通報の場合は「否認」を選択し、否定的にケースが解決されたことをマークします。 | ||||
|          */ | ||||
|         "resolveTutorial": string; | ||||
|     }; | ||||
|     "_delivery": { | ||||
|         /** | ||||
|          * 配信状態 | ||||
| @@ -5651,6 +5830,18 @@ export interface Locale extends ILocale { | ||||
|          * サーバー運営者へのお問い合わせフォームのURLや、運営者の連絡先等が記載されたWebページのURLを指定します。 | ||||
|          */ | ||||
|         "inquiryUrlDescription": string; | ||||
|         /** | ||||
|          * アカウントの作成をオープンにする | ||||
|          */ | ||||
|         "openRegistration": string; | ||||
|         /** | ||||
|          * 登録を開放することはリスクが伴います。サーバーを常に監視し、トラブルが発生した際にすぐに対応できる体制がある場合のみオンにすることを推奨します。 | ||||
|          */ | ||||
|         "openRegistrationWarning": string; | ||||
|         /** | ||||
|          * 一定期間モデレーターのアクティビティが検出されなかった場合、スパム防止のためこの設定は自動でオフになります。 | ||||
|          */ | ||||
|         "thisSettingWillAutomaticallyOffWhenModeratorsInactive": string; | ||||
|     }; | ||||
|     "_accountMigration": { | ||||
|         /** | ||||
| @@ -7660,10 +7851,6 @@ export interface Locale extends ILocale { | ||||
|              * 入力ボックスの縁取り | ||||
|              */ | ||||
|             "inputBorder": string; | ||||
|             /** | ||||
|              * リスト項目の背景 (ホバー) | ||||
|              */ | ||||
|             "listItemHoverBg": string; | ||||
|             /** | ||||
|              * ドライブフォルダーの背景 | ||||
|              */ | ||||
| @@ -8313,14 +8500,26 @@ export interface Locale extends ILocale { | ||||
|          * アプリケーションに戻っています | ||||
|          */ | ||||
|         "callback": string; | ||||
|         /** | ||||
|          * アクセスを許可しました | ||||
|          */ | ||||
|         "accepted": string; | ||||
|         /** | ||||
|          * アクセスを拒否しました | ||||
|          */ | ||||
|         "denied": string; | ||||
|         /** | ||||
|          * 以下のユーザーとして操作しています | ||||
|          */ | ||||
|         "scopeUser": string; | ||||
|         /** | ||||
|          * アプリケーションにアクセス許可を与えるには、ログインが必要です。 | ||||
|          */ | ||||
|         "pleaseLogin": string; | ||||
|         /** | ||||
|          * アクセスを許可すると、自動で以下のURLに遷移します | ||||
|          */ | ||||
|         "byClickingYouWillBeRedirectedToThisUrl": string; | ||||
|     }; | ||||
|     "_antennaSources": { | ||||
|         /** | ||||
| @@ -9202,7 +9401,7 @@ export interface Locale extends ILocale { | ||||
|          */ | ||||
|         "youGotQuote": ParameterizedString<"name">; | ||||
|         /** | ||||
|          * {name}がRenoteしました | ||||
|          * {name}がリノートしました | ||||
|          */ | ||||
|         "youRenoted": ParameterizedString<"name">; | ||||
|         /** | ||||
| @@ -9281,6 +9480,10 @@ export interface Locale extends ILocale { | ||||
|          * {x}のエクスポートが完了しました | ||||
|          */ | ||||
|         "exportOfXCompleted": ParameterizedString<"x">; | ||||
|         /** | ||||
|          * ログインがありました | ||||
|          */ | ||||
|         "login": string; | ||||
|         "_types": { | ||||
|             /** | ||||
|              * すべて | ||||
| @@ -9303,7 +9506,7 @@ export interface Locale extends ILocale { | ||||
|              */ | ||||
|             "reply": string; | ||||
|             /** | ||||
|              * Renote | ||||
|              * リノート | ||||
|              */ | ||||
|             "renote": string; | ||||
|             /** | ||||
| @@ -9338,6 +9541,10 @@ export interface Locale extends ILocale { | ||||
|              * エクスポートが完了した | ||||
|              */ | ||||
|             "exportCompleted": string; | ||||
|             /** | ||||
|              * ログイン | ||||
|              */ | ||||
|             "login": string; | ||||
|             /** | ||||
|              * 通知のテスト | ||||
|              */ | ||||
| @@ -9357,7 +9564,7 @@ export interface Locale extends ILocale { | ||||
|              */ | ||||
|             "reply": string; | ||||
|             /** | ||||
|              * Renote | ||||
|              * リノート | ||||
|              */ | ||||
|             "renote": string; | ||||
|         }; | ||||
| @@ -9584,6 +9791,14 @@ export interface Locale extends ILocale { | ||||
|              * ユーザーが作成されたとき | ||||
|              */ | ||||
|             "userCreated": string; | ||||
|             /** | ||||
|              * モデレーターが一定期間非アクティブになったとき | ||||
|              */ | ||||
|             "inactiveModeratorsWarning": string; | ||||
|             /** | ||||
|              * モデレーターが一定期間非アクティブだったため、システムにより招待制へと変更されたとき | ||||
|              */ | ||||
|             "inactiveModeratorsInvitationOnlyChanged": string; | ||||
|         }; | ||||
|         /** | ||||
|          * Webhookを削除しますか? | ||||
| @@ -9755,6 +9970,14 @@ export interface Locale extends ILocale { | ||||
|          * 通報を解決 | ||||
|          */ | ||||
|         "resolveAbuseReport": string; | ||||
|         /** | ||||
|          * 通報を転送 | ||||
|          */ | ||||
|         "forwardAbuseReport": string; | ||||
|         /** | ||||
|          * 通報のモデレーションノート更新 | ||||
|          */ | ||||
|         "updateAbuseReportNote": string; | ||||
|         /** | ||||
|          * 招待コードを作成 | ||||
|          */ | ||||
| @@ -10324,6 +10547,227 @@ export interface Locale extends ILocale { | ||||
|          */ | ||||
|         "native": string; | ||||
|     }; | ||||
|     "_gridComponent": { | ||||
|         "_error": { | ||||
|             /** | ||||
|              * この値は必須項目です | ||||
|              */ | ||||
|             "requiredValue": string; | ||||
|             /** | ||||
|              * 正規表現によるバリデーションはtype:textのカラムのみサポートします。 | ||||
|              */ | ||||
|             "columnTypeNotSupport": string; | ||||
|             /** | ||||
|              * この値は{pattern}のパターンに一致しません | ||||
|              */ | ||||
|             "patternNotMatch": ParameterizedString<"pattern">; | ||||
|             /** | ||||
|              * この値は一意である必要があります | ||||
|              */ | ||||
|             "notUnique": string; | ||||
|         }; | ||||
|     }; | ||||
|     "_roleSelectDialog": { | ||||
|         /** | ||||
|          * 選択されていません | ||||
|          */ | ||||
|         "notSelected": string; | ||||
|     }; | ||||
|     "_customEmojisManager": { | ||||
|         "_gridCommon": { | ||||
|             /** | ||||
|              * 選択行をコピー | ||||
|              */ | ||||
|             "copySelectionRows": string; | ||||
|             /** | ||||
|              * 選択範囲をコピー | ||||
|              */ | ||||
|             "copySelectionRanges": string; | ||||
|             /** | ||||
|              * 選択行を削除 | ||||
|              */ | ||||
|             "deleteSelectionRows": string; | ||||
|             /** | ||||
|              * 選択範囲の値をクリア | ||||
|              */ | ||||
|             "deleteSelectionRanges": string; | ||||
|             /** | ||||
|              * 検索設定 | ||||
|              */ | ||||
|             "searchSettings": string; | ||||
|             /** | ||||
|              * 検索条件を詳細に設定します。 | ||||
|              */ | ||||
|             "searchSettingCaption": string; | ||||
|             /** | ||||
|              * 表示件数 | ||||
|              */ | ||||
|             "searchLimit": string; | ||||
|             /** | ||||
|              * 並び順 | ||||
|              */ | ||||
|             "sortOrder": string; | ||||
|             /** | ||||
|              * 登録ログ | ||||
|              */ | ||||
|             "registrationLogs": string; | ||||
|             /** | ||||
|              * 絵文字更新・削除時のログが表示されます。更新・削除操作を行ったり、ページを遷移・リロードすると消えます。 | ||||
|              */ | ||||
|             "registrationLogsCaption": string; | ||||
|             /** | ||||
|              * 絵文字の更新・削除に失敗しました。詳細は登録ログをご確認ください。 | ||||
|              */ | ||||
|             "alertEmojisRegisterFailedDescription": string; | ||||
|         }; | ||||
|         "_logs": { | ||||
|             /** | ||||
|              * 成功ログを表示 | ||||
|              */ | ||||
|             "showSuccessLogSwitch": string; | ||||
|             /** | ||||
|              * 失敗ログはありません。 | ||||
|              */ | ||||
|             "failureLogNothing": string; | ||||
|             /** | ||||
|              * ログはありません。 | ||||
|              */ | ||||
|             "logNothing": string; | ||||
|         }; | ||||
|         "_remote": { | ||||
|             /** | ||||
|              * 選択行の詳細 | ||||
|              */ | ||||
|             "selectionRowDetail": string; | ||||
|             /** | ||||
|              * 選択行をインポート | ||||
|              */ | ||||
|             "importSelectionRows": string; | ||||
|             /** | ||||
|              * 選択範囲の行をインポート | ||||
|              */ | ||||
|             "importSelectionRangesRows": string; | ||||
|             /** | ||||
|              * チェックされた絵文字をインポート | ||||
|              */ | ||||
|             "importEmojisButton": string; | ||||
|             /** | ||||
|              * 絵文字のインポート | ||||
|              */ | ||||
|             "confirmImportEmojisTitle": string; | ||||
|             /** | ||||
|              * リモートから受信した{count}個の絵文字のインポートを行います。絵文字のライセンスに十分な注意を払ってください。実行しますか? | ||||
|              */ | ||||
|             "confirmImportEmojisDescription": ParameterizedString<"count">; | ||||
|         }; | ||||
|         "_local": { | ||||
|             /** | ||||
|              * 登録済み絵文字一覧 | ||||
|              */ | ||||
|             "tabTitleList": string; | ||||
|             /** | ||||
|              * 絵文字の登録 | ||||
|              */ | ||||
|             "tabTitleRegister": string; | ||||
|             "_list": { | ||||
|                 /** | ||||
|                  * 登録された絵文字はありません。 | ||||
|                  */ | ||||
|                 "emojisNothing": string; | ||||
|                 /** | ||||
|                  * 選択行を削除対象にする | ||||
|                  */ | ||||
|                 "markAsDeleteTargetRows": string; | ||||
|                 /** | ||||
|                  * 選択範囲の行を削除対象にする | ||||
|                  */ | ||||
|                 "markAsDeleteTargetRanges": string; | ||||
|                 /** | ||||
|                  * 変更された絵文字はありません。 | ||||
|                  */ | ||||
|                 "alertUpdateEmojisNothingDescription": string; | ||||
|                 /** | ||||
|                  * 削除対象の絵文字はありません。 | ||||
|                  */ | ||||
|                 "alertDeleteEmojisNothingDescription": string; | ||||
|                 /** | ||||
|                  * ページを移動しますか? | ||||
|                  */ | ||||
|                 "confirmMovePage": string; | ||||
|                 /** | ||||
|                  * 表示を変更しますか? | ||||
|                  */ | ||||
|                 "confirmChangeView": string; | ||||
|                 /** | ||||
|                  * {count}個の絵文字を更新します。実行しますか? | ||||
|                  */ | ||||
|                 "confirmUpdateEmojisDescription": ParameterizedString<"count">; | ||||
|                 /** | ||||
|                  * チェックがつけられた{count}個の絵文字を削除します。実行しますか? | ||||
|                  */ | ||||
|                 "confirmDeleteEmojisDescription": ParameterizedString<"count">; | ||||
|                 /** | ||||
|                  * 今までに加えた変更がすべてリセットされます。 | ||||
|                  */ | ||||
|                 "confirmResetDescription": string; | ||||
|                 /** | ||||
|                  * このページの絵文字に変更が加えられています。 | ||||
|                  * 保存せずにこのままページを移動すると、このページで加えた変更はすべて破棄されます。 | ||||
|                  */ | ||||
|                 "confirmMovePageDesciption": string; | ||||
|                 /** | ||||
|                  * 絵文字に設定されたロールで検索 | ||||
|                  */ | ||||
|                 "dialogSelectRoleTitle": string; | ||||
|             }; | ||||
|             "_register": { | ||||
|                 /** | ||||
|                  * アップロード設定 | ||||
|                  */ | ||||
|                 "uploadSettingTitle": string; | ||||
|                 /** | ||||
|                  * この画面で絵文字アップロードを行う際の動作を設定できます。 | ||||
|                  */ | ||||
|                 "uploadSettingDescription": string; | ||||
|                 /** | ||||
|                  * ディレクトリ名を"category"に入力する | ||||
|                  */ | ||||
|                 "directoryToCategoryLabel": string; | ||||
|                 /** | ||||
|                  * ディレクトリをドラッグ・ドロップした時に、ディレクトリ名を"category"に入力します。 | ||||
|                  */ | ||||
|                 "directoryToCategoryCaption": string; | ||||
|                 /** | ||||
|                  * いずれかの方法で登録する絵文字を選択してください。 | ||||
|                  */ | ||||
|                 "emojiInputAreaCaption": string; | ||||
|                 /** | ||||
|                  * この枠に画像ファイルまたはディレクトリをドラッグ&ドロップ | ||||
|                  */ | ||||
|                 "emojiInputAreaList1": string; | ||||
|                 /** | ||||
|                  * このリンクをクリックしてPCから選択する | ||||
|                  */ | ||||
|                 "emojiInputAreaList2": string; | ||||
|                 /** | ||||
|                  * このリンクをクリックしてドライブから選択する | ||||
|                  */ | ||||
|                 "emojiInputAreaList3": string; | ||||
|                 /** | ||||
|                  * リストに表示されている絵文字を新たなカスタム絵文字として登録します。よろしいですか?(負荷を避けるため、一度の操作で登録可能な絵文字は{count}件までです) | ||||
|                  */ | ||||
|                 "confirmRegisterEmojisDescription": ParameterizedString<"count">; | ||||
|                 /** | ||||
|                  * 編集内容を破棄し、リストに表示されている絵文字をクリアします。よろしいですか? | ||||
|                  */ | ||||
|                 "confirmClearEmojisDescription": string; | ||||
|                 /** | ||||
|                  * ドラッグ&ドロップされた{count}個のファイルをドライブにアップロードします。実行しますか? | ||||
|                  */ | ||||
|                 "confirmUploadEmojisDescription": ParameterizedString<"count">; | ||||
|             }; | ||||
|         }; | ||||
|     }; | ||||
|     "_embedCodeGen": { | ||||
|         /** | ||||
|          * 埋め込みコードをカスタマイズ | ||||
| @@ -10378,6 +10822,140 @@ export interface Locale extends ILocale { | ||||
|          */ | ||||
|         "codeGeneratedDescription": string; | ||||
|     }; | ||||
|     "_selfXssPrevention": { | ||||
|         /** | ||||
|          * 警告 | ||||
|          */ | ||||
|         "warning": string; | ||||
|         /** | ||||
|          * 「この画面に何か貼り付けろ」はすべて詐欺です。 | ||||
|          */ | ||||
|         "title": string; | ||||
|         /** | ||||
|          * ここに何かを貼り付けると、悪意のあるユーザーにアカウントを乗っ取られたり、個人情報を盗まれたりする可能性があります。 | ||||
|          */ | ||||
|         "description1": string; | ||||
|         /** | ||||
|          * 貼り付けようとしているものが何なのかを正確に理解していない場合は、%c今すぐ作業を中止してこのウィンドウを閉じてください。 | ||||
|          */ | ||||
|         "description2": string; | ||||
|         /** | ||||
|          * 詳しくはこちらをご確認ください。 {link} | ||||
|          */ | ||||
|         "description3": ParameterizedString<"link">; | ||||
|     }; | ||||
|     "_followRequest": { | ||||
|         /** | ||||
|          * 受け取った申請 | ||||
|          */ | ||||
|         "recieved": string; | ||||
|         /** | ||||
|          * 送った申請 | ||||
|          */ | ||||
|         "sent": string; | ||||
|     }; | ||||
|     "_remoteLookupErrors": { | ||||
|         "_federationNotAllowed": { | ||||
|             /** | ||||
|              * このサーバーとは通信できません | ||||
|              */ | ||||
|             "title": string; | ||||
|             /** | ||||
|              * このサーバーとの通信が無効化されているか、このサーバーをブロックしている・ブロックされている可能性があります。 | ||||
|              * サーバー管理者にお問い合わせください。 | ||||
|              */ | ||||
|             "description": string; | ||||
|         }; | ||||
|         "_uriInvalid": { | ||||
|             /** | ||||
|              * URIが不正です | ||||
|              */ | ||||
|             "title": string; | ||||
|             /** | ||||
|              * 入力されたURIに問題があります。URIに使用できない文字を入力していないか確認してください。 | ||||
|              */ | ||||
|             "description": string; | ||||
|         }; | ||||
|         "_requestFailed": { | ||||
|             /** | ||||
|              * リクエストに失敗しました | ||||
|              */ | ||||
|             "title": string; | ||||
|             /** | ||||
|              * このサーバーとの通信に失敗しました。相手サーバーがダウンしている可能性があります。また、不正なURIや存在しないURIを入力していないか確認してください。 | ||||
|              */ | ||||
|             "description": string; | ||||
|         }; | ||||
|         "_responseInvalid": { | ||||
|             /** | ||||
|              * レスポンスが不正です | ||||
|              */ | ||||
|             "title": string; | ||||
|             /** | ||||
|              * このサーバーと通信することはできましたが、得られたデータが不正なものでした。 | ||||
|              */ | ||||
|             "description": string; | ||||
|         }; | ||||
|         "_responseInvalidIdHostNotMatch": { | ||||
|             /** | ||||
|              * 入力されたURIのドメインと最終的に得られたURIのドメインとが異なります。第三者のサーバーを介してリモートのコンテンツを照会している場合は、発信元のサーバーで取得できるURIを使用して照会し直してください。 | ||||
|              */ | ||||
|             "description": string; | ||||
|         }; | ||||
|         "_noSuchObject": { | ||||
|             /** | ||||
|              * 見つかりません | ||||
|              */ | ||||
|             "title": string; | ||||
|             /** | ||||
|              * 要求されたリソースは見つかりませんでした。URIをもう一度お確かめください。 | ||||
|              */ | ||||
|             "description": string; | ||||
|         }; | ||||
|     }; | ||||
|     "_captcha": { | ||||
|         /** | ||||
|          * CAPTCHAを通過してください | ||||
|          */ | ||||
|         "verify": string; | ||||
|         /** | ||||
|          * サイトキーとシークレットキーにテスト用の値を入力することでプレビューを確認できます。 | ||||
|          * 詳細は下記ページをご確認ください。 | ||||
|          */ | ||||
|         "testSiteKeyMessage": string; | ||||
|         "_error": { | ||||
|             "_requestFailed": { | ||||
|                 /** | ||||
|                  * CAPTCHAのリクエストに失敗しました | ||||
|                  */ | ||||
|                 "title": string; | ||||
|                 /** | ||||
|                  * しばらく後に実行するか、設定をもう一度ご確認ください。 | ||||
|                  */ | ||||
|                 "text": string; | ||||
|             }; | ||||
|             "_verificationFailed": { | ||||
|                 /** | ||||
|                  * CAPTCHAの検証に失敗しました | ||||
|                  */ | ||||
|                 "title": string; | ||||
|                 /** | ||||
|                  * 設定が正しいかどうかもう一度確認ください。 | ||||
|                  */ | ||||
|                 "text": string; | ||||
|             }; | ||||
|             "_unknown": { | ||||
|                 /** | ||||
|                  * CAPTCHAエラー | ||||
|                  */ | ||||
|                 "title": string; | ||||
|                 /** | ||||
|                  * 想定外のエラーが発生しました。 | ||||
|                  */ | ||||
|                 "text": string; | ||||
|             }; | ||||
|         }; | ||||
|     }; | ||||
| } | ||||
| declare const locales: { | ||||
|     [lang: string]: Locale; | ||||
|   | ||||
| @@ -15,6 +15,7 @@ const merge = (...args) => args.reduce((a, c) => ({ | ||||
|  | ||||
| const languages = [ | ||||
| 	'ar-SA', | ||||
| 	'ca-ES', | ||||
| 	'cs-CZ', | ||||
| 	'da-DK', | ||||
| 	'de-DE', | ||||
|   | ||||
| @@ -5,9 +5,13 @@ introMisskey: "Eccoci! Misskey è un servizio di microblogging decentralizzato, | ||||
| poweredByMisskeyDescription: "{name} è uno dei servizi (chiamati istanze) che utilizzano la piattaforma open source <b>Misskey</b>." | ||||
| monthAndDay: "{day}/{month}" | ||||
| search: "Cerca" | ||||
| reset: "Ripristinare" | ||||
| notifications: "Notifiche" | ||||
| username: "Nome utente" | ||||
| password: "Password" | ||||
| initialPasswordForSetup: "Password iniziale, per avviare le impostazioni" | ||||
| initialPasswordIsIncorrect: "Password iniziale, sbagliata." | ||||
| initialPasswordForSetupDescription: "Se hai installato Misskey di persona, usa la password che hai indicato nel file di configurazione.\nSe stai utilizzando un servizio di hosting Misskey, usa la password fornita dal gestore.\nSe non hai una password preimpostata, lascia il campo vuoto e continua." | ||||
| forgotPassword: "Hai dimenticato la password?" | ||||
| fetchingAsApObject: "Recuperando dal Fediverso..." | ||||
| ok: "OK" | ||||
| @@ -45,6 +49,7 @@ pin: "Fissa sul profilo" | ||||
| unpin: "Non fissare sul profilo" | ||||
| copyContent: "Copia il contenuto" | ||||
| copyLink: "Copia il link" | ||||
| copyRemoteLink: "Copia link remoto" | ||||
| copyLinkRenote: "Copia collegamento alla Rinota" | ||||
| delete: "Elimina" | ||||
| deleteAndEdit: "Elimina e modifica" | ||||
| @@ -53,7 +58,7 @@ addToList: "Aggiungi alla lista" | ||||
| addToAntenna: "Aggiungi all'antenna" | ||||
| sendMessage: "Invia messaggio" | ||||
| copyRSS: "Copia RSS" | ||||
| copyUsername: "Copia nome utente" | ||||
| copyUsername: "Copia indirizzo del profilo" | ||||
| copyUserId: "Copia ID del profilo" | ||||
| copyNoteId: "Copia ID della Nota" | ||||
| copyFileId: "Copia ID del file" | ||||
| @@ -65,7 +70,7 @@ reply: "Rispondi" | ||||
| loadMore: "Mostra di più" | ||||
| showMore: "Espandi" | ||||
| showLess: "Comprimi" | ||||
| youGotNewFollower: "Adesso ti segue" | ||||
| youGotNewFollower: "Hai un nuovo Follower" | ||||
| receiveFollowRequest: "Hai ricevuto una richiesta di follow" | ||||
| followRequestAccepted: "Ha accettato la tua richiesta di follow" | ||||
| mention: "Menzioni" | ||||
| @@ -77,14 +82,14 @@ export: "Esporta" | ||||
| files: "Allegati" | ||||
| download: "Scarica" | ||||
| driveFileDeleteConfirm: "Vuoi davvero eliminare il file \"{name}\", e le Note a cui è stato allegato?" | ||||
| unfollowConfirm: "Vuoi davvero smettere di seguire {name}?" | ||||
| unfollowConfirm: "Vuoi davvero togliere il Following a {name}?" | ||||
| exportRequested: "Hai richiesto un'esportazione, e potrebbe volerci tempo. Quando sarà compiuta, il file verrà aggiunto direttamente al Drive." | ||||
| importRequested: "Hai richiesto un'importazione. Potrebbe richiedere un po' di tempo." | ||||
| lists: "Liste" | ||||
| noLists: "Nessuna lista" | ||||
| note: "Nota" | ||||
| notes: "Note" | ||||
| following: "Follow" | ||||
| following: "Following" | ||||
| followers: "Follower" | ||||
| followsYou: "Follower" | ||||
| createList: "Aggiungi una nuova lista" | ||||
| @@ -103,7 +108,7 @@ defaultNoteVisibility: "Privacy predefinita delle note" | ||||
| follow: "Segui" | ||||
| followRequest: "Richiesta di follow" | ||||
| followRequests: "Richieste di follow" | ||||
| unfollow: "Smetti di seguire" | ||||
| unfollow: "Togli Following" | ||||
| followRequestPending: "Richiesta in approvazione" | ||||
| enterEmoji: "Inserisci emoji" | ||||
| renote: "Rinota" | ||||
| @@ -192,7 +197,7 @@ setWallpaper: "Imposta sfondo" | ||||
| removeWallpaper: "Elimina lo sfondo" | ||||
| searchWith: "Cerca: {q}" | ||||
| youHaveNoLists: "Non hai ancora creato nessuna lista" | ||||
| followConfirm: "Vuoi seguire {name}?" | ||||
| followConfirm: "Confermi il Following a {name}?" | ||||
| proxyAccount: "Profilo proxy" | ||||
| proxyAccountDescription: "Un profilo proxy funziona come follower per i profili remoti, sotto certe condizioni. Ad esempio, quando un profilo locale ne inserisce uno remoto in una lista (senza seguirlo), se nessun altro segue quel profilo remoto, le attività non possono essere distribuite. Dunque, il profilo proxy le seguirà per tutti." | ||||
| host: "Host" | ||||
| @@ -236,6 +241,8 @@ silencedInstances: "Istanze silenziate" | ||||
| silencedInstancesDescription: "Elenca i nomi host delle istanze che vuoi silenziare. Tutti i profili nelle istanze silenziate vengono trattati come tali. Possono solo inviare richieste di follow e menzionare soltanto i profili locali che seguono. Le istanze bloccate non sono interessate." | ||||
| mediaSilencedInstances: "Istanze coi media silenziati" | ||||
| mediaSilencedInstancesDescription: "Elenca i nomi host delle istanze di cui vuoi silenziare i media, uno per riga. Tutti gli allegati dei profili nelle istanze silenziate per via degli allegati espliciti, verranno impostati come tali, le emoji personalizzate non saranno disponibili. Le istanze bloccate sono escluse." | ||||
| federationAllowedHosts: "Server a cui consentire la federazione" | ||||
| federationAllowedHostsDescription: "Indica gli host dei server a cui è consentita la federazione, uno per ogni linea." | ||||
| muteAndBlock: "Silenziare e bloccare" | ||||
| mutedUsers: "Profili silenziati" | ||||
| blockedUsers: "Profili bloccati" | ||||
| @@ -258,7 +265,7 @@ all: "Tutte" | ||||
| subscribing: "Iscrizione" | ||||
| publishing: "Pubblicazione" | ||||
| notResponding: "Nessuna risposta" | ||||
| instanceFollowing: "Seguiti dall'istanza" | ||||
| instanceFollowing: "Istanza Following" | ||||
| instanceFollowers: "Follower dell'istanza" | ||||
| instanceUsers: "Profili nell'istanza" | ||||
| changePassword: "Aggiorna Password" | ||||
| @@ -377,7 +384,6 @@ enableLocalTimeline: "Abilita la timeline locale" | ||||
| enableGlobalTimeline: "Abilita la timeline federata" | ||||
| disablingTimelinesInfo: "Anche disabilitandole, gli Amministratori e i Moderatori potranno comunque accedervi." | ||||
| registration: "Iscriviti" | ||||
| enableRegistration: "Consenti a chiunque di registrarsi" | ||||
| invite: "Invita" | ||||
| driveCapacityPerLocalAccount: "Capienza del Drive per profilo locale" | ||||
| driveCapacityPerRemoteAccount: "Capienza del Drive per profilo remoto" | ||||
| @@ -436,7 +442,7 @@ recentlyRegisteredUsers: "Profili iscritti di recente" | ||||
| recentlyDiscoveredUsers: "Profili scoperti di recente" | ||||
| exploreUsersCount: "Ci sono {count} profili" | ||||
| exploreFediverse: "Esplora il Fediverso" | ||||
| popularTags: "Tag di tendenza" | ||||
| popularTags: "Hashtag popolari" | ||||
| userList: "Liste" | ||||
| about: "Informazioni" | ||||
| aboutMisskey: "Informazioni di Misskey" | ||||
| @@ -449,6 +455,7 @@ totpDescription: "Puoi autenticarti inserendo un codice OTP tramite la tua App d | ||||
| moderator: "Moderatore" | ||||
| moderation: "moderazione" | ||||
| moderationNote: "Promemoria di moderazione" | ||||
| moderationNoteDescription: "Puoi scrivere promemoria condivisi solo tra moderatori." | ||||
| addModerationNote: "Aggiungi promemoria di moderazione" | ||||
| moderationLogs: "Cronologia di moderazione" | ||||
| nUsersMentioned: "{n} profili ne parlano" | ||||
| @@ -546,8 +553,8 @@ promote: "Pubblicizza" | ||||
| numberOfDays: "Numero di giorni" | ||||
| hideThisNote: "Nasconda la nota" | ||||
| showFeaturedNotesInTimeline: "Mostrare le note di tendenza nella tua timeline" | ||||
| objectStorage: "Stoccaggio oggetti" | ||||
| useObjectStorage: "Utilizza stoccaggio oggetti" | ||||
| objectStorage: "Storage S3" | ||||
| useObjectStorage: "Utilizza lo storage S3 in cloud" | ||||
| objectStorageBaseUrl: "Base URL" | ||||
| objectStorageBaseUrlDesc: "URL di riferimento. In caso di utilizzo di proxy o CDN l'URL è 'https://<bucket>.s3.amazonaws.com' per S3, 'https://storage.googleapis.com/<bucket>' per GCS eccetera. " | ||||
| objectStorageBucket: "Bucket" | ||||
| @@ -581,6 +588,7 @@ masterVolume: "Volume principale" | ||||
| notUseSound: "Non emettere suoni" | ||||
| useSoundOnlyWhenActive: "Emetti suoni solo quando Misskey è in attività" | ||||
| details: "Dettagli" | ||||
| renoteDetails: "Dettagli della Rinota" | ||||
| chooseEmoji: "Scegli emoji" | ||||
| unableToProcess: "Impossibile compiere l'operazione" | ||||
| recentUsed: "Usato di recente" | ||||
| @@ -609,7 +617,7 @@ unsetUserBannerConfirm: "Vuoi davvero rimuovere l'intestazione dal profilo?" | ||||
| deleteAllFiles: "Elimina tutti i file" | ||||
| deleteAllFilesConfirm: "Vuoi davvero eliminare tutti i file?" | ||||
| removeAllFollowing: "Annulla tutti i follow" | ||||
| removeAllFollowingDescription: "Cancella tutti i follows del server {host}. Per favore, esegui se, ad esempio, l'istanza non esiste più." | ||||
| removeAllFollowingDescription: "Togli il Following a tutti i profili su {host}. Utile, ad esempio, quando l'istanza non esiste più." | ||||
| userSuspended: "L'utente è in sospensione" | ||||
| userSilenced: "Profilo silenziato" | ||||
| yourAccountSuspendedTitle: "Questo profilo è sospeso" | ||||
| @@ -678,11 +686,15 @@ smtpSecure: "Usare SSL/TLS implicito per le connessioni SMTP" | ||||
| smtpSecureInfo: "Disabilitare quando è attivo STARTTLS." | ||||
| testEmail: "Verifica il funzionamento" | ||||
| wordMute: "Filtri parole" | ||||
| wordMuteDescription: "Contrae le Note con la parola o la frase specificata. Permette di espandere le Note, cliccandole." | ||||
| hardWordMute: "Filtro parole forte" | ||||
| showMutedWord: "Elenca le parole silenziate" | ||||
| hardWordMuteDescription: "Nasconde le Note con la parola o la frase specificata. A differenza delle parole silenziate, la Nota non verrà federata." | ||||
| regexpError: "errore regex" | ||||
| regexpErrorDescription: "Si è verificato un errore nell'espressione regolare alla riga {line} della parola muta {tab}:" | ||||
| instanceMute: "Silenziare l'istanza" | ||||
| userSaysSomething: "{name} ha parlato" | ||||
| userSaysSomething: "{name} ha detto qualcosa" | ||||
| userSaysSomethingAbout: "{name} ha Notato a riguardo di \"{word}\"" | ||||
| makeActive: "Attiva" | ||||
| display: "Visualizza" | ||||
| copy: "Copia" | ||||
| @@ -694,10 +706,10 @@ database: "Base dati" | ||||
| channel: "Canale" | ||||
| create: "Crea" | ||||
| notificationSetting: "Impostazioni notifiche" | ||||
| notificationSettingDesc: "Seleziona il tipo di notifiche da visualizzare." | ||||
| notificationSettingDesc: "Scegli quali notifiche mostrare." | ||||
| useGlobalSetting: "Usa impostazioni generali" | ||||
| useGlobalSettingDesc: "Quando attiva, verranno utilizzate le impostazioni notifiche del profilo. Altrimenti si possono segliere impostazioni personalizzate." | ||||
| other: "Ulteriori" | ||||
| other: "Eccetera" | ||||
| regenerateLoginToken: "Genera di nuovo un token di connessione" | ||||
| regenerateLoginTokenDescription: "Genera un nuovo token di autenticazione. Solitamente questa operazione non è necessaria: quando si genera un nuovo token, tutti i dispositivi vanno disconnessi." | ||||
| theKeywordWhenSearchingForCustomEmoji: "Questa sarà la parola chiave durante la ricerca di emoji personalizzate" | ||||
| @@ -714,10 +726,7 @@ abuseReported: "La segnalazione è stata inviata. Grazie." | ||||
| reporter: "il corrispondente" | ||||
| reporteeOrigin: "Segnalazione a" | ||||
| reporterOrigin: "Segnalazione da" | ||||
| forwardReport: "Inoltro di un report a un'istanza remota." | ||||
| forwardReportIsAnonymous: "L'istanza remota non vedrà le tue informazioni, apparirai come profilo di sistema, anonimo." | ||||
| send: "Inviare" | ||||
| abuseMarkAsResolved: "Risolvi segnalazione" | ||||
| openInNewTab: "Apri in una nuova scheda" | ||||
| openInSideView: "Apri in vista laterale" | ||||
| defaultNavigationBehaviour: "Navigazione preimpostata" | ||||
| @@ -744,7 +753,7 @@ repliesCount: "Numero di risposte inviate" | ||||
| renotesCount: "Numero di note che hai ricondiviso" | ||||
| repliedCount: "Numero di risposte ricevute" | ||||
| renotedCount: "Numero delle tue note ricondivise" | ||||
| followingCount: "Numero di profili seguiti" | ||||
| followingCount: "Numero di Following" | ||||
| followersCount: "Numero di profili che ti seguono" | ||||
| sentReactionsCount: "Numero di reazioni inviate" | ||||
| receivedReactionsCount: "Numero di reazioni ricevute" | ||||
| @@ -839,7 +848,7 @@ onlineStatus: "Stato di connessione" | ||||
| hideOnlineStatus: "Modalità invisibile" | ||||
| hideOnlineStatusDescription: "Attivando questa opzione potresti ridurre l'usabilità di alcune funzioni, come la ricerca." | ||||
| online: "Online" | ||||
| active: "Attività" | ||||
| active: "Attivo" | ||||
| offline: "Offline" | ||||
| notRecommended: "Sconsigliato" | ||||
| botProtection: "Protezione contro i bot" | ||||
| @@ -898,13 +907,13 @@ pubSub: "Publish/Subscribe del profilo" | ||||
| lastCommunication: "La comunicazione più recente" | ||||
| resolved: "Risolto" | ||||
| unresolved: "Non risolto" | ||||
| breakFollow: "Impedire di seguirmi" | ||||
| breakFollowConfirm: "Vuoi davvero che questo profilo smetta di seguirti?" | ||||
| breakFollow: "Rimuovi Follower" | ||||
| breakFollowConfirm: "Vuoi davvero togliere questo Follower?" | ||||
| itsOn: "Abilitato" | ||||
| itsOff: "Disabilitato" | ||||
| on: "Acceso" | ||||
| off: "Spento" | ||||
| emailRequiredForSignup: "L'ndirizzo e-mail è obbligatorio per registrarsi" | ||||
| emailRequiredForSignup: "L'indirizzo e-mail è obbligatorio per registrarsi" | ||||
| unread: "Non lette" | ||||
| filter: "Filtri" | ||||
| controlPanel: "Pannello di controllo" | ||||
| @@ -914,11 +923,12 @@ makeReactionsPublicDescription: "La lista delle reazioni che avete fatto è a di | ||||
| classic: "Classico" | ||||
| muteThread: "Silenziare conversazione" | ||||
| unmuteThread: "Riattiva la conversazione" | ||||
| followingVisibility: "Visibilità dei profili seguiti" | ||||
| followingVisibility: "Visibilità dei Following" | ||||
| followersVisibility: "Visibilità dei profili che ti seguono" | ||||
| continueThread: "Altre conversazioni" | ||||
| deleteAccountConfirm: "Così verrà eliminato il profilo. Vuoi procedere?" | ||||
| incorrectPassword: "La password è errata." | ||||
| incorrectTotp: "Il codice OTP è sbagliato, oppure scaduto." | ||||
| voteConfirm: "Votare per「{choice}」?" | ||||
| hide: "Nascondere" | ||||
| useDrawerReactionPickerForMobile: "Mostra sul drawer da dispositivo mobile" | ||||
| @@ -943,6 +953,9 @@ oneHour: "1 ora" | ||||
| oneDay: "1 giorno" | ||||
| oneWeek: "1 settimana" | ||||
| oneMonth: "Un mese" | ||||
| threeMonths: "3 mesi" | ||||
| oneYear: "1 anno" | ||||
| threeDays: "3 giorni" | ||||
| reflectMayTakeTime: "Potrebbe essere necessario un po' di tempo perché ciò abbia effetto." | ||||
| failedToFetchAccountInformation: "Impossibile recuperare le informazioni sul profilo" | ||||
| rateLimitExceeded: "Superato il limite di richieste." | ||||
| @@ -961,9 +974,9 @@ driveCapOverrideLabel: "Modificare la capienza del Drive per questo profilo" | ||||
| driveCapOverrideCaption: "Se viene specificato meno di 0, viene annullato." | ||||
| requireAdminForView: "Per visualizzarli, è necessario aver effettuato l'accesso con un profilo amministratore." | ||||
| isSystemAccount: "Questi profili vengono creati e gestiti automaticamente dal sistema" | ||||
| typeToConfirm: "Per eseguire questa operazione, digitare {x}" | ||||
| typeToConfirm: "Digita {x} per continuare" | ||||
| deleteAccount: "Eliminazione profilo" | ||||
| document: "Documento" | ||||
| document: "Documentazione" | ||||
| numberOfPageCache: "Numero di pagine cache" | ||||
| numberOfPageCacheDescription: "Aumenta l'usabilità, ma aumenta anche il carico e l'utilizzo della memoria." | ||||
| logoutConfirm: "Vuoi davvero uscire da Misskey? " | ||||
| @@ -1016,7 +1029,7 @@ neverShow: "Non mostrare più" | ||||
| remindMeLater: "Rimanda" | ||||
| didYouLikeMisskey: "Ti piace Misskey?" | ||||
| pleaseDonate: "Misskey è il software libero utilizzato su {host}. Offrendo una donazione è più facile continuare a svilupparlo!" | ||||
| correspondingSourceIsAvailable: "" | ||||
| correspondingSourceIsAvailable: "Il codice sorgente corrispondente è disponibile su {anchor}." | ||||
| roles: "Ruoli" | ||||
| role: "Ruolo" | ||||
| noRole: "Ruolo non trovato" | ||||
| @@ -1083,6 +1096,7 @@ retryAllQueuesConfirmTitle: "Vuoi ritentare adesso?" | ||||
| retryAllQueuesConfirmText: "Potrebbe sovraccaricare il server temporaneamente." | ||||
| enableChartsForRemoteUser: "Abilita i grafici per i profili remoti" | ||||
| enableChartsForFederatedInstances: "Abilita i grafici per le istanze federate" | ||||
| enableStatsForFederatedInstances: "Informazioni statistiche sui server federati" | ||||
| showClipButtonInNoteFooter: "Aggiungi il bottone Clip tra le azioni delle Note" | ||||
| reactionsDisplaySize: "Grandezza delle reazioni" | ||||
| limitWidthOfReaction: "Limita la larghezza delle reazioni e ridimensionale" | ||||
| @@ -1098,7 +1112,7 @@ accountMovedShort: "Questo profilo è stato migrato" | ||||
| operationForbidden: "Operazione non consentita" | ||||
| forceShowAds: "Mostra sempre i banner" | ||||
| addMemo: "Aggiungi Memo" | ||||
| editMemo: "Modifica Memo" | ||||
| editMemo: "Modifica il promemoria" | ||||
| reactionsList: "Chi ha reagito?" | ||||
| renotesList: "Chi ha Rinotato?" | ||||
| notificationDisplay: "Stile delle notifiche" | ||||
| @@ -1125,14 +1139,14 @@ channelArchiveConfirmDescription: "Un canale archiviato non compare nell'elenco | ||||
| thisChannelArchived: "Questo canale è stato archiviato." | ||||
| displayOfNote: "Visualizzazione delle Note" | ||||
| initialAccountSetting: "Impostazioni iniziali del profilo" | ||||
| youFollowing: "Seguiti" | ||||
| youFollowing: "Following" | ||||
| preventAiLearning: "Impedisci l'apprendimento della IA" | ||||
| preventAiLearningDescription: "Aggiungendo il campo \"noai\" alla risposta HTML, si indica ai Robot esterni di non usare testi e allegati per addestrare sistemi di Machine Learning (IA predittiva/generativa). Anche se è impossibile sapere se la richiesta venga onorata o semplicemente ignorata." | ||||
| options: "Opzioni del ruolo" | ||||
| specifyUser: "Profilo specifico" | ||||
| lookupConfirm: "Vuoi davvero richiedere informazioni?" | ||||
| openTagPageConfirm: "Vuoi davvero aprire la pagina dell'hashtag?" | ||||
| specifyHost: "Specifica l'host" | ||||
| specifyHost: "Host specifici" | ||||
| failedToPreviewUrl: "Anteprima non disponibile" | ||||
| update: "Aggiorna" | ||||
| rolesThatCanBeUsedThisEmojiAsReaction: "Ruoli che possono usare questa emoji come reazione" | ||||
| @@ -1232,7 +1246,7 @@ code: "Codice" | ||||
| reloadRequiredToApplySettings: "Per applicare le impostazioni, occorre ricaricare." | ||||
| remainingN: "Rimangono: {n}" | ||||
| overwriteContentConfirm: "Vuoi davvero sostituire l'attuale contenuto?" | ||||
| seasonalScreenEffect: "Schermate in base alla stagione" | ||||
| seasonalScreenEffect: "Abilita gli effetti speciali stagionali" | ||||
| decorate: "Decora" | ||||
| addMfmFunction: "Aggiungi decorazioni" | ||||
| enableQuickAddMfmFunction: "Attiva il selettore di funzioni MFM" | ||||
| @@ -1281,6 +1295,39 @@ signinWithPasskey: "Accedi con passkey" | ||||
| unknownWebAuthnKey: "Questa è una passkey sconosciuta." | ||||
| passkeyVerificationFailed: "La verifica della passkey non è riuscita." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "La verifica della passkey è riuscita, ma l'accesso senza password è disabilitato." | ||||
| messageToFollower: "Messaggio ai follower" | ||||
| target: "Riferimento" | ||||
| testCaptchaWarning: "Questa funzione è destinata al test CAPTCHA. <strong>Da non utilizzare in ambiente di produzione.</strong>" | ||||
| prohibitedWordsForNameOfUser: "Parole proibite (nome utente)" | ||||
| prohibitedWordsForNameOfUserDescription: "Il sistema rifiuta di rinominare un utente, se il nome contiene qualsiasi parola nell'elenco. Sono esenti i profili con privilegi di moderazione." | ||||
| yourNameContainsProhibitedWords: "Il nome che hai scelto contiene una o più parole vietate" | ||||
| yourNameContainsProhibitedWordsDescription: "Se desideri comunque utilizzare questo nome, contatta l''amministrazione." | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "L'autore richiede di iscriversi per vedere il contenuto" | ||||
| lockdown: "Isolamento" | ||||
| pleaseSelectAccount: "Per favore, seleziona un profilo" | ||||
| availableRoles: "Ruoli disponibili" | ||||
| acknowledgeNotesAndEnable: "Attivare dopo averne compreso il comportamento." | ||||
| federationSpecified: "Questo server è federato solo con istanze specifiche del Fediverso. Puoi interagire solo con quelle scelte dall'amministrazione." | ||||
| federationDisabled: "Questo server ha la federazione disabilitata. Non puoi interagire con profili provenienti da altri server." | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "Per vedere il contenuto, è necessaria l'iscrizione" | ||||
|   requireSigninToViewContentsDescription1: "Richiedere l'iscrizione per visualizzare tutte le Note e gli altri contenuti che hai creato. Probabilmente l'effetto è impedire la raccolta di informazioni da parte dei bot crawler." | ||||
|   requireSigninToViewContentsDescription2: "La visualizzazione verrà disabilitata a server che non supportano l'anteprima URL (OGP), all'incorporamento nelle pagine Web e alla citazione delle Note." | ||||
|   requireSigninToViewContentsDescription3: "Queste restrizioni potrebbero non applicarsi al contenuto federato su server remoti." | ||||
|   makeNotesFollowersOnlyBefore: "Rendi visibili solo ai Follower le Note pubblicate in precedenza" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "Mentre questa funzione è abilitata, le Note antecedenti al momento impostato, saranno visibili solo ai profili Follower. Disabilitandola nuovamente, verrà ripristinata anche la visibilità pubblica della Nota." | ||||
|   makeNotesHiddenBefore: "Nascondi le Note pubblicate in precedenza" | ||||
|   makeNotesHiddenBeforeDescription: "Mentre questa funzione è abilitata, le Note antecedenti al momento impostato, saranno visibili soltanto a te (private). Disabilitandola nuovamente, verrà ripristinata anche la visibilità pubblica della Nota." | ||||
|   mayNotEffectForFederatedNotes: "Le Note già federate su server remoti potrebbero non essere modificate." | ||||
|   notesHavePassedSpecifiedPeriod: "Note antecedenti al periodo specificato" | ||||
|   notesOlderThanSpecifiedDateAndTime: "Note antecedenti al momento specificato" | ||||
| _abuseUserReport: | ||||
|   forward: "Inoltra" | ||||
|   forwardDescription: "Inoltra il report al server remoto, per mezzo di account di sistema, anonimo." | ||||
|   resolve: "Risolvi" | ||||
|   accept: "Approva" | ||||
|   reject: "Rifiuta" | ||||
|   resolveTutorial: "Se moderi una segnalazione legittima, scegli \"Approva\" per risolvere positivamente.\nSe la segnalazione non è legittima, seleziona \"Rifiuta\" per risolvere negativamente." | ||||
| _delivery: | ||||
|   status: "Stato della consegna" | ||||
|   stop: "Sospensione" | ||||
| @@ -1308,16 +1355,16 @@ _bubbleGame: | ||||
| _announcement: | ||||
|   forExistingUsers: "Solo ai profili attuali" | ||||
|   forExistingUsersDescription: "L'annuncio sarà visibile solo ai profili esistenti in questo momento. Se disabilitato, sarà visibile anche ai profili che verranno creati dopo la pubblicazione di questo annuncio." | ||||
|   needConfirmationToRead: "Richiede la conferma di lettura" | ||||
|   needConfirmationToReadDescription: "Sarà visualizzata una finestra di dialogo che richiede la conferma di lettura. Inoltre, non è soggetto a conferme di lettura massicce." | ||||
|   needConfirmationToRead: "Conferma di lettura obbligatoria" | ||||
|   needConfirmationToReadDescription: "I profili riceveranno una finestra di dialogo che richiede di accettare obbligatoriamente per procedere. Tale richiesta è esente da  \"conferma tutte\"." | ||||
|   end: "Archivia l'annuncio" | ||||
|   tooManyActiveAnnouncementDescription: "L'esperienza delle persone può peggiorare se ci sono troppi annunci attivi. Considera anche l'archiviazione degli annunci conclusi." | ||||
|   readConfirmTitle: "Segnare come già letto?" | ||||
|   readConfirmText: "Hai già letto \"{title}˝?" | ||||
|   shouldNotBeUsedToPresentPermanentInfo: "Ti consigliamo di utilizzare gli annunci per pubblicare informazioni tempestive e limitate nel tempo, anziché informazioni importanti a lungo andare nel tempo, poiché potrebbero risultare difficili da ritrovare e peggiorare la fruibilità del servizio, specialmente alle nuove persone iscritte." | ||||
|   dialogAnnouncementUxWarn: "Ti consigliamo di usarli con cautela, poiché è molto probabile che avere più di un annuncio in stile \"finestra di dialogo\" peggiori sensibilmente la fruibilità del servizio, specialmente alle nuove persone iscritte." | ||||
|   silence: "Silenziare gli annunci" | ||||
|   silenceDescription: "Se attivi questa opzione, non riceverai notifiche sugli annunci, evitando di contrassegnarle come già lette." | ||||
|   silence: "Annuncio silenzioso" | ||||
|   silenceDescription: "Attivando questa opzione, non invierai la notifica, evitando che debba essere contrassegnata come già letta." | ||||
| _initialAccountSetting: | ||||
|   accountCreated: "Il tuo profilo è stato creato!" | ||||
|   letsStartAccountSetup: "Per iniziare, impostiamo il tuo profilo." | ||||
| @@ -1359,7 +1406,7 @@ _initialTutorial: | ||||
|   _timeline: | ||||
|     title: "Come funziona la Timeline" | ||||
|     description1: "Misskey fornisce alcune Timeline (sequenze cronologiche di Note). Una di queste potrebbe essere stata disattivata dagli amministratori." | ||||
|     home: "le Note provenienti dai profili che segui (follow)." | ||||
|     home: "le Note provenienti dai profili che segui (Following)." | ||||
|     local: "tutte le Note pubblicate dai profili di questa istanza." | ||||
|     social: "sia le Note della Timeline Home che quelle della Timeline Locale, insieme!" | ||||
|     global: "le Note da pubblicate da tutte le altre istanze federate con la nostra." | ||||
| @@ -1397,7 +1444,7 @@ _initialTutorial: | ||||
|     title: "Il tutorial è finito! 🎉" | ||||
|     description: "Queste sono solamente alcune delle funzionalità principali di Misskey. Per ulteriori informazioni, {link}." | ||||
| _timelineDescription: | ||||
|   home: "Nella Timeline Home, la tua cronologia principale, puoi vedere le Note provenienti dai profili che segui (follow)." | ||||
|   home: "Nella Timeline Home, la tua cronologia principale, puoi vedere le Note provenienti dai profili che segui (Following)." | ||||
|   local: "La Timeline Locale, è una cronologia di Note pubblicate da tutti i profili iscritti su questo server." | ||||
|   social: "La Timeline Sociale, unisce in ordine cronologico l'elenco di Note presenti nella Timeline Home e quella Locale." | ||||
|   global: "La Timeline Federata ti consente di vedere le Note pubblicate dai profili di tutti gli altri server federati a questo." | ||||
| @@ -1418,11 +1465,14 @@ _serverSettings: | ||||
|   reactionsBufferingDescription: "Attivando questa opzione, puoi migliorare significativamente le prestazioni durante la creazione delle reazioni e ridurre il carico sul database. Tuttavia, aumenterà l'impiego di memoria Redis." | ||||
|   inquiryUrl: "URL di contatto" | ||||
|   inquiryUrlDescription: "Specificare l'URL al modulo di contatto, oppure le informazioni con i dati di contatto dell'amministrazione." | ||||
|   openRegistration: "Registrazioni aperte" | ||||
|   openRegistrationWarning: "L’apertura della registrazione comporta dei rischi. Ti consigliamo di attivarla solo se hai predisposto il monitoraggio continuo del tuo server e puoi rispondere immediatamente se si verifica un problema." | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "Per prevenire SPAM, questa impostazione verrà disattivata automaticamente, se non si rileva alcuna attività di moderazione durante un certo periodo di tempo." | ||||
| _accountMigration: | ||||
|   moveFrom: "Migra un altro profilo dentro a questo" | ||||
|   moveFromSub: "Crea un alias verso un altro profilo remoto" | ||||
|   moveFromLabel: "Profilo da cui migrare #{n}" | ||||
|   moveFromDescription: "Se desideri spostare i profili follower da un altro profilo a questo, devi prima creare un alias qui. Assicurati averlo creato PRIMA di eseguire l'attività! Inserisci l'indirizzo del profilo mittente in questo modo: @persona@istanza.it" | ||||
|   moveFromDescription: "Se desideri spostare i Follower da un altro profilo a questo, devi prima creare un alias qui. Assicurati averlo creato PRIMA di eseguire l'attività! Inserisci l'indirizzo del profilo mittente in questo modo: @persona@istanza.it" | ||||
|   moveTo: "Migrare questo profilo verso un un altro" | ||||
|   moveToLabel: "Profilo verso cui migrare" | ||||
|   moveCannotBeUndone: "La migrazione è irreversibile, non può essere interrotta o annullata." | ||||
| @@ -1431,7 +1481,7 @@ _accountMigration: | ||||
|   startMigration: "Avvia la migrazione" | ||||
|   migrationConfirm: "Vuoi davvero migrare questo profilo su {account}? L'azione è irreversibile e non potrai più utilizzare questo profilo nel suo stato originale.\nInoltre, assicurati di aver già creato un alias sull'account a cui ti stai trasferendo." | ||||
|   movedAndCannotBeUndone: "Il tuo profilo è stato migrato.\nLa migrazione non può essere annullata." | ||||
|   postMigrationNote: "Questo profilo smetterà di seguire gli altri profili remoti a 24 ore dal termine della migrazione.\nSia i Follow che i Follower scenderanno a zero. I tuoi follower saranno comunque in grado di vedere le Note per soli follower, poiché non smetteranno di seguirti." | ||||
|   postMigrationNote: "Questo profilo smetterà di seguire gli altri profili remoti a 24 ore dal termine della migrazione.\nSia i Following che i Follower scenderanno a zero. I tuoi Follower saranno comunque in grado di vedere le Note per soli Follower, poiché non smetteranno di seguirti." | ||||
|   movedTo: "Profilo verso cui migrare" | ||||
| _achievements: | ||||
|   earnedAt: "Data di conseguimento" | ||||
| @@ -1824,7 +1874,7 @@ _gallery: | ||||
|   unlike: "Non mi piace più" | ||||
| _email: | ||||
|   _follow: | ||||
|     title: "Adesso ti segue" | ||||
|     title: "Follower aggiuntivo" | ||||
|   _receiveFollowRequest: | ||||
|     title: "Hai ricevuto una richiesta di follow" | ||||
| _plugin: | ||||
| @@ -1886,9 +1936,9 @@ _channel: | ||||
|   edit: "Gerisci canale" | ||||
|   setBanner: "Scegli intestazione" | ||||
|   removeBanner: "Rimuovi intestazione" | ||||
|   featured: "Di tendenza" | ||||
|   featured: "Popolari nel canale" | ||||
|   owned: "I miei canali" | ||||
|   following: "Seguiti" | ||||
|   following: "Following" | ||||
|   usersCount: "{n} partecipanti" | ||||
|   notesCount: "{n} note" | ||||
|   nameAndDescription: "Nome e descrizione" | ||||
| @@ -1971,7 +2021,6 @@ _theme: | ||||
|     buttonBg: "Sfondo del pulsante" | ||||
|     buttonHoverBg: "Sfondo del pulsante (sorvolato)" | ||||
|     inputBorder: "Inquadra casella di testo" | ||||
|     listItemHoverBg: "Sfondo della voce di elenco (sorvolato)" | ||||
|     driveFolderBg: "Sfondo della cartella di disco" | ||||
|     wallpaperOverlay: "Sovrapposizione dello sfondo" | ||||
|     badge: "Distintivo" | ||||
| @@ -2055,7 +2104,7 @@ _permissions: | ||||
|   "read:favorites": "Visualizza i tuoi preferiti" | ||||
|   "write:favorites": "Gestisci i tuoi preferiti" | ||||
|   "read:following": "Vedi le informazioni di follow" | ||||
|   "write:following": "Following di altri profili" | ||||
|   "write:following": "Aggiungere e togliere Following" | ||||
|   "read:messaging": "Visualizzare la chat" | ||||
|   "write:messaging": "Gestire la chat" | ||||
|   "read:mutes": "Vedi i profili silenziati" | ||||
| @@ -2138,11 +2187,14 @@ _auth: | ||||
|   permissionAsk: "Questa app richiede le seguenti autorizzazioni:" | ||||
|   pleaseGoBack: "Si prega di ritornare sulla app" | ||||
|   callback: "Ritornando sulla app" | ||||
|   accepted: "Accesso concesso" | ||||
|   denied: "Accesso negato" | ||||
|   scopeUser: "Sto funzionando per il seguente profilo" | ||||
|   pleaseLogin: "Per favore accedi al tuo account per cambiare i permessi dell'applicazione" | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "Consentendo l'accesso, si verrà reindirizzati presso questo indirizzo URL" | ||||
| _antennaSources: | ||||
|   all: "Tutte le note" | ||||
|   homeTimeline: "Note dagli utenti che segui" | ||||
|   homeTimeline: "Note dai tuoi Following" | ||||
|   users: "Note dagli utenti selezionati" | ||||
|   userList: "Note dagli utenti della lista selezionata" | ||||
|   userBlacklist: "Tutte le Note tranne quelle di uno o più profili specificati" | ||||
| @@ -2161,7 +2213,7 @@ _widgets: | ||||
|   notifications: "Notifiche" | ||||
|   timeline: "Timeline" | ||||
|   calendar: "Calendario" | ||||
|   trends: "Di tendenza" | ||||
|   trends: "Hashtag popolari" | ||||
|   clock: "Orologio" | ||||
|   rss: "Lettura RSS" | ||||
|   rssTicker: "Nastro RSS" | ||||
| @@ -2184,7 +2236,7 @@ _widgets: | ||||
|   _userList: | ||||
|     chooseList: "Seleziona una lista" | ||||
|   clicker: "Cliccaggio" | ||||
|   birthdayFollowings: "Chi nacque oggi" | ||||
|   birthdayFollowings: "Compleanni del giorno" | ||||
| _cw: | ||||
|   hide: "Nascondere" | ||||
|   show: "Continua la lettura..." | ||||
| @@ -2248,11 +2300,14 @@ _profile: | ||||
|   changeBanner: "Cambia intestazione" | ||||
|   verifiedLinkDescription: "Puoi verificare il tuo profilo mostrando una icona. Devi inserire la URL alla pagina che contiene un link al tuo profilo." | ||||
|   avatarDecorationMax: "Puoi aggiungere fino a {max} decorazioni." | ||||
|   followedMessage: "Messaggio, quando qualcuno ti segue" | ||||
|   followedMessageDescription: "Puoi impostare un breve messaggio da mostrare agli altri profili quando ti seguono." | ||||
|   followedMessageDescriptionForLockedAccount: "Quando approvi una richiesta di follow, verrà visualizzato questo testo." | ||||
| _exportOrImport: | ||||
|   allNotes: "Tutte le note" | ||||
|   favoritedNotes: "Note preferite" | ||||
|   clips: "Clip" | ||||
|   followingList: "Follow" | ||||
|   followingList: "Following" | ||||
|   muteList: "Elenco profili silenziati" | ||||
|   blockingList: "Elenco profili bloccati" | ||||
|   userLists: "Liste" | ||||
| @@ -2368,7 +2423,7 @@ _notification: | ||||
|   youGotReply: "{name} ti ha risposto" | ||||
|   youGotQuote: "{name} ha citato la tua Nota e ha detto" | ||||
|   youRenoted: "{name} ha rinotato" | ||||
|   youWereFollowed: "Adesso ti segue" | ||||
|   youWereFollowed: "Follower aggiuntivo" | ||||
|   youReceivedFollowRequest: "Hai ricevuto una richiesta di follow" | ||||
|   yourFollowRequestAccepted: "La tua richiesta di follow è stata accettata" | ||||
|   pollEnded: "Risultati del sondaggio." | ||||
| @@ -2387,25 +2442,27 @@ _notification: | ||||
|   followedBySomeUsers: "{n} follower" | ||||
|   flushNotification: "Azzera le notifiche" | ||||
|   exportOfXCompleted: "Abbiamo completato l'esportazione di {x}" | ||||
|   login: "Autenticazione avvenuta" | ||||
|   _types: | ||||
|     all: "Tutto" | ||||
|     note: "Nuove Note" | ||||
|     follow: "Nuovi profili follower" | ||||
|     follow: "Follower" | ||||
|     mention: "Menzioni" | ||||
|     reply: "Risposte" | ||||
|     renote: "Rinota" | ||||
|     quote: "Cita" | ||||
|     reaction: "Reazioni" | ||||
|     pollEnded: "Sondaggio chiuso." | ||||
|     receiveFollowRequest: "Richiesta di follow ricevuta" | ||||
|     followRequestAccepted: "Richiesta di follow accettata" | ||||
|     receiveFollowRequest: "Richieste di follow in arrivo" | ||||
|     followRequestAccepted: "Richieste di follow accettate" | ||||
|     roleAssigned: "Ruolo concesso" | ||||
|     achievementEarned: "Risultato raggiunto" | ||||
|     exportCompleted: "Esportazione completata" | ||||
|     test: "Prova la notifica" | ||||
|     login: "Accessi" | ||||
|     test: "Notifiche di test" | ||||
|     app: "Notifiche da applicazioni" | ||||
|   _actions: | ||||
|     followBack: "Segui" | ||||
|     followBack: "Following ricambiato" | ||||
|     reply: "Rispondi" | ||||
|     renote: "Rinota" | ||||
| _deck: | ||||
| @@ -2457,7 +2514,7 @@ _webhookSettings: | ||||
|   trigger: "Trigger" | ||||
|   active: "Attivo" | ||||
|   _events: | ||||
|     follow: "Quando segui un profilo" | ||||
|     follow: "Quando aggiungi Following" | ||||
|     followed: "Quando ti segue un profilo" | ||||
|     note: "Quando pubblichi una Nota" | ||||
|     reply: "Quando rispondono ad una Nota" | ||||
| @@ -2468,6 +2525,8 @@ _webhookSettings: | ||||
|     abuseReport: "Quando arriva una segnalazione" | ||||
|     abuseReportResolved: "Quando una segnalazione è risolta" | ||||
|     userCreated: "Quando viene creato un profilo" | ||||
|     inactiveModeratorsWarning: "Quando un profilo moderatore rimane inattivo per un determinato periodo" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "Quando la moderazione è rimasta inattiva per un determinato periodo e il sistema è cambiato in modalità \"solo inviti\"" | ||||
|   deleteConfirm: "Vuoi davvero eliminare il Webhook?" | ||||
|   testRemarks: "Clicca il bottone a destra dell'interruttore, per provare l'invio di un webhook con dati fittizi." | ||||
| _abuseReport: | ||||
| @@ -2513,6 +2572,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "File nel Drive segnato come esplicito" | ||||
|   unmarkSensitiveDriveFile: "File nel Drive segnato come non esplicito" | ||||
|   resolveAbuseReport: "Segnalazione risolta" | ||||
|   forwardAbuseReport: "Segnalazione inoltrata" | ||||
|   updateAbuseReportNote: "Ha aggiornato la segnalazione" | ||||
|   createInvitation: "Genera codice di invito" | ||||
|   createAd: "Banner creato" | ||||
|   deleteAd: "Banner eliminato" | ||||
| @@ -2668,6 +2729,66 @@ _contextMenu: | ||||
|   app: "Applicazione" | ||||
|   appWithShift: "Applicazione Shift+Tasto" | ||||
|   native: "Interfaccia utente del browser" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "Campo obbligatorio" | ||||
|     columnTypeNotSupport: "Solo le colonne type:text permettono la convalida delle Espresioni Regolari" | ||||
|     patternNotMatch: "Il valore non coincide con {pattern}" | ||||
|     notUnique: "Il valore deve essere univoco" | ||||
| _roleSelectDialog: | ||||
|   notSelected: "Niente selezioato" | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "Copia le righe selezionate" | ||||
|     copySelectionRanges: "Copia l'intervallo selezionato" | ||||
|     deleteSelectionRows: "Elimina le righe selezionate" | ||||
|     deleteSelectionRanges: "Elimina le righe nell'intervallo selezionato" | ||||
|     searchSettings: "Impostazioni di ricerca" | ||||
|     searchSettingCaption: "Imposta condizioni di ricerca dettagliate." | ||||
|     searchLimit: "Risultati visualizzati" | ||||
|     sortOrder: "Ordine" | ||||
|     registrationLogs: "Storico della registrazione" | ||||
|     registrationLogsCaption: "Lo storico verrà visualizzato in base alla attività sulle emoji. Scompare quando si esegue un'operazione di aggiornamento/eliminazione o si modifica/ricarica la pagina." | ||||
|     alertEmojisRegisterFailedDescription: "Attenzione, è impossibile modificare la emoji. Si prega di controllare lo storico per ulteriori dettagli." | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "Mostra le azioni a buon fine" | ||||
|     failureLogNothing: "Non ci sono errori nello storico delle emoji" | ||||
|     logNothing: "Lo storico è vuoto." | ||||
|   _remote: | ||||
|     selectionRowDetail: "Dettagli della riga selezionata" | ||||
|     importSelectionRows: "Importa le righe selezionate" | ||||
|     importSelectionRangesRows: "Importa le righe nell'intervallo selezionato" | ||||
|     importEmojisButton: "Importa le emoji selezionate" | ||||
|     confirmImportEmojisTitle: "Importazione emoji" | ||||
|     confirmImportEmojisDescription: "Importazione di {count} emoji ricevute da remoto. Si prega di prestare molta attenzione al tipo di licenza delle emoji. Vuoi confermare?" | ||||
|   _local: | ||||
|     tabTitleList: "Elenco delle emoji registrate" | ||||
|     tabTitleRegister: "Registrazione emoji" | ||||
|     _list: | ||||
|       emojisNothing: "Non ci sono emoji registrate." | ||||
|       markAsDeleteTargetRows: "Selezionare le righe come eliminabili" | ||||
|       markAsDeleteTargetRanges: "Selezionare le righe nell'intervallo come eliminabili" | ||||
|       alertUpdateEmojisNothingDescription: "Non ci sono emoji aggiornate." | ||||
|       alertDeleteEmojisNothingDescription: "Non ci sono emoji da eliminare." | ||||
|       confirmMovePage: "Vuoi davvero spostare la pagina?" | ||||
|       confirmChangeView: "Vuoi davvero cambiare la vista?" | ||||
|       confirmUpdateEmojisDescription: "Aggiornamento di {count} emoji. Vuoi davvero continuare?" | ||||
|       confirmDeleteEmojisDescription: "Eliminazione delle {count} emoji selezionate. Vuoi davvero continuare?" | ||||
|       confirmResetDescription: "Verranno ripristinate tutte le modifiche apportate finora." | ||||
|       confirmMovePageDesciption: "Sono state modificate le emoji in questa pagina.\nUscendo senza salvare, tutte le modifiche verranno ignorate." | ||||
|       dialogSelectRoleTitle: "Cerca emoji per ruolo" | ||||
|     _register: | ||||
|       uploadSettingTitle: "Caricamento impostazioni" | ||||
|       uploadSettingDescription: "Questa schermata ti permette di scegliere il comportamento durante il caricamento delle emoji." | ||||
|       directoryToCategoryLabel: "Inseriscile in una cartella omonima alla categoria" | ||||
|       directoryToCategoryCaption: "Crea il campo categoria in base alla cartella." | ||||
|       emojiInputAreaCaption: "Seleziona l'emoji da registrare utilizzando uno dei metodi." | ||||
|       emojiInputAreaList1: "Trascina una immagine o una cartella in quest'area" | ||||
|       emojiInputAreaList2: "Clicca per scegliere file dal tuo dispositivo" | ||||
|       emojiInputAreaList3: "Clicca per selezionare dal Drive" | ||||
|       confirmRegisterEmojisDescription: "Registrazione delle emoji elencate come nuove emoji personalizzate. Vuoi davvero procedere? (Per evitare sovraccarichi, puoi registrare al massimo {count} emoji per volta)" | ||||
|       confirmClearEmojisDescription: "Annullare le modifiche e cancella le emoji nell'elenco. Confermi?" | ||||
|       confirmUploadEmojisDescription: "Caricamento sul Drive di {count} file locali. Vuoi davvero procedere?" | ||||
| _embedCodeGen: | ||||
|   title: "Personalizza il codice di incorporamento" | ||||
|   header: "Mostra la testata" | ||||
| @@ -2682,3 +2803,43 @@ _embedCodeGen: | ||||
|   generateCode: "Crea il codice di incorporamento" | ||||
|   codeGenerated: "Codice generato" | ||||
|   codeGeneratedDescription: "Incolla il codice appena generato sul tuo sito web." | ||||
| _selfXssPrevention: | ||||
|   warning: "Avviso" | ||||
|   title: "\"Incolla qualcosa su questa schermata\" è tutta una truffa." | ||||
|   description1: "Incollando qualcosa qui, malintenzionati potrebbero prendere il controllo del tuo profilo o rubare i tuoi dati personali." | ||||
|   description2: "Se non sai esattamente cosa stai facendo, %c smetti subito e chiudi questa finestra." | ||||
|   description3: "Per favore, controlla questo collegamento per avere maggiori dettagli. {link}" | ||||
| _followRequest: | ||||
|   recieved: "Ricezione richiesta di Follow" | ||||
|   sent: "Richiesta di Follow, inviata" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "Server irraggiungibile" | ||||
|     description: "La comunicazione con questo server potrebbe essere disattivata. Hai bloccato il server? Oppure potrebbero averlo bloccato gli amministratori. Contattali per ulteriori informazioni." | ||||
|   _uriInvalid: | ||||
|     title: "URL non valido" | ||||
|     description: "Controlla che l'indirizzo sia valido e sia privo di caratteri non validi." | ||||
|   _requestFailed: | ||||
|     title: "Richiesta fallita" | ||||
|     description: "La comunicazione col server non è riuscita. Potrebbe essere inattivo. Assicurati anche che la URL sia valida." | ||||
|   _responseInvalid: | ||||
|     title: "Risposta non valida" | ||||
|     description: "La comunicazione col server è andata a buon fine, ma abbiamo ricevuto dati non validi." | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "L'indirizzo immesso non coincide con la URL finale. Interrogando i server per un contenuto remoto, assicurarsi di utilizzare la URL finale e non quella di un server intermedio." | ||||
|   _noSuchObject: | ||||
|     title: "Non trovato" | ||||
|     description: "La risorsa richiesta non è stata trovata. Verificare nuovamente la URL." | ||||
| _captcha: | ||||
|   verify: "Per favore, controlla la verifica CAPTCHA" | ||||
|   testSiteKeyMessage: "Puoi provare l'anteprima inserendo valori di test, sia per la chiave del sito che per la chiave segreta.\nSi prega di controllare la pagina qui sotto per i dettagli." | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "Errore durante la richiesta del CAPTCHA" | ||||
|       text: "Riprova più tardi o controlla nuovamente le impostazioni." | ||||
|     _verificationFailed: | ||||
|       title: "Convalida CAPTCHA non riuscita" | ||||
|       text: "Si prega di verificare nuovamente se le impostazioni sono corrette." | ||||
|     _unknown: | ||||
|       title: "Errore CAPTCHA" | ||||
|       text: "Si è verificato un errore imprevisto." | ||||
|   | ||||
| @@ -5,9 +5,13 @@ introMisskey: "ようこそ!Misskeyは、オープンソースの分散型マ | ||||
| poweredByMisskeyDescription: "{name}は、オープンソースのプラットフォーム<b>Misskey</b>のサーバーのひとつです。" | ||||
| monthAndDay: "{month}月 {day}日" | ||||
| search: "検索" | ||||
| reset: "リセット" | ||||
| notifications: "通知" | ||||
| username: "ユーザー名" | ||||
| password: "パスワード" | ||||
| initialPasswordForSetup: "初期設定開始用パスワード" | ||||
| initialPasswordIsIncorrect: "初期設定開始用のパスワードが違います。" | ||||
| initialPasswordForSetupDescription: "Misskeyを自分でインストールした場合は、設定ファイルに入力したパスワードを使用してください。\nMisskeyのホスティングサービスなどを使用している場合は、提供されたパスワードを使用してください。\nパスワードを設定していない場合は、空欄にしたまま続行してください。" | ||||
| forgotPassword: "パスワードを忘れた" | ||||
| fetchingAsApObject: "連合に照会中" | ||||
| ok: "OK" | ||||
| @@ -45,6 +49,7 @@ pin: "ピン留め" | ||||
| unpin: "ピン留め解除" | ||||
| copyContent: "内容をコピー" | ||||
| copyLink: "リンクをコピー" | ||||
| copyRemoteLink: "リモートのリンクをコピー" | ||||
| copyLinkRenote: "リノートのリンクをコピー" | ||||
| delete: "削除" | ||||
| deleteAndEdit: "削除して編集" | ||||
| @@ -379,7 +384,6 @@ enableLocalTimeline: "ローカルタイムラインを有効にする" | ||||
| enableGlobalTimeline: "グローバルタイムラインを有効にする" | ||||
| disablingTimelinesInfo: "これらのタイムラインを無効化しても、利便性のため管理者およびモデレーターは引き続き利用することができます。" | ||||
| registration: "登録" | ||||
| enableRegistration: "誰でも新規登録できるようにする" | ||||
| invite: "招待" | ||||
| driveCapacityPerLocalAccount: "ローカルユーザーひとりあたりのドライブ容量" | ||||
| driveCapacityPerRemoteAccount: "リモートユーザーひとりあたりのドライブ容量" | ||||
| @@ -451,6 +455,7 @@ totpDescription: "認証アプリを使ってワンタイムパスワードを | ||||
| moderator: "モデレーター" | ||||
| moderation: "モデレーション" | ||||
| moderationNote: "モデレーションノート" | ||||
| moderationNoteDescription: "モデレーター間でだけ共有されるメモを記入することができます。" | ||||
| addModerationNote: "モデレーションノートを追加する" | ||||
| moderationLogs: "モデログ" | ||||
| nUsersMentioned: "{n}人が投稿" | ||||
| @@ -583,6 +588,7 @@ masterVolume: "マスター音量" | ||||
| notUseSound: "サウンドを出力しない" | ||||
| useSoundOnlyWhenActive: "Misskeyがアクティブな時のみサウンドを出力する" | ||||
| details: "詳細" | ||||
| renoteDetails: "リノートの詳細" | ||||
| chooseEmoji: "絵文字を選択" | ||||
| unableToProcess: "操作を完了できません" | ||||
| recentUsed: "最近使用" | ||||
| @@ -680,11 +686,15 @@ smtpSecure: "SMTP 接続に暗黙的なSSL/TLSを使用する" | ||||
| smtpSecureInfo: "STARTTLS使用時はオフにします。" | ||||
| testEmail: "配信テスト" | ||||
| wordMute: "ワードミュート" | ||||
| wordMuteDescription: "指定した語句を含むノートを最小化します。最小化されたノートをクリックすることで表示することができます。" | ||||
| hardWordMute: "ハードワードミュート" | ||||
| showMutedWord: "ミュートされたワードを表示" | ||||
| hardWordMuteDescription: "指定した語句を含むノートを隠します。ワードミュートとは異なり、ノートは完全に表示されなくなります。" | ||||
| regexpError: "正規表現エラー" | ||||
| regexpErrorDescription: "{tab}ワードミュートの{line}行目の正規表現にエラーが発生しました:" | ||||
| instanceMute: "サーバーミュート" | ||||
| userSaysSomething: "{name}が何かを言いました" | ||||
| userSaysSomethingAbout: "{name}が「{word}」について何かを言いました" | ||||
| makeActive: "アクティブにする" | ||||
| display: "表示" | ||||
| copy: "コピー" | ||||
| @@ -716,10 +726,7 @@ abuseReported: "内容が送信されました。ご報告ありがとうござ | ||||
| reporter: "通報者" | ||||
| reporteeOrigin: "通報先" | ||||
| reporterOrigin: "通報元" | ||||
| forwardReport: "リモートサーバーに通報を転送する" | ||||
| forwardReportIsAnonymous: "リモートサーバーからはあなたの情報は見れず、匿名のシステムアカウントとして表示されます。" | ||||
| send: "送信" | ||||
| abuseMarkAsResolved: "対応済みにする" | ||||
| openInNewTab: "新しいタブで開く" | ||||
| openInSideView: "サイドビューで開く" | ||||
| defaultNavigationBehaviour: "デフォルトのナビゲーション" | ||||
| @@ -921,6 +928,7 @@ followersVisibility: "フォロワーの公開範囲" | ||||
| continueThread: "さらにスレッドを見る" | ||||
| deleteAccountConfirm: "アカウントが削除されます。よろしいですか?" | ||||
| incorrectPassword: "パスワードが間違っています。" | ||||
| incorrectTotp: "ワンタイムパスワードが間違っているか、期限切れになっています。" | ||||
| voteConfirm: "「{choice}」に投票しますか?" | ||||
| hide: "隠す" | ||||
| useDrawerReactionPickerForMobile: "モバイルデバイスのときドロワーで表示" | ||||
| @@ -945,6 +953,9 @@ oneHour: "1時間" | ||||
| oneDay: "1日" | ||||
| oneWeek: "1週間" | ||||
| oneMonth: "1ヶ月" | ||||
| threeMonths: "3ヶ月" | ||||
| oneYear: "1年" | ||||
| threeDays: "3日" | ||||
| reflectMayTakeTime: "反映されるまで時間がかかる場合があります。" | ||||
| failedToFetchAccountInformation: "アカウント情報の取得に失敗しました" | ||||
| rateLimitExceeded: "レート制限を超えました" | ||||
| @@ -1085,6 +1096,7 @@ retryAllQueuesConfirmTitle: "今すぐ再試行しますか?" | ||||
| retryAllQueuesConfirmText: "一時的にサーバーの負荷が増大することがあります。" | ||||
| enableChartsForRemoteUser: "リモートユーザーのチャートを生成" | ||||
| enableChartsForFederatedInstances: "リモートサーバーのチャートを生成" | ||||
| enableStatsForFederatedInstances: "リモートサーバーの情報を取得" | ||||
| showClipButtonInNoteFooter: "ノートのアクションにクリップを追加" | ||||
| reactionsDisplaySize: "リアクションの表示サイズ" | ||||
| limitWidthOfReaction: "リアクションの最大横幅を制限し、縮小して表示する" | ||||
| @@ -1283,6 +1295,41 @@ signinWithPasskey: "パスキーでログイン" | ||||
| unknownWebAuthnKey: "登録されていないパスキーです。" | ||||
| passkeyVerificationFailed: "パスキーの検証に失敗しました。" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "パスキーの検証に成功しましたが、パスワードレスログインが無効になっています。" | ||||
| messageToFollower: "フォロワーへのメッセージ" | ||||
| target: "対象" | ||||
| testCaptchaWarning: "CAPTCHAのテストを目的とした機能です。<strong>本番環境で使用しないでください。</strong>" | ||||
| prohibitedWordsForNameOfUser: "禁止ワード(ユーザーの名前)" | ||||
| prohibitedWordsForNameOfUserDescription: "このリストに含まれる文字列がユーザーの名前に含まれる場合、ユーザーの名前の変更を拒否します。モデレーター権限を持つユーザーはこの制限の影響を受けません。" | ||||
| yourNameContainsProhibitedWords: "変更しようとした名前に禁止された文字列が含まれています" | ||||
| yourNameContainsProhibitedWordsDescription: "名前に禁止されている文字列が含まれています。この名前を使用したい場合は、サーバー管理者にお問い合わせください。" | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "投稿者により、表示にはログインが必要と設定されています" | ||||
| lockdown: "ロックダウン" | ||||
| pleaseSelectAccount: "アカウントを選択してください" | ||||
| availableRoles: "利用可能なロール" | ||||
| acknowledgeNotesAndEnable: "注意事項を理解した上でオンにします。" | ||||
| federationSpecified: "このサーバーはホワイトリスト連合で運用されています。管理者が指定したサーバー以外とやり取りすることはできません。" | ||||
| federationDisabled: "このサーバーは連合が無効化されています。他のサーバーのユーザーとやり取りすることはできません。" | ||||
|  | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "コンテンツの表示にログインを必須にする" | ||||
|   requireSigninToViewContentsDescription1: "あなたが作成した全てのノートなどのコンテンツを表示するのにログインを必須にします。クローラーに情報が収集されるのを防ぐ効果が期待できます。" | ||||
|   requireSigninToViewContentsDescription2: "URLプレビュー(OGP)、Webページへの埋め込み、ノートの引用に対応していないサーバーからの表示も不可になります。" | ||||
|   requireSigninToViewContentsDescription3: "リモートサーバーに連合されたコンテンツでは、これらの制限が適用されない場合があります。" | ||||
|   makeNotesFollowersOnlyBefore: "過去のノートをフォロワーのみ表示可能にする" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "この機能が有効になっている間、設定された日時より過去、または設定された時間を経過しているノートがフォロワーのみ表示可能になります。無効に戻すと、ノートの公開状態も元に戻ります。" | ||||
|   makeNotesHiddenBefore: "過去のノートを非公開化する" | ||||
|   makeNotesHiddenBeforeDescription: "この機能が有効になっている間、設定された日時より過去、または設定された時間を経過しているノートが自分のみ表示可能(非公開化)になります。無効に戻すと、ノートの公開状態も元に戻ります。" | ||||
|   mayNotEffectForFederatedNotes: "リモートサーバーに連合されたノートには効果が及ばない場合があります。" | ||||
|   notesHavePassedSpecifiedPeriod: "指定した時間を経過しているノート" | ||||
|   notesOlderThanSpecifiedDateAndTime: "指定した日時より前のノート" | ||||
|  | ||||
| _abuseUserReport: | ||||
|   forward: "転送" | ||||
|   forwardDescription: "匿名のシステムアカウントとして、リモートサーバーに通報を転送します。" | ||||
|   resolve: "解決" | ||||
|   accept: "是認" | ||||
|   reject: "否認" | ||||
|   resolveTutorial: "内容が正当である通報に対応した場合は「是認」を選択し、肯定的にケースが解決されたことをマークします。\n内容が正当でない通報の場合は「否認」を選択し、否定的にケースが解決されたことをマークします。" | ||||
|  | ||||
| _delivery: | ||||
|   status: "配信状態" | ||||
| @@ -1428,6 +1475,9 @@ _serverSettings: | ||||
|   reactionsBufferingDescription: "有効にすると、リアクション作成時のパフォーマンスが大幅に向上し、データベースへの負荷を軽減することが可能です。ただし、Redisのメモリ使用量は増加します。" | ||||
|   inquiryUrl: "問い合わせ先URL" | ||||
|   inquiryUrlDescription: "サーバー運営者へのお問い合わせフォームのURLや、運営者の連絡先等が記載されたWebページのURLを指定します。" | ||||
|   openRegistration: "アカウントの作成をオープンにする" | ||||
|   openRegistrationWarning: "登録を開放することはリスクが伴います。サーバーを常に監視し、トラブルが発生した際にすぐに対応できる体制がある場合のみオンにすることを推奨します。" | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "一定期間モデレーターのアクティビティが検出されなかった場合、スパム防止のためこの設定は自動でオフになります。" | ||||
|  | ||||
| _accountMigration: | ||||
|   moveFrom: "別のアカウントからこのアカウントに移行" | ||||
| @@ -2006,7 +2056,6 @@ _theme: | ||||
|     buttonBg: "ボタンの背景" | ||||
|     buttonHoverBg: "ボタンの背景 (ホバー)" | ||||
|     inputBorder: "入力ボックスの縁取り" | ||||
|     listItemHoverBg: "リスト項目の背景 (ホバー)" | ||||
|     driveFolderBg: "ドライブフォルダーの背景" | ||||
|     wallpaperOverlay: "壁紙のオーバーレイ" | ||||
|     badge: "バッジ" | ||||
| @@ -2181,8 +2230,11 @@ _auth: | ||||
|   permissionAsk: "このアプリは次の権限を要求しています" | ||||
|   pleaseGoBack: "アプリケーションに戻ってやっていってください" | ||||
|   callback: "アプリケーションに戻っています" | ||||
|   accepted: "アクセスを許可しました" | ||||
|   denied: "アクセスを拒否しました" | ||||
|   scopeUser: "以下のユーザーとして操作しています" | ||||
|   pleaseLogin: "アプリケーションにアクセス許可を与えるには、ログインが必要です。" | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "アクセスを許可すると、自動で以下のURLに遷移します" | ||||
|  | ||||
| _antennaSources: | ||||
|   all: "全てのノート" | ||||
| @@ -2430,7 +2482,7 @@ _notification: | ||||
|   youGotMention: "{name}からのメンション" | ||||
|   youGotReply: "{name}からのリプライ" | ||||
|   youGotQuote: "{name}による引用" | ||||
|   youRenoted: "{name}がRenoteしました" | ||||
|   youRenoted: "{name}がリノートしました" | ||||
|   youWereFollowed: "フォローされました" | ||||
|   youReceivedFollowRequest: "フォローリクエストが来ました" | ||||
|   yourFollowRequestAccepted: "フォローリクエストが承認されました" | ||||
| @@ -2450,6 +2502,7 @@ _notification: | ||||
|   followedBySomeUsers: "{n}人にフォローされました" | ||||
|   flushNotification: "通知の履歴をリセットする" | ||||
|   exportOfXCompleted: "{x}のエクスポートが完了しました" | ||||
|   login: "ログインがありました" | ||||
|  | ||||
|   _types: | ||||
|     all: "すべて" | ||||
| @@ -2457,7 +2510,7 @@ _notification: | ||||
|     follow: "フォロー" | ||||
|     mention: "メンション" | ||||
|     reply: "リプライ" | ||||
|     renote: "Renote" | ||||
|     renote: "リノート" | ||||
|     quote: "引用" | ||||
|     reaction: "リアクション" | ||||
|     pollEnded: "アンケートが終了" | ||||
| @@ -2466,13 +2519,14 @@ _notification: | ||||
|     roleAssigned: "ロールが付与された" | ||||
|     achievementEarned: "実績の獲得" | ||||
|     exportCompleted: "エクスポートが完了した" | ||||
|     login: "ログイン" | ||||
|     test: "通知のテスト" | ||||
|     app: "連携アプリからの通知" | ||||
|  | ||||
|   _actions: | ||||
|     followBack: "フォローバック" | ||||
|     reply: "返信" | ||||
|     renote: "Renote" | ||||
|     renote: "リノート" | ||||
|  | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "常にメインカラムを表示" | ||||
| @@ -2539,6 +2593,8 @@ _webhookSettings: | ||||
|     abuseReport: "ユーザーから通報があったとき" | ||||
|     abuseReportResolved: "ユーザーからの通報を処理したとき" | ||||
|     userCreated: "ユーザーが作成されたとき" | ||||
|     inactiveModeratorsWarning: "モデレーターが一定期間非アクティブになったとき" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "モデレーターが一定期間非アクティブだったため、システムにより招待制へと変更されたとき" | ||||
|   deleteConfirm: "Webhookを削除しますか?" | ||||
|   testRemarks: "スイッチの右にあるボタンをクリックするとダミーのデータを使用したテスト用Webhookを送信できます。" | ||||
|  | ||||
| @@ -2586,6 +2642,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "ファイルをセンシティブ付与" | ||||
|   unmarkSensitiveDriveFile: "ファイルをセンシティブ解除" | ||||
|   resolveAbuseReport: "通報を解決" | ||||
|   forwardAbuseReport: "通報を転送" | ||||
|   updateAbuseReportNote: "通報のモデレーションノート更新" | ||||
|   createInvitation: "招待コードを作成" | ||||
|   createAd: "広告を作成" | ||||
|   deleteAd: "広告を削除" | ||||
| @@ -2751,6 +2809,69 @@ _contextMenu: | ||||
|   appWithShift: "Shiftキーでアプリケーション" | ||||
|   native: "ブラウザのUI" | ||||
|  | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "この値は必須項目です" | ||||
|     columnTypeNotSupport: "正規表現によるバリデーションはtype:textのカラムのみサポートします。" | ||||
|     patternNotMatch: "この値は{pattern}のパターンに一致しません" | ||||
|     notUnique: "この値は一意である必要があります" | ||||
|  | ||||
| _roleSelectDialog: | ||||
|   notSelected: "選択されていません" | ||||
|  | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "選択行をコピー" | ||||
|     copySelectionRanges: "選択範囲をコピー" | ||||
|     deleteSelectionRows: "選択行を削除" | ||||
|     deleteSelectionRanges: "選択範囲の値をクリア" | ||||
|     searchSettings: "検索設定" | ||||
|     searchSettingCaption: "検索条件を詳細に設定します。" | ||||
|     searchLimit: "表示件数" | ||||
|     sortOrder: "並び順" | ||||
|     registrationLogs: "登録ログ" | ||||
|     registrationLogsCaption: "絵文字更新・削除時のログが表示されます。更新・削除操作を行ったり、ページを遷移・リロードすると消えます。" | ||||
|     alertEmojisRegisterFailedDescription: "絵文字の更新・削除に失敗しました。詳細は登録ログをご確認ください。" | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "成功ログを表示" | ||||
|     failureLogNothing: "失敗ログはありません。" | ||||
|     logNothing: "ログはありません。" | ||||
|   _remote: | ||||
|     selectionRowDetail: "選択行の詳細" | ||||
|     importSelectionRows: "選択行をインポート" | ||||
|     importSelectionRangesRows: "選択範囲の行をインポート" | ||||
|     importEmojisButton: "チェックされた絵文字をインポート" | ||||
|     confirmImportEmojisTitle: "絵文字のインポート" | ||||
|     confirmImportEmojisDescription: "リモートから受信した{count}個の絵文字のインポートを行います。絵文字のライセンスに十分な注意を払ってください。実行しますか?" | ||||
|   _local: | ||||
|     tabTitleList: "登録済み絵文字一覧" | ||||
|     tabTitleRegister: "絵文字の登録" | ||||
|     _list: | ||||
|       emojisNothing: "登録された絵文字はありません。" | ||||
|       markAsDeleteTargetRows: "選択行を削除対象にする" | ||||
|       markAsDeleteTargetRanges: "選択範囲の行を削除対象にする" | ||||
|       alertUpdateEmojisNothingDescription: "変更された絵文字はありません。" | ||||
|       alertDeleteEmojisNothingDescription: "削除対象の絵文字はありません。" | ||||
|       confirmMovePage: "ページを移動しますか?" | ||||
|       confirmChangeView: "表示を変更しますか?" | ||||
|       confirmUpdateEmojisDescription: "{count}個の絵文字を更新します。実行しますか?" | ||||
|       confirmDeleteEmojisDescription: "チェックがつけられた{count}個の絵文字を削除します。実行しますか?" | ||||
|       confirmResetDescription: "今までに加えた変更がすべてリセットされます。" | ||||
|       confirmMovePageDesciption: "このページの絵文字に変更が加えられています。\n保存せずにこのままページを移動すると、このページで加えた変更はすべて破棄されます。" | ||||
|       dialogSelectRoleTitle: "絵文字に設定されたロールで検索" | ||||
|     _register: | ||||
|       uploadSettingTitle: "アップロード設定" | ||||
|       uploadSettingDescription: "この画面で絵文字アップロードを行う際の動作を設定できます。" | ||||
|       directoryToCategoryLabel: "ディレクトリ名を\"category\"に入力する" | ||||
|       directoryToCategoryCaption: "ディレクトリをドラッグ・ドロップした時に、ディレクトリ名を\"category\"に入力します。" | ||||
|       emojiInputAreaCaption: "いずれかの方法で登録する絵文字を選択してください。" | ||||
|       emojiInputAreaList1: "この枠に画像ファイルまたはディレクトリをドラッグ&ドロップ" | ||||
|       emojiInputAreaList2: "このリンクをクリックしてPCから選択する" | ||||
|       emojiInputAreaList3: "このリンクをクリックしてドライブから選択する" | ||||
|       confirmRegisterEmojisDescription: "リストに表示されている絵文字を新たなカスタム絵文字として登録します。よろしいですか?(負荷を避けるため、一度の操作で登録可能な絵文字は{count}件までです)" | ||||
|       confirmClearEmojisDescription: "編集内容を破棄し、リストに表示されている絵文字をクリアします。よろしいですか?" | ||||
|       confirmUploadEmojisDescription: "ドラッグ&ドロップされた{count}個のファイルをドライブにアップロードします。実行しますか?" | ||||
|  | ||||
| _embedCodeGen: | ||||
|   title: "埋め込みコードをカスタマイズ" | ||||
|   header: "ヘッダーを表示" | ||||
| @@ -2765,3 +2886,47 @@ _embedCodeGen: | ||||
|   generateCode: "埋め込みコードを作成" | ||||
|   codeGenerated: "コードが生成されました" | ||||
|   codeGeneratedDescription: "生成されたコードをウェブサイトに貼り付けてご利用ください。" | ||||
|  | ||||
| _selfXssPrevention: | ||||
|   warning: "警告" | ||||
|   title: "「この画面に何か貼り付けろ」はすべて詐欺です。" | ||||
|   description1: "ここに何かを貼り付けると、悪意のあるユーザーにアカウントを乗っ取られたり、個人情報を盗まれたりする可能性があります。" | ||||
|   description2: "貼り付けようとしているものが何なのかを正確に理解していない場合は、%c今すぐ作業を中止してこのウィンドウを閉じてください。" | ||||
|   description3: "詳しくはこちらをご確認ください。 {link}" | ||||
|  | ||||
| _followRequest: | ||||
|   recieved: "受け取った申請" | ||||
|   sent: "送った申請" | ||||
|  | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "このサーバーとは通信できません" | ||||
|     description: "このサーバーとの通信が無効化されているか、このサーバーをブロックしている・ブロックされている可能性があります。\nサーバー管理者にお問い合わせください。" | ||||
|   _uriInvalid: | ||||
|     title: "URIが不正です" | ||||
|     description: "入力されたURIに問題があります。URIに使用できない文字を入力していないか確認してください。" | ||||
|   _requestFailed: | ||||
|     title: "リクエストに失敗しました" | ||||
|     description: "このサーバーとの通信に失敗しました。相手サーバーがダウンしている可能性があります。また、不正なURIや存在しないURIを入力していないか確認してください。" | ||||
|   _responseInvalid: | ||||
|     title: "レスポンスが不正です" | ||||
|     description: "このサーバーと通信することはできましたが、得られたデータが不正なものでした。" | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "入力されたURIのドメインと最終的に得られたURIのドメインとが異なります。第三者のサーバーを介してリモートのコンテンツを照会している場合は、発信元のサーバーで取得できるURIを使用して照会し直してください。" | ||||
|   _noSuchObject: | ||||
|     title: "見つかりません" | ||||
|     description: "要求されたリソースは見つかりませんでした。URIをもう一度お確かめください。" | ||||
|  | ||||
| _captcha: | ||||
|   verify: "CAPTCHAを通過してください" | ||||
|   testSiteKeyMessage: "サイトキーとシークレットキーにテスト用の値を入力することでプレビューを確認できます。\n詳細は下記ページをご確認ください。" | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "CAPTCHAのリクエストに失敗しました" | ||||
|       text: "しばらく後に実行するか、設定をもう一度ご確認ください。" | ||||
|     _verificationFailed: | ||||
|       title: "CAPTCHAの検証に失敗しました" | ||||
|       text: "設定が正しいかどうかもう一度確認ください。" | ||||
|     _unknown: | ||||
|       title: "CAPTCHAエラー" | ||||
|       text: "想定外のエラーが発生しました。" | ||||
|   | ||||
| @@ -8,11 +8,14 @@ search: "探す" | ||||
| notifications: "通知" | ||||
| username: "ユーザー名" | ||||
| password: "パスワード" | ||||
| initialPasswordForSetup: "初期設定開始用パスワード" | ||||
| initialPasswordIsIncorrect: "初期設定開始用のパスワードがちゃうで。" | ||||
| initialPasswordForSetupDescription: "Miskkeyを自分でインストールしたんやったら、設定ファイルに入れたパスワードを使ってや。\nホスティングサービスを使っとるんやったら、サービスから言われたやつを使うんやで。\n別に何も設定しとらんのやったら、何も入れずに空けといてな。" | ||||
| forgotPassword: "パスワード忘れたん?" | ||||
| fetchingAsApObject: "今ちと連合に照会しとるで" | ||||
| ok: "ええで" | ||||
| gotIt: "ほい" | ||||
| cancel: "やめとく" | ||||
| cancel: "やめる" | ||||
| noThankYou: "やめとく" | ||||
| enterUsername: "ユーザー名を入れてや" | ||||
| renotedBy: "{user}がリノートしたで" | ||||
| @@ -23,7 +26,7 @@ settings: "設定" | ||||
| notificationSettings: "通知の設定" | ||||
| basicSettings: "基本設定" | ||||
| otherSettings: "ほかの設定" | ||||
| openInWindow: "ウィンドウで開くで" | ||||
| openInWindow: "ウィンドウで開く" | ||||
| profile: "プロフィール" | ||||
| timeline: "タイムライン" | ||||
| noAccountDescription: "自己紹介食ってもた" | ||||
| @@ -42,7 +45,7 @@ favorited: "お気に入りに入れたで。" | ||||
| alreadyFavorited: "もうお気に入りに入れとるがな。" | ||||
| cantFavorite: "アカン、お気に入りに入れれんかったわ。" | ||||
| pin: "ピン留めしとく" | ||||
| unpin: "やっぱピン留めせん" | ||||
| unpin: "ピン留めやめる" | ||||
| copyContent: "内容をコピー" | ||||
| copyLink: "リンクをコピー" | ||||
| copyLinkRenote: "リノートのリンクをコピーするで?" | ||||
| @@ -60,7 +63,7 @@ copyFileId: "ファイルIDをコピー" | ||||
| copyFolderId: "フォルダーIDをコピー" | ||||
| copyProfileUrl: "プロフィールURLをコピー" | ||||
| searchUser: "ユーザーを探す" | ||||
| searchThisUsersNotes: "ユーザーのノートを検索" | ||||
| searchThisUsersNotes: "ユーザーのノートを探す" | ||||
| reply: "返事" | ||||
| loadMore: "まだまだあるで!" | ||||
| showMore: "まだまだあるで!" | ||||
| @@ -135,8 +138,8 @@ reactionSettingDescription2: "ドラッグで並び替え、クリックで削 | ||||
| rememberNoteVisibility: "公開範囲覚えといて" | ||||
| attachCancel: "のっけるのやめる" | ||||
| deleteFile: "ファイルをほかす" | ||||
| markAsSensitive: "ちょっとこれはアカン" | ||||
| unmarkAsSensitive: "そこまでアカンことないやろ" | ||||
| markAsSensitive: "ちょっと見せられへんわ" | ||||
| unmarkAsSensitive: "別にええんじゃね?" | ||||
| enterFileName: "ファイル名を入れてや" | ||||
| mute: "ミュート" | ||||
| unmute: "ミュートやめたる" | ||||
| @@ -149,13 +152,13 @@ unsuspend: "溶かす" | ||||
| blockConfirm: "ブロックしてもええんか?" | ||||
| unblockConfirm: "ブロックやめたるってほんまか?" | ||||
| suspendConfirm: "凍結してしもうてええか?" | ||||
| unsuspendConfirm: "解凍するけどええか?" | ||||
| unsuspendConfirm: "溶かしたるけどええか?" | ||||
| selectList: "リストを選ぶ" | ||||
| editList: "リストいじる" | ||||
| selectChannel: "チャンネルを選ぶ" | ||||
| selectAntenna: "アンテナを選ぶ" | ||||
| editAntenna: "アンテナいじる" | ||||
| createAntenna: "アンテナを作成" | ||||
| createAntenna: "アンテナを作る" | ||||
| selectWidget: "ウィジェットを選ぶ" | ||||
| editWidgets: "ウィジェットをいじる" | ||||
| editWidgetsExit: "いじるのをやめる" | ||||
| @@ -169,12 +172,12 @@ settingGuide: "ええ感じの設定" | ||||
| cacheRemoteFiles: "リモートのファイルをキャッシュする" | ||||
| cacheRemoteFilesDescription: "この設定を入れとったら、リモートのファイルを端から端までこのサーバーのキャッシュん中突っ込むようになるで。画像映し出すんがめっちゃ速うなるけど、サーバーの容量をやたらと食うようになるで。リモートの人がどんだけ長くキャッシュを持っとくかはドライブ容量の制限で決めとくで。制限を超えたら古いのから順々に消してって、かわりにリンクになるで。この設定を切ったら、リモートのファイルは最初っからリンクとして扱うことにするけど、画像のサムネ作るのとかみんなのプライバシー守るために、default.ymlのproxyRemoteFilesをtrueにしといたほうがええよ。" | ||||
| youCanCleanRemoteFilesCache: "ファイル管理にある🗑️ボタンでキャッシュ全部ほかすで。" | ||||
| cacheRemoteSensitiveFiles: "リモートのきわどいファイルをキャッシュに突っ込む" | ||||
| cacheRemoteSensitiveFiles: "リモートのきわどいファイルをキャッシュする" | ||||
| cacheRemoteSensitiveFilesDescription: "この設定を切ると、リモートのきわどいファイルはキャッシュせず直でリンクするようになるで。" | ||||
| flagAsBot: "Botにするで" | ||||
| flagAsBotDescription: "もしこのアカウントをプログラム使うて運用するんやったら、このフラグをオンにしてや。オンにすれば、反応がバーッて連鎖せんように開発者が使うたり、Misskeyのシステム上での扱いがBotに合ったもんになるからな。" | ||||
| flagAsCat: "猫や。かわええな。" | ||||
| flagAsCatDescription: "ネコになりたいんならこれつけとき。" | ||||
| flagAsCatDescription: "猫になりたいんならこれつけとき。" | ||||
| flagShowTimelineReplies: "タイムラインにノートへの返信を表示するで" | ||||
| flagShowTimelineRepliesDescription: "オンにしたら、タイムラインにユーザーのノートの他にもそのユーザーの他のノートへの返信を表示するで。" | ||||
| autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストを勝手に許可しとく" | ||||
| @@ -183,9 +186,9 @@ reloadAccountsList: "アカウントリストの情報を更新" | ||||
| loginFailed: "ログインに失敗してもうた…" | ||||
| showOnRemote: "リモートで見る" | ||||
| continueOnRemote: "リモートで続行" | ||||
| chooseServerOnMisskeyHub: "Misskey Hubからサーバーを選択" | ||||
| chooseServerOnMisskeyHub: "Misskey Hubからサーバーを選ぶ" | ||||
| specifyServerHost: "サーバーのドメインを直接指定" | ||||
| inputHostName: "ドメインを入力せえや" | ||||
| inputHostName: "ドメインを入力してや" | ||||
| general: "全般" | ||||
| wallpaper: "壁紙" | ||||
| setWallpaper: "壁紙を設定" | ||||
| @@ -236,6 +239,8 @@ silencedInstances: "サーバーサイレンスされてんねん" | ||||
| silencedInstancesDescription: "サイレンスしたいサーバーのホストを改行で区切って設定すんで。サイレンスされたサーバーに所属するアカウントはすべて「サイレンス」として扱われ、フォローがすべてリクエストになり、フォロワーでないローカルアカウントにはメンションできなくなんねん。ブロックしたインスタンスには影響せーへんで。" | ||||
| mediaSilencedInstances: "メディアサイレンスしたサーバー" | ||||
| mediaSilencedInstancesDescription: "メディアサイレンスしたいサーバーのホストを改行で区切って設定するで。メディアサイレンスされたサーバーに所属するアカウントによるファイルはすべてセンシティブとして扱われてな、カスタム絵文字が使えへんようになるで。ブロックしたインスタンスには影響せえへんで。" | ||||
| federationAllowedHosts: "連合を許すサーバー" | ||||
| federationAllowedHostsDescription: "連合してもいいサーバーのホストを行ごとに区切って設定してや。" | ||||
| muteAndBlock: "ミュートとブロック" | ||||
| mutedUsers: "ミュートしとるユーザー" | ||||
| blockedUsers: "ブロックしとるユーザー" | ||||
| @@ -334,6 +339,7 @@ renameFolder: "フォルダー名を変える" | ||||
| deleteFolder: "フォルダーをほかす" | ||||
| folder: "フォルダー" | ||||
| addFile: "ファイルを追加" | ||||
| showFile: "ファイル出す" | ||||
| emptyDrive: "ドライブは空っぽや" | ||||
| emptyFolder: "このフォルダーは空や" | ||||
| unableToDelete: "消せんかったわ" | ||||
| @@ -376,7 +382,6 @@ enableLocalTimeline: "ローカルタイムラインを使えるようにする | ||||
| enableGlobalTimeline: "グローバルタイムラインを使えるようにするわ" | ||||
| disablingTimelinesInfo: "ここらへんのタイムラインを使えんようにしてしもても、管理者とモデレーターは使えるままになってるで、そうやなかったら不便やからな。" | ||||
| registration: "登録" | ||||
| enableRegistration: "一見さんでも誰でもいらっしゃ~い" | ||||
| invite: "来てや" | ||||
| driveCapacityPerLocalAccount: "ローカルユーザーはんひとりあたりのドライブ容量" | ||||
| driveCapacityPerRemoteAccount: "リモートユーザーはんひとりあたりのドライブ容量" | ||||
| @@ -448,6 +453,7 @@ totpDescription: "認証アプリ使うてワンタイムパスワードを入 | ||||
| moderator: "モデレーター" | ||||
| moderation: "モデレーション" | ||||
| moderationNote: "モデレーションノート" | ||||
| moderationNoteDescription: "モデレーターの中だけで共有するメモを入れれるで。" | ||||
| addModerationNote: "モデレーションノートを追加するで" | ||||
| moderationLogs: "モデログ" | ||||
| nUsersMentioned: "{n}人が投稿" | ||||
| @@ -509,6 +515,10 @@ uiLanguage: "UIの表示言語" | ||||
| aboutX: "{x}について" | ||||
| emojiStyle: "絵文字のスタイル" | ||||
| native: "ネイティブ" | ||||
| menuStyle: "メニューのスタイル" | ||||
| style: "スタイル" | ||||
| drawer: "ドロワー" | ||||
| popup: "ポップアップ" | ||||
| showNoteActionsOnlyHover: "ノートの操作部をホバー時のみ表示するで" | ||||
| showReactionsCount: "ノートのリアクション数を表示する" | ||||
| noHistory: "履歴はないわ。" | ||||
| @@ -576,6 +586,7 @@ masterVolume: "全体のやかましさ" | ||||
| notUseSound: "音出さへん" | ||||
| useSoundOnlyWhenActive: "Misskeyがアクティブなときだけ音出す" | ||||
| details: "もっと" | ||||
| renoteDetails: "リノートの詳細" | ||||
| chooseEmoji: "絵文字を選ぶ" | ||||
| unableToProcess: "なんか奥の方で詰まってもうた" | ||||
| recentUsed: "最近使ったやつ" | ||||
| @@ -591,6 +602,8 @@ ascendingOrder: "小さい順" | ||||
| descendingOrder: "大きい順" | ||||
| scratchpad: "スクラッチパッド" | ||||
| scratchpadDescription: "スクラッチパッドではAiScriptを色々試すことができるんや。Misskeyに対して色々できるコードを書いて動かしてみたり、結果を見たりできるで。" | ||||
| uiInspector: "UIインスペクター" | ||||
| uiInspectorDescription: "メモリ上にあるUIコンポーネントのインスタンス一覧を見れるで。UIコンポーネントはUi:C:系関数で生成されるで。" | ||||
| output: "出力" | ||||
| script: "スクリプト" | ||||
| disablePagesScript: "Pagesのスクリプトを無効にしてや" | ||||
| @@ -707,10 +720,7 @@ abuseReported: "無事内容が送信されたみたいやで。おおきに〜 | ||||
| reporter: "通報者" | ||||
| reporteeOrigin: "通報先" | ||||
| reporterOrigin: "通報元" | ||||
| forwardReport: "リモートサーバーに通報を転送するで" | ||||
| forwardReportIsAnonymous: "リモートサーバーからはあんたの情報は見えんなって、匿名のシステムアカウントとして表示されるで。" | ||||
| send: "送信" | ||||
| abuseMarkAsResolved: "対応したで" | ||||
| openInNewTab: "新しいタブで開く" | ||||
| openInSideView: "サイドビューで開く" | ||||
| defaultNavigationBehaviour: "デフォルトのナビゲーション" | ||||
| @@ -912,6 +922,7 @@ followersVisibility: "フォロワーの公開範囲" | ||||
| continueThread: "さらにスレッドを見るで" | ||||
| deleteAccountConfirm: "アカウントを消すで?ええんか?" | ||||
| incorrectPassword: "パスワードがちゃうわ。" | ||||
| incorrectTotp: "ワンタイムパスワードが間違っとるか、期限が切れとるみたいやな。" | ||||
| voteConfirm: "「{choice}」に投票するんか?" | ||||
| hide: "隠す" | ||||
| useDrawerReactionPickerForMobile: "ケータイとかのときドロワーで表示するで" | ||||
| @@ -936,6 +947,9 @@ oneHour: "1時間" | ||||
| oneDay: "1日" | ||||
| oneWeek: "1週間" | ||||
| oneMonth: "1ヶ月" | ||||
| threeMonths: "3ヶ月" | ||||
| oneYear: "1年" | ||||
| threeDays: "3日" | ||||
| reflectMayTakeTime: "反映されるまで時間がかかることがあるで" | ||||
| failedToFetchAccountInformation: "アカウントの取得に失敗したみたいや…" | ||||
| rateLimitExceeded: "レート制限が超えたみたいやで" | ||||
| @@ -1076,6 +1090,7 @@ retryAllQueuesConfirmTitle: "もっかいやってみるか?" | ||||
| retryAllQueuesConfirmText: "一時的にサーバー重なるかもしれへんで。" | ||||
| enableChartsForRemoteUser: "リモートユーザーのチャートを作る" | ||||
| enableChartsForFederatedInstances: "リモートサーバーのチャートを作る" | ||||
| enableStatsForFederatedInstances: "リモートサーバの情報を取得" | ||||
| showClipButtonInNoteFooter: "ノートのアクションにクリップを追加" | ||||
| reactionsDisplaySize: "ツッコミの表示のでかさ" | ||||
| limitWidthOfReaction: "ツッコミの最大横幅を制限して、ちっさく表示するで" | ||||
| @@ -1262,6 +1277,49 @@ confirmWhenRevealingSensitiveMedia: "センシティブなメディアを表示 | ||||
| sensitiveMediaRevealConfirm: "センシティブなメディアやで。表示するんか?" | ||||
| createdLists: "作成したリスト" | ||||
| createdAntennas: "作成したアンテナ" | ||||
| fromX: "{x}から" | ||||
| genEmbedCode: "埋め込みコードを作る" | ||||
| noteOfThisUser: "このユーザーのノート全部" | ||||
| clipNoteLimitExceeded: "これ以上このクリップにノート追加でけへんわ。" | ||||
| performance: "パフォーマンス" | ||||
| modified: "変更あり" | ||||
| discard: "やめる" | ||||
| thereAreNChanges: "{n}個の変更があるみたいや" | ||||
| signinWithPasskey: "パスキーでログイン" | ||||
| unknownWebAuthnKey: "登録されてへんパスキーやな。" | ||||
| passkeyVerificationFailed: "パスキーの検証に失敗したで。" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "パスキーの検証は成功したんやけど、パスワードレスログインが無効になっとるわ。" | ||||
| messageToFollower: "フォロワーへのメッセージ" | ||||
| target: "対象" | ||||
| testCaptchaWarning: "CAPTCHAのテストを目的としてるで。<strong>絶対に本番環境で使わんといてな。絶対やで。</strong>" | ||||
| prohibitedWordsForNameOfUser: "禁止ワード(ユーザー名)" | ||||
| prohibitedWordsForNameOfUserDescription: "このリストの中にある文字列がユーザー名に入っとったら、その名前に変更できひんようになるで。モデレーター権限があるユーザーは除外や。" | ||||
| yourNameContainsProhibitedWords: "その名前は禁止した文字列が含まれとるで" | ||||
| yourNameContainsProhibitedWordsDescription: "その名前は禁止した文字列が含まれとるわ。どうしてもって言うなら、サーバー管理者に言うしかないで。" | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "投稿者が、表示にログインが要るって設定してるで" | ||||
| lockdown: "ロックダウン" | ||||
| pleaseSelectAccount: "アカウント選んでや" | ||||
| availableRoles: "使えるロール" | ||||
| acknowledgeNotesAndEnable: "注意事項をわかった上でオンにする。" | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "ログインしてもらってからコンテンツ見てもらう" | ||||
|   requireSigninToViewContentsDescription1: "あなたが作成した全部のノートとかのコンテンツを見れるようにするのにログインがいるようにするで。クローラーにいろいろ収集されるんを防げるかもしれん。" | ||||
|   requireSigninToViewContentsDescription2: "URLプレビュー(OGP)、Webページへの埋め込み、ノートの引用に対応してないサーバーからの表示ができんくなるで。" | ||||
|   requireSigninToViewContentsDescription3: "リモートサーバーに連合されたコンテンツは、これらの制限が適用されんかもしれんで。" | ||||
|   makeNotesFollowersOnlyBefore: "昔のノートをフォロワーだけに見てもらう" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "この機能が有効になってる間は、設定された日時より前、それか設定された時間が経ったノートがフォロワーのみ見れるようになるで。無効に戻すと、ノートの公開状態も戻るで。" | ||||
|   makeNotesHiddenBefore: "昔のノートを見れんようにする" | ||||
|   makeNotesHiddenBeforeDescription: "この機能が有効になってる間は、設定された日時より前、それか設定された時間が経ったノートがフォロワーのみ見れるようになるで。無効に戻すと、ノートの公開状態も戻るで。" | ||||
|   mayNotEffectForFederatedNotes: "リモートサーバーに連合されたノートには効果が及ばんかもしれん。" | ||||
|   notesHavePassedSpecifiedPeriod: "決めた時間が経ったノート" | ||||
|   notesOlderThanSpecifiedDateAndTime: "決めた日時より前のノート" | ||||
| _abuseUserReport: | ||||
|   forward: "転送" | ||||
|   forwardDescription: "匿名のシステムアカウントってことにして、リモートサーバーに通報を転送するで。" | ||||
|   resolve: "解決" | ||||
|   accept: "ええよ" | ||||
|   reject: "あかんよ" | ||||
|   resolveTutorial: "内容がええなら「ええよ」を選ぶんや。肯定的に解決されたことにして記録するで。\n逆に、内容がだめなら「あかんよ」を選びいや。否定的に解決されたって記録しとくで。" | ||||
| _delivery: | ||||
|   status: "配信状態" | ||||
|   stop: "配信せぇへん" | ||||
| @@ -1396,8 +1454,12 @@ _serverSettings: | ||||
|   fanoutTimelineDescription: "入れると、おのおのタイムラインを取得するときにめちゃめちゃ動きが良うなって、データベースが軽くなるわ。でも、Redisのメモリ使う量が増えるから注意な。サーバーのメモリが足りんときとか、動きが変なときは切れるで。" | ||||
|   fanoutTimelineDbFallback: "データベースにフォールバックする" | ||||
|   fanoutTimelineDbFallbackDescription: "有効にしたら、タイムラインがキャッシュん中に入ってないときにDBにもっかい問い合わせるフォールバック処理ってのをやっとくで。切ったらフォールバック処理をやらんからサーバーはもっと軽くなんねんけど、タイムラインの取得範囲がちょっと減るで。" | ||||
|   reactionsBufferingDescription: "有効にしたら、リアクション作るときのパフォーマンスがすっごい上がって、データベースへの負荷が減るで。代わりに、Redisのメモリ使用は増えるで。" | ||||
|   inquiryUrl: "問い合わせ先URL" | ||||
|   inquiryUrlDescription: "サーバー運営者へのお問い合わせフォームのURLや、運営者の連絡先等が記載されたWebページのURLを指定するで。" | ||||
|   openRegistration: "アカウントの作成をオープンにする" | ||||
|   openRegistrationWarning: "登録を解放するのはリスクが伴うで。サーバーをいっつも監視して、なんか起きたらすぐに対応できるんやったら、オンにしてもええと思う。" | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "一定期間モデレーターがおらんかったら、スパムを防ぐためにこの設定は勝手に切られるで。" | ||||
| _accountMigration: | ||||
|   moveFrom: "別のアカウントからこのアカウントに引っ越す" | ||||
|   moveFromSub: "別のアカウントへエイリアスを作る" | ||||
| @@ -1729,6 +1791,11 @@ _role: | ||||
|     canSearchNotes: "ノート探せるかどうか" | ||||
|     canUseTranslator: "翻訳使えるかどうか" | ||||
|     avatarDecorationLimit: "アイコンデコのいっちばんつけれる数" | ||||
|     canImportAntennas: "アンテナのインポートを許す" | ||||
|     canImportBlocking: "ブロックのインポートを許す" | ||||
|     canImportFollowing: "フォローのインポートを許す" | ||||
|     canImportMuting: "ミュートのインポートを許す" | ||||
|     canImportUserLists: "リストのインポートを許す" | ||||
|   _condition: | ||||
|     roleAssignedTo: "マニュアルロールにアサイン済み" | ||||
|     isLocal: "ローカルユーザー" | ||||
| @@ -1946,7 +2013,6 @@ _theme: | ||||
|     buttonBg: "ボタンの背景" | ||||
|     buttonHoverBg: "ボタンの背景 (ホバー)" | ||||
|     inputBorder: "入力ボックスの縁取り" | ||||
|     listItemHoverBg: "リスト項目の背景 (ホバー)" | ||||
|     driveFolderBg: "ドライブフォルダーの背景" | ||||
|     wallpaperOverlay: "壁紙のオーバーレイ" | ||||
|     badge: "バッジ" | ||||
| @@ -2113,8 +2179,11 @@ _auth: | ||||
|   permissionAsk: "このアプリは次の権限を要求しとるで" | ||||
|   pleaseGoBack: "アプリケーションに戻ってええよ" | ||||
|   callback: "アプリケーションに戻っとるで" | ||||
|   accepted: "アクセスを許可したで" | ||||
|   denied: "アクセスを拒否ったで" | ||||
|   scopeUser: "以下のユーザーとしていじってるで" | ||||
|   pleaseLogin: "アプリにアクセスさせるんやったら、ログインしてや。" | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "アクセスを許したら、自動で下のURLに遷移するで" | ||||
| _antennaSources: | ||||
|   all: "みんなのノート" | ||||
|   homeTimeline: "フォローしとるユーザーのノート" | ||||
| @@ -2223,6 +2292,9 @@ _profile: | ||||
|   changeBanner: "バナー画像を変更するで" | ||||
|   verifiedLinkDescription: "内容をURLに設定すると、リンク先のwebサイトに自分のプロフのリンクが含まれてる場合に所有者確認済みアイコンを表示させることができるで。" | ||||
|   avatarDecorationMax: "最大{max}つまでデコつけれんで" | ||||
|   followedMessage: "フォローされたら返すメッセージ" | ||||
|   followedMessageDescription: "フォローされたときに相手に返す短めのメッセージを決めれるで。" | ||||
|   followedMessageDescriptionForLockedAccount: "フォローが承認制なら、フォローリクエストをOKしたときに見せるで。" | ||||
| _exportOrImport: | ||||
|   allNotes: "全てのノート" | ||||
|   favoritedNotes: "お気に入りにしたノート" | ||||
| @@ -2315,6 +2387,7 @@ _pages: | ||||
|   eyeCatchingImageSet: "アイキャッチ画像を設定" | ||||
|   eyeCatchingImageRemove: "アイキャッチ画像を削除" | ||||
|   chooseBlock: "ブロックを追加" | ||||
|   enterSectionTitle: "セクションタイトルを入れる" | ||||
|   selectType: "種類を選択" | ||||
|   contentBlocks: "コンテンツ" | ||||
|   inputBlocks: "入力" | ||||
| @@ -2360,13 +2433,15 @@ _notification: | ||||
|   renotedBySomeUsers: "{n}人がリノートしたで" | ||||
|   followedBySomeUsers: "{n}人にフォローされたで" | ||||
|   flushNotification: "通知の履歴をリセットする" | ||||
|   exportOfXCompleted: "{x}のエクスポートが終わったわ" | ||||
|   login: "ログインしとったで" | ||||
|   _types: | ||||
|     all: "すべて" | ||||
|     note: "あんたらの新規投稿" | ||||
|     follow: "フォロー" | ||||
|     mention: "メンション" | ||||
|     reply: "リプライ" | ||||
|     renote: "Renote" | ||||
|     renote: "リノート" | ||||
|     quote: "引用" | ||||
|     reaction: "ツッコミ" | ||||
|     pollEnded: "アンケートが終了したで" | ||||
| @@ -2374,11 +2449,14 @@ _notification: | ||||
|     followRequestAccepted: "フォローが受理されたで" | ||||
|     roleAssigned: "ロールが付与された" | ||||
|     achievementEarned: "実績の獲得" | ||||
|     exportCompleted: "エクスポート終わった" | ||||
|     login: "ログイン" | ||||
|     test: "通知テスト" | ||||
|     app: "連携アプリからの通知や" | ||||
|   _actions: | ||||
|     followBack: "フォローバック" | ||||
|     reply: "返事" | ||||
|     renote: "Renote" | ||||
|     renote: "リノート" | ||||
| _deck: | ||||
|   alwaysShowMainColumn: "いつもメインカラムを表示" | ||||
|   columnAlign: "カラムの寄せ" | ||||
| @@ -2439,7 +2517,10 @@ _webhookSettings: | ||||
|     abuseReport: "ユーザーから通報があったとき" | ||||
|     abuseReportResolved: "ユーザーからの通報を処理したとき" | ||||
|     userCreated: "ユーザーが作成されたとき" | ||||
|     inactiveModeratorsWarning: "モデレーターがしばらくおらんかったとき" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "モデレーターがしばらくおらんかったから、システムが招待制に変えたとき" | ||||
|   deleteConfirm: "ほんまにWebhookをほかしてもええんか?" | ||||
|   testRemarks: "スイッチ右のボタンを押すとダミーデータを使ったテスト用Webhookを送れるで。" | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     createRecipient: "通報の通知先を追加" | ||||
| @@ -2483,6 +2564,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "ファイルをセンシティブ付与" | ||||
|   unmarkSensitiveDriveFile: "ファイルをセンシティブ解除" | ||||
|   resolveAbuseReport: "苦情を解決" | ||||
|   forwardAbuseReport: "通報を転送" | ||||
|   updateAbuseReportNote: "通報のモデレーションノート更新" | ||||
|   createInvitation: "招待コード作る" | ||||
|   createAd: "広告を作んで" | ||||
|   deleteAd: "広告ほかす" | ||||
| @@ -2494,6 +2577,14 @@ _moderationLogTypes: | ||||
|   unsetUserBanner: "この子のバナー元に戻す" | ||||
|   createSystemWebhook: "SystemWebhookを作成" | ||||
|   updateSystemWebhook: "SystemWebhookを更新" | ||||
|   deleteSystemWebhook: "SystemWebhookを削除" | ||||
|   createAbuseReportNotificationRecipient: "通報の通知先作る" | ||||
|   updateAbuseReportNotificationRecipient: "通報の通知先更新" | ||||
|   deleteAbuseReportNotificationRecipient: "通報の通知先消す" | ||||
|   deleteAccount: "アカウント消す" | ||||
|   deletePage: "ページ消す" | ||||
|   deleteFlash: "Playをほかす" | ||||
|   deleteGalleryPost: "ギャラリーの投稿をほかす" | ||||
| _fileViewer: | ||||
|   title: "ファイルの詳しい情報" | ||||
|   type: "ファイルの種類" | ||||
| @@ -2625,3 +2716,49 @@ _mediaControls: | ||||
|   pip: "ピクチャインピクチャ" | ||||
|   playbackRate: "再生速度" | ||||
|   loop: "ループ再生" | ||||
| _contextMenu: | ||||
|   title: "コンテキストメニュー" | ||||
|   app: "アプリ" | ||||
|   appWithShift: "Shiftキーでアプリ" | ||||
|   native: "ブラウザのUI" | ||||
| _embedCodeGen: | ||||
|   title: "埋め込みコードをカスタム" | ||||
|   header: "ヘッダー出す" | ||||
|   autoload: "勝手に続きを読み込む(非推奨)" | ||||
|   maxHeight: "高さの最大値" | ||||
|   maxHeightDescription: "0は最大値を指定せえへんけど、ウィジェットが伸び続けるから絶対1以上にしといてや。" | ||||
|   maxHeightWarn: "高さの最大値が無効になっとるで。意図してへん変更なら、普通の値に戻してや。" | ||||
|   previewIsNotActual: "プレビュー画面で出せる範囲をはみ出したから、ホンマの表示とはちゃうとおもうで。" | ||||
|   rounded: "角丸める" | ||||
|   border: "外枠に枠線つける" | ||||
|   applyToPreview: "プレビューに反映" | ||||
|   generateCode: "埋め込みコード作る" | ||||
|   codeGenerated: "コード作ったで" | ||||
|   codeGeneratedDescription: "作ったコードはウェブサイトに貼っつけて使ってや。" | ||||
| _selfXssPrevention: | ||||
|   warning: "警告" | ||||
|   title: "「この画面になんか貼り付けろ」は全部詐欺やで。" | ||||
|   description1: "ここになんかはつっつけると、悪いユーザーにアカウント乗っ取られたり、個人情報盗まれたりするかもやで" | ||||
|   description2: "はっつけようとしてるものがなんなんかわからんのやったら、%c今すぐ作業やめてウィンドウを閉じて。" | ||||
|   description3: "詳しくはこれを見て。{link}" | ||||
| _followRequest: | ||||
|   recieved: "もらった申請" | ||||
|   sent: "送った申請" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "このサーバーと通信できん" | ||||
|     description: "このサーバーとの通信は無効化されてるか、このサーバーをブロックしてるんか、ブロックされてるかもしれん。\nサーバー管理者に問い合わせてや。" | ||||
|   _uriInvalid: | ||||
|     title: "URIがおかしいで" | ||||
|     description: "入力されたURIに問題があるで。URIに使えん文字を入れてないから確かめて。" | ||||
|   _requestFailed: | ||||
|     title: "リクエスト失敗してもうたで" | ||||
|     description: "このサーバーとの通信に失敗してもうたわ。相手サーバーがダウンしてるかもしれん。あと、おかしいURIとか、ありえんURIを入れてないか確かめて。" | ||||
|   _responseInvalid: | ||||
|     title: "レスポンスがおかしいで" | ||||
|     description: "このサーバーと通信することはできたけど、もらったデータがおかしかったで。" | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "入力されたURIのドメインと最終的に得られたURIのドメインとが違うで。第三者のサーバーを介してリモートのコンテンツを照会してるんやったら、発信元のサーバーで取得できるURIを使って照会し直して。" | ||||
|   _noSuchObject: | ||||
|     title: "見つからへんね" | ||||
|     description: "求められたリソースが見つからんかったで。URIをもっかい確かめてや。" | ||||
|   | ||||
| @@ -77,6 +77,8 @@ _profile: | ||||
|   username: "ಬಳಕೆಹೆಸರು" | ||||
| _notification: | ||||
|   youWereFollowed: "ಹಿಂಬಾಲಿಸಿದರು" | ||||
|   _types: | ||||
|     login: "ಪ್ರವೇಶ" | ||||
|   _actions: | ||||
|     reply: "ಉತ್ತರಿಸು" | ||||
| _deck: | ||||
|   | ||||
| @@ -356,7 +356,6 @@ enableLocalTimeline: "로컬 타임라인 키기" | ||||
| enableGlobalTimeline: "글로벌 타임라인 키기" | ||||
| disablingTimelinesInfo: "요 타임라인얼 꺼도 간리자하고 중재자넌 고대로 설 수 잇십니다." | ||||
| registration: "맨걸기" | ||||
| enableRegistration: "누라도 새로 맨걸 수 잇거로 하기" | ||||
| invite: "초대하기" | ||||
| driveCapacityPerLocalAccount: "로컬 사용자 하나마중 드라이브 커기" | ||||
| driveCapacityPerRemoteAccount: "웬겍 사용자 하나마중 드라이브 커기" | ||||
| @@ -468,7 +467,7 @@ tooShort: "억수로 짜립니다" | ||||
| tooLong: "억수로 집니다" | ||||
| passwordMatched: "맞십니다" | ||||
| passwordNotMatched: "안 맞십니다" | ||||
| signinWith: "{n}서 로그인" | ||||
| signinWith: "{x} 서 로그인" | ||||
| signinFailed: "로그인 몬 했십니다. 고 이름이랑 비밀번호 제대로 썼는가 확인해 주이소." | ||||
| or: "아니면" | ||||
| language: "언어" | ||||
| @@ -601,8 +600,6 @@ reportAbuseOf: "{name}님얼 신고하기" | ||||
| reporter: "신고한 사람" | ||||
| reporteeOrigin: "신고덴 사람" | ||||
| reporterOrigin: "신고한 곳" | ||||
| forwardReport: "웬겍 서버에 신고 보내기" | ||||
| forwardReportIsAnonymous: "웬겍 서버서는 나으 정보럴 몬 보고 익멩으 시스템 게정어로 보입니다." | ||||
| waitingFor: "{x}(얼)럴 지달리고 잇십니다" | ||||
| random: "무작이" | ||||
| system: "시스템" | ||||
| @@ -811,10 +808,13 @@ _notification: | ||||
|   _types: | ||||
|     follow: "팔로잉" | ||||
|     mention: "멘션" | ||||
|     renote: "리노트" | ||||
|     quote: "따오기" | ||||
|     reaction: "반엉" | ||||
|     login: "로그인" | ||||
|   _actions: | ||||
|     reply: "답하기" | ||||
|     renote: "리노트" | ||||
| _deck: | ||||
|   _columns: | ||||
|     notifications: "알림" | ||||
| @@ -840,3 +840,6 @@ _reversi: | ||||
|   black: "꺼멍" | ||||
|   white: "허영" | ||||
|   total: "합게" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "몬 찾앗십니다" | ||||
|   | ||||
| @@ -5,9 +5,13 @@ introMisskey: "환영합니다! Misskey는 오픈 소스 분산형 마이크로 | ||||
| poweredByMisskeyDescription: "{name} 서버는 오픈소스 플랫폼 <b>Misskey</b>의 서버 가운데 하나입니다." | ||||
| monthAndDay: "{month}월 {day}일" | ||||
| search: "검색" | ||||
| reset: "초기화" | ||||
| notifications: "알림" | ||||
| username: "유저명" | ||||
| password: "비밀번호" | ||||
| initialPasswordForSetup: "초기 설정용 비밀번호" | ||||
| initialPasswordIsIncorrect: "초기 설정용 비밀번호가 올바르지 않습니다." | ||||
| initialPasswordForSetupDescription: "Misskey를 직접 설치하는 경우, 설정 파일에 입력해둔 비밀번호를 사용하세요.\nMisskey 설치를 도와주는 호스팅 서비스 등을 사용하는 경우, 서비스 제공자로부터 받은 비밀번호를 사용하세요.\n비밀번호를 따로 설정하지 않은 경우, 아무것도 입력하지 않아도 됩니다." | ||||
| forgotPassword: "비밀번호 재설정" | ||||
| fetchingAsApObject: "연합에서 찾아보는 중" | ||||
| ok: "확인" | ||||
| @@ -39,12 +43,13 @@ favorite: "즐겨찾기" | ||||
| favorites: "즐겨찾기" | ||||
| unfavorite: "즐겨찾기에서 제거" | ||||
| favorited: "즐겨찾기에 등록했습니다." | ||||
| alreadyFavorited: "이미 즐겨찾기에 등록했습니다." | ||||
| alreadyFavorited: "이미 즐겨찾기에 등록되어 있습니다." | ||||
| cantFavorite: "즐겨찾기에 등록하지 못했습니다." | ||||
| pin: "프로필에 고정" | ||||
| unpin: "프로필에서 고정 해제" | ||||
| copyContent: "내용 복사" | ||||
| copyLink: "링크 복사" | ||||
| copyRemoteLink: "리모트 서버의 링크로 복사하기" | ||||
| copyLinkRenote: "리노트 링크 복사" | ||||
| delete: "삭제" | ||||
| deleteAndEdit: "삭제 후 편집" | ||||
| @@ -379,7 +384,6 @@ enableLocalTimeline: "로컬 타임라인 활성화" | ||||
| enableGlobalTimeline: "글로벌 타임라인 활성화" | ||||
| disablingTimelinesInfo: "특정 타임라인을 비활성화하더라도 관리자 및 모더레이터는 계속 사용할 수 있습니다." | ||||
| registration: "등록" | ||||
| enableRegistration: "신규 회원가입을 활성화" | ||||
| invite: "초대" | ||||
| driveCapacityPerLocalAccount: "로컬 유저 한 명당 드라이브 용량" | ||||
| driveCapacityPerRemoteAccount: "원격 사용자별 드라이브 용량" | ||||
| @@ -451,6 +455,7 @@ totpDescription: "인증 앱을 사용하여 일회성 비밀번호 입력" | ||||
| moderator: "모더레이터" | ||||
| moderation: "조정" | ||||
| moderationNote: "조정 기록" | ||||
| moderationNoteDescription: "모더레이터 역할을 가진 유저만 보이는 메모를 적을 수 있습니다." | ||||
| addModerationNote: "조정 기록 추가하기" | ||||
| moderationLogs: "모더레이션 로그" | ||||
| nUsersMentioned: "{n}명이 언급함" | ||||
| @@ -583,6 +588,7 @@ masterVolume: "마스터 볼륨" | ||||
| notUseSound: "음소거 하기" | ||||
| useSoundOnlyWhenActive: "Misskey를 활성화한 때에만 소리를 출력하기" | ||||
| details: "자세히" | ||||
| renoteDetails: "리노트 상세 내용" | ||||
| chooseEmoji: "이모지 선택" | ||||
| unableToProcess: "작업을 완료할 수 없습니다" | ||||
| recentUsed: "최근 사용" | ||||
| @@ -680,11 +686,15 @@ smtpSecure: "SMTP 연결에 Implicit SSL/TTS 사용" | ||||
| smtpSecureInfo: "STARTTLS 사용 시에는 해제합니다." | ||||
| testEmail: "이메일 전송 테스트" | ||||
| wordMute: "단어 뮤트" | ||||
| wordMuteDescription: "정해진 단어가 포함된 노트를 최소화 한 상태로 표시합니다. 최소화 된 노트는 클릭해서 표시할 수 있습니다." | ||||
| hardWordMute: "하드 단어 뮤트" | ||||
| showMutedWord: "뮤트한 단어를 표시하기" | ||||
| hardWordMuteDescription: "정한 단어가 들어간 노트를 숨깁니다. 단어 뮤트와 차이점은 노트가 아예 보이지 않습니다." | ||||
| regexpError: "정규 표현식 오류" | ||||
| regexpErrorDescription: "{tab}단어 뮤트 {line}행의 정규 표현식에 오류가 발생했습니다:" | ||||
| instanceMute: "서버 뮤트" | ||||
| userSaysSomething: "{name}님이 무언가를 말했습니다" | ||||
| userSaysSomethingAbout: "{name}님이 \"{word}\"를 언급했습니다." | ||||
| makeActive: "활성화" | ||||
| display: "보기" | ||||
| copy: "복사" | ||||
| @@ -716,10 +726,7 @@ abuseReported: "신고를 보냈습니다. 신고해 주셔서 감사합니다." | ||||
| reporter: "신고자" | ||||
| reporteeOrigin: "피신고자" | ||||
| reporterOrigin: "신고자" | ||||
| forwardReport: "리모트 서버에도 신고 내용 보내기" | ||||
| forwardReportIsAnonymous: "리모트 서버에서는 나의 정보를 볼 수 없으며, 익명의 시스템 계정으로 표시됩니다." | ||||
| send: "전송" | ||||
| abuseMarkAsResolved: "해결됨으로 표시" | ||||
| openInNewTab: "새 탭에서 열기" | ||||
| openInSideView: "사이드뷰로 열기" | ||||
| defaultNavigationBehaviour: "기본 탐색 동작" | ||||
| @@ -921,6 +928,7 @@ followersVisibility: "팔로워의 공개 범위" | ||||
| continueThread: "글타래 더 보기" | ||||
| deleteAccountConfirm: "계정이 삭제되고 되돌릴 수 없게 됩니다. 계속하시겠습니까? " | ||||
| incorrectPassword: "비밀번호가 올바르지 않습니다." | ||||
| incorrectTotp: "OTP 번호가 틀렸거나 유효기간이 만료되어 있을 수 있습니다." | ||||
| voteConfirm: "\"{choice}\"에 투표하시겠습니까?" | ||||
| hide: "숨기기" | ||||
| useDrawerReactionPickerForMobile: "모바일에서 드로어 메뉴로 표시" | ||||
| @@ -945,6 +953,9 @@ oneHour: "1시간" | ||||
| oneDay: "1일" | ||||
| oneWeek: "일주일" | ||||
| oneMonth: "1개월" | ||||
| threeMonths: "3개월" | ||||
| oneYear: "1년" | ||||
| threeDays: "3일" | ||||
| reflectMayTakeTime: "반영되기까지 시간이 걸릴 수 있습니다." | ||||
| failedToFetchAccountInformation: "계정 정보를 가져오지 못했습니다" | ||||
| rateLimitExceeded: "요청 제한 횟수를 초과하였습니다" | ||||
| @@ -1085,6 +1096,7 @@ retryAllQueuesConfirmTitle: "지금 다시 시도하시겠습니까?" | ||||
| retryAllQueuesConfirmText: "일시적으로 서버의 부하가 증가할 수 있습니다." | ||||
| enableChartsForRemoteUser: "리모트 유저의 차트를 생성" | ||||
| enableChartsForFederatedInstances: "리모트 서버의 차트를 생성" | ||||
| enableStatsForFederatedInstances: "리모트 서버 정보 받아오기" | ||||
| showClipButtonInNoteFooter: "노트 동작에 클립을 추가" | ||||
| reactionsDisplaySize: "리액션 표시 크기" | ||||
| limitWidthOfReaction: "리액션의 최대 폭을 제한하고 작게 표시하기" | ||||
| @@ -1120,7 +1132,7 @@ preservedUsernames: "예약한 사용자 이름" | ||||
| preservedUsernamesDescription: "예약할 사용자명을 한 줄에 하나씩 입력합니다. 여기에서 지정한 사용자명으로는 계정을 생성할 수 없게 됩니다. 단, 관리자 권한으로 계정을 생성할 때에는 해당되지 않으며, 이미 존재하는 계정도 영향을 받지 않습니다." | ||||
| createNoteFromTheFile: "이 파일로 노트를 작성" | ||||
| archive: "아카이브" | ||||
| archived: "보관됨" | ||||
| archived: "아카이브 됨" | ||||
| unarchive: "보관 취소" | ||||
| channelArchiveConfirmTitle: "{name} 채널을 보존하시겠습니까?" | ||||
| channelArchiveConfirmDescription: "보존한 채널은 채널 목록과 검색 결과에 표시되지 않으며 새로운 노트도 작성할 수 없습니다." | ||||
| @@ -1251,7 +1263,7 @@ lastNDays: "최근 {n}일" | ||||
| backToTitle: "타이틀로 가기" | ||||
| hemisphere: "거주 지역" | ||||
| withSensitive: "민감한 파일이 포함된 노트 보기" | ||||
| userSaysSomethingSensitive: "{name} 같은 민감한 파일이 포함된 글" | ||||
| userSaysSomethingSensitive: "{name}의 민감한 파일이 포함된 게시물" | ||||
| enableHorizontalSwipe: "스와이프하여 탭 전환" | ||||
| loading: "불러오는 중" | ||||
| surrender: "그만두기" | ||||
| @@ -1283,6 +1295,39 @@ signinWithPasskey: "패스키로 로그인" | ||||
| unknownWebAuthnKey: "등록되지 않은 패스키입니다." | ||||
| passkeyVerificationFailed: "패스키 검증을 실패했습니다." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "패스키를 검증했으나, 비밀번호 없이 로그인하기가 꺼져 있습니다." | ||||
| messageToFollower: "팔로워에게 보낼 메시지" | ||||
| target: "대상" | ||||
| testCaptchaWarning: "CAPTCHA를 테스트하기 위한 기능입니다. <strong>실제 환경에서는 사용하지 마세요.</strong>" | ||||
| prohibitedWordsForNameOfUser: "금지 단어 (사용자 이름)" | ||||
| prohibitedWordsForNameOfUserDescription: "이 목록에 포함되는 키워드가 사용자 이름에 있는 경우, 일반 사용자는 이름을 바꿀 수 없습니다. 모더레이터 권한을 가진 사용자는 제한 대상에서 제외됩니다." | ||||
| yourNameContainsProhibitedWords: "바꾸려는 이름에 금지된 키워드가 포함되어 있습니다." | ||||
| yourNameContainsProhibitedWordsDescription: "이름에 금지된 키워드가 있습니다. 이름을 사용해야 하는 경우, 서버 관리자에 문의하세요." | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "게시자에 의해 로그인해야 볼 수 있도록 설정되어 있습니다." | ||||
| lockdown: "잠금" | ||||
| pleaseSelectAccount: "계정을 선택해주세요." | ||||
| availableRoles: "사용 가능한 역할" | ||||
| acknowledgeNotesAndEnable: "활성화 하기 전에 주의 사항을 확인했습니다." | ||||
| federationSpecified: "이 서버는 화이트 리스트 제도로 운영 중 입니다. 정해진 리모트 서버가 아닌 경우 연합되지 않습니다." | ||||
| federationDisabled: "이 서버는 연합을 하지 않고 있습니다. 리모트 서버 유저와 통신을 할 수 없습니다." | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "콘텐츠 열람을 위해 로그인을 필수로 설정하기" | ||||
|   requireSigninToViewContentsDescription1: "자신이 작성한 모든 노트 등의 콘텐츠를 보기 위해 로그인을 필수로 설정합니다. 크롤러가 정보 수집하는 것을 방지하는 효과를 기대할 수 있습니다." | ||||
|   requireSigninToViewContentsDescription2: "URL 미리보기(OGP), 웹페이지에 삽입, 노트 인용을 지원하지 않는 서버에서 볼 수 없게 됩니다." | ||||
|   requireSigninToViewContentsDescription3: "원격 서버에 연합된 콘텐츠에는 이러한 제한이 적용되지 않을 수 있습니다." | ||||
|   makeNotesFollowersOnlyBefore: "과거 노트는 팔로워만 볼 수 있도록 설정하기" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "이 기능이 활성화되어 있는 동안, 설정된 날짜 및 시간보다 과거 또는 설정된 시간이 지난 노트는 팔로워만 볼 수 있게 됩니다. 비활성화하면 노트의 공개 상태도 원래대로 돌아갑니다." | ||||
|   makeNotesHiddenBefore: "과거 노트 비공개로 전환하기" | ||||
|   makeNotesHiddenBeforeDescription: "이 기능이 활성화되어 있는 동안 설정한 날짜 및 시간보다 과거 또는 설정한 시간이 지난 노트는 본인만 볼 수 있게(비공개로 전환) 됩니다. 비활성화하면 노트의 공개 상태도 원래대로 돌아갑니다." | ||||
|   mayNotEffectForFederatedNotes: "원격 서버에 연합된 노트에는 효과가 없을 수도 있습니다." | ||||
|   notesHavePassedSpecifiedPeriod: "지정한 시간이 경과된 노트" | ||||
|   notesOlderThanSpecifiedDateAndTime: "지정된 날짜 및 시간 이전의 노트" | ||||
| _abuseUserReport: | ||||
|   forward: "전달" | ||||
|   forwardDescription: "익명 시스템 계정을 사용하여 리모트 서버에 신고 내용을 전달할 수 있습니다." | ||||
|   resolve: "해결됨" | ||||
|   accept: "인용" | ||||
|   reject: "기각" | ||||
|   resolveTutorial: "적절한 신고 내용에 대응한 경우, \"인용\"을 선택하여 \"해결됨\"으로 기록합니다.\n적절하지 않은 신고를 받은 경우, \"기각\"을 선택하여 \"기각\"으로 기록합니다." | ||||
| _delivery: | ||||
|   status: "전송 상태" | ||||
|   stop: "정지됨" | ||||
| @@ -1420,6 +1465,9 @@ _serverSettings: | ||||
|   reactionsBufferingDescription: "활성화 한 경우, 리액션 작성 퍼포먼스가 대폭 향상되어 DB의 부하를 줄일 수 있으나, Redis의 메모리 사용량이 많아집니다." | ||||
|   inquiryUrl: "문의처 URL" | ||||
|   inquiryUrlDescription: "서버 운영자에게 보내는 문의 양식의 URL이나 운영자의 연락처 등이 적힌 웹 페이지의 URL을 설정합니다." | ||||
|   openRegistration: "회원 가입을 활성화 하기" | ||||
|   openRegistrationWarning: "회원 가입을 개방하는 것은 리스크가 따릅니다. 서버를 항상 감시할 수 있고, 문제가 발생했을 때 바로 대응할 수 있는 상태에서만 활성화 하는 것을 권장합니다." | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "일정 기간동안 모더레이터의 활동이 감지되지 않는 경우, 스팸 방지를 위해 이 설정은 자동으로 꺼집니다." | ||||
| _accountMigration: | ||||
|   moveFrom: "다른 계정에서 이 계정으로 이사" | ||||
|   moveFromSub: "다른 계정에 대한 별칭을 생성" | ||||
| @@ -1973,7 +2021,6 @@ _theme: | ||||
|     buttonBg: "버튼 배경" | ||||
|     buttonHoverBg: "버튼 배경 (호버)" | ||||
|     inputBorder: "입력 필드 테두리" | ||||
|     listItemHoverBg: "리스트 항목 배경 (호버)" | ||||
|     driveFolderBg: "드라이브 폴더 배경" | ||||
|     wallpaperOverlay: "배경화면 오버레이" | ||||
|     badge: "배지" | ||||
| @@ -1989,7 +2036,7 @@ _sfx: | ||||
| _soundSettings: | ||||
|   driveFile: "드라이브에 있는 오디오를 사용" | ||||
|   driveFileWarn: "드라이브에 있는 파일을 선택하세요." | ||||
|   driveFileTypeWarn: "이 파일은 지원되지 않습니다." | ||||
|   driveFileTypeWarn: "이 파이" | ||||
|   driveFileTypeWarnDescription: "오디오 파일을 선택하세요." | ||||
|   driveFileDurationWarn: "오디오가 너무 깁니다" | ||||
|   driveFileDurationWarnDescription: "긴 오디오로 설정할 경우 미스키 사용에 지장이 갈 수도 있습니다. 그래도 괜찮습니까?" | ||||
| @@ -2140,8 +2187,11 @@ _auth: | ||||
|   permissionAsk: "이 앱은 다음의 권한을 요청합니다" | ||||
|   pleaseGoBack: "앱으로 돌아가서 시도해 주세요" | ||||
|   callback: "앱으로 돌아갑니다" | ||||
|   accepted: "접근 권한이 부여되었습니다." | ||||
|   denied: "접근이 거부되었습니다" | ||||
|   scopeUser: "다음 사용자로 활동하고 있습니다." | ||||
|   pleaseLogin: "어플리케이션의 접근을 허가하려면 로그인하십시오." | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "접근을 허용하면 자동으로 다음 URL로 이동합니다." | ||||
| _antennaSources: | ||||
|   all: "모든 노트" | ||||
|   homeTimeline: "팔로우중인 유저의 노트" | ||||
| @@ -2392,6 +2442,7 @@ _notification: | ||||
|   followedBySomeUsers: "{n}명에게 팔로우됨" | ||||
|   flushNotification: "알림 이력을 초기화" | ||||
|   exportOfXCompleted: "{x} 추출에 성공했습니다." | ||||
|   login: "로그인 알림이 있습니다" | ||||
|   _types: | ||||
|     all: "전부" | ||||
|     note: "사용자의 새 글" | ||||
| @@ -2407,6 +2458,7 @@ _notification: | ||||
|     roleAssigned: "역할이 부여 됨" | ||||
|     achievementEarned: "도전 과제 획득" | ||||
|     exportCompleted: "추출을 성공함" | ||||
|     login: "로그인" | ||||
|     test: "알림 테스트" | ||||
|     app: "연동된 앱을 통한 알림" | ||||
|   _actions: | ||||
| @@ -2473,6 +2525,8 @@ _webhookSettings: | ||||
|     abuseReport: "유저로부터 신고를 받았을 때" | ||||
|     abuseReportResolved: "받은 신고를 처리했을 때" | ||||
|     userCreated: "유저가 생성되었을 때" | ||||
|     inactiveModeratorsWarning: "모더레이터가 일정 기간동안 활동하지 않은 경우" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "모더레이터가 일정 기간 활동하지 않아 시스템에 의해 초대제로 바뀐 경우" | ||||
|   deleteConfirm: "Webhook을 삭제할까요?" | ||||
|   testRemarks: "스위치 오른쪽에 있는 버튼을 클릭하여 더미 데이터를 사용한 테스트용 웹 훅을 보낼 수 있습니다." | ||||
| _abuseReport: | ||||
| @@ -2518,6 +2572,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "파일에 열람주의를 설정" | ||||
|   unmarkSensitiveDriveFile: "파일에 열람주의를 해제" | ||||
|   resolveAbuseReport: "신고 처리" | ||||
|   forwardAbuseReport: "신고 전달" | ||||
|   updateAbuseReportNote: "신고 조정 노트 갱신" | ||||
|   createInvitation: "초대 코드 생성" | ||||
|   createAd: "광고 생성" | ||||
|   deleteAd: "광고 삭제" | ||||
| @@ -2657,7 +2713,7 @@ _urlPreviewSetting: | ||||
|   timeoutDescription: "미리보기를 로딩하는데 걸리는 시간이 정한 시간보다 오래 걸리는 경우, 미리보기를 생성하지 않습니다." | ||||
|   maximumContentLength: "Content-Length의 최대치 (byte)" | ||||
|   maximumContentLengthDescription: "Content-Length가 이 값을 넘어서면 미리보기를 생성하지 않습니다." | ||||
|   requireContentLength: "Content-Length를 얻었을 때만 미리보기 만들기" | ||||
|   requireContentLength: "Content-Length를 받아온 경우에만 " | ||||
|   requireContentLengthDescription: "상대 서버가 Content-Length를 되돌려주지 않는다면 미리보기를 만들지 않습니다." | ||||
|   userAgent: "User-Agent" | ||||
|   userAgentDescription: "미리보기를 얻을 때 사용한 User-Agent를 설정합니다. 비어 있다면 기본값의 User-Agent를 사용합니다." | ||||
| @@ -2673,6 +2729,66 @@ _contextMenu: | ||||
|   app: "애플리케이션" | ||||
|   appWithShift: "Shift 키로 애플리케이션" | ||||
|   native: "브라우저의 UI" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "이 값은 필수 항목입니다." | ||||
|     columnTypeNotSupport: "정규표현 규칙이 type:text인 칼럼만 지원합니다." | ||||
|     patternNotMatch: "이 값은 {pattern} 패턴과 일치하지 않습니다." | ||||
|     notUnique: "이 값은 다른 값과 중복되지 않아야 합니다." | ||||
| _roleSelectDialog: | ||||
|   notSelected: "선택하지 않았습니다." | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "선택한 행을 복사하기" | ||||
|     copySelectionRanges: "선택범위를 복사하기" | ||||
|     deleteSelectionRows: "선택한 행을 삭제" | ||||
|     deleteSelectionRanges: "선택한 행을 삭제" | ||||
|     searchSettings: "검색 설정" | ||||
|     searchSettingCaption: "고급 검색을 설정합니다." | ||||
|     searchLimit: "표시 건수" | ||||
|     sortOrder: "정렬 순서" | ||||
|     registrationLogs: "등록 로그" | ||||
|     registrationLogsCaption: "이모지를 갱신하거나 삭제할 때 로그가 표시됩니다. 갱신 또는 삭제하거나, 페이지 이동, 새로 고침하면 삭제됩니다." | ||||
|     alertEmojisRegisterFailedDescription: "이모지를 갱신 또는 삭제하지 못했습니다. 자세한 내용은 등록 로그를 확인해주세요." | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "성공 로그를 표시" | ||||
|     failureLogNothing: "실패 로그가 없습니다." | ||||
|     logNothing: "로그가 없습니다." | ||||
|   _remote: | ||||
|     selectionRowDetail: "선택 행 (상세)" | ||||
|     importSelectionRows: "선택 행을 가져오기" | ||||
|     importSelectionRangesRows: "선택한 범위 안의 행을 가져오기" | ||||
|     importEmojisButton: "선택한 이모지를 가져오기" | ||||
|     confirmImportEmojisTitle: "이모지 가져오기" | ||||
|     confirmImportEmojisDescription: "리모트 서버에서 받아온 이모지 {count}개를 이 서버로 가져옵니다. 이모지의 저작권, 라이선스를 확실히 확인하셨다면 실행해주세요." | ||||
|   _local: | ||||
|     tabTitleList: "등록한 이모지 리스트" | ||||
|     tabTitleRegister: "이모지 등록" | ||||
|     _list: | ||||
|       emojisNothing: "등록한 이모지가 없습니다." | ||||
|       markAsDeleteTargetRows: "선택한 행을 삭제할 대상으로 하기" | ||||
|       markAsDeleteTargetRanges: "선택한 범위의 행을 삭제 대상으로 하기" | ||||
|       alertUpdateEmojisNothingDescription: "변경할 이모지가 없습니다." | ||||
|       alertDeleteEmojisNothingDescription: "삭제 대상의 이모지는 없습니다." | ||||
|       confirmMovePage: "페이지를 이동할까요?" | ||||
|       confirmChangeView: "표시를 바꿀까요?" | ||||
|       confirmUpdateEmojisDescription: "{count}개의 이모지를 갱신합니다. 실행할까요?" | ||||
|       confirmDeleteEmojisDescription: "선택한 이모지 {count}개를 삭제합니다. 실행할까요?" | ||||
|       confirmResetDescription: "지금까지 했던 변경 내용이 모두 초기화됩니다." | ||||
|       confirmMovePageDesciption: "이 페이지의 이모지에 변경이 있습니다.\n저장하지 않은 상태로 페이지를 이동하면, 이 페이지에서 바꾼 변경 내용이 모두 지워집니다." | ||||
|       dialogSelectRoleTitle: "이모지에 설정된 역할을 검색" | ||||
|     _register: | ||||
|       uploadSettingTitle: "업로드 설정" | ||||
|       uploadSettingDescription: "여기서 이모지를 업로드 할 때의 동작을 설정할 수 있습니다." | ||||
|       directoryToCategoryLabel: "디렉토리 이름을 \"category\"로 입력하기" | ||||
|       directoryToCategoryCaption: "디렉토리를 드래그 앤 드롭한 경우, 디렉토리 이름을 \"category\"로 입력합니다." | ||||
|       emojiInputAreaCaption: "이모지를 등록할 방법을 선택해주세요." | ||||
|       emojiInputAreaList1: "이 틀 안에 이미지 파일 또는 디렉토리를 끌어서 가져오기" | ||||
|       emojiInputAreaList2: "이 링크를 클릭해서 PC에서 선택하기" | ||||
|       emojiInputAreaList3: "이 링크를 클릭해서 드라이브에서 선택하기" | ||||
|       confirmRegisterEmojisDescription: "리스트에 표시되어진 이모지를 새로운 커스텀 이모지로 등록합니다. 실행할까요? (부하를 피하기 위해, 한 번에 등록할 수 있는 이모지는 {count}건까지 입니다.)" | ||||
|       confirmClearEmojisDescription: "편집 내용을 지우고, 목록에 표시되어진 이모지를 지웁니다. 실행할까요?" | ||||
|       confirmUploadEmojisDescription: "드래그 앤 드롭한 {count}개의 파일을 드라이브에 업로드 합니다. 실행할까요?" | ||||
| _embedCodeGen: | ||||
|   title: "임베디드 코드를 커스터마이즈" | ||||
|   header: "해더를 표시" | ||||
| @@ -2687,3 +2803,43 @@ _embedCodeGen: | ||||
|   generateCode: "임베디드 코드를 만들기" | ||||
|   codeGenerated: "코드를 만들었습니다." | ||||
|   codeGeneratedDescription: "만들어진 코드를 웹 사이트에 붙여서 사용하세요." | ||||
| _selfXssPrevention: | ||||
|   warning: "경고" | ||||
|   title: "“이 화면에 뭔가를 붙여넣어라\"는 것은 모두 사기입니다." | ||||
|   description1: "여기에 무언가를 붙여넣으면 악의적인 사용자에게 계정을 탈취당하거나 개인정보를 도용당할 수 있습니다." | ||||
|   description2: "붙여 넣으려는 항목이 무엇인지 정확히 이해하지 못하는 경우, %c지금 바로 작업을 중단하고 이 창을 닫으십시오." | ||||
|   description3: "자세한 내용은 여기를 확인해 주세요.  {link}" | ||||
| _followRequest: | ||||
|   recieved: "받은 신청" | ||||
|   sent: "보낸 신청" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "이 서버와 통신할 수 없음" | ||||
|     description: "이 서버와의 통신이 비활성화 되었거나, 이 서버를 차단 중이거나 서버에게 차단되었을 수 있습니다.\n서버 관리자에게 문의하세요." | ||||
|   _uriInvalid: | ||||
|     title: "URI가 잘못되었습니다." | ||||
|     description: "입력한 URI에 문제가 있습니다. URI에 쓸 수 없는 문자를 넣었는지 확인해보세요." | ||||
|   _requestFailed: | ||||
|     title: "요청을 실패했습니다." | ||||
|     description: "해당 서버와 통신을 실패했습니다. 상대방 서버에 접속 불가능한 상태일 수도 있습니다. 또는 잘못된 URI 또는 없는 URI를 입력했는지 확인해보세요." | ||||
|   _responseInvalid: | ||||
|     title: "유효하지 않은 반응입니다." | ||||
|     description: "이 서버와 통신할 수 있지만, 데이터가 올바르지 않습니다." | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "입력된 URI과 실제 URI가 다릅니다. 제 3자 서버를 통한 리모트 컨텐츠를 조회하는 경우, 원래 서버 측에서 받아올 수 있는 URI를 사용하여 조회하시길 바랍니다." | ||||
|   _noSuchObject: | ||||
|     title: "찾을 수 없습니다" | ||||
|     description: "요구된 리소스를 찾을 수 없습니다. URI를 다시 한 번 확인해보세요." | ||||
| _captcha: | ||||
|   verify: "CAPTCHA를 먼저 해결하세요." | ||||
|   testSiteKeyMessage: "사이트 키와 비밀 키에 테스트용 값을 입력하여 미리보기를 확인할 수 있습니다.\n자세한 내용은 아래 페이지를 확인해보세요." | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "CAPTCHA 요구에 실패했습니다." | ||||
|       text: "잠시 후에 다시 실행하거나, 설정을 다시 한 번 확인해보세요." | ||||
|     _verificationFailed: | ||||
|       title: "CAPTCHA 검증을 실패했습니다." | ||||
|       text: "설정이 올바른지 다시 한 번 확인해보세요." | ||||
|     _unknown: | ||||
|       title: "CAPTCHA 에러" | ||||
|       text: "알 수 없는 에러가 발생했습니다." | ||||
|   | ||||
| @@ -299,7 +299,6 @@ enableLocalTimeline: "ເປີດໃຊ້ທາມລາຍທ້ອງຖິ | ||||
| enableGlobalTimeline: "ເປີດໃຊ້ທາມລາຍທົ່ວໂລກ" | ||||
| disablingTimelinesInfo: "ຜູ້ດູແລລະບບແລະຜູ້ຄວບຄຸມຈະສາມາດເຂົ້າເຖີງໄທມ໌ໄລນ໌ທັ້ງເບີດ ເຖີງວ່າຈະບໍ່ໄດ້ເປີດໃຊ້ງານກໍ່ຕາມ" | ||||
| registration: "ລົງທະບຽນ" | ||||
| enableRegistration: "ເປີດໃຊ້ການລົງທະບຽນຜູ້ໃຊ້ໃໝ່" | ||||
| invite: "ເຊີນ" | ||||
| driveCapacityPerLocalAccount: "ຄວາມຈຸຂອງ drive ຕໍ່ຜູ້ໃຊ້ທ້ອງຖິ່ນ" | ||||
| driveCapacityPerRemoteAccount: "ຄວາມຈຸຂອງ drive ຕໍ່ຜູ້ໃຊ້ໄລຍະໄກ" | ||||
| @@ -456,6 +455,7 @@ _notification: | ||||
|     renote: "Renote" | ||||
|     quote: "ອ້າງອີງ" | ||||
|     reaction: "Reaction" | ||||
|     login: "ເຂົ້າສູ່ລະບົບ" | ||||
|   _actions: | ||||
|     reply: "ຕອບກັບ" | ||||
|     renote: "Renote" | ||||
| @@ -474,3 +474,6 @@ _abuseReport: | ||||
|       mail: "ອີເມວ" | ||||
| _moderationLogTypes: | ||||
|   suspend: "ລະງັບ" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "ບໍ່ພົບ" | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "Zoeken" | ||||
| notifications: "Meldingen" | ||||
| username: "Gebruikersnaam" | ||||
| password: "Wachtwoord" | ||||
| initialPasswordForSetup: "Initiële wachtwoord voor configuratie" | ||||
| initialPasswordIsIncorrect: "Initiële wachtwoord voor configuratie is onjuist" | ||||
| initialPasswordForSetupDescription: "Gebruik het initiële wachtwoord uit de configuratie, als je Misskey zelf hebt geïnstalleerd.\nAls je een Misskey hosting provider gebruikt, gebruik dan het gegeven wachtwoord.\nAls je geen wachtwoord hebt gezet, laat het dan leeg om verder te gaan." | ||||
| forgotPassword: "Wachtwoord vergeten" | ||||
| fetchingAsApObject: "Ophalen vanuit de Fediverse" | ||||
| ok: "Ok" | ||||
| @@ -108,9 +111,12 @@ enterEmoji: "Voer een emoji in" | ||||
| renote: "Herdelen" | ||||
| unrenote: "Stop herdelen" | ||||
| renoted: "Herdeeld" | ||||
| renotedToX: "Renoted naar {name}" | ||||
| cantRenote: "Dit bericht kan niet worden herdeeld" | ||||
| cantReRenote: "Een herdeling kan niet worden herdeeld" | ||||
| quote: "Quote" | ||||
| renoteToChannel: "Renote naar kanaal" | ||||
| renoteToOtherChannel: "Renote naar ander kanaal" | ||||
| pinnedNote: "Vastgemaakte notitie" | ||||
| pinned: "Vastmaken aan profielpagina" | ||||
| you: "Jij" | ||||
| @@ -119,6 +125,10 @@ sensitive: "NSFW" | ||||
| add: "Toevoegen" | ||||
| reaction: "Reacties" | ||||
| reactions: "Reacties" | ||||
| emojiPicker: "Emoji kiezer" | ||||
| pinnedEmojisForReactionSettingDescription: "Kies de emojis die als eerste getoond worden tijdens het reageren" | ||||
| pinnedEmojisSettingDescription: "Kies de emojis die als eerste getoond worden tijdens het reageren" | ||||
| emojiPickerDisplay: "Emoji kiezer weergave" | ||||
| reactionSettingDescription2: "Sleep om opnieuw te ordenen, Klik om te verwijderen, Druk op \"+\" om toe te voegen" | ||||
| rememberNoteVisibility: "Vergeet niet de notitie zichtbaarheidsinstellingen" | ||||
| attachCancel: "Verwijder bijlage" | ||||
| @@ -140,7 +150,7 @@ selectAntenna: "Kies een antenne" | ||||
| selectWidget: "Kies een widget" | ||||
| editWidgets: "Bewerk widgets" | ||||
| editWidgetsExit: "Klaar" | ||||
| customEmojis: "Maatwerk emoji" | ||||
| customEmojis: "Eigen emoji" | ||||
| emoji: "Emoji" | ||||
| emojis: "Emoji" | ||||
| emojiName: "Naam emoji" | ||||
| @@ -333,7 +343,6 @@ enableLocalTimeline: "Inschakelen lokale tijdlijn" | ||||
| enableGlobalTimeline: "Inschakelen globale tijdlijn " | ||||
| disablingTimelinesInfo: "Beheerders en moderators hebben altijd toegang tot alle tijdlijnen, ook als ze niet actief zijn." | ||||
| registration: "Registreren" | ||||
| enableRegistration: "Inschakelen registratie nieuwe gebruikers " | ||||
| invite: "Uitnodigen" | ||||
| driveCapacityPerLocalAccount: "Opslagruimte per lokale gebruiker" | ||||
| driveCapacityPerRemoteAccount: "Opslagruimte per externe gebruiker" | ||||
| @@ -404,7 +413,31 @@ help: "Help" | ||||
| inputMessageHere: "Voer hier je bericht in" | ||||
| close: "Sluiten" | ||||
| invites: "Uitnodigen" | ||||
| members: "Leden" | ||||
| transfer: "Overdracht" | ||||
| title: "Titel" | ||||
| text: "Tekst" | ||||
| enable: "Inschakelen" | ||||
| next: "Volgende" | ||||
| retype: "Opnieuw invoeren" | ||||
| noteOf: "Notitie van {user}" | ||||
| quoteAttached: "Citaat" | ||||
| quoteQuestion: "Toevoegen als citaat?" | ||||
| invitations: "Uitnodigen" | ||||
| dashboard: "Overzicht" | ||||
| local: "Lokaal" | ||||
| remote: "Remote" | ||||
| total: "Totaal" | ||||
| weekOverWeekChanges: "Wijzigingen sinds vorige week" | ||||
| dayOverDayChanges: "Dagelijkse wijzigingen" | ||||
| appearance: "Weergave" | ||||
| clientSettings: "Clientinstellingen" | ||||
| accountSettings: "Accountinstellingen" | ||||
| promotion: "Promotie" | ||||
| promote: "Promoot" | ||||
| numberOfDays: "Aantal dagen" | ||||
| hideThisNote: "Verberg deze notitie" | ||||
| showFeaturedNotesInTimeline: "Laat featured notities in tijdlijn zien" | ||||
| sound: "Geluid" | ||||
| smtpHost: "Server" | ||||
| smtpUser: "Gebruikersnaam" | ||||
| @@ -486,6 +519,7 @@ _notification: | ||||
|     renote: "Herdelen" | ||||
|     quote: "Quote" | ||||
|     reaction: "Reacties" | ||||
|     login: "Inloggen" | ||||
|   _actions: | ||||
|     reply: "Antwoord" | ||||
|     renote: "Herdelen" | ||||
| @@ -501,3 +535,8 @@ _webhookSettings: | ||||
| _moderationLogTypes: | ||||
|   suspend: "Opschorten" | ||||
|   resetPassword: "Wachtwoord terugzetten" | ||||
| _reversi: | ||||
|   total: "Totaal" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Niet gevonden" | ||||
|   | ||||
| @@ -260,7 +260,6 @@ enableLocalTimeline: "Aktiver lokal tidslinje" | ||||
| enableGlobalTimeline: "Aktiver global tidslinje" | ||||
| disablingTimelinesInfo: "Administratorer og Moderatorer vil alltid ha tilgang til alle tidslinjer, selv om de ikke er aktivert." | ||||
| registration: "Registrer" | ||||
| enableRegistration: "Aktiver registrering av nye brukere" | ||||
| invite: "Inviter" | ||||
| basicInfo: "Grunnleggende informasjon" | ||||
| pinnedUsers: "Festede brukrere" | ||||
| @@ -701,6 +700,7 @@ _notification: | ||||
|     renote: "Renotes" | ||||
|     quote: "Sitater" | ||||
|     reaction: "Reaksjoner" | ||||
|     login: "Logg inn" | ||||
|   _actions: | ||||
|     reply: "Svar" | ||||
|     renote: "Renote" | ||||
| @@ -727,3 +727,6 @@ _abuseReport: | ||||
|       mail: "E-post" | ||||
| _moderationLogTypes: | ||||
|   suspend: "Suspender" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Ikke funnet" | ||||
|   | ||||
| @@ -362,7 +362,6 @@ enableLocalTimeline: "Włącz lokalną oś czasu" | ||||
| enableGlobalTimeline: "Włącz globalną oś czasu" | ||||
| disablingTimelinesInfo: "Administratorzy i moderatorzy będą zawsze mieć dostęp do wszystkich osi czasu, nawet gdy są one wyłączone." | ||||
| registration: "Zarejestruj się" | ||||
| enableRegistration: "Włącz rejestrację nowych użytkowników" | ||||
| invite: "Zaproś" | ||||
| driveCapacityPerLocalAccount: "Powierzchnia dyskowa na lokalnego użytkownika" | ||||
| driveCapacityPerRemoteAccount: "Powierzchnia dyskowa na zdalnego użytkownika" | ||||
| @@ -492,6 +491,10 @@ uiLanguage: "Język wyświetlania UI" | ||||
| aboutX: "O {x}" | ||||
| emojiStyle: "Styl emoji" | ||||
| native: "Natywny" | ||||
| menuStyle: "Styl Menu" | ||||
| style: "Styl" | ||||
| drawer: "Schowek" | ||||
| popup: "Wyskakujące okienka" | ||||
| showNoteActionsOnlyHover: "Pokazuj akcje notatek tylko po najechaniu myszką" | ||||
| showReactionsCount: "Wyświetl liczbę reakcji na notatkę" | ||||
| noHistory: "Brak historii" | ||||
| @@ -574,6 +577,7 @@ ascendingOrder: "Rosnąco" | ||||
| descendingOrder: "Malejąco" | ||||
| scratchpad: "Brudnopis" | ||||
| scratchpadDescription: "Brudnopis zawiera eksperymentalne środowisko dla AiScript. Możesz pisać, wykonywać i sprawdzać wyniki w interakcji z Misskey." | ||||
| uiInspector: "Inspektor UI" | ||||
| output: "Wyjście" | ||||
| script: "Skrypt" | ||||
| disablePagesScript: "Wyłącz AiScript na Stronach" | ||||
| @@ -654,6 +658,7 @@ smtpSecure: "Użyj niejawnego SSL/TLS dla połączeń SMTP" | ||||
| smtpSecureInfo: "Wyłącz, jeżeli używasz STARTTLS" | ||||
| testEmail: "Przetestuj dostarczanie wiadomości e-mail" | ||||
| wordMute: "Wyciszenie słowa" | ||||
| hardWordMute: "Wyciszaj przekleństwa" | ||||
| regexpError: "Błąd wyrażenia regularnego" | ||||
| regexpErrorDescription: "Wystąpił błąd w wyrażeniu regularnym w linii {line} twoich {tab} wyciszeń:" | ||||
| instanceMute: "Wyciszone instancje" | ||||
| @@ -689,10 +694,7 @@ abuseReported: "Twoje zgłoszenie zostało wysłane. Dziękujemy." | ||||
| reporter: "Zgłaszający" | ||||
| reporteeOrigin: "Pochodzenie zgłoszonego" | ||||
| reporterOrigin: "Pochodzenie zgłaszającego" | ||||
| forwardReport: "Przekaż zgłoszenie do innej instancji" | ||||
| forwardReportIsAnonymous: "Zamiast twojego konta, anonimowe konto systemowe będzie wyświetlone jako zgłaszający na instancji zdalnej." | ||||
| send: "Wyślij" | ||||
| abuseMarkAsResolved: "Oznacz zgłoszenie jako rozwiązane" | ||||
| openInNewTab: "Otwórz w nowej karcie" | ||||
| openInSideView: "Otwórz w bocznym widoku" | ||||
| defaultNavigationBehaviour: "Domyślne zachowanie nawigacji" | ||||
| @@ -829,6 +831,7 @@ administration: "Zarządzanie" | ||||
| accounts: "Konta" | ||||
| switch: "Przełącz" | ||||
| noMaintainerInformationWarning: "Informacje o administratorze nie są skonfigurowane." | ||||
| noInquiryUrlWarning: "Adres URL zapytania nie został ustawiony" | ||||
| noBotProtectionWarning: "Zabezpieczenie przed botami nie jest skonfigurowane." | ||||
| configure: "Skonfiguruj" | ||||
| postToGallery: "Opublikuj w galerii" | ||||
| @@ -893,6 +896,7 @@ followersVisibility: "Widoczność obserwujących" | ||||
| continueThread: "Pokaż kontynuację wątku" | ||||
| deleteAccountConfirm: "Spowoduje to nieodwracalne usunięcie Twojego konta. Kontynuować?" | ||||
| incorrectPassword: "Nieprawidłowe hasło." | ||||
| incorrectTotp: "Hasło pojedynczego użytku jest nie poprawne, lub straciło ważność" | ||||
| voteConfirm: "Potwierdzić swój głos na \"{choice}\"?" | ||||
| hide: "Ukryj" | ||||
| useDrawerReactionPickerForMobile: "Wyświetlaj wybornik reakcji jako szufladę na urządzeniach mobilnych" | ||||
| @@ -917,6 +921,10 @@ oneHour: "1 godzina" | ||||
| oneDay: "1 dzień" | ||||
| oneWeek: "1 tydzień" | ||||
| oneMonth: "jeden miesiąc" | ||||
| threeMonths: "3 miesiące" | ||||
| oneYear: "Rok" | ||||
| threeDays: "3 dni" | ||||
| reflectMayTakeTime: "Może minąć trochę czasu, zanim będzie to uwzględnione" | ||||
| failedToFetchAccountInformation: "Nie udało się uzyskać informacji o koncie" | ||||
| rateLimitExceeded: "Limit szybkości przekroczony" | ||||
| cropImage: "Przytnij obraz" | ||||
| @@ -927,9 +935,11 @@ file: "Pliki" | ||||
| recentNHours: "W ciągu ostatnich {n} godzin" | ||||
| recentNDays: "W ciągu ostatnich {n} dni" | ||||
| noEmailServerWarning: "Serwer Email nie jest skonfigurowany" | ||||
| thereIsUnresolvedAbuseReportWarning: "Istnieją niewyjaśnione raporty" | ||||
| recommended: "Zalecane" | ||||
| check: "Zweryfikuj" | ||||
| driveCapOverrideLabel: "Zmień limit pojemności dysku użytkownika" | ||||
| driveCapOverrideCaption: "Resetuje pojemność do wartości domyślnej, przez wpisanie wartości 0 lub niższej" | ||||
| requireAdminForView: "Aby to zobaczyć, musisz być administratorem" | ||||
| isSystemAccount: "To jest konto stworzone i zarządzane przez system" | ||||
| typeToConfirm: "Wprowadź {x}, aby potwierdzić" | ||||
| @@ -998,17 +1008,29 @@ unassign: "Cofnij przydzielenie" | ||||
| color: "Kolor" | ||||
| manageCustomEmojis: "Zarządzaj niestandardowymi Emoji" | ||||
| manageAvatarDecorations: "Zarządzaj dekoracjami awatara" | ||||
| youCannotCreateAnymore: "Limit kreacji został przekroczony" | ||||
| cannotPerformTemporary: "Opcja tymczasowo niedostępna" | ||||
| cannotPerformTemporaryDescription: "Ta akcja nie może zostać wykonana, z powodu przekroczenia limitu wykonań. Prosimy poczekać chwilę i spróbować ponownie" | ||||
| invalidParamError: "Błąd parametrów" | ||||
| invalidParamErrorDescription: "Wartości, które zostały podane są niepoprawne. Zwykle jest to spowodowane bugiem, lecz również może być to spowodowane przekroczeniem limitu wartości, lub podobnym problemem" | ||||
| permissionDeniedError: "Odrzucono operacje" | ||||
| permissionDeniedErrorDescription: "Konto nie posiada uprawnień" | ||||
| preset: "Konfiguracja" | ||||
| selectFromPresets: "Wybierz konfiguracje" | ||||
| achievements: "Osiągnięcia" | ||||
| gotInvalidResponseError: "Niepoprawna odpowiedź serwera" | ||||
| gotInvalidResponseErrorDescription: "Wystąpił problem z Twoim połączeniem z Internetem, lub z serwerem. {Spróbuj ponownie} wkrótce." | ||||
| thisPostMayBeAnnoying: "Ten wpis może obrażać pozostałych użytkowników" | ||||
| thisPostMayBeAnnoyingHome: "Opublikuj na domowej osi czasu" | ||||
| thisPostMayBeAnnoyingCancel: "Odrzuć" | ||||
| thisPostMayBeAnnoyingIgnore: "Zignoruj i wyślij" | ||||
| collapseRenotes: "Zwiń wpisy, które już zobaczyłeś" | ||||
| collapseRenotesDescription: "Zwiń wpisy, na które już zareagowałeś lub udostępniłeś" | ||||
| internalServerError: "Wewnętrzny błąd serwera" | ||||
| internalServerErrorDescription: "Niespodziewany błąd po stronie serwera" | ||||
| copyErrorInfo: "Kopiuj informacje o błędzie" | ||||
| joinThisServer: "Dołącz do chaty" | ||||
| exploreOtherServers: "Szukaj innej instancji" | ||||
| disableFederationOk: "Wyłącz federacje" | ||||
| invitationRequiredToRegister: "Ten serwer wymaga zaproszenia. Tylko osoby z zaproszeniem mogą się zarejestrować" | ||||
| emailNotSupported: "Wysyłanie wiadomości E-mail nie jest obsługiwane na tym serwerze" | ||||
| @@ -1208,7 +1230,6 @@ _theme: | ||||
|     buttonBg: "Tło przycisku" | ||||
|     buttonHoverBg: "Tło przycisku (po najechaniu)" | ||||
|     inputBorder: "Obramowanie pola wejścia" | ||||
|     listItemHoverBg: "Tło elementu listy (po najechaniu)" | ||||
|     driveFolderBg: "Tło folderu na dysku" | ||||
|     wallpaperOverlay: "Nakładka tapety" | ||||
|     badge: "Odznaka" | ||||
| @@ -1509,6 +1530,7 @@ _notification: | ||||
|     reaction: "Reakcja" | ||||
|     receiveFollowRequest: "Otrzymano prośbę o możliwość obserwacji" | ||||
|     followRequestAccepted: "Przyjęto prośbę o możliwość obserwacji" | ||||
|     login: "Zaloguj się" | ||||
|     app: "Powiadomienia z aplikacji" | ||||
|   _actions: | ||||
|     followBack: "zaobserwował cię z powrotem" | ||||
| @@ -1561,3 +1583,6 @@ _moderationLogTypes: | ||||
|   resetPassword: "Zresetuj hasło" | ||||
| _reversi: | ||||
|   total: "Łącznie" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Nie znaleziono" | ||||
|   | ||||
| @@ -1,5 +1,5 @@ | ||||
| --- | ||||
| _lang_: "日本語" | ||||
| _lang_: "Português" | ||||
| headlineMisskey: "Uma rede ligada por notas" | ||||
| introMisskey: "Bem-vindo! O Misskey é um serviço de microblog descentralizado de código aberto.\nCrie \"notas\" para compartilhar o que está acontecendo agora ou para se expressar com todos à sua volta 📡\nVocê também pode adicionar rapidamente reações às notas de outras pessoas usando a função \"Reações\" 👍\nVamos explorar um novo mundo 🚀" | ||||
| poweredByMisskeyDescription: "{name} é uma instância da plataforma de código aberto <b>Misskey</b>." | ||||
| @@ -8,6 +8,9 @@ search: "Pesquisar" | ||||
| notifications: "Notificações" | ||||
| username: "Nome de usuário" | ||||
| password: "Senha" | ||||
| initialPasswordForSetup: "Senha para a configuração inicial" | ||||
| initialPasswordIsIncorrect: "Senha para configuração inicial está incorreta" | ||||
| initialPasswordForSetupDescription: "Use a senha configurada no arquivo de configuração se você instalou o Misskey manualmente.\nSe você estiver utilizando um serviço de hospedagem, utilize a senha fornecida.\nSe uma senha não foi configurada, deixe em branco e continue." | ||||
| forgotPassword: "Esqueci-me da senha" | ||||
| fetchingAsApObject: "Buscando no Fediverso..." | ||||
| ok: "OK" | ||||
| @@ -25,7 +28,7 @@ basicSettings: "Configurações básicas" | ||||
| otherSettings: "Outras configurações" | ||||
| openInWindow: "Abrir em um janela" | ||||
| profile: "Perfil" | ||||
| timeline: "Cronologia" | ||||
| timeline: "Linha do tempo" | ||||
| noAccountDescription: "Este usuário não tem uma descrição." | ||||
| login: "Iniciar sessão" | ||||
| loggingIn: "Iniciando sessão…" | ||||
| @@ -196,7 +199,7 @@ followConfirm: "Tem certeza que quer seguir {name}?" | ||||
| proxyAccount: "Conta proxy" | ||||
| proxyAccountDescription: "Uma conta de proxy é uma conta que assume o acompanhamento remoto de um usuário sob certas condições específicas. Por exemplo, quando um usuário inclui um usuário remoto em uma lista, mas ninguém na lista está seguindo o usuário remoto, a atividade não é entregue ao servidor. Nesse caso, a conta de proxy entra em ação para seguir o usuário remoto em vez disso." | ||||
| host: "Host" | ||||
| selectSelf: "Escolher manualmente" | ||||
| selectSelf: "Selecionar a mim" | ||||
| selectUser: "Selecionar usuário" | ||||
| recipient: "Destinatário" | ||||
| annotation: "Anotação" | ||||
| @@ -236,6 +239,8 @@ silencedInstances: "Instâncias silenciadas" | ||||
| silencedInstancesDescription: "Liste o nome de hospedagem dos servidores que você deseja silenciar, separados por linha. Todas as contas desses servidores serão silenciada e poderão enviar solicitações para seguir, mas não poderão mencionar usuários locais sem segui-los. Isso não afetará servidores bloqueados." | ||||
| mediaSilencedInstances: "Instâncias com mídia silenciadas" | ||||
| mediaSilencedInstancesDescription: "Liste o nome de hospedagem dos servidores cuja mídia você deseja silenciar, separados por linha. Todas as contas desses servidores serão consideradas sensíveis e não poderão utilizar emojis personalizados. Isso não afetará servidores bloqueados." | ||||
| federationAllowedHosts: "Servidores com federação permitida" | ||||
| federationAllowedHostsDescription: "Especifique o endereço dos servidores em que deseja permitir a federação separados por linha." | ||||
| muteAndBlock: "Silenciar e bloquear" | ||||
| mutedUsers: "Usuários silenciados" | ||||
| blockedUsers: "Usuários bloqueados" | ||||
| @@ -334,6 +339,7 @@ renameFolder: "Renomear Pasta" | ||||
| deleteFolder: "Excluir pasta" | ||||
| folder: "Pasta" | ||||
| addFile: "Adicionar arquivo" | ||||
| showFile: "Mostrar arquivos" | ||||
| emptyDrive: "O drive está vazio" | ||||
| emptyFolder: "A pasta está vazia" | ||||
| unableToDelete: "Não é possível excluir" | ||||
| @@ -376,7 +382,6 @@ enableLocalTimeline: "Ativar linha do tempo local" | ||||
| enableGlobalTimeline: "Ativar linha do tempo global" | ||||
| disablingTimelinesInfo: "Se você desabilitar essas linhas do tempo, administradores e moderadores ainda poderão usá-las por conveniência." | ||||
| registration: "Registar" | ||||
| enableRegistration: "Permitir que qualquer pessoa se registre" | ||||
| invite: "Convidar" | ||||
| driveCapacityPerLocalAccount: "Capacidade do drive por usuário local" | ||||
| driveCapacityPerRemoteAccount: "Capacidade do drive por usuário remoto" | ||||
| @@ -448,6 +453,7 @@ totpDescription: "Digite a senha de uso único informado pelo aplicativo autenti | ||||
| moderator: "Moderador" | ||||
| moderation: "Moderação" | ||||
| moderationNote: "Nota de moderação" | ||||
| moderationNoteDescription: "Você pode preencher notas que serão compartilhadas apenas com moderadores." | ||||
| addModerationNote: "Adicionar nota de moderação" | ||||
| moderationLogs: "Logs de moderação" | ||||
| nUsersMentioned: "Postado por {n} pessoas" | ||||
| @@ -509,6 +515,10 @@ uiLanguage: "Idioma de exibição da interface " | ||||
| aboutX: "Sobre {x}" | ||||
| emojiStyle: "Estilo de emojis" | ||||
| native: "Nativo" | ||||
| menuStyle: "Estilo do menu" | ||||
| style: "Estilo" | ||||
| drawer: "Gaveta" | ||||
| popup: "Pop-up" | ||||
| showNoteActionsOnlyHover: "Exibir as ações da nota somente ao passar o cursor sobre ela" | ||||
| showReactionsCount: "Ver o número de reações nas notas" | ||||
| noHistory: "Ainda não há histórico" | ||||
| @@ -576,6 +586,7 @@ masterVolume: "volume principal" | ||||
| notUseSound: "Desabilitar som" | ||||
| useSoundOnlyWhenActive: "Apenas reproduzir sons quando Misskey estiver aberto." | ||||
| details: "Detalhes" | ||||
| renoteDetails: "Detalhes da repostagem" | ||||
| chooseEmoji: "Selecione um emoji" | ||||
| unableToProcess: "Não é possível concluir a operação" | ||||
| recentUsed: "Usado recentemente" | ||||
| @@ -591,6 +602,8 @@ ascendingOrder: "Ascendente" | ||||
| descendingOrder: "Descendente" | ||||
| scratchpad: "Bloco de rascunho" | ||||
| scratchpadDescription: "O Bloco de rascunho fornece um ambiente experimental para AiScript. Permite escrever, executar e verificar os resultados do código para interagir com o Misskey." | ||||
| uiInspector: "Inspecionador de interface" | ||||
| uiInspectorDescription: "Você pode ver a lista de servidores de componentes de interface na memória. Componentes da interface serão gerados pela função Ui:C:." | ||||
| output: "Resultado" | ||||
| script: "Script" | ||||
| disablePagesScript: "Desabilitar scripts nas páginas" | ||||
| @@ -671,7 +684,7 @@ smtpSecure: "Use SSL/TLS implícito para conexões SMTP" | ||||
| smtpSecureInfo: "Desative esta opção ao utilizar STARTTLS." | ||||
| testEmail: "Testar envio de e-mail" | ||||
| wordMute: "Silenciar palavras" | ||||
| hardWordMute: "SIlenciamento pesado de palavra" | ||||
| hardWordMute: "Silenciar palavras (esconder posts)" | ||||
| regexpError: "Erro na expressão regular" | ||||
| regexpErrorDescription: "Ocorreu um erro na expressão regular na linha {line} da palavra mutada {tab}:" | ||||
| instanceMute: "Instâncias silenciadas" | ||||
| @@ -707,10 +720,7 @@ abuseReported: "Denúncia enviada. Obrigado por sua ajuda." | ||||
| reporter: "Denunciante" | ||||
| reporteeOrigin: "Origem da denúncia" | ||||
| reporterOrigin: "Origem do denunciante" | ||||
| forwardReport: "Encaminhar a denúncia para o servidor remoto" | ||||
| forwardReportIsAnonymous: "No servidor remoto, suas informações não serão visíveis, e você será apresentado como uma conta do sistema anônima." | ||||
| send: "Enviar" | ||||
| abuseMarkAsResolved: "Marcar denúncia como resolvida" | ||||
| openInNewTab: "Abrir em nova aba" | ||||
| openInSideView: "Abrir em visão lateral" | ||||
| defaultNavigationBehaviour: "Navegação padrão" | ||||
| @@ -912,6 +922,7 @@ followersVisibility: "Visibilidade dos seguidores" | ||||
| continueThread: "Ver mais desta conversa" | ||||
| deleteAccountConfirm: "Deseja realmente excluir a conta?" | ||||
| incorrectPassword: "Senha inválida." | ||||
| incorrectTotp: "A senha de uso único está incorreta ou expirou." | ||||
| voteConfirm: "Deseja confirmar o seu voto em \"{choice}\"?" | ||||
| hide: "Ocultar" | ||||
| useDrawerReactionPickerForMobile: "Mostrar em formato de gaveta" | ||||
| @@ -936,6 +947,9 @@ oneHour: "1 hora" | ||||
| oneDay: "1 dia" | ||||
| oneWeek: "1 semana" | ||||
| oneMonth: "1 mês" | ||||
| threeMonths: "3 meses" | ||||
| oneYear: "1 ano" | ||||
| threeDays: "3 dias" | ||||
| reflectMayTakeTime: "As mudanças podem demorar a aparecer." | ||||
| failedToFetchAccountInformation: "Não foi possível obter informações da conta" | ||||
| rateLimitExceeded: "Taxa limite excedido" | ||||
| @@ -1061,7 +1075,7 @@ resetPasswordConfirm: "Deseja realmente mudar a sua senha?" | ||||
| sensitiveWords: "Palavras sensíveis" | ||||
| sensitiveWordsDescription: "A visibilidade de todas as notas contendo as palavras configuradas será colocadas como \"Início\" automaticamente. Você pode listar várias delas separando-as por linha." | ||||
| sensitiveWordsDescription2: "Utilizar espaços irá criar expressões aditivas (AND) e cercar palavras-chave com barras irá transformá-las em expressões regulares (RegEx)" | ||||
| prohibitedWords: "Palavras proibídas" | ||||
| prohibitedWords: "Palavras proibidas" | ||||
| prohibitedWordsDescription: "Habilita um erro ao tentar publicar uma nota contendo as palavras escolhidas. Várias palavras podem ser escolhidas, separando-as por linha." | ||||
| prohibitedWordsDescription2: "Utilizar espaços irá criar expressões aditivas (AND) e cercar palavras-chave com barras irá transformá-las em expressões regulares (RegEx)" | ||||
| hiddenTags: "Hashtags escondidas" | ||||
| @@ -1076,6 +1090,7 @@ retryAllQueuesConfirmTitle: "Gostaria de tentar novamente agora?" | ||||
| retryAllQueuesConfirmText: "Isso irá temporariamente aumentar a carga do servidor." | ||||
| enableChartsForRemoteUser: "Gerar gráficos estatísticos de usuários remotos" | ||||
| enableChartsForFederatedInstances: "Gerar gráficos estatísticos de instâncias remotas" | ||||
| enableStatsForFederatedInstances: "Receber estatísticas de servidores remotos" | ||||
| showClipButtonInNoteFooter: "Adicionar \"Clip\" ao menu de ação de notas" | ||||
| reactionsDisplaySize: "Tamanho de exibição das reações" | ||||
| limitWidthOfReaction: "Limita o comprimento máximo de reações e as exibe em tamanho reduzido" | ||||
| @@ -1262,7 +1277,49 @@ confirmWhenRevealingSensitiveMedia: "Confirmar ao revelar mídia sensível" | ||||
| sensitiveMediaRevealConfirm: "Essa mídia pode ser sensível. Deseja revelá-la?" | ||||
| createdLists: "Listas criadas" | ||||
| createdAntennas: "Antenas criadas" | ||||
| fromX: "De {x}" | ||||
| genEmbedCode: "Gerar código de embed" | ||||
| noteOfThisUser: "Notas por este usuário" | ||||
| clipNoteLimitExceeded: "Não é possível adicionar mais notas ao clipe." | ||||
| performance: "Desempenho" | ||||
| modified: "Modificado" | ||||
| discard: "Descartar" | ||||
| thereAreNChanges: "Há {n} mudança(s)" | ||||
| signinWithPasskey: "Entrar com Passkey" | ||||
| unknownWebAuthnKey: "Passkey desconhecida" | ||||
| passkeyVerificationFailed: "A verificação com Passkey falhou." | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "A verificação com Passkey teve êxito, mas a entrada sem senha está desabilitada." | ||||
| messageToFollower: "Mensagem aos seguidores" | ||||
| target: "Alvo" | ||||
| testCaptchaWarning: "Essa função é utilizada apenas para testar CAPTCHA. <strong>Não a use num ambiente de produção.</strong>" | ||||
| prohibitedWordsForNameOfUser: "Palavras proibidas para nomes de usuário" | ||||
| prohibitedWordsForNameOfUserDescription: "Se quaisquer palavras dessa lista forem incluídas no nome de usuário, seu uso será negado. Usuários com privilégios de moderador não serão afetados pela restrição." | ||||
| yourNameContainsProhibitedWords: "O seu nome possui palavras proibidas" | ||||
| yourNameContainsProhibitedWordsDescription: "Se você deseja utilizar esse nome, entre em contato com o administrador do servidor." | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "O autor exige que você esteja cadastrado para ver" | ||||
| lockdown: "Lockdown" | ||||
| pleaseSelectAccount: "Selecione uma conta" | ||||
| availableRoles: "Cargos disponíveis" | ||||
| acknowledgeNotesAndEnable: "Ative após compreender as precauções." | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "Exigir cadastro para ver o conteúdo" | ||||
|   requireSigninToViewContentsDescription1: "Exigir cadastro para ver todas as notas e outro conteúdo que você criou. Isso previne 'crawlers' de coletar os seus dados." | ||||
|   requireSigninToViewContentsDescription2: "Conteúdo não será exibido nas prévias de URL (OGP), incorporado em outras páginas web ou em servidores que não têm suporte a citações." | ||||
|   requireSigninToViewContentsDescription3: "Essas restrições podem não ser aplicadas a conteúdo federado de outros servidores." | ||||
|   makeNotesFollowersOnlyBefore: "Tornar notas passadas visíveis apenas para seguidores." | ||||
|   makeNotesFollowersOnlyBeforeDescription: "Com essa função ativada, apenas seguidores podem ver as notas anteriores à data e hora marcadas. Se isso for desativado, o status de publicação da nota será reestabelecido." | ||||
|   makeNotesHiddenBefore: "Tornar notas passadas privadas" | ||||
|   makeNotesHiddenBeforeDescription: "Com essa função ativada, apenas você poderá ver as notas anteriores à data e hora marcadas. Se isso for desativado, o status de publicação da nota será reestabelecido." | ||||
|   mayNotEffectForFederatedNotes: "Notas federadas a servidores remotos podem não ser afetadas." | ||||
|   notesHavePassedSpecifiedPeriod: "Notas que duraram um tempo específico." | ||||
|   notesOlderThanSpecifiedDateAndTime: "Notas antes do tempo específico." | ||||
| _abuseUserReport: | ||||
|   forward: "Encaminhar" | ||||
|   forwardDescription: "Encaminhar a denúncia ao servidor remoto como uma conta anônima do sistema." | ||||
|   resolve: "Resolver" | ||||
|   accept: "Aceitar" | ||||
|   reject: "Rejeitar" | ||||
|   resolveTutorial: "Se a denúncia for legítima em conteúdo, selecione \"Aceitar\" para marcar o caso como resolvido afirmativamente.\nSe a denúncia for ilegítima em conteúdo, selecione \"Rejeitar\" para marcar o caso como resolvido negativamente." | ||||
| _delivery: | ||||
|   status: "Estado de entrega" | ||||
|   stop: "Suspenso" | ||||
| @@ -1397,8 +1454,12 @@ _serverSettings: | ||||
|   fanoutTimelineDescription: "Melhora significativamente a performance do retorno da linha do tempo e reduz o impacto no banco de dados quando habilitado. Em contrapartida, o uso de memória do Redis aumentará. Considere desabilitar em casos de baixa disponibilidade de memória ou instabilidade do servidor." | ||||
|   fanoutTimelineDbFallback: "\"Fallback\" ao banco de dados" | ||||
|   fanoutTimelineDbFallbackDescription: "Quando habilitado, a linha do tempo irá recuar ao banco de dados caso consultas adicionais sejam feitas e ela não estiver em cache. Quando desabilitado, o impacto no servidor será reduzido ao eliminar o recuo, mas limita a quantidade de linhas do tempo que podem ser recebidas." | ||||
|   reactionsBufferingDescription: "Quando ativado, o desempenho durante a criação de uma reação será melhorado substancialmente, reduzindo a carga do banco de dados. Porém, a o uso de memória do Redis irá aumentar." | ||||
|   inquiryUrl: "URL de inquérito" | ||||
|   inquiryUrlDescription: "Especifique um URL para um formulário de inquérito para a administração ou uma página web com informações de contato." | ||||
|   openRegistration: "Abrir a criação de contas" | ||||
|   openRegistrationWarning: "Abrir cadastros contém riscos. É recomendado apenas habilitá-los se houver um sistema de monitoramento contínuo e resolução imediata de problemas." | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "Se nenhuma atividade da moderação for detectada por um tempo, essa configuração será desativada para prevenir spam." | ||||
| _accountMigration: | ||||
|   moveFrom: "Migrar outra conta para essa" | ||||
|   moveFromSub: "Criar um 'alias' a outra conta" | ||||
| @@ -1419,7 +1480,7 @@ _achievements: | ||||
|   _types: | ||||
|     _notes1: | ||||
|       title: "Configurando o meu misskey" | ||||
|       description: "Post uma nota pela primeira vez" | ||||
|       description: "Poste uma nota pela primeira vez" | ||||
|       flavor: "Divirta-se com o Misskey!" | ||||
|     _notes10: | ||||
|       title: "Algumas notas" | ||||
| @@ -1730,6 +1791,11 @@ _role: | ||||
|     canSearchNotes: "Permitir a busca de notas" | ||||
|     canUseTranslator: "Uso do tradutor" | ||||
|     avatarDecorationLimit: "Número máximo de decorações de avatar que podem ser aplicadas" | ||||
|     canImportAntennas: "Permitir importação de antenas" | ||||
|     canImportBlocking: "Permitir importação de bloqueios" | ||||
|     canImportFollowing: "Permitir importação de usuários seguidos" | ||||
|     canImportMuting: "Permitir importação de silenciamentos" | ||||
|     canImportUserLists: "Permitir importação de listas" | ||||
|   _condition: | ||||
|     roleAssignedTo: "Atribuído a cargos manuais" | ||||
|     isLocal: "Usuário local" | ||||
| @@ -1947,7 +2013,6 @@ _theme: | ||||
|     buttonBg: "Plano de fundo de botão" | ||||
|     buttonHoverBg: "Plano de fundo de botão (Selecionado)" | ||||
|     inputBorder: "Borda de campo digitável" | ||||
|     listItemHoverBg: "Plano de fundo do item de uma lista (Selecionado)" | ||||
|     driveFolderBg: "Plano de fundo da pasta no Drive" | ||||
|     wallpaperOverlay: "Sobreposição do papel de parede." | ||||
|     badge: "Emblema" | ||||
| @@ -2114,8 +2179,11 @@ _auth: | ||||
|   permissionAsk: "O aplicativo solicita as seguintes permissões" | ||||
|   pleaseGoBack: "Por favor, volte ao aplicativo" | ||||
|   callback: "Retornando ao aplicativo" | ||||
|   accepted: "Acesso permitido" | ||||
|   denied: "Acesso negado" | ||||
|   scopeUser: "Operar como o usuário a seguir" | ||||
|   pleaseLogin: "Por favor, entre para autorizar aplicativos." | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "Quando o acesso for permitido, você será redirecionado para o seguinte endereço" | ||||
| _antennaSources: | ||||
|   all: "Todas as notas" | ||||
|   homeTimeline: "Notas de usuários seguidos" | ||||
| @@ -2224,6 +2292,9 @@ _profile: | ||||
|   changeBanner: "Mudar banner" | ||||
|   verifiedLinkDescription: "Ao inserir um URL que contém um link para essa conta, um ícone de verificação será exibido ao lado do campo" | ||||
|   avatarDecorationMax: "Você pode adicionar até {max} decorações." | ||||
|   followedMessage: "Mensagem exibida quando alguém segue você" | ||||
|   followedMessageDescription: "Você pode definir uma curta mensagem que será exibida aos usuários que seguirem você." | ||||
|   followedMessageDescriptionForLockedAccount: "Se você aceita pedidos de seguidor manualmente, isso será exibido quando você aceitá-los." | ||||
| _exportOrImport: | ||||
|   allNotes: "Todas as notas" | ||||
|   favoritedNotes: "Notas nos favoritos" | ||||
| @@ -2362,6 +2433,8 @@ _notification: | ||||
|   renotedBySomeUsers: "{n} usuários repostaram a nota" | ||||
|   followedBySomeUsers: "{n} usuários te seguiram" | ||||
|   flushNotification: "Limpar notificações" | ||||
|   exportOfXCompleted: "Exportação de {x} foi concluída" | ||||
|   login: "Alguém entrou na conta" | ||||
|   _types: | ||||
|     all: "Todas" | ||||
|     note: "Novas notas" | ||||
| @@ -2376,6 +2449,9 @@ _notification: | ||||
|     followRequestAccepted: "Aceitou pedidos de seguidor" | ||||
|     roleAssigned: "Cargo dado" | ||||
|     achievementEarned: "Conquista desbloqueada" | ||||
|     exportCompleted: "A exportação foi concluída" | ||||
|     login: "Iniciar sessão" | ||||
|     test: "Notificação teste" | ||||
|     app: "Notificações de aplicativos conectados" | ||||
|   _actions: | ||||
|     followBack: "te seguiu de volta" | ||||
| @@ -2441,7 +2517,10 @@ _webhookSettings: | ||||
|     abuseReport: "Quando receber um relatório de abuso" | ||||
|     abuseReportResolved: "Quando relatórios de abuso forem resolvidos " | ||||
|     userCreated: "Quando um usuário é criado" | ||||
|     inactiveModeratorsWarning: "Quando moderadores estiverem inativos por um tempo" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "Quando um moderador está inativo por um tempo e os cadastros passam a exigir convites" | ||||
|   deleteConfirm: "Você tem certeza de que deseja excluir o Webhook?" | ||||
|   testRemarks: "Clique no botão à direita do interruptor para enviar um Webhook de teste com dados fictícios." | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     createRecipient: "Adicionar destinatário para relatórios de abuso" | ||||
| @@ -2485,6 +2564,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "Arquivo marcado como sensível" | ||||
|   unmarkSensitiveDriveFile: "Arquivo desmarcado como sensível" | ||||
|   resolveAbuseReport: "Relatório resolvido" | ||||
|   forwardAbuseReport: "Denúncia encaminhada" | ||||
|   updateAbuseReportNote: "Nota de moderação da denúncia atualizada" | ||||
|   createInvitation: "Convite gerado" | ||||
|   createAd: "Propaganda criada" | ||||
|   deleteAd: "Propaganda excluída" | ||||
| @@ -2640,3 +2721,44 @@ _contextMenu: | ||||
|   app: "Aplicativo" | ||||
|   appWithShift: "Aplicativo com a tecla shift" | ||||
|   native: "Nativo" | ||||
| _embedCodeGen: | ||||
|   title: "Personalizar código do embed" | ||||
|   header: "Exibir cabeçalho" | ||||
|   autoload: "Carregar mais automaticamente (obsoleto)" | ||||
|   maxHeight: "Altura máxima" | ||||
|   maxHeightDescription: "Colocar em 0 desabilita a altura máxima. Especifique um valor para prevenir uma expansão vertical contínua." | ||||
|   maxHeightWarn: "O limite de altura máxima está desabilitado (0). Se isso não for intencional, insira um valor para a altura máxima." | ||||
|   previewIsNotActual: "A exibição difere do embed original porque ela excede o tamanho da tela de prévia." | ||||
|   rounded: "Tornar arredondado" | ||||
|   border: "Adicionar uma borda ao quadro externo" | ||||
|   applyToPreview: "Aplicar para a prévia" | ||||
|   generateCode: "Gerar código de embed" | ||||
|   codeGenerated: "O código foi gerado" | ||||
|   codeGeneratedDescription: "Coloque o código no seu website para incorporar o conteúdo." | ||||
| _selfXssPrevention: | ||||
|   warning: "AVISO" | ||||
|   title: "\"Cole algo nessa tela\" é uma fraude" | ||||
|   description1: "Se você colar algo aqui, um usuário malicioso pode sabotar a sua conta ou roubar informações pessoais." | ||||
|   description2: "Se você não entender exatamente o que está colando, %cpare agora e feche essa janela." | ||||
|   description3: "Para mais informação, clique no link. {link}" | ||||
| _followRequest: | ||||
|   recieved: "Aplicação recebida" | ||||
|   sent: "Aplicação enviada" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "Não foi possível se comunicar com o servidor" | ||||
|     description: "Comunicação com esse servidor pode ter sido desabilitada ou o servidor pode ter sido bloqueado.\nPor favor, entre em contato com o administrador do servidor." | ||||
|   _uriInvalid: | ||||
|     title: "Endereço inválido" | ||||
|     description: "Há um problema com o endereço inserido. Por favor, confira se você não inseriu caracteres inválidos." | ||||
|   _requestFailed: | ||||
|     title: "Solicitação falhou" | ||||
|     description: "Comunicação com esse servidor falhou. O servidor pode estar inativo. Além disso, confira se você não inseriu um endereço inválido ou inexistente." | ||||
|   _responseInvalid: | ||||
|     title: "Resposta inválida" | ||||
|     description: "Foi possível comunicar com o servidor, porém os dados obtidos foram incorretos." | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "O domínio do endereço inserido difere do domínio do endereço final. Se você estiver pesquisando por um servidor de terceiros, tente buscar novamente com um endereço que pode ser obtido através do servidor original." | ||||
|   _noSuchObject: | ||||
|     title: "Não encontrado" | ||||
|     description: "O recurso solicitado não foi encontrado, confira o endereço." | ||||
|   | ||||
| @@ -341,7 +341,6 @@ enableLocalTimeline: "Activează cronologia locală" | ||||
| enableGlobalTimeline: "Activeaza cronologia globală" | ||||
| disablingTimelinesInfo: "Administratorii și Moderatorii vor avea mereu access la toate cronologiile, chiar dacă nu sunt activate." | ||||
| registration: "Inregistrare" | ||||
| enableRegistration: "Activează înregistrările pentru utilizatori noi" | ||||
| invite: "Invită" | ||||
| driveCapacityPerLocalAccount: "Capacitatea Drive-ului per utilizator local" | ||||
| driveCapacityPerRemoteAccount: "Capacitatea Drive-ului per utilizator extern" | ||||
| @@ -625,10 +624,7 @@ abuseReported: "Raportul tău a fost trimis. Mulțumim." | ||||
| reporter: "Raportorul" | ||||
| reporteeOrigin: "Originea raportatului" | ||||
| reporterOrigin: "Originea raportorului" | ||||
| forwardReport: "Redirecționează raportul către instanța externă" | ||||
| forwardReportIsAnonymous: "În locul contului tău, va fi afișat un cont anonim, de sistem, ca raportor către instanța externă." | ||||
| send: "Trimite" | ||||
| abuseMarkAsResolved: "Marchează raportul ca rezolvat" | ||||
| openInNewTab: "Deschide în tab nou" | ||||
| openInSideView: "Deschide în vedere laterală" | ||||
| defaultNavigationBehaviour: "Comportament de navigare implicit" | ||||
| @@ -714,6 +710,7 @@ _notification: | ||||
|     renote: "Re-notează" | ||||
|     quote: "Citează" | ||||
|     reaction: "Reacție" | ||||
|     login: "Autentifică-te" | ||||
|   _actions: | ||||
|     reply: "Răspunde" | ||||
|     renote: "Re-notează" | ||||
| @@ -736,3 +733,6 @@ _moderationLogTypes: | ||||
|   resetPassword: "Resetează parola" | ||||
| _reversi: | ||||
|   total: "Total" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Nu a fost găsit" | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "Поиск" | ||||
| notifications: "Уведомления" | ||||
| username: "Имя пользователя" | ||||
| password: "Пароль" | ||||
| initialPasswordForSetup: "Пароль для начала настройки" | ||||
| initialPasswordIsIncorrect: "Пароль для запуска настройки неверен" | ||||
| initialPasswordForSetupDescription: "Если вы установили Misskey самостоятельно, используйте пароль, который вы указали в файле конфигурации.\nЕсли вы используете что-то вроде хостинга Misskey, используйте предоставленный пароль.\nЕсли вы не установили пароль, оставьте его пустым и продолжайте." | ||||
| forgotPassword: "Забыли пароль?" | ||||
| fetchingAsApObject: "Приём с других сайтов" | ||||
| ok: "Подтвердить" | ||||
| @@ -15,7 +18,7 @@ gotIt: "Ясно!" | ||||
| cancel: "Отмена" | ||||
| noThankYou: "Нет, спасибо" | ||||
| enterUsername: "Введите имя пользователя" | ||||
| renotedBy: "{user} репостнул(а)" | ||||
| renotedBy: "{user} делает репост" | ||||
| noNotes: "Нет ни одной заметки" | ||||
| noNotifications: "Нет уведомлений" | ||||
| instance: "Экземпляр" | ||||
| @@ -232,6 +235,7 @@ clearCachedFilesConfirm: "Удалить все закэшированные ф | ||||
| blockedInstances: "Заблокированные инстансы" | ||||
| blockedInstancesDescription: "Введите список инстансов, которые хотите заблокировать. Они больше не смогут обмениваться с вашим инстансом." | ||||
| silencedInstances: "Заглушённые инстансы" | ||||
| federationAllowedHosts: "Серверы, поддерживающие федерацию" | ||||
| muteAndBlock: "Скрытие и блокировка" | ||||
| mutedUsers: "Скрытые пользователи" | ||||
| blockedUsers: "Заблокированные пользователи" | ||||
| @@ -330,6 +334,7 @@ renameFolder: "Переименовать папку" | ||||
| deleteFolder: "Удалить папку" | ||||
| folder: "Папка" | ||||
| addFile: "Добавить файл" | ||||
| showFile: "Посмотреть файл" | ||||
| emptyDrive: "Диск пуст" | ||||
| emptyFolder: "Папка пуста" | ||||
| unableToDelete: "Удаление невозможно" | ||||
| @@ -372,7 +377,6 @@ enableLocalTimeline: "Включить локальную ленту" | ||||
| enableGlobalTimeline: "Включить глобальную ленту" | ||||
| disablingTimelinesInfo: "У администраторов и модераторов есть доступ ко всем лентам, даже если они отключены." | ||||
| registration: "Регистрация" | ||||
| enableRegistration: "Разрешить регистрацию" | ||||
| invite: "Пригласить" | ||||
| driveCapacityPerLocalAccount: "Объём Диска на одного локального пользователя" | ||||
| driveCapacityPerRemoteAccount: "Объём Диска на одного пользователя с другого экземпляра" | ||||
| @@ -443,6 +447,7 @@ totp: "Приложение-аутентификатор" | ||||
| totpDescription: "Описание приложения-аутентификатора" | ||||
| moderator: "Модератор" | ||||
| moderation: "Модерация" | ||||
| moderationNote: "Примечания модератора" | ||||
| moderationLogs: "Журнал модерации" | ||||
| nUsersMentioned: "Упомянуло пользователей: {n}" | ||||
| securityKeyAndPasskey: "Ключ безопасности и парольная фраза" | ||||
| @@ -503,6 +508,8 @@ uiLanguage: "Язык интерфейса" | ||||
| aboutX: "Описание {x}" | ||||
| emojiStyle: "Стиль эмодзи" | ||||
| native: "Системные" | ||||
| menuStyle: "Стиль меню" | ||||
| style: "Стиль" | ||||
| showNoteActionsOnlyHover: "Показывать кнопки у заметок только при наведении" | ||||
| showReactionsCount: "Видеть количество реакций на заметках" | ||||
| noHistory: "История пока пуста" | ||||
| @@ -700,10 +707,7 @@ abuseReported: "Жалоба отправлена. Большое спасибо | ||||
| reporter: "Сообщивший" | ||||
| reporteeOrigin: "О ком сообщено" | ||||
| reporterOrigin: "Кто сообщил" | ||||
| forwardReport: "Отправить жалобу на инстанс автора." | ||||
| forwardReportIsAnonymous: "Жалоба на удалённый инстанс будет отправлена анонимно. Вместо ваших данных у получателя будет отображена системная учётная запись." | ||||
| send: "Отправить" | ||||
| abuseMarkAsResolved: "Отметить жалобу как решённую" | ||||
| openInNewTab: "Открыть в новой вкладке" | ||||
| openInSideView: "Открывать в боковой колонке" | ||||
| defaultNavigationBehaviour: "Поведение навигации по умолчанию" | ||||
| @@ -1059,7 +1063,7 @@ hiddenTags: "Скрытые хештеги" | ||||
| notesSearchNotAvailable: "Поиск заметок недоступен" | ||||
| license: "Лицензия" | ||||
| unfavoriteConfirm: "Удалить избранное?" | ||||
| myClips: "Мои клипы" | ||||
| myClips: "Мои подборки" | ||||
| drivecleaner: "Очиститель дисков" | ||||
| retryAllQueuesNow: "Повторить все очереди сейчас" | ||||
| retryAllQueuesConfirmTitle: "Хотите попробовать ещё раз?" | ||||
| @@ -1101,16 +1105,18 @@ preservedUsernames: "Зарезервированные имена пользо | ||||
| preservedUsernamesDescription: "Перечислите зарезервированные имена пользователей, отделяя их строками. Они станут недоступны при создании учётной записи. Это ограничение не применяется при создании учётной записи администраторами. Также, уже существующие учётные записи останутся без изменений." | ||||
| createNoteFromTheFile: "Создать заметку из этого файла" | ||||
| archive: "Архив" | ||||
| unarchive: "Разархивировать" | ||||
| channelArchiveConfirmTitle: "Переместить {name} в архив?" | ||||
| channelArchiveConfirmDescription: "Архивированные каналы перестанут отображаться в списке каналов или результатах поиска. В них также нельзя будет добавлять новые записи." | ||||
| thisChannelArchived: "Этот канал находится в архиве." | ||||
| displayOfNote: "Отображение заметок" | ||||
| initialAccountSetting: "Настройка профиля" | ||||
| youFollowing: "Подписки" | ||||
| youFollowing: "Вы подписаны" | ||||
| preventAiLearning: "Отказаться от использования в машинном обучении (Генеративный ИИ)" | ||||
| preventAiLearningDescription: "Запросить краулеров не использовать опубликованный текст или изображения и т.д. для машинного обучения (Прогнозирующий / Генеративный ИИ) датасетов. Это достигается путём добавления \"noai\" HTTP-заголовка в ответ на соответствующий контент. Полного предотвращения через этот заголовок не избежать, так как он может быть просто проигнорирован." | ||||
| options: "Настройки ролей" | ||||
| specifyUser: "Указанный пользователь" | ||||
| lookupConfirm: "Хотите узнать?" | ||||
| openTagPageConfirm: "Открыть страницу этого хештега?" | ||||
| specifyHost: "Указать сайт" | ||||
| failedToPreviewUrl: "Предварительный просмотр недоступен" | ||||
| @@ -1174,6 +1180,7 @@ keepOriginalFilename: "Сохранять исходное имя файла" | ||||
| keepOriginalFilenameDescription: "Если вы выключите данную настройку, имена файлов будут автоматически заменены случайной строкой при загрузке." | ||||
| alwaysConfirmFollow: "Всегда подтверждать подписку" | ||||
| inquiry: "Связаться" | ||||
| messageToFollower: "Сообщение подписчикам" | ||||
| _delivery: | ||||
|   stop: "Заморожено" | ||||
|   _type: | ||||
| @@ -1500,6 +1507,7 @@ _role: | ||||
|     rateLimitFactor: "Ограничение активности" | ||||
|     descriptionOfRateLimitFactor: "Меньшее значение — слабые ограничения, большее — сильные" | ||||
|     canHideAds: "Может скрыть рекламу" | ||||
|     canImportFollowing: "Можно импортировать подписчиков" | ||||
|   _condition: | ||||
|     isLocal: "Местный" | ||||
|     isRemote: "Неместный" | ||||
| @@ -1697,7 +1705,6 @@ _theme: | ||||
|     buttonBg: "Фон кнопки" | ||||
|     buttonHoverBg: "Текст кнопки" | ||||
|     inputBorder: "Рамка поля ввода" | ||||
|     listItemHoverBg: "Фон пункта списка (под указателем)" | ||||
|     driveFolderBg: "Фон папки «Диска»" | ||||
|     wallpaperOverlay: "Слой обоев" | ||||
|     badge: "Значок" | ||||
| @@ -2046,6 +2053,7 @@ _notification: | ||||
|     receiveFollowRequest: "Получен запрос на подписку" | ||||
|     followRequestAccepted: "Запрос на подписку одобрен" | ||||
|     achievementEarned: "Получение достижений" | ||||
|     login: "Войти" | ||||
|     app: "Уведомления из приложений" | ||||
|   _actions: | ||||
|     followBack: "отвечает взаимной подпиской" | ||||
| @@ -2139,3 +2147,6 @@ _hemisphere: | ||||
|   caption: "Используется для некоторых настроек клиента для определения сезона." | ||||
| _reversi: | ||||
|   total: "Всего" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Не найдено" | ||||
|   | ||||
| @@ -17,3 +17,6 @@ _sfx: | ||||
|   note: "නෝට්" | ||||
| _profile: | ||||
|   username: "පරිශීලක නාමය" | ||||
| _notification: | ||||
|   _types: | ||||
|     login: "පිවිසෙන්න" | ||||
|   | ||||
| @@ -331,7 +331,6 @@ enableLocalTimeline: "Povoliť lokálnu časovú os" | ||||
| enableGlobalTimeline: "Povoliť globálnu časovú os" | ||||
| disablingTimelinesInfo: "Administrátori a moderátori majú vždy prístup ku všetkým časovým osiam, aj keď sú vypnuté." | ||||
| registration: "Registrácia" | ||||
| enableRegistration: "Povoliť registráciu nových používateľov" | ||||
| invite: "Pozvať" | ||||
| driveCapacityPerLocalAccount: "Kapacita disku pre používateľa" | ||||
| driveCapacityPerRemoteAccount: "Kapacita disku pre vzdialeného používateľa" | ||||
| @@ -631,10 +630,7 @@ abuseReported: "Vaše nahlásenie je odoslané. Veľmi pekne ďakujeme." | ||||
| reporter: "Nahlásil" | ||||
| reporteeOrigin: "Pôvod nahláseného" | ||||
| reporterOrigin: "Pôvod nahlasovača" | ||||
| forwardReport: "Preposlať nahlásenie na server" | ||||
| forwardReportIsAnonymous: "Namiesto vášho účtu bude zobrazený anonymný systémový účet na vzdialenom serveri ako autor nahlásenia." | ||||
| send: "Poslať" | ||||
| abuseMarkAsResolved: "Označiť nahlásenia ako vyriešené" | ||||
| openInNewTab: "Otvoriť v novom tabe" | ||||
| openInSideView: "Otvoriť v bočnom paneli" | ||||
| defaultNavigationBehaviour: "Predvolené správanie navigácie" | ||||
| @@ -1111,7 +1107,6 @@ _theme: | ||||
|     buttonBg: "Pozadie tlačidla" | ||||
|     buttonHoverBg: "Pozadie tlačidla (pod kurzorom)" | ||||
|     inputBorder: "Okraj vstupného poľa" | ||||
|     listItemHoverBg: "Pozadie položky zoznamu (pod kurzorom)" | ||||
|     driveFolderBg: "Pozadie priečinu disku" | ||||
|     wallpaperOverlay: "Vrstvenie pozadia" | ||||
|     badge: "Odznak" | ||||
| @@ -1409,6 +1404,7 @@ _notification: | ||||
|     pollEnded: "Hlasovanie skončilo" | ||||
|     receiveFollowRequest: "Doručené žiadosti o sledovanie" | ||||
|     followRequestAccepted: "Schválené žiadosti o sledovanie" | ||||
|     login: "Prihlásiť sa" | ||||
|     app: "Oznámenia z prepojených aplikácií" | ||||
|   _actions: | ||||
|     followBack: "Sledovať späť\n" | ||||
| @@ -1453,3 +1449,6 @@ _moderationLogTypes: | ||||
|   resetPassword: "Resetovať heslo" | ||||
| _reversi: | ||||
|   total: "Celkom" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Nenájdené" | ||||
|   | ||||
| @@ -333,7 +333,6 @@ disconnectService: "Koppla från" | ||||
| enableLocalTimeline: "Aktivera lokal tidslinje" | ||||
| enableGlobalTimeline: "Aktivera global tidslinje" | ||||
| registration: "Registrera" | ||||
| enableRegistration: "Aktivera registrering av nya användare" | ||||
| invite: "Inbjudan" | ||||
| inMb: "I megabyte" | ||||
| bannerUrl: "URL till banner-bilden" | ||||
| @@ -385,6 +384,7 @@ passwordLessLoginDescription: "Tillåter lösenordsfri inloggning med endast en | ||||
| resetPassword: "Återställ Lösenord" | ||||
| newPasswordIs: "Det nya lösenordet är \"{password}\"" | ||||
| share: "Dela" | ||||
| markAsReadAllTalkMessages: "Markera alla meddelanden som lästa" | ||||
| help: "Hjälp" | ||||
| close: "Stäng" | ||||
| invites: "Inbjudan" | ||||
| @@ -393,12 +393,15 @@ transfer: "Överför" | ||||
| text: "Text" | ||||
| enable: "Aktivera" | ||||
| next: "Nästa" | ||||
| retype: "Ange igen" | ||||
| noMessagesYet: "Inga meddelanden än" | ||||
| invitations: "Inbjudan" | ||||
| invitationCode: "Inbjudningskod" | ||||
| available: "Tillgängligt" | ||||
| weakPassword: "Svagt Lösenord" | ||||
| normalPassword: "Medel Lösenord" | ||||
| strongPassword: "Starkt Lösenord" | ||||
| signinWith: "Logga in med {x}" | ||||
| signinFailed: "Kan inte logga in. Det angivna användarnamnet eller lösenordet är felaktigt." | ||||
| or: "eller" | ||||
| language: "Språk" | ||||
| @@ -410,70 +413,124 @@ existingAccount: "Existerande konto" | ||||
| regenerate: "Regenerera" | ||||
| fontSize: "Textstorlek" | ||||
| openImageInNewTab: "Öppna bild i ny flik" | ||||
| appearance: "Utseende" | ||||
| clientSettings: "Klientinställningar" | ||||
| accountSettings: "Kontoinställningar" | ||||
| numberOfDays: "Antal dagar" | ||||
| objectStorageUseSSL: "Använd SSL" | ||||
| serverLogs: "Serverloggar" | ||||
| deleteAll: "Radera alla" | ||||
| sounds: "Ljud" | ||||
| sound: "Ljud" | ||||
| listen: "Lyssna" | ||||
| none: "Ingen" | ||||
| volume: "Volym" | ||||
| notUseSound: "Inaktivera ljud" | ||||
| chooseEmoji: "Välj en emoji" | ||||
| recentUsed: "Senast använd" | ||||
| install: "Installera" | ||||
| uninstall: "Avinstallera" | ||||
| deleteAllFiles: "Radera alla filer" | ||||
| deleteAllFilesConfirm: "Är du säker på att du vill radera alla filer?" | ||||
| menu: "Meny" | ||||
| addItem: "Lägg till objekt" | ||||
| serviceworkerInfo: "Måste vara aktiverad för pushnotiser." | ||||
| enableInfiniteScroll: "Ladda mer automatiskt" | ||||
| enablePlayer: "Öppna videospelare" | ||||
| description: "Beskrivning" | ||||
| permission: "Behörigheter" | ||||
| enableAll: "Aktivera alla" | ||||
| disableAll: "Inaktivera alla" | ||||
| edit: "Ändra" | ||||
| enableEmail: "Aktivera epost-utskick" | ||||
| email: "E-post" | ||||
| emailAddress: "E-postadress" | ||||
| smtpHost: "Värd" | ||||
| smtpUser: "Användarnamn" | ||||
| smtpPass: "Lösenord" | ||||
| emptyToDisableSmtpAuth: "Lämna användarnamn och lösenord tomt för att avaktivera SMTP verifiering" | ||||
| makeActive: "Aktivera" | ||||
| copy: "Kopiera" | ||||
| overview: "Översikt" | ||||
| logs: "Logg" | ||||
| database: "Databas" | ||||
| channel: "kanal" | ||||
| create: "Skapa" | ||||
| other: "Mer" | ||||
| abuseReports: "Rapporter" | ||||
| reportAbuse: "Rapporter" | ||||
| reportAbuseOf: "Rapportera {name}" | ||||
| abuseReported: "Din rapport har skickats. Tack så mycket." | ||||
| send: "Skicka" | ||||
| openInNewTab: "Öppna i ny flik" | ||||
| createNew: "Skapa ny" | ||||
| private: "Privat" | ||||
| i18nInfo: "Misskey översätts till många olika språk av volontärer. Du kan hjälpa till med översättningen på {link}." | ||||
| accountInfo: "Kontoinformation" | ||||
| followersCount: "Antal följare" | ||||
| yes: "Ja" | ||||
| no: "Nej" | ||||
| clips: "Klipp" | ||||
| duplicate: "Duplicera" | ||||
| reloadToApplySetting: "Inställningen tillämpas efter sidan laddas om. Vill du göra det nu?" | ||||
| clearCache: "Rensa cache" | ||||
| onlineUsersCount: "{n} användare är online" | ||||
| nUsers: "{n} användare" | ||||
| nNotes: "{n} Noter" | ||||
| backgroundColor: "Bakgrundsbild" | ||||
| textColor: "Text" | ||||
| saveAs: "Spara som..." | ||||
| saveConfirm: "Spara ändringar?" | ||||
| youAreRunningUpToDateClient: "Klienten du använder är uppdaterat." | ||||
| newVersionOfClientAvailable: "Ny version av klienten är tillgänglig." | ||||
| editCode: "Redigera kod" | ||||
| publish: "Publicera" | ||||
| typingUsers: "{users} skriver" | ||||
| goBack: "Tillbaka" | ||||
| addDescription: "Lägg till beskrivning" | ||||
| info: "Om" | ||||
| online: "Online" | ||||
| active: "Aktiv" | ||||
| offline: "Offline" | ||||
| enabled: "Aktiverad" | ||||
| quickAction: "Snabbåtgärder" | ||||
| user: "Användare" | ||||
| gallery: "Galleri" | ||||
| popularPosts: "Populära inlägg" | ||||
| customCssWarn: "Den här inställningen borde bara ändrats av en som har rätta kunskaper. Om du ställer in det här fel så kan klienten sluta fungera rätt." | ||||
| global: "Global" | ||||
| squareAvatars: "Visa fyrkantiga profilbilder" | ||||
| sent: "Skicka" | ||||
| searchResult: "Sökresultat" | ||||
| learnMore: "Läs mer" | ||||
| misskeyUpdated: "Misskey har uppdaterats!" | ||||
| translate: "Översätt" | ||||
| controlPanel: "Kontrollpanel" | ||||
| manageAccounts: "Hantera konton" | ||||
| incorrectPassword: "Fel lösenord." | ||||
| hide: "Dölj" | ||||
| welcomeBackWithName: "Välkommen tillbaka, {name}" | ||||
| clickToFinishEmailVerification: "Tryck på [{ok}] för att slutföra bekräftelsen på e-postadressen." | ||||
| size: "Storlek" | ||||
| searchByGoogle: "Sök" | ||||
| indefinitely: "Aldrig" | ||||
| tenMinutes: "10 minuter" | ||||
| oneHour: "En timme" | ||||
| oneDay: "En dag" | ||||
| oneWeek: "En vecka" | ||||
| oneMonth: "En månad" | ||||
| threeMonths: "3 månader" | ||||
| oneYear: "1 år" | ||||
| threeDays: "3 dagar" | ||||
| file: "Filer" | ||||
| deleteAccount: "Radera konto" | ||||
| label: "Etikett" | ||||
| cannotUploadBecauseNoFreeSpace: "Kan inte ladda upp filen för att det finns inget lagringsutrymme kvar." | ||||
| cannotUploadBecauseExceedsFileSizeLimit: "Kan inte ladda upp filen för att den är större än filstorleksgränsen." | ||||
| beta: "Beta" | ||||
| enableAutoSensitive: "Automatisk NSFW markering" | ||||
| enableAutoSensitiveDescription: "Tillåter automatiskt detektering och marketing av NSFW media genom Maskininlärning när möjligt. Även om denna inställningen är avaktiverad, kan det vara aktiverat på hela instansen." | ||||
| move: "Flytta" | ||||
| pushNotification: "Pushnotiser" | ||||
| subscribePushNotification: "Aktivera pushnotiser" | ||||
| unsubscribePushNotification: "Avaktivera pushnotiser" | ||||
| @@ -482,38 +539,86 @@ pushNotificationNotSupported: "Din webbläsare eller instans har inte stöd för | ||||
| windowMaximize: "Maximera" | ||||
| windowMinimize: "Minimera" | ||||
| windowRestore: "Återställ" | ||||
| tools: "Verktyg" | ||||
| like: "Gilla" | ||||
| pleaseDonate: "Misskey är en gratis programvara som används på {host}. Donera gärna för att göra utvecklingen ständigt, tack!" | ||||
| roles: "Roll" | ||||
| role: "Roll" | ||||
| color: "Färg" | ||||
| resetPasswordConfirm: "Återställ verkligen ditt lösenord?" | ||||
| dataSaver: "Databesparing" | ||||
| icon: "Profilbild" | ||||
| forYou: "För dig" | ||||
| replies: "Svara" | ||||
| renotes: "Omnotera" | ||||
| loadReplies: "Visa svar" | ||||
| loadConversation: "Visa konversation" | ||||
| authentication: "Autentisering" | ||||
| sourceCode: "Källkod" | ||||
| doReaction: "Lägg till reaktion" | ||||
| code: "Kod" | ||||
| gameRetry: "Försök igen" | ||||
| inquiry: "Kontakt" | ||||
| tryAgain: "Försök igen senare" | ||||
| signinWithPasskey: "Logga in med nyckel" | ||||
| unknownWebAuthnKey: "Okänd nyckel" | ||||
| _delivery: | ||||
|   stop: "Suspenderad" | ||||
|   _type: | ||||
|     none: "Publiceras" | ||||
| _initialAccountSetting: | ||||
|   profileSetting: "Profilinställningar" | ||||
| _initialTutorial: | ||||
|   _reaction: | ||||
|     title: "Vad är reaktioner?" | ||||
| _achievements: | ||||
|   _types: | ||||
|     _open3windows: | ||||
|       title: "Flera Fönster" | ||||
|       description: "Ha minst 3 fönster öppna samtidigt" | ||||
| _role: | ||||
|   edit: "Redigera roll" | ||||
| _ffVisibility: | ||||
|   public: "Publicera" | ||||
|   private: "Privat" | ||||
| _accountDelete: | ||||
|   accountDelete: "Radera konto" | ||||
| _ad: | ||||
|   back: "Tillbaka" | ||||
| _gallery: | ||||
|   like: "Gilla" | ||||
| _email: | ||||
|   _follow: | ||||
|     title: "följde dig" | ||||
| _aboutMisskey: | ||||
|   source: "Källkod" | ||||
|   projectMembers: "Projektmedlemmar" | ||||
| _channel: | ||||
|   setBanner: "Välj banner" | ||||
|   removeBanner: "Ta bort banner" | ||||
|   nameAndDescription: "Namn och beskrivning" | ||||
| _menuDisplay: | ||||
|   hide: "Dölj" | ||||
| _theme: | ||||
|   description: "Beskrivning" | ||||
|   color: "Färg" | ||||
|   keys: | ||||
|     mention: "Nämn" | ||||
|     renote: "Omnotera" | ||||
| _sfx: | ||||
|   note: "Noter" | ||||
|   notification: "Notifikationer" | ||||
| _ago: | ||||
|   justNow: "Just nu" | ||||
| _2fa: | ||||
|   step3Title: "Ange en autentiseringskod" | ||||
|   renewTOTPCancel: "Nej tack" | ||||
| _permissions: | ||||
|   "read:reactions": "Visa dina reaktioner" | ||||
|   "write:reactions": "Redigera dina reaktioner" | ||||
|   "write:admin:delete-account": "Radera användarkonto" | ||||
|   "write:admin:roles": "Hantera roller" | ||||
|   "read:admin:roles": "Visa roller" | ||||
| _antennaSources: | ||||
|   all: "Alla noter" | ||||
|   homeTimeline: "Noter från följda användare" | ||||
| @@ -530,13 +635,19 @@ _widgets: | ||||
|   _userList: | ||||
|     chooseList: "Välj lista" | ||||
| _cw: | ||||
|   hide: "Dölj" | ||||
|   show: "Ladda mer" | ||||
|   chars: "{count} tecken" | ||||
|   files: "{count} fil(er)" | ||||
| _poll: | ||||
|   infinite: "Aldrig" | ||||
| _visibility: | ||||
|   home: "Hem" | ||||
|   followers: "Följare" | ||||
| _profile: | ||||
|   name: "Namn" | ||||
|   username: "Användarnamn" | ||||
|   metadataLabel: "Etikett" | ||||
|   changeAvatar: "Ändra profilbild" | ||||
|   changeBanner: "Ändra banner" | ||||
| _exportOrImport: | ||||
| @@ -547,9 +658,12 @@ _exportOrImport: | ||||
|   userLists: "Listor" | ||||
| _charts: | ||||
|   federation: "Federation" | ||||
|   activeUsers: "Aktiva användare" | ||||
| _timelines: | ||||
|   home: "Hem" | ||||
|   global: "Global" | ||||
| _play: | ||||
|   summary: "Beskrivning" | ||||
| _pages: | ||||
|   blocks: | ||||
|     image: "Bilder" | ||||
| @@ -562,10 +676,13 @@ _notification: | ||||
|     renote: "Omnotera" | ||||
|     quote: "Citat" | ||||
|     reaction: "Reaktioner" | ||||
|     login: "Logga in" | ||||
|   _actions: | ||||
|     reply: "Svara" | ||||
|     renote: "Omnotera" | ||||
| _deck: | ||||
|   addColumn: "Lägg till kolumn" | ||||
|   deleteProfile: "Radera profil" | ||||
|   _columns: | ||||
|     notifications: "Notifikationer" | ||||
|     tl: "Tidslinje" | ||||
| @@ -583,3 +700,10 @@ _abuseReport: | ||||
| _moderationLogTypes: | ||||
|   suspend: "Suspendera" | ||||
|   resetPassword: "Återställ Lösenord" | ||||
| _reversi: | ||||
|   blackOrWhite: "Svart/Vit" | ||||
|   rules: "Regler" | ||||
|   black: "Svart" | ||||
|   white: "Vit" | ||||
| _selfXssPrevention: | ||||
|   warning: "VARNING" | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "ค้นหา" | ||||
| notifications: "เเจ้งเตือน" | ||||
| username: "ชื่อผู้ใช้" | ||||
| password: "รหัสผ่าน" | ||||
| initialPasswordForSetup: "รหัสผ่านเริ่มต้นสำหรับการตั้งค่า" | ||||
| initialPasswordIsIncorrect: "รหัสผ่านเริ่มต้นสำหรับตั้งค่านั้นไม่ถูกต้องค่ะ" | ||||
| initialPasswordForSetupDescription: "ถ้าหากคุณติดตั้ง Misskey เอง ให้ใช้รหัสผ่านที่คุณป้อนในไฟล์กำหนดค่า \nถ้าหากคุณกำลังใช้บริการโฮสต์ Misskey ให้ใช้รหัสผ่านที่ได้รับมา\nถ้ายังไม่มีรหัสผ่าน ให้ข้ามช่องรหัสผ่านไป แล้วกดต่อไป" | ||||
| forgotPassword: "ลืมรหัสผ่าน" | ||||
| fetchingAsApObject: "กำลังดึงข้อมูลจากสหพันธ์..." | ||||
| ok: "ตกลง" | ||||
| @@ -236,6 +239,8 @@ silencedInstances: "ปิดปากเซิร์ฟเวอร์นี้ | ||||
| silencedInstancesDescription: "ระบุโฮสต์ของเซิร์ฟเวอร์ที่ต้องการปิดปาก คั่นด้วยการขึ้นบรรทัดใหม่, บัญชีทั้งหมดของเซิร์ฟเวอร์ดังกล่าวจะถือว่าถูกปิดปากเช่นกัน ทำได้เฉพาะคำขอติดตามเท่านั้น และไม่สามารถกล่าวถึงบัญชีในเซิร์ฟเวอร์นี้ได้หากไม่ได้ถูกติดตามกลับ | สิ่งนี้ไม่มีผลต่ออินสแตนซ์ที่ถูกบล็อก" | ||||
| mediaSilencedInstances: "เซิร์ฟเวอร์ที่ถูกปิดปากสื่อ" | ||||
| mediaSilencedInstancesDescription: "ระบุโฮสต์ของเซิร์ฟเวอร์ที่ต้องการปิดปากสื่อ คั่นด้วยการขึ้นบรรทัดใหม่, ไฟล์ที่ถูกส่งจากบัญชีของเซิร์ฟเวอร์ดังกล่าวจะถือว่าถูกปิดปาก แล้วจะถูกติดเครื่องหมายว่ามีเนื้อหาละเอียดอ่อน และเอโมจิแบบกำหนดเองก็จะใช้ไม่ได้ด้วย | สิ่งนี้ไม่มีผลต่ออินสแตนซ์ที่ถูกบล็อก" | ||||
| federationAllowedHosts: "เซิร์ฟเวอร์ที่เปิดให้บริการแบบเฟเดอเรชั่น" | ||||
| federationAllowedHostsDescription: "ระบุชื่อโฮสต์ของเซิร์ฟเวอร์ที่คุณต้องการอนุญาตให้เชื่อมต่อแบบเฟเดอเรชั่น โดยต้องเว้นวรรคแต่ละบรรทัด" | ||||
| muteAndBlock: "ปิดเสียงและบล็อก" | ||||
| mutedUsers: "ผู้ใช้ที่ถูกปิดเสียง" | ||||
| blockedUsers: "ผู้ใช้ที่ถูกบล็อก" | ||||
| @@ -334,6 +339,7 @@ renameFolder: "เปลี่ยนชื่อโฟลเดอร์" | ||||
| deleteFolder: "ลบโฟลเดอร์" | ||||
| folder: "โฟลเดอร์" | ||||
| addFile: "เพิ่มไฟล์" | ||||
| showFile: "แสดงไฟล์" | ||||
| emptyDrive: "ไดรฟ์ของคุณว่างเปล่านะ" | ||||
| emptyFolder: "โฟลเดอร์นี้ว่างเปล่า" | ||||
| unableToDelete: "ไม่สามารถลบออกได้" | ||||
| @@ -376,7 +382,6 @@ enableLocalTimeline: "เปิดใช้งานไทม์ไลน์ท | ||||
| enableGlobalTimeline: "เปิดใช้งานไทม์ไลน์ทั่วโลก" | ||||
| disablingTimelinesInfo: "ผู้ดูแลระบบและผู้ควบคุมจะสามารถเข้าถึงไทม์ไลน์ทั้งหมด ถึงแม้ว่าจะไม่ได้เปิดใช้งานก็ตาม" | ||||
| registration: "ลงทะเบียน" | ||||
| enableRegistration: "เปิดใช้งานการลงทะเบียนผู้ใช้ใหม่" | ||||
| invite: "คำเชิญ" | ||||
| driveCapacityPerLocalAccount: "ความจุของไดรฟ์ต่อผู้ใช้ท้องถิ่น" | ||||
| driveCapacityPerRemoteAccount: "ความจุของไดรฟ์ต่อผู้ใช้ระยะไกล" | ||||
| @@ -448,6 +453,7 @@ totpDescription: "ใช้แอปยืนยันตัวตนเพื | ||||
| moderator: "ผู้ควบคุม" | ||||
| moderation: "การกลั่นกรอง" | ||||
| moderationNote: "โน้ตการกลั่นกรอง" | ||||
| moderationNoteDescription: "คุณสามารถใส่โน้ตส่วนตัวที่เฉพาะผู้ดูแลระบบเท่านั้นที่สามารถเข้าถึงได้" | ||||
| addModerationNote: "เพิ่มโน้ตการกลั่นกรอง" | ||||
| moderationLogs: "ปูมการควบคุมดูแล" | ||||
| nUsersMentioned: "กล่าวถึงโดยผู้ใช้ {n} ราย" | ||||
| @@ -509,6 +515,10 @@ uiLanguage: "ภาษาอินเทอร์เฟซผู้ใช้ง | ||||
| aboutX: "เกี่ยวกับ {x}" | ||||
| emojiStyle: "สไตล์ของเอโมจิ" | ||||
| native: "ภาษาแม่" | ||||
| menuStyle: "สไตล์เมนู" | ||||
| style: "สไตล์" | ||||
| drawer: "ตัววาด" | ||||
| popup: "ป๊อปอัพ" | ||||
| showNoteActionsOnlyHover: "แสดงการดำเนินการโน้ตเมื่อโฮเวอร์(วางเมาส์เหนือ)เท่านั้น" | ||||
| showReactionsCount: "แสดงจำนวนรีแอกชั่นในโน้ต" | ||||
| noHistory: "ไม่มีประวัติ" | ||||
| @@ -591,6 +601,8 @@ ascendingOrder: "เรียงลำดับขึ้น" | ||||
| descendingOrder: "เรียงลำดับลง" | ||||
| scratchpad: "Scratchpad" | ||||
| scratchpadDescription: "Scratchpad ให้สภาพแวดล้อมสำหรับการทดลอง AiScript คุณสามารถเขียนโค้ด/สั่งดำเนินการ/ตรวจสอบผลลัพธ์ ของการโต้ตอบกับ Misskey ได้" | ||||
| uiInspector: "ตัวตรวจสอบ UI" | ||||
| uiInspectorDescription: "คุณสามารถตรวจสอบรายชื่อเซิร์ฟเวอร์ที่เกี่ยวข้องกับส่วนประกอบอินเตอร์เฟซผู้ใช้ (UI) บนหน่วยความจำของระบบ ส่วนประกอบ UI เหล่านี้จะถูกสร้างขึ้นโดยฟังก์ชัน Ui:C:" | ||||
| output: "เอาท์พุต" | ||||
| script: "สคริปต์" | ||||
| disablePagesScript: "ปิดการใช้งาน AiScript บนเพจ" | ||||
| @@ -707,10 +719,7 @@ abuseReported: "เราได้ส่งรายงานของคุณ | ||||
| reporter: "ผู้รายงาน" | ||||
| reporteeOrigin: "ปลายทางรายงาน" | ||||
| reporterOrigin: "แหล่งผู้รายงาน" | ||||
| forwardReport: "ส่งต่อรายงานไปยังเซิร์ฟเวอร์ระยะไกล" | ||||
| forwardReportIsAnonymous: "ข้อมูลของคุณจะไม่ปรากฏบนเซิร์ฟเวอร์ระยะไกลและปรากฏเป็นบัญชีระบบที่ไม่ระบุชื่อ" | ||||
| send: "ส่ง" | ||||
| abuseMarkAsResolved: "ทำเครื่องหมายรายงานว่าแก้ไขแล้ว" | ||||
| openInNewTab: "เปิดในแท็บใหม่" | ||||
| openInSideView: "เปิดในมุมมองด้านข้าง" | ||||
| defaultNavigationBehaviour: "พฤติกรรมการนำทางที่เป็นค่าเริ่มต้น" | ||||
| @@ -912,6 +921,7 @@ followersVisibility: "การมองเห็นผู้ที่กำล | ||||
| continueThread: "ดูความต่อเนื่องเธรด" | ||||
| deleteAccountConfirm: "การดำเนินการนี้จะลบบัญชีของคุณอย่างถาวรเลยนะ แน่ใจหรอดำเนินการ?" | ||||
| incorrectPassword: "รหัสผ่านไม่ถูกต้อง" | ||||
| incorrectTotp: "รหัสยืนยันตัวตนแบบใช้ครั้งเดียวที่ท่านได้ระบุมานั้น ไม่ถูกต้องหรือหมดอายุลงแล้วค่ะ" | ||||
| voteConfirm: "ต้องการโหวต “{choice}” ใช่ไหม?" | ||||
| hide: "ซ่อน" | ||||
| useDrawerReactionPickerForMobile: "แสดง ตัวจิ้มรีแอคชั่น เป็นแบบลิ้นชัก เมื่อใช้บนมือถือ" | ||||
| @@ -1076,6 +1086,7 @@ retryAllQueuesConfirmTitle: "ลองใหม่ทั้งหมดจริ | ||||
| retryAllQueuesConfirmText: "สิ่งนี้จะเพิ่มการโหลดเซิร์ฟเวอร์ชั่วคราวนะ" | ||||
| enableChartsForRemoteUser: "สร้างแผนภูมิข้อมูลผู้ใช้ระยะไกล" | ||||
| enableChartsForFederatedInstances: "สร้างแผนภูมิของเซิร์ฟเวอร์ระยะไกล" | ||||
| enableStatsForFederatedInstances: "ดึงข้อมูลสถิติจากเซิร์ฟเวอร์ที่อยู่ห่างไกล" | ||||
| showClipButtonInNoteFooter: "เพิ่ม “คลิป” ไปยังเมนูสั่งการของโน้ต" | ||||
| reactionsDisplaySize: "ขนาดของรีแอคชั่น" | ||||
| limitWidthOfReaction: "จำกัดความกว้างสูงสุดของรีแอคชั่นและแสดงให้เล็กลง" | ||||
| @@ -1262,6 +1273,32 @@ confirmWhenRevealingSensitiveMedia: "ตรวจสอบก่อนแสด | ||||
| sensitiveMediaRevealConfirm: "สื่อนี้มีเนื้อหาละเอียดอ่อน, ต้องการแสดงใช่ไหม?" | ||||
| createdLists: "รายชื่อที่ถูกสร้าง" | ||||
| createdAntennas: "เสาอากาศที่ถูกสร้าง" | ||||
| fromX: "จาก {x}" | ||||
| genEmbedCode: "สร้างรหัสฝัง" | ||||
| noteOfThisUser: "โน้ตโดยผู้ใช้นี้" | ||||
| clipNoteLimitExceeded: "ไม่สามารถเพิ่มโน้ตเพิ่มเติมในคลิปนี้ได้อีกแล้ว" | ||||
| performance: "ประสิทธิภาพ" | ||||
| modified: "แก้ไข" | ||||
| discard: "ละทิ้ง" | ||||
| thereAreNChanges: "มีอยู่ {n} เปลี่ยนแปลง(s)" | ||||
| signinWithPasskey: "ลงชื่อเข้าใช้ด้วย Passkey" | ||||
| unknownWebAuthnKey: "พาสคีย์ไม่ถูกต้องค่ะ" | ||||
| passkeyVerificationFailed: "การยืนยันกุญแจดิจิทัลไม่สำเร็จค่ะ" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "การยืนยันพาสคีย์สำเร็จแล้ว แต่การลงชื่อเข้าใช้แบบไม่ต้องใส่รหัสผ่านถูกปิดใช้งานแล้ว" | ||||
| messageToFollower: "ข้อความถึงผู้ติดตาม" | ||||
| target: "เป้า" | ||||
| testCaptchaWarning: "ฟังก์ชันนี้มีไว้สำหรับทดสอบ CAPTCHA เท่านั้น\n<strong>ห้ามนำไปใช้ในระบบจริงโดยเด็ดขาด</strong>" | ||||
| prohibitedWordsForNameOfUser: "คำนี้ไม่สามารถใช้เป็นชื่อผู้ใช้ได้" | ||||
| prohibitedWordsForNameOfUserDescription: "หากมีสตริงใดๆ ในรายการนี้ปรากฏอยู่ในชื่อของผู้ใช้ ชื่อนั้นจะถูกปฏิเสธ ผู้ใช้ที่มีสิทธิ์แต่ผู้ดูแลระบบนั้นจะไม่ได้รับผลกระทบใดๆจากข้อจำกัดนี้ค่ะ" | ||||
| yourNameContainsProhibitedWords: "ชื่อของคุณนั้นมีคำที่ต้องห้าม" | ||||
| yourNameContainsProhibitedWordsDescription: "ถ้าหากคุณต้องการใช้ชื่อนี้ กรุณาติดต่อผู้ดูแลระบบของเซิร์ฟเวอร์นะค่ะ" | ||||
| _abuseUserReport: | ||||
|   forward: "ส่งต่อ" | ||||
|   forwardDescription: "ส่งรายงานไปยังเซิร์ฟเวอร์ระยะไกลโดยใช้บัญชีระบบที่ไม่ระบุตัวตน" | ||||
|   resolve: "แก้ไข" | ||||
|   accept: "ยอมรับ" | ||||
|   reject: "ปฏิเสธ" | ||||
|   resolveTutorial: "ถ้าหากรายงานนี้มีเนื้อหาถูกต้อง ให้เลือก \"ยอมรับ\" เพื่อปิดเคสกรณีนี้โดยถือว่าได้รับการแก้ไขแล้ว\nถ้าหากเนื้อหาในรายงานนี้นั้นไม่ถูกต้อง ให้เลือก \"ปฏิเสธ\" เพื่อปิดเคสกรณีนี้โดยถือว่าไม่ได้รับการแก้ไข" | ||||
| _delivery: | ||||
|   status: "สถานะการจัดส่ง" | ||||
|   stop: "ระงับการส่ง" | ||||
| @@ -1396,8 +1433,10 @@ _serverSettings: | ||||
|   fanoutTimelineDescription: "เพิ่มประสิทธิภาพการดึงข้อมูลไทม์ไลน์อย่างมาก และลดภาระในฐานข้อมูลเมื่อเปิดใช้งาน ในทางกลับกัน การใช้หน่วยความจำของ Redis จะเพิ่มขึ้น ลองปิดการใช้งานนี้ในกรณีที่หน่วยความจำเซิร์ฟเวอร์เหลือน้อยหรือเซิร์ฟเวอร์ไม่เสถียร" | ||||
|   fanoutTimelineDbFallback: "ฟอลแบ๊กกลับฐานข้อมูล" | ||||
|   fanoutTimelineDbFallbackDescription: "เมื่อเปิดใช้งาน หากไม่ได้แคชไทม์ไลน์ ไทม์ไลน์จะฟอลแบ๊กไปยังฐานข้อมูลสำหรับการ query เพิ่มเติม การปิดใช้งานจะช่วยลดภาระของเซิร์ฟเวอร์ด้วยการกำจัดกระบวนฟอลแบ๊ก แต่มันก็จะจำกัดช่วงเวลาไทม์ไลน์ที่สามารถดึงข้อมูลได้" | ||||
|   reactionsBufferingDescription: "เมื่อเปิดใช้งานฟังก์ชันนี้ก็จะช่วยลด latency ในการสร้างปฏิกิริยา แต่อาจจะส่งผลให้ memory footprint ของ Redis เพิ่มขึ้นนะ" | ||||
|   inquiryUrl: "URL สำหรับการติดต่อสอบถาม" | ||||
|   inquiryUrlDescription: "ระบุ URL ของหน้าเว็บที่มีแบบฟอร์มสำหรับติดต่อผู้ดูแลเซิร์ฟเวอร์ หรือข้อมูลการติดต่อของผู้ดูแลเซิร์ฟเวอร์" | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "ถ้าหากไม่มีการตรวจสอบจากผู้ดูแลระบบหรือไม่มีความเคลื่อนไหวมาเป็นระยะเวลาหนึ่ง ระบบจะทำการปิดใช้งานฟังก์ชันนี้โดยอัตโนมัติ เพื่อลดความเสี่ยงในการถูกโจมตีด้วยสแปมและอื่นๆ" | ||||
| _accountMigration: | ||||
|   moveFrom: "ย้ายจากบัญชีอื่นมาที่บัญชีนี้" | ||||
|   moveFromSub: "สร้างนามแฝงไปยังบัญชีอื่น" | ||||
| @@ -1729,6 +1768,11 @@ _role: | ||||
|     canSearchNotes: "การใช้การค้นหาโน้ต" | ||||
|     canUseTranslator: "การใช้งานแปล" | ||||
|     avatarDecorationLimit: "จำนวนการตกแต่งไอคอนสูงสุดที่สามารถติดตั้งได้" | ||||
|     canImportAntennas: "อนุญาตให้นำเข้าเสาอากาศ" | ||||
|     canImportBlocking: "อนุญาตให้นำเข้าการบล็อก" | ||||
|     canImportFollowing: "อนุญาตให้นำเข้ารายการต่อไปนี้" | ||||
|     canImportMuting: "อนุญาตให้นำเข้าการปิดกั้น" | ||||
|     canImportUserLists: "อนุญาตให้นำเข้ารายการ" | ||||
|   _condition: | ||||
|     roleAssignedTo: "มอบหมายให้มีบทบาทแบบทำมือ" | ||||
|     isLocal: "ผู้ใช้ท้องถิ่น" | ||||
| @@ -1946,7 +1990,6 @@ _theme: | ||||
|     buttonBg: "ปุ่มพื้นหลัง" | ||||
|     buttonHoverBg: "ปุ่มพื้นหลัง (โฮเวอร์)" | ||||
|     inputBorder: "เส้นขอบของช่องป้อนข้อมูล" | ||||
|     listItemHoverBg: "รายการไอเทมพื้นหลัง (โฮเวอร์)" | ||||
|     driveFolderBg: "พื้นหลังโฟลเดอร์ไดรฟ์" | ||||
|     wallpaperOverlay: "วอลล์เปเปอร์ซ้อนทับ" | ||||
|     badge: "ตรา" | ||||
| @@ -2223,6 +2266,9 @@ _profile: | ||||
|   changeBanner: "เปลี่ยนแบนเนอร์" | ||||
|   verifiedLinkDescription: "หากป้อน URL ที่มีลิงก์ไปยังโปรไฟล์ของคุณ ไอคอนการยืนยันความเป็นเจ้าของจะแสดงถัดจากฟิลด์นั้น ๆ" | ||||
|   avatarDecorationMax: "คุณสามารถเพิ่มการตกแต่งได้สูงสุด {max}" | ||||
|   followedMessage: "ส่งข้อความเมื่อมีคนกดติดตาม" | ||||
|   followedMessageDescription: "ส่งข้อความเมื่อมีคนกดติดตามแล้ว" | ||||
|   followedMessageDescriptionForLockedAccount: "ถ้าหากคุณตั้งค่าให้คนอื่นต้องขออนุญาตก่อนที่จะติดตามคุณ ระบบจะขึ้นข้อความนี้ในตอนที่คุณอนุมัติให้เขาติดตาม" | ||||
| _exportOrImport: | ||||
|   allNotes: "โน้ตทั้งหมด" | ||||
|   favoritedNotes: "โน้ตที่ถูกใจไว้" | ||||
| @@ -2315,6 +2361,7 @@ _pages: | ||||
|   eyeCatchingImageSet: "ตั้งค่าภาพขนาดย่อ" | ||||
|   eyeCatchingImageRemove: "ลบภาพขนาดย่อ" | ||||
|   chooseBlock: "เพิ่มบล็อค" | ||||
|   enterSectionTitle: "ป้อนชื่อหัวข้อ" | ||||
|   selectType: "เลือกชนิด" | ||||
|   contentBlocks: "เนื้อหา" | ||||
|   inputBlocks: "ป้อนข้อมูล" | ||||
| @@ -2360,6 +2407,8 @@ _notification: | ||||
|   renotedBySomeUsers: "รีโน้ตจากผู้ใช้ {n} ราย" | ||||
|   followedBySomeUsers: "มีผู้ติดตาม {n} ราย" | ||||
|   flushNotification: "ล้างประวัติการแจ้งเตือน" | ||||
|   exportOfXCompleted: "การดำเนินการส่งออก {x} ได้เสร็จสิ้นลงแล้ว" | ||||
|   login: "มีคนล็อกอิน" | ||||
|   _types: | ||||
|     all: "ทั้งหมด" | ||||
|     note: "โน้ตใหม่" | ||||
| @@ -2374,6 +2423,9 @@ _notification: | ||||
|     followRequestAccepted: "อนุมัติให้ติดตามแล้ว" | ||||
|     roleAssigned: "ให้บทบาท" | ||||
|     achievementEarned: "ปลดล็อกความสำเร็จแล้ว" | ||||
|     exportCompleted: "กระบวนการส่งออกข้อมูลได้เสร็จสิ้นสมบูรณ์แล้ว" | ||||
|     login: "เข้าสู่ระบบ" | ||||
|     test: "ทดสอบระบบแจ้งเตือน" | ||||
|     app: "การแจ้งเตือนจากแอปที่มีลิงก์" | ||||
|   _actions: | ||||
|     followBack: "ติดตามกลับด้วย" | ||||
| @@ -2439,7 +2491,10 @@ _webhookSettings: | ||||
|     abuseReport: "เมื่อมีการรายงานจากผู้ใช้" | ||||
|     abuseReportResolved: "เมื่อมีการจัดการกับการรายงานจากผู้ใช้" | ||||
|     userCreated: "เมื่อผู้ใช้ถูกสร้างขึ้น" | ||||
|     inactiveModeratorsWarning: "เมื่อผู้ดูแลระบบไม่ได้ใช้งานมานานระยะหนึ่ง" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "เมื่อผู้ดูแลระบบที่ไม่ได้ใช้งานมานาน และเซิร์ฟเวอร์เปลี่ยนเป็นแบบเชิญเข้าร่วมเท่านั้น" | ||||
|   deleteConfirm: "ต้องการลบ Webhook ใช่ไหม?" | ||||
|   testRemarks: "คลิกปุ่มทางด้านขวาของสวิตช์เพื่อส่ง Webhook ทดสอบที่มีข้อมูลจำลอง" | ||||
| _abuseReport: | ||||
|   _notificationRecipient: | ||||
|     createRecipient: "เพิ่มปลายทางการแจ้งเตือนการรายงาน" | ||||
| @@ -2483,6 +2538,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "ทำเครื่องหมายไฟล์ว่ามีเนื้อหาละเอียดอ่อน" | ||||
|   unmarkSensitiveDriveFile: "ยกเลิกทำเครื่องหมายไฟล์ว่ามีเนื้อหาละเอียดอ่อน" | ||||
|   resolveAbuseReport: "รายงานได้รับการแก้ไขแล้ว" | ||||
|   forwardAbuseReport: "ได้ส่งรายงานไปแล้ว" | ||||
|   updateAbuseReportNote: "โน้ตการกลั่นกรองที่รายงานไปนั้น ได้รับการอัปเดตแล้ว" | ||||
|   createInvitation: "สร้างรหัสเชิญ" | ||||
|   createAd: "สร้างโฆษณาแล้ว" | ||||
|   deleteAd: "ลบโฆษณาออกแล้ว" | ||||
| @@ -2498,6 +2555,10 @@ _moderationLogTypes: | ||||
|   createAbuseReportNotificationRecipient: "สร้างปลายทางการแจ้งเตือนการรายงาน" | ||||
|   updateAbuseReportNotificationRecipient: "อัปเดตปลายทางการแจ้งเตือนการรายงาน" | ||||
|   deleteAbuseReportNotificationRecipient: "ลบปลายทางการแจ้งเตือนการรายงาน" | ||||
|   deleteAccount: "บัญชีถูกลบไปแล้ว" | ||||
|   deletePage: "เพจถูกลบออกไปแล้ว" | ||||
|   deleteFlash: "Play ถูกลบออกไปแล้ว" | ||||
|   deleteGalleryPost: "โพสต์แกลเลอรี่ถูกลบออกแล้ว" | ||||
| _fileViewer: | ||||
|   title: "รายละเอียดไฟล์" | ||||
|   type: "ประเภทไฟล์" | ||||
| @@ -2634,3 +2695,20 @@ _contextMenu: | ||||
|   app: "แอปพลิเคชัน" | ||||
|   appWithShift: "แอปฟลิเคชันด้วยปุ่มยกแคร่ (Shift)" | ||||
|   native: "UI ของเบราว์เซอร์" | ||||
| _embedCodeGen: | ||||
|   title: "ปรับแต่งโค้ดฝัง" | ||||
|   header: "แสดงส่วนหัว" | ||||
|   autoload: "โหลดเพิ่มโดยอัตโนมัติ (เลิกใช้แล้ว)" | ||||
|   maxHeight: "ความสูงสุด" | ||||
|   maxHeightDescription: "หากถ้าตั้งค่าเป็น 0 จะทำให้ไม่มีการจำกัดความสูงของวิดเจ็ต แต่ควรตั้งค่าเป็นตัวเลขอื่นๆ เพื่อไม่ให้วิดเจ็ตยืดตัวลงไปเรื่อยๆ" | ||||
|   maxHeightWarn: "การจำกัดความสูงสูงสุดถูกปิดใช้งาน (0) หากไม่ได้ตั้งใจให้เป็นเช่นนี้ โปรดตั้งค่าความสูงสูงสุดให้เป็นค่าอื่นๆแทน" | ||||
|   previewIsNotActual: "การแสดงผลนั้นต่างจากการฝังจริงเพราะเกินขอบเขตที่แสดงบนหน้าจอตัวอย่างนะ" | ||||
|   rounded: "ทำให้มันกลม" | ||||
|   border: "เพิ่มขอบให้กับกรอบด้านนอก" | ||||
|   applyToPreview: "นำไปใช้กับการแสดงตัวอย่าง" | ||||
|   generateCode: "สร้างโค้ดสำหรับการฝัง" | ||||
|   codeGenerated: "รหัสถูกสร้างขึ้นแล้ว" | ||||
|   codeGeneratedDescription: "นำโค้ดที่สร้างแล้วไปวางในเว็บไซต์ของคุณเพื่อฝังเนื้อหา" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "ไม่พบหน้าที่ต้องการ" | ||||
|   | ||||
| @@ -8,6 +8,7 @@ search: "Arama" | ||||
| notifications: "Bildirim" | ||||
| username: "Kullanıcı Adı" | ||||
| password: "Şifre" | ||||
| initialPasswordForSetup: "" | ||||
| forgotPassword: "şifremi unuttum" | ||||
| fetchingAsApObject: "從聯邦宇宙取得中..." | ||||
| ok: "TAMAM" | ||||
| @@ -344,7 +345,6 @@ today: "Bugün" | ||||
| monthX: "{month} ay" | ||||
| pages: "Sayfalar" | ||||
| integration: "Entegrasyon" | ||||
| enableRegistration: "Kayıtlara izin ver" | ||||
| basicInfo: "Temel bilgiler" | ||||
| pinnedUsers: "Sabitlenmiş kullanıcılar" | ||||
| pinnedNotes: "Sabitlenen" | ||||
| @@ -446,6 +446,7 @@ _notification: | ||||
|     reaction: "Tepkiler" | ||||
|     receiveFollowRequest: "Takip isteği alındı" | ||||
|     followRequestAccepted: "Takip isteği kabul edildi" | ||||
|     login: "Giriş Yap " | ||||
|   _actions: | ||||
|     reply: "yanıt" | ||||
|     renote: "vazgeçme" | ||||
|   | ||||
| @@ -17,3 +17,6 @@ _2fa: | ||||
|   renewTOTPCancel: "ئۇنى توختىتىڭ" | ||||
| _widgets: | ||||
|   profile: "profile" | ||||
| _notification: | ||||
|   _types: | ||||
|     login: "كىرىش" | ||||
|   | ||||
| @@ -334,7 +334,6 @@ enableLocalTimeline: "Увімкнути локальну стрічку" | ||||
| enableGlobalTimeline: "Увімкнути глобальну стрічку" | ||||
| disablingTimelinesInfo: "Адміністратори та модератори завжди мають доступ до всіх стрічок, навіть якщо вони вимкнуті." | ||||
| registration: "Реєстрація" | ||||
| enableRegistration: "Дозволити реєстрацію" | ||||
| invite: "Запросити" | ||||
| driveCapacityPerLocalAccount: "Об'єм диска на одного локального користувача" | ||||
| driveCapacityPerRemoteAccount: "Об'єм диска на одного віддаленого користувача" | ||||
| @@ -630,10 +629,7 @@ abuseReported: "Дякуємо, вашу скаргу було відправл | ||||
| reporter: "Репортер" | ||||
| reporteeOrigin: "Про кого повідомлено" | ||||
| reporterOrigin: "Хто повідомив" | ||||
| forwardReport: "Переслати звіт на віддалений інстанс" | ||||
| forwardReportIsAnonymous: "Замість вашого облікового запису анонімний системний обліковий запис буде відображатися як доповідач на віддаленому інстансі" | ||||
| send: "Відправити" | ||||
| abuseMarkAsResolved: "Позначити скаргу як вирішену" | ||||
| openInNewTab: "Відкрити в новій вкладці" | ||||
| openInSideView: "Відкрити збоку" | ||||
| defaultNavigationBehaviour: "Поведінка навігації за замовчуванням" | ||||
| @@ -1305,7 +1301,6 @@ _theme: | ||||
|     buttonBg: "Фон кнопки" | ||||
|     buttonHoverBg: "Фон кнопки (при наведенні)" | ||||
|     inputBorder: "Край поля вводу" | ||||
|     listItemHoverBg: "Фон елементу в списку (при наведенні)" | ||||
|     driveFolderBg: "Фон папки на диску" | ||||
|     wallpaperOverlay: "Накладання шпалер" | ||||
|     badge: "Значок" | ||||
| @@ -1587,6 +1582,7 @@ _notification: | ||||
|     reaction: "Реакції" | ||||
|     receiveFollowRequest: "Запити на підписку" | ||||
|     followRequestAccepted: "Прийняті підписки" | ||||
|     login: "Увійти" | ||||
|     app: "Сповіщення від додатків" | ||||
|   _actions: | ||||
|     reply: "Відповісти" | ||||
| @@ -1628,3 +1624,6 @@ _moderationLogTypes: | ||||
|   resetPassword: "Скинути пароль" | ||||
| _reversi: | ||||
|   total: "Всього" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Не знайдено" | ||||
|   | ||||
| @@ -349,7 +349,6 @@ enableLocalTimeline: "Mahalliy vaqt mintaqasini yoqing" | ||||
| enableGlobalTimeline: "Global vaqt mintaqasini yoqing" | ||||
| disablingTimelinesInfo: "Administratorlar va Moderatorlar har doim barcha vaqt jadvallariga kirish huquqiga ega bo'ladilar, hatto ular yoqilmagan bo'lsa ham." | ||||
| registration: "Ro'yxatdan o'tish" | ||||
| enableRegistration: "Ro'yxatdan o'tishni yoqing" | ||||
| invite: "Taklif qilish" | ||||
| driveCapacityPerLocalAccount: "Har bir mahalliy foydalanuvchi uchun disk maydoni" | ||||
| driveCapacityPerRemoteAccount: "Har bir masofaviy foydalanuvchi uchun disk maydoni" | ||||
| @@ -629,10 +628,7 @@ abuseReported: "Shikoyatingiz yetkazildi. Ma'lumot uchun rahmat." | ||||
| reporter: "Shikoyat qiluvchi" | ||||
| reporteeOrigin: "Xabarning kelib chiqishi" | ||||
| reporterOrigin: "Xabarchining joylashuvi" | ||||
| forwardReport: "Xabarni masofadagi serverga yuborish" | ||||
| forwardReportIsAnonymous: "Sizning yuborayotgan xabaringiz o'z akkountingiz emas balki anonim tarzda qoladi" | ||||
| send: "Yuborish" | ||||
| abuseMarkAsResolved: "Yuborilgan xabarni hal qilingan deb belgilash" | ||||
| openInNewTab: "Yangi tab da ochish" | ||||
| openInSideView: "Yon panelda ochish" | ||||
| defaultNavigationBehaviour: "Standart navigatsiya harakati" | ||||
| @@ -1057,6 +1053,7 @@ _notification: | ||||
|     quote: "Iqtibos keltirish" | ||||
|     reaction: "Reaktsiyalar" | ||||
|     receiveFollowRequest: "Qabul qilingan kuzatuv so'rovlari" | ||||
|     login: "Kirish" | ||||
|   _actions: | ||||
|     reply: "Javob berish" | ||||
|     renote: "Qayta qayd qilish" | ||||
| @@ -1097,3 +1094,6 @@ _moderationLogTypes: | ||||
|   resetPassword: "Parolni tiklash" | ||||
| _reversi: | ||||
|   total: "Jami" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Topilmadi" | ||||
|   | ||||
| @@ -8,6 +8,9 @@ search: "Tìm kiếm" | ||||
| notifications: "Thông báo" | ||||
| username: "Tên người dùng" | ||||
| password: "Mật khẩu" | ||||
| initialPasswordForSetup: "Mật khẩu ban đầu để thiết lập" | ||||
| initialPasswordIsIncorrect: "Mật khẩu ban đầu đã nhập sai" | ||||
| initialPasswordForSetupDescription: "Nếu bạn tự cài đặt Misskey, hãy sử dụng mật khẩu ban đầu của bạn đã nhập trong tệp cấu hình.\nNếu bạn đang sử dụng dịch vụ nào đó giống như dịch vụ lưu trữ của Misskey, hãy sử dụng mật khẩu ban đầu được cung cấp.\nNếu bạn chưa đặt mật khẩu ban đầu, vui lòng để trống và tiếp tục." | ||||
| forgotPassword: "Quên mật khẩu" | ||||
| fetchingAsApObject: "Đang nạp dữ liệu từ Fediverse..." | ||||
| ok: "Đồng ý" | ||||
| @@ -354,7 +357,6 @@ enableLocalTimeline: "Bật bảng tin máy chủ" | ||||
| enableGlobalTimeline: "Bật bảng tin liên hợp" | ||||
| disablingTimelinesInfo: "Quản trị viên và Kiểm duyệt viên luôn có quyền truy cập mọi bảng tin, kể cả khi chúng không được bật." | ||||
| registration: "Đăng ký" | ||||
| enableRegistration: "Cho phép đăng ký mới" | ||||
| invite: "Mời" | ||||
| driveCapacityPerLocalAccount: "Dung lượng ổ đĩa tối đa cho mỗi người dùng" | ||||
| driveCapacityPerRemoteAccount: "Dung lượng ổ đĩa tối đa cho mỗi người dùng từ xa" | ||||
| @@ -675,10 +677,7 @@ abuseReported: "Báo cáo đã được gửi. Cảm ơn bạn nhiều." | ||||
| reporter: "Người báo cáo" | ||||
| reporteeOrigin: "Bị báo cáo" | ||||
| reporterOrigin: "Máy chủ người báo cáo" | ||||
| forwardReport: "Chuyển tiếp báo cáo cho máy chủ từ xa" | ||||
| forwardReportIsAnonymous: "Thay vì tài khoản của bạn, một tài khoản hệ thống ẩn danh sẽ được hiển thị dưới dạng người báo cáo ở máy chủ từ xa." | ||||
| send: "Gửi" | ||||
| abuseMarkAsResolved: "Đánh dấu đã xử lý" | ||||
| openInNewTab: "Mở trong tab mới" | ||||
| openInSideView: "Mở trong thanh bên" | ||||
| defaultNavigationBehaviour: "Thao tác điều hướng mặc định" | ||||
| @@ -1549,7 +1548,6 @@ _theme: | ||||
|     buttonBg: "Nền nút" | ||||
|     buttonHoverBg: "Nền nút (Chạm)" | ||||
|     inputBorder: "Đường viền khung soạn thảo" | ||||
|     listItemHoverBg: "Nền mục liệt kê (Chạm)" | ||||
|     driveFolderBg: "Nền thư mục Ổ đĩa" | ||||
|     wallpaperOverlay: "Lớp phủ hình nền" | ||||
|     badge: "Huy hiệu" | ||||
| @@ -1878,6 +1876,7 @@ _notification: | ||||
|     receiveFollowRequest: "Yêu cầu theo dõi" | ||||
|     followRequestAccepted: "Yêu cầu theo dõi được chấp nhận" | ||||
|     achievementEarned: "Hoàn thành Achievement" | ||||
|     login: "Đăng nhập" | ||||
|     app: "Từ app liên kết" | ||||
|   _actions: | ||||
|     followBack: "đã theo dõi lại bạn" | ||||
| @@ -1931,3 +1930,6 @@ _moderationLogTypes: | ||||
|   createInvitation: "Tạo lời mời" | ||||
| _reversi: | ||||
|   total: "Tổng cộng" | ||||
| _remoteLookupErrors: | ||||
|   _noSuchObject: | ||||
|     title: "Không tìm thấy" | ||||
|   | ||||
| @@ -5,9 +5,13 @@ introMisskey: "欢迎!Misskey是一个开源的、去中心化的“微博客 | ||||
| poweredByMisskeyDescription: "{name} 是开源平台 <b>Misskey</b> 的服务器之一。" | ||||
| monthAndDay: "{month}月 {day}日" | ||||
| search: "搜索" | ||||
| reset: "重置" | ||||
| notifications: "通知" | ||||
| username: "用户名" | ||||
| password: "密码" | ||||
| initialPasswordForSetup: "初始化密码" | ||||
| initialPasswordIsIncorrect: "初始化密码不正确" | ||||
| initialPasswordForSetupDescription: "如果是自己安装的 Misskey,请输入配置文件里设好的密码。\n如果使用的是 Misskey 的托管服务等,请输入服务商提供的密码。\n如果没有设置密码,请留空并继续。" | ||||
| forgotPassword: "忘记密码" | ||||
| fetchingAsApObject: "在联邦宇宙查询中..." | ||||
| ok: "OK" | ||||
| @@ -45,6 +49,7 @@ pin: "置顶" | ||||
| unpin: "取消置顶" | ||||
| copyContent: "复制内容" | ||||
| copyLink: "复制链接" | ||||
| copyRemoteLink: "复制远程连接" | ||||
| copyLinkRenote: "复制转帖链接" | ||||
| delete: "删除" | ||||
| deleteAndEdit: "删除并编辑" | ||||
| @@ -90,7 +95,7 @@ followsYou: "正在关注你" | ||||
| createList: "创建列表" | ||||
| manageLists: "管理列表" | ||||
| error: "错误" | ||||
| somethingHappened: "出现了一些问题!" | ||||
| somethingHappened: "出错了" | ||||
| retry: "重试" | ||||
| pageLoadError: "页面加载失败。" | ||||
| pageLoadErrorDescription: "这通常是由于网络或浏览器缓存的原因。请清除缓存或等待片刻后重试。" | ||||
| @@ -104,7 +109,7 @@ follow: "关注" | ||||
| followRequest: "关注申请" | ||||
| followRequests: "关注申请" | ||||
| unfollow: "取消关注" | ||||
| followRequestPending: "关注请求批准中" | ||||
| followRequestPending: "关注请求待批准" | ||||
| enterEmoji: "输入表情符号" | ||||
| renote: "转发" | ||||
| unrenote: "取消转发" | ||||
| @@ -133,21 +138,21 @@ overwriteFromPinnedEmojisForReaction: "从「置顶(回应)」设置覆盖" | ||||
| overwriteFromPinnedEmojis: "从全局设置覆盖" | ||||
| reactionSettingDescription2: "拖动重新排序,单击删除,点击 + 添加。" | ||||
| rememberNoteVisibility: "保存上次设置的可见性" | ||||
| attachCancel: "删除附件" | ||||
| attachCancel: "取消添加附件" | ||||
| deleteFile: "删除文件" | ||||
| markAsSensitive: "标记为敏感内容" | ||||
| unmarkAsSensitive: "取消标记为敏感内容" | ||||
| enterFileName: "输入文件名" | ||||
| mute: "屏蔽" | ||||
| unmute: "解除静音" | ||||
| renoteMute: "屏蔽转帖" | ||||
| renoteUnmute: "解除屏蔽转帖" | ||||
| block: "拉黑" | ||||
| unblock: "取消拉黑" | ||||
| unmute: "取消隐藏" | ||||
| renoteMute: "隐藏转帖" | ||||
| renoteUnmute: "解除隐藏转帖" | ||||
| block: "屏蔽" | ||||
| unblock: "取消屏蔽" | ||||
| suspend: "冻结" | ||||
| unsuspend: "解除冻结" | ||||
| blockConfirm: "确定要拉黑吗?" | ||||
| unblockConfirm: "确定要解除拉黑吗?" | ||||
| blockConfirm: "确定要屏蔽吗?" | ||||
| unblockConfirm: "确定要取消屏蔽吗?" | ||||
| suspendConfirm: "要冻结吗?" | ||||
| unsuspendConfirm: "要解除冻结吗?" | ||||
| selectList: "选择列表" | ||||
| @@ -167,7 +172,7 @@ emojiUrl: "emoji 地址" | ||||
| addEmoji: "添加表情符号" | ||||
| settingGuide: "推荐配置" | ||||
| cacheRemoteFiles: "缓存远程文件" | ||||
| cacheRemoteFilesDescription: "启用此设定时,将在此服务器上缓存远程文件。虽然可以加快图片显示的速度,但是相对的会消耗大量的服务器存储空间。用户角色内的网盘容量决定了这个远程用户能在服务器上保留保留多少缓存。当超出了这个限制时,旧的文件将从缓存中被删除,成为链接。当禁用此设定时,则是从一开始就将远程文件保留为链接。此时推荐将 default.yml 的 proxyRemoteFiles 设置为 true 以优化缩略图生成及保护用户隐私。" | ||||
| cacheRemoteFilesDescription: "启用此设定时,将在此服务器上缓存远程文件。虽然可以加快图片显示的速度,但是相对的会消耗大量的服务器存储空间。用户角色内的网盘容量决定了这个远程用户能在服务器上保留多少缓存。当超出了这个限制时,旧的文件将从缓存中被删除,成为链接。当禁用此设定时,则是从一开始就将远程文件保留为链接。此时推荐将 default.yml 的 proxyRemoteFiles 设置为 true 以优化缩略图生成及保护用户隐私。" | ||||
| youCanCleanRemoteFilesCache: "可以使用文件管理的🗑️按钮来删除所有的缓存。" | ||||
| cacheRemoteSensitiveFiles: "缓存远程敏感媒体文件" | ||||
| cacheRemoteSensitiveFilesDescription: "如果禁用这项设定,远程服务器的敏感媒体将不会被缓存,而是直接链接。" | ||||
| @@ -192,7 +197,7 @@ setWallpaper: "设置壁纸" | ||||
| removeWallpaper: "移除壁纸" | ||||
| searchWith: "搜索:{q}" | ||||
| youHaveNoLists: "列表为空" | ||||
| followConfirm: "你确定要关注 {name} 吗?" | ||||
| followConfirm: "确定要关注 {name} 吗?" | ||||
| proxyAccount: "代理账户" | ||||
| proxyAccountDescription: "代理账户是在某些情况下替代用户进行远程关注用的账户。 例如说,当用户将一位远程用户放入一个列表中时,如果本地服务器上没有任何人关注这位远程用户,则这位远程用户的账户活动将不会被送到本地服务器上。作为替代,此时将使用代理账户进行关注。" | ||||
| host: "主机名" | ||||
| @@ -210,8 +215,8 @@ charts: "图表" | ||||
| perHour: "每小时" | ||||
| perDay: "每天" | ||||
| stopActivityDelivery: "停止发送活动" | ||||
| blockThisInstance: "阻止此服务器向本服务器推流" | ||||
| silenceThisInstance: "使服务器静音" | ||||
| blockThisInstance: "屏蔽此服务器" | ||||
| silenceThisInstance: "静音此服务器" | ||||
| mediaSilenceThisInstance: "隐藏此服务器的媒体文件" | ||||
| operations: "操作" | ||||
| software: "软件" | ||||
| @@ -226,22 +231,24 @@ disk: "存储" | ||||
| instanceInfo: "服务器信息" | ||||
| statistics: "统计" | ||||
| clearQueue: "清除队列" | ||||
| clearQueueConfirmTitle: "确定清除队列?" | ||||
| clearQueueConfirmTitle: "确定要清除队列吗?" | ||||
| clearQueueConfirmText: "未送达的帖子将不会被投递。 通常无需执行此操作。" | ||||
| clearCachedFiles: "清除缓存" | ||||
| clearCachedFilesConfirm: "确定要清除所有缓存的远程文件?" | ||||
| blockedInstances: "被封锁的服务器" | ||||
| blockedInstancesDescription: "设定要封锁的服务器,以换行分隔。被封锁的服务器将无法与本服务器进行交换通讯。子域名也同样会被封锁。" | ||||
| clearCachedFilesConfirm: "确定要清除所有缓存的远程文件吗?" | ||||
| blockedInstances: "被屏蔽的服务器" | ||||
| blockedInstancesDescription: "设定要屏蔽的服务器,以换行分隔。被屏蔽的服务器将无法与本服务器进行交换通讯。子域名也同样会被屏蔽。" | ||||
| silencedInstances: "被静音的服务器" | ||||
| silencedInstancesDescription: "设置要静音的服务器,以换行分隔。被静音的服务器内所有的账户将默认处于「静音」状态,仅能发送关注请求,并且在未关注状态下无法提及本地账户。被阻止的实例不受影响。" | ||||
| mediaSilencedInstances: "已隐藏媒体文件的服务器" | ||||
| mediaSilencedInstancesDescription: "设置要隐藏媒体文件的服务器,以换行分隔。被设置为隐藏媒体文件服务器内所有账号的文件均按照「敏感内容」处理,且将无法使用自定义表情符号。被阻止的实例不受影响。" | ||||
| muteAndBlock: "静音/拉黑" | ||||
| mutedUsers: "已静音用户" | ||||
| blockedUsers: "已拉黑的用户" | ||||
| federationAllowedHosts: "允许联合的服务器" | ||||
| federationAllowedHostsDescription: "设定允许联合的服务器,以换行分隔。" | ||||
| muteAndBlock: "隐藏和屏蔽" | ||||
| mutedUsers: "已隐藏用户" | ||||
| blockedUsers: "已屏蔽的用户" | ||||
| noUsers: "无用户" | ||||
| editProfile: "编辑资料" | ||||
| noteDeleteConfirm: "要删除该帖子吗?" | ||||
| noteDeleteConfirm: "确定要删除该帖子吗?" | ||||
| pinLimitExceeded: "无法置顶更多了" | ||||
| intro: "Misskey 的部署结束啦!创建管理员账号吧!" | ||||
| done: "完成" | ||||
| @@ -252,8 +259,8 @@ defaultValueIs: "默认值: {value}" | ||||
| noCustomEmojis: "没有自定义表情符号" | ||||
| noJobs: "没有任务" | ||||
| federating: "联合中" | ||||
| blocked: "已拉黑" | ||||
| suspended: "停止推流" | ||||
| blocked: "已屏蔽" | ||||
| suspended: "停止投递" | ||||
| all: "全部" | ||||
| subscribing: "已订阅" | ||||
| publishing: "投递中" | ||||
| @@ -377,7 +384,6 @@ enableLocalTimeline: "启用本地时间线" | ||||
| enableGlobalTimeline: "启用全局时间线" | ||||
| disablingTimelinesInfo: "即使时间线功能被禁用,出于方便,管理员和监察员也可以继续使用。" | ||||
| registration: "注册" | ||||
| enableRegistration: "允许任何人注册" | ||||
| invite: "邀请" | ||||
| driveCapacityPerLocalAccount: "每个用户的网盘容量" | ||||
| driveCapacityPerRemoteAccount: "每个远程用户的网盘容量" | ||||
| @@ -449,6 +455,7 @@ totpDescription: "使用验证器输入一次性密码" | ||||
| moderator: "监察员" | ||||
| moderation: "管理" | ||||
| moderationNote: "管理笔记" | ||||
| moderationNoteDescription: "可以用来记录仅在管理员之间共享的笔记。" | ||||
| addModerationNote: "添加管理笔记" | ||||
| moderationLogs: "管理日志" | ||||
| nUsersMentioned: "{n} 被提到" | ||||
| @@ -512,6 +519,7 @@ emojiStyle: "表情符号的样式" | ||||
| native: "原生" | ||||
| menuStyle: "菜单样式" | ||||
| style: "样式" | ||||
| drawer: "抽屉" | ||||
| popup: "弹窗" | ||||
| showNoteActionsOnlyHover: "仅在悬停时显示帖子操作" | ||||
| showReactionsCount: "显示帖子的回应数" | ||||
| @@ -560,7 +568,7 @@ objectStorageRegionDesc: "指定一个可用区,例如“xx-east-1”。 如 | ||||
| objectStorageUseSSL: "使用 SSL" | ||||
| objectStorageUseSSLDesc: "如果不使用 https 进行 API 连接,请关闭。" | ||||
| objectStorageUseProxy: "使用代理" | ||||
| objectStorageUseProxyDesc: "如果您不使用代理进行 API 连接,请将其关闭。" | ||||
| objectStorageUseProxyDesc: "如果不使用代理进行 API 连接,请关闭。" | ||||
| objectStorageSetPublicRead: "上传时设置为 public-read" | ||||
| s3ForcePathStyleDesc: "启用 s3ForcePathStyle 会强制将存储桶名称指定为 URL 中路径的一部分,而不是主机名。使用自托管 Minio 等时可能需要启用。" | ||||
| serverLogs: "服务器日志" | ||||
| @@ -580,6 +588,7 @@ masterVolume: "主音量" | ||||
| notUseSound: "静音" | ||||
| useSoundOnlyWhenActive: "仅在 Misskey 活跃时输出声音" | ||||
| details: "详情" | ||||
| renoteDetails: "转帖详情" | ||||
| chooseEmoji: "选择表情符号" | ||||
| unableToProcess: "操作无法完成" | ||||
| recentUsed: "最近使用" | ||||
| @@ -596,7 +605,7 @@ descendingOrder: "降序" | ||||
| scratchpad: "AiScript 控制台" | ||||
| scratchpadDescription: "AiScript 控制台为 AiScript 提供了实验环境。您可以编写代码与 Misskey 交互,运行并查看结果。" | ||||
| uiInspector: "UI 检查器" | ||||
| uiInspectorDescription: "查看所有内存中由 UI 组件生成出的实例。UI 组件由 UI:C 系列函数所生成。" | ||||
| uiInspectorDescription: "查看内存中所有由 UI 组件生成出的实例。UI 组件由 UI:C 系列函数所生成。" | ||||
| output: "输出" | ||||
| script: "脚本" | ||||
| disablePagesScript: "禁用页面脚本" | ||||
| @@ -676,12 +685,16 @@ emptyToDisableSmtpAuth: "用户名和密码留空可以禁用 SMTP 验证" | ||||
| smtpSecure: "在 SMTP 连接中使用隐式 SSL / TLS" | ||||
| smtpSecureInfo: "使用 STARTTLS 时关闭。" | ||||
| testEmail: "邮件发送测试" | ||||
| wordMute: "文字屏蔽" | ||||
| hardWordMute: "屏蔽关键词" | ||||
| wordMute: "隐藏关键词" | ||||
| wordMuteDescription: "折叠包含指定关键词的帖子。被折叠的帖子可单击展开。" | ||||
| hardWordMute: "隐藏硬关键词" | ||||
| showMutedWord: "显示已隐藏的关键词" | ||||
| hardWordMuteDescription: "隐藏包含指定关键词的帖子。与隐藏关键词不同,帖子将完全不会显示。" | ||||
| regexpError: "正则表达式错误" | ||||
| regexpErrorDescription: "{tab} 屏蔽文字的第 {line} 行的正则表达式有错误:" | ||||
| instanceMute: "被屏蔽的服务器" | ||||
| regexpErrorDescription: "{tab} 隐藏文字的第 {line} 行的正则表达式有错误:" | ||||
| instanceMute: "已隐藏的服务器" | ||||
| userSaysSomething: "{name} 说了什么,但是被屏蔽词过滤了" | ||||
| userSaysSomethingAbout: "{name} 说了关于「{word}」的什么" | ||||
| makeActive: "启用" | ||||
| display: "显示" | ||||
| copy: "复制" | ||||
| @@ -699,7 +712,7 @@ useGlobalSettingDesc: "启用时,将使用账户通知设置。关闭时,则 | ||||
| other: "其他" | ||||
| regenerateLoginToken: "重新生成登录令牌" | ||||
| regenerateLoginTokenDescription: "重新生成用于登录的内部令牌。通常您不需要这样做。重新生成后,您将在所有设备上登出。" | ||||
| theKeywordWhenSearchingForCustomEmoji: "这将是搜素自定义表情符号时的关键词。" | ||||
| theKeywordWhenSearchingForCustomEmoji: "这将是搜索自定义表情符号时的关键词。" | ||||
| setMultipleBySeparatingWithSpace: "您可以使用空格分隔多个项目。" | ||||
| fileIdOrUrl: "文件 ID 或者 URL" | ||||
| behavior: "行为" | ||||
| @@ -713,10 +726,7 @@ abuseReported: "内容已发送。感谢您提交信息。" | ||||
| reporter: "举报者" | ||||
| reporteeOrigin: "举报来源" | ||||
| reporterOrigin: "举报者来源" | ||||
| forwardReport: "将该举报信息转发给远程服务器" | ||||
| forwardReportIsAnonymous: "在远程实例上显示的报告者是匿名的系统账号,而不是您的账号。" | ||||
| send: "发送" | ||||
| abuseMarkAsResolved: "处理完毕" | ||||
| openInNewTab: "在新标签页中打开" | ||||
| openInSideView: "在侧边栏中打开" | ||||
| defaultNavigationBehaviour: "默认导航" | ||||
| @@ -755,7 +765,7 @@ driveFilesCount: "网盘的文件数" | ||||
| driveUsage: "网盘的空间用量" | ||||
| noCrawle: "要求搜索引擎不索引该用户" | ||||
| noCrawleDescription: "要求搜索引擎不要收录(索引)您的用户页面,帖子,页面等。" | ||||
| lockedAccountInfo: "即使启用该功能,只要您不将帖子可见范围设置为“仅关注者”,任何人都还是可以看到您的帖子。" | ||||
| lockedAccountInfo: "即使启用该功能,只要帖子可见范围不是「仅关注者」,任何人都可以看到您的帖子。" | ||||
| alwaysMarkSensitive: "默认将媒体文件标记为敏感内容" | ||||
| loadRawImages: "添加附件图像的缩略图时使用原始图像质量" | ||||
| disableShowingAnimatedImages: "不播放动画" | ||||
| @@ -842,7 +852,7 @@ active: "活动" | ||||
| offline: "离线" | ||||
| notRecommended: "不推荐" | ||||
| botProtection: "Bot防御" | ||||
| instanceBlocking: "被阻拦的服务器" | ||||
| instanceBlocking: "屏蔽/静音的服务器" | ||||
| selectAccount: "选择账户" | ||||
| switchAccount: "切换账户" | ||||
| enabled: "已启用" | ||||
| @@ -852,9 +862,9 @@ user: "用户" | ||||
| administration: "管理" | ||||
| accounts: "账户" | ||||
| switch: "切换" | ||||
| noMaintainerInformationWarning: "管理人员信息未设置。" | ||||
| noMaintainerInformationWarning: "尚未设置管理员信息。" | ||||
| noInquiryUrlWarning: "尚未设置联络地址。" | ||||
| noBotProtectionWarning: "Bot 防御未设置。" | ||||
| noBotProtectionWarning: "尚未设置 Bot 防御。" | ||||
| configure: "设置" | ||||
| postToGallery: "发送到图库" | ||||
| postToHashtag: "投稿到这个标签" | ||||
| @@ -870,11 +880,11 @@ priority: "优先级" | ||||
| high: "高" | ||||
| middle: "中" | ||||
| low: "低" | ||||
| emailNotConfiguredWarning: "电子邮件地址未设置。" | ||||
| emailNotConfiguredWarning: "尚未设置电子邮件地址。" | ||||
| ratio: "比率" | ||||
| previewNoteText: "预览文本" | ||||
| customCss: "自定义 CSS" | ||||
| customCssWarn: "这些设置必须有相关的基础知识,不当的配置可能导致客户端无法正常使用!" | ||||
| customCssWarn: "这些设置必须有相关的基础知识,不当的配置可能导致客户端无法正常使用。" | ||||
| global: "全局" | ||||
| squareAvatars: "显示方形头像图标" | ||||
| sent: "发送" | ||||
| @@ -911,13 +921,14 @@ manageAccounts: "管理账户" | ||||
| makeReactionsPublic: "将回应设置为公开" | ||||
| makeReactionsPublicDescription: "将您发表过的回应设置成公开可见。" | ||||
| classic: "经典" | ||||
| muteThread: "屏蔽帖子列表" | ||||
| unmuteThread: "取消屏蔽帖子列表" | ||||
| muteThread: "隐藏帖子列表" | ||||
| unmuteThread: "取消隐藏帖子列表" | ||||
| followingVisibility: "关注的人的公开范围" | ||||
| followersVisibility: "关注者的公开范围" | ||||
| continueThread: "查看更多帖子" | ||||
| deleteAccountConfirm: "将要删除账户。是否确认?" | ||||
| incorrectPassword: "密码错误" | ||||
| incorrectTotp: "一次性密码不正确或已过期" | ||||
| voteConfirm: "确定投给 “{choice}” ?" | ||||
| hide: "隐藏" | ||||
| useDrawerReactionPickerForMobile: "在移动设备上使用抽屉显示" | ||||
| @@ -934,7 +945,7 @@ searchByGoogle: "Google" | ||||
| instanceDefaultLightTheme: "服务器默认浅色主题" | ||||
| instanceDefaultDarkTheme: "服务器默认深色主题" | ||||
| instanceDefaultThemeDescription: "以对象格式输入主题代码" | ||||
| mutePeriod: "屏蔽期限" | ||||
| mutePeriod: "隐藏期限" | ||||
| period: "截止时间" | ||||
| indefinitely: "永久" | ||||
| tenMinutes: "10 分钟" | ||||
| @@ -942,6 +953,9 @@ oneHour: "1 小时" | ||||
| oneDay: "1 天" | ||||
| oneWeek: "1 周" | ||||
| oneMonth: "1 个月" | ||||
| threeMonths: "3 个月" | ||||
| oneYear: "1 年" | ||||
| threeDays: "3 天" | ||||
| reflectMayTakeTime: "可能需要一些时间才能体现出效果。" | ||||
| failedToFetchAccountInformation: "获取账户信息失败" | ||||
| rateLimitExceeded: "已超过速率限制" | ||||
| @@ -1049,7 +1063,7 @@ internalServerErrorDescription: "内部服务器发生了预期外的错误" | ||||
| copyErrorInfo: "复制错误信息" | ||||
| joinThisServer: "在本服务器上注册" | ||||
| exploreOtherServers: "探索其他服务器" | ||||
| letsLookAtTimeline: "时间线" | ||||
| letsLookAtTimeline: "看看时间线" | ||||
| disableFederationConfirm: "确定要禁用联合?" | ||||
| disableFederationConfirmWarn: "禁用联合不会将帖子设为私有。在大多数情况下,不需要禁用联合。" | ||||
| disableFederationOk: "联合禁用" | ||||
| @@ -1065,10 +1079,10 @@ nonSensitiveOnlyForLocalLikeOnlyForRemote: "仅限非敏感内容(远程仅点 | ||||
| rolesAssignedToMe: "指派给自己的角色" | ||||
| resetPasswordConfirm: "确定重置密码?" | ||||
| sensitiveWords: "敏感词" | ||||
| sensitiveWordsDescription: "将包含设置词的帖子的可见范围设置为首页。可以通过用换行符分隔来设置多个。" | ||||
| sensitiveWordsDescription: "包含这些词的帖子将只在首页可见。可用换行来设定多个词。" | ||||
| sensitiveWordsDescription2: "AND 条件用空格分隔,正则表达式用斜线包裹。" | ||||
| prohibitedWords: "禁用词" | ||||
| prohibitedWordsDescription: "发布包含设定词汇的帖子时将出错。可用换行设定多个关键字" | ||||
| prohibitedWordsDescription: "发布包含设定词汇的帖子时将出错。可用换行设定多个关键字。" | ||||
| prohibitedWordsDescription2: "AND 条件用空格分隔,正则表达式用斜线包裹。" | ||||
| hiddenTags: "隐藏标签" | ||||
| hiddenTagsDescription: "设定的标签将不会在时间线上显示。可使用换行来设置多个标签。" | ||||
| @@ -1082,6 +1096,7 @@ retryAllQueuesConfirmTitle: "要再尝试一次吗?" | ||||
| retryAllQueuesConfirmText: "可能会使服务器负荷在一定时间内增加" | ||||
| enableChartsForRemoteUser: "生成远程用户的图表" | ||||
| enableChartsForFederatedInstances: "生成远程服务器的图表" | ||||
| enableStatsForFederatedInstances: "获取远程服务器的信息" | ||||
| showClipButtonInNoteFooter: "在贴文下方显示便签按钮" | ||||
| reactionsDisplaySize: "回应显示大小" | ||||
| limitWidthOfReaction: "限制回应的最大宽度,并将其缩小显示" | ||||
| @@ -1110,7 +1125,7 @@ vertical: "纵向" | ||||
| horizontal: "横向" | ||||
| position: "位置" | ||||
| serverRules: "服务器规则" | ||||
| pleaseConfirmBelowBeforeSignup: "在这个服务器上注册账号前,请确认以下信息。" | ||||
| pleaseConfirmBelowBeforeSignup: "如果要在此服务器上注册,需要确认并同意以下内容。" | ||||
| pleaseAgreeAllToContinue: "必须全部勾选「同意」才能够继续。" | ||||
| continue: "继续" | ||||
| preservedUsernames: "保留的用户名" | ||||
| @@ -1150,10 +1165,10 @@ turnOffToImprovePerformance: "关闭该选项可以提高性能。" | ||||
| createInviteCode: "生成邀请码" | ||||
| createWithOptions: "使用选项来创建" | ||||
| createCount: "发行数" | ||||
| inviteCodeCreated: "已创建邀请码" | ||||
| inviteLimitExceeded: "可供发行的邀请码已达上限。" | ||||
| createLimitRemaining: "可供发行的邀请码:剩余{limit}个" | ||||
| inviteLimitResetCycle: "可以在{time}内发行最多{limit}个邀请码。" | ||||
| inviteCodeCreated: "已生成邀请码" | ||||
| inviteLimitExceeded: "可供生成的邀请码已达上限。" | ||||
| createLimitRemaining: "可供生成的邀请码:剩余 {limit} 个" | ||||
| inviteLimitResetCycle: "可以在 {time} 内生成最多 {limit} 个邀请码。" | ||||
| expirationDate: "有效日期" | ||||
| noExpirationDate: "不设置有效日期" | ||||
| inviteCodeUsedAt: "邀请码被使用的日期和时间" | ||||
| @@ -1194,10 +1209,10 @@ followingOrFollower: "关注中或关注者" | ||||
| fileAttachedOnly: "仅限媒体" | ||||
| showRepliesToOthersInTimeline: "在时间线中包含给别人的回复" | ||||
| hideRepliesToOthersInTimeline: "在时间线中隐藏给别人的回复" | ||||
| showRepliesToOthersInTimelineAll: "在时间线中包含现在关注的所有人的回复" | ||||
| hideRepliesToOthersInTimelineAll: "在时间线中隐藏现在关注的所有人的回复" | ||||
| confirmShowRepliesAll: "此操作不可撤销。确认要在时间线中包含现在关注的所有人的回复吗?" | ||||
| confirmHideRepliesAll: "此操作不可撤销。确认要在时间线中隐藏现在关注的所有人的回复吗?" | ||||
| showRepliesToOthersInTimelineAll: "在时间线中显示所有现在关注的人的回复" | ||||
| hideRepliesToOthersInTimelineAll: "在时间线中隐藏所有现在关注的人的回复" | ||||
| confirmShowRepliesAll: "此操作不可撤销。确认要在时间线中显示所有现在关注的人的回复吗?" | ||||
| confirmHideRepliesAll: "此操作不可撤销。确认要在时间线中隐藏所有现在关注的人的回复吗?" | ||||
| externalServices: "外部服务" | ||||
| sourceCode: "源代码" | ||||
| sourceCodeIsNotYetProvided: "还未提供源代码。要解决此问题请联系管理员。" | ||||
| @@ -1273,10 +1288,46 @@ genEmbedCode: "生成嵌入代码" | ||||
| noteOfThisUser: "此用户的帖子" | ||||
| clipNoteLimitExceeded: "无法再往此便签内添加更多帖子" | ||||
| performance: "性能" | ||||
| modified: "有变更" | ||||
| discard: "取消" | ||||
| thereAreNChanges: "有 {n} 处更改" | ||||
| signinWithPasskey: "使用通行密钥登录" | ||||
| unknownWebAuthnKey: "此通行密钥未注册。" | ||||
| passkeyVerificationFailed: "验证通行密钥失败。" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "通行密钥验证成功,但账户未开启无密码登录。" | ||||
| messageToFollower: "给关注者的消息" | ||||
| target: "对象" | ||||
| testCaptchaWarning: "此功能为测试 CAPTCHA 用。<strong>请勿在正式环境中使用。</strong>" | ||||
| prohibitedWordsForNameOfUser: "用户名中禁止的词" | ||||
| prohibitedWordsForNameOfUserDescription: "更改用户名时,如果用户名中包含此列表里的词汇,用户的改名请求将被拒绝。持有管理员权限的用户不受此限制。" | ||||
| yourNameContainsProhibitedWords: "目标用户名包含违禁词" | ||||
| yourNameContainsProhibitedWordsDescription: "用户名内含有违禁词。若想使用此用户名,请联系服务器管理员。" | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "根据发帖者的设定,需要登录才能显示" | ||||
| lockdown: "锁定" | ||||
| pleaseSelectAccount: "请选择帐户" | ||||
| availableRoles: "可用角色" | ||||
| acknowledgeNotesAndEnable: "理解注意事项后再开启。" | ||||
| federationSpecified: "此服务器已开启联合白名单。只能与管理员指定的服务器通信。" | ||||
| federationDisabled: "此服务器已禁用联合。无法与其它服务器上的用户通信。" | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "需要登录才能显示内容" | ||||
|   requireSigninToViewContentsDescription1: "您发布的所有帖子将变成需要登入后才会显示。有望防止爬虫收集各种信息。" | ||||
|   requireSigninToViewContentsDescription2: "没有 URL 预览(OGP)、内嵌网页、引用帖子的功能的服务器也将无法显示。" | ||||
|   requireSigninToViewContentsDescription3: "这些限制可能不适用于联合到远程服务器的内容。" | ||||
|   makeNotesFollowersOnlyBefore: "可将过去的帖子设为仅关注者可见" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "开启此设定时,超过设定的时间或日期后,帖子将变为仅关注者可见。关闭后帖子的公开状态将恢复成原本的设定。" | ||||
|   makeNotesHiddenBefore: "将过去的帖子设为私密" | ||||
|   makeNotesHiddenBeforeDescription: "开启此设定时,超过设定的时间或日期后,帖子将变为仅自己可见。关闭后帖子的公开状态将恢复成原本的设定。" | ||||
|   mayNotEffectForFederatedNotes: "与远程服务器联合的帖子在远端可能会没有效果。" | ||||
|   notesHavePassedSpecifiedPeriod: "超过指定时间的帖子" | ||||
|   notesOlderThanSpecifiedDateAndTime: "指定日期前的帖子" | ||||
| _abuseUserReport: | ||||
|   forward: "转发" | ||||
|   forwardDescription: "目标是匿名系统账户,将把举报转发给远程服务器。" | ||||
|   resolve: "解决" | ||||
|   accept: "确认" | ||||
|   reject: "拒绝" | ||||
|   resolveTutorial: "如果认可举报并已解决,选择「确认」将案件以肯定的态度标记为已解决。\n如果不认可举报,选择「拒绝」将案件以否定的态度标记为已解决。" | ||||
| _delivery: | ||||
|   status: "投递状态" | ||||
|   stop: "停止投递" | ||||
| @@ -1385,8 +1436,8 @@ _initialTutorial: | ||||
|     description: "对于服务器方针所要求要求的,又或者不适合直接展示的附件,请添加「敏感」标记。\n" | ||||
|     tryThisFile: "试试看,将附加到此窗口的图像标注为敏感!" | ||||
|     _exampleNote: | ||||
|       note: "拆纳豆包装时出错了…" | ||||
|     method: "要标注附件为敏感内容,请单击该文件以打开菜单,然后单击“标记为敏感内容”。" | ||||
|       note: "拆纳豆包装时失手了…" | ||||
|     method: "要标注附件为敏感内容,请单击该文件以打开菜单,然后单击「标记为敏感内容」。" | ||||
|     sensitiveSucceeded: "附加文件时,请遵循服务器的条款来设置正确敏感设定。\n" | ||||
|     doItToContinue: "将图像标记为敏感后才能够继续" | ||||
|   _done: | ||||
| @@ -1414,6 +1465,9 @@ _serverSettings: | ||||
|   reactionsBufferingDescription: "开启时可显著提高发送回应时的性能,及减轻数据库负荷。但 Redis 的内存用量会相应增加。" | ||||
|   inquiryUrl: "联络地址" | ||||
|   inquiryUrlDescription: "用来指定诸如向服务运营商咨询的论坛地址,或记载了运营商联系方式之类的网页地址。" | ||||
|   openRegistration: "开放注册" | ||||
|   openRegistrationWarning: "开放注册有风险。建议仅当能够持续监控服务器并在出现问题时能够立即响应时才打开它。" | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "若在一段时间内没有检测到管理活动,为防止垃圾信息,此设定将自动关闭。" | ||||
| _accountMigration: | ||||
|   moveFrom: "从别的账号迁移到此账户" | ||||
|   moveFromSub: "为另一个账户建立别名" | ||||
| @@ -1422,7 +1476,7 @@ _accountMigration: | ||||
|   moveTo: "把这个账户迁移到新的账户" | ||||
|   moveToLabel: "迁移后的账户" | ||||
|   moveCannotBeUndone: "一旦迁移账户,就无法撤销。" | ||||
|   moveAccountDescription: "\n迁移到新帐户。\n ・现有的关注者自动关注新帐户\n ・此帐户的所有关注者都将被删除\n ・您将无法再使用此帐户发帖。\n关注者迁移是自动的,但关注中迁移必须手动完成。请在迁移前在此帐户上导出关注列表,并在迁移后立即在目标帐户上执行导入。\n屏蔽列表也是如此,因此您必须手动迁移它。\n(此描述适用于该服务器(Misskey v13.12.0 或更高版本)。其他 ActivityPub 软件(例如 Mastodon)的行为可能有所不同。)" | ||||
|   moveAccountDescription: "\n迁移到新帐户。\n ・现有的关注者自动关注新帐户\n ・此帐户的所有关注者都将被删除\n ・您将无法再使用此帐户发帖。\n关注者迁移是自动的,但关注中迁移必须手动完成。请在迁移前在此帐户上导出关注列表,并在迁移后立即在目标帐户上执行导入。\n列表、隐藏、屏蔽也是如此,因此您必须手动迁移它。\n(此描述适用于该服务器(Misskey v13.12.0 或更高版本)。其他 ActivityPub 软件(例如 Mastodon)的行为可能有所不同。)" | ||||
|   moveAccountHowTo: "要进行账户迁移,请现在目标账户中为此账户建立一个别名。\n建立别名后,请像这样输入目标账户:@username@server.example.com" | ||||
|   startMigration: "迁移" | ||||
|   migrationConfirm: "确定要把此账户迁移到 {account} 吗?一旦确定后,此操作无法取消,此账户也无法以原来的状态使用。\n同时,请确认迁移后的账户,已创造别名。" | ||||
| @@ -1613,7 +1667,7 @@ _achievements: | ||||
|     _postedAt0min0sec: | ||||
|       title: "报时" | ||||
|       description: "在 0 点发布一篇帖子" | ||||
|       flavor: "报时信号最后一响,零点整" | ||||
|       flavor: "嘟 · 嘟 · 嘟 · 哔——" | ||||
|     _selfQuote: | ||||
|       title: "自我引用" | ||||
|       description: "引用了自己的帖子" | ||||
| @@ -1642,7 +1696,7 @@ _achievements: | ||||
|       title: "超高校级的幸运" | ||||
|       description: "每 10 秒有 0.005% 的概率自动获得" | ||||
|     _setNameToSyuilo: | ||||
|       title: "像神一样呐" | ||||
|       title: "上帝情结" | ||||
|       description: "将名称设定为 syuilo" | ||||
|     _passedSinceAccountCreated1: | ||||
|       title: "一周年" | ||||
| @@ -1661,9 +1715,9 @@ _achievements: | ||||
|       description: "在元旦登入" | ||||
|       flavor: "今年也请对本服务器多多指教!" | ||||
|     _cookieClicked: | ||||
|       title: "点击饼干小游戏" | ||||
|       title: "饼干点点乐" | ||||
|       description: "点击了饼干" | ||||
|       flavor: "用错软件了?" | ||||
|       flavor: "穿越了?" | ||||
|     _brainDiver: | ||||
|       title: "Brain Diver" | ||||
|       description: "发布了包含 Brain Diver 链接的帖子" | ||||
| @@ -1733,7 +1787,7 @@ _role: | ||||
|     canUpdateBioMedia: "可以更新头像和横幅" | ||||
|     pinMax: "帖子置顶数量限制" | ||||
|     antennaMax: "可创建的最大天线数量" | ||||
|     wordMuteMax: "屏蔽词的字数限制" | ||||
|     wordMuteMax: "隐藏词的字数限制" | ||||
|     webhookMax: "Webhook 创建数量限制" | ||||
|     clipMax: "便签创建数量限制" | ||||
|     noteEachClipsMax: "单个便签内的贴文数量限制" | ||||
| @@ -1746,9 +1800,9 @@ _role: | ||||
|     canUseTranslator: "使用翻译功能" | ||||
|     avatarDecorationLimit: "可添加头像挂件的最大个数" | ||||
|     canImportAntennas: "允许导入天线" | ||||
|     canImportBlocking: "允许导入拉黑列表" | ||||
|     canImportBlocking: "允许导入屏蔽列表" | ||||
|     canImportFollowing: "允许导入关注列表" | ||||
|     canImportMuting: "允许导入屏蔽列表" | ||||
|     canImportMuting: "允许导入隐藏列表" | ||||
|     canImportUserLists: "允许导入用户列表" | ||||
|   _condition: | ||||
|     roleAssignedTo: "已分配给手动角色" | ||||
| @@ -1896,14 +1950,14 @@ _menuDisplay: | ||||
|   top: "顶部" | ||||
|   hide: "隐藏" | ||||
| _wordMute: | ||||
|   muteWords: "禁用词" | ||||
|   muteWords: "要隐藏的词" | ||||
|   muteWordsDescription: "AND 条件用空格分隔,OR 条件用换行符分隔。" | ||||
|   muteWordsDescription2: "正则表达式用斜线包裹" | ||||
| _instanceMute: | ||||
|   instanceMuteDescription: "屏蔽服务器中的所有帖子和转帖,包括这些服务器上的用户回复。" | ||||
|   instanceMuteDescription: "隐藏服务器中的所有帖子和转帖,包括这些服务器上的用户回复。" | ||||
|   instanceMuteDescription2: "一行一个" | ||||
|   title: "隐藏服务器已设置的帖子。" | ||||
|   heading: "屏蔽服务器" | ||||
|   title: "下面实例中的帖子将被隐藏。" | ||||
|   heading: "已隐藏的服务器" | ||||
| _theme: | ||||
|   explore: "寻找主题" | ||||
|   install: "安装主题" | ||||
| @@ -1967,7 +2021,6 @@ _theme: | ||||
|     buttonBg: "按钮背景" | ||||
|     buttonHoverBg: "按钮背景(悬停)" | ||||
|     inputBorder: "输入框边框" | ||||
|     listItemHoverBg: "下拉列表项目背景(悬停)" | ||||
|     driveFolderBg: "网盘的文件夹背景" | ||||
|     wallpaperOverlay: "壁纸叠加层" | ||||
|     badge: "徽章" | ||||
| @@ -2024,12 +2077,12 @@ _2fa: | ||||
|   step4: "从现在开始,任何登录操作都将要求您提供动态口令。" | ||||
|   securityKeyNotSupported: "您的浏览器不支持安全密钥。" | ||||
|   registerTOTPBeforeKey: "要注册安全密钥或 Passkey,请先设置验证器。" | ||||
|   securityKeyInfo: "注册兼容 WebAuthn 的密钥,例如支持 FIDO2 的硬件安全密钥、设备上的生物识别功能、PIN 码以及 Passkey 等。" | ||||
|   securityKeyInfo: "注册兼容 WebAuthn 的密钥,例如支持 FIDO2 的硬件安全密钥、设备上的生物识别功能、PIN 以及 Passkey 等。" | ||||
|   registerSecurityKey: "注册安全密钥或 Passkey" | ||||
|   securityKeyName: "输入密钥名称" | ||||
|   tapSecurityKey: "请按照浏览器说明操作来注册安全密钥或 Passkey。" | ||||
|   removeKey: "删除安全密钥" | ||||
|   removeKeyConfirm: "您确定要删除 {name} 吗?" | ||||
|   removeKeyConfirm: "确定要删除 {name} 吗?" | ||||
|   whyTOTPOnlyRenew: "当注册了安全密钥时,无法取消使用验证器。" | ||||
|   renewTOTP: "重置验证器" | ||||
|   renewTOTPConfirm: "当前验证器的验证码及备用代码已失效" | ||||
| @@ -2044,8 +2097,8 @@ _2fa: | ||||
| _permissions: | ||||
|   "read:account": "查看账户信息" | ||||
|   "write:account": "更改帐户信息" | ||||
|   "read:blocks": "查看黑名单" | ||||
|   "write:blocks": "编辑黑名单" | ||||
|   "read:blocks": "查看屏蔽列表" | ||||
|   "write:blocks": "编辑屏蔽列表" | ||||
|   "read:drive": "查看网盘" | ||||
|   "write:drive": "管理网盘文件" | ||||
|   "read:favorites": "查看收藏夹" | ||||
| @@ -2054,8 +2107,8 @@ _permissions: | ||||
|   "write:following": "关注/取消关注" | ||||
|   "read:messaging": "查看消息" | ||||
|   "write:messaging": "撰写或删除消息" | ||||
|   "read:mutes": "查看屏蔽列表" | ||||
|   "write:mutes": "编辑屏蔽列表" | ||||
|   "read:mutes": "查看隐藏列表" | ||||
|   "write:mutes": "编辑隐藏列表" | ||||
|   "write:notes": "撰写或删除帖子" | ||||
|   "read:notifications": "查看通知" | ||||
|   "write:notifications": "管理通知" | ||||
| @@ -2134,8 +2187,11 @@ _auth: | ||||
|   permissionAsk: "这个应用程序需要以下权限" | ||||
|   pleaseGoBack: "请返回到应用程序" | ||||
|   callback: "回到应用程序" | ||||
|   accepted: "已允许访问" | ||||
|   denied: "拒绝访问" | ||||
|   scopeUser: "以下面的用户进行操作" | ||||
|   pleaseLogin: "在对应用进行授权许可之前,请先登录" | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "允许访问后将会自动重定向到以下 URL" | ||||
| _antennaSources: | ||||
|   all: "所有帖子" | ||||
|   homeTimeline: "已关注用户的帖子" | ||||
| @@ -2234,7 +2290,7 @@ _profile: | ||||
|   name: "昵称" | ||||
|   username: "用户名" | ||||
|   description: "个人简介" | ||||
|   youCanIncludeHashtags: "你可以在个人简介中包含一些#标签。" | ||||
|   youCanIncludeHashtags: "可以在个人简介中包含 #标签。" | ||||
|   metadata: "附加信息" | ||||
|   metadataEdit: "附加信息编辑" | ||||
|   metadataDescription: "最多可以在个人资料中以表格形式显示四条其他信息。" | ||||
| @@ -2244,13 +2300,16 @@ _profile: | ||||
|   changeBanner: "修改横幅" | ||||
|   verifiedLinkDescription: "如果将内容设置为 URL,当链接所指向的网页内包含自己的个人资料链接时,可以显示一个已验证图标。" | ||||
|   avatarDecorationMax: "最多可添加 {max} 个挂件" | ||||
|   followedMessage: "被关注时显示的消息" | ||||
|   followedMessageDescription: "可以设置被关注时向对方显示的短消息。" | ||||
|   followedMessageDescriptionForLockedAccount: "需要批准才能关注的情况下,消息是在请求被批准后显示。" | ||||
| _exportOrImport: | ||||
|   allNotes: "所有帖子" | ||||
|   favoritedNotes: "收藏的帖子" | ||||
|   clips: "便签" | ||||
|   followingList: "关注中" | ||||
|   muteList: "屏蔽" | ||||
|   blockingList: "拉黑" | ||||
|   muteList: "隐藏" | ||||
|   blockingList: "屏蔽" | ||||
|   userLists: "列表" | ||||
|   excludeMutingUsers: "排除屏蔽用户" | ||||
|   excludeInactiveUsers: "排除不活跃用户" | ||||
| @@ -2335,7 +2394,7 @@ _pages: | ||||
|   fontSansSerif: "无衬线字体" | ||||
|   eyeCatchingImageSet: "设置封面图片" | ||||
|   eyeCatchingImageRemove: "删除封面图片" | ||||
|   chooseBlock: "添加块" | ||||
|   chooseBlock: "添加内容块" | ||||
|   enterSectionTitle: "输入会话标题" | ||||
|   selectType: "选择类型" | ||||
|   contentBlocks: "内容" | ||||
| @@ -2347,8 +2406,8 @@ _pages: | ||||
|     section: "章节" | ||||
|     image: "图片" | ||||
|     button: "按钮" | ||||
|     dynamic: "动态区块" | ||||
|     dynamicDescription: "这个区块已经废弃。以后请使用{play}。" | ||||
|     dynamic: "动态内容块" | ||||
|     dynamicDescription: "这个内容块已经废弃。以后请使用{play}。" | ||||
|     note: "嵌入的帖子" | ||||
|     _note: | ||||
|       id: "帖子 ID" | ||||
| @@ -2382,7 +2441,8 @@ _notification: | ||||
|   renotedBySomeUsers: "{n} 人转发了" | ||||
|   followedBySomeUsers: "被 {n} 人关注" | ||||
|   flushNotification: "重置通知历史" | ||||
|   exportOfXCompleted: "已完成 {x} 个导出" | ||||
|   exportOfXCompleted: "已完成 {x} 的导出" | ||||
|   login: "有新的登录" | ||||
|   _types: | ||||
|     all: "全部" | ||||
|     note: "用户的新帖子" | ||||
| @@ -2398,6 +2458,7 @@ _notification: | ||||
|     roleAssigned: "授予的角色" | ||||
|     achievementEarned: "取得的成就" | ||||
|     exportCompleted: "已完成导出" | ||||
|     login: "登录" | ||||
|     test: "测试通知" | ||||
|     app: "关联应用的通知" | ||||
|   _actions: | ||||
| @@ -2464,6 +2525,8 @@ _webhookSettings: | ||||
|     abuseReport: "当收到举报时" | ||||
|     abuseReportResolved: "当举报被处理时" | ||||
|     userCreated: "当用户被创建时" | ||||
|     inactiveModeratorsWarning: "当管理员在一段时间内不活跃时" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "当因为管理员在一段时间内不活跃,导致服务器变为邀请制时" | ||||
|   deleteConfirm: "要删除 webhook 吗?" | ||||
|   testRemarks: "点击开关右侧的按钮,可以发送使用假数据的测试 Webhook。" | ||||
| _abuseReport: | ||||
| @@ -2509,6 +2572,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "标记网盘文件为敏感媒体" | ||||
|   unmarkSensitiveDriveFile: "取消标记网盘文件为敏感媒体" | ||||
|   resolveAbuseReport: "处理举报" | ||||
|   forwardAbuseReport: "转发举报" | ||||
|   updateAbuseReportNote: "更新举报用管理笔记" | ||||
|   createInvitation: "生成邀请码" | ||||
|   createAd: "创建了广告" | ||||
|   deleteAd: "删除了广告" | ||||
| @@ -2664,6 +2729,66 @@ _contextMenu: | ||||
|   app: "应用" | ||||
|   appWithShift: "Shift 键应用" | ||||
|   native: "浏览器的用户界面" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "此值为必填项" | ||||
|     columnTypeNotSupport: "正则表达式验证仅支持 type:text 列。" | ||||
|     patternNotMatch: "此值与 {pattern} 的模式不一致" | ||||
|     notUnique: "此值必须唯一" | ||||
| _roleSelectDialog: | ||||
|   notSelected: "未选中" | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "复制所选行" | ||||
|     copySelectionRanges: "复制所选范围" | ||||
|     deleteSelectionRows: "删除所选行" | ||||
|     deleteSelectionRanges: "删除所选范围的行" | ||||
|     searchSettings: "搜索设置" | ||||
|     searchSettingCaption: "设置详细的搜索条件。" | ||||
|     searchLimit: "显示项目数" | ||||
|     sortOrder: "排序方式" | ||||
|     registrationLogs: "注册日志" | ||||
|     registrationLogsCaption: "将显示更新和删除表情符号的日志。执行更新或删除操作,又或者更改或重新加载页面时会消失。" | ||||
|     alertEmojisRegisterFailedDescription: "更新或删除表情符号失败。详情请确认注册日志。" | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "显示成功日志" | ||||
|     failureLogNothing: "没有失败日志。" | ||||
|     logNothing: "没有日志" | ||||
|   _remote: | ||||
|     selectionRowDetail: "所选行的详细信息" | ||||
|     importSelectionRows: "导入所选行" | ||||
|     importSelectionRangesRows: "导入所选范围的行" | ||||
|     importEmojisButton: "导入已选择的表情符号" | ||||
|     confirmImportEmojisTitle: "导入表情符号" | ||||
|     confirmImportEmojisDescription: "是否导入从远程服务器接收的 {count} 个表情符号?请密切关注表情符号的许可协议。" | ||||
|   _local: | ||||
|     tabTitleList: "已注册的表情符号列表" | ||||
|     tabTitleRegister: "注册表情符号" | ||||
|     _list: | ||||
|       emojisNothing: "没有已注册的表情符号。" | ||||
|       markAsDeleteTargetRows: "将所选行标记为删除对象" | ||||
|       markAsDeleteTargetRanges: "将所选范围的行标记为删除对象" | ||||
|       alertUpdateEmojisNothingDescription: "没有已更改的表情符号。" | ||||
|       alertDeleteEmojisNothingDescription: "没有被标记为删除对象的表情符号。" | ||||
|       confirmMovePage: "要离开此页吗?" | ||||
|       confirmChangeView: "要更改显示吗?" | ||||
|       confirmUpdateEmojisDescription: "要更新 {count} 个表情符号吗?" | ||||
|       confirmDeleteEmojisDescription: "要删除已选择的 {count} 个表情符号吗?" | ||||
|       confirmResetDescription: "至今为止所做的所有修改都将被重置。" | ||||
|       confirmMovePageDesciption: "此页面上的表情符号已更改。\n若不保存就离开此页,此页面上所有的更改都将丢失。" | ||||
|       dialogSelectRoleTitle: "按角色搜索表情符号" | ||||
|     _register: | ||||
|       uploadSettingTitle: "上传设置" | ||||
|       uploadSettingDescription: "可以在此页面设置上传表情符号时的行为。" | ||||
|       directoryToCategoryLabel: "目录名请输入「category」" | ||||
|       directoryToCategoryCaption: "拖放目录时,目录名请输入「category」" | ||||
|       emojiInputAreaCaption: "请使用其中一种方法选择要注册的表情符号。" | ||||
|       emojiInputAreaList1: "在此区域内拖放图像文件或者目录" | ||||
|       emojiInputAreaList2: "单击此链接以从电脑中选择" | ||||
|       emojiInputAreaList3: "单击此链接以从网盘中选择" | ||||
|       confirmRegisterEmojisDescription: "要将列表内显示的表情符号替换为新的自定义表情符号吗?(为降低服务器负载,一次操作最多只能注册 {count} 个表情符号)" | ||||
|       confirmClearEmojisDescription: "要放弃编辑并将列表内表示的表情符号清空吗?" | ||||
|       confirmUploadEmojisDescription: "要将拖放的 {count} 个文件上传到网盘上吗?" | ||||
| _embedCodeGen: | ||||
|   title: "自定义嵌入代码" | ||||
|   header: "显示标题" | ||||
| @@ -2678,3 +2803,43 @@ _embedCodeGen: | ||||
|   generateCode: "生成嵌入代码" | ||||
|   codeGenerated: "已生成代码" | ||||
|   codeGeneratedDescription: "将生成的代码贴到网站上来使用。" | ||||
| _selfXssPrevention: | ||||
|   warning: "警告" | ||||
|   title: "「在此处粘贴什么东西」是欺诈行为。" | ||||
|   description1: "如果在此处粘贴了什么,恶意用户可能会接管账户或者盗取个人资料。" | ||||
|   description2: "如果不能完全理解将要粘贴的内容,%c 请立即停止操作并关闭这个窗口。" | ||||
|   description3: "详情请看这里。{link}" | ||||
| _followRequest: | ||||
|   recieved: "已收到申请" | ||||
|   sent: "已发送申请" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "无法与此服务器通信" | ||||
|     description: "与此服务器的通信可能被禁用,又或者是屏蔽了此服务器或被此服务器屏蔽了。\n请联系服务器的管理者。" | ||||
|   _uriInvalid: | ||||
|     title: "URI 有误" | ||||
|     description: "输入的 URI 有问题。请确认是否输入了 URI 中无法使用的字符。" | ||||
|   _requestFailed: | ||||
|     title: "请求失败" | ||||
|     description: "与该服务器的通信失败。对面服务器可能不可用。另外,请确认是否输入了无效或不存在的 URI。" | ||||
|   _responseInvalid: | ||||
|     title: "响应无效" | ||||
|     description: "成功与此服务器通信,但返回的数据无效。" | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "输入 URI 的域名和最终取得的 URI 的域名不同。如果是通过第三方服务器获取远程内容,请使用可以从原始服务器获取内容的 URI 再试一次。" | ||||
|   _noSuchObject: | ||||
|     title: "未找到" | ||||
|     description: "未找到请求的资源。请再次检查 URI。" | ||||
| _captcha: | ||||
|   verify: "请通过 CAPTCHA 验证" | ||||
|   testSiteKeyMessage: "输入测试用的网站密钥及私密密钥后可以生成预览并检查,\n详情请看以下页面。" | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "请求 CAPTCHA 失败" | ||||
|       text: "请稍后再试,又或者再检查一次设置。" | ||||
|     _verificationFailed: | ||||
|       title: "验证 CAPTCHA 失败" | ||||
|       text: "请再次确认设置是否正确。" | ||||
|     _unknown: | ||||
|       title: "CAPTCHA 错误" | ||||
|       text: "发生意外错误。" | ||||
|   | ||||
| @@ -5,9 +5,13 @@ introMisskey: "歡迎!Misskey 是一個開放原始碼且去中心化的社群 | ||||
| poweredByMisskeyDescription: "{name}是開放原始碼平臺 <b>Misskey</b> 的伺服器之一。" | ||||
| monthAndDay: "{month} 月 {day} 日" | ||||
| search: "搜尋" | ||||
| reset: "重設" | ||||
| notifications: "通知" | ||||
| username: "使用者名稱" | ||||
| password: "密碼" | ||||
| initialPasswordForSetup: "啟動初始設定的密碼" | ||||
| initialPasswordIsIncorrect: "啟動初始設定的密碼錯誤。" | ||||
| initialPasswordForSetupDescription: "如果您自己安裝了 Misskey,請使用您在設定檔中輸入的密碼。\n如果您使用 Misskey 的託管服務之類的服務,請使用提供的密碼。\n如果您尚未設定密碼,請將其留空並繼續。" | ||||
| forgotPassword: "忘記密碼" | ||||
| fetchingAsApObject: "從聯邦宇宙取得中..." | ||||
| ok: "OK" | ||||
| @@ -45,6 +49,7 @@ pin: "置頂" | ||||
| unpin: "取消置頂" | ||||
| copyContent: "複製內容" | ||||
| copyLink: "複製連結" | ||||
| copyRemoteLink: "複製遠端的連結" | ||||
| copyLinkRenote: "複製轉發的連結" | ||||
| delete: "刪除" | ||||
| deleteAndEdit: "刪除並編輯" | ||||
| @@ -227,7 +232,7 @@ instanceInfo: "伺服器資訊" | ||||
| statistics: "統計" | ||||
| clearQueue: "清除佇列" | ||||
| clearQueueConfirmTitle: "確定要清除佇列嗎?" | ||||
| clearQueueConfirmText: "未發佈的貼文將不會發佈。您通常不需要確認。" | ||||
| clearQueueConfirmText: "未成功發佈的貼文將不會再嘗試發佈。通常不需要進行這項操作。" | ||||
| clearCachedFiles: "清除快取資料" | ||||
| clearCachedFilesConfirm: "確定要清除所有遠端暫存資料嗎?" | ||||
| blockedInstances: "已封鎖的伺服器" | ||||
| @@ -288,8 +293,8 @@ messaging: "聊天" | ||||
| upload: "上傳" | ||||
| keepOriginalUploading: "保留原圖" | ||||
| keepOriginalUploadingDescription: "上傳圖片時保留原始圖片。關閉時,瀏覽器會在上傳時生成適用於網路傳送的版本。" | ||||
| fromDrive: "從雲端空間" | ||||
| fromUrl: "從 URL" | ||||
| fromDrive: "從雲端空間中選擇" | ||||
| fromUrl: "從 URL 上傳" | ||||
| uploadFromUrl: "從網址上傳" | ||||
| uploadFromUrlDescription: "您要上傳的檔案網址" | ||||
| uploadFromUrlRequested: "已請求上傳" | ||||
| @@ -321,7 +326,7 @@ light: "淺色" | ||||
| dark: "深色" | ||||
| lightThemes: "淺色佈景主題" | ||||
| darkThemes: "深色佈景主題" | ||||
| syncDeviceDarkMode: "與設備的深色模式同步" | ||||
| syncDeviceDarkMode: "與裝置的深色模式同步" | ||||
| drive: "雲端硬碟" | ||||
| fileName: "檔案名稱" | ||||
| selectFile: "選擇檔案" | ||||
| @@ -379,7 +384,6 @@ enableLocalTimeline: "啟用本地時間軸" | ||||
| enableGlobalTimeline: "啟用全域時間軸" | ||||
| disablingTimelinesInfo: "為了方便,即使您關閉了時間軸功能,管理員和審查員仍可以繼續使用。" | ||||
| registration: "註冊" | ||||
| enableRegistration: "開放新使用者註冊" | ||||
| invite: "邀請" | ||||
| driveCapacityPerLocalAccount: "每個本地使用者的雲端硬碟容量" | ||||
| driveCapacityPerRemoteAccount: "每個非本地用戶的雲端空間大小" | ||||
| @@ -451,6 +455,7 @@ totpDescription: "以驗證應用程式輸入一次性密碼" | ||||
| moderator: "審查員" | ||||
| moderation: "審查" | ||||
| moderationNote: "管理筆記" | ||||
| moderationNoteDescription: "您可以編寫僅在審查員之間共用的註解。" | ||||
| addModerationNote: "新增管理筆記" | ||||
| moderationLogs: "管理日誌" | ||||
| nUsersMentioned: "被 {n} 個人提及" | ||||
| @@ -516,7 +521,7 @@ menuStyle: "選單風格" | ||||
| style: "風格" | ||||
| drawer: "側邊欄" | ||||
| popup: "彈出式視窗" | ||||
| showNoteActionsOnlyHover: "僅在游標停留時顯示貼文的操作選項" | ||||
| showNoteActionsOnlyHover: "僅在游標停留時顯示貼文的" | ||||
| showReactionsCount: "顯示貼文的反應數目" | ||||
| noHistory: "沒有歷史紀錄" | ||||
| signinHistory: "登入歷史" | ||||
| @@ -583,6 +588,7 @@ masterVolume: "主音量" | ||||
| notUseSound: "關閉音效" | ||||
| useSoundOnlyWhenActive: "瀏覽器在前景運作時,Misskey 才會發出音效" | ||||
| details: "詳細資訊" | ||||
| renoteDetails: "轉發貼文的細節" | ||||
| chooseEmoji: "選擇您的表情符號" | ||||
| unableToProcess: "操作無法完成" | ||||
| recentUsed: "最近使用" | ||||
| @@ -680,11 +686,15 @@ smtpSecure: "在 SMTP 連接中使用隱式 SSL/TLS" | ||||
| smtpSecureInfo: "使用 STARTTLS 時關閉。" | ||||
| testEmail: "測試郵件發送" | ||||
| wordMute: "被靜音的文字" | ||||
| wordMuteDescription: "將包含指定語句的貼文最小化。 點擊最小化的貼文即可顯示。" | ||||
| hardWordMute: "硬文字靜音" | ||||
| showMutedWord: "顯示靜音字" | ||||
| hardWordMuteDescription: "隱藏含有指定語句的貼文。 與詞彙靜音不同的是,貼文將完全隱藏不見。" | ||||
| regexpError: "正規表達式錯誤" | ||||
| regexpErrorDescription: "{tab} 靜音文字的第 {line} 行的正規表達式有錯誤:" | ||||
| instanceMute: "被靜音的實例" | ||||
| userSaysSomething: "{name}說了什麼" | ||||
| userSaysSomethingAbout: "{name} 說了一些關於「{word}」的話" | ||||
| makeActive: "啟用" | ||||
| display: "檢視" | ||||
| copy: "複製" | ||||
| @@ -716,10 +726,7 @@ abuseReported: "檢舉完成。感謝您的報告。" | ||||
| reporter: "檢舉者" | ||||
| reporteeOrigin: "檢舉來源" | ||||
| reporterOrigin: "檢舉者來源" | ||||
| forwardReport: "將報告轉送給遠端伺服器" | ||||
| forwardReportIsAnonymous: "在遠端實例上看不到您的資訊,顯示的報告者是匿名的系统帳戶。" | ||||
| send: "發送" | ||||
| abuseMarkAsResolved: "處理完畢" | ||||
| openInNewTab: "在新分頁中開啟" | ||||
| openInSideView: "在側欄中開啟" | ||||
| defaultNavigationBehaviour: "預設導航" | ||||
| @@ -763,7 +770,7 @@ alwaysMarkSensitive: "預設標記檔案為敏感內容" | ||||
| loadRawImages: "以原始圖檔顯示附件圖檔的縮圖" | ||||
| disableShowingAnimatedImages: "不播放動態圖檔" | ||||
| highlightSensitiveMedia: "強調敏感標記" | ||||
| verificationEmailSent: "已發送驗證電子郵件。請點擊進入電子郵件中的鏈接完成驗證。" | ||||
| verificationEmailSent: "已發送驗證電子郵件。請點擊進入電子郵件中的連結以完成驗證。" | ||||
| notSet: "未設定" | ||||
| emailVerified: "已成功驗證您的電子郵件地址" | ||||
| noteFavoritesCount: "我的最愛貼文的數目" | ||||
| @@ -820,7 +827,7 @@ apply: "套用" | ||||
| receiveAnnouncementFromInstance: "接收來自伺服器的通知" | ||||
| emailNotification: "郵件通知" | ||||
| publish: "發布" | ||||
| inChannelSearch: "頻道内搜尋" | ||||
| inChannelSearch: "頻道內搜尋" | ||||
| useReactionPickerForContextMenu: "點擊右鍵開啟反應選擇器" | ||||
| typingUsers: "{users}輸入中" | ||||
| jumpToSpecifiedDate: "跳轉到特定日期" | ||||
| @@ -921,9 +928,10 @@ followersVisibility: "追隨者的可見性" | ||||
| continueThread: "查看更多貼文" | ||||
| deleteAccountConfirm: "將要刪除帳戶。是否確定?" | ||||
| incorrectPassword: "密碼錯誤。" | ||||
| incorrectTotp: "一次性密碼錯誤,或者已過期。" | ||||
| voteConfirm: "確定投給「{choice}」?" | ||||
| hide: "隱藏" | ||||
| useDrawerReactionPickerForMobile: "在移動設備上使用抽屜顯示" | ||||
| useDrawerReactionPickerForMobile: "在行動裝置上使用抽屜顯示" | ||||
| welcomeBackWithName: "歡迎回來,{name}" | ||||
| clickToFinishEmailVerification: "點擊 [{ok}] 完成電子郵件地址認證。" | ||||
| overridedDeviceKind: "裝置類型" | ||||
| @@ -945,6 +953,9 @@ oneHour: "一小時" | ||||
| oneDay: "一天" | ||||
| oneWeek: "一週" | ||||
| oneMonth: "一個月" | ||||
| threeMonths: "3 個月" | ||||
| oneYear: "1 年" | ||||
| threeDays: "3 日" | ||||
| reflectMayTakeTime: "可能需要一些時間才會出現效果。" | ||||
| failedToFetchAccountInformation: "取得帳戶資訊失敗" | ||||
| rateLimitExceeded: "已超過速率限制" | ||||
| @@ -1001,7 +1012,7 @@ unsubscribePushNotification: "停用推播通知" | ||||
| pushNotificationAlreadySubscribed: "推播通知啟用中" | ||||
| pushNotificationNotSupported: "瀏覽器或伺服器不支援推播通知" | ||||
| sendPushNotificationReadMessage: "如果已閱讀通知與訊息,就刪除推播通知" | ||||
| sendPushNotificationReadMessageCaption: "「{emptyPushNotificationMessage}」通知將立刻顯示。可能會更消耗裝置電池。" | ||||
| sendPushNotificationReadMessageCaption: "可能會導致裝置的電池消耗量增加。" | ||||
| windowMaximize: "最大化" | ||||
| windowMinimize: "最小化" | ||||
| windowRestore: "復原" | ||||
| @@ -1017,7 +1028,7 @@ show: "檢視" | ||||
| neverShow: "不再顯示" | ||||
| remindMeLater: "以後再說" | ||||
| didYouLikeMisskey: "您喜歡 Misskey 嗎?" | ||||
| pleaseDonate: "Misskey 是由 {host} 使用的免費軟體。請贊助我們,讓開發得以持續!" | ||||
| pleaseDonate: "Misskey是由{host}使用的免費軟體。請贊助我們,讓開發的工作能夠持續!" | ||||
| correspondingSourceIsAvailable: "對應的原始碼可以在 {anchor} 處找到。" | ||||
| roles: "角色" | ||||
| role: "角色" | ||||
| @@ -1085,6 +1096,7 @@ retryAllQueuesConfirmTitle: "要現在重試嗎?" | ||||
| retryAllQueuesConfirmText: "伺服器的負荷可能會暫時增加。" | ||||
| enableChartsForRemoteUser: "生成遠端使用者的圖表" | ||||
| enableChartsForFederatedInstances: "生成遠端伺服器的圖表" | ||||
| enableStatsForFederatedInstances: "取得遠端伺服器資訊" | ||||
| showClipButtonInNoteFooter: "新增摘錄按鈕至貼文" | ||||
| reactionsDisplaySize: "反應的顯示尺寸" | ||||
| limitWidthOfReaction: "限制反應的最大寬度,並縮小顯示尺寸。" | ||||
| @@ -1113,7 +1125,7 @@ vertical: "直向" | ||||
| horizontal: "橫向" | ||||
| position: "位置" | ||||
| serverRules: "伺服器規則" | ||||
| pleaseConfirmBelowBeforeSignup: "在本伺服器註冊之前,請確認下列事項。" | ||||
| pleaseConfirmBelowBeforeSignup: "在本伺服器註冊之前,必須確認並同意以下內容。" | ||||
| pleaseAgreeAllToContinue: "必須全部勾選「同意」才能繼續。" | ||||
| continue: "繼續" | ||||
| preservedUsernames: "保留的使用者名稱" | ||||
| @@ -1169,20 +1181,20 @@ used: "已使用" | ||||
| expired: "過期" | ||||
| doYouAgree: "你同意嗎?" | ||||
| beSureToReadThisAsItIsImportant: "重要,請務必閱讀。" | ||||
| iHaveReadXCarefullyAndAgree: "我已仔細閱讀並同意「{x}」的内容。" | ||||
| iHaveReadXCarefullyAndAgree: "我已仔細閱讀並同意「{x}」的內容。" | ||||
| dialog: "對話方塊" | ||||
| icon: "圖示" | ||||
| forYou: "給您" | ||||
| currentAnnouncements: "最新公告" | ||||
| pastAnnouncements: "歷史公告" | ||||
| youHaveUnreadAnnouncements: "有未讀的公告。" | ||||
| useSecurityKey: "請按照瀏覽器或設備上的說明使用安全金鑰或 Passkey。" | ||||
| useSecurityKey: "請按照瀏覽器或裝置上的說明來使用安全金鑰或 Passkey。" | ||||
| replies: "回覆" | ||||
| renotes: "轉發" | ||||
| loadReplies: "閱覽回覆" | ||||
| loadConversation: "閱覽對話" | ||||
| pinnedList: "已置頂的清單" | ||||
| keepScreenOn: "保持設備螢幕開啟" | ||||
| keepScreenOn: "保持裝置螢幕開啟" | ||||
| verifiedLink: "已驗證連結" | ||||
| notifyNotes: "開啟貼文通知" | ||||
| unnotifyNotes: "關閉貼文通知" | ||||
| @@ -1193,7 +1205,7 @@ showRenotes: "顯示其他人的轉發貼文" | ||||
| edited: "已編輯" | ||||
| notificationRecieveConfig: "接受通知的設定" | ||||
| mutualFollow: "互相追隨" | ||||
| followingOrFollower: "追隨中或追隨者" | ||||
| followingOrFollower: "追隨中或者追隨者" | ||||
| fileAttachedOnly: "只顯示包含附件的貼文" | ||||
| showRepliesToOthersInTimeline: "顯示給其他人的回覆" | ||||
| hideRepliesToOthersInTimeline: "在時間軸上隱藏給其他人的回覆" | ||||
| @@ -1237,7 +1249,7 @@ overwriteContentConfirm: "確定要覆蓋目前的內容嗎?" | ||||
| seasonalScreenEffect: "隨季節變換畫面的呈現" | ||||
| decorate: "設置頭像裝飾" | ||||
| addMfmFunction: "插入 MFM 功能語法" | ||||
| enableQuickAddMfmFunction: "顯示高級 MFM 選擇器" | ||||
| enableQuickAddMfmFunction: "顯示進階 MFM 選擇器" | ||||
| bubbleGame: "氣泡遊戲" | ||||
| sfx: "音效" | ||||
| soundWillBePlayed: "將播放音效" | ||||
| @@ -1264,7 +1276,7 @@ useNativeUIForVideoAudioPlayer: "使用瀏覽器的 UI 播放影片與音訊" | ||||
| keepOriginalFilename: "保留原始檔名" | ||||
| keepOriginalFilenameDescription: "如果關閉此設置,上傳時檔案名稱會自動替換為隨機字串。" | ||||
| noDescription: "沒有說明文字" | ||||
| alwaysConfirmFollow: "點擊追隨時總是顯示確認訊息" | ||||
| alwaysConfirmFollow: "追隨時總是確認" | ||||
| inquiry: "聯絡我們" | ||||
| tryAgain: "請再試一次。" | ||||
| confirmWhenRevealingSensitiveMedia: "要顯示敏感媒體時需確認" | ||||
| @@ -1283,6 +1295,39 @@ signinWithPasskey: "使用密碼金鑰登入" | ||||
| unknownWebAuthnKey: "未註冊的金鑰。" | ||||
| passkeyVerificationFailed: "驗證金鑰失敗。" | ||||
| passkeyVerificationSucceededButPasswordlessLoginDisabled: "雖然驗證金鑰成功,但是無密碼登入的方式是停用的。" | ||||
| messageToFollower: "給追隨者的訊息" | ||||
| target: "目標 " | ||||
| testCaptchaWarning: "此功能用於 CAPTCHA 的測試。<strong>請勿在正式環境中使用。</strong>" | ||||
| prohibitedWordsForNameOfUser: "禁止使用的字詞(使用者名稱)" | ||||
| prohibitedWordsForNameOfUserDescription: "如果使用者名稱包含此清單中的任何字串,則拒絕重新命名使用者。 具有審查員權限的使用者不受此限制的影響。" | ||||
| yourNameContainsProhibitedWords: "您嘗試更改的名稱包含禁止的字串" | ||||
| yourNameContainsProhibitedWordsDescription: "名稱中包含禁止使用的字串。 如果您想使用此名稱,請聯絡您的伺服器管理員。" | ||||
| thisContentsAreMarkedAsSigninRequiredByAuthor: "作者將其設定為需要登入才能顯示。" | ||||
| lockdown: "鎖定" | ||||
| pleaseSelectAccount: "請選擇帳戶" | ||||
| availableRoles: "可用角色" | ||||
| acknowledgeNotesAndEnable: "了解注意事項後再開啟。" | ||||
| federationSpecified: "此伺服器以白名單聯邦的方式運作。除了管理員指定的伺服器外,它無法與其他伺服器互動。" | ||||
| federationDisabled: "此伺服器未開啟站台聯邦。無法與其他伺服器上的使用者互動。" | ||||
| _accountSettings: | ||||
|   requireSigninToViewContents: "須登入以顯示內容" | ||||
|   requireSigninToViewContentsDescription1: "必須登入才會顯示您建立的貼文等內容。可望有效防止資訊被爬蟲蒐集。" | ||||
|   requireSigninToViewContentsDescription2: "來自不支援 URL 預覽 (OGP)、 網頁嵌入和引用貼文的伺服器,也將停止顯示。" | ||||
|   requireSigninToViewContentsDescription3: "這些限制可能不適用於被聯邦發送至遠端伺服器的內容。" | ||||
|   makeNotesFollowersOnlyBefore: "讓過去的貼文僅對追隨者顯示" | ||||
|   makeNotesFollowersOnlyBeforeDescription: "啟用此功能後,超過設定的日期和時間或超過設定時間的貼文將僅對追隨者顯示。 如果您再次停用它,貼文的公開狀態也會恢復原狀。" | ||||
|   makeNotesHiddenBefore: "隱藏過去的貼文" | ||||
|   makeNotesHiddenBeforeDescription: "啟用此功能後,超過設定的日期和時間或超過設定時間的貼文將僅對自己顯示(私密化)。 如果您再次停用它,貼文的公開狀態也會恢復原狀。" | ||||
|   mayNotEffectForFederatedNotes: "聯邦發送至遠端伺服器的貼文可能會不受影響。" | ||||
|   notesHavePassedSpecifiedPeriod: "早於指定時間的貼文" | ||||
|   notesOlderThanSpecifiedDateAndTime: "指定時間和日期之前的貼文" | ||||
| _abuseUserReport: | ||||
|   forward: "轉發" | ||||
|   forwardDescription: "以匿名系統帳戶將檢舉轉發至遠端伺服器。" | ||||
|   resolve: "解決" | ||||
|   accept: "接受" | ||||
|   reject: "拒絕" | ||||
|   resolveTutorial: "如果您已回覆正當的檢舉,請選擇「接受」以將案件標記為已解決。\n 如果檢舉的內容不正當,請選擇「拒絕」將案件標記為已解決。" | ||||
| _delivery: | ||||
|   status: "傳送狀態" | ||||
|   stop: "停止發送" | ||||
| @@ -1329,7 +1374,7 @@ _initialAccountSetting: | ||||
|   theseSettingsCanEditLater: "這裡的設定可以在之後變更。" | ||||
|   youCanEditMoreSettingsInSettingsPageLater: "除此之外,還可以在「設定」頁面進行各種設定。之後請確認看看。" | ||||
|   followUsers: "為了構築時間軸,試著追隨您感興趣的使用者吧。" | ||||
|   pushNotificationDescription: "啟用推送通知,就可以在設備上接收{name}的通知。" | ||||
|   pushNotificationDescription: "啟用推送通知後,就可以在裝置上接收來自{name}的通知了。" | ||||
|   initialAccountSettingCompleted: "初始設定完成了!" | ||||
|   haveFun: "盡情享受{name}吧!" | ||||
|   youCanContinueTutorial: "您可以繼續學習如何使用{name}(Misskey),也可以就此打住,立即開始使用。" | ||||
| @@ -1349,12 +1394,12 @@ _initialTutorial: | ||||
|     description: "在Misskey上發布的內容稱為「貼文」。貼文在時間軸上按時間順序排列,並即時更新。" | ||||
|     reply: "您可以回覆貼文,並像討論串一樣繼續對話。" | ||||
|     renote: "您可以將此貼文分享到自己的時間軸。您也可以在引用時添加文字。" | ||||
|     reaction: "您可以添加反應。詳細資訊將在下一頁進行說明。" | ||||
|     reaction: "您可以加入反應。詳細資訊將在下一頁進行說明。" | ||||
|     menu: "可執行各種操作,如查看貼文詳細資訊和複製連結。" | ||||
|   _reaction: | ||||
|     title: "什麼是反應?" | ||||
|     description: "您可以在貼文中添加「反應」。您可以使用反應輕鬆隨意地表達「最愛/大心」所無法傳達的細微差別。" | ||||
|     letsTryReacting: "可以透過點擊貼文上的「+」按鈕來添加反應。請嘗試在此範例貼文添加反應!" | ||||
|     description: "您可以在貼文中加上「反應」。有些用「最愛/大心」無法傳達的感想,可以用反應輕鬆地表達出來。" | ||||
|     letsTryReacting: "按一下貼文上的「+」按鈕即可加入反應。試著對此範例貼文加上反應!" | ||||
|     reactToContinue: "添加反應以繼續教學課程。" | ||||
|     reactNotification: "當有人對您的貼文做出反應時會即時接收到通知。" | ||||
|     reactDone: "按下「-」按鈕可以取消反應。" | ||||
| @@ -1420,6 +1465,9 @@ _serverSettings: | ||||
|   reactionsBufferingDescription: "啟用時,可以顯著提高建立反應時的效能並減少資料庫的負載。 但是,Redis 記憶體使用量會增加。" | ||||
|   inquiryUrl: "聯絡表單網址" | ||||
|   inquiryUrlDescription: "指定伺服器運營者的聯絡表單網址,或包含運營者聯絡資訊網頁的網址。" | ||||
|   openRegistration: "允許建立帳戶" | ||||
|   openRegistrationWarning: "開放註冊伴隨著風險。 建議只有在伺服器受到持續監控,並準備好在出現問題時能立即處理的情況下才開放註冊。" | ||||
|   thisSettingWillAutomaticallyOffWhenModeratorsInactive: "為了防止 spam,如果一段期間內沒有偵測到審查員的活動,此設定將自動關閉。" | ||||
| _accountMigration: | ||||
|   moveFrom: "從其他帳戶遷移到這個帳戶" | ||||
|   moveFromSub: "為另一個帳戶建立別名" | ||||
| @@ -1433,7 +1481,7 @@ _accountMigration: | ||||
|   startMigration: "遷移" | ||||
|   migrationConfirm: "確定要將這個帳戶遷移至 {account} 嗎?一旦遷移就無法撤銷,也就無法以原來的狀態使用這個帳戶。\n另外,請確認在要遷移到的帳戶已經建立了一個別名。" | ||||
|   movedAndCannotBeUndone: "帳戶已遷移。\n遷移無法撤消。" | ||||
|   postMigrationNote: "在完成遷移的 24 小時後解除此帳戶的追隨。此帳戶的追隨中、追隨者數量變為 0。由於不會解除追隨者,你的追隨者仍然可以繼續檢視這個帳戶發布給追隨者的貼文。" | ||||
|   postMigrationNote: "將在完成遷移後的 24 小時取消追隨所有帳號。\n此帳戶的追隨中/追隨者人數將歸零。由於不會解除粉絲對您的追隨,因此他們仍然可以繼續閱覽此帳戶僅對追隨者公開的貼文。" | ||||
|   movedTo: "要遷移到的帳戶:" | ||||
| _achievements: | ||||
|   earnedAt: "獲得日期" | ||||
| @@ -1553,7 +1601,7 @@ _achievements: | ||||
|     _markedAsCat: | ||||
|       title: "我是貓" | ||||
|       description: "已將帳戶設定為貓" | ||||
|       flavor: "還沒有名字。" | ||||
|       flavor: "沒有名字。" | ||||
|     _following1: | ||||
|       title: "首次追隨" | ||||
|       description: "首次追隨了" | ||||
| @@ -1567,7 +1615,7 @@ _achievements: | ||||
|       title: "一百位朋友" | ||||
|       description: "追隨超過100人了" | ||||
|     _following300: | ||||
|       title: "朋友過多" | ||||
|       title: "朋友太多" | ||||
|       description: "追隨超過300人了" | ||||
|     _followers1: | ||||
|       title: "第一個追隨者" | ||||
| @@ -1753,7 +1801,7 @@ _role: | ||||
|     avatarDecorationLimit: "頭像裝飾的最大設置量" | ||||
|     canImportAntennas: "允許匯入天線" | ||||
|     canImportBlocking: "允許匯入封鎖名單" | ||||
|     canImportFollowing: "允許匯入跟隨名單" | ||||
|     canImportFollowing: "允許匯入追隨名單" | ||||
|     canImportMuting: "允許匯入靜音名單" | ||||
|     canImportUserLists: "允許匯入清單" | ||||
|   _condition: | ||||
| @@ -1893,7 +1941,7 @@ _channel: | ||||
|   following: "追隨中" | ||||
|   usersCount: "有 {n} 人參與" | ||||
|   notesCount: "有 {n} 篇貼文" | ||||
|   nameAndDescription: "名稱與說明" | ||||
|   nameAndDescription: "名稱" | ||||
|   nameOnly: "僅名稱" | ||||
|   allowRenoteToExternal: "允許在頻道外轉發和引用" | ||||
| _menuDisplay: | ||||
| @@ -1973,7 +2021,6 @@ _theme: | ||||
|     buttonBg: "按鈕背景" | ||||
|     buttonHoverBg: "按鈕背景 (漂浮)" | ||||
|     inputBorder: "輸入框邊框" | ||||
|     listItemHoverBg: "列表物品背景 (漂浮)" | ||||
|     driveFolderBg: "雲端硬碟文件夾背景" | ||||
|     wallpaperOverlay: "壁紙覆蓋層" | ||||
|     badge: "徽章" | ||||
| @@ -2030,7 +2077,7 @@ _2fa: | ||||
|   step4: "從現在開始,任何登入操作都將要求您提供權杖。" | ||||
|   securityKeyNotSupported: "您的瀏覽器不支援安全金鑰。" | ||||
|   registerTOTPBeforeKey: "如要註冊安全金鑰或 Passkey,請先設定驗證應用程式。" | ||||
|   securityKeyInfo: "您可以設定使用支援 FIDO2 的硬體安全鎖、終端設備的指紋認證,或者 PIN 碼來登入。" | ||||
|   securityKeyInfo: "您可以設定使用支援 FIDO2 的硬體安全金鑰,以及裝置上的生物辨識、PIN 碼和密碼等來登入。" | ||||
|   registerSecurityKey: "註冊安全金鑰或 Passkey" | ||||
|   securityKeyName: "輸入金鑰名稱" | ||||
|   tapSecurityKey: "按照瀏覽器的說明註冊安全金鑰或 Passkey。" | ||||
| @@ -2140,8 +2187,11 @@ _auth: | ||||
|   permissionAsk: "此應用程式需要以下權限" | ||||
|   pleaseGoBack: "請返回至應用程式" | ||||
|   callback: "回到應用程式" | ||||
|   accepted: "已授予存取權限" | ||||
|   denied: "拒絕訪問" | ||||
|   scopeUser: "以下列使用者身分操作" | ||||
|   pleaseLogin: "必須登入以提供應用程式的存取權限。" | ||||
|   byClickingYouWillBeRedirectedToThisUrl: "如果授予存取權限,就會自動導向到以下的網址" | ||||
| _antennaSources: | ||||
|   all: "全部貼文" | ||||
|   homeTimeline: "來自已追隨使用者的貼文" | ||||
| @@ -2245,7 +2295,7 @@ _profile: | ||||
|   metadataEdit: "編輯附加資訊" | ||||
|   metadataDescription: "可以在個人資料中以表格形式顯示其他資訊。" | ||||
|   metadataLabel: "標籤" | ||||
|   metadataContent: "内容" | ||||
|   metadataContent: "內容" | ||||
|   changeAvatar: "更換大頭貼" | ||||
|   changeBanner: "變更橫幅圖像" | ||||
|   verifiedLinkDescription: "如果輸入包含您個人資料的網站 URL,欄位旁邊將出現驗證圖示。" | ||||
| @@ -2392,13 +2442,14 @@ _notification: | ||||
|   followedBySomeUsers: "被{n}人追隨了" | ||||
|   flushNotification: "重置通知歷史紀錄" | ||||
|   exportOfXCompleted: "{x} 的匯出已完成。" | ||||
|   login: "已登入" | ||||
|   _types: | ||||
|     all: "全部 " | ||||
|     note: "使用者的最新貼文" | ||||
|     follow: "追隨中" | ||||
|     mention: "提及" | ||||
|     reply: "回覆" | ||||
|     renote: "轉發貼文" | ||||
|     renote: "轉發" | ||||
|     quote: "引用" | ||||
|     reaction: "反應" | ||||
|     pollEnded: "問卷調查結束" | ||||
| @@ -2407,6 +2458,7 @@ _notification: | ||||
|     roleAssigned: "已授予角色" | ||||
|     achievementEarned: "獲得成就" | ||||
|     exportCompleted: "已完成匯出。" | ||||
|     login: "登入" | ||||
|     test: "通知測試" | ||||
|     app: "應用程式通知" | ||||
|   _actions: | ||||
| @@ -2473,6 +2525,8 @@ _webhookSettings: | ||||
|     abuseReport: "當使用者檢舉時" | ||||
|     abuseReportResolved: "當處理了使用者的檢舉時" | ||||
|     userCreated: "使用者被新增時" | ||||
|     inactiveModeratorsWarning: "當審查員在一段時間內沒有活動時" | ||||
|     inactiveModeratorsInvitationOnlyChanged: "當審查員在一段時間內不活動時,系統會將模式變更為邀請制" | ||||
|   deleteConfirm: "請問是否要刪除 Webhook?" | ||||
|   testRemarks: "按下切換開關右側的按鈕,就會將假資料發送至 Webhook。" | ||||
| _abuseReport: | ||||
| @@ -2487,7 +2541,7 @@ _abuseReport: | ||||
|         mail: "寄送到擁有監察員權限的使用者電子郵件地址(僅在收到檢舉時)" | ||||
|         webhook: "向指定的 SystemWebhook 發送通知(在收到檢舉和解決檢舉時發送)" | ||||
|     keywords: "關鍵字" | ||||
|     notifiedUser: "被通知的使用者" | ||||
|     notifiedUser: "通知的使用者" | ||||
|     notifiedWebhook: "使用的 Webhook" | ||||
|     deleteConfirm: "確定要刪除通知對象嗎?" | ||||
| _moderationLogTypes: | ||||
| @@ -2518,6 +2572,8 @@ _moderationLogTypes: | ||||
|   markSensitiveDriveFile: "標記為敏感檔案" | ||||
|   unmarkSensitiveDriveFile: "撤銷標記為敏感檔案" | ||||
|   resolveAbuseReport: "解決檢舉" | ||||
|   forwardAbuseReport: "轉發檢舉" | ||||
|   updateAbuseReportNote: "更新檢舉的審查備註" | ||||
|   createInvitation: "建立邀請碼" | ||||
|   createAd: "建立廣告" | ||||
|   deleteAd: "刪除廣告" | ||||
| @@ -2579,7 +2635,7 @@ _externalResourceInstaller: | ||||
|       description: "已取得資料但解析 AiScript 時發生錯誤,導致無法載入。請聯絡外掛作者。請檢查 Javascript 控制台以取得錯誤詳細資訊。" | ||||
|     _pluginInstallFailed: | ||||
|       title: "外掛安裝失敗" | ||||
|       description: "安裝插件時出現問題。請再試一次。請參閱 Javascript 控制台以取得錯誤詳細資訊。" | ||||
|       description: "安裝外掛時出現問題。請再試一次。可參閱 Javascript 控制台以取得錯誤詳細資訊。" | ||||
|     _themeParseFailed: | ||||
|       title: "佈景主題解析錯誤" | ||||
|       description: "已取得資料但解析佈景主題時發生錯誤,導致無法載入。請聯絡佈景主題的作者。請檢查 Javascript 控制台以取得錯誤詳細資訊。" | ||||
| @@ -2598,7 +2654,7 @@ _dataSaver: | ||||
|     description: "將不再自動載入網址預覽縮圖。" | ||||
|   _code: | ||||
|     title: "程式碼突出顯示" | ||||
|     description: "如果使用了 MFM 的程式碼突顯標記,則在點擊之前不會載入。程式碼突顯要求加載每種程式語言的突顯定義檔案,但由於這些檔案不再自動載入,因此有望減少資料流量。" | ||||
|     description: "如果使用了程式碼突顯語法(如 MFM),則在點擊之前不會被載入。由於需要為對應的程式語言下載突顯定義檔案,因此關閉自動載入有助於減少資料流量。" | ||||
| _hemisphere: | ||||
|   N: "北半球" | ||||
|   S: "南半球" | ||||
| @@ -2673,6 +2729,66 @@ _contextMenu: | ||||
|   app: "應用程式" | ||||
|   appWithShift: "Shift 鍵應用程式" | ||||
|   native: "瀏覽器的使用者介面" | ||||
| _gridComponent: | ||||
|   _error: | ||||
|     requiredValue: "此值為必填欄位" | ||||
|     columnTypeNotSupport: "正規表達式驗證僅支援 type:text 的欄位。" | ||||
|     patternNotMatch: "此值不符合 {pattern} 中的樣式。" | ||||
|     notUnique: "此值必須是唯一的" | ||||
| _roleSelectDialog: | ||||
|   notSelected: "未選擇" | ||||
| _customEmojisManager: | ||||
|   _gridCommon: | ||||
|     copySelectionRows: "複製選取的行" | ||||
|     copySelectionRanges: "複製選取的範圍" | ||||
|     deleteSelectionRows: "刪除所選的行" | ||||
|     deleteSelectionRanges: "刪除選取範圍的行" | ||||
|     searchSettings: "搜尋設定" | ||||
|     searchSettingCaption: "詳細設定搜尋條件。" | ||||
|     searchLimit: "顯示的數量" | ||||
|     sortOrder: "排序" | ||||
|     registrationLogs: "登錄日誌" | ||||
|     registrationLogsCaption: "會顯示更新或刪除表情符號時的日誌。進行更新或刪除操作,或切換頁面、重新載入後,日誌將會消失。" | ||||
|     alertEmojisRegisterFailedDescription: "更新或刪除表情符號失敗。詳情請查看登錄日誌。" | ||||
|   _logs: | ||||
|     showSuccessLogSwitch: "顯示成功日誌" | ||||
|     failureLogNothing: "沒有失敗的日誌。" | ||||
|     logNothing: "沒有日誌。" | ||||
|   _remote: | ||||
|     selectionRowDetail: "選取行的詳細資訊" | ||||
|     importSelectionRows: "匯入選取的行" | ||||
|     importSelectionRangesRows: "匯入選取範圍的行" | ||||
|     importEmojisButton: "匯入勾選的表情符號" | ||||
|     confirmImportEmojisTitle: "匯入表情符號" | ||||
|     confirmImportEmojisDescription: "將從遠端接收的{count}個表情符號進行匯入。請務必注意表情符號的授權。是否執行此操作?" | ||||
|   _local: | ||||
|     tabTitleList: "已登錄的表情符號列表" | ||||
|     tabTitleRegister: "登錄表情符號" | ||||
|     _list: | ||||
|       emojisNothing: "沒有登錄的表情符號。" | ||||
|       markAsDeleteTargetRows: "將選取的行設為刪除對象" | ||||
|       markAsDeleteTargetRanges: "將選取範圍的行設為刪除對象\n" | ||||
|       alertUpdateEmojisNothingDescription: "沒有選取需要變更的表情符號。" | ||||
|       alertDeleteEmojisNothingDescription: "沒有選取需要刪除的表情符號。" | ||||
|       confirmMovePage: "要移動到其他頁面嗎?" | ||||
|       confirmChangeView: "要更改顯示方式嗎?" | ||||
|       confirmUpdateEmojisDescription: "將更新{count}個表情符號。是否執行此操作?" | ||||
|       confirmDeleteEmojisDescription: "將刪除勾選的{count}個表情符號。是否執行此操作?" | ||||
|       confirmResetDescription: "目前所做的所有變更都會重設。" | ||||
|       confirmMovePageDesciption: "此頁面的表情符號已被更改。  \n若未儲存就直接離開此頁面,則在此頁面進行的所有更改將會被捨棄。" | ||||
|       dialogSelectRoleTitle: "根據表情符號設定的角色進行搜尋" | ||||
|     _register: | ||||
|       uploadSettingTitle: "上傳設定" | ||||
|       uploadSettingDescription: "您可以在此畫面設定表情符號上傳時的操作。" | ||||
|       directoryToCategoryLabel: "在「類別」欄位中輸入目錄名稱" | ||||
|       directoryToCategoryCaption: "拖放目錄時,請在「類別」欄位中輸入目錄名稱。" | ||||
|       emojiInputAreaCaption: "以下列其中一種方式選擇您想要註冊的表情符號" | ||||
|       emojiInputAreaList1: "將圖片檔案或目錄拖放到此框中" | ||||
|       emojiInputAreaList2: "點擊此連結從電腦中選擇" | ||||
|       emojiInputAreaList3: "點擊此連結從雲端硬碟中選擇" | ||||
|       confirmRegisterEmojisDescription: "將列表中顯示的表情符號登錄為新的自定表情符號。是否確定?(為避免過高負荷,每次操作最多可登錄{count}個表情符號)" | ||||
|       confirmClearEmojisDescription: "放棄編輯內容並清除列表中顯示的表情符號。是否確定?" | ||||
|       confirmUploadEmojisDescription: "將拖放的{count}個檔案上傳到雲端硬碟。是否執行此操作?" | ||||
| _embedCodeGen: | ||||
|   title: "自訂嵌入程式碼" | ||||
|   header: "檢視標頭 " | ||||
| @@ -2687,3 +2803,43 @@ _embedCodeGen: | ||||
|   generateCode: "建立嵌入程式碼" | ||||
|   codeGenerated: "已產生程式碼" | ||||
|   codeGeneratedDescription: "請將產生的程式碼貼到您的網站上。" | ||||
| _selfXssPrevention: | ||||
|   warning: "警告" | ||||
|   title: "「在此畫面貼上一些內容」完全是個騙局。" | ||||
|   description1: "如果您在此處貼上任何內容,惡意使用者可能會接管您的帳戶或竊取您的個人資訊。" | ||||
|   description2: "如果您不確切知道要貼上的內容,%c 請立即停止工作並關閉此視窗。" | ||||
|   description3: "細節請看這裡。{link}" | ||||
| _followRequest: | ||||
|   recieved: "收到的請求" | ||||
|   sent: "送出的請求" | ||||
| _remoteLookupErrors: | ||||
|   _federationNotAllowed: | ||||
|     title: "無法與這個伺服器通訊" | ||||
|     description: "與此伺服器的通訊可能被停用、或封鎖了該伺服器,或被該伺服器封鎖。\n請聯繫您的伺服器管理員。" | ||||
|   _uriInvalid: | ||||
|     title: "URI 不正確" | ||||
|     description: "輸入的 URI 有問題。請檢查是否輸入了 URI 中不能使用的字元。" | ||||
|   _requestFailed: | ||||
|     title: "請求失敗" | ||||
|     description: "與此伺服器的通訊失敗。可能是對方伺服器斷線。 此外,請檢查是否輸入了不正確或不存在的 URI。" | ||||
|   _responseInvalid: | ||||
|     title: "回應不正確" | ||||
|     description: "雖然能夠與這個伺服器通訊,但是取得的資料不正確。" | ||||
|   _responseInvalidIdHostNotMatch: | ||||
|     description: "輸入的 URI 的網域與最終取得的 URI 的網域不同。 如果您是透過第三方伺服器查詢遠端內容,請使用可在原始伺服器上取得的 URI 再次查詢。" | ||||
|   _noSuchObject: | ||||
|     title: "查無項目" | ||||
|     description: "無法找到所要求的資源,請再次檢查 URI。" | ||||
| _captcha: | ||||
|   verify: "請通過 CAPTCHA 驗證" | ||||
|   testSiteKeyMessage: "可以輸入網站金鑰和秘密金鑰的測試值來檢查預覽。\n詳細資訊請參閱以下頁面。" | ||||
|   _error: | ||||
|     _requestFailed: | ||||
|       title: "CAPTCHA 請求失敗" | ||||
|       text: "請過一段時間後再執行,或再次檢查設定。" | ||||
|     _verificationFailed: | ||||
|       title: "CAPTCHA 驗證失敗" | ||||
|       text: "請再次檢查設定是否正確。" | ||||
|     _unknown: | ||||
|       title: "CAPTCHA 錯誤" | ||||
|       text: "發生了意外的錯誤。" | ||||
|   | ||||
							
								
								
									
										18
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| { | ||||
| 	"name": "misskey", | ||||
| 	"version": "2024.9.0-beta.14", | ||||
| 	"version": "2025.2.0-alpha.0", | ||||
| 	"codename": "nasubi", | ||||
| 	"repository": { | ||||
| 		"type": "git", | ||||
| @@ -56,22 +56,22 @@ | ||||
| 		"fast-glob": "3.3.2", | ||||
| 		"ignore-walk": "6.0.5", | ||||
| 		"js-yaml": "4.1.0", | ||||
| 		"postcss": "8.4.47", | ||||
| 		"postcss": "8.4.49", | ||||
| 		"tar": "6.2.1", | ||||
| 		"terser": "5.33.0", | ||||
| 		"typescript": "5.6.2", | ||||
| 		"esbuild": "0.23.1", | ||||
| 		"terser": "5.36.0", | ||||
| 		"typescript": "5.6.3", | ||||
| 		"esbuild": "0.24.0", | ||||
| 		"glob": "11.0.0" | ||||
| 	}, | ||||
| 	"devDependencies": { | ||||
| 		"@misskey-dev/eslint-plugin": "2.0.3", | ||||
| 		"@types/node": "20.14.12", | ||||
| 		"@types/node": "22.9.0", | ||||
| 		"@typescript-eslint/eslint-plugin": "7.17.0", | ||||
| 		"@typescript-eslint/parser": "7.17.0", | ||||
| 		"cross-env": "7.0.3", | ||||
| 		"cypress": "13.14.2", | ||||
| 		"eslint": "9.8.0", | ||||
| 		"globals": "15.9.0", | ||||
| 		"cypress": "13.15.2", | ||||
| 		"eslint": "9.14.0", | ||||
| 		"globals": "15.12.0", | ||||
| 		"ncp": "2.0.0", | ||||
| 		"start-server-and-test": "2.0.8" | ||||
| 	}, | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								packages/backend/assets/tabler-badges/login-2.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								packages/backend/assets/tabler-badges/login-2.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 3.7 KiB | 
| @@ -11,7 +11,7 @@ export default [ | ||||
| 		languageOptions: { | ||||
| 			parserOptions: { | ||||
| 				parser: tsParser, | ||||
| 				project: ['./tsconfig.json', './test/tsconfig.json'], | ||||
| 				project: ['./tsconfig.json', './test/tsconfig.json', './test-federation/tsconfig.json'], | ||||
| 				sourceType: 'module', | ||||
| 				tsconfigRootDir: import.meta.dirname, | ||||
| 			}, | ||||
|   | ||||
							
								
								
									
										13
									
								
								packages/backend/jest.config.fed.cjs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								packages/backend/jest.config.fed.cjs
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| /* | ||||
|  * For a detailed explanation regarding each configuration property and type check, visit: | ||||
|  * https://jestjs.io/docs/en/configuration.html | ||||
|  */ | ||||
|  | ||||
| const base = require('./jest.config.cjs'); | ||||
|  | ||||
| module.exports = { | ||||
| 	...base, | ||||
| 	testMatch: [ | ||||
| 		'<rootDir>/test-federation/test/**/*.test.ts', | ||||
| 	], | ||||
| }; | ||||
| @@ -0,0 +1,18 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class OptimizeEmojiIndex1709126576000 { | ||||
| 	name = 'OptimizeEmojiIndex1709126576000' | ||||
|  | ||||
| 	async up(queryRunner) { | ||||
| 		await queryRunner.query(`CREATE INDEX "IDX_EMOJI_ROLE_IDS" ON "emoji" using gin ("roleIdsThatCanBeUsedThisEmojiAsReaction")`) | ||||
| 		await queryRunner.query(`CREATE INDEX "IDX_EMOJI_CATEGORY" ON "emoji" ("category")`) | ||||
| 	} | ||||
|  | ||||
| 	async down(queryRunner) { | ||||
| 		await queryRunner.query(`DROP INDEX "IDX_EMOJI_CATEGORY"`) | ||||
| 		await queryRunner.query(`DROP INDEX "IDX_EMOJI_ROLE_IDS"`) | ||||
| 	} | ||||
| } | ||||
| @@ -0,0 +1,16 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class EnableStatsForFederatedInstances1727318020265 { | ||||
|     name = 'EnableStatsForFederatedInstances1727318020265' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" ADD "enableStatsForFederatedInstances" boolean NOT NULL DEFAULT true`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "enableStatsForFederatedInstances"`); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,18 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class RefineAbuseUserReport1728085812127 { | ||||
|     name = 'RefineAbuseUserReport1728085812127' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "moderationNote" character varying(8192) NOT NULL DEFAULT ''`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "resolvedAs" character varying(128)`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "resolvedAs"`); | ||||
|         await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "moderationNote"`); | ||||
|     } | ||||
| } | ||||
							
								
								
									
										16
									
								
								packages/backend/migration/1728550878802-testcaptcha.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										16
									
								
								packages/backend/migration/1728550878802-testcaptcha.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,16 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class Testcaptcha1728550878802 { | ||||
|     name = 'Testcaptcha1728550878802' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
| 			await queryRunner.query(`ALTER TABLE "meta" ADD "enableTestcaptcha" boolean NOT NULL DEFAULT false`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
| 			await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "enableTestcaptcha"`); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,14 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class ProhibitedWordsForNameOfUser1728634286056 { | ||||
| 		async up(queryRunner) { | ||||
| 			await queryRunner.query(`ALTER TABLE "meta" ADD "prohibitedWordsForNameOfUser" character varying(1024) array NOT NULL DEFAULT '{}'`); | ||||
| 		} | ||||
|  | ||||
| 		async down(queryRunner) { | ||||
| 			await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "prohibitedWordsForNameOfUser"`); | ||||
| 		} | ||||
| } | ||||
| @@ -0,0 +1,16 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class SigninRequiredForShowContents1729333924409 { | ||||
|     name = 'SigninRequiredForShowContents1729333924409' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "requireSigninToViewContents" boolean NOT NULL DEFAULT false`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "requireSigninToViewContents"`); | ||||
|     } | ||||
| } | ||||
| @@ -0,0 +1,18 @@ | ||||
| /* | ||||
|  * SPDX-FileCopyrightText: syuilo and misskey-project | ||||
|  * SPDX-License-Identifier: AGPL-3.0-only | ||||
|  */ | ||||
|  | ||||
| export class MakeNotesHiddenBefore1729486255072 { | ||||
|     name = 'MakeNotesHiddenBefore1729486255072' | ||||
|  | ||||
|     async up(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "makeNotesFollowersOnlyBefore" integer`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" ADD "makeNotesHiddenBefore" integer`); | ||||
|     } | ||||
|  | ||||
|     async down(queryRunner) { | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "makeNotesHiddenBefore"`); | ||||
|         await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "makeNotesFollowersOnlyBefore"`); | ||||
|     } | ||||
| } | ||||
| @@ -19,16 +19,18 @@ | ||||
| 		"watch": "node ./scripts/watch.mjs", | ||||
| 		"restart": "pnpm build && pnpm start", | ||||
| 		"dev": "node ./scripts/dev.mjs", | ||||
| 		"typecheck": "tsc --noEmit && tsc -p test --noEmit", | ||||
| 		"eslint": "eslint --quiet \"src/**/*.ts\"", | ||||
| 		"typecheck": "tsc --noEmit && tsc -p test --noEmit && tsc -p test-federation --noEmit", | ||||
| 		"eslint": "eslint --quiet \"{src,test-federation}/**/*.ts\"", | ||||
| 		"lint": "pnpm typecheck && pnpm eslint", | ||||
| 		"jest": "cross-env NODE_ENV=test node --experimental-vm-modules --experimental-import-meta-resolve node_modules/jest/bin/jest.js --forceExit --config jest.config.unit.cjs", | ||||
| 		"jest:e2e": "cross-env NODE_ENV=test node --experimental-vm-modules --experimental-import-meta-resolve node_modules/jest/bin/jest.js --forceExit --config jest.config.e2e.cjs", | ||||
| 		"jest:fed": "node --experimental-vm-modules --experimental-import-meta-resolve node_modules/jest/bin/jest.js --forceExit --config jest.config.fed.cjs", | ||||
| 		"jest-and-coverage": "cross-env NODE_ENV=test node --experimental-vm-modules --experimental-import-meta-resolve node_modules/jest/bin/jest.js --coverage --forceExit --config jest.config.unit.cjs", | ||||
| 		"jest-and-coverage:e2e": "cross-env NODE_ENV=test node --experimental-vm-modules --experimental-import-meta-resolve node_modules/jest/bin/jest.js --coverage --forceExit --config jest.config.e2e.cjs", | ||||
| 		"jest-clear": "cross-env NODE_ENV=test node --experimental-vm-modules --experimental-import-meta-resolve node_modules/jest/bin/jest.js --clearCache", | ||||
| 		"test": "pnpm jest", | ||||
| 		"test:e2e": "pnpm build && pnpm build:test && pnpm jest:e2e", | ||||
| 		"test:fed": "pnpm jest:fed", | ||||
| 		"test-and-coverage": "pnpm jest-and-coverage", | ||||
| 		"test-and-coverage:e2e": "pnpm build && pnpm build:test && pnpm jest-and-coverage:e2e", | ||||
| 		"generate-api-json": "node ./scripts/generate_api_json.js" | ||||
| @@ -67,32 +69,32 @@ | ||||
| 	"dependencies": { | ||||
| 		"@aws-sdk/client-s3": "3.620.0", | ||||
| 		"@aws-sdk/lib-storage": "3.620.0", | ||||
| 		"@bull-board/api": "6.0.0", | ||||
| 		"@bull-board/fastify": "6.0.0", | ||||
| 		"@bull-board/ui": "6.0.0", | ||||
| 		"@bull-board/api": "6.5.0", | ||||
| 		"@bull-board/fastify": "6.5.0", | ||||
| 		"@bull-board/ui": "6.5.0", | ||||
| 		"@discordapp/twemoji": "15.1.0", | ||||
| 		"@fastify/accepts": "5.0.0", | ||||
| 		"@fastify/cookie": "10.0.0", | ||||
| 		"@fastify/cors": "10.0.0", | ||||
| 		"@fastify/express": "4.0.0", | ||||
| 		"@fastify/http-proxy": "10.0.0", | ||||
| 		"@fastify/multipart": "9.0.0", | ||||
| 		"@fastify/static": "8.0.0", | ||||
| 		"@fastify/view": "10.0.0", | ||||
| 		"@fastify/accepts": "5.0.1", | ||||
| 		"@fastify/cookie": "11.0.1", | ||||
| 		"@fastify/cors": "10.0.1", | ||||
| 		"@fastify/express": "4.0.1", | ||||
| 		"@fastify/http-proxy": "10.0.1", | ||||
| 		"@fastify/multipart": "9.0.1", | ||||
| 		"@fastify/static": "8.0.2", | ||||
| 		"@fastify/view": "10.0.1", | ||||
| 		"@misskey-dev/sharp-read-bmp": "1.2.0", | ||||
| 		"@misskey-dev/summaly": "5.1.0", | ||||
| 		"@napi-rs/canvas": "0.1.56", | ||||
| 		"@nestjs/common": "10.4.3", | ||||
| 		"@nestjs/core": "10.4.3", | ||||
| 		"@nestjs/testing": "10.4.3", | ||||
| 		"@nestjs/common": "10.4.7", | ||||
| 		"@nestjs/core": "10.4.7", | ||||
| 		"@nestjs/testing": "10.4.7", | ||||
| 		"@peertube/http-signature": "1.7.0", | ||||
| 		"@sentry/node": "8.20.0", | ||||
| 		"@sentry/profiling-node": "8.20.0", | ||||
| 		"@sentry/node": "8.38.0", | ||||
| 		"@sentry/profiling-node": "8.38.0", | ||||
| 		"@simplewebauthn/server": "10.0.1", | ||||
| 		"@sinonjs/fake-timers": "11.2.2", | ||||
| 		"@smithy/node-http-handler": "2.5.0", | ||||
| 		"@swc/cli": "0.3.12", | ||||
| 		"@swc/core": "1.6.6", | ||||
| 		"@swc/core": "1.9.2", | ||||
| 		"@twemoji/parser": "15.1.1", | ||||
| 		"accepts": "1.3.8", | ||||
| 		"ajv": "8.17.1", | ||||
| @@ -101,7 +103,7 @@ | ||||
| 		"bcryptjs": "2.4.3", | ||||
| 		"blurhash": "2.0.5", | ||||
| 		"body-parser": "1.20.3", | ||||
| 		"bullmq": "5.13.2", | ||||
| 		"bullmq": "5.26.1", | ||||
| 		"cacheable-lookup": "7.0.0", | ||||
| 		"cbor": "9.0.2", | ||||
| 		"chalk": "5.3.0", | ||||
| @@ -115,11 +117,11 @@ | ||||
| 		"fastify": "5.0.0", | ||||
| 		"fastify-raw-body": "5.0.0", | ||||
| 		"feed": "4.2.2", | ||||
| 		"file-type": "19.5.0", | ||||
| 		"file-type": "19.6.0", | ||||
| 		"fluent-ffmpeg": "2.1.3", | ||||
| 		"form-data": "4.0.0", | ||||
| 		"got": "14.4.2", | ||||
| 		"happy-dom": "15.7.4", | ||||
| 		"form-data": "4.0.1", | ||||
| 		"got": "14.4.4", | ||||
| 		"happy-dom": "15.11.4", | ||||
| 		"hpagent": "1.2.0", | ||||
| 		"htmlescape": "1.1.1", | ||||
| 		"http-link-header": "1.1.3", | ||||
| @@ -132,31 +134,30 @@ | ||||
| 		"json5": "2.2.3", | ||||
| 		"jsonld": "8.3.2", | ||||
| 		"jsrsasign": "11.1.0", | ||||
| 		"meilisearch": "0.42.0", | ||||
| 		"juice": "11.0.0", | ||||
| 		"meilisearch": "0.45.0", | ||||
| 		"mfm-js": "0.24.0", | ||||
| 		"microformats-parser": "2.0.2", | ||||
| 		"mime-types": "2.1.35", | ||||
| 		"misskey-js": "workspace:*", | ||||
| 		"misskey-reversi": "workspace:*", | ||||
| 		"ms": "3.0.0-canary.1", | ||||
| 		"nanoid": "5.0.7", | ||||
| 		"nanoid": "5.0.8", | ||||
| 		"nested-property": "4.0.0", | ||||
| 		"node-fetch": "3.3.2", | ||||
| 		"nodemailer": "6.9.15", | ||||
| 		"nsfwjs": "2.4.2", | ||||
| 		"nodemailer": "6.9.16", | ||||
| 		"nsfwjs": "4.2.0", | ||||
| 		"oauth": "0.10.0", | ||||
| 		"oauth2orize": "1.12.0", | ||||
| 		"oauth2orize-pkce": "0.1.2", | ||||
| 		"os-utils": "0.0.14", | ||||
| 		"otpauth": "9.3.2", | ||||
| 		"parse5": "7.1.2", | ||||
| 		"pg": "8.13.0", | ||||
| 		"otpauth": "9.3.4", | ||||
| 		"parse5": "7.2.1", | ||||
| 		"pg": "8.13.1", | ||||
| 		"pkce-challenge": "4.1.0", | ||||
| 		"probe-image-size": "7.2.3", | ||||
| 		"promise-limit": "2.7.0", | ||||
| 		"pug": "3.0.3", | ||||
| 		"punycode": "2.3.1", | ||||
| 		"qrcode": "1.5.4", | ||||
| 		"random-seed": "0.3.0", | ||||
| 		"ratelimiter": "3.4.1", | ||||
| @@ -166,7 +167,7 @@ | ||||
| 		"rename": "1.0.4", | ||||
| 		"rss-parser": "3.13.0", | ||||
| 		"rxjs": "7.8.1", | ||||
| 		"sanitize-html": "2.13.0", | ||||
| 		"sanitize-html": "2.13.1", | ||||
| 		"secure-json-parse": "2.7.0", | ||||
| 		"sharp": "0.33.5", | ||||
| 		"slacc": "0.0.10", | ||||
| @@ -178,7 +179,7 @@ | ||||
| 		"tsc-alias": "1.8.10", | ||||
| 		"tsconfig-paths": "4.2.0", | ||||
| 		"typeorm": "0.3.20", | ||||
| 		"typescript": "5.6.2", | ||||
| 		"typescript": "5.6.3", | ||||
| 		"ulid": "2.3.0", | ||||
| 		"vary": "1.1.2", | ||||
| 		"web-push": "3.6.7", | ||||
| @@ -187,33 +188,32 @@ | ||||
| 	}, | ||||
| 	"devDependencies": { | ||||
| 		"@jest/globals": "29.7.0", | ||||
| 		"@nestjs/platform-express": "10.4.3", | ||||
| 		"@nestjs/platform-express": "10.4.7", | ||||
| 		"@simplewebauthn/types": "10.0.0", | ||||
| 		"@swc/jest": "0.2.36", | ||||
| 		"@swc/jest": "0.2.37", | ||||
| 		"@types/accepts": "1.3.7", | ||||
| 		"@types/archiver": "6.0.2", | ||||
| 		"@types/archiver": "6.0.3", | ||||
| 		"@types/bcryptjs": "2.4.6", | ||||
| 		"@types/body-parser": "1.19.5", | ||||
| 		"@types/color-convert": "2.0.3", | ||||
| 		"@types/color-convert": "2.0.4", | ||||
| 		"@types/content-disposition": "0.5.8", | ||||
| 		"@types/fluent-ffmpeg": "2.1.26", | ||||
| 		"@types/fluent-ffmpeg": "2.1.27", | ||||
| 		"@types/htmlescape": "1.1.3", | ||||
| 		"@types/http-link-header": "1.0.7", | ||||
| 		"@types/jest": "29.5.13", | ||||
| 		"@types/jest": "29.5.14", | ||||
| 		"@types/js-yaml": "4.0.9", | ||||
| 		"@types/jsdom": "21.1.7", | ||||
| 		"@types/jsonld": "1.5.15", | ||||
| 		"@types/jsrsasign": "10.5.14", | ||||
| 		"@types/mime-types": "2.1.4", | ||||
| 		"@types/ms": "0.7.34", | ||||
| 		"@types/node": "20.14.12", | ||||
| 		"@types/node": "22.9.0", | ||||
| 		"@types/nodemailer": "6.4.16", | ||||
| 		"@types/oauth": "0.9.5", | ||||
| 		"@types/oauth": "0.9.6", | ||||
| 		"@types/oauth2orize": "1.11.5", | ||||
| 		"@types/oauth2orize-pkce": "0.1.2", | ||||
| 		"@types/pg": "8.11.10", | ||||
| 		"@types/pug": "2.0.10", | ||||
| 		"@types/punycode": "2.1.4", | ||||
| 		"@types/qrcode": "1.5.5", | ||||
| 		"@types/random-seed": "0.3.5", | ||||
| 		"@types/ratelimiter": "3.4.6", | ||||
| @@ -225,14 +225,14 @@ | ||||
| 		"@types/tinycolor2": "1.4.6", | ||||
| 		"@types/tmp": "0.2.6", | ||||
| 		"@types/vary": "1.1.3", | ||||
| 		"@types/web-push": "3.6.3", | ||||
| 		"@types/ws": "8.5.12", | ||||
| 		"@types/web-push": "3.6.4", | ||||
| 		"@types/ws": "8.5.13", | ||||
| 		"@typescript-eslint/eslint-plugin": "7.17.0", | ||||
| 		"@typescript-eslint/parser": "7.17.0", | ||||
| 		"aws-sdk-client-mock": "4.0.1", | ||||
| 		"cross-env": "7.0.3", | ||||
| 		"eslint-plugin-import": "2.30.0", | ||||
| 		"execa": "9.4.0", | ||||
| 		"execa": "8.0.1", | ||||
| 		"fkill": "9.0.0", | ||||
| 		"jest": "29.7.0", | ||||
| 		"jest-mock": "29.7.0", | ||||
|   | ||||
| @@ -5,11 +5,52 @@ | ||||
|  | ||||
| import Redis from 'ioredis'; | ||||
| import { loadConfig } from '../built/config.js'; | ||||
| import { createPostgresDataSource } from '../built/postgres.js'; | ||||
|  | ||||
| const config = loadConfig(); | ||||
| const redis = new Redis(config.redis); | ||||
|  | ||||
| redis.on('connect', () => redis.disconnect()); | ||||
| redis.on('error', (e) => { | ||||
| 	throw e; | ||||
| }); | ||||
| async function connectToPostgres() { | ||||
| 	const source = createPostgresDataSource(config); | ||||
| 	await source.initialize(); | ||||
| 	await source.destroy(); | ||||
| } | ||||
|  | ||||
| async function connectToRedis(redisOptions) { | ||||
| 	return await new Promise(async (resolve, reject) => { | ||||
| 		const redis = new Redis({ | ||||
| 			...redisOptions, | ||||
| 			lazyConnect: true, | ||||
| 			reconnectOnError: false, | ||||
| 			showFriendlyErrorStack: true, | ||||
| 		}); | ||||
| 		redis.on('error', e => reject(e)); | ||||
|  | ||||
| 		try { | ||||
| 			await redis.connect(); | ||||
| 			resolve(); | ||||
|  | ||||
| 		} catch (e) { | ||||
| 			reject(e); | ||||
|  | ||||
| 		} finally { | ||||
| 			redis.disconnect(false); | ||||
| 		} | ||||
| 	}); | ||||
| } | ||||
|  | ||||
| // If not all of these are defined, the default one gets reused. | ||||
| // so we use a Set to only try connecting once to each **uniq** redis. | ||||
| const promises = Array | ||||
| 	.from(new Set([ | ||||
| 		config.redis, | ||||
| 		config.redisForPubsub, | ||||
| 		config.redisForJobQueue, | ||||
| 		config.redisForTimelines, | ||||
| 		config.redisForReactions, | ||||
| 	])) | ||||
| 	.map(connectToRedis) | ||||
| 	.concat([ | ||||
| 		connectToPostgres() | ||||
| 	]); | ||||
|  | ||||
| await Promise.all(promises); | ||||
|   | ||||
| @@ -7,14 +7,14 @@ import { Global, Inject, Module } from '@nestjs/common'; | ||||
| import * as Redis from 'ioredis'; | ||||
| import { DataSource } from 'typeorm'; | ||||
| import { MeiliSearch } from 'meilisearch'; | ||||
| import { MiMeta } from '@/models/Meta.js'; | ||||
| import { DI } from './di-symbols.js'; | ||||
| import { Config, loadConfig } from './config.js'; | ||||
| import { createPostgresDataSource } from './postgres.js'; | ||||
| import { RepositoryModule } from './models/RepositoryModule.js'; | ||||
| import { allSettled } from './misc/promise-tracker.js'; | ||||
| import type { Provider, OnApplicationShutdown } from '@nestjs/common'; | ||||
| import { MiMeta } from '@/models/Meta.js'; | ||||
| import { GlobalEvents } from './core/GlobalEventService.js'; | ||||
| import type { Provider, OnApplicationShutdown } from '@nestjs/common'; | ||||
|  | ||||
| const $config: Provider = { | ||||
| 	provide: DI.config, | ||||
| @@ -33,7 +33,11 @@ const $db: Provider = { | ||||
| const $meilisearch: Provider = { | ||||
| 	provide: DI.meilisearch, | ||||
| 	useFactory: (config: Config) => { | ||||
| 		if (config.meilisearch) { | ||||
| 		if (config.fulltextSearch?.provider === 'meilisearch') { | ||||
| 			if (!config.meilisearch) { | ||||
| 				throw new Error('MeiliSearch is enabled but no configuration is provided'); | ||||
| 			} | ||||
|  | ||||
| 			return new MeiliSearch({ | ||||
| 				host: `${config.meilisearch.ssl ? 'https' : 'http'}://${config.meilisearch.host}:${config.meilisearch.port}`, | ||||
| 				apiKey: config.meilisearch.apiKey, | ||||
|   | ||||
| @@ -68,16 +68,22 @@ process.on('exit', code => { | ||||
|  | ||||
| //#endregion | ||||
|  | ||||
| if (cluster.isPrimary || envOption.disableClustering) { | ||||
| 	await masterMain(); | ||||
|  | ||||
| if (!envOption.disableClustering) { | ||||
| 	if (cluster.isPrimary) { | ||||
| 		logger.info(`Start main process... pid: ${process.pid}`); | ||||
| 		await masterMain(); | ||||
| 		ev.mount(); | ||||
| 	} else if (cluster.isWorker) { | ||||
| 		logger.info(`Start worker process... pid: ${process.pid}`); | ||||
| 		await workerMain(); | ||||
| 	} else { | ||||
| 		throw new Error('Unknown process type'); | ||||
| 	} | ||||
| } | ||||
|  | ||||
| if (cluster.isWorker || envOption.disableClustering) { | ||||
| 	await workerMain(); | ||||
| } else { | ||||
| 	// 非clusterの場合はMasterのみが起動するため、Workerの処理は行わない(cluster.isWorker === trueの状態でこのブロックに来ることはない) | ||||
| 	logger.info(`Start main process... pid: ${process.pid}`); | ||||
| 	await masterMain(); | ||||
| 	ev.mount(); | ||||
| } | ||||
|  | ||||
| readyRef.value = true; | ||||
|   | ||||
| @@ -91,25 +91,36 @@ export async function masterMain() { | ||||
| 		}); | ||||
| 	} | ||||
|  | ||||
| 	if (envOption.disableClustering) { | ||||
| 	bootLogger.info( | ||||
| 		`mode: [disableClustering: ${envOption.disableClustering}, onlyServer: ${envOption.onlyServer}, onlyQueue: ${envOption.onlyQueue}]`, | ||||
| 	); | ||||
|  | ||||
| 	if (!envOption.disableClustering) { | ||||
| 		// clusterモジュール有効時 | ||||
|  | ||||
| 		if (envOption.onlyServer) { | ||||
| 			await server(); | ||||
| 			// onlyServer かつ enableCluster な場合、メインプロセスはforkのみに制限する(listenしない)。 | ||||
| 			// ワーカープロセス側でlistenすると、メインプロセスでポートへの着信を受け入れてワーカープロセスへの分配を行う動作をする。 | ||||
| 			// そのため、メインプロセスでも直接listenするとポートの競合が発生して起動に失敗してしまう。 | ||||
| 			// see: https://nodejs.org/api/cluster.html#cluster | ||||
| 		} else if (envOption.onlyQueue) { | ||||
| 			await jobQueue(); | ||||
| 		} else { | ||||
| 			await server(); | ||||
| 			await jobQueue(); | ||||
| 		} | ||||
| 	} else { | ||||
| 		if (envOption.onlyServer) { | ||||
| 			// nop | ||||
| 		} else if (envOption.onlyQueue) { | ||||
| 			// nop | ||||
| 		} else { | ||||
| 			await server(); | ||||
| 		} | ||||
|  | ||||
| 		await spawnWorkers(config.clusterLimit); | ||||
| 	} else { | ||||
| 		// clusterモジュール無効時 | ||||
|  | ||||
| 		if (envOption.onlyServer) { | ||||
| 			await server(); | ||||
| 		} else if (envOption.onlyQueue) { | ||||
| 			await jobQueue(); | ||||
| 		} else { | ||||
| 			await server(); | ||||
| 			await jobQueue(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	if (envOption.onlyQueue) { | ||||
|   | ||||
| @@ -50,6 +50,9 @@ type Source = { | ||||
| 	redisForJobQueue?: RedisOptionsSource; | ||||
| 	redisForTimelines?: RedisOptionsSource; | ||||
| 	redisForReactions?: RedisOptionsSource; | ||||
| 	fulltextSearch?: { | ||||
| 		provider?: FulltextSearchProvider; | ||||
| 	}; | ||||
| 	meilisearch?: { | ||||
| 		host: string; | ||||
| 		port: string; | ||||
| @@ -63,6 +66,8 @@ type Source = { | ||||
|  | ||||
| 	publishTarballInsteadOfProvideRepositoryUrl?: boolean; | ||||
|  | ||||
| 	setupPassword?: string; | ||||
|  | ||||
| 	proxy?: string; | ||||
| 	proxySmtp?: string; | ||||
| 	proxyBypassHosts?: string[]; | ||||
| @@ -97,6 +102,13 @@ type Source = { | ||||
| 	perUserNotificationsMaxCount?: number; | ||||
| 	deactivateAntennaThreshold?: number; | ||||
| 	pidFile: string; | ||||
|  | ||||
| 	logging?: { | ||||
| 		sql?: { | ||||
| 			disableQueryTruncation? : boolean, | ||||
| 			enableQueryParamLogging? : boolean, | ||||
| 		} | ||||
| 	} | ||||
| }; | ||||
|  | ||||
| export type Config = { | ||||
| @@ -122,6 +134,9 @@ export type Config = { | ||||
| 		user: string; | ||||
| 		pass: string; | ||||
| 	}[] | undefined; | ||||
| 	fulltextSearch?: { | ||||
| 		provider?: FulltextSearchProvider; | ||||
| 	}; | ||||
| 	meilisearch: { | ||||
| 		host: string; | ||||
| 		port: string; | ||||
| @@ -149,9 +164,16 @@ export type Config = { | ||||
| 	inboxJobMaxAttempts: number | undefined; | ||||
| 	proxyRemoteFiles: boolean | undefined; | ||||
| 	signToActivityPubGet: boolean | undefined; | ||||
| 	logging?: { | ||||
| 		sql?: { | ||||
| 			disableQueryTruncation? : boolean, | ||||
| 			enableQueryParamLogging? : boolean, | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	version: string; | ||||
| 	publishTarballInsteadOfProvideRepositoryUrl: boolean; | ||||
| 	setupPassword: string | undefined; | ||||
| 	host: string; | ||||
| 	hostname: string; | ||||
| 	scheme: string; | ||||
| @@ -181,6 +203,8 @@ export type Config = { | ||||
| 	pidFile: string; | ||||
| }; | ||||
|  | ||||
| export type FulltextSearchProvider = 'sqlLike' | 'sqlPgroonga' | 'meilisearch'; | ||||
|  | ||||
| const _filename = fileURLToPath(import.meta.url); | ||||
| const _dirname = dirname(_filename); | ||||
|  | ||||
| @@ -232,6 +256,7 @@ export function loadConfig(): Config { | ||||
| 	return { | ||||
| 		version, | ||||
| 		publishTarballInsteadOfProvideRepositoryUrl: !!config.publishTarballInsteadOfProvideRepositoryUrl, | ||||
| 		setupPassword: config.setupPassword, | ||||
| 		url: url.origin, | ||||
| 		port: config.port ?? parseInt(process.env.PORT ?? '', 10), | ||||
| 		socket: config.socket, | ||||
| @@ -248,6 +273,7 @@ export function loadConfig(): Config { | ||||
| 		db: { ...config.db, db: dbDb, user: dbUser, pass: dbPass }, | ||||
| 		dbReplications: config.dbReplications, | ||||
| 		dbSlaves: config.dbSlaves, | ||||
| 		fulltextSearch: config.fulltextSearch, | ||||
| 		meilisearch: config.meilisearch, | ||||
| 		redis, | ||||
| 		redisForPubsub: config.redisForPubsub ? convertRedisOptions(config.redisForPubsub, host) : redis, | ||||
| @@ -289,6 +315,7 @@ export function loadConfig(): Config { | ||||
| 		perUserNotificationsMaxCount: config.perUserNotificationsMaxCount ?? 500, | ||||
| 		deactivateAntennaThreshold: config.deactivateAntennaThreshold ?? (1000 * 60 * 60 * 24 * 7), | ||||
| 		pidFile: config.pidFile, | ||||
| 		logging: config.logging, | ||||
| 	}; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -26,6 +26,18 @@ export const DB_MAX_NOTE_TEXT_LENGTH = 8192; | ||||
| export const DB_MAX_IMAGE_COMMENT_LENGTH = 512; | ||||
| //#endregion | ||||
|  | ||||
| export const FILE_TYPE_IMAGE = [ | ||||
| 	'image/png', | ||||
| 	'image/gif', | ||||
| 	'image/jpeg', | ||||
| 	'image/webp', | ||||
| 	'image/avif', | ||||
| 	'image/apng', | ||||
| 	'image/bmp', | ||||
| 	'image/tiff', | ||||
| 	'image/x-icon', | ||||
| ]; | ||||
|  | ||||
| // ブラウザで直接表示することを許可するファイルの種類のリスト | ||||
| // ここに含まれないものは application/octet-stream としてレスポンスされる | ||||
| // SVGはXSSを生むので許可しない | ||||
|   | ||||
| @@ -22,6 +22,7 @@ import { RoleService } from '@/core/RoleService.js'; | ||||
| import { RecipientMethod } from '@/models/AbuseReportNotificationRecipient.js'; | ||||
| import { ModerationLogService } from '@/core/ModerationLogService.js'; | ||||
| import { SystemWebhookService } from '@/core/SystemWebhookService.js'; | ||||
| import { UserEntityService } from '@/core/entities/UserEntityService.js'; | ||||
| import { IdService } from './IdService.js'; | ||||
|  | ||||
| @Injectable() | ||||
| @@ -42,6 +43,7 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 		private emailService: EmailService, | ||||
| 		private moderationLogService: ModerationLogService, | ||||
| 		private globalEventService: GlobalEventService, | ||||
| 		private userEntityService: UserEntityService, | ||||
| 	) { | ||||
| 		this.redisForSub.on('message', this.onMessage); | ||||
| 	} | ||||
| @@ -59,7 +61,10 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		const moderatorIds = await this.roleService.getModeratorIds(true, true); | ||||
| 		const moderatorIds = await this.roleService.getModeratorIds({ | ||||
| 			includeAdmins: true, | ||||
| 			excludeExpire: true, | ||||
| 		}); | ||||
|  | ||||
| 		for (const moderatorId of moderatorIds) { | ||||
| 			for (const abuseReport of abuseReports) { | ||||
| @@ -135,22 +140,42 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		const recipientWebhookIds = await this.fetchWebhookRecipients() | ||||
| 			.then(it => it | ||||
| 				.filter(it => it.isActive && it.systemWebhookId && it.method === 'webhook') | ||||
| 				.map(it => it.systemWebhookId) | ||||
| 				.filter(x => x != null)); | ||||
| 		for (const webhookId of recipientWebhookIds) { | ||||
| 			await Promise.all( | ||||
| 				abuseReports.map(it => { | ||||
| 					return this.systemWebhookService.enqueueSystemWebhook( | ||||
| 						webhookId, | ||||
| 						type, | ||||
| 						it, | ||||
| 					); | ||||
| 				}), | ||||
| 			); | ||||
| 		} | ||||
| 		const usersMap = await this.userEntityService.packMany( | ||||
| 			[ | ||||
| 				...new Set([ | ||||
| 					...abuseReports.map(it => it.reporter ?? it.reporterId), | ||||
| 					...abuseReports.map(it => it.targetUser ?? it.targetUserId), | ||||
| 					...abuseReports.map(it => it.assignee ?? it.assigneeId), | ||||
| 				].filter(x => x != null)), | ||||
| 			], | ||||
| 			null, | ||||
| 			{ schema: 'UserLite' }, | ||||
| 		).then(it => new Map(it.map(it => [it.id, it]))); | ||||
| 		const convertedReports = abuseReports.map(it => { | ||||
| 			return { | ||||
| 				...it, | ||||
| 				reporter: usersMap.get(it.reporterId) ?? null, | ||||
| 				targetUser: usersMap.get(it.targetUserId) ?? null, | ||||
| 				assignee: it.assigneeId ? (usersMap.get(it.assigneeId) ?? null) : null, | ||||
| 			}; | ||||
| 		}); | ||||
|  | ||||
| 		const inactiveRecipients = await this.fetchWebhookRecipients() | ||||
| 			.then(it => it.filter(it => !it.isActive)); | ||||
| 		const withoutWebhookIds = inactiveRecipients | ||||
| 			.map(it => it.systemWebhookId) | ||||
| 			.filter(x => x != null); | ||||
| 		return Promise.all( | ||||
| 			convertedReports.map(it => { | ||||
| 				return this.systemWebhookService.enqueueSystemWebhook( | ||||
| 					type, | ||||
| 					it, | ||||
| 					{ | ||||
| 						excludes: withoutWebhookIds, | ||||
| 					}, | ||||
| 				); | ||||
| 			}), | ||||
| 		); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -263,8 +288,7 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 			.log(updater, 'createAbuseReportNotificationRecipient', { | ||||
| 				recipientId: id, | ||||
| 				recipient: created, | ||||
| 			}) | ||||
| 			.then(); | ||||
| 			}); | ||||
|  | ||||
| 		return created; | ||||
| 	} | ||||
| @@ -302,8 +326,7 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 				recipientId: params.id, | ||||
| 				before: beforeEntity, | ||||
| 				after: afterEntity, | ||||
| 			}) | ||||
| 			.then(); | ||||
| 			}); | ||||
|  | ||||
| 		return afterEntity; | ||||
| 	} | ||||
| @@ -324,8 +347,7 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 			.log(updater, 'deleteAbuseReportNotificationRecipient', { | ||||
| 				recipientId: id, | ||||
| 				recipient: entity, | ||||
| 			}) | ||||
| 			.then(); | ||||
| 			}); | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| @@ -348,7 +370,10 @@ export class AbuseReportNotificationService implements OnApplicationShutdown { | ||||
| 		} | ||||
|  | ||||
| 		// モデレータ権限の有無で通知先設定を振り分ける | ||||
| 		const authorizedUserIds = await this.roleService.getModeratorIds(true, true); | ||||
| 		const authorizedUserIds = await this.roleService.getModeratorIds({ | ||||
| 			includeAdmins: true, | ||||
| 			excludeExpire: true, | ||||
| 		}); | ||||
| 		const authorizedUserRecipients = Array.of<MiAbuseReportNotificationRecipient>(); | ||||
| 		const unauthorizedUserRecipients = Array.of<MiAbuseReportNotificationRecipient>(); | ||||
| 		for (const recipient of userRecipients) { | ||||
|   | ||||
| @@ -20,8 +20,10 @@ export class AbuseReportService { | ||||
| 	constructor( | ||||
| 		@Inject(DI.abuseUserReportsRepository) | ||||
| 		private abuseUserReportsRepository: AbuseUserReportsRepository, | ||||
|  | ||||
| 		@Inject(DI.usersRepository) | ||||
| 		private usersRepository: UsersRepository, | ||||
|  | ||||
| 		private idService: IdService, | ||||
| 		private abuseReportNotificationService: AbuseReportNotificationService, | ||||
| 		private queueService: QueueService, | ||||
| @@ -77,16 +79,16 @@ export class AbuseReportService { | ||||
| 	 * - SystemWebhook | ||||
| 	 * | ||||
| 	 * @param params 通報内容. もし複数件の通報に対応した時のために、あらかじめ複数件を処理できる前提で考える | ||||
| 	 * @param operator 通報を処理したユーザ | ||||
| 	 * @param moderator 通報を処理したユーザ | ||||
| 	 * @see AbuseReportNotificationService.notify | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async resolve( | ||||
| 		params: { | ||||
| 			reportId: string; | ||||
| 			forward: boolean; | ||||
| 			resolvedAs: MiAbuseUserReport['resolvedAs']; | ||||
| 		}[], | ||||
| 		operator: MiUser, | ||||
| 		moderator: MiUser, | ||||
| 	) { | ||||
| 		const paramsMap = new Map(params.map(it => [it.reportId, it])); | ||||
| 		const reports = await this.abuseUserReportsRepository.findBy({ | ||||
| @@ -99,30 +101,76 @@ export class AbuseReportService { | ||||
|  | ||||
| 			await this.abuseUserReportsRepository.update(report.id, { | ||||
| 				resolved: true, | ||||
| 				assigneeId: operator.id, | ||||
| 				forwarded: ps.forward && report.targetUserHost !== null, | ||||
| 				assigneeId: moderator.id, | ||||
| 				resolvedAs: ps.resolvedAs, | ||||
| 			}); | ||||
|  | ||||
| 			if (ps.forward && report.targetUserHost != null) { | ||||
| 				const actor = await this.instanceActorService.getInstanceActor(); | ||||
| 				const targetUser = await this.usersRepository.findOneByOrFail({ id: report.targetUserId }); | ||||
|  | ||||
| 				// eslint-disable-next-line | ||||
| 				const flag = this.apRendererService.renderFlag(actor, targetUser.uri!, report.comment); | ||||
| 				const contextAssignedFlag = this.apRendererService.addContext(flag); | ||||
| 				this.queueService.deliver(actor, contextAssignedFlag, targetUser.inbox, false); | ||||
| 			} | ||||
|  | ||||
| 			this.moderationLogService | ||||
| 				.log(operator, 'resolveAbuseReport', { | ||||
| 				.log(moderator, 'resolveAbuseReport', { | ||||
| 					reportId: report.id, | ||||
| 					report: report, | ||||
| 					forwarded: ps.forward && report.targetUserHost !== null, | ||||
| 				}) | ||||
| 				.then(); | ||||
| 					resolvedAs: ps.resolvedAs, | ||||
| 				}); | ||||
| 		} | ||||
|  | ||||
| 		return this.abuseUserReportsRepository.findBy({ id: In(reports.map(it => it.id)) }) | ||||
| 			.then(reports => this.abuseReportNotificationService.notifySystemWebhook(reports, 'abuseReportResolved')); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async forward( | ||||
| 		reportId: MiAbuseUserReport['id'], | ||||
| 		moderator: MiUser, | ||||
| 	) { | ||||
| 		const report = await this.abuseUserReportsRepository.findOneByOrFail({ id: reportId }); | ||||
|  | ||||
| 		if (report.targetUserHost == null) { | ||||
| 			throw new Error('The target user host is null.'); | ||||
| 		} | ||||
|  | ||||
| 		if (report.forwarded) { | ||||
| 			throw new Error('The report has already been forwarded.'); | ||||
| 		} | ||||
|  | ||||
| 		await this.abuseUserReportsRepository.update(report.id, { | ||||
| 			forwarded: true, | ||||
| 		}); | ||||
|  | ||||
| 		const actor = await this.instanceActorService.getInstanceActor(); | ||||
| 		const targetUser = await this.usersRepository.findOneByOrFail({ id: report.targetUserId }); | ||||
|  | ||||
| 		const flag = this.apRendererService.renderFlag(actor, targetUser.uri!, report.comment); | ||||
| 		const contextAssignedFlag = this.apRendererService.addContext(flag); | ||||
| 		this.queueService.deliver(actor, contextAssignedFlag, targetUser.inbox, false); | ||||
|  | ||||
| 		this.moderationLogService | ||||
| 			.log(moderator, 'forwardAbuseReport', { | ||||
| 				reportId: report.id, | ||||
| 				report: report, | ||||
| 			}); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async update( | ||||
| 		reportId: MiAbuseUserReport['id'], | ||||
| 		params: { | ||||
| 			moderationNote?: MiAbuseUserReport['moderationNote']; | ||||
| 		}, | ||||
| 		moderator: MiUser, | ||||
| 	) { | ||||
| 		const report = await this.abuseUserReportsRepository.findOneByOrFail({ id: reportId }); | ||||
|  | ||||
| 		await this.abuseUserReportsRepository.update(report.id, { | ||||
| 			moderationNote: params.moderationNote, | ||||
| 		}); | ||||
|  | ||||
| 		if (params.moderationNote != null && report.moderationNote !== params.moderationNote) { | ||||
| 			this.moderationLogService.log(moderator, 'updateAbuseReportNote', { | ||||
| 				reportId: report.id, | ||||
| 				report: report, | ||||
| 				before: report.moderationNote, | ||||
| 				after: params.moderationNote, | ||||
| 			}); | ||||
| 		} | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -274,13 +274,15 @@ export class AccountMoveService { | ||||
| 		} | ||||
|  | ||||
| 		// Update instance stats by decreasing remote followers count by the number of local followers who were following the old account. | ||||
| 		if (this.userEntityService.isRemoteUser(oldAccount)) { | ||||
| 			this.federatedInstanceService.fetch(oldAccount.host).then(async i => { | ||||
| 				this.instancesRepository.decrement({ id: i.id }, 'followersCount', localFollowerIds.length); | ||||
| 				if (this.meta.enableChartsForFederatedInstances) { | ||||
| 					this.instanceChart.updateFollowers(i.host, false); | ||||
| 				} | ||||
| 			}); | ||||
| 		if (this.meta.enableStatsForFederatedInstances) { | ||||
| 			if (this.userEntityService.isRemoteUser(oldAccount)) { | ||||
| 				this.federatedInstanceService.fetchOrRegister(oldAccount.host).then(async i => { | ||||
| 					this.instancesRepository.decrement({ id: i.id }, 'followersCount', localFollowerIds.length); | ||||
| 					if (this.meta.enableChartsForFederatedInstances) { | ||||
| 						this.instanceChart.updateFollowers(i.host, false); | ||||
| 					} | ||||
| 				}); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		// FIXME: expensive? | ||||
|   | ||||
| @@ -10,12 +10,13 @@ import { Injectable } from '@nestjs/common'; | ||||
| import * as nsfw from 'nsfwjs'; | ||||
| import si from 'systeminformation'; | ||||
| import { Mutex } from 'async-mutex'; | ||||
| import fetch from 'node-fetch'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
|  | ||||
| const _filename = fileURLToPath(import.meta.url); | ||||
| const _dirname = dirname(_filename); | ||||
|  | ||||
| const REQUIRED_CPU_FLAGS = ['avx2', 'fma']; | ||||
| const REQUIRED_CPU_FLAGS_X64 = ['avx2', 'fma']; | ||||
| let isSupportedCpu: undefined | boolean = undefined; | ||||
|  | ||||
| @Injectable() | ||||
| @@ -28,11 +29,10 @@ export class AiService { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async detectSensitive(path: string): Promise<nsfw.predictionType[] | null> { | ||||
| 	public async detectSensitive(path: string): Promise<nsfw.PredictionType[] | null> { | ||||
| 		try { | ||||
| 			if (isSupportedCpu === undefined) { | ||||
| 				const cpuFlags = await this.getCpuFlags(); | ||||
| 				isSupportedCpu = REQUIRED_CPU_FLAGS.every(required => cpuFlags.includes(required)); | ||||
| 				isSupportedCpu = await this.computeIsSupportedCpu(); | ||||
| 			} | ||||
|  | ||||
| 			if (!isSupportedCpu) { | ||||
| @@ -41,6 +41,7 @@ export class AiService { | ||||
| 			} | ||||
|  | ||||
| 			const tf = await import('@tensorflow/tfjs-node'); | ||||
| 			tf.env().global.fetch = fetch; | ||||
|  | ||||
| 			if (this.model == null) { | ||||
| 				await this.modelLoadMutex.runExclusive(async () => { | ||||
| @@ -64,6 +65,22 @@ export class AiService { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	private async computeIsSupportedCpu(): Promise<boolean> { | ||||
| 		switch (process.arch) { | ||||
| 			case 'x64': { | ||||
| 				const cpuFlags = await this.getCpuFlags(); | ||||
| 				return REQUIRED_CPU_FLAGS_X64.every(required => cpuFlags.includes(required)); | ||||
| 			} | ||||
| 			case 'arm64': { | ||||
| 				// As far as I know, no required CPU flags for ARM64. | ||||
| 				return true; | ||||
| 			} | ||||
| 			default: { | ||||
| 				return false; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async getCpuFlags(): Promise<string[]> { | ||||
| 		const str = await si.cpuFlags(); | ||||
|   | ||||
| @@ -72,7 +72,7 @@ export class AnnouncementService { | ||||
| 			updatedAt: null, | ||||
| 			title: values.title, | ||||
| 			text: values.text, | ||||
| 			imageUrl: values.imageUrl, | ||||
| 			imageUrl: values.imageUrl || null, | ||||
| 			icon: values.icon, | ||||
| 			display: values.display, | ||||
| 			forExistingUsers: values.forExistingUsers, | ||||
| @@ -209,6 +209,13 @@ export class AnnouncementService { | ||||
| 			return; | ||||
| 		} | ||||
|  | ||||
| 		const announcement = await this.announcementsRepository.findOneBy({ id: announcementId }); | ||||
| 		if (announcement != null && announcement.userId === user.id) { | ||||
| 			await this.announcementsRepository.update(announcementId, { | ||||
| 				isActive: false, | ||||
| 			}); | ||||
| 		} | ||||
|  | ||||
| 		if ((await this.getUnreadAnnouncements(user)).length === 0) { | ||||
| 			this.globalEventService.publishMainStream(user.id, 'readAllAnnouncements'); | ||||
| 		} | ||||
|   | ||||
| @@ -6,6 +6,65 @@ | ||||
| import { Injectable } from '@nestjs/common'; | ||||
| import { HttpRequestService } from '@/core/HttpRequestService.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { MetaService } from '@/core/MetaService.js'; | ||||
| import { MiMeta } from '@/models/Meta.js'; | ||||
| import Logger from '@/logger.js'; | ||||
| import { LoggerService } from './LoggerService.js'; | ||||
|  | ||||
| export const supportedCaptchaProviders = ['none', 'hcaptcha', 'mcaptcha', 'recaptcha', 'turnstile', 'testcaptcha'] as const; | ||||
| export type CaptchaProvider = typeof supportedCaptchaProviders[number]; | ||||
|  | ||||
| export const captchaErrorCodes = { | ||||
| 	invalidProvider: Symbol('invalidProvider'), | ||||
| 	invalidParameters: Symbol('invalidParameters'), | ||||
| 	noResponseProvided: Symbol('noResponseProvided'), | ||||
| 	requestFailed: Symbol('requestFailed'), | ||||
| 	verificationFailed: Symbol('verificationFailed'), | ||||
| 	unknown: Symbol('unknown'), | ||||
| } as const; | ||||
| export type CaptchaErrorCode = typeof captchaErrorCodes[keyof typeof captchaErrorCodes]; | ||||
|  | ||||
| export type CaptchaSetting = { | ||||
| 	provider: CaptchaProvider; | ||||
| 	hcaptcha: { | ||||
| 		siteKey: string | null; | ||||
| 		secretKey: string | null; | ||||
| 	} | ||||
| 	mcaptcha: { | ||||
| 		siteKey: string | null; | ||||
| 		secretKey: string | null; | ||||
| 		instanceUrl: string | null; | ||||
| 	} | ||||
| 	recaptcha: { | ||||
| 		siteKey: string | null; | ||||
| 		secretKey: string | null; | ||||
| 	} | ||||
| 	turnstile: { | ||||
| 		siteKey: string | null; | ||||
| 		secretKey: string | null; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export class CaptchaError extends Error { | ||||
| 	public readonly code: CaptchaErrorCode; | ||||
| 	public readonly cause?: unknown; | ||||
|  | ||||
| 	constructor(code: CaptchaErrorCode, message: string, cause?: unknown) { | ||||
| 		super(message); | ||||
| 		this.code = code; | ||||
| 		this.cause = cause; | ||||
| 		this.name = 'CaptchaError'; | ||||
| 	} | ||||
| } | ||||
|  | ||||
| export type CaptchaSaveSuccess = { | ||||
| 	success: true; | ||||
| } | ||||
| export type CaptchaSaveFailure = { | ||||
| 	success: false; | ||||
| 	error: CaptchaError; | ||||
| } | ||||
| export type CaptchaSaveResult = CaptchaSaveSuccess | CaptchaSaveFailure; | ||||
|  | ||||
| type CaptchaResponse = { | ||||
| 	success: boolean; | ||||
| @@ -14,9 +73,14 @@ type CaptchaResponse = { | ||||
|  | ||||
| @Injectable() | ||||
| export class CaptchaService { | ||||
| 	private readonly logger: Logger; | ||||
|  | ||||
| 	constructor( | ||||
| 		private httpRequestService: HttpRequestService, | ||||
| 		private metaService: MetaService, | ||||
| 		loggerService: LoggerService, | ||||
| 	) { | ||||
| 		this.logger = loggerService.getLogger('captcha'); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| @@ -44,32 +108,32 @@ export class CaptchaService { | ||||
| 	@bindThis | ||||
| 	public async verifyRecaptcha(secret: string, response: string | null | undefined): Promise<void> { | ||||
| 		if (response == null) { | ||||
| 			throw new Error('recaptcha-failed: no response provided'); | ||||
| 			throw new CaptchaError(captchaErrorCodes.noResponseProvided, 'recaptcha-failed: no response provided'); | ||||
| 		} | ||||
|  | ||||
| 		const result = await this.getCaptchaResponse('https://www.recaptcha.net/recaptcha/api/siteverify', secret, response).catch(err => { | ||||
| 			throw new Error(`recaptcha-request-failed: ${err}`); | ||||
| 			throw new CaptchaError(captchaErrorCodes.requestFailed, `recaptcha-request-failed: ${err}`); | ||||
| 		}); | ||||
|  | ||||
| 		if (result.success !== true) { | ||||
| 			const errorCodes = result['error-codes'] ? result['error-codes'].join(', ') : ''; | ||||
| 			throw new Error(`recaptcha-failed: ${errorCodes}`); | ||||
| 			throw new CaptchaError(captchaErrorCodes.verificationFailed, `recaptcha-failed: ${errorCodes}`); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async verifyHcaptcha(secret: string, response: string | null | undefined): Promise<void> { | ||||
| 		if (response == null) { | ||||
| 			throw new Error('hcaptcha-failed: no response provided'); | ||||
| 			throw new CaptchaError(captchaErrorCodes.noResponseProvided, 'hcaptcha-failed: no response provided'); | ||||
| 		} | ||||
|  | ||||
| 		const result = await this.getCaptchaResponse('https://hcaptcha.com/siteverify', secret, response).catch(err => { | ||||
| 			throw new Error(`hcaptcha-request-failed: ${err}`); | ||||
| 			throw new CaptchaError(captchaErrorCodes.requestFailed, `hcaptcha-request-failed: ${err}`); | ||||
| 		}); | ||||
|  | ||||
| 		if (result.success !== true) { | ||||
| 			const errorCodes = result['error-codes'] ? result['error-codes'].join(', ') : ''; | ||||
| 			throw new Error(`hcaptcha-failed: ${errorCodes}`); | ||||
| 			throw new CaptchaError(captchaErrorCodes.verificationFailed, `hcaptcha-failed: ${errorCodes}`); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| @@ -77,7 +141,7 @@ export class CaptchaService { | ||||
| 	@bindThis | ||||
| 	public async verifyMcaptcha(secret: string, siteKey: string, instanceHost: string, response: string | null | undefined): Promise<void> { | ||||
| 		if (response == null) { | ||||
| 			throw new Error('mcaptcha-failed: no response provided'); | ||||
| 			throw new CaptchaError(captchaErrorCodes.noResponseProvided, 'mcaptcha-failed: no response provided'); | ||||
| 		} | ||||
|  | ||||
| 		const endpointUrl = new URL('/api/v1/pow/siteverify', instanceHost); | ||||
| @@ -91,33 +155,251 @@ export class CaptchaService { | ||||
| 			headers: { | ||||
| 				'Content-Type': 'application/json', | ||||
| 			}, | ||||
| 		}); | ||||
| 		}, { throwErrorWhenResponseNotOk: false }); | ||||
|  | ||||
| 		if (result.status !== 200) { | ||||
| 			throw new Error('mcaptcha-failed: mcaptcha didn\'t return 200 OK'); | ||||
| 			throw new CaptchaError(captchaErrorCodes.requestFailed, 'mcaptcha-failed: mcaptcha didn\'t return 200 OK'); | ||||
| 		} | ||||
|  | ||||
| 		const resp = (await result.json()) as { valid: boolean }; | ||||
|  | ||||
| 		if (!resp.valid) { | ||||
| 			throw new Error('mcaptcha-request-failed'); | ||||
| 			throw new CaptchaError(captchaErrorCodes.verificationFailed, 'mcaptcha-request-failed'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async verifyTurnstile(secret: string, response: string | null | undefined): Promise<void> { | ||||
| 		if (response == null) { | ||||
| 			throw new Error('turnstile-failed: no response provided'); | ||||
| 			throw new CaptchaError(captchaErrorCodes.noResponseProvided, 'turnstile-failed: no response provided'); | ||||
| 		} | ||||
|  | ||||
| 		const result = await this.getCaptchaResponse('https://challenges.cloudflare.com/turnstile/v0/siteverify', secret, response).catch(err => { | ||||
| 			throw new Error(`turnstile-request-failed: ${err}`); | ||||
| 			throw new CaptchaError(captchaErrorCodes.requestFailed, `turnstile-request-failed: ${err}`); | ||||
| 		}); | ||||
|  | ||||
| 		if (result.success !== true) { | ||||
| 			const errorCodes = result['error-codes'] ? result['error-codes'].join(', ') : ''; | ||||
| 			throw new Error(`turnstile-failed: ${errorCodes}`); | ||||
| 			throw new CaptchaError(captchaErrorCodes.verificationFailed, `turnstile-failed: ${errorCodes}`); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async verifyTestcaptcha(response: string | null | undefined): Promise<void> { | ||||
| 		if (response == null) { | ||||
| 			throw new CaptchaError(captchaErrorCodes.noResponseProvided, 'testcaptcha-failed: no response provided'); | ||||
| 		} | ||||
|  | ||||
| 		const success = response === 'testcaptcha-passed'; | ||||
|  | ||||
| 		if (!success) { | ||||
| 			throw new CaptchaError(captchaErrorCodes.verificationFailed, 'testcaptcha-failed'); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async get(): Promise<CaptchaSetting> { | ||||
| 		const meta = await this.metaService.fetch(true); | ||||
|  | ||||
| 		let provider: CaptchaProvider; | ||||
| 		switch (true) { | ||||
| 			case meta.enableHcaptcha: { | ||||
| 				provider = 'hcaptcha'; | ||||
| 				break; | ||||
| 			} | ||||
| 			case meta.enableMcaptcha: { | ||||
| 				provider = 'mcaptcha'; | ||||
| 				break; | ||||
| 			} | ||||
| 			case meta.enableRecaptcha: { | ||||
| 				provider = 'recaptcha'; | ||||
| 				break; | ||||
| 			} | ||||
| 			case meta.enableTurnstile: { | ||||
| 				provider = 'turnstile'; | ||||
| 				break; | ||||
| 			} | ||||
| 			case meta.enableTestcaptcha: { | ||||
| 				provider = 'testcaptcha'; | ||||
| 				break; | ||||
| 			} | ||||
| 			default: { | ||||
| 				provider = 'none'; | ||||
| 				break; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return { | ||||
| 			provider: provider, | ||||
| 			hcaptcha: { | ||||
| 				siteKey: meta.hcaptchaSiteKey, | ||||
| 				secretKey: meta.hcaptchaSecretKey, | ||||
| 			}, | ||||
| 			mcaptcha: { | ||||
| 				siteKey: meta.mcaptchaSitekey, | ||||
| 				secretKey: meta.mcaptchaSecretKey, | ||||
| 				instanceUrl: meta.mcaptchaInstanceUrl, | ||||
| 			}, | ||||
| 			recaptcha: { | ||||
| 				siteKey: meta.recaptchaSiteKey, | ||||
| 				secretKey: meta.recaptchaSecretKey, | ||||
| 			}, | ||||
| 			turnstile: { | ||||
| 				siteKey: meta.turnstileSiteKey, | ||||
| 				secretKey: meta.turnstileSecretKey, | ||||
| 			}, | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	/** | ||||
| 	 * captchaの設定を更新します. その際、フロントエンド側で受け取ったcaptchaからの戻り値を検証し、passした場合のみ設定を更新します. | ||||
| 	 * 実際の検証処理はサービス内で定義されている各captchaプロバイダの検証関数に委譲します. | ||||
| 	 * | ||||
| 	 * @param provider 検証するcaptchaのプロバイダ | ||||
| 	 * @param params | ||||
| 	 * @param params.sitekey hcaptcha, recaptcha, turnstile, mcaptchaの場合に指定するsitekey. それ以外のプロバイダでは無視されます | ||||
| 	 * @param params.secret hcaptcha, recaptcha, turnstile, mcaptchaの場合に指定するsecret. それ以外のプロバイダでは無視されます | ||||
| 	 * @param params.instanceUrl mcaptchaの場合に指定するインスタンスのURL. それ以外のプロバイダでは無視されます | ||||
| 	 * @param params.captchaResult フロントエンド側で受け取ったcaptchaプロバイダからの戻り値. この値を使ってサーバサイドでの検証を行います | ||||
| 	 * @see verifyHcaptcha | ||||
| 	 * @see verifyMcaptcha | ||||
| 	 * @see verifyRecaptcha | ||||
| 	 * @see verifyTurnstile | ||||
| 	 * @see verifyTestcaptcha | ||||
| 	 */ | ||||
| 	@bindThis | ||||
| 	public async save( | ||||
| 		provider: CaptchaProvider, | ||||
| 		params?: { | ||||
| 			sitekey?: string | null; | ||||
| 			secret?: string | null; | ||||
| 			instanceUrl?: string | null; | ||||
| 			captchaResult?: string | null; | ||||
| 		}, | ||||
| 	): Promise<CaptchaSaveResult> { | ||||
| 		if (!supportedCaptchaProviders.includes(provider)) { | ||||
| 			return { | ||||
| 				success: false, | ||||
| 				error: new CaptchaError(captchaErrorCodes.invalidProvider, `Invalid captcha provider: ${provider}`), | ||||
| 			}; | ||||
| 		} | ||||
|  | ||||
| 		const operation = { | ||||
| 			none: async () => { | ||||
| 				await this.updateMeta(provider, params); | ||||
| 			}, | ||||
| 			hcaptcha: async () => { | ||||
| 				if (!params?.secret || !params.captchaResult) { | ||||
| 					throw new CaptchaError(captchaErrorCodes.invalidParameters, 'hcaptcha-failed: secret and captureResult are required'); | ||||
| 				} | ||||
|  | ||||
| 				await this.verifyHcaptcha(params.secret, params.captchaResult); | ||||
| 				await this.updateMeta(provider, params); | ||||
| 			}, | ||||
| 			mcaptcha: async () => { | ||||
| 				if (!params?.secret || !params.sitekey || !params.instanceUrl || !params.captchaResult) { | ||||
| 					throw new CaptchaError(captchaErrorCodes.invalidParameters, 'mcaptcha-failed: secret, sitekey, instanceUrl and captureResult are required'); | ||||
| 				} | ||||
|  | ||||
| 				await this.verifyMcaptcha(params.secret, params.sitekey, params.instanceUrl, params.captchaResult); | ||||
| 				await this.updateMeta(provider, params); | ||||
| 			}, | ||||
| 			recaptcha: async () => { | ||||
| 				if (!params?.secret || !params.captchaResult) { | ||||
| 					throw new CaptchaError(captchaErrorCodes.invalidParameters, 'recaptcha-failed: secret and captureResult are required'); | ||||
| 				} | ||||
|  | ||||
| 				await this.verifyRecaptcha(params.secret, params.captchaResult); | ||||
| 				await this.updateMeta(provider, params); | ||||
| 			}, | ||||
| 			turnstile: async () => { | ||||
| 				if (!params?.secret || !params.captchaResult) { | ||||
| 					throw new CaptchaError(captchaErrorCodes.invalidParameters, 'turnstile-failed: secret and captureResult are required'); | ||||
| 				} | ||||
|  | ||||
| 				await this.verifyTurnstile(params.secret, params.captchaResult); | ||||
| 				await this.updateMeta(provider, params); | ||||
| 			}, | ||||
| 			testcaptcha: async () => { | ||||
| 				if (!params?.captchaResult) { | ||||
| 					throw new CaptchaError(captchaErrorCodes.invalidParameters, 'turnstile-failed: captureResult are required'); | ||||
| 				} | ||||
|  | ||||
| 				await this.verifyTestcaptcha(params.captchaResult); | ||||
| 				await this.updateMeta(provider, params); | ||||
| 			}, | ||||
| 		}[provider]; | ||||
|  | ||||
| 		return operation() | ||||
| 			.then(() => ({ success: true }) as CaptchaSaveSuccess) | ||||
| 			.catch(err => { | ||||
| 				this.logger.info(err); | ||||
| 				const error = err instanceof CaptchaError | ||||
| 					? err | ||||
| 					: new CaptchaError(captchaErrorCodes.unknown, `unknown error: ${err}`); | ||||
| 				return { | ||||
| 					success: false, | ||||
| 					error, | ||||
| 				}; | ||||
| 			}); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private async updateMeta( | ||||
| 		provider: CaptchaProvider, | ||||
| 		params?: { | ||||
| 			sitekey?: string | null; | ||||
| 			secret?: string | null; | ||||
| 			instanceUrl?: string | null; | ||||
| 		}, | ||||
| 	) { | ||||
| 		const metaPartial: Partial< | ||||
| 			Pick< | ||||
| 				MiMeta, | ||||
| 				('enableHcaptcha' | 'hcaptchaSiteKey' | 'hcaptchaSecretKey') | | ||||
| 				('enableMcaptcha' | 'mcaptchaSitekey' | 'mcaptchaSecretKey' | 'mcaptchaInstanceUrl') | | ||||
| 				('enableRecaptcha' | 'recaptchaSiteKey' | 'recaptchaSecretKey') | | ||||
| 				('enableTurnstile' | 'turnstileSiteKey' | 'turnstileSecretKey') | | ||||
| 				('enableTestcaptcha') | ||||
| 			> | ||||
| 		> = { | ||||
| 			enableHcaptcha: provider === 'hcaptcha', | ||||
| 			enableMcaptcha: provider === 'mcaptcha', | ||||
| 			enableRecaptcha: provider === 'recaptcha', | ||||
| 			enableTurnstile: provider === 'turnstile', | ||||
| 			enableTestcaptcha: provider === 'testcaptcha', | ||||
| 		}; | ||||
|  | ||||
| 		const updateIfNotUndefined = <K extends keyof typeof metaPartial>(key: K, value: typeof metaPartial[K]) => { | ||||
| 			if (value !== undefined) { | ||||
| 				metaPartial[key] = value; | ||||
| 			} | ||||
| 		}; | ||||
| 		switch (provider) { | ||||
| 			case 'hcaptcha': { | ||||
| 				updateIfNotUndefined('hcaptchaSiteKey', params?.sitekey); | ||||
| 				updateIfNotUndefined('hcaptchaSecretKey', params?.secret); | ||||
| 				break; | ||||
| 			} | ||||
| 			case 'mcaptcha': { | ||||
| 				updateIfNotUndefined('mcaptchaSitekey', params?.sitekey); | ||||
| 				updateIfNotUndefined('mcaptchaSecretKey', params?.secret); | ||||
| 				updateIfNotUndefined('mcaptchaInstanceUrl', params?.instanceUrl); | ||||
| 				break; | ||||
| 			} | ||||
| 			case 'recaptcha': { | ||||
| 				updateIfNotUndefined('recaptchaSiteKey', params?.sitekey); | ||||
| 				updateIfNotUndefined('recaptchaSecretKey', params?.secret); | ||||
| 				break; | ||||
| 			} | ||||
| 			case 'turnstile': { | ||||
| 				updateIfNotUndefined('turnstileSiteKey', params?.sitekey); | ||||
| 				updateIfNotUndefined('turnstileSecretKey', params?.secret); | ||||
| 				break; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		await this.metaService.update(metaPartial); | ||||
| 	} | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -14,6 +14,7 @@ import { AbuseReportNotificationService } from '@/core/AbuseReportNotificationSe | ||||
| import { SystemWebhookService } from '@/core/SystemWebhookService.js'; | ||||
| import { UserSearchService } from '@/core/UserSearchService.js'; | ||||
| import { WebhookTestService } from '@/core/WebhookTestService.js'; | ||||
| import { FlashService } from '@/core/FlashService.js'; | ||||
| import { AccountMoveService } from './AccountMoveService.js'; | ||||
| import { AccountUpdateService } from './AccountUpdateService.js'; | ||||
| import { AiService } from './AiService.js'; | ||||
| @@ -217,6 +218,7 @@ const $SystemWebhookService: Provider = { provide: 'SystemWebhookService', useEx | ||||
| const $WebhookTestService: Provider = { provide: 'WebhookTestService', useExisting: WebhookTestService }; | ||||
| const $UtilityService: Provider = { provide: 'UtilityService', useExisting: UtilityService }; | ||||
| const $FileInfoService: Provider = { provide: 'FileInfoService', useExisting: FileInfoService }; | ||||
| const $FlashService: Provider = { provide: 'FlashService', useExisting: FlashService }; | ||||
| const $SearchService: Provider = { provide: 'SearchService', useExisting: SearchService }; | ||||
| const $ClipService: Provider = { provide: 'ClipService', useExisting: ClipService }; | ||||
| const $FeaturedService: Provider = { provide: 'FeaturedService', useExisting: FeaturedService }; | ||||
| @@ -367,6 +369,7 @@ const $ApQuestionService: Provider = { provide: 'ApQuestionService', useExisting | ||||
| 		WebhookTestService, | ||||
| 		UtilityService, | ||||
| 		FileInfoService, | ||||
| 		FlashService, | ||||
| 		SearchService, | ||||
| 		ClipService, | ||||
| 		FeaturedService, | ||||
| @@ -513,6 +516,7 @@ const $ApQuestionService: Provider = { provide: 'ApQuestionService', useExisting | ||||
| 		$WebhookTestService, | ||||
| 		$UtilityService, | ||||
| 		$FileInfoService, | ||||
| 		$FlashService, | ||||
| 		$SearchService, | ||||
| 		$ClipService, | ||||
| 		$FeaturedService, | ||||
| @@ -660,6 +664,7 @@ const $ApQuestionService: Provider = { provide: 'ApQuestionService', useExisting | ||||
| 		WebhookTestService, | ||||
| 		UtilityService, | ||||
| 		FileInfoService, | ||||
| 		FlashService, | ||||
| 		SearchService, | ||||
| 		ClipService, | ||||
| 		FeaturedService, | ||||
|   | ||||
| @@ -4,24 +4,59 @@ | ||||
|  */ | ||||
|  | ||||
| import { Inject, Injectable, OnApplicationShutdown } from '@nestjs/common'; | ||||
| import { In, IsNull } from 'typeorm'; | ||||
| import * as Redis from 'ioredis'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import { IdService } from '@/core/IdService.js'; | ||||
| import { In, IsNull } from 'typeorm'; | ||||
| import { EmojiEntityService } from '@/core/entities/EmojiEntityService.js'; | ||||
| import { GlobalEventService } from '@/core/GlobalEventService.js'; | ||||
| import type { MiDriveFile } from '@/models/DriveFile.js'; | ||||
| import type { MiEmoji } from '@/models/Emoji.js'; | ||||
| import type { EmojisRepository, MiRole, MiUser } from '@/models/_.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { MemoryKVCache, RedisSingleCache } from '@/misc/cache.js'; | ||||
| import { UtilityService } from '@/core/UtilityService.js'; | ||||
| import { query } from '@/misc/prelude/url.js'; | ||||
| import type { Serialized } from '@/types.js'; | ||||
| import { IdService } from '@/core/IdService.js'; | ||||
| import { ModerationLogService } from '@/core/ModerationLogService.js'; | ||||
| import { UtilityService } from '@/core/UtilityService.js'; | ||||
| import { bindThis } from '@/decorators.js'; | ||||
| import { DI } from '@/di-symbols.js'; | ||||
| import { MemoryKVCache, RedisSingleCache } from '@/misc/cache.js'; | ||||
| import { sqlLikeEscape } from '@/misc/sql-like-escape.js'; | ||||
| import type { EmojisRepository, MiRole, MiUser } from '@/models/_.js'; | ||||
| import type { MiEmoji } from '@/models/Emoji.js'; | ||||
| import type { Serialized } from '@/types.js'; | ||||
|  | ||||
| const parseEmojiStrRegexp = /^([-\w]+)(?:@([\w.-]+))?$/; | ||||
|  | ||||
| export const fetchEmojisHostTypes = [ | ||||
| 	'local', | ||||
| 	'remote', | ||||
| 	'all', | ||||
| ] as const; | ||||
| export type FetchEmojisHostTypes = typeof fetchEmojisHostTypes[number]; | ||||
| export const fetchEmojisSortKeys = [ | ||||
| 	'+id', | ||||
| 	'-id', | ||||
| 	'+updatedAt', | ||||
| 	'-updatedAt', | ||||
| 	'+name', | ||||
| 	'-name', | ||||
| 	'+host', | ||||
| 	'-host', | ||||
| 	'+uri', | ||||
| 	'-uri', | ||||
| 	'+publicUrl', | ||||
| 	'-publicUrl', | ||||
| 	'+type', | ||||
| 	'-type', | ||||
| 	'+aliases', | ||||
| 	'-aliases', | ||||
| 	'+category', | ||||
| 	'-category', | ||||
| 	'+license', | ||||
| 	'-license', | ||||
| 	'+isSensitive', | ||||
| 	'-isSensitive', | ||||
| 	'+localOnly', | ||||
| 	'-localOnly', | ||||
| 	'+roleIdsThatCanBeUsedThisEmojiAsReaction', | ||||
| 	'-roleIdsThatCanBeUsedThisEmojiAsReaction', | ||||
| ] as const; | ||||
| export type FetchEmojisSortKeys = typeof fetchEmojisSortKeys[number]; | ||||
|  | ||||
| @Injectable() | ||||
| export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 	private emojisCache: MemoryKVCache<MiEmoji | null>; | ||||
| @@ -30,10 +65,8 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 	constructor( | ||||
| 		@Inject(DI.redis) | ||||
| 		private redisClient: Redis.Redis, | ||||
|  | ||||
| 		@Inject(DI.emojisRepository) | ||||
| 		private emojisRepository: EmojisRepository, | ||||
|  | ||||
| 		private utilityService: UtilityService, | ||||
| 		private idService: IdService, | ||||
| 		private emojiEntityService: EmojiEntityService, | ||||
| @@ -58,7 +91,9 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async add(data: { | ||||
| 		driveFile: MiDriveFile; | ||||
| 		originalUrl: string; | ||||
| 		publicUrl: string; | ||||
| 		fileType: string; | ||||
| 		name: string; | ||||
| 		category: string | null; | ||||
| 		aliases: string[]; | ||||
| @@ -75,9 +110,9 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 			category: data.category, | ||||
| 			host: data.host, | ||||
| 			aliases: data.aliases, | ||||
| 			originalUrl: data.driveFile.url, | ||||
| 			publicUrl: data.driveFile.webpublicUrl ?? data.driveFile.url, | ||||
| 			type: data.driveFile.webpublicType ?? data.driveFile.type, | ||||
| 			originalUrl: data.originalUrl, | ||||
| 			publicUrl: data.publicUrl, | ||||
| 			type: data.fileType, | ||||
| 			license: data.license, | ||||
| 			isSensitive: data.isSensitive, | ||||
| 			localOnly: data.localOnly, | ||||
| @@ -103,19 +138,35 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async update(id: MiEmoji['id'], data: { | ||||
| 		driveFile?: MiDriveFile; | ||||
| 		name?: string; | ||||
| 	public async update(data: ( | ||||
| 		{ id: MiEmoji['id'], name?: string; } | { name: string; id?: MiEmoji['id'], } | ||||
| 		) & { | ||||
| 		originalUrl?: string; | ||||
| 		publicUrl?: string; | ||||
| 		fileType?: string; | ||||
| 		category?: string | null; | ||||
| 		aliases?: string[]; | ||||
| 		license?: string | null; | ||||
| 		isSensitive?: boolean; | ||||
| 		localOnly?: boolean; | ||||
| 		roleIdsThatCanBeUsedThisEmojiAsReaction?: MiRole['id'][]; | ||||
| 	}, moderator?: MiUser): Promise<void> { | ||||
| 		const emoji = await this.emojisRepository.findOneByOrFail({ id: id }); | ||||
| 		const sameNameEmoji = await this.emojisRepository.findOneBy({ name: data.name, host: IsNull() }); | ||||
| 		if (sameNameEmoji != null && sameNameEmoji.id !== id) throw new Error('name already exists'); | ||||
| 	}, moderator?: MiUser): Promise< | ||||
| 		null | ||||
| 		| 'NO_SUCH_EMOJI' | ||||
| 		| 'SAME_NAME_EMOJI_EXISTS' | ||||
| 	> { | ||||
| 		const emoji = data.id | ||||
| 			? await this.getEmojiById(data.id) | ||||
| 			: await this.getEmojiByName(data.name!); | ||||
| 		if (emoji === null) return 'NO_SUCH_EMOJI'; | ||||
| 		const id = emoji.id; | ||||
|  | ||||
| 		// IDと絵文字名が両方指定されている場合は絵文字名の変更を行うため重複チェックが必要 | ||||
| 		const doNameUpdate = data.id && data.name && (data.name !== emoji.name); | ||||
| 		if (doNameUpdate) { | ||||
| 			const isDuplicate = await this.checkDuplicate(data.name!); | ||||
| 			if (isDuplicate) return 'SAME_NAME_EMOJI_EXISTS'; | ||||
| 		} | ||||
|  | ||||
| 		await this.emojisRepository.update(emoji.id, { | ||||
| 			updatedAt: new Date(), | ||||
| @@ -125,9 +176,9 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 			license: data.license, | ||||
| 			isSensitive: data.isSensitive, | ||||
| 			localOnly: data.localOnly, | ||||
| 			originalUrl: data.driveFile != null ? data.driveFile.url : undefined, | ||||
| 			publicUrl: data.driveFile != null ? (data.driveFile.webpublicUrl ?? data.driveFile.url) : undefined, | ||||
| 			type: data.driveFile != null ? (data.driveFile.webpublicType ?? data.driveFile.type) : undefined, | ||||
| 			originalUrl: data.originalUrl, | ||||
| 			publicUrl: data.publicUrl, | ||||
| 			type: data.fileType, | ||||
| 			roleIdsThatCanBeUsedThisEmojiAsReaction: data.roleIdsThatCanBeUsedThisEmojiAsReaction ?? undefined, | ||||
| 		}); | ||||
|  | ||||
| @@ -135,7 +186,7 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
|  | ||||
| 		const packed = await this.emojiEntityService.packDetailed(emoji.id); | ||||
|  | ||||
| 		if (emoji.name === data.name) { | ||||
| 		if (!doNameUpdate) { | ||||
| 			this.globalEventService.publishBroadcastStream('emojiUpdated', { | ||||
| 				emojis: [packed], | ||||
| 			}); | ||||
| @@ -157,6 +208,7 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 				after: updated, | ||||
| 			}); | ||||
| 		} | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| @@ -293,7 +345,7 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
|  | ||||
| 	@bindThis | ||||
| 	private normalizeHost(src: string | undefined, noteUserHost: string | null): string | null { | ||||
| 	// クエリに使うホスト | ||||
| 		// クエリに使うホスト | ||||
| 		let host = src === '.' ? null	// .はローカルホスト (ここがマッチするのはリアクションのみ) | ||||
| 			: src === undefined ? noteUserHost	// ノートなどでホスト省略表記の場合はローカルホスト (ここがリアクションにマッチすることはない) | ||||
| 			: this.utilityService.isSelfHost(src) ? null	// 自ホスト指定 | ||||
| @@ -399,6 +451,151 @@ export class CustomEmojiService implements OnApplicationShutdown { | ||||
| 		return this.emojisRepository.findOneBy({ name, host: IsNull() }); | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async fetchEmojis( | ||||
| 		params?: { | ||||
| 			query?: { | ||||
| 				updatedAtFrom?: string; | ||||
| 				updatedAtTo?: string; | ||||
| 				name?: string; | ||||
| 				host?: string; | ||||
| 				uri?: string; | ||||
| 				publicUrl?: string; | ||||
| 				type?: string; | ||||
| 				aliases?: string; | ||||
| 				category?: string; | ||||
| 				license?: string; | ||||
| 				isSensitive?: boolean; | ||||
| 				localOnly?: boolean; | ||||
| 				hostType?: FetchEmojisHostTypes; | ||||
| 				roleIds?: string[]; | ||||
| 			}, | ||||
| 			sinceId?: string; | ||||
| 			untilId?: string; | ||||
| 		}, | ||||
| 		opts?: { | ||||
| 			limit?: number; | ||||
| 			page?: number; | ||||
| 			sortKeys?: FetchEmojisSortKeys[] | ||||
| 		}, | ||||
| 	) { | ||||
| 		function multipleWordsToQuery(words: string) { | ||||
| 			return words.split(/\s/).filter(x => x.length > 0).map(x => `%${sqlLikeEscape(x)}%`); | ||||
| 		} | ||||
|  | ||||
| 		const builder = this.emojisRepository.createQueryBuilder('emoji'); | ||||
| 		if (params?.query) { | ||||
| 			const q = params.query; | ||||
| 			if (q.updatedAtFrom) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('CAST(emoji.updatedAt AS DATE) >= :updateAtFrom', { updateAtFrom: q.updatedAtFrom }); | ||||
| 			} | ||||
| 			if (q.updatedAtTo) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('CAST(emoji.updatedAt AS DATE) <= :updateAtTo', { updateAtTo: q.updatedAtTo }); | ||||
| 			} | ||||
| 			if (q.name) { | ||||
| 				builder.andWhere('emoji.name ~~ ANY(ARRAY[:...name])', { name: multipleWordsToQuery(q.name) }); | ||||
| 			} | ||||
|  | ||||
| 			switch (true) { | ||||
| 				case q.hostType === 'local': { | ||||
| 					builder.andWhere('emoji.host IS NULL'); | ||||
| 					break; | ||||
| 				} | ||||
| 				case q.hostType === 'remote': { | ||||
| 					if (q.host) { | ||||
| 						// noIndexScan | ||||
| 						builder.andWhere('emoji.host ~~ ANY(ARRAY[:...host])', { host: multipleWordsToQuery(q.host) }); | ||||
| 					} else { | ||||
| 						builder.andWhere('emoji.host IS NOT NULL'); | ||||
| 					} | ||||
| 					break; | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			if (q.uri) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('emoji.uri ~~ ANY(ARRAY[:...uri])', { uri: multipleWordsToQuery(q.uri) }); | ||||
| 			} | ||||
| 			if (q.publicUrl) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('emoji.publicUrl ~~ ANY(ARRAY[:...publicUrl])', { publicUrl: multipleWordsToQuery(q.publicUrl) }); | ||||
| 			} | ||||
| 			if (q.type) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('emoji.type ~~ ANY(ARRAY[:...type])', { type: multipleWordsToQuery(q.type) }); | ||||
| 			} | ||||
| 			if (q.aliases) { | ||||
| 				// noIndexScan | ||||
| 				const subQueryBuilder = builder.subQuery() | ||||
| 					.select('COUNT(0)', 'count') | ||||
| 					.from( | ||||
| 						sq2 => sq2 | ||||
| 							.select('unnest(subEmoji.aliases)', 'alias') | ||||
| 							.addSelect('subEmoji.id', 'id') | ||||
| 							.from('emoji', 'subEmoji'), | ||||
| 						'aliasTable', | ||||
| 					) | ||||
| 					.where('"emoji"."id" = "aliasTable"."id"') | ||||
| 					.andWhere('"aliasTable"."alias" ~~ ANY(ARRAY[:...aliases])', { aliases: multipleWordsToQuery(q.aliases) }); | ||||
|  | ||||
| 				builder.andWhere(`(${subQueryBuilder.getQuery()}) > 0`); | ||||
| 			} | ||||
| 			if (q.category) { | ||||
| 				builder.andWhere('emoji.category ~~ ANY(ARRAY[:...category])', { category: multipleWordsToQuery(q.category) }); | ||||
| 			} | ||||
| 			if (q.license) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('emoji.license ~~ ANY(ARRAY[:...license])', { license: multipleWordsToQuery(q.license) }); | ||||
| 			} | ||||
| 			if (q.isSensitive != null) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('emoji.isSensitive = :isSensitive', { isSensitive: q.isSensitive }); | ||||
| 			} | ||||
| 			if (q.localOnly != null) { | ||||
| 				// noIndexScan | ||||
| 				builder.andWhere('emoji.localOnly = :localOnly', { localOnly: q.localOnly }); | ||||
| 			} | ||||
| 			if (q.roleIds && q.roleIds.length > 0) { | ||||
| 				builder.andWhere('emoji.roleIdsThatCanBeUsedThisEmojiAsReaction && ARRAY[:...roleIds]::VARCHAR[]', { roleIds: q.roleIds }); | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		if (params?.sinceId) { | ||||
| 			builder.andWhere('emoji.id > :sinceId', { sinceId: params.sinceId }); | ||||
| 		} | ||||
| 		if (params?.untilId) { | ||||
| 			builder.andWhere('emoji.id < :untilId', { untilId: params.untilId }); | ||||
| 		} | ||||
|  | ||||
| 		if (opts?.sortKeys && opts.sortKeys.length > 0) { | ||||
| 			for (const sortKey of opts.sortKeys) { | ||||
| 				const direction = sortKey.startsWith('-') ? 'DESC' : 'ASC'; | ||||
| 				const key = sortKey.replace(/^[+-]/, ''); | ||||
| 				builder.addOrderBy(`emoji.${key}`, direction); | ||||
| 			} | ||||
| 		} else { | ||||
| 			builder.addOrderBy('emoji.id', 'DESC'); | ||||
| 		} | ||||
|  | ||||
| 		const limit = opts?.limit ?? 10; | ||||
| 		if (opts?.page) { | ||||
| 			builder.skip((opts.page - 1) * limit); | ||||
| 		} | ||||
|  | ||||
| 		builder.take(limit); | ||||
|  | ||||
| 		const [emojis, count] = await builder.getManyAndCount(); | ||||
|  | ||||
| 		return { | ||||
| 			emojis, | ||||
| 			count: (count > limit ? emojis.length : count), | ||||
| 			allCount: count, | ||||
| 			allPages: Math.ceil(count / limit), | ||||
| 		}; | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public dispose(): void { | ||||
| 		this.emojisCache.dispose(); | ||||
|   | ||||
| @@ -6,7 +6,6 @@ | ||||
| import * as fs from 'node:fs'; | ||||
| import * as stream from 'node:stream/promises'; | ||||
| import { Inject, Injectable } from '@nestjs/common'; | ||||
| import ipaddr from 'ipaddr.js'; | ||||
| import chalk from 'chalk'; | ||||
| import got, * as Got from 'got'; | ||||
| import { parse } from 'content-disposition'; | ||||
| @@ -70,13 +69,6 @@ export class DownloadService { | ||||
| 			}, | ||||
| 			enableUnixSockets: false, | ||||
| 		}).on('response', (res: Got.Response) => { | ||||
| 			if ((process.env.NODE_ENV === 'production' || process.env.NODE_ENV === 'test') && !this.config.proxy && res.ip) { | ||||
| 				if (this.isPrivateIp(res.ip)) { | ||||
| 					this.logger.warn(`Blocked address: ${res.ip}`); | ||||
| 					req.destroy(); | ||||
| 				} | ||||
| 			} | ||||
|  | ||||
| 			const contentLength = res.headers['content-length']; | ||||
| 			if (contentLength != null) { | ||||
| 				const size = Number(contentLength); | ||||
| @@ -139,18 +131,4 @@ export class DownloadService { | ||||
| 			cleanup(); | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	private isPrivateIp(ip: string): boolean { | ||||
| 		const parsedIp = ipaddr.parse(ip); | ||||
|  | ||||
| 		for (const net of this.config.allowedPrivateNetworks ?? []) { | ||||
| 			const cidr = ipaddr.parseCIDR(net); | ||||
| 			if (cidr[0].kind() === parsedIp.kind() && parsedIp.match(ipaddr.parseCIDR(net))) { | ||||
| 				return false; | ||||
| 			} | ||||
| 		} | ||||
|  | ||||
| 		return parsedIp.range() !== 'unicast'; | ||||
| 	} | ||||
| } | ||||
|   | ||||
| @@ -312,6 +312,7 @@ export class EmailService { | ||||
| 					Accept: 'application/json', | ||||
| 					Authorization: truemailAuthKey, | ||||
| 				}, | ||||
| 				isLocalAddressAllowed: true, | ||||
| 			}); | ||||
|  | ||||
| 			const json = (await res.json()) as { | ||||
|   | ||||
| @@ -47,7 +47,7 @@ export class FederatedInstanceService implements OnApplicationShutdown { | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async fetch(host: string): Promise<MiInstance> { | ||||
| 	public async fetchOrRegister(host: string): Promise<MiInstance> { | ||||
| 		host = this.utilityService.toPuny(host); | ||||
|  | ||||
| 		const cached = await this.federatedInstanceCache.get(host); | ||||
| @@ -70,6 +70,24 @@ export class FederatedInstanceService implements OnApplicationShutdown { | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async fetch(host: string): Promise<MiInstance | null> { | ||||
| 		host = this.utilityService.toPuny(host); | ||||
|  | ||||
| 		const cached = await this.federatedInstanceCache.get(host); | ||||
| 		if (cached !== undefined) return cached; | ||||
|  | ||||
| 		const index = await this.instancesRepository.findOneBy({ host }); | ||||
|  | ||||
| 		if (index == null) { | ||||
| 			this.federatedInstanceCache.set(host, null); | ||||
| 			return null; | ||||
| 		} else { | ||||
| 			this.federatedInstanceCache.set(host, index); | ||||
| 			return index; | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
| 	@bindThis | ||||
| 	public async update(id: MiInstance['id'], data: Partial<MiInstance>): Promise<void> { | ||||
| 		const result = await this.instancesRepository.createQueryBuilder().update() | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user