Compare commits
592 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
fd5999378b | ||
![]() |
1894df882b | ||
![]() |
983599bdae | ||
![]() |
8451436cb8 | ||
![]() |
6319dd1bfb | ||
![]() |
d1ea8654e6 | ||
![]() |
37628953c5 | ||
![]() |
13288e1ed8 | ||
![]() |
6d82bbef17 | ||
![]() |
a46e2f2868 | ||
![]() |
6cbc460c19 | ||
![]() |
9cd2b767a9 | ||
![]() |
60b9c467e6 | ||
![]() |
ceabd7c791 | ||
![]() |
0be4e10462 | ||
![]() |
d95fafb5b3 | ||
![]() |
ef485044ea | ||
![]() |
c599a304c8 | ||
![]() |
6d918f195a | ||
![]() |
31a3748a18 | ||
![]() |
48212e7a44 | ||
![]() |
0f7241c2c2 | ||
![]() |
bd903cdbb5 | ||
![]() |
0b038f6477 | ||
![]() |
7e26daa51b | ||
![]() |
225d7701a4 | ||
![]() |
1cae39e281 | ||
![]() |
b635b064ee | ||
![]() |
640fc337af | ||
![]() |
43f2ac56ee | ||
![]() |
d3c7c0ebe3 | ||
![]() |
d15c8afcdf | ||
![]() |
20134a5367 | ||
![]() |
46c0280764 | ||
![]() |
980a99b6c9 | ||
![]() |
c69b72e199 | ||
![]() |
0abe2dfee0 | ||
![]() |
caf0a219a6 | ||
![]() |
4341c4cccc | ||
![]() |
054417354c | ||
![]() |
b9095995eb | ||
![]() |
a60bd33cfc | ||
![]() |
7eedb9b19b | ||
![]() |
e804a299e0 | ||
![]() |
bcf7530eef | ||
![]() |
bed982e705 | ||
![]() |
d9853d9683 | ||
![]() |
fbe4869d1e | ||
![]() |
ac04c46d3b | ||
![]() |
b1bd7307bb | ||
![]() |
8a3f860213 | ||
![]() |
e42e9530cb | ||
![]() |
b65353bc3c | ||
![]() |
83a77f1064 | ||
![]() |
75c087b79f | ||
![]() |
300785923c | ||
![]() |
00982d2742 | ||
![]() |
4f208b99ff | ||
![]() |
fa36b88af4 | ||
![]() |
8223a069fe | ||
![]() |
8de8de7669 | ||
![]() |
705b46b3a0 | ||
![]() |
e46e88344c | ||
![]() |
5c8561c903 | ||
![]() |
5fe2e8a59a | ||
![]() |
c722225c80 | ||
![]() |
584ceb3714 | ||
![]() |
902bed4db3 | ||
![]() |
e617ced1d3 | ||
![]() |
22464c434e | ||
![]() |
f33ded3107 | ||
![]() |
a82ff360c6 | ||
![]() |
14fa8b177d | ||
![]() |
e46bb2f948 | ||
![]() |
3eef0a65c2 | ||
![]() |
bcd188a0e0 | ||
![]() |
f38b6a1806 | ||
![]() |
4cc2a561d5 | ||
![]() |
f3e29c4f6a | ||
![]() |
2fc58a780e | ||
![]() |
561b0fc10e | ||
![]() |
b8f42fca56 | ||
![]() |
e8005c8d3a | ||
![]() |
335e4bd213 | ||
![]() |
0d21083c9a | ||
![]() |
698e0d08a1 | ||
![]() |
8e0108a0b8 | ||
![]() |
d9775c147f | ||
![]() |
b4ebf254c8 | ||
![]() |
dec7c4f722 | ||
![]() |
aaba43e754 | ||
![]() |
9604ad3dc1 | ||
![]() |
8e04bd12cf | ||
![]() |
270df5c5b0 | ||
![]() |
f5bea67515 | ||
![]() |
1ec4156b49 | ||
![]() |
5e33ca3da0 | ||
![]() |
b9a57715e8 | ||
![]() |
99640a35a3 | ||
![]() |
24681bbe10 | ||
![]() |
88cdbc2ad6 | ||
![]() |
a0c6ae2cba | ||
![]() |
9a51ae5def | ||
![]() |
f7c21868fe | ||
![]() |
5d968afa74 | ||
![]() |
b6e3f1c490 | ||
![]() |
cb4d65b5c9 | ||
![]() |
a902576334 | ||
![]() |
1c6463e66f | ||
![]() |
1cf5198372 | ||
![]() |
a9a5673069 | ||
![]() |
9d67857a34 | ||
![]() |
25fde3b5eb | ||
![]() |
0e3ca41b3c | ||
![]() |
318759cfa4 | ||
![]() |
73b5c12927 | ||
![]() |
c850cef711 | ||
![]() |
12fad68f58 | ||
![]() |
037db7c5ef | ||
![]() |
ea9aeef9d8 | ||
![]() |
63415f1074 | ||
![]() |
dded3912f8 | ||
![]() |
d35f0247a2 | ||
![]() |
76a7b5f067 | ||
![]() |
c864d700d2 | ||
![]() |
50e1040f1e | ||
![]() |
8a40026c5c | ||
![]() |
974250da6c | ||
![]() |
7042933b3b | ||
![]() |
8b7f5be878 | ||
![]() |
01afdc410e | ||
![]() |
db10103d8e | ||
![]() |
7f5299cf46 | ||
![]() |
ac7f04e669 | ||
![]() |
65740da979 | ||
![]() |
2795fe4579 | ||
![]() |
4ab773eb92 | ||
![]() |
66b512af5d | ||
![]() |
0f9a6417b0 | ||
![]() |
6a9e52d83c | ||
![]() |
1161d6cae2 | ||
![]() |
187696c973 | ||
![]() |
4b7b51d5cc | ||
![]() |
0e3213ff6d | ||
![]() |
9b092e918a | ||
![]() |
cfa38e875c | ||
![]() |
9ea7d75aa4 | ||
![]() |
165d272552 | ||
![]() |
9b876b30b2 | ||
![]() |
5e82064a7d | ||
![]() |
90fade8e72 | ||
![]() |
c038892795 | ||
![]() |
926eb34680 | ||
![]() |
e6e33faefb | ||
![]() |
0a2e046b28 | ||
![]() |
36a632dc02 | ||
![]() |
c9ce150fe8 | ||
![]() |
6496835515 | ||
![]() |
b404ce463f | ||
![]() |
b875b0faa2 | ||
![]() |
4786214e2a | ||
![]() |
0484976afa | ||
![]() |
19cc9f7fb0 | ||
![]() |
7706c38d3d | ||
![]() |
9acc36185b | ||
![]() |
be89516707 | ||
![]() |
e5acd1afb9 | ||
![]() |
f6e7f389d6 | ||
![]() |
b9eaf906e7 | ||
![]() |
84df0714d8 | ||
![]() |
c7650846a2 | ||
![]() |
ea97d6a028 | ||
![]() |
0e4a111f81 | ||
![]() |
037837b551 | ||
![]() |
c5eb3021c0 | ||
![]() |
3b8b03d8b4 | ||
![]() |
1afe46b19a | ||
![]() |
fe281f1786 | ||
![]() |
24ef4d3da2 | ||
![]() |
68192126e6 | ||
![]() |
a28c515ef6 | ||
![]() |
07526ada45 | ||
![]() |
71d9c2a53d | ||
![]() |
c0144db75c | ||
![]() |
5e8c95bde8 | ||
![]() |
8630542146 | ||
![]() |
a674657bcb | ||
![]() |
c625a3fa5b | ||
![]() |
ae6f0d49c2 | ||
![]() |
575a8bd9c8 | ||
![]() |
3db7551ad3 | ||
![]() |
37b535df30 | ||
![]() |
f30df92597 | ||
![]() |
9b18104343 | ||
![]() |
e2862ed097 | ||
![]() |
1c38c7010d | ||
![]() |
34ea3cf226 | ||
![]() |
54631026de | ||
![]() |
944250f7fd | ||
![]() |
ab0253ab07 | ||
![]() |
758e054c92 | ||
![]() |
187b44c7f3 | ||
![]() |
587ea5b424 | ||
![]() |
1a883f4f05 | ||
![]() |
540e6e4f99 | ||
![]() |
baf3d8f3ee | ||
![]() |
7a66c9b5f3 | ||
![]() |
15cd563612 | ||
![]() |
e2556189de | ||
![]() |
9236a8fd6c | ||
![]() |
303c5abfb4 | ||
![]() |
fc65190ef7 | ||
![]() |
f47a564819 | ||
![]() |
fa0814f939 | ||
![]() |
ddd931a0a3 | ||
![]() |
46010187c3 | ||
![]() |
877bd52ed7 | ||
![]() |
d964c5f27f | ||
![]() |
d35b02fa23 | ||
![]() |
21ece52a9f | ||
![]() |
c2ae160d23 | ||
![]() |
9c74c5c5dc | ||
![]() |
2e80cebc11 | ||
![]() |
80783199a9 | ||
![]() |
f418eaecf9 | ||
![]() |
901436a095 | ||
![]() |
6d557269c1 | ||
![]() |
a905188e95 | ||
![]() |
a21070c01b | ||
![]() |
5d0ee544f4 | ||
![]() |
e52a9e0a65 | ||
![]() |
67bf6ff3ce | ||
![]() |
000bee6327 | ||
![]() |
19a232cad7 | ||
![]() |
a744f75eb9 | ||
![]() |
5cf07fc50f | ||
![]() |
1143606bc8 | ||
![]() |
09f4885f89 | ||
![]() |
dfd92efa89 | ||
![]() |
c3fcfad910 | ||
![]() |
652588abed | ||
![]() |
2b4d5b73b9 | ||
![]() |
c08d959b59 | ||
![]() |
7783c1e0e1 | ||
![]() |
6afa67089a | ||
![]() |
26928ab407 | ||
![]() |
4f04421cb3 | ||
![]() |
4d1c723496 | ||
![]() |
ae5d537197 | ||
![]() |
2d21685d22 | ||
![]() |
d4c0d85cbc | ||
![]() |
26b268588f | ||
![]() |
781b57585b | ||
![]() |
a0b036a119 | ||
![]() |
c6afc61c94 | ||
![]() |
a1af83c0ab | ||
![]() |
4168addbb2 | ||
![]() |
600394458c | ||
![]() |
f33785a09c | ||
![]() |
d0d5068f72 | ||
![]() |
d70b8275b4 | ||
![]() |
7253f83ca3 | ||
![]() |
6171f27f8d | ||
![]() |
96b5684fa0 | ||
![]() |
4df409f77b | ||
![]() |
0f122884cc | ||
![]() |
f29c9fe22c | ||
![]() |
93230815f5 | ||
![]() |
632af91878 | ||
![]() |
81a0ee4b2d | ||
![]() |
967c655de0 | ||
![]() |
4bb19b9596 | ||
![]() |
d43b17519e | ||
![]() |
76a881df39 | ||
![]() |
f84ad3e1ea | ||
![]() |
9d11c29c3b | ||
![]() |
90b62a3e95 | ||
![]() |
4e4c559db6 | ||
![]() |
e7660bc8db | ||
![]() |
cfcc626de2 | ||
![]() |
b7a5602003 | ||
![]() |
b3a4d1795b | ||
![]() |
23de94785d | ||
![]() |
69b56f6658 | ||
![]() |
5ca6e6b5df | ||
![]() |
98c26dfff8 | ||
![]() |
a4e3136611 | ||
![]() |
ea8e6d88ab | ||
![]() |
202cb38c40 | ||
![]() |
d3c7ddd2f4 | ||
![]() |
bc19cd77ad | ||
![]() |
0005de6a98 | ||
![]() |
386d3cd997 | ||
![]() |
2d196b6779 | ||
![]() |
0cc055de3a | ||
![]() |
a96e5277db | ||
![]() |
7413634734 | ||
![]() |
1bfb176667 | ||
![]() |
4a90c7aef8 | ||
![]() |
b0992de59d | ||
![]() |
37e666817f | ||
![]() |
a607149b19 | ||
![]() |
3a11dba24f | ||
![]() |
c76a384b41 | ||
![]() |
dec69cc67b | ||
![]() |
0c21ae226b | ||
![]() |
835aad44bb | ||
![]() |
8a1f3a4c0b | ||
![]() |
8b646822fc | ||
![]() |
6d3e2b9386 | ||
![]() |
73cdf5ca81 | ||
![]() |
133936652d | ||
![]() |
66470b4937 | ||
![]() |
3f688a728b | ||
![]() |
0d306e9d41 | ||
![]() |
1e8132e610 | ||
![]() |
d672fccef4 | ||
![]() |
c194eddb1b | ||
![]() |
4ba4062519 | ||
![]() |
23753ec75a | ||
![]() |
d184f73160 | ||
![]() |
482081c41b | ||
![]() |
03b04acb16 | ||
![]() |
345a9d3525 | ||
![]() |
aee816ced9 | ||
![]() |
1e28081aa3 | ||
![]() |
ff0521e3aa | ||
![]() |
8cabc5953e | ||
![]() |
4a766a19cf | ||
![]() |
bd8052fedb | ||
![]() |
5fb4538315 | ||
![]() |
e78f16bcc4 | ||
![]() |
fe62f3508b | ||
![]() |
c11c22fc73 | ||
![]() |
056ab675cf | ||
![]() |
f00d543447 | ||
![]() |
72b616a990 | ||
![]() |
8ee4b180f9 | ||
![]() |
46e4b07a87 | ||
![]() |
3ec6101b16 | ||
![]() |
955b3e313b | ||
![]() |
3dc70f9878 | ||
![]() |
8e2be5e9a7 | ||
![]() |
46f3736f44 | ||
![]() |
dc12b189de | ||
![]() |
3f95bd53cd | ||
![]() |
23de45cea5 | ||
![]() |
ba6959b8c1 | ||
![]() |
91c9a6390c | ||
![]() |
a99478e2ea | ||
![]() |
12635da473 | ||
![]() |
36170c816a | ||
![]() |
50bad84747 | ||
![]() |
abd3efa318 | ||
![]() |
816493e01f | ||
![]() |
a0c9fd75d7 | ||
![]() |
94bf7101f8 | ||
![]() |
46424f63f2 | ||
![]() |
c33e93c662 | ||
![]() |
49b43eb3c8 | ||
![]() |
6b22b7a31f | ||
![]() |
b77167a4a1 | ||
![]() |
79a591d72d | ||
![]() |
8006e7a34d | ||
![]() |
abc45ded9b | ||
![]() |
ec05c07321 | ||
![]() |
27c056cbbf | ||
![]() |
b3779875d0 | ||
![]() |
748a451e23 | ||
![]() |
8b1999dc5b | ||
![]() |
a38e4b0b14 | ||
![]() |
129f652dc2 | ||
![]() |
5bf69476f6 | ||
![]() |
597c9761cb | ||
![]() |
b875cc9949 | ||
![]() |
e568c3888f | ||
![]() |
67875e2afa | ||
![]() |
dd17065129 | ||
![]() |
8d05ef3058 | ||
![]() |
66369b4b1d | ||
![]() |
9a33495694 | ||
![]() |
f0b2eaf70d | ||
![]() |
ef67f3eee6 | ||
![]() |
9cab659392 | ||
![]() |
dcd216daff | ||
![]() |
8f673d80d4 | ||
![]() |
3e81ebf8e9 | ||
![]() |
19d531922d | ||
![]() |
9109ae02a7 | ||
![]() |
8d3fe0c5c2 | ||
![]() |
f9185f201a | ||
![]() |
027380c013 | ||
![]() |
a73a787753 | ||
![]() |
bd9df789d1 | ||
![]() |
4fd4132f5e | ||
![]() |
68aa1312f5 | ||
![]() |
7974dbf477 | ||
![]() |
834fb3bebd | ||
![]() |
18fa317ee7 | ||
![]() |
414f1d1158 | ||
![]() |
c5e5a9b8ef | ||
![]() |
1ac1a968b9 | ||
![]() |
0d3a36e519 | ||
![]() |
ebce02c253 | ||
![]() |
78b400e8b0 | ||
![]() |
8d93f148be | ||
![]() |
4b8a2d2a6b | ||
![]() |
5fd549656b | ||
![]() |
a70dbb7e74 | ||
![]() |
a75f3fb87c | ||
![]() |
67e2768c3e | ||
![]() |
ece3ac967d | ||
![]() |
da71d8f4af | ||
![]() |
ac93af8eb5 | ||
![]() |
76cdbe74ba | ||
![]() |
ce4ea5071f | ||
![]() |
8a558eed36 | ||
![]() |
ce32cd576b | ||
![]() |
338793d891 | ||
![]() |
78ac41a613 | ||
![]() |
be23ccf23b | ||
![]() |
1ba5e433e5 | ||
![]() |
5bf4f569e4 | ||
![]() |
5a11844eff | ||
![]() |
14795b68f2 | ||
![]() |
bea42f5804 | ||
![]() |
fbbce302bc | ||
![]() |
4b9c605477 | ||
![]() |
a499ad6879 | ||
![]() |
76c5dc8999 | ||
![]() |
b985e14b13 | ||
![]() |
61de9cdbd4 | ||
![]() |
9208825975 | ||
![]() |
72a49f334a | ||
![]() |
b35ca3b739 | ||
![]() |
85950f17fa | ||
![]() |
78f95b5910 | ||
![]() |
909a09a0c0 | ||
![]() |
bb9fc56cc1 | ||
![]() |
9f3b4ccd14 | ||
![]() |
90bf976fe2 | ||
![]() |
388de9dc96 | ||
![]() |
8a0a46b1c9 | ||
![]() |
186163ec3f | ||
![]() |
91171c559a | ||
![]() |
36b483d04d | ||
![]() |
54e0a7f8a8 | ||
![]() |
6d4e96dea2 | ||
![]() |
a6958da091 | ||
![]() |
502bde5567 | ||
![]() |
d5702f9d51 | ||
![]() |
5141afe476 | ||
![]() |
4422219be7 | ||
![]() |
4b2afec108 | ||
![]() |
07bb8067ae | ||
![]() |
4f63eb0c7e | ||
![]() |
4ea7b2dd63 | ||
![]() |
e8189f7c69 | ||
![]() |
23c054caec | ||
![]() |
a084c8b344 | ||
![]() |
361069314f | ||
![]() |
d252514a39 | ||
![]() |
31d1edc0fb | ||
![]() |
987474726c | ||
![]() |
4beea63d3f | ||
![]() |
53f3b779bf | ||
![]() |
f59f424795 | ||
![]() |
c63ba5470a | ||
![]() |
935d6473ed | ||
![]() |
0faa4470fb | ||
![]() |
0281bdd90c | ||
![]() |
608ff73907 | ||
![]() |
c82ce9233b | ||
![]() |
cc75620976 | ||
![]() |
1cd8bfaded | ||
![]() |
65d9c304df | ||
![]() |
4b48ba4e8c | ||
![]() |
bf7bacceab | ||
![]() |
a56f461895 | ||
![]() |
e21ff916b0 | ||
![]() |
da20675ada | ||
![]() |
7364fb84ef | ||
![]() |
48f46333f8 | ||
![]() |
8407702b38 | ||
![]() |
e1a8b158e0 | ||
![]() |
7e30910ab8 | ||
![]() |
7fbee704ec | ||
![]() |
b1f94c7bc6 | ||
![]() |
90411967d6 | ||
![]() |
5719c623a4 | ||
![]() |
e210ec782a | ||
![]() |
229780f6ff | ||
![]() |
6490a9829b | ||
![]() |
6384d0708d | ||
![]() |
db1fde2956 | ||
![]() |
c86720a331 | ||
![]() |
2af158be26 | ||
![]() |
7115bd46ff | ||
![]() |
f84483896e | ||
![]() |
fe7bc174fb | ||
![]() |
e967d9ded3 | ||
![]() |
c3b55b6849 | ||
![]() |
3e193c9864 | ||
![]() |
d64e25e449 | ||
![]() |
c4707c612d | ||
![]() |
9d3448c880 | ||
![]() |
dad6a77645 | ||
![]() |
f64d3942d7 | ||
![]() |
45fe754759 | ||
![]() |
98f1d93628 | ||
![]() |
8785e1c3a4 | ||
![]() |
f00ceedae4 | ||
![]() |
7387e010c2 | ||
![]() |
a59dfff12f | ||
![]() |
f6128dd3ff | ||
![]() |
eeff88ece2 | ||
![]() |
bae1282f74 | ||
![]() |
d2007add75 | ||
![]() |
802db92d98 | ||
![]() |
a53e1e4ec3 | ||
![]() |
fd1ef4a62d | ||
![]() |
8ab9068d8e | ||
![]() |
47dd30d3b2 | ||
![]() |
fcdd042b02 | ||
![]() |
04855f9201 | ||
![]() |
cf0a5d5735 | ||
![]() |
bb2db1cf76 | ||
![]() |
0e69091455 | ||
![]() |
3cb5ed167a | ||
![]() |
1ffee15b83 | ||
![]() |
75b9f31acf | ||
![]() |
fc56b12690 | ||
![]() |
60e768436e | ||
![]() |
84f2192cde | ||
![]() |
97f2675d40 | ||
![]() |
6d881d4570 | ||
![]() |
42cc93dd0f | ||
![]() |
e9f34a0f09 | ||
![]() |
b9cb6d1c10 | ||
![]() |
7bf517e990 | ||
![]() |
ab54e147f2 | ||
![]() |
e677540fd6 | ||
![]() |
31e3aaeda0 | ||
![]() |
938fc317c9 | ||
![]() |
4c431c5432 | ||
![]() |
881b914c6a | ||
![]() |
df67836c1a | ||
![]() |
6a3a8ba4d0 | ||
![]() |
9e535c341e | ||
![]() |
17fa4ba804 | ||
![]() |
dd9a3c91fc | ||
![]() |
7015df37e3 | ||
![]() |
7ebdd4739a | ||
![]() |
c4bcb31a00 | ||
![]() |
0a18ee24ac | ||
![]() |
37d10b108e | ||
![]() |
b5cadeca2e | ||
![]() |
c8e93054bc | ||
![]() |
def32107af | ||
![]() |
1b84ae9f3f | ||
![]() |
73ce1f61a8 | ||
![]() |
8661cd1ee7 | ||
![]() |
53f55defda | ||
![]() |
d60dc60bc9 | ||
![]() |
bf1d7e6252 | ||
![]() |
c96b2767b9 | ||
![]() |
6c1f03eefd | ||
![]() |
cced83024b | ||
![]() |
1cd6ba3c1d | ||
![]() |
2365761ba5 | ||
![]() |
d3b4b70bfc | ||
![]() |
f95d5701a2 | ||
![]() |
a8c56afd0f | ||
![]() |
4de30aa47e | ||
![]() |
f05f7c920e | ||
![]() |
5f86509abc | ||
![]() |
1561391293 | ||
![]() |
60553a8a5e | ||
![]() |
e656074de4 | ||
![]() |
b81ff340b1 | ||
![]() |
77456ae0bc | ||
![]() |
9fd0e90850 | ||
![]() |
ab01cf1881 | ||
![]() |
0d10ca02db | ||
![]() |
0627df8116 | ||
![]() |
c88ea7150c | ||
![]() |
555954c71e | ||
![]() |
f231f02329 | ||
![]() |
b8af5dfde0 | ||
![]() |
ef3710fdc2 | ||
![]() |
bde114ad13 | ||
![]() |
9d138aa282 |
13
.babelrc
13
.babelrc
@@ -1,13 +0,0 @@
|
|||||||
{
|
|
||||||
"plugins": [
|
|
||||||
[
|
|
||||||
"@babel/plugin-transform-runtime",
|
|
||||||
{
|
|
||||||
"corejs": {
|
|
||||||
"version": 3,
|
|
||||||
"proposals": true
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
]
|
|
||||||
}
|
|
@@ -1,49 +0,0 @@
|
|||||||
version: 2.1
|
|
||||||
|
|
||||||
executors:
|
|
||||||
docker:
|
|
||||||
working_directory: /tmp/workspace
|
|
||||||
docker:
|
|
||||||
- image: docker:latest
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
docker:
|
|
||||||
parameters:
|
|
||||||
with_deploy:
|
|
||||||
type: boolean
|
|
||||||
default: false
|
|
||||||
executor: docker
|
|
||||||
steps:
|
|
||||||
- checkout
|
|
||||||
- setup_remote_docker:
|
|
||||||
version: 19.03.13
|
|
||||||
- run:
|
|
||||||
name: Build
|
|
||||||
command: |
|
|
||||||
docker build -t misskey/misskey .
|
|
||||||
- when:
|
|
||||||
condition: <<parameters.with_deploy>>
|
|
||||||
steps:
|
|
||||||
- run:
|
|
||||||
name: Deploy
|
|
||||||
command: |
|
|
||||||
if [ "$DOCKERHUB_USERNAME$DOCKERHUB_PASSWORD" ]
|
|
||||||
then
|
|
||||||
apk update && apk add jq
|
|
||||||
docker tag misskey/misskey misskey/misskey:$(cat package.json | jq -r .version)
|
|
||||||
docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_PASSWORD
|
|
||||||
docker push -a misskey/misskey
|
|
||||||
else
|
|
||||||
echo -e '\033[0;33mAborted deploying to Docker Hub\033[0;39m'
|
|
||||||
fi
|
|
||||||
|
|
||||||
workflows:
|
|
||||||
version: 2
|
|
||||||
docker:
|
|
||||||
jobs:
|
|
||||||
- docker:
|
|
||||||
name: auto-build
|
|
||||||
with_deploy: true
|
|
||||||
filters:
|
|
||||||
branches:
|
|
||||||
only: master
|
|
@@ -1,12 +0,0 @@
|
|||||||
url: 'http://misskey.local'
|
|
||||||
port: 8080
|
|
||||||
db:
|
|
||||||
host: localhost
|
|
||||||
port: 5432
|
|
||||||
db: test-misskey
|
|
||||||
user: postgres
|
|
||||||
pass: ''
|
|
||||||
redis:
|
|
||||||
host: localhost
|
|
||||||
port: 6379
|
|
||||||
id: aid
|
|
@@ -1,12 +0,0 @@
|
|||||||
url: 'http://misskey.local'
|
|
||||||
port: 8080
|
|
||||||
db:
|
|
||||||
host: localhost
|
|
||||||
port: 5432
|
|
||||||
db: test-misskey
|
|
||||||
user: postgres
|
|
||||||
pass: ''
|
|
||||||
redis:
|
|
||||||
host: localhost
|
|
||||||
port: 6379
|
|
||||||
id: aid
|
|
@@ -157,3 +157,10 @@ id: 'aid'
|
|||||||
|
|
||||||
# Sign to ActivityPub GET request (default: false)
|
# Sign to ActivityPub GET request (default: false)
|
||||||
#signToActivityPubGet: true
|
#signToActivityPubGet: true
|
||||||
|
|
||||||
|
#allowedPrivateNetworks: [
|
||||||
|
# '127.0.0.1/32'
|
||||||
|
#]
|
||||||
|
|
||||||
|
# Upload or download file size limits (bytes)
|
||||||
|
#maxFileSize: 262144000
|
||||||
|
@@ -1,8 +1,8 @@
|
|||||||
.autogen
|
.autogen
|
||||||
.git
|
|
||||||
.github
|
.github
|
||||||
.travis
|
.travis
|
||||||
.vscode
|
.vscode
|
||||||
|
.config
|
||||||
Dockerfile
|
Dockerfile
|
||||||
build/
|
build/
|
||||||
built/
|
built/
|
||||||
@@ -12,3 +12,4 @@ elasticsearch/
|
|||||||
node_modules/
|
node_modules/
|
||||||
redis/
|
redis/
|
||||||
files/
|
files/
|
||||||
|
misskey-assets/
|
||||||
|
13
.eslintrc
13
.eslintrc
@@ -1,13 +0,0 @@
|
|||||||
{
|
|
||||||
"parserOptions": {
|
|
||||||
"parser": "@typescript-eslint/parser"
|
|
||||||
},
|
|
||||||
"extends": [
|
|
||||||
"eslint:recommended"
|
|
||||||
],
|
|
||||||
"rules": {
|
|
||||||
"no-console": 0,
|
|
||||||
"no-unused-vars": 0,
|
|
||||||
"no-empty": 0
|
|
||||||
}
|
|
||||||
}
|
|
38
.github/CODEOWNERS
vendored
38
.github/CODEOWNERS
vendored
@@ -1,38 +0,0 @@
|
|||||||
# PATH OWNERS
|
|
||||||
/.autogen/ @acid-chicken
|
|
||||||
/.circleci/ @syuilo @acid-chicken
|
|
||||||
/.config/ @syuilo @AyaMorisawa @mei23 @acid-chicken @rinsuki
|
|
||||||
# /.config/mongo_initdb_example.js @khws4v1
|
|
||||||
/.github/ @syuilo @AyaMorisawa @acid-chicken
|
|
||||||
/.vscode/ @acid-chicken
|
|
||||||
/assets/ @syuilo # @tamaina
|
|
||||||
/docs/ @syuilo
|
|
||||||
/docs/*.en.md @AyaMorisawa # @skid9000
|
|
||||||
# /docs/*.fr.md @BoFFire
|
|
||||||
# /docs/docker.*.md @khws4v1
|
|
||||||
/locales/ @syuilo
|
|
||||||
/src/ @syuilo @AyaMorisawa @mei23 @acid-chicken @rinsuki
|
|
||||||
# /src/crypto_key.cc @akihikodaki
|
|
||||||
# /src/crypto_key.d.ts @akihikodaki
|
|
||||||
/.dockerignore @syuilo # @khws4v1
|
|
||||||
/.editorconfig @syuilo @AyaMorisawa
|
|
||||||
/.eslintrc @syuilo
|
|
||||||
/.gitattributes @syuilo
|
|
||||||
/.gitignore @syuilo
|
|
||||||
/.npmrc @syuilo
|
|
||||||
/.vsls.json @AyaMorisawa
|
|
||||||
/CHANGELOG.md @syuilo
|
|
||||||
/CODE_OF_CONDUCT.md @syuilo
|
|
||||||
/CONTRIBUTING.md @syuilo
|
|
||||||
/Dockerfile @syuilo @AyaMorisawa @acid-chicken # @khws4v1
|
|
||||||
/LICENSE @syuilo
|
|
||||||
/README.md @syuilo @AyaMorisawa @acid-chicken # @nikhiljha
|
|
||||||
# /binding.gyp @akihikodaki
|
|
||||||
/crowdin.yml @syuilo
|
|
||||||
# /docker-compose.yml @khws4v1
|
|
||||||
/gulpfile.ts @syuilo @AyaMorisawa
|
|
||||||
/jsconfig.json @syuilo @AyaMorisawa
|
|
||||||
/package.json @syuilo @AyaMorisawa
|
|
||||||
/tsconfig.json @syuilo @AyaMorisawa
|
|
||||||
/tslint.json @syuilo @AyaMorisawa
|
|
||||||
/webpack.config.ts @syuilo @AyaMorisawa
|
|
7
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
7
.github/ISSUE_TEMPLATE/config.yml
vendored
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
contact_links:
|
||||||
|
- name: 👪 Misskey Forum
|
||||||
|
url: https://forum.misskey.io/
|
||||||
|
about: Ask questions and share knowledge
|
||||||
|
- name: 💬 Misskey official Discord
|
||||||
|
url: https://discord.gg/Wp8gVStHW3
|
||||||
|
about: Chat freely about Misskey
|
20
.github/PULL_REQUEST_TEMPLATE.md
vendored
20
.github/PULL_REQUEST_TEMPLATE.md
vendored
@@ -1,22 +1,10 @@
|
|||||||
<!-- ℹ お読みください
|
<!-- ℹ お読みください
|
||||||
PRありがとうございます! PRを作成する前に、以下をご確認ください:
|
PRありがとうございます! PRを作成する前に、コントリビューションガイドをご確認ください:
|
||||||
可能であればタイトルに、以下で示すようなPRの種類が分かるキーワードをプリフィクスしてください。
|
https://github.com/misskey-dev/misskey/blob/develop/CONTRIBUTING.md
|
||||||
fix / refactor / feat / enhance / perf / chore
|
|
||||||
また、PRの粒度が適切であることを確認してください。ひとつのPRに複数の種類の変更や関心を含めることは避けてください。
|
|
||||||
このPRによって解決されるIssueがある場合は、そのIssue IDを本文内に記入してください。
|
|
||||||
CHANGELOG.mdに変更点を追記してください。リファクタリングなど、利用者に影響を与えない変更についてはこの限りではありません。
|
|
||||||
機能追加やバグ修正をした場合は、可能であればテストケースを追加してください。
|
|
||||||
ご協力ありがとうございます🤗
|
|
||||||
-->
|
-->
|
||||||
<!-- ℹ README
|
<!-- ℹ README
|
||||||
Thank you for your PR! Before creating a PR, please check the following:
|
Thank you for your PR! Before creating a PR, please check the contribution guide:
|
||||||
If possible, prefix the title with a keyword that identifies the type of this PR, as shown below.
|
https://github.com/misskey-dev/misskey/blob/develop/docs/CONTRIBUTING.en.md
|
||||||
fix / refactor / feat / enhance / perf / chore
|
|
||||||
Also, make sure that the granularity of this PR is appropriate. Please do not include more than one type of change or interest in a single PR.
|
|
||||||
If there is an issue to be resolved by this PR, please include the Issue ID in the text.
|
|
||||||
Please add the summary of the changes to CHANGELOG.md. However, this is not necessary for changes that do not affect the users, such as refactoring.
|
|
||||||
If you have added a feature or fixed a bug, please add a test case if possible.
|
|
||||||
Thanks for your cooperation 🤗
|
|
||||||
-->
|
-->
|
||||||
|
|
||||||
# What
|
# What
|
||||||
|
11
.github/dependabot.yml
vendored
Normal file
11
.github/dependabot.yml
vendored
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# To get started with Dependabot version updates, you'll need to specify which
|
||||||
|
# package ecosystems to update and where the package manifests are located.
|
||||||
|
# Please see the documentation for all configuration options:
|
||||||
|
# https://help.github.com/github/administering-a-repository/configuration-options-for-dependency-updates
|
||||||
|
|
||||||
|
version: 2
|
||||||
|
updates:
|
||||||
|
- package-ecosystem: "npm" # See documentation for possible values
|
||||||
|
directory: "/" # Location of package manifests
|
||||||
|
schedule:
|
||||||
|
interval: "daily"
|
15
.github/misskey/test.yml
vendored
Normal file
15
.github/misskey/test.yml
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
url: 'http://misskey.local'
|
||||||
|
|
||||||
|
# ローカルでテストするときにポートを被らないようにするためデフォルトのものとは変える(以下同じ)
|
||||||
|
port: 61812
|
||||||
|
|
||||||
|
db:
|
||||||
|
host: localhost
|
||||||
|
port: 54312
|
||||||
|
db: test-misskey
|
||||||
|
user: postgres
|
||||||
|
pass: ''
|
||||||
|
redis:
|
||||||
|
host: localhost
|
||||||
|
port: 56312
|
||||||
|
id: aid
|
33
.github/workflows/docker-develop.yml
vendored
Normal file
33
.github/workflows/docker-develop.yml
vendored
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
name: Publish Docker image (develop)
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- develop
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
push_to_registry:
|
||||||
|
name: Push Docker image to Docker Hub
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Check out the repo
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Docker meta
|
||||||
|
id: meta
|
||||||
|
uses: docker/metadata-action@v3
|
||||||
|
with:
|
||||||
|
images: misskey/misskey
|
||||||
|
- name: Log in to Docker Hub
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
- name: Build and Push to Docker Hub
|
||||||
|
uses: docker/build-push-action@v2
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
tags: misskey/misskey:develop
|
||||||
|
labels: develop
|
32
.github/workflows/docker.yml
vendored
Normal file
32
.github/workflows/docker.yml
vendored
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
name: Publish Docker image
|
||||||
|
|
||||||
|
on:
|
||||||
|
release:
|
||||||
|
types: [published]
|
||||||
|
workflow_dispatch:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
push_to_registry:
|
||||||
|
name: Push Docker image to Docker Hub
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- name: Check out the repo
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
- name: Docker meta
|
||||||
|
id: meta
|
||||||
|
uses: docker/metadata-action@v3
|
||||||
|
with:
|
||||||
|
images: misskey/misskey
|
||||||
|
- name: Log in to Docker Hub
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKER_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKER_PASSWORD }}
|
||||||
|
- name: Build and Push to Docker Hub
|
||||||
|
uses: docker/build-push-action@v2
|
||||||
|
with:
|
||||||
|
context: .
|
||||||
|
push: true
|
||||||
|
tags: ${{ steps.meta.outputs.tags }}
|
||||||
|
labels: ${{ steps.meta.outputs.labels }}
|
25
.github/workflows/lint.yml
vendored
Normal file
25
.github/workflows/lint.yml
vendored
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
name: Lint
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- develop
|
||||||
|
pull_request:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
lint:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- uses: actions/setup-node@v1
|
||||||
|
with:
|
||||||
|
node-version: 12.x
|
||||||
|
- uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
path: '**/node_modules'
|
||||||
|
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
|
||||||
|
- run: yarn install
|
||||||
|
- run: yarn lint
|
53
.github/workflows/nodejs.yml
vendored
53
.github/workflows/nodejs.yml
vendored
@@ -1,53 +0,0 @@
|
|||||||
name: Node.js CI
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- develop
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build_and_test:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
strategy:
|
|
||||||
matrix:
|
|
||||||
node-version: [14.x, 16.x]
|
|
||||||
|
|
||||||
services:
|
|
||||||
postgres:
|
|
||||||
image: postgres:10-alpine
|
|
||||||
ports:
|
|
||||||
- 5432:5432
|
|
||||||
env:
|
|
||||||
POSTGRES_DB: test-misskey
|
|
||||||
POSTGRES_HOST_AUTH_METHOD: trust
|
|
||||||
redis:
|
|
||||||
image: redis:alpine
|
|
||||||
ports:
|
|
||||||
- 6379:6379
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- name: Use Node.js ${{ matrix.node-version }}
|
|
||||||
uses: actions/setup-node@v1
|
|
||||||
with:
|
|
||||||
node-version: ${{ matrix.node-version }}
|
|
||||||
- name: Install dependencies
|
|
||||||
run: yarn install
|
|
||||||
- name: Copy Configure
|
|
||||||
run: cp .circleci/misskey/*.yml .config
|
|
||||||
- name: Build
|
|
||||||
run: yarn build
|
|
||||||
- name: Test
|
|
||||||
run: yarn test
|
|
||||||
|
|
||||||
lint:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v2
|
|
||||||
- uses: actions/setup-node@v1
|
|
||||||
with:
|
|
||||||
node-version: 12.x
|
|
||||||
- run: yarn install
|
|
||||||
- run: yarn lint
|
|
91
.github/workflows/test.yml
vendored
Normal file
91
.github/workflows/test.yml
vendored
Normal file
@@ -0,0 +1,91 @@
|
|||||||
|
name: Test
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- master
|
||||||
|
- develop
|
||||||
|
pull_request:
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
mocha:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
node-version: [16.x]
|
||||||
|
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:12.2-alpine
|
||||||
|
ports:
|
||||||
|
- 54312:5432
|
||||||
|
env:
|
||||||
|
POSTGRES_DB: test-misskey
|
||||||
|
POSTGRES_HOST_AUTH_METHOD: trust
|
||||||
|
redis:
|
||||||
|
image: redis:4.0-alpine
|
||||||
|
ports:
|
||||||
|
- 56312:6379
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Use Node.js ${{ matrix.node-version }}
|
||||||
|
uses: actions/setup-node@v1
|
||||||
|
with:
|
||||||
|
node-version: ${{ matrix.node-version }}
|
||||||
|
- name: Install dependencies
|
||||||
|
run: yarn install
|
||||||
|
- name: Check yarn.lock
|
||||||
|
run: git diff --exit-code yarn.lock
|
||||||
|
- name: Copy Configure
|
||||||
|
run: cp .github/misskey/test.yml .config
|
||||||
|
- name: Build
|
||||||
|
run: yarn build
|
||||||
|
- name: Test
|
||||||
|
run: yarn mocha
|
||||||
|
|
||||||
|
e2e:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
|
||||||
|
strategy:
|
||||||
|
matrix:
|
||||||
|
node-version: [16.x]
|
||||||
|
|
||||||
|
services:
|
||||||
|
postgres:
|
||||||
|
image: postgres:12.2-alpine
|
||||||
|
ports:
|
||||||
|
- 54312:5432
|
||||||
|
env:
|
||||||
|
POSTGRES_DB: test-misskey
|
||||||
|
POSTGRES_HOST_AUTH_METHOD: trust
|
||||||
|
redis:
|
||||||
|
image: redis:4.0-alpine
|
||||||
|
ports:
|
||||||
|
- 56312:6379
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v2
|
||||||
|
with:
|
||||||
|
submodules: true
|
||||||
|
- name: Use Node.js ${{ matrix.node-version }}
|
||||||
|
uses: actions/setup-node@v1
|
||||||
|
with:
|
||||||
|
node-version: ${{ matrix.node-version }}
|
||||||
|
- uses: actions/cache@v2
|
||||||
|
with:
|
||||||
|
path: '**/node_modules'
|
||||||
|
key: ${{ runner.os }}-modules-${{ hashFiles('**/yarn.lock') }}
|
||||||
|
- name: Install dependencies
|
||||||
|
run: yarn install
|
||||||
|
- name: Check yarn.lock
|
||||||
|
run: git diff --exit-code yarn.lock
|
||||||
|
- name: Copy Configure
|
||||||
|
run: cp .github/misskey/test.yml .config
|
||||||
|
- name: Build
|
||||||
|
run: yarn build
|
||||||
|
- name: Test
|
||||||
|
run: yarn e2e
|
8
.gitignore
vendored
8
.gitignore
vendored
@@ -6,9 +6,13 @@
|
|||||||
/.idea
|
/.idea
|
||||||
|
|
||||||
# Node.js
|
# Node.js
|
||||||
/node_modules
|
node_modules
|
||||||
report.*.json
|
report.*.json
|
||||||
|
|
||||||
|
# Cypress
|
||||||
|
cypress/screenshots
|
||||||
|
cypress/videos
|
||||||
|
|
||||||
# config
|
# config
|
||||||
/.config/*
|
/.config/*
|
||||||
!/.config/example.yml
|
!/.config/example.yml
|
||||||
@@ -16,7 +20,7 @@ report.*.json
|
|||||||
|
|
||||||
# misskey
|
# misskey
|
||||||
/build
|
/build
|
||||||
/built
|
built
|
||||||
/data
|
/data
|
||||||
/.cache-loader
|
/.cache-loader
|
||||||
/db
|
/db
|
||||||
|
3
.gitmodules
vendored
Normal file
3
.gitmodules
vendored
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
[submodule "misskey-assets"]
|
||||||
|
path = misskey-assets
|
||||||
|
url = https://github.com/misskey-dev/assets.git
|
@@ -1,5 +0,0 @@
|
|||||||
{
|
|
||||||
"ignoredFiles": [
|
|
||||||
"test/resources/*"
|
|
||||||
]
|
|
||||||
}
|
|
@@ -1 +1 @@
|
|||||||
v16.2.0
|
v16.6.2
|
||||||
|
6
.vscode/extensions.json
vendored
6
.vscode/extensions.json
vendored
@@ -1,12 +1,10 @@
|
|||||||
{
|
{
|
||||||
"recommendations": [
|
"recommendations": [
|
||||||
"ducksoupdev.vue2",
|
|
||||||
"editorconfig.editorconfig",
|
"editorconfig.editorconfig",
|
||||||
"eg2.vscode-npm-script",
|
"eg2.vscode-npm-script",
|
||||||
"hollowtree.vue-snippets",
|
|
||||||
"ms-vscode.typescript-javascript-grammar",
|
"ms-vscode.typescript-javascript-grammar",
|
||||||
"ms-vscode.vscode-typescript-tslint-plugin",
|
"dbaeumer.vscode-eslint",
|
||||||
"octref.vetur",
|
"johnsoncodehk.volar",
|
||||||
"sysoev.language-stylus"
|
"sysoev.language-stylus"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
306
CHANGELOG.md
306
CHANGELOG.md
@@ -1,3 +1,307 @@
|
|||||||
|
<!--
|
||||||
|
## 12.x.x (unreleased)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
|
||||||
|
-->
|
||||||
|
|
||||||
|
## 12.99.0 (2021/12/14)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- Added a user-level instance mute in user settings
|
||||||
|
- フォローエクスポートでミュートしているユーザーを含めないオプションを追加
|
||||||
|
- フォローエクスポートで使われていないアカウントを含めないオプションを追加
|
||||||
|
- カスタム絵文字エクスポート機能
|
||||||
|
- チャートのパフォーマンスの改善
|
||||||
|
- グループから抜けられるように
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: タッチ機能付きディスプレイを使っていてマウス操作をしている場合に一部機能が動作しない問題を修正
|
||||||
|
- クライアント: クリップの設定を編集できない問題を修正
|
||||||
|
- クライアント: メニューなどがウィンドウの裏に隠れる問題を修正
|
||||||
|
|
||||||
|
## 12.98.0 (2021/12/03)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- API: /antennas/notes API で日付による絞り込みができるように
|
||||||
|
- クライアント: アンケートに投票する際に確認ダイアログを出すように
|
||||||
|
- クライアント: Renoteなノート詳細ページから元のノートページに遷移できるように
|
||||||
|
- クライアント: 画像ポップアップでクリックで閉じられるように
|
||||||
|
- クライアント: デザインの調整
|
||||||
|
- フォロワーを解除できる機能
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: LTLやGTLが無効になっている場合でもUI上にタブが表示される問題を修正
|
||||||
|
- クライアント: ログインにおいてパスワードが誤っている際のエラーメッセージが正しく表示されない問題を修正
|
||||||
|
- クライアント: リアクションツールチップ、Renoteツールチップのユーザーの並び順を修正
|
||||||
|
- クライアント: サウンドのマスターボリュームが正しく保存されない問題を修正
|
||||||
|
- クライアント: 一部環境において通知が表示されると操作不能になる問題を修正
|
||||||
|
- クライアント: モバイルでタップしたときにツールチップが表示される問題を修正
|
||||||
|
- クライアント: リモートインスタンスのノートに返信するとき、対象のノートにそのリモートインスタンス内のユーザーへのメンションが含まれていると、返信テキスト内にローカルユーザーへのメンションとして引き継がれてしまう場合がある問題を修正
|
||||||
|
- クライアント: 画像ビューワーで全体表示した時に上側の一部しか表示されない画像がある問題を修正
|
||||||
|
- API: ユーザーを取得時に条件によっては内部エラーになる問題を修正
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
- クライアント: ノートにモデレーターバッジを表示するのを廃止
|
||||||
|
|
||||||
|
## 12.97.0 (2021/11/19)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- クライアント: 返信先やRenoteに対しても自動折りたたみされるように
|
||||||
|
- クライアント: 長いスレッドの表示を改善
|
||||||
|
- クライアント: 翻訳にもMFMを適用し、元の文章の改行などを保持するように
|
||||||
|
- クライアント: アカウント削除に確認ダイアログを出すように
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: ユーザー検索の「全て」が動作しない問題を修正
|
||||||
|
- クライアント: リアクション一覧、Renote一覧ツールチップのスタイルを修正
|
||||||
|
|
||||||
|
## 12.96.1 (2021/11/13)
|
||||||
|
### Improvements
|
||||||
|
- npm scriptの互換性を向上
|
||||||
|
|
||||||
|
## 12.96.0 (2021/11/13)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- フォロー/フォロワーを非公開にできるように
|
||||||
|
- インスタンスプロフィールレンダリング ready
|
||||||
|
- 通知のリアクションアイコンをホバーで拡大できるように
|
||||||
|
- RenoteボタンをホバーでRenoteしたユーザー一覧を表示するように
|
||||||
|
- 返信の際にメンションを含めるように
|
||||||
|
- 通報があったときに管理者へEメールで通知されるように
|
||||||
|
- メールアドレスのバリデーションを強化
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- アカウント削除処理があると高負荷になる問題を修正
|
||||||
|
- クライアント: 長いメニューが画面からはみ出す問題を修正
|
||||||
|
- クライアント: コントロールパネルのジョブキューに個々のジョブが表示されないのを修正
|
||||||
|
- クライアント: fix missing i18n string
|
||||||
|
- fix html conversion issue with code blocks
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
- ノートにモバイルからの投稿か否かの情報を含めないように
|
||||||
|
|
||||||
|
## 12.95.0 (2021/10/31)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- スレッドミュート機能
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- リレー向けのActivityが一部実装で除外されてしまうことがあるのを修正
|
||||||
|
- 削除したノートやユーザーがリモートから参照されると復活することがあるのを修正
|
||||||
|
- クライアント: ページ編集時のドロップダウンメニューなどが動作しない問題を修正
|
||||||
|
- クライアント: コントロールパネルのカスタム絵文字タブが切り替わらないように見える問題を修正
|
||||||
|
- API: ユーザー情報の hasUnreadChannel が常に false になっている問題を修正
|
||||||
|
|
||||||
|
## 12.94.1 (2021/10/25)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: ユーザーページのナビゲーションが失敗する問題を修正
|
||||||
|
|
||||||
|
## 12.94.0 (2021/10/25)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- クライアント: 画像ビューアを強化
|
||||||
|
- クライアント: メンションにユーザーのアバターを表示するように
|
||||||
|
- クライアント: デザインの調整
|
||||||
|
- クライアント: twemojiをセルフホスティングするように
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: CWで画像が隠されたとき、画像の高さがおかしいことになる問題を修正
|
||||||
|
|
||||||
|
### NOTE
|
||||||
|
- このバージョンから、iOS 15未満のサポートがされなくなります。対象のバージョンをお使いの方は、iOSのバージョンアップを行ってください。
|
||||||
|
|
||||||
|
## 12.93.2 (2021/10/23)
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: ウィジェットを追加できない問題を修正
|
||||||
|
|
||||||
|
## 12.93.1 (2021/10/23)
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: 通知上でローカルのリアクションが表示されないのを修正
|
||||||
|
|
||||||
|
## 12.93.0 (2021/10/23)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- クライアント: コントロールパネルのパフォーマンスを改善
|
||||||
|
- クライアント: 自分のリアクション一覧を見れるように
|
||||||
|
- 設定により、リアクション一覧を全員に公開することも可能
|
||||||
|
- クライアント: ユーザー検索の精度を強化
|
||||||
|
- クライアント: 新しいライトテーマを追加
|
||||||
|
- クライアント: 新しいダークテーマを追加
|
||||||
|
- API: ユーザーのリアクション一覧を取得する users/reactions を追加
|
||||||
|
- API: users/search および users/search-by-username-and-host を強化
|
||||||
|
- ミュート及びブロックのインポートを行えるように
|
||||||
|
- クライアント: /share のクエリでリプライやファイル等の情報を渡せるように
|
||||||
|
- チャートのsyncを毎日0時に自動で行うように
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- クライアント: テーマの管理が行えない問題を修正
|
||||||
|
- API: アプリケーション通知が取得できない問題を修正
|
||||||
|
- クライアント: リモートノートで意図せずローカルカスタム絵文字が使われてしまうことがあるのを修正
|
||||||
|
- ActivityPub: not reacted な Undo.Like がinboxに滞留するのを修正
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
- 連合の考慮に問題があることなどが分かったため、モデレーターをブロックできない仕様を廃止しました
|
||||||
|
- データベースにログを保存しないようになりました
|
||||||
|
- ログを永続化したい場合はsyslogを利用してください
|
||||||
|
|
||||||
|
## 12.92.0 (2021/10/16)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- アカウント登録にメールアドレスの設定を必須にするオプション
|
||||||
|
- クライアント: 全体的なUIのブラッシュアップ
|
||||||
|
- クライアント: MFM関数構文のサジェストを実装
|
||||||
|
- クライアント: ノート本文を投稿フォーム内でプレビューできるように
|
||||||
|
- クライアント: 未読の通知のみ表示する機能
|
||||||
|
- クライアント: 通知ページで通知の種類によるフィルタ
|
||||||
|
- クライアント: アニメーションを減らす設定の適用範囲を拡充
|
||||||
|
- クライアント: 新しいダークテーマを追加
|
||||||
|
- クライアント: テーマコンパイラに hue と saturate 関数を追加
|
||||||
|
- ActivityPub: HTML -> MFMの変換を強化
|
||||||
|
- API: グループから抜ける users/groups/leave エンドポイントを実装
|
||||||
|
- API: i/notifications に unreadOnly オプションを追加
|
||||||
|
- API: ap系のエンドポイントをログイン必須化+レートリミット追加
|
||||||
|
- MFM: Add tag syntaxes of bold <b></b> and strikethrough <s></s>
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- Fix createDeleteAccountJob
|
||||||
|
- admin inbox queue does not show individual jobs
|
||||||
|
- クライアント: ヘッダーのタブが折り返される問題を修正
|
||||||
|
- クライアント: ヘッダーにタブが表示されている状態でタイトルをクリックしたときにタブ選択が表示されるのを修正
|
||||||
|
- クライアント: ユーザーページのタブが機能していない問題を修正
|
||||||
|
- クライアント: ピン留めユーザーの設定項目がない問題を修正
|
||||||
|
- クライアント: Deck UIにおいて、重ねたカラムの片方を畳んだ状態で右に出すと表示が壊れる問題を修正
|
||||||
|
- API: 管理者およびモデレーターをブロックできてしまう問題を修正
|
||||||
|
- MFM: Mentions in the link label are parsed as text
|
||||||
|
- MFM: Add a property to the URL node indicating whether it was enclosed in <>
|
||||||
|
- MFM: Disallows < and > in hashtags
|
||||||
|
|
||||||
|
### Changes
|
||||||
|
- 保守性やユーザビリティの観点から、Misskeyのコマンドラインオプションが削除されました。
|
||||||
|
- 必要であれば、代わりに環境変数で設定することができます
|
||||||
|
- MFM: パフォーマンス、保守性、構文誤認識抑制の観点から、旧関数構文のサポートが削除されました。
|
||||||
|
- 旧構文(`[foo bar]`)を使用せず、現行の構文(`$[foo bar]`)を使用してください。
|
||||||
|
|
||||||
|
## 12.91.0 (2021/09/22)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- ActivityPub: リモートユーザーのDeleteアクティビティに対応
|
||||||
|
- ActivityPub: add resolver check for blocked instance
|
||||||
|
- ActivityPub: deliverキューのメモリ使用量を削減
|
||||||
|
- API: 管理者用アカウント削除APIを実装(/admin/accounts/delete)
|
||||||
|
- リモートユーザーの削除も可能に
|
||||||
|
- アカウントが凍結された場合に、凍結された旨を表示してからログアウトするように
|
||||||
|
- 凍結されたアカウントにログインしようとしたときに、凍結されている旨を表示するように
|
||||||
|
- リスト、アンテナタイムラインを個別ページとして分割
|
||||||
|
- UIの改善
|
||||||
|
- MFMにsparklesエフェクトを追加
|
||||||
|
- 非ログイン自は更新ダイアログを出さないように
|
||||||
|
- クライアント起動時、アップデートが利用可能な場合エラー表示およびダイアログ表示しないように
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- アカウントデータのエクスポート/インポート処理ができない問題を修正
|
||||||
|
- アンテナの既読が付かない問題を修正
|
||||||
|
- popupで設定ページを表示すると、アカウントの削除ページにアクセスすることができない問題を修正
|
||||||
|
- "問題が発生しました"ウィンドウを開くと☓ボタンがなくて閉じれない問題を修正
|
||||||
|
|
||||||
|
## 12.90.1 (2021/09/05)
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- Dockerfileを修正
|
||||||
|
- ノート翻訳時に公開範囲が考慮されていない問題を修正
|
||||||
|
|
||||||
|
## 12.90.0 (2021/09/04)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- 藍モード、および藍ウィジェット
|
||||||
|
- クライアントに藍ちゃんを召喚することができるようになりました。
|
||||||
|
- URLからのアップロード, APの添付ファイル, 外部ファイルのプロキシ等では、Privateアドレス等へのリクエストは拒否されるようになりました。
|
||||||
|
- developmentで動作している場合は、この制限は適用されません。
|
||||||
|
- Proxy使用時には、この制限は適用されません。
|
||||||
|
Proxy使用時に同等の制限を行いたい場合は、Proxy側で設定を行う必要があります。
|
||||||
|
- `default.yml`にて`allowedPrivateNetworks`にCIDRを追加することにより、宛先ネットワークを指定してこの制限から除外することが出来ます。
|
||||||
|
- アップロード, ダウンロード出来るファイルサイズにハードリミットが適用されるようになりました。(約250MB)
|
||||||
|
- `default.yml`にて`maxFileSize`を変更することにより、制限値を変更することが出来ます。
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- 管理者が最初にサインアップするページでログインされないのを修正
|
||||||
|
- CWを維持する設定を復活
|
||||||
|
- クライアントの表示を修正
|
||||||
|
|
||||||
|
## 12.89.2 (2021/08/24)
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- カスタムCSSを有効にしているとエラーになる問題を修正
|
||||||
|
|
||||||
|
## 12.89.1 (2021/08/24)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- クライアントのデザインの調整
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- 翻訳でDeepLのProアカウントに対応していない問題を修正
|
||||||
|
- インスタンス設定でDeepLのAuth Keyが空で表示される問題を修正
|
||||||
|
- セキュリティの向上
|
||||||
|
|
||||||
|
## 12.89.0 (2021/08/21)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- アカウント削除の安定性を向上
|
||||||
|
- 絵文字オートコンプリートの挙動を改修
|
||||||
|
- localStorageのaccountsはindexedDBで保持するように
|
||||||
|
- ActivityPub: ジョブキューの試行タイミングを調整 (#7635)
|
||||||
|
- API: sw/unregisterを追加
|
||||||
|
- ワードミュートのドキュメントを追加
|
||||||
|
- クライアントのデザインの調整
|
||||||
|
- 依存関係の更新
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- チャンネルを作成しているとアカウントを削除できないのを修正
|
||||||
|
- ノートの「削除して編集」をするとアンケートの選択肢が[object Object]になる問題を修正
|
||||||
|
|
||||||
|
## 12.88.0 (2021/08/17)
|
||||||
|
|
||||||
|
### Features
|
||||||
|
- ノートの翻訳機能を追加
|
||||||
|
- 有効にするには、サーバー管理者がDeepLの無料アカウントを登録し、取得した認証キーを「インスタンス設定 > その他 > DeepL Auth Key」に設定する必要があります。
|
||||||
|
- Misskey更新時にダイアログを表示するように
|
||||||
|
- ジョブキューウィジェットに警報音を鳴らす設定を追加
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- ブロックの挙動を改修
|
||||||
|
- ブロックされたユーザーがブロックしたユーザーに対してアクション出来ないようになりました。詳細はドキュメントをご確認ください。
|
||||||
|
- UIデザインの調整
|
||||||
|
- データベースのインデックスを最適化
|
||||||
|
- Proxy使用時にKeep-Aliveをサポート
|
||||||
|
- DNSキャッシュでネガティブキャッシュをサポート
|
||||||
|
- 依存関係の更新
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- タッチ操作でウィンドウを閉じることができない問題を修正
|
||||||
|
- Renoteされた時刻が投稿された時刻のように表示される問題を修正
|
||||||
|
- コントロールパネルでファイルを削除した際の表示を修正
|
||||||
|
- ActivityPub: 長いユーザーの名前や自己紹介の対応
|
||||||
|
|
||||||
|
## 12.87.0 (2021/08/12)
|
||||||
|
|
||||||
|
### Improvements
|
||||||
|
- 絵文字オートコンプリートで一文字目は最近使った絵文字をサジェストするように
|
||||||
|
- 絵文字オートコンプリートのパフォーマンスを改善
|
||||||
|
- about-misskeyページにドキュメントへのリンクを追加
|
||||||
|
- Docker: Node.jsを16.6.2に
|
||||||
|
- 依存関係の更新
|
||||||
|
- 翻訳の更新
|
||||||
|
|
||||||
|
### Bugfixes
|
||||||
|
- Misskey更新時、テーマキャッシュの影響でスタイルがおかしくなる問題を修正
|
||||||
|
|
||||||
## 12.86.0 (2021/08/11)
|
## 12.86.0 (2021/08/11)
|
||||||
|
|
||||||
### Improvements
|
### Improvements
|
||||||
@@ -9,4 +313,4 @@
|
|||||||
|
|
||||||
### Bugfixes
|
### Bugfixes
|
||||||
- ハッシュタグ入力が空のときに#が付くのを修正
|
- ハッシュタグ入力が空のときに#が付くのを修正
|
||||||
- フォロー通知のEメール通知を修正
|
- フォローリクエストのEメール通知を修正
|
||||||
|
206
CONTRIBUTING.md
206
CONTRIBUTING.md
@@ -1,22 +1,43 @@
|
|||||||
# Contribution guide
|
# Contribution guide
|
||||||
:v: Thanks for your contributions :v:
|
We're glad you're interested in contributing Misskey! In this document you will find the information you need to contribute to the project.
|
||||||
|
|
||||||
## When you contribute...
|
**ℹ️ Important:** This project uses Japanese as its major language, **but you do not need to translate and write the Issues/PRs in Japanese.**
|
||||||
- 任意のIssueについて、せっかく実装してくださっても、実装方法や設計の認識が揃ってないとマージできない/しないことになりかねないので、初めにそのIssue上で着手することを宣言し、必要に応じて他メンバーと実装方法や設計のすり合わせを行ってください。宣言することは作業が他の人と被るのを防止する効果もあります。
|
Also, you might receive comments on your Issue/PR in Japanese, but you do not need to reply to them in Japanese as well.\
|
||||||
- 設計に迷った時はプロジェクトリーダーの判断を仰いでください。
|
The accuracy of translation into Japanese is not high, so it will be easier for us to understand if you write it in the original language.
|
||||||
- 時間や優先度の都合上、提出してくださったPRが長期間放置されることもありますがご理解ください。
|
It will also allow the reader to use the translation tool of their preference if necessary.
|
||||||
- 温度感高めで見てほしいものは責付いてください。
|
|
||||||
|
|
||||||
## Issues
|
## Issues
|
||||||
Feature suggestions and bug reports are filed in https://github.com/misskey-dev/misskey/issues .
|
Before creating an issue, please check the following:
|
||||||
|
- To avoid duplication, please search for similar issues before creating a new issue.
|
||||||
|
- Do not use Issues to ask questions or troubleshooting.
|
||||||
|
- Issues should only be used to feature requests, suggestions, and bug tracking.
|
||||||
|
- Please ask questions or troubleshooting in the [Misskey Forum](https://forum.misskey.io/) or [Discord](https://discord.gg/Wp8gVStHW3).
|
||||||
|
|
||||||
* Please search existing issues to avoid duplication. If your issue is already filed, please add your reaction or comment to the existing one.
|
## Before implementation
|
||||||
* If you have multiple independent issues, please submit them separately.
|
When you want to add a feature or fix a bug, **first have the design and policy reviewed in an Issue** (if it is not there, please make one). Without this step, there is a high possibility that the PR will not be merged even if it is implemented.
|
||||||
|
|
||||||
## Branches
|
Also, when you start implementation, assign yourself to the Issue (if you cannot do it yourself, ask another member to assign you). By expressing your intention to work the Issue, you can prevent conflicts in the work.
|
||||||
* **master** branch is tracking the latest release and used for production purposes.
|
|
||||||
* **develop** branch is where we work for the next release.
|
## Well-known branches
|
||||||
* **l10n_develop** branch is reserved for localization management.
|
- **`master`** branch is tracking the latest release and used for production purposes.
|
||||||
|
- **`develop`** branch is where we work for the next release.
|
||||||
|
- When you create a PR, basically target it to this branch.
|
||||||
|
- **`l10n_develop`** branch is reserved for localization management.
|
||||||
|
|
||||||
|
## Creating a PR
|
||||||
|
Thank you for your PR! Before creating a PR, please check the following:
|
||||||
|
- If possible, prefix the title with a keyword that identifies the type of this PR, as shown below.
|
||||||
|
- `fix` / `refactor` / `feat` / `enhance` / `perf` / `chore` etc
|
||||||
|
- Also, make sure that the granularity of this PR is appropriate. Please do not include more than one type of change or interest in a single PR.
|
||||||
|
- If there is an Issue which will be resolved by this PR, please include a reference to the Issue in the text.
|
||||||
|
- Please add the summary of the changes to [`CHANGELOG.md`](/CHANGELOG.md). However, this is not necessary for changes that do not affect the users, such as refactoring.
|
||||||
|
- Check if there are any documents that need to be created or updated due to this change.
|
||||||
|
- If you have added a feature or fixed a bug, please add a test case if possible.
|
||||||
|
- Please make sure that tests and Lint are passed in advance.
|
||||||
|
- You can run it with `npm run test` and `npm run lint`. [See more info](#testing)
|
||||||
|
- If this PR includes UI changes, please attach a screenshot in the text.
|
||||||
|
|
||||||
|
Thanks for your cooperation 🤗
|
||||||
|
|
||||||
## Localization (l10n)
|
## Localization (l10n)
|
||||||
Misskey uses [Crowdin](https://crowdin.com/project/misskey) for localization management.
|
Misskey uses [Crowdin](https://crowdin.com/project/misskey) for localization management.
|
||||||
@@ -28,17 +49,47 @@ If your language is not listed in Crowdin, please open an issue.
|
|||||||
|
|
||||||

|

|
||||||
|
|
||||||
## Documentation
|
## Development
|
||||||
* Documents for instance admins are located in [`/docs`](/docs).
|
During development, it is useful to use the `npm run dev` command.
|
||||||
* Documents for end users are located in [`/src/docs`](/src/docs).
|
This command monitors the server-side and client-side source files and automatically builds them if they are modified.
|
||||||
|
In addition, it will also automatically start the Misskey server process.
|
||||||
|
|
||||||
## Test
|
## Testing
|
||||||
* Test codes are located in [`/test`](/test).
|
- Test codes are located in [`/test`](/test).
|
||||||
|
|
||||||
|
### Run test
|
||||||
|
Create a config file.
|
||||||
|
```
|
||||||
|
cp test/test.yml .config/
|
||||||
|
```
|
||||||
|
Prepare DB/Redis for testing.
|
||||||
|
```
|
||||||
|
docker-compose -f test/docker-compose.yml up
|
||||||
|
```
|
||||||
|
Alternatively, prepare an empty (data can be erased) DB and edit `.config/test.yml`.
|
||||||
|
|
||||||
|
Run all test.
|
||||||
|
```
|
||||||
|
npm run test
|
||||||
|
```
|
||||||
|
|
||||||
|
#### Run specify test
|
||||||
|
```
|
||||||
|
npx cross-env TS_NODE_FILES=true TS_NODE_TRANSPILE_ONLY=true TS_NODE_PROJECT="./test/tsconfig.json" npx mocha test/foo.ts --require ts-node/register
|
||||||
|
```
|
||||||
|
|
||||||
|
### e2e tests
|
||||||
|
TODO
|
||||||
|
|
||||||
## Continuous integration
|
## Continuous integration
|
||||||
Misskey uses GitHub Actions for executing automated tests.
|
Misskey uses GitHub Actions for executing automated tests.
|
||||||
Configuration files are located in [`/.github/workflows`](/.github/workflows).
|
Configuration files are located in [`/.github/workflows`](/.github/workflows).
|
||||||
|
|
||||||
|
## Vue
|
||||||
|
Misskey uses Vue(v3) as its front-end framework.
|
||||||
|
**When creating a new component, please use the Composition API instead of the Options API.**
|
||||||
|
Some of the existing components are implemented in the Options API, but it is an old implementation. Refactors that migrate those components to the Composition API are also welcome.
|
||||||
|
|
||||||
## Adding MisskeyRoom items
|
## Adding MisskeyRoom items
|
||||||
* Use English for material, object and texture names.
|
* Use English for material, object and texture names.
|
||||||
* Use meter for unit of length.
|
* Use meter for unit of length.
|
||||||
@@ -50,116 +101,11 @@ Configuration files are located in [`/.github/workflows`](/.github/workflows).
|
|||||||
If you have no experience on 3D modeling, we suggest to use the free 3DCG software [Blender](https://www.blender.org/).
|
If you have no experience on 3D modeling, we suggest to use the free 3DCG software [Blender](https://www.blender.org/).
|
||||||
You can find information on glTF 2.0 at [glTF 2.0 — Blender Manual]( https://docs.blender.org/manual/en/dev/addons/io_scene_gltf2.html).
|
You can find information on glTF 2.0 at [glTF 2.0 — Blender Manual]( https://docs.blender.org/manual/en/dev/addons/io_scene_gltf2.html).
|
||||||
|
|
||||||
## FAQ
|
## Notes
|
||||||
### How to resolve conflictions occurred at yarn.lock?
|
### How to resolve conflictions occurred at yarn.lock?
|
||||||
|
|
||||||
Just execute `yarn` to fix it.
|
Just execute `yarn` to fix it.
|
||||||
|
|
||||||
## Glossary
|
|
||||||
### AP
|
|
||||||
Stands for _**A**ctivity**P**ub_.
|
|
||||||
|
|
||||||
### MFM
|
|
||||||
Stands for _**M**isskey **F**lavored **M**arkdown_.
|
|
||||||
|
|
||||||
### Mk
|
|
||||||
Stands for _**M**iss**k**ey_.
|
|
||||||
|
|
||||||
### SW
|
|
||||||
Stands for _**S**ervice**W**orker_.
|
|
||||||
|
|
||||||
### Nyaize
|
|
||||||
Convert な(na) to にゃ(nya)
|
|
||||||
|
|
||||||
#### Denyaize
|
|
||||||
Revert Nyaize
|
|
||||||
|
|
||||||
## TypeScript Coding Style
|
|
||||||
### Do not omit semicolons
|
|
||||||
This is to avoid Automatic Semicolon Insertion (ASI) hazard.
|
|
||||||
|
|
||||||
Ref:
|
|
||||||
* https://www.ecma-international.org/ecma-262/#sec-automatic-semicolon-insertion
|
|
||||||
* https://github.com/tc39/ecma262/pull/1062
|
|
||||||
|
|
||||||
### Do not omit curly brackets
|
|
||||||
Bad:
|
|
||||||
``` ts
|
|
||||||
if (foo)
|
|
||||||
bar;
|
|
||||||
else
|
|
||||||
baz;
|
|
||||||
```
|
|
||||||
|
|
||||||
Good:
|
|
||||||
``` ts
|
|
||||||
if (foo) {
|
|
||||||
bar;
|
|
||||||
} else {
|
|
||||||
baz;
|
|
||||||
}
|
|
||||||
```
|
|
||||||
|
|
||||||
As a special case, you can omit the curly brackets if
|
|
||||||
|
|
||||||
* the body of the `if`-statement have only one statement and,
|
|
||||||
* the `if`-statement does not have `else`-clause.
|
|
||||||
|
|
||||||
Good:
|
|
||||||
``` ts
|
|
||||||
if (foo) bar;
|
|
||||||
```
|
|
||||||
|
|
||||||
Make sure that the condition and the body statement are on the same line.
|
|
||||||
|
|
||||||
### Do not use `==` when it can simply be replaced with `===`.
|
|
||||||
🥰
|
|
||||||
|
|
||||||
### Use only boolean (or null related) values in the condition of an `if`-statement.
|
|
||||||
Bad:
|
|
||||||
``` ts
|
|
||||||
if (foo.length)
|
|
||||||
```
|
|
||||||
|
|
||||||
Good:
|
|
||||||
``` ts
|
|
||||||
if (foo.length > 0)
|
|
||||||
```
|
|
||||||
|
|
||||||
### Do not use `export default`
|
|
||||||
This is because the current language support does not work well with `export default`.
|
|
||||||
|
|
||||||
Ref:
|
|
||||||
* https://basarat.gitbooks.io/typescript/docs/tips/defaultIsBad.html
|
|
||||||
* https://gfx.hatenablog.com/entry/2017/11/24/135343
|
|
||||||
|
|
||||||
Bad:
|
|
||||||
``` ts
|
|
||||||
export default function(foo: string): string {
|
|
||||||
```
|
|
||||||
|
|
||||||
Good:
|
|
||||||
``` ts
|
|
||||||
export function something(foo: string): string {
|
|
||||||
```
|
|
||||||
|
|
||||||
## Directory structure
|
|
||||||
```
|
|
||||||
src ... Source code
|
|
||||||
@types ... Type definitions
|
|
||||||
prelude ... Independence utils for coding JavaScript without side effects
|
|
||||||
misc ... Independence utils for Misskey without side effects
|
|
||||||
service ... Common functions with side effects
|
|
||||||
queue ... Job queues and Jobs
|
|
||||||
server ... Web Server
|
|
||||||
client ... Client
|
|
||||||
mfm ... MFM
|
|
||||||
|
|
||||||
test ... Test code
|
|
||||||
|
|
||||||
```
|
|
||||||
|
|
||||||
## Notes
|
|
||||||
### placeholder
|
### placeholder
|
||||||
SQLをクエリビルダで組み立てる際、使用するプレースホルダは重複してはならない
|
SQLをクエリビルダで組み立てる際、使用するプレースホルダは重複してはならない
|
||||||
例えば
|
例えば
|
||||||
@@ -231,13 +177,16 @@ const users = userIds.length > 0 ? await Users.find({
|
|||||||
SQLでは配列のインデックスは**1始まり**。
|
SQLでは配列のインデックスは**1始まり**。
|
||||||
`[a, b, c]`の `a`にアクセスしたいなら`[0]`ではなく`[1]`と書く
|
`[a, b, c]`の `a`にアクセスしたいなら`[0]`ではなく`[1]`と書く
|
||||||
|
|
||||||
|
### null IN
|
||||||
|
nullが含まれる可能性のあるカラムにINするときは、そのままだとおかしくなるのでORなどでnullのハンドリングをしよう。
|
||||||
|
|
||||||
### `undefined`にご用心
|
### `undefined`にご用心
|
||||||
MongoDBの時とは違い、findOneでレコードを取得する時に対象レコードが存在しない場合 **`undefined`** が返ってくるので注意。
|
MongoDBの時とは違い、findOneでレコードを取得する時に対象レコードが存在しない場合 **`undefined`** が返ってくるので注意。
|
||||||
MongoDBは`null`で返してきてたので、その感覚で`if (x === null)`とか書くとバグる。代わりに`if (x == null)`と書いてください
|
MongoDBは`null`で返してきてたので、その感覚で`if (x === null)`とか書くとバグる。代わりに`if (x == null)`と書いてください
|
||||||
|
|
||||||
### Migration作成方法
|
### Migration作成方法
|
||||||
```
|
```
|
||||||
npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前
|
npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前 -o
|
||||||
```
|
```
|
||||||
|
|
||||||
作成されたスクリプトは不必要な変更を含むため除去してください。
|
作成されたスクリプトは不必要な変更を含むため除去してください。
|
||||||
@@ -245,6 +194,13 @@ npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前
|
|||||||
### コネクションには`markRaw`せよ
|
### コネクションには`markRaw`せよ
|
||||||
**Vueのコンポーネントのdataオプションとして**misskey.jsのコネクションを設定するとき、必ず`markRaw`でラップしてください。インスタンスが不必要にリアクティブ化されることで、misskey.js内の処理で不具合が発生するとともに、パフォーマンス上の問題にも繋がる。なお、Composition APIを使う場合はこの限りではない(リアクティブ化はマニュアルなため)。
|
**Vueのコンポーネントのdataオプションとして**misskey.jsのコネクションを設定するとき、必ず`markRaw`でラップしてください。インスタンスが不必要にリアクティブ化されることで、misskey.js内の処理で不具合が発生するとともに、パフォーマンス上の問題にも繋がる。なお、Composition APIを使う場合はこの限りではない(リアクティブ化はマニュアルなため)。
|
||||||
|
|
||||||
|
### JSONのimportに気を付けよう
|
||||||
|
TypeScriptでjsonをimportすると、tscでコンパイルするときにそのjsonファイルも一緒にdistディレクトリに吐き出されてしまう。この挙動により、意図せずファイルの書き換えが発生することがあるので、jsonをimportするときは書き換えられても良いものかどうか確認すること。書き換えされて欲しくない場合は、importで読み込むのではなく、`fs.readFileSync`などの関数を使って読み込むようにすればよい。
|
||||||
|
|
||||||
|
### コンポーネントのスタイル定義でmarginを持たせない
|
||||||
|
コンポーネント自身がmarginを設定するのは問題の元となることはよく知られている
|
||||||
|
marginはそのコンポーネントを使う側が設定する
|
||||||
|
|
||||||
## その他
|
## その他
|
||||||
### HTMLのクラス名で follow という単語は使わない
|
### HTMLのクラス名で follow という単語は使わない
|
||||||
広告ブロッカーで誤ってブロックされる
|
広告ブロッカーで誤ってブロックされる
|
||||||
|
36
Dockerfile
36
Dockerfile
@@ -1,43 +1,35 @@
|
|||||||
FROM node:16.2.0-alpine3.13 AS base
|
FROM node:16.6.2-alpine3.13 AS base
|
||||||
|
|
||||||
ENV NODE_ENV=production
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
WORKDIR /misskey
|
WORKDIR /misskey
|
||||||
|
|
||||||
|
ENV BUILD_DEPS autoconf automake file g++ gcc libc-dev libtool make nasm pkgconfig python3 zlib-dev git
|
||||||
|
|
||||||
FROM base AS builder
|
FROM base AS builder
|
||||||
|
|
||||||
RUN apk add --no-cache \
|
|
||||||
autoconf \
|
|
||||||
automake \
|
|
||||||
file \
|
|
||||||
g++ \
|
|
||||||
gcc \
|
|
||||||
libc-dev \
|
|
||||||
libtool \
|
|
||||||
make \
|
|
||||||
nasm \
|
|
||||||
pkgconfig \
|
|
||||||
python3 \
|
|
||||||
zlib-dev \
|
|
||||||
vips-dev \
|
|
||||||
vips
|
|
||||||
|
|
||||||
COPY package.json yarn.lock .yarnrc ./
|
|
||||||
RUN yarn install
|
|
||||||
COPY . ./
|
COPY . ./
|
||||||
RUN yarn build
|
|
||||||
|
RUN apk add --no-cache $BUILD_DEPS && \
|
||||||
|
git submodule update --init && \
|
||||||
|
yarn install && \
|
||||||
|
yarn build && \
|
||||||
|
rm -rf .git
|
||||||
|
|
||||||
FROM base AS runner
|
FROM base AS runner
|
||||||
|
|
||||||
RUN apk add --no-cache \
|
RUN apk add --no-cache \
|
||||||
ffmpeg \
|
ffmpeg \
|
||||||
tini \
|
tini
|
||||||
vips
|
|
||||||
|
|
||||||
ENTRYPOINT ["/sbin/tini", "--"]
|
ENTRYPOINT ["/sbin/tini", "--"]
|
||||||
|
|
||||||
COPY --from=builder /misskey/node_modules ./node_modules
|
COPY --from=builder /misskey/node_modules ./node_modules
|
||||||
COPY --from=builder /misskey/built ./built
|
COPY --from=builder /misskey/built ./built
|
||||||
|
COPY --from=builder /misskey/packages/backend/node_modules ./packages/backend/node_modules
|
||||||
|
COPY --from=builder /misskey/packages/backend/built ./packages/backend/built
|
||||||
|
COPY --from=builder /misskey/packages/client/node_modules ./packages/client/node_modules
|
||||||
COPY . ./
|
COPY . ./
|
||||||
|
|
||||||
CMD ["npm", "run", "migrateandstart"]
|
CMD ["npm", "run", "migrateandstart"]
|
||||||
|
|
||||||
|
130
README.md
130
README.md
@@ -1,111 +1,57 @@
|
|||||||
[](https://join.misskey.page/)
|
[](https://join.misskey.page/)
|
||||||
|
|
||||||
<h1 align="center">Misskey</h1>
|
|
||||||
|
|
||||||
<div align="center">
|
<div align="center">
|
||||||
|
|
||||||
[](https://circleci.com/gh/misskey-dev/misskey)
|
**🌎 A forever evolving, interplanetary microblogging platform. 🚀**
|
||||||
[](https://david-dm.org/misskey-dev/misskey)
|
|
||||||
[](http://makeapullrequest.com)
|
|
||||||
[](https://github.com/humanetech-community/awesome-humane-tech)
|
|
||||||
|
|
||||||
**A forever evolving, interplanetary microblogging platform.**
|
**Misskey** is a distributed microblogging platform with advanced features such as Reactions and a highly customizable UI.
|
||||||
|
|
||||||
<a href="https://join.misskey.page/">Misskey</a> is a decentralized microblogging platform born on Earth.
|
[Learn more](https://misskey-hub.net/)
|
||||||
Since it exists within the Fediverse (a universe where various social media platforms are organized),
|
|
||||||
it is mutually linked with other social media platforms.
|
---
|
||||||
Why don't you take a short break from the hustle and bustle of the city, and dive into a new Internet? <a href="https://join.misskey.page/">Find an instance!</a>
|
|
||||||
|
[✨ Find an instance](https://misskey-hub.net/instances.html)
|
||||||
|
•
|
||||||
|
[📦 Create your own instance](https://misskey-hub.net/docs/install.html)
|
||||||
|
•
|
||||||
|
[🛠️ Contribute](./CONTRIBUTING.md)
|
||||||
|
•
|
||||||
|
[🚀 Join the community](https://discord.gg/Wp8gVStHW3)
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
<a href="https://www.patreon.com/syuilo"><img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" alt="Become a Patron!" width="160" /></a>
|
<a href="https://www.patreon.com/syuilo"><img src="https://c5.patreon.com/external/logo/become_a_patron_button@2x.png" alt="Become a Patron!" width="160" /></a>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
---
|
<div>
|
||||||
|
|
||||||
Do you have a question? Or are you experiencing trouble?
|
<a href="https://xn--931a.moe/"><img src="https://github.com/misskey-dev/misskey/blob/develop/assets/ai.png?raw=true" align="right" height="320px"/></a>
|
||||||
Visit [our forum](https://forum.misskey.io/)!
|
|
||||||
|
|
||||||
---
|
## ✨ Features
|
||||||
|
- **ActivityPub support**\
|
||||||
|
It is possible to interact with other software.
|
||||||
|
- **Reactions**\
|
||||||
|
You can add "reactions" to each post, making it easy for you to express your feelings.
|
||||||
|
- **Drive**\
|
||||||
|
An interface to manage uploaded files such as images, videos, sounds, etc.
|
||||||
|
You can also organize your favorite content into folders, making it easy to share again.
|
||||||
|
- **Rich Web UI**\
|
||||||
|
Misskey has a rich WebUI by default.
|
||||||
|
It is highly customizable by flexibly changing the layout and installing various widgets and themes.
|
||||||
|
Furthermore, plug-ins can be created using AiScript, a original programming language.
|
||||||
|
- and more...
|
||||||
|
|
||||||

|
</div>
|
||||||
|
|
||||||
:sparkles: Features
|
<div style="clear: both;"></div>
|
||||||
----------------------------------------------------------------
|
|
||||||
<a href="https://xn--931a.moe/"><img src="https://github.com/misskey-dev/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/></a>
|
|
||||||
|
|
||||||
<h3>Posting</h3>
|
## Sponsors
|
||||||
<p>
|
<div align="center">
|
||||||
Post your ideas, discussion topics, fun moments, or anything else you want to share! Misskey supports text, emoji, pictures, videos, and polls!
|
<a class="rss3" title="RSS3" href="https://rss3.io/" target="_blank" style="display: inline-block;"><img src="https://rss3.io/assets/images/Logo.svg" alt="RSS3" style="display: inline-block; height: 60px;"></a>
|
||||||
</p>
|
</div>
|
||||||
|
|
||||||
---
|
## Backers
|
||||||
|
|
||||||
<h3 >Reactions</h3>
|
|
||||||
<p>
|
|
||||||
Reactions are the simplest way to respond to others' posts. Simply pick a reaction emote from the list! Reactions on Misskey are much more expressive than other social media services which only allow “liking”.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
<h3>Interface</h3>
|
|
||||||
<p>
|
|
||||||
Customize the UI to your own tastes! No UI will work for everyone, so Misskey is completely customizable. Make Misskey *yours* by editing the style, adjusting timeline layouts, and placing widgets.
|
|
||||||
</p>
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
<h3>Misskey Drive</h3>
|
|
||||||
<p>
|
|
||||||
Organize and store your files! Want to post a picture you have already uploaded? Wish you could organize your files into folders? Misskey Drive is a solution!
|
|
||||||
</p>
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
...and more!
|
|
||||||
|
|
||||||
:package: Create your own instance
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Please see the [Setup and Installation Guide](./docs/setup.en.md).
|
|
||||||
|
|
||||||
:wrench: Contribution
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Please see the [Contribution Guide](./CONTRIBUTING.md).
|
|
||||||
|
|
||||||
### Collaborators
|
|
||||||
<table>
|
|
||||||
<tr>
|
|
||||||
<td><img src="https://avatars3.githubusercontent.com/u/4439005?s=460&v=4" alt="syuilo" width="100"></td>
|
|
||||||
<td><img src="https://avatars0.githubusercontent.com/u/10798641?s=460&v=4" alt="AyaMorisawa" width="100"></td>
|
|
||||||
<td><img src="https://avatars1.githubusercontent.com/u/30769358?s=460&v=4" alt="mei23" width="100"></td>
|
|
||||||
<td><img src="https://avatars2.githubusercontent.com/u/20679825?s=460&v=4" alt="acid-chicken" width="100"></td>
|
|
||||||
<td><img src="https://avatars2.githubusercontent.com/u/6533808?s=460&v=4" alt="rinsuki" width="100"></td>
|
|
||||||
<td><img src="https://avatars0.githubusercontent.com/u/7973572?s=460&v=4" alt="tamaina" width="100"></td>
|
|
||||||
<td><img src="https://avatars1.githubusercontent.com/u/7106976?s=460&v=4" alt="Xeltica" width="100"></td>
|
|
||||||
<td><img src="https://avatars1.githubusercontent.com/u/17376330?s=460&v=4" alt="u1-liquid" width="100"></td>
|
|
||||||
</tr>
|
|
||||||
<tr>
|
|
||||||
<td align="center"><a href="https://github.com/syuilo">@syuilo</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/AyaMorisawa">@AyaMorisawa</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/mei23">@mei23</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/acid-chicken">@acid-chicken</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/rinsuki">@rinsuki</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/tamaina">@tamaina</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/Xeltica">@Xeltica</a></td>
|
|
||||||
<td align="center"><a href="https://github.com/u1-liquid">@u1-liquid</a></td>
|
|
||||||
</tr>
|
|
||||||
</table>
|
|
||||||
|
|
||||||
---
|
|
||||||
|
|
||||||
To receive updates of this repo, follow [@repo@misskey.io](https://misskey.io/@repo) on fediverse.
|
|
||||||
|
|
||||||
Related projects
|
|
||||||
----------------------------------------------------------------
|
|
||||||
- [misskey.js](https://github.com/misskey-dev/misskey.js) - Misskey SDK for JavaScript
|
|
||||||
- [mfm.js](https://github.com/misskey-dev/mfm.js) - MFM parser
|
|
||||||
|
|
||||||
:heart: Backers
|
|
||||||
----------------------------------------------------------------
|
|
||||||
<!-- PATREON_START -->
|
<!-- PATREON_START -->
|
||||||
<table><tr>
|
<table><tr>
|
||||||
<td><img src="https://c8.patreon.com/2/200/20832595" alt="Roujo " width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/20832595" alt="Roujo " width="100"></td>
|
||||||
|
File diff suppressed because one or more lines are too long
Before Width: | Height: | Size: 38 KiB |
@@ -2,6 +2,3 @@ files:
|
|||||||
- source: /locales/ja-JP.yml
|
- source: /locales/ja-JP.yml
|
||||||
translation: /locales/%locale%.yml
|
translation: /locales/%locale%.yml
|
||||||
update_option: update_as_unapproved
|
update_option: update_as_unapproved
|
||||||
- source: /src/docs/ja-JP/**/*.md
|
|
||||||
translation: /src/docs/%locale%/**/%original_file_name%
|
|
||||||
update_option: update_as_unapproved
|
|
||||||
|
3
cypress.json
Normal file
3
cypress.json
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"baseUrl": "http://localhost:61812"
|
||||||
|
}
|
5
cypress/fixtures/example.json
Normal file
5
cypress/fixtures/example.json
Normal file
@@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"name": "Using fixtures to represent data",
|
||||||
|
"email": "hello@cypress.io",
|
||||||
|
"body": "Fixtures are a great way to mock data for responses to routes"
|
||||||
|
}
|
190
cypress/integration/basic.js
Normal file
190
cypress/integration/basic.js
Normal file
@@ -0,0 +1,190 @@
|
|||||||
|
describe('Before setup instance', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.request('POST', '/api/reset-db').as('reset');
|
||||||
|
cy.get('@reset').its('status').should('equal', 204);
|
||||||
|
cy.reload(true);
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。
|
||||||
|
// waitを入れることでそれを防止できる
|
||||||
|
cy.wait(1000);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('successfully loads', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('setup instance', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
|
||||||
|
cy.intercept('POST', '/api/admin/accounts/create').as('signup');
|
||||||
|
|
||||||
|
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();
|
||||||
|
|
||||||
|
// なぜか動かない
|
||||||
|
//cy.wait('@signup').should('have.property', 'response.statusCode');
|
||||||
|
cy.wait('@signup');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('After setup instance', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.request('POST', '/api/reset-db').as('reset');
|
||||||
|
cy.get('@reset').its('status').should('equal', 204);
|
||||||
|
cy.reload(true);
|
||||||
|
|
||||||
|
// インスタンス初期セットアップ
|
||||||
|
cy.request('POST', '/api/admin/accounts/create', {
|
||||||
|
username: 'admin',
|
||||||
|
password: 'pass',
|
||||||
|
}).its('body').as('admin');
|
||||||
|
|
||||||
|
cy.get('@admin');
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。
|
||||||
|
// waitを入れることでそれを防止できる
|
||||||
|
cy.wait(1000);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('successfully loads', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('signup', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
|
||||||
|
cy.intercept('POST', '/api/signup').as('signup');
|
||||||
|
|
||||||
|
cy.get('[data-cy-signup]').click();
|
||||||
|
cy.get('[data-cy-signup-username] input').type('alice');
|
||||||
|
cy.get('[data-cy-signup-password] input').type('alice1234');
|
||||||
|
cy.get('[data-cy-signup-password-retype] input').type('alice1234');
|
||||||
|
cy.get('[data-cy-signup-submit]').click();
|
||||||
|
|
||||||
|
cy.wait('@signup');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('After user signup', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.request('POST', '/api/reset-db').as('reset');
|
||||||
|
cy.get('@reset').its('status').should('equal', 204);
|
||||||
|
cy.reload(true);
|
||||||
|
|
||||||
|
// インスタンス初期セットアップ
|
||||||
|
cy.request('POST', '/api/admin/accounts/create', {
|
||||||
|
username: 'admin',
|
||||||
|
password: 'pass',
|
||||||
|
}).its('body').as('admin');
|
||||||
|
|
||||||
|
cy.get('@admin').then(() => {
|
||||||
|
// ユーザー作成
|
||||||
|
cy.request('POST', '/api/signup', {
|
||||||
|
username: 'alice',
|
||||||
|
password: 'alice1234',
|
||||||
|
}).its('body').as('alice');
|
||||||
|
});
|
||||||
|
|
||||||
|
cy.get('@alice');
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。
|
||||||
|
// waitを入れることでそれを防止できる
|
||||||
|
cy.wait(1000);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('successfully loads', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('signin', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
|
||||||
|
cy.intercept('POST', '/api/signin').as('signin');
|
||||||
|
|
||||||
|
cy.get('[data-cy-signin]').click();
|
||||||
|
cy.get('[data-cy-signin-username] input').type('alice');
|
||||||
|
// Enterキーでサインインできるかの確認も兼ねる
|
||||||
|
cy.get('[data-cy-signin-password] input').type('alice1234{enter}');
|
||||||
|
|
||||||
|
cy.wait('@signin');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('suspend', function() {
|
||||||
|
cy.request('POST', '/api/admin/suspend-user', {
|
||||||
|
i: this.admin.token,
|
||||||
|
userId: this.alice.id,
|
||||||
|
});
|
||||||
|
|
||||||
|
cy.visit('/');
|
||||||
|
|
||||||
|
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}');
|
||||||
|
|
||||||
|
// TODO: cypressにブラウザの言語指定できる機能が実装され次第英語のみテストするようにする
|
||||||
|
cy.contains(/アカウントが凍結されています|This account has been suspended due to/gi);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('After user singed in', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
cy.request('POST', '/api/reset-db').as('reset');
|
||||||
|
cy.get('@reset').its('status').should('equal', 204);
|
||||||
|
cy.reload(true);
|
||||||
|
|
||||||
|
// インスタンス初期セットアップ
|
||||||
|
cy.request('POST', '/api/admin/accounts/create', {
|
||||||
|
username: 'admin',
|
||||||
|
password: 'pass',
|
||||||
|
}).its('body').as('admin');
|
||||||
|
|
||||||
|
cy.get('@admin').then(() => {
|
||||||
|
// ユーザー作成
|
||||||
|
cy.request('POST', '/api/signup', {
|
||||||
|
username: 'alice',
|
||||||
|
password: 'alice1234',
|
||||||
|
}).its('body').as('alice');
|
||||||
|
});
|
||||||
|
|
||||||
|
cy.get('@alice').then(() => {
|
||||||
|
cy.visit('/');
|
||||||
|
|
||||||
|
cy.intercept('POST', '/api/signin').as('signin');
|
||||||
|
|
||||||
|
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.wait('@signin').as('signedIn');
|
||||||
|
});
|
||||||
|
|
||||||
|
cy.get('@signedIn');
|
||||||
|
});
|
||||||
|
|
||||||
|
afterEach(() => {
|
||||||
|
// テスト終了直前にページ遷移するようなテストケース(例えばアカウント作成)だと、たぶんCypressのバグでブラウザの内容が次のテストケースに引き継がれてしまう(例えばアカウントが作成し終わった段階からテストが始まる)。
|
||||||
|
// waitを入れることでそれを防止できる
|
||||||
|
cy.wait(1000);
|
||||||
|
});
|
||||||
|
|
||||||
|
it('successfully loads', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('note', () => {
|
||||||
|
cy.visit('/');
|
||||||
|
|
||||||
|
cy.get('[data-cy-open-post-form]').click();
|
||||||
|
cy.get('[data-cy-post-form-text]').type('Hello, Misskey!');
|
||||||
|
cy.get('[data-cy-open-post-form-submit]').click();
|
||||||
|
|
||||||
|
cy.contains('Hello, Misskey!');
|
||||||
|
});
|
||||||
|
});
|
22
cypress/plugins/index.js
Normal file
22
cypress/plugins/index.js
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
/// <reference types="cypress" />
|
||||||
|
// ***********************************************************
|
||||||
|
// This example plugins/index.js can be used to load plugins
|
||||||
|
//
|
||||||
|
// You can change the location of this file or turn off loading
|
||||||
|
// the plugins file with the 'pluginsFile' configuration option.
|
||||||
|
//
|
||||||
|
// You can read more here:
|
||||||
|
// https://on.cypress.io/plugins-guide
|
||||||
|
// ***********************************************************
|
||||||
|
|
||||||
|
// This function is called when a project is opened or re-opened (e.g. due to
|
||||||
|
// the project's config changing)
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {Cypress.PluginConfig}
|
||||||
|
*/
|
||||||
|
// eslint-disable-next-line no-unused-vars
|
||||||
|
module.exports = (on, config) => {
|
||||||
|
// `on` is used to hook into various events Cypress emits
|
||||||
|
// `config` is the resolved Cypress config
|
||||||
|
}
|
25
cypress/support/commands.js
Normal file
25
cypress/support/commands.js
Normal file
@@ -0,0 +1,25 @@
|
|||||||
|
// ***********************************************
|
||||||
|
// This example commands.js shows you how to
|
||||||
|
// create various custom commands and overwrite
|
||||||
|
// existing commands.
|
||||||
|
//
|
||||||
|
// For more comprehensive examples of custom
|
||||||
|
// commands please read more here:
|
||||||
|
// https://on.cypress.io/custom-commands
|
||||||
|
// ***********************************************
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// -- This is a parent command --
|
||||||
|
// Cypress.Commands.add('login', (email, password) => { ... })
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// -- This is a child command --
|
||||||
|
// Cypress.Commands.add('drag', { prevSubject: 'element'}, (subject, options) => { ... })
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// -- This is a dual command --
|
||||||
|
// Cypress.Commands.add('dismiss', { prevSubject: 'optional'}, (subject, options) => { ... })
|
||||||
|
//
|
||||||
|
//
|
||||||
|
// -- This will overwrite an existing command --
|
||||||
|
// Cypress.Commands.overwrite('visit', (originalFn, url, options) => { ... })
|
20
cypress/support/index.js
Normal file
20
cypress/support/index.js
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
// ***********************************************************
|
||||||
|
// This example support/index.js is processed and
|
||||||
|
// loaded automatically before your test files.
|
||||||
|
//
|
||||||
|
// This is a great place to put global configuration and
|
||||||
|
// behavior that modifies Cypress.
|
||||||
|
//
|
||||||
|
// You can change the location of this file or turn off
|
||||||
|
// automatically serving support files with the
|
||||||
|
// 'supportFile' configuration option.
|
||||||
|
//
|
||||||
|
// You can read more here:
|
||||||
|
// https://on.cypress.io/configuration
|
||||||
|
// ***********************************************************
|
||||||
|
|
||||||
|
// Import commands.js using ES2015 syntax:
|
||||||
|
import './commands'
|
||||||
|
|
||||||
|
// Alternatively you can use CommonJS syntax:
|
||||||
|
// require('./commands')
|
@@ -15,6 +15,7 @@ services:
|
|||||||
- external_network
|
- external_network
|
||||||
volumes:
|
volumes:
|
||||||
- ./files:/misskey/files
|
- ./files:/misskey/files
|
||||||
|
- ./.config:/misskey/.config:ro
|
||||||
|
|
||||||
redis:
|
redis:
|
||||||
restart: always
|
restart: always
|
||||||
|
@@ -1,33 +0,0 @@
|
|||||||
# Docs
|
|
||||||
These docs are for contributors of Misskey or admins of instance of Misskey.
|
|
||||||
Docs for users are located in `src/docs`.
|
|
||||||
|
|
||||||
これらのドキュメントはMisskeyの開発者またはMisskeyインスタンス運営者向けです。
|
|
||||||
利用者向けのドキュメントは`src/docs`にあります。
|
|
||||||
|
|
||||||
这些文档是为 Misskey 的贡献者,或是 Misskey 实例的管理者准备的。
|
|
||||||
为用户准备的文档放置在 `src/docs` 文件夹中。
|
|
||||||
|
|
||||||
## 日本語版
|
|
||||||
|
|
||||||
- [Misskey構築の手引き](./setup.ja.md)
|
|
||||||
- [運営ガイド](./manage.ja.md)
|
|
||||||
- [Dockerを使ったMisskey構築方法](./docker.ja.md)
|
|
||||||
|
|
||||||
## English Version
|
|
||||||
|
|
||||||
- [Misskey Setup and Installation Guide](./setup.en.md)
|
|
||||||
- [Management guide](./manage.en.md)
|
|
||||||
- [Docker Guide](./docker.en.md)
|
|
||||||
|
|
||||||
## Française Version
|
|
||||||
|
|
||||||
- [Guide d'installation et de configuration de Misskey](./setup.fr.md)
|
|
||||||
- [Guide d'administration](./manage.fr.md)
|
|
||||||
- [Guide Docker](./docker.fr.md)
|
|
||||||
|
|
||||||
## 简体中文版
|
|
||||||
|
|
||||||
- [Misskey 设置和安装指南](./setup.zh.md)
|
|
||||||
- [运营指南](./manage.zh.md)
|
|
||||||
- [Docker 部署指南](./docker.zh.md)
|
|
@@ -1,96 +0,0 @@
|
|||||||
Docker Guide
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
This guide describes how to install and setup Misskey with Docker.
|
|
||||||
|
|
||||||
- [Japanese version also available - 日本語版もあります](./docker.ja.md)
|
|
||||||
- [Simplified Chinese version also available - 简体中文版同样可用](./docker.zh.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* Download Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Clone Misskey repository's master branch.
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
2. Move to misskey directory.
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
3. Checkout to the [latest release](https://github.com/misskey-dev/misskey/releases/latest) tag.
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
*2.* Configure Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
Create configuration files with following:
|
|
||||||
|
|
||||||
```bash
|
|
||||||
cd .config
|
|
||||||
cp example.yml default.yml
|
|
||||||
cp docker_example.env docker.env
|
|
||||||
```
|
|
||||||
|
|
||||||
### `default.yml`
|
|
||||||
|
|
||||||
Edit this file the same as non-Docker environment.
|
|
||||||
However hostname of Postgresql, Redis and Elasticsearch are not `localhost`, they are set in `docker-compose.yml`.
|
|
||||||
The following is default hostname:
|
|
||||||
|
|
||||||
| Service | Hostname |
|
|
||||||
|---------------|----------|
|
|
||||||
| Postgresql | `db` |
|
|
||||||
| Redis | `redis` |
|
|
||||||
| Elasticsearch | `es` |
|
|
||||||
|
|
||||||
### `docker.env`
|
|
||||||
|
|
||||||
Configure Postgresql in this file.
|
|
||||||
The minimum required settings are:
|
|
||||||
|
|
||||||
| name | Description |
|
|
||||||
|---------------------|---------------|
|
|
||||||
| `POSTGRES_PASSWORD` | Password |
|
|
||||||
| `POSTGRES_USER` | Username |
|
|
||||||
| `POSTGRES_DB` | Database name |
|
|
||||||
|
|
||||||
*3.* Configure Docker
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Edit `docker-compose.yml`.
|
|
||||||
|
|
||||||
*4.* Build Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Build misskey with the following:
|
|
||||||
|
|
||||||
`docker-compose build`
|
|
||||||
|
|
||||||
*5.* Init DB
|
|
||||||
----------------------------------------------------------------
|
|
||||||
``` shell
|
|
||||||
docker-compose run --rm web yarn run init
|
|
||||||
```
|
|
||||||
|
|
||||||
*6.* That is it.
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Well done! Now you have an environment to run Misskey.
|
|
||||||
|
|
||||||
### Launch normally
|
|
||||||
Just `docker-compose up -d`. GLHF!
|
|
||||||
|
|
||||||
### How to update your Misskey server to the latest version
|
|
||||||
1. `git stash`
|
|
||||||
2. `git checkout master`
|
|
||||||
3. `git pull`
|
|
||||||
4. `git stash pop`
|
|
||||||
5. `docker-compose build`
|
|
||||||
6. Check [ChangeLog](../CHANGELOG.md) for migration information
|
|
||||||
7. `docker-compose stop && docker-compose up -d`
|
|
||||||
|
|
||||||
### How to execute [cli commands](manage.en.md):
|
|
||||||
`docker-compose run --rm web node built/tools/mark-admin @example`
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
If you have any questions or trouble, feel free to contact us!
|
|
@@ -1,90 +0,0 @@
|
|||||||
Guide Docker
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
Ce guide explique comment installer et configurer Misskey avec Docker.
|
|
||||||
|
|
||||||
- [Version japonaise également disponible - Japanese version also available - 日本語版もあります](./docker.ja.md)
|
|
||||||
- [Version anglaise également disponible - English version also available - 英語版もあります](./docker.en.md)
|
|
||||||
- [Version Chinois simplifié également disponible - Simplified Chinese version also available - 简体中文版同样可用](./docker.zh.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* Télécharger Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Clone le dépôt de Misskey sur la branche master.
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
2. Naviguez dans le dossier du dépôt.
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
3. Checkout sur le tag de la [dernière version](https://github.com/misskey-dev/misskey/releases/latest).
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
*2.* Configuration de Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. `cp .config/example.yml .config/default.yml` Copiez le fichier `.config/example.yml` et renommez-le `default.yml`.
|
|
||||||
2. `cp .config/mongo_initdb_example.js .config/mongo_initdb.js` Copie le fichier `.config/mongo_initdb_example.js` et le renomme en `mongo_initdb.js`.
|
|
||||||
3. Editez `default.yml` et `mongo_initdb.js`.
|
|
||||||
|
|
||||||
*3.* Configurer Docker
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Editez `docker-compose.yml`.
|
|
||||||
|
|
||||||
*4.* Contruire Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Contruire l'image Docker avec:
|
|
||||||
|
|
||||||
`docker-compose build`
|
|
||||||
|
|
||||||
*5.* C'est tout !
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Parfait, Vous avez un environnement prêt pour démarrer Misskey.
|
|
||||||
|
|
||||||
### Lancer normalement
|
|
||||||
Utilisez la commande `docker-compose up -d`. GLHF!
|
|
||||||
|
|
||||||
### How to update your Misskey server to the latest version
|
|
||||||
1. `git stash`
|
|
||||||
2. `git checkout master`
|
|
||||||
3. `git pull`
|
|
||||||
4. `git stash pop`
|
|
||||||
5. `docker-compose build`
|
|
||||||
6. Consultez le [ChangeLog](../CHANGELOG.md) pour avoir les éventuelles informations de migration
|
|
||||||
7. `docker-compose stop && docker-compose up -d`
|
|
||||||
|
|
||||||
### Comment exécuter des [commandes](manage.fr.md)
|
|
||||||
`docker-compose run --rm web node built/tools/mark-admin @example`
|
|
||||||
|
|
||||||
### Configuration d'ElasticSearch (pour la fonction de recherche)
|
|
||||||
*1.* Préparation de l'environnement
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Permet de créer le dossier d'accueil de la base ElasticSearch aves les bons droits
|
|
||||||
|
|
||||||
`mkdir elasticsearch && chown 1000:1000 elasticsearch`
|
|
||||||
|
|
||||||
2. Augmente la valeur max du paramètre map_count du système (valeur minimum pour pouvoir lancer ES)
|
|
||||||
|
|
||||||
`sysctl -w vm.max_map_count=262144`
|
|
||||||
|
|
||||||
*2.* Après lancement du docker-compose, initialisation de la base ElasticSearch
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Connexion dans le conteneur web
|
|
||||||
|
|
||||||
`docker-compose -it web /bin/sh`
|
|
||||||
|
|
||||||
2. Ajout du paquet curl
|
|
||||||
|
|
||||||
`apk add curl`
|
|
||||||
|
|
||||||
3. Création de la base ES
|
|
||||||
|
|
||||||
`curl -X PUT "es:9200/misskey" -H 'Content-Type: application/json' -d'{ "settings" : { "index" : { } }}'`
|
|
||||||
|
|
||||||
4. `exit`
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
Si vous avez des questions ou des problèmes, n'hésitez pas à nous contacter !
|
|
@@ -1,97 +0,0 @@
|
|||||||
Dockerを使ったMisskey構築方法
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
このガイドはDockerを使ったMisskeyセットアップ方法について解説します。
|
|
||||||
|
|
||||||
- [英語版もあります - English version also available](./docker.en.md)
|
|
||||||
- [简体中文版同样可用 - Simplified Chinese version also available](./docker.zh.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* Misskeyのダウンロード
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. masterブランチからMisskeyレポジトリをクローン
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
2. misskeyディレクトリに移動
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
3. [最新のリリース](https://github.com/misskey-dev/misskey/releases/latest)を確認
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
*2.* 設定ファイルの作成と編集
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
下記コマンドで設定ファイルを作成してください。
|
|
||||||
|
|
||||||
```bash
|
|
||||||
cd .config
|
|
||||||
cp example.yml default.yml
|
|
||||||
cp docker_example.env docker.env
|
|
||||||
```
|
|
||||||
|
|
||||||
### `default.yml`の編集
|
|
||||||
|
|
||||||
非Docker環境と同じ様に編集してください。
|
|
||||||
ただし、Postgresql、RedisとElasticsearchのホストは`localhost`ではなく、`docker-compose.yml`で設定されたサービス名になっています。
|
|
||||||
標準設定では次の通りです。
|
|
||||||
|
|
||||||
| サービス | ホスト名 |
|
|
||||||
|---------------|---------|
|
|
||||||
| Postgresql |`db` |
|
|
||||||
| Redis |`redis` |
|
|
||||||
| Elasticsearch |`es` |
|
|
||||||
|
|
||||||
### `docker.env`の編集
|
|
||||||
|
|
||||||
このファイルはPostgresqlの設定を記述します。
|
|
||||||
最低限記述する必要がある設定は次の通りです。
|
|
||||||
|
|
||||||
| 設定 | 内容 |
|
|
||||||
|---------------------|--------------|
|
|
||||||
| `POSTGRES_PASSWORD` | パスワード |
|
|
||||||
| `POSTGRES_USER` | ユーザー名 |
|
|
||||||
| `POSTGRES_DB` | データベース名 |
|
|
||||||
|
|
||||||
*3.* Dockerの設定
|
|
||||||
----------------------------------------------------------------
|
|
||||||
`docker-compose.yml`を編集してください。
|
|
||||||
|
|
||||||
*4.* Misskeyのビルド
|
|
||||||
----------------------------------------------------------------
|
|
||||||
次のコマンドでMisskeyをビルドしてください:
|
|
||||||
|
|
||||||
`docker-compose build`
|
|
||||||
|
|
||||||
*5.* データベースを初期化
|
|
||||||
----------------------------------------------------------------
|
|
||||||
``` shell
|
|
||||||
docker-compose run --rm web yarn run init
|
|
||||||
```
|
|
||||||
|
|
||||||
*6.* 以上です!
|
|
||||||
----------------------------------------------------------------
|
|
||||||
お疲れ様でした。これでMisskeyを動かす準備は整いました。
|
|
||||||
|
|
||||||
### 通常起動
|
|
||||||
`docker-compose up -d`するだけです。GLHF!
|
|
||||||
|
|
||||||
### Misskeyを最新バージョンにアップデートする方法:
|
|
||||||
1. `git stash`
|
|
||||||
2. `git checkout master`
|
|
||||||
3. `git pull`
|
|
||||||
4. `git stash pop`
|
|
||||||
5. `docker-compose build`
|
|
||||||
6. [ChangeLog](../CHANGELOG.md)でマイグレーション情報を確認する
|
|
||||||
7. `docker-compose stop && docker-compose up -d`
|
|
||||||
|
|
||||||
### cliコマンドを実行する方法:
|
|
||||||
|
|
||||||
`docker-compose run --rm web node built/tools/mark-admin @example`
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
なにかお困りのことがありましたらお気軽にご連絡ください。
|
|
@@ -1,96 +0,0 @@
|
|||||||
Docker 部署指南
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
这份指南描述了如何使用Docker安装并设置 Misskey 。
|
|
||||||
|
|
||||||
- [日本語版もあります - Japanese version also available](./docker.ja.md)
|
|
||||||
- [英語版もあります - English version also available](./docker.en.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* 下载 Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. 克隆 Misskey 项目的 master 分支。
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
2. 进入 misskey 文件夹。
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
3. 检查 [最新发布版](https://github.com/misskey-dev/misskey/releases/latest) 标签。
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
*2.* 配置 Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
可以按照如下方式创建配置文件:
|
|
||||||
|
|
||||||
``` bash
|
|
||||||
cd .config
|
|
||||||
cp example.yml default.yml
|
|
||||||
cp docker_example.env docker.env
|
|
||||||
```
|
|
||||||
|
|
||||||
### `default.yml`
|
|
||||||
|
|
||||||
这个文件的编辑工作基本与非 Docker 环境的版本相同。
|
|
||||||
但请注意, Postgresql、 Redis 和 Elasticsearch 的 **主机名(hostname)** 配置不应该是 `localhost` ,它们被设置在 `docker-compose.yml` 文件中。
|
|
||||||
以下是默认的主机名:
|
|
||||||
|
|
||||||
| 服务 | 主机名 |
|
|
||||||
|---------------|----------|
|
|
||||||
| Postgresql | `db` |
|
|
||||||
| Redis | `redis` |
|
|
||||||
| Elasticsearch | `es` |
|
|
||||||
|
|
||||||
### `docker.env`
|
|
||||||
|
|
||||||
在这个文件中配置 Postgresql 。
|
|
||||||
至少需要如下这些配置:
|
|
||||||
|
|
||||||
| 名称 | 描述 |
|
|
||||||
|---------------------|---------------|
|
|
||||||
| `POSTGRES_PASSWORD` | 数据库密码 |
|
|
||||||
| `POSTGRES_USER` | 数据库用户名 |
|
|
||||||
| `POSTGRES_DB` | 数据库名 |
|
|
||||||
|
|
||||||
*3.* 配置 Docker
|
|
||||||
----------------------------------------------------------------
|
|
||||||
编辑 `docker-compose.yml` 文件。
|
|
||||||
|
|
||||||
*4.* 构建 Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
使用如下的方式构建Misskey:
|
|
||||||
|
|
||||||
`docker-compose build`
|
|
||||||
|
|
||||||
*5.* 初始化数据库
|
|
||||||
----------------------------------------------------------------
|
|
||||||
``` bash
|
|
||||||
docker-compose run --rm web yarn run init
|
|
||||||
```
|
|
||||||
|
|
||||||
*6.* 完成了!
|
|
||||||
----------------------------------------------------------------
|
|
||||||
干得不错!现在您拥有了一个可以运行Misskey的环境啦。
|
|
||||||
|
|
||||||
### 正常启动
|
|
||||||
只需要 `docker-compose up -d` 即可。玩得愉快!
|
|
||||||
|
|
||||||
### 如何将您的 Misskey 服务器升级至最新版本
|
|
||||||
1. `git stash`
|
|
||||||
2. `git checkout master`
|
|
||||||
3. `git pull`
|
|
||||||
4. `git stash pop`
|
|
||||||
5. `docker-compose build`
|
|
||||||
6. 检查 [更新日志](../CHANGELOG.md) 以获取升级迁移信息。
|
|
||||||
7. `docker-compose stop && docker-compose up -d`
|
|
||||||
|
|
||||||
### 如何执行 [控制台指令](manage.zh.md):
|
|
||||||
`docker-compose run --rm web node built/tools/mark-admin @example`
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
如果您有任何疑问或是困惑,欢迎与我们联系!
|
|
@@ -1,71 +0,0 @@
|
|||||||
# Sample nginx configuration for Misskey
|
|
||||||
#
|
|
||||||
# 1. Replace example.tld to your domain
|
|
||||||
# 2. Copy to /etc/nginx/sites-available/ and then symlink from /etc/nginx/sites-enabled/
|
|
||||||
# or copy to /etc/nginx/conf.d/
|
|
||||||
|
|
||||||
# For WebSocket
|
|
||||||
map $http_upgrade $connection_upgrade {
|
|
||||||
default upgrade;
|
|
||||||
'' close;
|
|
||||||
}
|
|
||||||
|
|
||||||
proxy_cache_path /tmp/nginx_cache levels=1:2 keys_zone=cache1:16m max_size=1g inactive=720m use_temp_path=off;
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen 80;
|
|
||||||
listen [::]:80;
|
|
||||||
server_name example.tld;
|
|
||||||
|
|
||||||
# For SSL domain validation
|
|
||||||
root /var/www/html;
|
|
||||||
location /.well-known/acme-challenge/ { allow all; }
|
|
||||||
location /.well-known/pki-validation/ { allow all; }
|
|
||||||
location / { return 301 https://$server_name$request_uri; }
|
|
||||||
}
|
|
||||||
|
|
||||||
server {
|
|
||||||
listen 443 ssl http2;
|
|
||||||
listen [::]:443 ssl http2;
|
|
||||||
server_name example.tld;
|
|
||||||
ssl_session_cache shared:ssl_session_cache:10m;
|
|
||||||
|
|
||||||
# To use Let's Encrypt certificate
|
|
||||||
ssl_certificate /etc/letsencrypt/live/example.tld/fullchain.pem;
|
|
||||||
ssl_certificate_key /etc/letsencrypt/live/example.tld/privkey.pem;
|
|
||||||
|
|
||||||
# To use Debian/Ubuntu's self-signed certificate (For testing or before issuing a certificate)
|
|
||||||
#ssl_certificate /etc/ssl/certs/ssl-cert-snakeoil.pem;
|
|
||||||
#ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
|
|
||||||
|
|
||||||
# SSL protocol settings
|
|
||||||
ssl_protocols TLSv1.2;
|
|
||||||
ssl_ciphers ECDHE-ECDSA-AES256-GCM-SHA384:ECDHE-RSA-AES256-GCM-SHA384:ECDHE-ECDSA-AES128-GCM-SHA256:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-ECDSA-AES256-SHA384:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:AES128-SHA;
|
|
||||||
ssl_prefer_server_ciphers on;
|
|
||||||
|
|
||||||
# Change to your upload limit
|
|
||||||
client_max_body_size 80m;
|
|
||||||
|
|
||||||
# Proxy to Node
|
|
||||||
location / {
|
|
||||||
proxy_pass http://127.0.0.1:3000;
|
|
||||||
proxy_set_header Host $host;
|
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_redirect off;
|
|
||||||
|
|
||||||
# If it's behind another reverse proxy or CDN, remove the following.
|
|
||||||
proxy_set_header X-Real-IP $remote_addr;
|
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
|
||||||
proxy_set_header X-Forwarded-Proto https;
|
|
||||||
|
|
||||||
# For WebSocket
|
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
|
||||||
proxy_set_header Connection $connection_upgrade;
|
|
||||||
|
|
||||||
# Cache settings
|
|
||||||
proxy_cache cache1;
|
|
||||||
proxy_cache_lock on;
|
|
||||||
proxy_cache_use_stale updating;
|
|
||||||
add_header X-Cache $upstream_cache_status;
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,14 +0,0 @@
|
|||||||
# Management guide
|
|
||||||
|
|
||||||
## Check the status of the job queue
|
|
||||||
coming soon
|
|
||||||
|
|
||||||
## Mark as 'admin' user
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin (Username)
|
|
||||||
```
|
|
||||||
|
|
||||||
e.g.
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin @syuilo
|
|
||||||
```
|
|
@@ -1,14 +0,0 @@
|
|||||||
# Guide d'administration
|
|
||||||
|
|
||||||
## Vérifier le status de la file d'attente des taches
|
|
||||||
coming soon
|
|
||||||
|
|
||||||
## Marquer un utilisateur en tant que 'admin'
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin (nom d'utilisateur)
|
|
||||||
```
|
|
||||||
|
|
||||||
Exemple :
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin @syuilo
|
|
||||||
```
|
|
@@ -1,14 +0,0 @@
|
|||||||
# 運営ガイド
|
|
||||||
|
|
||||||
## ジョブキューの状態を調べる
|
|
||||||
coming soon
|
|
||||||
|
|
||||||
## 管理者ユーザーを設定する
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin (ユーザー名)
|
|
||||||
```
|
|
||||||
|
|
||||||
例:
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin @syuilo
|
|
||||||
```
|
|
@@ -1,14 +0,0 @@
|
|||||||
# 运营指南
|
|
||||||
|
|
||||||
## 检查任务队列的状态
|
|
||||||
即将到来……
|
|
||||||
|
|
||||||
## 设置用户为管理员
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin (用户名)
|
|
||||||
```
|
|
||||||
|
|
||||||
样例
|
|
||||||
``` shell
|
|
||||||
node built/tools/mark-admin @syuilo
|
|
||||||
```
|
|
146
docs/setup.en.md
146
docs/setup.en.md
@@ -1,146 +0,0 @@
|
|||||||
Misskey Setup and Installation Guide
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
We thank you for your interest in setting up your Misskey server!
|
|
||||||
This guide describes how to install and setup Misskey.
|
|
||||||
|
|
||||||
- [Japanese version also available - 日本語版もあります](./setup.ja.md)
|
|
||||||
- [Simplified Chinese version also available - 简体中文版同样可用](./setup.zh.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* Create Misskey user
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Running misskey as root is not a good idea so we create a user for that.
|
|
||||||
In debian for exemple :
|
|
||||||
|
|
||||||
```
|
|
||||||
adduser --disabled-password --disabled-login misskey
|
|
||||||
```
|
|
||||||
|
|
||||||
*2.* Install dependencies
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Please install and setup these softwares:
|
|
||||||
|
|
||||||
#### Dependencies :package:
|
|
||||||
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** (>= 10)
|
|
||||||
* **[Redis](https://redis.io/)**
|
|
||||||
|
|
||||||
##### Optional
|
|
||||||
* [Yarn](https://yarnpkg.com/) *Optional but recommended for security reason. If you won't install it, use `npx yarn` instead of `yarn`.*
|
|
||||||
* [Elasticsearch](https://www.elastic.co/) - required to enable the search feature
|
|
||||||
* [FFmpeg](https://www.ffmpeg.org/)
|
|
||||||
|
|
||||||
*3.* Install Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Connect to misskey user.
|
|
||||||
|
|
||||||
`su - misskey`
|
|
||||||
|
|
||||||
2. Clone the misskey repo from master branch.
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
3. Navigate to misskey directory
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
4. Checkout to the [latest release](https://github.com/misskey-dev/misskey/releases/latest)
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
5. Install misskey dependencies.
|
|
||||||
|
|
||||||
`yarn`
|
|
||||||
|
|
||||||
*4.* Configure Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Copy the `.config/example.yml` and rename it to `default.yml`.
|
|
||||||
|
|
||||||
`cp .config/example.yml .config/default.yml`
|
|
||||||
|
|
||||||
2. Edit `default.yml`
|
|
||||||
|
|
||||||
*5.* Build Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
Build misskey with the following:
|
|
||||||
|
|
||||||
`NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
If you're on Debian, you will need to install the `build-essential`, `python` package.
|
|
||||||
|
|
||||||
If you're still encountering errors about some modules, use node-gyp:
|
|
||||||
|
|
||||||
1. `npx node-gyp configure`
|
|
||||||
2. `npx node-gyp build`
|
|
||||||
3. `NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
*6.* Init DB
|
|
||||||
----------------------------------------------------------------
|
|
||||||
``` shell
|
|
||||||
yarn run init
|
|
||||||
```
|
|
||||||
|
|
||||||
*7.* That is it.
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Well done! Now, you have an environment that run to Misskey.
|
|
||||||
|
|
||||||
### Launch normally
|
|
||||||
Just `NODE_ENV=production npm start`. GLHF!
|
|
||||||
|
|
||||||
### Launch with systemd
|
|
||||||
|
|
||||||
1. Create a systemd service here
|
|
||||||
|
|
||||||
`/etc/systemd/system/misskey.service`
|
|
||||||
|
|
||||||
2. Edit it, and paste this and save:
|
|
||||||
|
|
||||||
```
|
|
||||||
[Unit]
|
|
||||||
Description=Misskey daemon
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=misskey
|
|
||||||
ExecStart=/usr/bin/npm start
|
|
||||||
WorkingDirectory=/home/misskey/misskey
|
|
||||||
Environment="NODE_ENV=production"
|
|
||||||
TimeoutSec=60
|
|
||||||
StandardOutput=syslog
|
|
||||||
StandardError=syslog
|
|
||||||
SyslogIdentifier=misskey
|
|
||||||
Restart=always
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
```
|
|
||||||
|
|
||||||
3. Reload systemd and enable the misskey service.
|
|
||||||
|
|
||||||
`systemctl daemon-reload ; systemctl enable misskey`
|
|
||||||
|
|
||||||
4. Start the misskey service.
|
|
||||||
|
|
||||||
`systemctl start misskey`
|
|
||||||
|
|
||||||
You can check if the service is running with `systemctl status misskey`.
|
|
||||||
|
|
||||||
### How to update your Misskey server to the latest version
|
|
||||||
1. `git checkout master`
|
|
||||||
2. `git pull`
|
|
||||||
3. `yarn install`
|
|
||||||
4. `NODE_ENV=production yarn build`
|
|
||||||
5. `yarn migrate`
|
|
||||||
6. Restart your Misskey process to apply changes
|
|
||||||
7. Enjoy
|
|
||||||
|
|
||||||
If you encounter any problems with updating, please try the following:
|
|
||||||
1. `yarn clean` or `yarn cleanall`
|
|
||||||
2. Retry update (Don't forget `yarn install`
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
If you have any questions or troubles, feel free to contact us!
|
|
135
docs/setup.fr.md
135
docs/setup.fr.md
@@ -1,135 +0,0 @@
|
|||||||
Guide d'installation et de configuration de Misskey
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
Nous vous remerçions de l'intrêt que vous manifestez pour l'installation de votre propre instance Misskey !
|
|
||||||
Ce guide décrit les étapes à suivre afin d'installer et de configurer une instance Misskey.
|
|
||||||
|
|
||||||
- [La version en japonnais est également disponible sur - 日本語版もあります](./setup.ja.md)
|
|
||||||
- [Version anglaise également disponible - English version also available - 英語版もあります](./setup.en.md)
|
|
||||||
- [Version Chinois simplifié également disponible - Simplified Chinese version also available - 简体中文版同样可用](./setup.zh.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* Création de l'utilisateur Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Executer misskey en tant que super-utilisateur étant une mauvaise idée, nous allons créer un utilisateur dédié.
|
|
||||||
Sous Debian, par exemple :
|
|
||||||
|
|
||||||
```
|
|
||||||
adduser --disabled-password --disabled-login misskey
|
|
||||||
```
|
|
||||||
|
|
||||||
*2.* Installation des dépendances
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Installez les paquets suivants :
|
|
||||||
|
|
||||||
#### Dépendences :package:
|
|
||||||
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** (>= 10)
|
|
||||||
* **[Redis](https://redis.io/)**
|
|
||||||
|
|
||||||
##### Optionnels
|
|
||||||
* [Yarn](https://yarnpkg.com/) - *recommander pour des raisons de sécurité. Si vous ne l'installez pas, utilisez `npx yarn` au lieu de` yarn`.*
|
|
||||||
* [Elasticsearch](https://www.elastic.co/) - *requis pour pouvoir activer la fonctionnalité de recherche.*
|
|
||||||
* [FFmpeg](https://www.ffmpeg.org/)
|
|
||||||
|
|
||||||
*3.* Installation de Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Basculez vers l'utilisateur misskey.
|
|
||||||
|
|
||||||
`su - misskey`
|
|
||||||
|
|
||||||
2. Clonez la branche master du dépôt misskey.
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
3. Accédez au dossier misskey.
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
4. Checkout sur le tag de la [version la plus récente](https://github.com/misskey-dev/misskey/releases/latest)
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
5. Installez les dépendances de misskey.
|
|
||||||
|
|
||||||
`yarn install`
|
|
||||||
|
|
||||||
*4.* Création du fichier de configuration
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. Copiez le fichier `.config/example.yml` et renommez-le`default.yml`.
|
|
||||||
|
|
||||||
`cp .config/example.yml .config/default.yml`
|
|
||||||
|
|
||||||
2. Editez le fichier `default.yml`
|
|
||||||
|
|
||||||
*5.* Construction de Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
Construisez Misskey comme ceci :
|
|
||||||
|
|
||||||
`NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
Si vous êtes sous Debian, vous serez amené à installer les paquets `build-essential` et `python`.
|
|
||||||
|
|
||||||
Si vous rencontrez des erreurs concernant certains modules, utilisez node-gyp:
|
|
||||||
|
|
||||||
1. `npx node-gyp configure`
|
|
||||||
2. `npx node-gyp build`
|
|
||||||
3. `NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
*6.* C'est tout.
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Excellent ! Maintenant, vous avez un environnement prêt pour lancer Misskey
|
|
||||||
|
|
||||||
### Lancement conventionnel
|
|
||||||
Lancez tout simplement `NODE_ENV=production yarn start`. Bonne chance et amusez-vous bien !
|
|
||||||
|
|
||||||
### Démarrage avec systemd
|
|
||||||
|
|
||||||
1. Créez un service systemd sur
|
|
||||||
|
|
||||||
`/etc/systemd/system/misskey.service`
|
|
||||||
|
|
||||||
2. Editez-le puis copiez et coller ceci dans le fichier :
|
|
||||||
|
|
||||||
```
|
|
||||||
[Unit]
|
|
||||||
Description=Misskey daemon
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=misskey
|
|
||||||
ExecStart=/usr/bin/npm start
|
|
||||||
WorkingDirectory=/home/misskey/misskey
|
|
||||||
Environment="NODE_ENV=production"
|
|
||||||
TimeoutSec=60
|
|
||||||
StandardOutput=syslog
|
|
||||||
StandardError=syslog
|
|
||||||
SyslogIdentifier=misskey
|
|
||||||
Restart=always
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
```
|
|
||||||
|
|
||||||
3. Redémarre systemd et active le service misskey.
|
|
||||||
|
|
||||||
`systemctl daemon-reload ; systemctl enable misskey`
|
|
||||||
|
|
||||||
4. Démarre le service misskey.
|
|
||||||
|
|
||||||
`systemctl start misskey`
|
|
||||||
|
|
||||||
Vous pouvez vérifier si le service a démarré en utilisant la commande `systemctl status misskey`.
|
|
||||||
|
|
||||||
### Méthode de mise à jour vers la plus récente version de Misskey
|
|
||||||
1. `git checkout master`
|
|
||||||
2. `git pull`
|
|
||||||
3. `yarn install`
|
|
||||||
4. `NODE_ENV=production yarn build`
|
|
||||||
5. `yarn migrate`
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
Si vous rencontrez des difficultés ou avez d'autres questions, n'hésitez pas à nous contacter !
|
|
144
docs/setup.ja.md
144
docs/setup.ja.md
@@ -1,144 +0,0 @@
|
|||||||
Misskey構築の手引き
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
Misskeyサーバーの構築にご関心をお寄せいただきありがとうございます!
|
|
||||||
このガイドではMisskeyのインストール・セットアップ方法について解説します。
|
|
||||||
|
|
||||||
- [英語版もあります - English version also available](./setup.en.md)
|
|
||||||
- [简体中文版同样可用 - Simplified Chinese version also available](./setup.zh.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* Misskeyユーザーの作成
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Misskeyはrootユーザーで実行しない方がよいため、代わりにユーザーを作成します。
|
|
||||||
Debianの例:
|
|
||||||
|
|
||||||
```
|
|
||||||
adduser --disabled-password --disabled-login misskey
|
|
||||||
```
|
|
||||||
|
|
||||||
*2.* 依存関係をインストールする
|
|
||||||
----------------------------------------------------------------
|
|
||||||
これらのソフトウェアをインストール・設定してください:
|
|
||||||
|
|
||||||
#### 依存関係 :package:
|
|
||||||
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** (10以上)
|
|
||||||
* **[Redis](https://redis.io/)**
|
|
||||||
|
|
||||||
##### オプション
|
|
||||||
* [Yarn](https://yarnpkg.com/)
|
|
||||||
* セキュリティの観点から推奨されます。 yarn をインストールしない方針の場合は、文章中の `yarn` を適宜 `npx yarn` と読み替えてください。
|
|
||||||
* [Elasticsearch](https://www.elastic.co/)
|
|
||||||
* 検索機能を有効にするためにはインストールが必要です。
|
|
||||||
* [FFmpeg](https://www.ffmpeg.org/)
|
|
||||||
|
|
||||||
*3.* Misskeyのインストール
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. misskeyユーザーを使用
|
|
||||||
|
|
||||||
`su - misskey`
|
|
||||||
|
|
||||||
2. masterブランチからMisskeyレポジトリをクローン
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
3. misskeyディレクトリに移動
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
4. [最新のリリース](https://github.com/misskey-dev/misskey/releases/latest)を確認
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
5. Misskeyの依存パッケージをインストール
|
|
||||||
|
|
||||||
`yarn install`
|
|
||||||
|
|
||||||
*4.* 設定ファイルを作成する
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. `.config/example.yml`をコピーし名前を`default.yml`にする。
|
|
||||||
|
|
||||||
`cp .config/example.yml .config/default.yml`
|
|
||||||
|
|
||||||
2. `default.yml` を編集する。
|
|
||||||
|
|
||||||
*5.* Misskeyのビルド
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
次のコマンドでMisskeyをビルドしてください:
|
|
||||||
|
|
||||||
`NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
Debianをお使いであれば、`build-essential`パッケージをインストールする必要があります。
|
|
||||||
|
|
||||||
何らかのモジュールでエラーが発生する場合はnode-gypを使ってください:
|
|
||||||
1. `npx node-gyp configure`
|
|
||||||
2. `npx node-gyp build`
|
|
||||||
3. `NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
*6.* データベースを初期化
|
|
||||||
----------------------------------------------------------------
|
|
||||||
``` shell
|
|
||||||
yarn run init
|
|
||||||
```
|
|
||||||
|
|
||||||
*7.* 以上です!
|
|
||||||
----------------------------------------------------------------
|
|
||||||
お疲れ様でした。これでMisskeyを動かす準備は整いました。
|
|
||||||
|
|
||||||
### 通常起動
|
|
||||||
`NODE_ENV=production yarn start`するだけです。GLHF!
|
|
||||||
|
|
||||||
### systemdを用いた起動
|
|
||||||
1. systemdサービスのファイルを作成
|
|
||||||
|
|
||||||
`/etc/systemd/system/misskey.service`
|
|
||||||
|
|
||||||
2. エディタで開き、以下のコードを貼り付けて保存:
|
|
||||||
|
|
||||||
```
|
|
||||||
[Unit]
|
|
||||||
Description=Misskey daemon
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=misskey
|
|
||||||
ExecStart=/usr/bin/npm start
|
|
||||||
WorkingDirectory=/home/misskey/misskey
|
|
||||||
Environment="NODE_ENV=production"
|
|
||||||
TimeoutSec=60
|
|
||||||
StandardOutput=syslog
|
|
||||||
StandardError=syslog
|
|
||||||
SyslogIdentifier=misskey
|
|
||||||
Restart=always
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
```
|
|
||||||
|
|
||||||
CentOSで1024以下のポートを使用してMisskeyを使用する場合は`ExecStart=/usr/bin/sudo /usr/bin/npm start`に変更する必要があります。
|
|
||||||
|
|
||||||
3. systemdを再読み込みしmisskeyサービスを有効化
|
|
||||||
|
|
||||||
`systemctl daemon-reload; systemctl enable misskey`
|
|
||||||
|
|
||||||
4. misskeyサービスの起動
|
|
||||||
|
|
||||||
`systemctl start misskey`
|
|
||||||
|
|
||||||
`systemctl status misskey`と入力すると、サービスの状態を調べることができます。
|
|
||||||
|
|
||||||
### Misskeyを最新バージョンにアップデートする方法:
|
|
||||||
1. `git checkout master`
|
|
||||||
2. `git pull`
|
|
||||||
3. `yarn install`
|
|
||||||
4. `NODE_ENV=production yarn build`
|
|
||||||
5. `yarn migrate`
|
|
||||||
|
|
||||||
なにか問題が発生した場合は、`yarn clean`または`yarn cleanall`すると直る場合があります。
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
なにかお困りのことがありましたらお気軽にご連絡ください。
|
|
146
docs/setup.zh.md
146
docs/setup.zh.md
@@ -1,146 +0,0 @@
|
|||||||
Misskey 设置和安装指南
|
|
||||||
================================================================
|
|
||||||
|
|
||||||
非常感谢您对构建 Misskey 服务器的关注!
|
|
||||||
这份指南描述了 Misskey 的安装与设置流程。
|
|
||||||
|
|
||||||
- [日本語版もあります - Japanese version also available](./setup.ja.md)
|
|
||||||
- [英語版もあります - English version also available](./setup.en.md)
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
*1.* 创建 Misskey 用户
|
|
||||||
----------------------------------------------------------------
|
|
||||||
直接使用 root 用户来运行 misskey 也许并不是一个好主意,因此我们有必要创建一个专用的用户。
|
|
||||||
以 Debian 为例:
|
|
||||||
|
|
||||||
``` bash
|
|
||||||
adduser --disabled-password --disabled-login misskey
|
|
||||||
```
|
|
||||||
|
|
||||||
*2.* 安装依赖
|
|
||||||
----------------------------------------------------------------
|
|
||||||
请安装并设置如下这些软件:
|
|
||||||
|
|
||||||
#### Dependencies :package:
|
|
||||||
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** (>= 10)
|
|
||||||
* **[Redis](https://redis.io/)**
|
|
||||||
|
|
||||||
##### Optional
|
|
||||||
* [Yarn](https://yarnpkg.com/) *可选,但出于安全因素考虑还是推荐安装。如果您没有安装, 您需要使用 `npx yarn` 来代替 `yarn`.*
|
|
||||||
* [Elasticsearch](https://www.elastic.co/) - 为了启用搜索功能,这个搜索引擎是有必要的。
|
|
||||||
* [FFmpeg](https://www.ffmpeg.org/)
|
|
||||||
|
|
||||||
*3.* 安装 Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. 连接至 misskey 用户.
|
|
||||||
|
|
||||||
`su - misskey`
|
|
||||||
|
|
||||||
2. 克隆 Misskey 项目的 master 分支。
|
|
||||||
|
|
||||||
`git clone -b master git://github.com/misskey-dev/misskey.git`
|
|
||||||
|
|
||||||
3. 进入 misskey 文件夹。
|
|
||||||
|
|
||||||
`cd misskey`
|
|
||||||
|
|
||||||
4. 检查 [最新发布版](https://github.com/misskey-dev/misskey/releases/latest) 标签。
|
|
||||||
|
|
||||||
`git checkout master`
|
|
||||||
|
|
||||||
5. 安装 Misskey 的依赖。
|
|
||||||
|
|
||||||
`yarn`
|
|
||||||
|
|
||||||
*4.* 配置 Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
1. 复制 `.config/example.yml` 并重命名为 `default.yml`。
|
|
||||||
|
|
||||||
`cp .config/example.yml .config/default.yml`
|
|
||||||
|
|
||||||
2. 编辑 `default.yml`
|
|
||||||
|
|
||||||
*5.* 构建 Misskey
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
使用如下的指令构建 Misskey :
|
|
||||||
|
|
||||||
`NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
如果您使用的是 Debian , 您需要安装 `build-essential`, `python` 环境包。
|
|
||||||
|
|
||||||
如果您仍然遇到有关某些模块的错误,您可以使用 node-gyp:
|
|
||||||
|
|
||||||
1. `npx node-gyp configure`
|
|
||||||
2. `npx node-gyp build`
|
|
||||||
3. `NODE_ENV=production yarn build`
|
|
||||||
|
|
||||||
*6.* 初始化数据库
|
|
||||||
----------------------------------------------------------------
|
|
||||||
``` bash
|
|
||||||
yarn run init
|
|
||||||
```
|
|
||||||
|
|
||||||
*7.* 完成了!
|
|
||||||
----------------------------------------------------------------
|
|
||||||
干得不错!现在您拥有了一个可以运行Misskey的环境啦。
|
|
||||||
|
|
||||||
### 正常启动
|
|
||||||
只需要 `NODE_ENV=production npm start` 即可。玩得愉快!
|
|
||||||
|
|
||||||
### 使用 systemd 来启动
|
|
||||||
|
|
||||||
1. 在此处创建一个 systemd 服务:
|
|
||||||
|
|
||||||
`/etc/systemd/system/misskey.service`
|
|
||||||
|
|
||||||
2. 编辑它,粘贴如下内容并保存:
|
|
||||||
|
|
||||||
```
|
|
||||||
[Unit]
|
|
||||||
Description=Misskey daemon
|
|
||||||
|
|
||||||
[Service]
|
|
||||||
Type=simple
|
|
||||||
User=misskey
|
|
||||||
ExecStart=/usr/bin/npm start
|
|
||||||
WorkingDirectory=/home/misskey/misskey
|
|
||||||
Environment="NODE_ENV=production"
|
|
||||||
TimeoutSec=60
|
|
||||||
StandardOutput=syslog
|
|
||||||
StandardError=syslog
|
|
||||||
SyslogIdentifier=misskey
|
|
||||||
Restart=always
|
|
||||||
|
|
||||||
[Install]
|
|
||||||
WantedBy=multi-user.target
|
|
||||||
```
|
|
||||||
|
|
||||||
3. 重启 systemd 并设置 misskey 服务自动启动:
|
|
||||||
|
|
||||||
`systemctl daemon-reload ; systemctl enable misskey`
|
|
||||||
|
|
||||||
4. 启动 misskey 服务:
|
|
||||||
|
|
||||||
`systemctl start misskey`
|
|
||||||
|
|
||||||
您可以使用 `systemctl status misskey` 来检查服务是否正在运行。
|
|
||||||
|
|
||||||
### 如何将您的 Misskey 服务器升级至最新版本
|
|
||||||
1. `git checkout master`
|
|
||||||
2. `git pull`
|
|
||||||
3. `yarn install`
|
|
||||||
4. `NODE_ENV=production yarn build`
|
|
||||||
5. `yarn migrate`
|
|
||||||
6. 重启您的 Misskey 进程来应用改变。
|
|
||||||
7. 尽情享受吧!
|
|
||||||
|
|
||||||
如果您在更新时遇到任何问题,请尝试以下操作:
|
|
||||||
1. `yarn clean` 或是 `yarn cleanall`
|
|
||||||
2. 重试升级 (请不要忘记 `yarn install` )
|
|
||||||
|
|
||||||
----------------------------------------------------------------
|
|
||||||
|
|
||||||
如果您有任何疑问或是困惑,欢迎与我们联系!
|
|
62
gulpfile.js
Normal file
62
gulpfile.js
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
/**
|
||||||
|
* Gulp tasks
|
||||||
|
*/
|
||||||
|
|
||||||
|
const fs = require('fs');
|
||||||
|
const gulp = require('gulp');
|
||||||
|
const replace = require('gulp-replace');
|
||||||
|
const terser = require('gulp-terser');
|
||||||
|
const cssnano = require('gulp-cssnano');
|
||||||
|
|
||||||
|
const locales = require('./locales');
|
||||||
|
const meta = require('./package.json');
|
||||||
|
|
||||||
|
gulp.task('copy:backend:views', () =>
|
||||||
|
gulp.src('./packages/backend/src/server/web/views/**/*').pipe(gulp.dest('./packages/backend/built/server/web/views'))
|
||||||
|
);
|
||||||
|
|
||||||
|
gulp.task('copy:client:fonts', () =>
|
||||||
|
gulp.src('./packages/client/node_modules/three/examples/fonts/**/*').pipe(gulp.dest('./built/_client_dist_/fonts/'))
|
||||||
|
);
|
||||||
|
|
||||||
|
gulp.task('copy:client:locales', cb => {
|
||||||
|
fs.mkdirSync('./built/_client_dist_/locales', { recursive: true });
|
||||||
|
|
||||||
|
const v = { '_version_': meta.version };
|
||||||
|
|
||||||
|
for (const [lang, locale] of Object.entries(locales)) {
|
||||||
|
fs.writeFileSync(`./built/_client_dist_/locales/${lang}.${meta.version}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8');
|
||||||
|
}
|
||||||
|
|
||||||
|
cb();
|
||||||
|
});
|
||||||
|
|
||||||
|
gulp.task('build:backend:script', () => {
|
||||||
|
return gulp.src(['./packages/backend/src/server/web/boot.js', './packages/backend/src/server/web/bios.js', './packages/backend/src/server/web/cli.js'])
|
||||||
|
.pipe(replace('VERSION', JSON.stringify(meta.version)))
|
||||||
|
.pipe(replace('LANGS', JSON.stringify(Object.keys(locales))))
|
||||||
|
.pipe(terser({
|
||||||
|
toplevel: true
|
||||||
|
}))
|
||||||
|
.pipe(gulp.dest('./packages/backend/built/server/web/'));
|
||||||
|
});
|
||||||
|
|
||||||
|
gulp.task('build:backend:style', () => {
|
||||||
|
return gulp.src(['./packages/backend/src/server/web/style.css', './packages/backend/src/server/web/bios.css', './packages/backend/src/server/web/cli.css'])
|
||||||
|
.pipe(cssnano({
|
||||||
|
zindex: false
|
||||||
|
}))
|
||||||
|
.pipe(gulp.dest('./packages/backend/built/server/web/'));
|
||||||
|
});
|
||||||
|
|
||||||
|
gulp.task('build', gulp.parallel(
|
||||||
|
'copy:client:locales', 'copy:backend:views', 'build:backend:script', 'build:backend:style', 'copy:client:fonts'
|
||||||
|
));
|
||||||
|
|
||||||
|
gulp.task('default', gulp.task('build'));
|
||||||
|
|
||||||
|
gulp.task('watch', () => {
|
||||||
|
gulp.watch([
|
||||||
|
'./packages/*/src/**/*',
|
||||||
|
], { ignoreInitial: false }, gulp.task('build'));
|
||||||
|
});
|
80
gulpfile.ts
80
gulpfile.ts
@@ -1,80 +0,0 @@
|
|||||||
/**
|
|
||||||
* Gulp tasks
|
|
||||||
*/
|
|
||||||
|
|
||||||
import * as fs from 'fs';
|
|
||||||
import * as gulp from 'gulp';
|
|
||||||
import rimraf from 'rimraf';
|
|
||||||
const replace = require('gulp-replace');
|
|
||||||
const terser = require('gulp-terser');
|
|
||||||
const cssnano = require('gulp-cssnano');
|
|
||||||
|
|
||||||
const locales: { [x: string]: any } = require('./locales');
|
|
||||||
const meta = require('./package.json');
|
|
||||||
|
|
||||||
gulp.task('build:copy:views', () =>
|
|
||||||
gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/views'))
|
|
||||||
);
|
|
||||||
|
|
||||||
gulp.task('build:copy:fonts', () =>
|
|
||||||
gulp.src('./node_modules/three/examples/fonts/**/*').pipe(gulp.dest('./built/assets/fonts/'))
|
|
||||||
);
|
|
||||||
|
|
||||||
gulp.task('build:copy:locales', cb => {
|
|
||||||
fs.mkdirSync('./built/assets/locales', { recursive: true });
|
|
||||||
|
|
||||||
const v = { '_version_': meta.version };
|
|
||||||
|
|
||||||
for (const [lang, locale] of Object.entries(locales)) {
|
|
||||||
fs.writeFileSync(`./built/assets/locales/${lang}.${meta.version}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8');
|
|
||||||
}
|
|
||||||
|
|
||||||
cb();
|
|
||||||
});
|
|
||||||
|
|
||||||
gulp.task('build:client:script', () => {
|
|
||||||
return gulp.src(['./src/server/web/boot.js', './src/server/web/bios.js', './src/server/web/cli.js'])
|
|
||||||
.pipe(replace('VERSION', JSON.stringify(meta.version)))
|
|
||||||
.pipe(replace('LANGS', JSON.stringify(Object.keys(locales))))
|
|
||||||
.pipe(terser({
|
|
||||||
toplevel: true
|
|
||||||
}))
|
|
||||||
.pipe(gulp.dest('./built/server/web/'));
|
|
||||||
});
|
|
||||||
|
|
||||||
gulp.task('build:client:style', () => {
|
|
||||||
return gulp.src(['./src/server/web/style.css', './src/server/web/bios.css', './src/server/web/cli.css'])
|
|
||||||
.pipe(cssnano({
|
|
||||||
zindex: false
|
|
||||||
}))
|
|
||||||
.pipe(gulp.dest('./built/server/web/'));
|
|
||||||
});
|
|
||||||
|
|
||||||
gulp.task('build:copy', gulp.parallel('build:copy:locales', 'build:copy:views', 'build:client:script', 'build:client:style', 'build:copy:fonts', () =>
|
|
||||||
gulp.src([
|
|
||||||
'./src/emojilist.json',
|
|
||||||
'./src/**/assets/**/*',
|
|
||||||
'!./src/client/assets/**/*'
|
|
||||||
]).pipe(gulp.dest('./built/'))
|
|
||||||
));
|
|
||||||
|
|
||||||
gulp.task('clean', cb =>
|
|
||||||
rimraf('./built', cb)
|
|
||||||
);
|
|
||||||
|
|
||||||
gulp.task('cleanall', gulp.parallel('clean', cb =>
|
|
||||||
rimraf('./node_modules', cb)
|
|
||||||
));
|
|
||||||
|
|
||||||
gulp.task('build', gulp.parallel(
|
|
||||||
'build:copy',
|
|
||||||
));
|
|
||||||
|
|
||||||
gulp.task('default', gulp.task('build'));
|
|
||||||
|
|
||||||
gulp.task('watch', () => {
|
|
||||||
gulp.watch([
|
|
||||||
'./src/**/*',
|
|
||||||
'!./src/client/**/*'
|
|
||||||
], { ignoreInitial: false }, gulp.task('build'));
|
|
||||||
});
|
|
7
index.js
7
index.js
@@ -1,7 +0,0 @@
|
|||||||
const fs = require('fs');
|
|
||||||
|
|
||||||
if (fs.existsSync('./built')) {
|
|
||||||
require('./built').default();
|
|
||||||
} else {
|
|
||||||
console.log('Built code is not found. Probably an error occurred during a build or you just forgot to build.');
|
|
||||||
}
|
|
File diff suppressed because it is too large
Load Diff
@@ -52,6 +52,7 @@ searchUser: "Vyhledat uživatele"
|
|||||||
reply: "Odpovědět"
|
reply: "Odpovědět"
|
||||||
loadMore: "Zobrazit více"
|
loadMore: "Zobrazit více"
|
||||||
showMore: "Zobrazit více"
|
showMore: "Zobrazit více"
|
||||||
|
youGotNewFollower: "Máte nového následovníka"
|
||||||
mention: "Zmínění"
|
mention: "Zmínění"
|
||||||
mentions: "Zmínění"
|
mentions: "Zmínění"
|
||||||
importAndExport: "Import a export"
|
importAndExport: "Import a export"
|
||||||
@@ -163,6 +164,7 @@ clearQueue: "Vyčistit frontu"
|
|||||||
clearQueueConfirmTitle: "Jste si jisti že zrušit všechny úlohy ve frontě?"
|
clearQueueConfirmTitle: "Jste si jisti že zrušit všechny úlohy ve frontě?"
|
||||||
clearCachedFiles: "Vyprázdnit mezipaměť"
|
clearCachedFiles: "Vyprázdnit mezipaměť"
|
||||||
blockedInstances: "Blokované instance"
|
blockedInstances: "Blokované instance"
|
||||||
|
noUsers: "Žádní uživatelé"
|
||||||
editProfile: "Upravit můj profil"
|
editProfile: "Upravit můj profil"
|
||||||
pinLimitExceeded: "Nemůžete připnout další poznámky."
|
pinLimitExceeded: "Nemůžete připnout další poznámky."
|
||||||
intro: "Instalace Misskey byla dokončena! Prosím vytvořte admina."
|
intro: "Instalace Misskey byla dokončena! Prosím vytvořte admina."
|
||||||
@@ -170,6 +172,7 @@ done: "Hotovo"
|
|||||||
processing: "Zpracovávám"
|
processing: "Zpracovávám"
|
||||||
preview: "Náhled"
|
preview: "Náhled"
|
||||||
default: "Výchozí"
|
default: "Výchozí"
|
||||||
|
noCustomEmojis: "Bez Emoji"
|
||||||
blocked: "Blokováno"
|
blocked: "Blokováno"
|
||||||
suspended: "Suspendováno"
|
suspended: "Suspendováno"
|
||||||
all: "Vše"
|
all: "Vše"
|
||||||
@@ -402,6 +405,9 @@ smtpPass: "Heslo"
|
|||||||
clearCache: "Vyprázdnit mezipaměť"
|
clearCache: "Vyprázdnit mezipaměť"
|
||||||
info: "Informace"
|
info: "Informace"
|
||||||
user: "Uživatelé"
|
user: "Uživatelé"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "Máte nového následovníka"
|
||||||
_mfm:
|
_mfm:
|
||||||
mention: "Zmínění"
|
mention: "Zmínění"
|
||||||
quote: "Citovat"
|
quote: "Citovat"
|
||||||
@@ -464,6 +470,7 @@ _pages:
|
|||||||
types:
|
types:
|
||||||
array: "Seznamy"
|
array: "Seznamy"
|
||||||
_notification:
|
_notification:
|
||||||
|
youWereFollowed: "Máte nového následovníka"
|
||||||
youWereInvitedToGroup: "Pozvat do skupiny"
|
youWereInvitedToGroup: "Pozvat do skupiny"
|
||||||
_types:
|
_types:
|
||||||
follow: "Sledovaní"
|
follow: "Sledovaní"
|
||||||
|
@@ -1,14 +1,14 @@
|
|||||||
---
|
---
|
||||||
_lang_: "Deutsch"
|
_lang_: "Deutsch"
|
||||||
headlineMisskey: "Ein durch Notizen verbundenes Netzwerk"
|
headlineMisskey: "Ein durch Notizen verbundenes Netzwerk"
|
||||||
introMisskey: "Willkommen! Misskey ist eine dezentralisierte Open-Source Microblogging-Platform.\nVerfasse \"Notizen\" um mitzuteilen, was gerade passiert oder um Ereignisse mit Anderen zu teilen. 📡\nMit \"Reaktionen\" kannst du außerdem schnell deine Gefühle über Notizen anderer Benutzer zum Ausdruck bringen. 👍\nErforsche eine neue Welt! 🚀"
|
introMisskey: "Willkommen! Misskey ist eine dezentralisierte Open-Source Microblogging-Platform.\nVerfasse „Notizen“ um mitzuteilen, was gerade passiert oder um Ereignisse mit anderen zu teilen. 📡\nMit „Reaktionen“ kannst du außerdem schnell deine Gefühle über Notizen anderer Benutzer zum Ausdruck bringen. 👍\nEine neue Welt wartet auf dich! 🚀"
|
||||||
monthAndDay: "{day}/{month}"
|
monthAndDay: "{day}.{month}."
|
||||||
search: "Suchen"
|
search: "Suchen"
|
||||||
notifications: "Benachrichtigungen"
|
notifications: "Benachrichtigungen"
|
||||||
username: "Benutzername"
|
username: "Benutzername"
|
||||||
password: "Passwort"
|
password: "Passwort"
|
||||||
forgotPassword: "Passwort vergessen"
|
forgotPassword: "Passwort vergessen"
|
||||||
fetchingAsApObject: "Wird aus dem Fediverse angefragt..."
|
fetchingAsApObject: "Wird aus dem Fediverse angefragt …"
|
||||||
ok: "OK"
|
ok: "OK"
|
||||||
gotIt: "Verstanden!"
|
gotIt: "Verstanden!"
|
||||||
cancel: "Abbrechen"
|
cancel: "Abbrechen"
|
||||||
@@ -25,10 +25,10 @@ profile: "Profil"
|
|||||||
timeline: "Chronik"
|
timeline: "Chronik"
|
||||||
noAccountDescription: "Dieser Nutzer hat seine Profilbeschreibung noch nicht ausgefüllt."
|
noAccountDescription: "Dieser Nutzer hat seine Profilbeschreibung noch nicht ausgefüllt."
|
||||||
login: "Anmelden"
|
login: "Anmelden"
|
||||||
loggingIn: "Du wirst angemeldet..."
|
loggingIn: "Du wirst angemeldet …"
|
||||||
logout: "Abmelden"
|
logout: "Abmelden"
|
||||||
signup: "Registrieren"
|
signup: "Registrieren"
|
||||||
uploading: "Wird hochgeladen..."
|
uploading: "Wird hochgeladen …"
|
||||||
save: "Speichern"
|
save: "Speichern"
|
||||||
users: "Benutzer"
|
users: "Benutzer"
|
||||||
addUser: "Benutzer hinzufügen"
|
addUser: "Benutzer hinzufügen"
|
||||||
@@ -63,7 +63,7 @@ import: "Import"
|
|||||||
export: "Export"
|
export: "Export"
|
||||||
files: "Dateien"
|
files: "Dateien"
|
||||||
download: "Herunterladen"
|
download: "Herunterladen"
|
||||||
driveFileDeleteConfirm: "Möchtest du die Datei \"{name}\" wirklich löschen? Die zugehörige Notiz wird ebenso verschwinden."
|
driveFileDeleteConfirm: "Möchtest du die Datei „{name}“ wirklich löschen? Die zugehörige Notiz wird ebenso verschwinden."
|
||||||
unfollowConfirm: "Möchtest du {name} nicht mehr folgen?"
|
unfollowConfirm: "Möchtest du {name} nicht mehr folgen?"
|
||||||
exportRequested: "Du hast einen Export angefragt. Dies kann etwas Zeit in Anspruch nehmen. Sobald der Export abgeschlossen ist, wird er deiner Drive hinzugefügt."
|
exportRequested: "Du hast einen Export angefragt. Dies kann etwas Zeit in Anspruch nehmen. Sobald der Export abgeschlossen ist, wird er deiner Drive hinzugefügt."
|
||||||
importRequested: "Du hast einen Import angefragt. Dies kann etwas Zeit in Anspruch nehmen."
|
importRequested: "Du hast einen Import angefragt. Dies kann etwas Zeit in Anspruch nehmen."
|
||||||
@@ -80,7 +80,9 @@ error: "Fehler"
|
|||||||
somethingHappened: "Ein Fehler ist aufgetreten"
|
somethingHappened: "Ein Fehler ist aufgetreten"
|
||||||
retry: "Wiederholen"
|
retry: "Wiederholen"
|
||||||
pageLoadError: "Laden der Seite fehlgeschlagen."
|
pageLoadError: "Laden der Seite fehlgeschlagen."
|
||||||
pageLoadErrorDescription: "Dieser Fehler wird meist durch Netzwerkfehler oder den Browser-Cache verursacht. Versuche bitte den Browser-Cache zu leeren und es nach kurzer Zeit noch einmal zu probieren."
|
pageLoadErrorDescription: "Dieser Fehler wird meist durch Netzwerkfehler oder den Browser-Cache verursacht. Bitte leere den Cache oder versuche es nach einiger Zeit erneut."
|
||||||
|
serverIsDead: "Dieser Server antwortet nicht. Bitte warte einen Moment und versuche es dann erneut."
|
||||||
|
youShouldUpgradeClient: "Bitte aktualisiere diese Seite, um eine neuere Version deines Clients zu verwenden."
|
||||||
enterListName: "Name der Liste eingeben"
|
enterListName: "Name der Liste eingeben"
|
||||||
privacy: "Privatsphäre"
|
privacy: "Privatsphäre"
|
||||||
makeFollowManuallyApprove: "Follow-Anfragen benötigen Bestätigung"
|
makeFollowManuallyApprove: "Follow-Anfragen benötigen Bestätigung"
|
||||||
@@ -105,7 +107,7 @@ sensitive: "NSFW"
|
|||||||
add: "Hinzufügen"
|
add: "Hinzufügen"
|
||||||
reaction: "Reaktionen"
|
reaction: "Reaktionen"
|
||||||
reactionSettingDescription: "Wähle die Reaktionen aus, die in der Reaktionsauswahl angezeigt werden sollen."
|
reactionSettingDescription: "Wähle die Reaktionen aus, die in der Reaktionsauswahl angezeigt werden sollen."
|
||||||
reactionSettingDescription2: "Ziehe zum Anordnen, Klicke zum Löschen, Drücke \"+\" zum Hinzufügen"
|
reactionSettingDescription2: "Ziehe zum Anordnen, klicke zum Löschen, drücke + zum Hinzufügen"
|
||||||
rememberNoteVisibility: "Notizsichtbarkeit merken"
|
rememberNoteVisibility: "Notizsichtbarkeit merken"
|
||||||
attachCancel: "Anhang entfernen"
|
attachCancel: "Anhang entfernen"
|
||||||
markAsSensitive: "Als NSFW markieren"
|
markAsSensitive: "Als NSFW markieren"
|
||||||
@@ -129,14 +131,14 @@ editWidgetsExit: "Fertig"
|
|||||||
customEmojis: "Benutzerdefinierte Emojis"
|
customEmojis: "Benutzerdefinierte Emojis"
|
||||||
emoji: "Emojis"
|
emoji: "Emojis"
|
||||||
emojis: "Emojis"
|
emojis: "Emojis"
|
||||||
emojiName: "Emojiname"
|
emojiName: "Emoji-Name"
|
||||||
emojiUrl: "Emoji-URL"
|
emojiUrl: "Emoji-URL"
|
||||||
addEmoji: "Emoji hinzufügen"
|
addEmoji: "Emoji hinzufügen"
|
||||||
settingGuide: "Empfohlene Einstellung"
|
settingGuide: "Empfohlene Einstellung"
|
||||||
cacheRemoteFiles: "Dateien von fremden Instanzen im Cache speichern"
|
cacheRemoteFiles: "Dateien von fremden Instanzen im Cache speichern"
|
||||||
cacheRemoteFilesDescription: "Ist diese Einstellung deaktiviert, so werden Dateien fremder Instanzen direkt von dort geladen. Hierdurch wird Speicherplatz auf dem Server gespart, aber durch fehlende Generierung von Vorschaubildern mehr Bandbreite verwendet."
|
cacheRemoteFilesDescription: "Ist diese Einstellung deaktiviert, so werden Dateien fremder Instanzen direkt von dort geladen. Hierdurch wird Speicherplatz auf dem Server gespart, aber durch fehlende Generierung von Vorschaubildern mehr Bandbreite verwendet."
|
||||||
flagAsBot: "Als Bot markieren"
|
flagAsBot: "Als Bot markieren"
|
||||||
flagAsBotDescription: "Aktiviere diese Option, falls dieses Benutzerkonto durch ein Programm gesteuert wird. Falls aktiviert, agiert es als Flag für andere Entwickler zur Verhinderung von endlosen Kettenreaktionen mit anderen Bots und lässt Misskey's interne Systeme dieses Benutzerkonto als Bot behandeln."
|
flagAsBotDescription: "Aktiviere diese Option, falls dieses Benutzerkonto durch ein Programm gesteuert wird. Falls aktiviert, agiert es als Flag für andere Entwickler zur Verhinderung von endlosen Kettenreaktionen mit anderen Bots und lässt Misskeys interne Systeme dieses Benutzerkonto als Bot behandeln."
|
||||||
flagAsCat: "Als Katze markieren"
|
flagAsCat: "Als Katze markieren"
|
||||||
flagAsCatDescription: "Aktiviere diese Option, um dieses Benutzerkonto als Katze zu markieren."
|
flagAsCatDescription: "Aktiviere diese Option, um dieses Benutzerkonto als Katze zu markieren."
|
||||||
autoAcceptFollowed: "Follow-Anfragen von Benutzern, denen du folgst, automatisch akzeptieren"
|
autoAcceptFollowed: "Follow-Anfragen von Benutzern, denen du folgst, automatisch akzeptieren"
|
||||||
@@ -196,7 +198,7 @@ noteDeleteConfirm: "Möchtest du diese Notiz wirklich löschen?"
|
|||||||
pinLimitExceeded: "Es können nicht noch mehr Notizen angeheftet werden"
|
pinLimitExceeded: "Es können nicht noch mehr Notizen angeheftet werden"
|
||||||
intro: "Misskey Installation abgeschlossen! Lass uns nun ein Administratorkonto erstellen."
|
intro: "Misskey Installation abgeschlossen! Lass uns nun ein Administratorkonto erstellen."
|
||||||
done: "Fertig"
|
done: "Fertig"
|
||||||
processing: "In Bearbeitung..."
|
processing: "In Bearbeitung …"
|
||||||
preview: "Vorschau"
|
preview: "Vorschau"
|
||||||
default: "Standard"
|
default: "Standard"
|
||||||
noCustomEmojis: "Keine benutzerdefinierten Emojis vorhanden"
|
noCustomEmojis: "Keine benutzerdefinierten Emojis vorhanden"
|
||||||
@@ -227,8 +229,8 @@ announcements: "Ankündigungen"
|
|||||||
imageUrl: "Bild-URL"
|
imageUrl: "Bild-URL"
|
||||||
remove: "Löschen"
|
remove: "Löschen"
|
||||||
removed: "Erfolgreich gelöscht"
|
removed: "Erfolgreich gelöscht"
|
||||||
removeAreYouSure: "Möchtest du \"{x}\" wirklich entfernen?"
|
removeAreYouSure: "Möchtest du „{x}“ wirklich entfernen?"
|
||||||
deleteAreYouSure: "Möchtest du \"{x}\" wirklich löschen?"
|
deleteAreYouSure: "Möchtest du „{x}“ wirklich löschen?"
|
||||||
resetAreYouSure: "Wirklich zurücksetzen?"
|
resetAreYouSure: "Wirklich zurücksetzen?"
|
||||||
saved: "Gespeichert"
|
saved: "Gespeichert"
|
||||||
messaging: "Chat"
|
messaging: "Chat"
|
||||||
@@ -240,7 +242,7 @@ uploadFromUrlDescription: "URL der hochzuladenden Datei"
|
|||||||
uploadFromUrlRequested: "Upload angefordert"
|
uploadFromUrlRequested: "Upload angefordert"
|
||||||
uploadFromUrlMayTakeTime: "Es kann eine Weile dauern, bis das Hochladen abgeschlossen ist."
|
uploadFromUrlMayTakeTime: "Es kann eine Weile dauern, bis das Hochladen abgeschlossen ist."
|
||||||
explore: "Erkunden"
|
explore: "Erkunden"
|
||||||
games: "Misskey Spiele"
|
games: "Misskey-Spiele"
|
||||||
messageRead: "Gelesen"
|
messageRead: "Gelesen"
|
||||||
noMoreHistory: "Kein weiterer Verlauf vorhanden"
|
noMoreHistory: "Kein weiterer Verlauf vorhanden"
|
||||||
startMessaging: "Neuen Chat erstellen"
|
startMessaging: "Neuen Chat erstellen"
|
||||||
@@ -256,14 +258,14 @@ birthday: "Geburtstag"
|
|||||||
yearsOld: "{age} Jahre alt"
|
yearsOld: "{age} Jahre alt"
|
||||||
registeredDate: "Registrationsdatum"
|
registeredDate: "Registrationsdatum"
|
||||||
location: "Ort"
|
location: "Ort"
|
||||||
theme: "Farbthemen"
|
theme: "Farbschema"
|
||||||
themeForLightMode: "Farbthema, das im Hellmodus genutzt wird"
|
themeForLightMode: "Helles Farbschema"
|
||||||
themeForDarkMode: "Farbthema, das im Dunkelmodus genutzt wird"
|
themeForDarkMode: "Dunkles Farbschema"
|
||||||
light: "Hell"
|
light: "Hell"
|
||||||
dark: "Dunkel"
|
dark: "Dunkel"
|
||||||
lightThemes: "Helle Farbthemen"
|
lightThemes: "Helle Farbschemata"
|
||||||
darkThemes: "Dunkle Farbthemen"
|
darkThemes: "Dunkle Farbschemata"
|
||||||
syncDeviceDarkMode: "Dunkelmodus mit den Einstellungen deines Gerätes synchronisieren"
|
syncDeviceDarkMode: "Einstellung deines Geräts übernehmen"
|
||||||
drive: "Drive"
|
drive: "Drive"
|
||||||
fileName: "Dateiname"
|
fileName: "Dateiname"
|
||||||
selectFile: "Datei auswählen"
|
selectFile: "Datei auswählen"
|
||||||
@@ -293,7 +295,7 @@ whenServerDisconnected: "Bei Verbindungsverlust zum Server"
|
|||||||
disconnectedFromServer: "Verbindung zum Server wurde getrennt"
|
disconnectedFromServer: "Verbindung zum Server wurde getrennt"
|
||||||
reload: "Aktualisieren"
|
reload: "Aktualisieren"
|
||||||
doNothing: "Ignorieren"
|
doNothing: "Ignorieren"
|
||||||
reloadConfirm: "Möchtest du die Chronik aktualisieren?"
|
reloadConfirm: "Seite neu laden?"
|
||||||
watch: "Beobachten"
|
watch: "Beobachten"
|
||||||
unwatch: "Nicht mehr beobachten"
|
unwatch: "Nicht mehr beobachten"
|
||||||
accept: "Akzeptieren"
|
accept: "Akzeptieren"
|
||||||
@@ -302,10 +304,10 @@ normal: "Normal"
|
|||||||
instanceName: "Name der Instanz"
|
instanceName: "Name der Instanz"
|
||||||
instanceDescription: "Beschreibung der Instanz"
|
instanceDescription: "Beschreibung der Instanz"
|
||||||
maintainerName: "Betreiber"
|
maintainerName: "Betreiber"
|
||||||
maintainerEmail: "Betreiber-Email"
|
maintainerEmail: "Betreiber-E-Mail"
|
||||||
tosUrl: "URL der Nutzungsbedingungen"
|
tosUrl: "URL der Nutzungsbedingungen"
|
||||||
thisYear: "Dieses Jahr"
|
thisYear: "Jahr"
|
||||||
thisMonth: "Dieser Monat"
|
thisMonth: "Monat"
|
||||||
today: "Heute"
|
today: "Heute"
|
||||||
dayX: "{day}"
|
dayX: "{day}"
|
||||||
monthX: "{month}"
|
monthX: "{month}"
|
||||||
@@ -522,13 +524,15 @@ scratchpadDescription: "Die Testumgebung bietet eine Umgebung für AiScript-Expe
|
|||||||
output: "Ausgabe"
|
output: "Ausgabe"
|
||||||
script: "Skript"
|
script: "Skript"
|
||||||
disablePagesScript: "AiScript auf Seiten deaktivieren"
|
disablePagesScript: "AiScript auf Seiten deaktivieren"
|
||||||
updateRemoteUser: "Informationen über Benutzer fremder Instanzen aktualisieren"
|
updateRemoteUser: "Benutzerinformationen aktualisieren"
|
||||||
deleteAllFiles: "Alle Dateien löschen"
|
deleteAllFiles: "Alle Dateien löschen"
|
||||||
deleteAllFilesConfirm: "Möchtest du wirklich alle Dateien löschen?"
|
deleteAllFilesConfirm: "Möchtest du wirklich alle Dateien löschen?"
|
||||||
removeAllFollowing: "Allen gefolgten Benutzern entfolgen"
|
removeAllFollowing: "Allen gefolgten Benutzern entfolgen"
|
||||||
removeAllFollowingDescription: "Dies entfolgt allen Benutzerkonten von {host}. Bitte führe dies durch, falls diese Instanz z.B. nicht mehr existiert."
|
removeAllFollowingDescription: "Dies entfolgt allen Benutzerkonten von {host}. Bitte führe dies durch, falls diese Instanz z.B. nicht mehr existiert."
|
||||||
userSuspended: "Dieser Benutzer wurde gesperrt."
|
userSuspended: "Dieser Benutzer wurde gesperrt."
|
||||||
userSilenced: "Dieser Benutzer wurde instanzweit stummgeschaltet."
|
userSilenced: "Dieser Benutzer wurde instanzweit stummgeschaltet."
|
||||||
|
yourAccountSuspendedTitle: "Dieses Benutzerkonto ist gesperrt"
|
||||||
|
yourAccountSuspendedDescription: "Dieses Benutzerkonto wurde gesperrt, da es gegen die Nutzungsbedingungen dieses Servers verstoßen hat. Trete mit dem Betreiber in Kontakt, falls du weitere Details erfahren möchtest. Bitte erstelle kein neues Benutzerkonto."
|
||||||
menu: "Menü"
|
menu: "Menü"
|
||||||
divider: "Trenner"
|
divider: "Trenner"
|
||||||
addItem: "Element hinzufügen"
|
addItem: "Element hinzufügen"
|
||||||
@@ -543,7 +547,7 @@ invisibleNote: "Private Notiz"
|
|||||||
enableInfiniteScroll: "Automatisch mehr Notizen laden"
|
enableInfiniteScroll: "Automatisch mehr Notizen laden"
|
||||||
visibility: "Sichtbarkeit"
|
visibility: "Sichtbarkeit"
|
||||||
poll: "Umfrage"
|
poll: "Umfrage"
|
||||||
useCw: "Inhalt verbergen"
|
useCw: "Inhaltswarnung verwenden"
|
||||||
enablePlayer: "Video-Player öffnen"
|
enablePlayer: "Video-Player öffnen"
|
||||||
disablePlayer: "Video-Player schließen"
|
disablePlayer: "Video-Player schließen"
|
||||||
expandTweet: "Tweet ausklappen"
|
expandTweet: "Tweet ausklappen"
|
||||||
@@ -588,6 +592,7 @@ smtpSecure: "Für SMTP-Verbindungen implizit SSL/TLS verwenden"
|
|||||||
smtpSecureInfo: "Schalte dies aus, falls du STARTTLS verwendest"
|
smtpSecureInfo: "Schalte dies aus, falls du STARTTLS verwendest"
|
||||||
testEmail: "Email-Versand testen"
|
testEmail: "Email-Versand testen"
|
||||||
wordMute: "Wort-Stummschaltung"
|
wordMute: "Wort-Stummschaltung"
|
||||||
|
instanceMute: "Instanzstummschaltungen"
|
||||||
userSaysSomething: "{name} hat etwas gesagt"
|
userSaysSomething: "{name} hat etwas gesagt"
|
||||||
makeActive: "Aktivieren"
|
makeActive: "Aktivieren"
|
||||||
display: "Anzeigeart"
|
display: "Anzeigeart"
|
||||||
@@ -616,6 +621,8 @@ reportAbuse: "Melden"
|
|||||||
reportAbuseOf: "{name} melden"
|
reportAbuseOf: "{name} melden"
|
||||||
fillAbuseReportDescription: "Bitte gib zusätzliche Informationen zu dieser Meldung an. Falls es sich um eine spezielle Notiz handelt, bitte gib dessen URL an."
|
fillAbuseReportDescription: "Bitte gib zusätzliche Informationen zu dieser Meldung an. Falls es sich um eine spezielle Notiz handelt, bitte gib dessen URL an."
|
||||||
abuseReported: "Die Meldung wurde versendet. Vielen Dank."
|
abuseReported: "Die Meldung wurde versendet. Vielen Dank."
|
||||||
|
reporteeOrigin: "Herkunft des Gemeldeten"
|
||||||
|
reporterOrigin: "Herkunft des Meldenden"
|
||||||
send: "Senden"
|
send: "Senden"
|
||||||
abuseMarkAsResolved: "Meldung als gelöst markieren"
|
abuseMarkAsResolved: "Meldung als gelöst markieren"
|
||||||
openInNewTab: "In neuem Tab öffnen"
|
openInNewTab: "In neuem Tab öffnen"
|
||||||
@@ -715,7 +722,7 @@ inChannelSearch: "In Kanal suchen"
|
|||||||
useReactionPickerForContextMenu: "Reaktionsauswahl durch Rechtsklick öffnen"
|
useReactionPickerForContextMenu: "Reaktionsauswahl durch Rechtsklick öffnen"
|
||||||
typingUsers: "{users} ist/sind am schreiben..."
|
typingUsers: "{users} ist/sind am schreiben..."
|
||||||
jumpToSpecifiedDate: "Zu bestimmtem Datum springen"
|
jumpToSpecifiedDate: "Zu bestimmtem Datum springen"
|
||||||
showingPastTimeline: "Momentan wird eine alte Chronik angezeigt"
|
showingPastTimeline: "Es wird eine alte Chronik angezeigt"
|
||||||
clear: "Zurückkehren"
|
clear: "Zurückkehren"
|
||||||
markAllAsRead: "Alle als gelesen markieren"
|
markAllAsRead: "Alle als gelesen markieren"
|
||||||
goBack: "Zurück"
|
goBack: "Zurück"
|
||||||
@@ -748,7 +755,7 @@ switch: "Wechseln"
|
|||||||
noMaintainerInformationWarning: "Betreiberinformationen sind nicht konfiguriert."
|
noMaintainerInformationWarning: "Betreiberinformationen sind nicht konfiguriert."
|
||||||
noBotProtectionWarning: "Bot-Schutz ist nicht konfiguriert."
|
noBotProtectionWarning: "Bot-Schutz ist nicht konfiguriert."
|
||||||
configure: "Konfigurieren"
|
configure: "Konfigurieren"
|
||||||
postToGallery: "Beitrag zu Galerie hinzufügen"
|
postToGallery: "Neuen Galerie-Beitrag erstellen"
|
||||||
gallery: "Galerie"
|
gallery: "Galerie"
|
||||||
recentPosts: "Neue Beiträge"
|
recentPosts: "Neue Beiträge"
|
||||||
popularPosts: "Beliebte Beiträge"
|
popularPosts: "Beliebte Beiträge"
|
||||||
@@ -762,6 +769,7 @@ middle: "Mittel"
|
|||||||
low: "Niedrig"
|
low: "Niedrig"
|
||||||
emailNotConfiguredWarning: "Keine Email-Adresse hinterlegt"
|
emailNotConfiguredWarning: "Keine Email-Adresse hinterlegt"
|
||||||
ratio: "Verhältnis"
|
ratio: "Verhältnis"
|
||||||
|
previewNoteText: "Vorschau anzeigen"
|
||||||
customCss: "Benutzerdefiniertes CSS"
|
customCss: "Benutzerdefiniertes CSS"
|
||||||
customCssWarn: "Verwende diese Einstellung nur, wenn du weißt, was sie tut. Ungültige Eingaben können dazu führen, dass der Client nicht mehr normal funktioniert."
|
customCssWarn: "Verwende diese Einstellung nur, wenn du weißt, was sie tut. Ungültige Eingaben können dazu führen, dass der Client nicht mehr normal funktioniert."
|
||||||
global: "Global"
|
global: "Global"
|
||||||
@@ -771,13 +779,61 @@ received: "Erhalten"
|
|||||||
searchResult: "Suchergebnisse"
|
searchResult: "Suchergebnisse"
|
||||||
hashtags: "Hashtags"
|
hashtags: "Hashtags"
|
||||||
troubleshooting: "Problembehandlung"
|
troubleshooting: "Problembehandlung"
|
||||||
_docs:
|
useBlurEffect: "Weichzeichnungseffekt in der Benutzeroberfläche verwenden"
|
||||||
continueReading: "Mehr lesen"
|
learnMore: "Mehr erfahren"
|
||||||
features: "Funktionen"
|
misskeyUpdated: "Misskey wurde aktualisiert!"
|
||||||
generalTopics: "Allgemeine Themen"
|
whatIsNew: "Änderungen anzeigen"
|
||||||
advancedTopics: "Erweiterte Themen"
|
translate: "Übersetzen"
|
||||||
admin: "Administration"
|
translatedFrom: "Aus {x} übersetzt"
|
||||||
translateWarn: "Dies ist ein übersetztes Dokument. Es kann zu Unterschieden mit dem Original kommen."
|
accountDeletionInProgress: "Löschung des Benutzerkontos momentan in Bearbeitung"
|
||||||
|
usernameInfo: "Ein Name, durch den dein Benutzerkonto auf diesem Server identifiziert werden kann. Du kannst das Alphabet (a~z, A~Z), Ziffern (0~9) oder Unterstriche (_) verwenden. Benutzernamen können später nicht geändert werden."
|
||||||
|
aiChanMode: "Ai Modus"
|
||||||
|
keepCw: "Inhaltswarnungen beibehalten"
|
||||||
|
pubSub: "Pub/Sub Benutzerkonten"
|
||||||
|
lastCommunication: "Letzte Kommunikation"
|
||||||
|
resolved: "Gelöst"
|
||||||
|
unresolved: "Ungelöst"
|
||||||
|
breakFollow: "Follower entfernen"
|
||||||
|
itsOn: "Eingeschaltet"
|
||||||
|
itsOff: "Ausgeschaltet"
|
||||||
|
emailRequiredForSignup: "Angaben einer Email-Adresse als benötigt markieren"
|
||||||
|
unread: "Ungelesen"
|
||||||
|
filter: "Filter"
|
||||||
|
controlPanel: "Systemsteuerung"
|
||||||
|
manageAccounts: "Benutzerkonten verwalten"
|
||||||
|
makeReactionsPublic: "Reaktionsverlauf veröffentlichen"
|
||||||
|
makeReactionsPublicDescription: "Jeder wird die Liste deiner gesendeten Reaktionen einsehen können."
|
||||||
|
classic: "Classic"
|
||||||
|
muteThread: "Thread stummschalten"
|
||||||
|
unmuteThread: "Threadstummschaltung aufheben"
|
||||||
|
ffVisibility: "Sichtbarkeit von Gefolgten/Followern"
|
||||||
|
ffVisibilityDescription: "Konfiguriere wer sehen kann, wem du folgst sowie wer dir folgt."
|
||||||
|
continueThread: "Weiteren Threadverlauf anzeigen"
|
||||||
|
deleteAccountConfirm: "Dein Benutzerkonto wird unwiderruflich gelöscht. Trotzdem fortfahren?"
|
||||||
|
incorrectPassword: "Falsches Passwort."
|
||||||
|
voteConfirm: "Wirklich für \"{choice}\" abstimmen?"
|
||||||
|
hide: "Inhalt verbergen"
|
||||||
|
_emailUnavailable:
|
||||||
|
used: "Diese Email-Adresse wird bereits verwendet"
|
||||||
|
format: "Das Format dieser Email-Adresse ist ungültig"
|
||||||
|
disposable: "Wegwerf-Email-Adressen können nicht verwendet werden"
|
||||||
|
mx: "Dieser Email-Server ist ungültig"
|
||||||
|
smtp: "Dieser Email-Server antwortet nicht"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "Öffentlich"
|
||||||
|
followers: "Nur für Follower sichtbar"
|
||||||
|
private: "Privat"
|
||||||
|
_signup:
|
||||||
|
almostThere: "Fast geschafft"
|
||||||
|
emailAddressInfo: "Bitte gib deine Email-Adresse ein."
|
||||||
|
emailSent: "An deine Email-Adresse ({email}) wurde soeben eine Bestätigungsmail geschickt. Bitte klicke auf den enthaltenen Link, um die Erstellung deines Benutzerkontos abzuschließen."
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "Benutzerkonto löschen"
|
||||||
|
mayTakeTime: "Da die Löschung eines Benutzerkontos ein aufwendiger Prozess ist, kann dessen Dauer davon abhängen, wie viel Inhalt in diesem erstellt wurde oder wie viele Dateien hochgeladen wurden."
|
||||||
|
sendEmail: "Sobald die Löschung abgeschlossen ist, wird an die mit ihm verknüpfte Email-Adresse eine Benachrichtigung versendet."
|
||||||
|
requestAccountDelete: "Löschung des Benutzerkontos anfordern"
|
||||||
|
started: "Löschung wurde eingeleitet."
|
||||||
|
inProgress: "Löschung in Bearbeitung"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Zurück"
|
back: "Zurück"
|
||||||
reduceFrequencyOfThisAd: "Diese Werbung weniger anzeigen"
|
reduceFrequencyOfThisAd: "Diese Werbung weniger anzeigen"
|
||||||
@@ -792,7 +848,7 @@ _gallery:
|
|||||||
unlike: "\"Gefällt mir\" entfernen"
|
unlike: "\"Gefällt mir\" entfernen"
|
||||||
_email:
|
_email:
|
||||||
_follow:
|
_follow:
|
||||||
title: "ist dir gefolgt"
|
title: "Du hast einen neuen Follower"
|
||||||
_receiveFollowRequest:
|
_receiveFollowRequest:
|
||||||
title: "Du hast eine Follow-Anfrage erhalten"
|
title: "Du hast eine Follow-Anfrage erhalten"
|
||||||
_plugin:
|
_plugin:
|
||||||
@@ -853,19 +909,19 @@ _mfm:
|
|||||||
flip: "Spiegelung"
|
flip: "Spiegelung"
|
||||||
flipDescription: "Inhalt horizontal oder vertikal gespiegelt anzeigen."
|
flipDescription: "Inhalt horizontal oder vertikal gespiegelt anzeigen."
|
||||||
jelly: "Animation (Dehnen)"
|
jelly: "Animation (Dehnen)"
|
||||||
jellyDescription: "Verleiht eine sich dehnende Animation."
|
jellyDescription: "Verleiht dem Inhalt eine sich dehnende Animation."
|
||||||
tada: "Animation (Tada)"
|
tada: "Animation (Tada)"
|
||||||
tadaDescription: "Verleiht eine Animation mit \"Tada!\"-Gefühl"
|
tadaDescription: "Verleiht eine Animation mit \"Tada!\"-Gefühl"
|
||||||
jump: "Animation (Sprung)"
|
jump: "Animation (Sprung)"
|
||||||
jumpDescription: "Verleiht eine springende Animation."
|
jumpDescription: "Verleiht dem Inhalt eine springende Animation."
|
||||||
bounce: "Animation (Federn)"
|
bounce: "Animation (Federn)"
|
||||||
bounceDescription: "Verleiht eine federnde Animation."
|
bounceDescription: "Verleiht dem Inhalt eine federnde Animation."
|
||||||
shake: "Animation (Zittern)"
|
shake: "Animation (Zittern)"
|
||||||
shakeDescription: "Verleiht eine zitternde Animation."
|
shakeDescription: "Verleiht dem Inhalt eine zitternde Animation."
|
||||||
twitch: "Animation (Zucken)"
|
twitch: "Animation (Zucken)"
|
||||||
twitchDescription: "Verleiht eine sehr stark zuckende Animation."
|
twitchDescription: "Verleiht dem Inhalt eine sehr stark zuckende Animation."
|
||||||
spin: "Animation (Rotieren)"
|
spin: "Animation (Rotieren)"
|
||||||
spinDescription: "Verleiht eine rotierende Animation."
|
spinDescription: "Verleiht dem Inhalt eine rotierende Animation."
|
||||||
x2: "Groß"
|
x2: "Groß"
|
||||||
x2Description: "Inhalte größer anzeigen."
|
x2Description: "Inhalte größer anzeigen."
|
||||||
x3: "Sehr groß"
|
x3: "Sehr groß"
|
||||||
@@ -878,6 +934,10 @@ _mfm:
|
|||||||
fontDescription: "Setzt die Schriftart des Inhaltes fest."
|
fontDescription: "Setzt die Schriftart des Inhaltes fest."
|
||||||
rainbow: "Regenbogen"
|
rainbow: "Regenbogen"
|
||||||
rainbowDescription: "Lässt den Inhalt in Regenbogenfarben erscheinen."
|
rainbowDescription: "Lässt den Inhalt in Regenbogenfarben erscheinen."
|
||||||
|
sparkle: "Glitzer"
|
||||||
|
sparkleDescription: "Verleiht Inhalt einen glitzernden Partikeleffekt."
|
||||||
|
rotate: "Drehen"
|
||||||
|
rotateDescription: "Dreht den Inhalt um einen angegebenen Winkel"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Spieleinstellungen"
|
gameSettings: "Spieleinstellungen"
|
||||||
@@ -943,6 +1003,11 @@ _wordMute:
|
|||||||
soft: "Leicht"
|
soft: "Leicht"
|
||||||
hard: "Schwer"
|
hard: "Schwer"
|
||||||
mutedNotes: "Stummgeschaltete Notizen"
|
mutedNotes: "Stummgeschaltete Notizen"
|
||||||
|
_instanceMute:
|
||||||
|
instanceMuteDescription: "Schaltet alle Notizen/Renotes stumm, die von den gelisteten Instanzen stammen, inklusive Antworten von Benutzern an einen Benutzer einer stummgeschalteten Instanz."
|
||||||
|
instanceMuteDescription2: "Instanzen getrennt durch Zeilenumbrüchen angeben"
|
||||||
|
title: "Blendet Notizen von stummgeschalteten Instanzen aus."
|
||||||
|
heading: "Liste der stummzuschaltenden Instanzen"
|
||||||
_theme:
|
_theme:
|
||||||
explore: "Themen erforschen"
|
explore: "Themen erforschen"
|
||||||
install: "Thema installieren"
|
install: "Thema installieren"
|
||||||
@@ -1001,9 +1066,9 @@ _theme:
|
|||||||
infoFg: "Text von Informationen"
|
infoFg: "Text von Informationen"
|
||||||
infoWarnBg: "Hintergrund von Warnungen"
|
infoWarnBg: "Hintergrund von Warnungen"
|
||||||
infoWarnFg: "Text von Warnungen"
|
infoWarnFg: "Text von Warnungen"
|
||||||
cwBg: "Hintergrund von verborgenen Inhalten"
|
cwBg: "Hintergrund des Inhaltswarnungsknopfs"
|
||||||
cwFg: "Text von verborgenen Inhalten"
|
cwFg: "Text des Inhaltswarnungsknopfs"
|
||||||
cwHoverBg: "Hintergrund von verborgenen Inhalten (Mouseover)"
|
cwHoverBg: "Hintergrund des Inhaltswarnungsknopfs (Mouseover)"
|
||||||
toastBg: "Hintergrund von Benachrichtigungen"
|
toastBg: "Hintergrund von Benachrichtigungen"
|
||||||
toastFg: "Text von Benachrichtigungen"
|
toastFg: "Text von Benachrichtigungen"
|
||||||
buttonBg: "Hintergrund von Schaltflächen"
|
buttonBg: "Hintergrund von Schaltflächen"
|
||||||
@@ -1046,7 +1111,7 @@ _time:
|
|||||||
_tutorial:
|
_tutorial:
|
||||||
title: "Wie du Misskey verwendest"
|
title: "Wie du Misskey verwendest"
|
||||||
step1_1: "Willkommen!"
|
step1_1: "Willkommen!"
|
||||||
step1_2: "Diese Seite ist die \"Chronik\". Sie zeigt dir deine geschrieben \"Notizen\" sowie die aller Benutzer, denen du \"folgst\", in chronologischer Reihenfolge."
|
step1_2: "Diese Seite ist die „Chronik“. Sie zeigt dir deine geschrieben „Notizen“ sowie die aller Benutzer, denen du „folgst“, in chronologischer Reihenfolge."
|
||||||
step1_3: "Deine Chronik sollte momentan leer sein, da du bis jetzt noch keine Notizen geschrieben hast und auch noch keinen Benutzern folgst."
|
step1_3: "Deine Chronik sollte momentan leer sein, da du bis jetzt noch keine Notizen geschrieben hast und auch noch keinen Benutzern folgst."
|
||||||
step2_1: "Lass uns zuerst dein Profil vervollständigen, bevor du Notizen schreibst oder jemandem folgst."
|
step2_1: "Lass uns zuerst dein Profil vervollständigen, bevor du Notizen schreibst oder jemandem folgst."
|
||||||
step2_2: "Informationen darüber, was für eine Person du bist, macht es anderen leichter zu wissen, ob sie deine Notizen sehen wollen und ob sie dir folgen möchten."
|
step2_2: "Informationen darüber, was für eine Person du bist, macht es anderen leichter zu wissen, ob sie deine Notizen sehen wollen und ob sie dir folgen möchten."
|
||||||
@@ -1055,7 +1120,7 @@ _tutorial:
|
|||||||
step3_3: "Fülle das Fenster aus und drücke auf den Knopf oben rechts zum Senden."
|
step3_3: "Fülle das Fenster aus und drücke auf den Knopf oben rechts zum Senden."
|
||||||
step3_4: "Fällt dir nichts ein, das du schreiben möchtest? Versuch's mit \"Hallo Misskey!\""
|
step3_4: "Fällt dir nichts ein, das du schreiben möchtest? Versuch's mit \"Hallo Misskey!\""
|
||||||
step4_1: "Fertig mit dem Senden deiner ersten Notiz?"
|
step4_1: "Fertig mit dem Senden deiner ersten Notiz?"
|
||||||
step4_2: "Falls deine Notiz nun auf deiner Chronik auftaucht, hast du alles richtig gemacht."
|
step4_2: "Falls deine Notiz nun in deiner Chronik auftaucht, hast du alles richtig gemacht."
|
||||||
step5_1: "Lass uns nun deiner Chronik etwas mehr Leben einhauchen, indem du einigen anderen Benutzern folgst."
|
step5_1: "Lass uns nun deiner Chronik etwas mehr Leben einhauchen, indem du einigen anderen Benutzern folgst."
|
||||||
step5_2: "{featured} zeigt dir beliebte Notizen dieser Instanz. In {explore} kannst du beliebte Benutzer finden. Schau dort, ob du Benutzer findest, die dich interessieren."
|
step5_2: "{featured} zeigt dir beliebte Notizen dieser Instanz. In {explore} kannst du beliebte Benutzer finden. Schau dort, ob du Benutzer findest, die dich interessieren."
|
||||||
step5_3: "Klicke zum Anzeigen des Profils eines Benutzers auf dessen Profilbild und dann auf den \"Folgen\"-Knopf, um diesem zu folgen."
|
step5_3: "Klicke zum Anzeigen des Profils eines Benutzers auf dessen Profilbild und dann auf den \"Folgen\"-Knopf, um diesem zu folgen."
|
||||||
@@ -1104,6 +1169,10 @@ _permissions:
|
|||||||
"write:user-groups": "Benutzergruppen bearbeiten oder löschen"
|
"write:user-groups": "Benutzergruppen bearbeiten oder löschen"
|
||||||
"read:channels": "Kanäle lesen"
|
"read:channels": "Kanäle lesen"
|
||||||
"write:channels": "Kanäle bedienen"
|
"write:channels": "Kanäle bedienen"
|
||||||
|
"read:gallery": "Beiträge deiner Galerie lesen"
|
||||||
|
"write:gallery": "Deine Galerie bearbeiten"
|
||||||
|
"read:gallery-likes": "Liste deiner mit \"Gefällt mir\" markierten Galerie-Beiträge lesen"
|
||||||
|
"write:gallery-likes": "Liste deiner mit \"Gefällt mir\" markierten Galerie-Beiträge bearbeiten"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "Möchtest du \"{name}\" authorisieren, auf dieses Benuzerkonto zugreifen zu können?"
|
shareAccess: "Möchtest du \"{name}\" authorisieren, auf dieses Benuzerkonto zugreifen zu können?"
|
||||||
shareAccessAsk: "Bist du dir sicher, dass du diese Anwendung authorisieren möchtest, auf dein Benutzerkonto zugreifen zu können?"
|
shareAccessAsk: "Bist du dir sicher, dass du diese Anwendung authorisieren möchtest, auf dein Benutzerkonto zugreifen zu können?"
|
||||||
@@ -1144,8 +1213,9 @@ _widgets:
|
|||||||
jobQueue: "Job-Warteschlange"
|
jobQueue: "Job-Warteschlange"
|
||||||
serverMetric: "Servermetriken"
|
serverMetric: "Servermetriken"
|
||||||
aiscript: "AiScript-Konsole"
|
aiscript: "AiScript-Konsole"
|
||||||
|
aichan: "Ai"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "Verbergen"
|
hide: "Inhalt verbergen"
|
||||||
show: "Inhalt anzeigen"
|
show: "Inhalt anzeigen"
|
||||||
chars: "{count} Zeichen"
|
chars: "{count} Zeichen"
|
||||||
files: "{count} Datei(en)"
|
files: "{count} Datei(en)"
|
||||||
@@ -1211,6 +1281,8 @@ _exportOrImport:
|
|||||||
muteList: "Stummschaltungen"
|
muteList: "Stummschaltungen"
|
||||||
blockingList: "Blockierungen"
|
blockingList: "Blockierungen"
|
||||||
userLists: "Listen"
|
userLists: "Listen"
|
||||||
|
excludeMutingUsers: "Stummgeschaltete Benutzer aussortieren"
|
||||||
|
excludeInactiveUsers: "Inaktive Benutzer aussortieren"
|
||||||
_charts:
|
_charts:
|
||||||
federationInstancesIncDec: "Unterschied in der Anzahl von förderierenden Instanzen"
|
federationInstancesIncDec: "Unterschied in der Anzahl von förderierenden Instanzen"
|
||||||
federationInstancesTotal: "Anzahl aller föderierenden Instanzen"
|
federationInstancesTotal: "Anzahl aller föderierenden Instanzen"
|
||||||
|
@@ -1,7 +1,7 @@
|
|||||||
---
|
---
|
||||||
_lang_: "English"
|
_lang_: "English"
|
||||||
headlineMisskey: "A network connected by notes"
|
headlineMisskey: "A network connected by notes"
|
||||||
introMisskey: "Welcome! Misskey is an open source, decentralized microblogging service.\nCreate \"notes\" to share what is happening now, or to share it with everyone around you. 📡\nWith \"reactions\", you can also quickly express your feelings about everyone's notes. 👍\nLet's explore a new world! 🚀"
|
introMisskey: "Welcome! Misskey is an open source, decentralized microblogging service.\nCreate \"notes\" to share your thoughts with everyone around you. 📡\nWith \"reactions\", you can also quickly express your feelings about everyone's notes. 👍\nLet's explore a new world! 🚀"
|
||||||
monthAndDay: "{month}/{day}"
|
monthAndDay: "{month}/{day}"
|
||||||
search: "Search"
|
search: "Search"
|
||||||
notifications: "Notifications"
|
notifications: "Notifications"
|
||||||
@@ -81,6 +81,8 @@ somethingHappened: "An error occurred"
|
|||||||
retry: "Retry"
|
retry: "Retry"
|
||||||
pageLoadError: "Failed to load page."
|
pageLoadError: "Failed to load page."
|
||||||
pageLoadErrorDescription: "This is normally caused by network errors or the browser's cache. Try clearing the cache and then try again after waiting a little while."
|
pageLoadErrorDescription: "This is normally caused by network errors or the browser's cache. Try clearing the cache and then try again after waiting a little while."
|
||||||
|
serverIsDead: "This server is not responding. Please wait for a while and try again."
|
||||||
|
youShouldUpgradeClient: "To view this page, please refresh to update your client."
|
||||||
enterListName: "Enter a list name"
|
enterListName: "Enter a list name"
|
||||||
privacy: "Privacy"
|
privacy: "Privacy"
|
||||||
makeFollowManuallyApprove: "Follow requests require approval"
|
makeFollowManuallyApprove: "Follow requests require approval"
|
||||||
@@ -92,7 +94,7 @@ unfollow: "Unfollow"
|
|||||||
followRequestPending: "Pending follow request"
|
followRequestPending: "Pending follow request"
|
||||||
enterEmoji: "Enter an emoji"
|
enterEmoji: "Enter an emoji"
|
||||||
renote: "Renote"
|
renote: "Renote"
|
||||||
unrenote: "Take back Renote"
|
unrenote: "Take back renote"
|
||||||
renoted: "Renoted."
|
renoted: "Renoted."
|
||||||
cantRenote: "This post can't be renoted."
|
cantRenote: "This post can't be renoted."
|
||||||
cantReRenote: "A renote can't be renoted."
|
cantReRenote: "A renote can't be renoted."
|
||||||
@@ -135,8 +137,8 @@ addEmoji: "Add an emoji"
|
|||||||
settingGuide: "Recommended settings"
|
settingGuide: "Recommended settings"
|
||||||
cacheRemoteFiles: "Cache remote files"
|
cacheRemoteFiles: "Cache remote files"
|
||||||
cacheRemoteFilesDescription: "When this setting is disabled, remote files are loaded directly from the remote instance. Disabling this will decrease storage usage, but increase traffic, as thumbnails will not be generated."
|
cacheRemoteFilesDescription: "When this setting is disabled, remote files are loaded directly from the remote instance. Disabling this will decrease storage usage, but increase traffic, as thumbnails will not be generated."
|
||||||
flagAsBot: "Mark this account as as bot"
|
flagAsBot: "Mark this account as a bot"
|
||||||
flagAsBotDescription: "Enable this option if this account is controlled by a program. If enabled, it will act as flag for other developers to prevent endless interaction chains with other bots and adjust Misskey's internal systems to treat this account as a bot."
|
flagAsBotDescription: "Enable this option if this account is controlled by a program. If enabled, it will act as a flag for other developers to prevent endless interaction chains with other bots and adjust Misskey's internal systems to treat this account as a bot."
|
||||||
flagAsCat: "Mark this account as a cat"
|
flagAsCat: "Mark this account as a cat"
|
||||||
flagAsCatDescription: "Enable this option to mark this account as a cat."
|
flagAsCatDescription: "Enable this option to mark this account as a cat."
|
||||||
autoAcceptFollowed: "Automatically approve follow requests from users you're following"
|
autoAcceptFollowed: "Automatically approve follow requests from users you're following"
|
||||||
@@ -199,7 +201,7 @@ done: "Done"
|
|||||||
processing: "Processing..."
|
processing: "Processing..."
|
||||||
preview: "Preview"
|
preview: "Preview"
|
||||||
default: "Default"
|
default: "Default"
|
||||||
noCustomEmojis: "There are no emojis"
|
noCustomEmojis: "There are no emoji"
|
||||||
noJobs: "There are no jobs"
|
noJobs: "There are no jobs"
|
||||||
federating: "Federating"
|
federating: "Federating"
|
||||||
blocked: "Blocked"
|
blocked: "Blocked"
|
||||||
@@ -213,7 +215,7 @@ instanceFollowers: "Followers of instance"
|
|||||||
instanceUsers: "Users of this instance"
|
instanceUsers: "Users of this instance"
|
||||||
changePassword: "Change password"
|
changePassword: "Change password"
|
||||||
security: "Security"
|
security: "Security"
|
||||||
retypedNotMatch: "The inputs does not match."
|
retypedNotMatch: "The inputs do not match."
|
||||||
currentPassword: "Current password"
|
currentPassword: "Current password"
|
||||||
newPassword: "New password"
|
newPassword: "New password"
|
||||||
newPasswordRetype: "Retype new password"
|
newPasswordRetype: "Retype new password"
|
||||||
@@ -249,7 +251,7 @@ agreeTo: "I agree to {0}"
|
|||||||
tos: "Terms of Service"
|
tos: "Terms of Service"
|
||||||
start: "Begin"
|
start: "Begin"
|
||||||
home: "Home"
|
home: "Home"
|
||||||
remoteUserCaution: "As this user is from a renote instance, the shown information may be incomplete."
|
remoteUserCaution: "As this user is from a remote instance, the shown information may be incomplete."
|
||||||
activity: "Activity"
|
activity: "Activity"
|
||||||
images: "Images"
|
images: "Images"
|
||||||
birthday: "Birthday"
|
birthday: "Birthday"
|
||||||
@@ -429,7 +431,7 @@ invitationCode: "Invitation code"
|
|||||||
checking: "Checking..."
|
checking: "Checking..."
|
||||||
available: "Available"
|
available: "Available"
|
||||||
unavailable: "Not available"
|
unavailable: "Not available"
|
||||||
usernameInvalidFormat: "You can use upper- and lowercase letters, numbers as well as underscores."
|
usernameInvalidFormat: "You can use upper- and lowercase letters, numbers, and underscores."
|
||||||
tooShort: "Too short"
|
tooShort: "Too short"
|
||||||
tooLong: "Too long"
|
tooLong: "Too long"
|
||||||
weakPassword: "Weak password"
|
weakPassword: "Weak password"
|
||||||
@@ -445,7 +447,7 @@ language: "Language"
|
|||||||
uiLanguage: "User interface language"
|
uiLanguage: "User interface language"
|
||||||
groupInvited: "You've been invited to a group"
|
groupInvited: "You've been invited to a group"
|
||||||
aboutX: "About {x}"
|
aboutX: "About {x}"
|
||||||
useOsNativeEmojis: "Use OS native Emojis"
|
useOsNativeEmojis: "Use OS native Emoji"
|
||||||
youHaveNoGroups: "You have no groups"
|
youHaveNoGroups: "You have no groups"
|
||||||
joinOrCreateGroup: "Get invited to a group or create your own."
|
joinOrCreateGroup: "Get invited to a group or create your own."
|
||||||
noHistory: "No history available"
|
noHistory: "No history available"
|
||||||
@@ -482,7 +484,7 @@ objectStorageBaseUrlDesc: "URL used as reference. Specify the URL of your CDN or
|
|||||||
objectStorageBucket: "Bucket"
|
objectStorageBucket: "Bucket"
|
||||||
objectStorageBucketDesc: "Please specify the bucket name used at your provider."
|
objectStorageBucketDesc: "Please specify the bucket name used at your provider."
|
||||||
objectStoragePrefix: "Prefix"
|
objectStoragePrefix: "Prefix"
|
||||||
objectStoragePrefixDesc: "Files will stored under directories with this prefix."
|
objectStoragePrefixDesc: "Files will be stored under directories with this prefix."
|
||||||
objectStorageEndpoint: "Endpoint"
|
objectStorageEndpoint: "Endpoint"
|
||||||
objectStorageEndpointDesc: "Leave this empty if you are using AWS S3, otherwise specify the endpoint as '<host>' or '<host>:<port>', depending on the service you are using."
|
objectStorageEndpointDesc: "Leave this empty if you are using AWS S3, otherwise specify the endpoint as '<host>' or '<host>:<port>', depending on the service you are using."
|
||||||
objectStorageRegion: "Region"
|
objectStorageRegion: "Region"
|
||||||
@@ -529,6 +531,8 @@ removeAllFollowing: "Unfollow all followed users"
|
|||||||
removeAllFollowingDescription: "Executing this unfollows all accounts from {host}. Please run this if the instance e.g. no longer exists."
|
removeAllFollowingDescription: "Executing this unfollows all accounts from {host}. Please run this if the instance e.g. no longer exists."
|
||||||
userSuspended: "This user has been suspended."
|
userSuspended: "This user has been suspended."
|
||||||
userSilenced: "This user has been silenced."
|
userSilenced: "This user has been silenced."
|
||||||
|
yourAccountSuspendedTitle: "This account is suspended"
|
||||||
|
yourAccountSuspendedDescription: "This account has been suspended due to breaking the server's terms of services or similar. Contact the administrator if you would like to know a more detailed reason. Please do not create a new account."
|
||||||
menu: "Menu"
|
menu: "Menu"
|
||||||
divider: "Divider"
|
divider: "Divider"
|
||||||
addItem: "Add Item"
|
addItem: "Add Item"
|
||||||
@@ -588,6 +592,7 @@ smtpSecure: "Use implicit SSL/TLS for SMTP connections"
|
|||||||
smtpSecureInfo: "Turn this off when using STARTTLS"
|
smtpSecureInfo: "Turn this off when using STARTTLS"
|
||||||
testEmail: "Test email delivery"
|
testEmail: "Test email delivery"
|
||||||
wordMute: "Word mute"
|
wordMute: "Word mute"
|
||||||
|
instanceMute: "Instance mutes"
|
||||||
userSaysSomething: "{name} said something"
|
userSaysSomething: "{name} said something"
|
||||||
makeActive: "Activate"
|
makeActive: "Activate"
|
||||||
display: "Display"
|
display: "Display"
|
||||||
@@ -606,7 +611,7 @@ useGlobalSettingDesc: "If turned on, your account's notification settings will b
|
|||||||
other: "Other"
|
other: "Other"
|
||||||
regenerateLoginToken: "Regenerate login token"
|
regenerateLoginToken: "Regenerate login token"
|
||||||
regenerateLoginTokenDescription: "Regenerate the token used internally during login. Normally this action is not necessary. If regenerated, all devices will be logged out."
|
regenerateLoginTokenDescription: "Regenerate the token used internally during login. Normally this action is not necessary. If regenerated, all devices will be logged out."
|
||||||
setMultipleBySeparatingWithSpace: "You can set multiple by separating them with spaces."
|
setMultipleBySeparatingWithSpace: "Separate multiple entries with spaces."
|
||||||
fileIdOrUrl: "File-ID or URL"
|
fileIdOrUrl: "File-ID or URL"
|
||||||
chatOpenBehavior: "Behavior of the chat window when opened"
|
chatOpenBehavior: "Behavior of the chat window when opened"
|
||||||
behavior: "Behavior"
|
behavior: "Behavior"
|
||||||
@@ -616,6 +621,8 @@ reportAbuse: "Report"
|
|||||||
reportAbuseOf: "Report {name}"
|
reportAbuseOf: "Report {name}"
|
||||||
fillAbuseReportDescription: "Please fill in details regarding this report. If it is about a specific note, please include its URL."
|
fillAbuseReportDescription: "Please fill in details regarding this report. If it is about a specific note, please include its URL."
|
||||||
abuseReported: "Your report has been sent. Thank you very much."
|
abuseReported: "Your report has been sent. Thank you very much."
|
||||||
|
reporteeOrigin: "Reportee Origin"
|
||||||
|
reporterOrigin: "Reporter Origin"
|
||||||
send: "Send"
|
send: "Send"
|
||||||
abuseMarkAsResolved: "Mark report as resolved"
|
abuseMarkAsResolved: "Mark report as resolved"
|
||||||
openInNewTab: "Open in new tab"
|
openInNewTab: "Open in new tab"
|
||||||
@@ -649,7 +656,7 @@ pollVotesCount: "Number of sent poll votes"
|
|||||||
pollVotedCount: "Number of received poll votes"
|
pollVotedCount: "Number of received poll votes"
|
||||||
yes: "Yes"
|
yes: "Yes"
|
||||||
no: "No"
|
no: "No"
|
||||||
driveFilesCount: "Number of drive files"
|
driveFilesCount: "Number of Drive files"
|
||||||
driveUsage: "Drive space usage"
|
driveUsage: "Drive space usage"
|
||||||
noCrawle: "Reject crawler indexing"
|
noCrawle: "Reject crawler indexing"
|
||||||
noCrawleDescription: "Ask search engines to not index your profile page, notes, Pages, etc."
|
noCrawleDescription: "Ask search engines to not index your profile page, notes, Pages, etc."
|
||||||
@@ -657,7 +664,7 @@ lockedAccountInfo: "Unless you set your note visiblity to \"Followers only\", yo
|
|||||||
alwaysMarkSensitive: "Mark as NSFW by default"
|
alwaysMarkSensitive: "Mark as NSFW by default"
|
||||||
loadRawImages: "Load original images instead of showing thumbnails"
|
loadRawImages: "Load original images instead of showing thumbnails"
|
||||||
disableShowingAnimatedImages: "Don't play animated images"
|
disableShowingAnimatedImages: "Don't play animated images"
|
||||||
verificationEmailSent: "A verification email has been sent. Please access the included link to complete verification."
|
verificationEmailSent: "A verification email has been sent. Please follow the included link to complete verification."
|
||||||
notSet: "Not set"
|
notSet: "Not set"
|
||||||
emailVerified: "Email has been verified"
|
emailVerified: "Email has been verified"
|
||||||
noteFavoritesCount: "Number of favorite notes"
|
noteFavoritesCount: "Number of favorite notes"
|
||||||
@@ -688,7 +695,7 @@ sendErrorReportsDescription: "When turned on, detailed error information will be
|
|||||||
myTheme: "My theme"
|
myTheme: "My theme"
|
||||||
backgroundColor: "Background color"
|
backgroundColor: "Background color"
|
||||||
accentColor: "Accent color"
|
accentColor: "Accent color"
|
||||||
textColor: "Textfarbe"
|
textColor: "Text color"
|
||||||
saveAs: "Save as..."
|
saveAs: "Save as..."
|
||||||
advanced: "Advanced"
|
advanced: "Advanced"
|
||||||
value: "Value"
|
value: "Value"
|
||||||
@@ -724,7 +731,7 @@ fullView: "Full view"
|
|||||||
quitFullView: "Exit full view"
|
quitFullView: "Exit full view"
|
||||||
addDescription: "Add description"
|
addDescription: "Add description"
|
||||||
userPagePinTip: "You can display notes here by selecting \"Pin to profile\" from the menu of individual notes."
|
userPagePinTip: "You can display notes here by selecting \"Pin to profile\" from the menu of individual notes."
|
||||||
notSpecifiedMentionWarning: "This note contains mentions of users not included as recipient"
|
notSpecifiedMentionWarning: "This note contains mentions of users not included as recipients"
|
||||||
info: "About"
|
info: "About"
|
||||||
userInfo: "User information"
|
userInfo: "User information"
|
||||||
unknown: "Unknown"
|
unknown: "Unknown"
|
||||||
@@ -748,7 +755,7 @@ switch: "Switch"
|
|||||||
noMaintainerInformationWarning: "Maintainer information is not configured."
|
noMaintainerInformationWarning: "Maintainer information is not configured."
|
||||||
noBotProtectionWarning: "Bot protection is not configured."
|
noBotProtectionWarning: "Bot protection is not configured."
|
||||||
configure: "Configure"
|
configure: "Configure"
|
||||||
postToGallery: "Post to Gallery"
|
postToGallery: "Create new gallery post"
|
||||||
gallery: "Gallery"
|
gallery: "Gallery"
|
||||||
recentPosts: "Recent posts"
|
recentPosts: "Recent posts"
|
||||||
popularPosts: "Popular posts"
|
popularPosts: "Popular posts"
|
||||||
@@ -762,6 +769,7 @@ middle: "Medium"
|
|||||||
low: "Low"
|
low: "Low"
|
||||||
emailNotConfiguredWarning: "Email address not set."
|
emailNotConfiguredWarning: "Email address not set."
|
||||||
ratio: "Ratio"
|
ratio: "Ratio"
|
||||||
|
previewNoteText: "Show preview"
|
||||||
customCss: "Custom CSS"
|
customCss: "Custom CSS"
|
||||||
customCssWarn: "This setting should only be used if you know what it does. Entering improper values may cause the client to stop functioning normally."
|
customCssWarn: "This setting should only be used if you know what it does. Entering improper values may cause the client to stop functioning normally."
|
||||||
global: "Global"
|
global: "Global"
|
||||||
@@ -771,13 +779,60 @@ received: "Received"
|
|||||||
searchResult: "Search results"
|
searchResult: "Search results"
|
||||||
hashtags: "Hashtags"
|
hashtags: "Hashtags"
|
||||||
troubleshooting: "Troubleshooting"
|
troubleshooting: "Troubleshooting"
|
||||||
_docs:
|
useBlurEffect: "Use blur effects in the UI"
|
||||||
continueReading: "Read more"
|
learnMore: "Learn more"
|
||||||
features: "Features"
|
misskeyUpdated: "Misskey has been updated!"
|
||||||
generalTopics: "General topics"
|
whatIsNew: "Show changes"
|
||||||
advancedTopics: "Advanced Topics"
|
translate: "Translate"
|
||||||
admin: "Administration"
|
translatedFrom: "Translated from {x}"
|
||||||
translateWarn: "This is a translated document. Its contents may differ from the original."
|
accountDeletionInProgress: "Account deletion is currently in progress"
|
||||||
|
usernameInfo: "A name that identifies your account from others on this server. You can use the alphabet (a~z, A~Z), digits (0~9) or underscores (_). Usernames cannot be changed later."
|
||||||
|
aiChanMode: "Ai Mode"
|
||||||
|
keepCw: "Keep Content Warnings"
|
||||||
|
pubSub: "Pub/Sub Accounts"
|
||||||
|
lastCommunication: "Last communication"
|
||||||
|
resolved: "Resolved"
|
||||||
|
unresolved: "Unresolved"
|
||||||
|
itsOn: "Enabled"
|
||||||
|
itsOff: "Disabled"
|
||||||
|
emailRequiredForSignup: "Require email address for sign-up"
|
||||||
|
unread: "Unread"
|
||||||
|
filter: "Filter"
|
||||||
|
controlPanel: "Control Panel"
|
||||||
|
manageAccounts: "Manage Accounts"
|
||||||
|
makeReactionsPublic: "Set reaction history to public"
|
||||||
|
makeReactionsPublicDescription: "This will make the list of all your past reactions publicly visible."
|
||||||
|
classic: "Classic"
|
||||||
|
muteThread: "Mute thread"
|
||||||
|
unmuteThread: "Unmute thread"
|
||||||
|
ffVisibility: "Follows/Followers Visibility"
|
||||||
|
ffVisibilityDescription: "Allows you to configure who can see who you follow and who follows you."
|
||||||
|
continueThread: "View thread continuation"
|
||||||
|
deleteAccountConfirm: "This will irreversibly delete your account. Proceed?"
|
||||||
|
incorrectPassword: "Incorrect password."
|
||||||
|
voteConfirm: "Confirm your vote for \"{choice}\"?"
|
||||||
|
hide: "Hide"
|
||||||
|
_emailUnavailable:
|
||||||
|
used: "This email address is already being used"
|
||||||
|
format: "The format of this email address is invalid"
|
||||||
|
disposable: "Disposable email addresses may not be used"
|
||||||
|
mx: "This email server is invalid"
|
||||||
|
smtp: "This email server is not responding"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "Public"
|
||||||
|
followers: "Visible to followers only"
|
||||||
|
private: "Private"
|
||||||
|
_signup:
|
||||||
|
almostThere: "Almost there"
|
||||||
|
emailAddressInfo: "Please enter your email address."
|
||||||
|
emailSent: "A confirmation email has been sent to your email address ({email}). Please click the included link to complete account creation."
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "Delete Account"
|
||||||
|
mayTakeTime: "As account deletion is a resource-heavy process, it may take some time to complete depending on how much content you have created and how many files you have uploaded."
|
||||||
|
sendEmail: "Once account deletion has been completed, an email will be sent to the email address registered to this account."
|
||||||
|
requestAccountDelete: "Request account deletion"
|
||||||
|
started: "Deletion has been started."
|
||||||
|
inProgress: "Deletion is currently in progress"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Back"
|
back: "Back"
|
||||||
reduceFrequencyOfThisAd: "Show this ad less"
|
reduceFrequencyOfThisAd: "Show this ad less"
|
||||||
@@ -789,7 +844,7 @@ _gallery:
|
|||||||
my: "My Gallery"
|
my: "My Gallery"
|
||||||
liked: "Liked Posts"
|
liked: "Liked Posts"
|
||||||
like: "Like"
|
like: "Like"
|
||||||
unlike: "Undo like"
|
unlike: "Remove like"
|
||||||
_email:
|
_email:
|
||||||
_follow:
|
_follow:
|
||||||
title: "You've got a new follower"
|
title: "You've got a new follower"
|
||||||
@@ -829,11 +884,11 @@ _mfm:
|
|||||||
url: "URL"
|
url: "URL"
|
||||||
urlDescription: "URLs can be displayed."
|
urlDescription: "URLs can be displayed."
|
||||||
link: "Link"
|
link: "Link"
|
||||||
linkDescription: "Specific parts of text can be displayed as an URL."
|
linkDescription: "Specific parts of text can be displayed as a URL."
|
||||||
bold: "Bold"
|
bold: "Bold"
|
||||||
boldDescription: "Highlights letters by making them thicker."
|
boldDescription: "Highlights letters by making them thicker."
|
||||||
small: "Small"
|
small: "Small"
|
||||||
smallDescription: "Displays contents small and thin."
|
smallDescription: "Displays content small and thin."
|
||||||
center: "Center"
|
center: "Center"
|
||||||
centerDescription: "Displays content centered."
|
centerDescription: "Displays content centered."
|
||||||
inlineCode: "Code (In-line)"
|
inlineCode: "Code (In-line)"
|
||||||
@@ -845,7 +900,7 @@ _mfm:
|
|||||||
blockMath: "Math (Block)"
|
blockMath: "Math (Block)"
|
||||||
blockMathDescription: "Display multi-line Math formulas (KaTeX) in a block"
|
blockMathDescription: "Display multi-line Math formulas (KaTeX) in a block"
|
||||||
quote: "Quote"
|
quote: "Quote"
|
||||||
quoteDescription: "Displays content as quote."
|
quoteDescription: "Displays content as a quote."
|
||||||
emoji: "Custom Emoji"
|
emoji: "Custom Emoji"
|
||||||
emojiDescription: "By surrounding a custom emoji name with colons, custom emoji can be displayed."
|
emojiDescription: "By surrounding a custom emoji name with colons, custom emoji can be displayed."
|
||||||
search: "Search"
|
search: "Search"
|
||||||
@@ -875,9 +930,13 @@ _mfm:
|
|||||||
blur: "Blur"
|
blur: "Blur"
|
||||||
blurDescription: "Content can be blurred via this effect. It will be displayed clearly when hovered over."
|
blurDescription: "Content can be blurred via this effect. It will be displayed clearly when hovered over."
|
||||||
font: "Font"
|
font: "Font"
|
||||||
fontDescription: "Sets the font to display contents in."
|
fontDescription: "Sets the font to display content in."
|
||||||
rainbow: "Rainbow"
|
rainbow: "Rainbow"
|
||||||
rainbowDescription: "Makes the content appear in rainbow colors."
|
rainbowDescription: "Makes the content appear in rainbow colors."
|
||||||
|
sparkle: "Sparkle"
|
||||||
|
sparkleDescription: "Gives content a sparkling particle effect."
|
||||||
|
rotate: "Rotate"
|
||||||
|
rotateDescription: "Turns content by a specified angle."
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Game settings"
|
gameSettings: "Game settings"
|
||||||
@@ -937,12 +996,17 @@ _menuDisplay:
|
|||||||
_wordMute:
|
_wordMute:
|
||||||
muteWords: "Muted words"
|
muteWords: "Muted words"
|
||||||
muteWordsDescription: "Separate with spaces for an AND condition or with line breaks for an OR condition."
|
muteWordsDescription: "Separate with spaces for an AND condition or with line breaks for an OR condition."
|
||||||
muteWordsDescription2: "Surround keywords by slashes to use regular expressions."
|
muteWordsDescription2: "Surround keywords with slashes to use regular expressions."
|
||||||
softDescription: "Hides notes fulfilling the set conditions from the timeline."
|
softDescription: "Hide notes that fulfil the set conditions from the timeline."
|
||||||
hardDescription: "Prevents notes fulfilling the set conditions from being added to the timeline. In addition, these notes will not be added to the timeline even if the conditions are changed."
|
hardDescription: "Prevents notes fulfilling the set conditions from being added to the timeline. In addition, these notes will not be added to the timeline even if the conditions are changed."
|
||||||
soft: "Soft"
|
soft: "Soft"
|
||||||
hard: "Hard"
|
hard: "Hard"
|
||||||
mutedNotes: "Muted notes"
|
mutedNotes: "Muted notes"
|
||||||
|
_instanceMute:
|
||||||
|
instanceMuteDescription: "This will mute any notes/renotes from the listed instances, including those of users replying to a user from a muted instance."
|
||||||
|
instanceMuteDescription2: "Separate with newlines"
|
||||||
|
title: "Hides notes from listed instances."
|
||||||
|
heading: "List of instances to be muted"
|
||||||
_theme:
|
_theme:
|
||||||
explore: "Explore Themes"
|
explore: "Explore Themes"
|
||||||
install: "Install a theme"
|
install: "Install a theme"
|
||||||
@@ -996,7 +1060,7 @@ _theme:
|
|||||||
divider: "Divider"
|
divider: "Divider"
|
||||||
scrollbarHandle: "Scrollbar handle"
|
scrollbarHandle: "Scrollbar handle"
|
||||||
scrollbarHandleHover: "Scrollbar handle (Hover)"
|
scrollbarHandleHover: "Scrollbar handle (Hover)"
|
||||||
dateLabelFg: "Text of date labels"
|
dateLabelFg: "Date label text"
|
||||||
infoBg: "Information background"
|
infoBg: "Information background"
|
||||||
infoFg: "Information text"
|
infoFg: "Information text"
|
||||||
infoWarnBg: "Warning background"
|
infoWarnBg: "Warning background"
|
||||||
@@ -1069,19 +1133,19 @@ _tutorial:
|
|||||||
_2fa:
|
_2fa:
|
||||||
alreadyRegistered: "You have already registered a 2-factor authentication device."
|
alreadyRegistered: "You have already registered a 2-factor authentication device."
|
||||||
registerDevice: "Register a new device"
|
registerDevice: "Register a new device"
|
||||||
registerKey: "Register a new Security Key"
|
registerKey: "Register a security key"
|
||||||
step1: "First, install an authentication app (such as {a} or {b}) on your device."
|
step1: "First, install an authentication app (such as {a} or {b}) on your device."
|
||||||
step2: "Then, scan the QR code displayed on this screen."
|
step2: "Then, scan the QR code displayed on this screen."
|
||||||
step3: "Enter the token provided by your app to finish setup."
|
step3: "Enter the token provided by your app to finish setup."
|
||||||
step4: "From now, any future login attempts will ask for such a login token."
|
step4: "From now on, any future login attempts will ask for such a login token."
|
||||||
securityKeyInfo: "Besides fingerprint or PIN authentication, you can also setup authentication via hardware security keys that support FIDO2 to further secure your login process."
|
securityKeyInfo: "Besides fingerprint or PIN authentication, you can also setup authentication via hardware security keys that support FIDO2 to further secure your account."
|
||||||
_permissions:
|
_permissions:
|
||||||
"read:account": "View your account information"
|
"read:account": "View your account information"
|
||||||
"write:account": "Edit your account information"
|
"write:account": "Edit your account information"
|
||||||
"read:blocks": "View the list of people you blocked"
|
"read:blocks": "View your list of blocked users"
|
||||||
"write:blocks": "Edit your list of blocked users"
|
"write:blocks": "Edit your list of blocked users"
|
||||||
"read:drive": "Access your drive files and folders"
|
"read:drive": "Access your Drive files and folders"
|
||||||
"write:drive": "Edit or delete your drive files and folders"
|
"write:drive": "Edit or delete your Drive files and folders"
|
||||||
"read:favorites": "View your list of favorites"
|
"read:favorites": "View your list of favorites"
|
||||||
"write:favorites": "Edit your list of favorites"
|
"write:favorites": "Edit your list of favorites"
|
||||||
"read:following": "View information on who you follow"
|
"read:following": "View information on who you follow"
|
||||||
@@ -1104,6 +1168,10 @@ _permissions:
|
|||||||
"write:user-groups": "Edit or delete your user groups"
|
"write:user-groups": "Edit or delete your user groups"
|
||||||
"read:channels": "Read your channels"
|
"read:channels": "Read your channels"
|
||||||
"write:channels": "Modify your channels"
|
"write:channels": "Modify your channels"
|
||||||
|
"read:gallery": "View your gallery"
|
||||||
|
"write:gallery": "Edit your gallery"
|
||||||
|
"read:gallery-likes": "View list of liked gallery posts"
|
||||||
|
"write:gallery-likes": "Edit list of liked gallery posts"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "Would you like to authorize \"{name}\" to access this account?"
|
shareAccess: "Would you like to authorize \"{name}\" to access this account?"
|
||||||
shareAccessAsk: "Are you sure you want to authorize this application to access your account?"
|
shareAccessAsk: "Are you sure you want to authorize this application to access your account?"
|
||||||
@@ -1144,6 +1212,7 @@ _widgets:
|
|||||||
jobQueue: "Job Queue"
|
jobQueue: "Job Queue"
|
||||||
serverMetric: "Server metrics"
|
serverMetric: "Server metrics"
|
||||||
aiscript: "AiScript console"
|
aiscript: "AiScript console"
|
||||||
|
aichan: "Ai"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "Hide"
|
hide: "Hide"
|
||||||
show: "Show content"
|
show: "Show content"
|
||||||
@@ -1211,6 +1280,8 @@ _exportOrImport:
|
|||||||
muteList: "Muted users"
|
muteList: "Muted users"
|
||||||
blockingList: "Blocked users"
|
blockingList: "Blocked users"
|
||||||
userLists: "User lists"
|
userLists: "User lists"
|
||||||
|
excludeMutingUsers: "Exclude muted users"
|
||||||
|
excludeInactiveUsers: "Exclude inactive users"
|
||||||
_charts:
|
_charts:
|
||||||
federationInstancesIncDec: "Difference in # of federating instances"
|
federationInstancesIncDec: "Difference in # of federating instances"
|
||||||
federationInstancesTotal: "Total # of federating instances"
|
federationInstancesTotal: "Total # of federating instances"
|
||||||
@@ -1305,23 +1376,23 @@ _rooms:
|
|||||||
doll-ai: "Ai doll"
|
doll-ai: "Ai doll"
|
||||||
banknote: "Pile of money"
|
banknote: "Pile of money"
|
||||||
_pages:
|
_pages:
|
||||||
newPage: "Create a page"
|
newPage: "Create a new Page"
|
||||||
editPage: "Edit this page"
|
editPage: "Edit this Page"
|
||||||
readPage: "Source view activated"
|
readPage: "Source view activated"
|
||||||
created: "Page successfully created"
|
created: "Page successfully created"
|
||||||
updated: "Page successfully edited"
|
updated: "Page successfully edited"
|
||||||
deleted: "Page successfully deleted"
|
deleted: "Page successfully deleted"
|
||||||
pageSetting: "Page settings"
|
pageSetting: "Page settings"
|
||||||
nameAlreadyExists: "The specified page URL already exists"
|
nameAlreadyExists: "The specified Page URL already exists"
|
||||||
invalidNameTitle: "The specified page URL is invalid"
|
invalidNameTitle: "The specified Page URL is invalid"
|
||||||
invalidNameText: "Make sure the page title is not empty"
|
invalidNameText: "Make sure the Page title is not empty"
|
||||||
editThisPage: "Edit this page"
|
editThisPage: "Edit this Page"
|
||||||
viewSource: "View source"
|
viewSource: "View source"
|
||||||
viewPage: "View your pages"
|
viewPage: "View your Pages"
|
||||||
like: "Like"
|
like: "Like"
|
||||||
unlike: "Undo like"
|
unlike: "Remove like"
|
||||||
my: "My pages"
|
my: "My Pages"
|
||||||
liked: "Liked pages"
|
liked: "Liked Pages"
|
||||||
featured: "Featured"
|
featured: "Featured"
|
||||||
inspector: "Inspector"
|
inspector: "Inspector"
|
||||||
contents: "Contents"
|
contents: "Contents"
|
||||||
@@ -1331,10 +1402,10 @@ _pages:
|
|||||||
url: "Page URL"
|
url: "Page URL"
|
||||||
summary: "Page summary"
|
summary: "Page summary"
|
||||||
alignCenter: "Center elements"
|
alignCenter: "Center elements"
|
||||||
hideTitleWhenPinned: "Hide page title when pinned to profile"
|
hideTitleWhenPinned: "Hide Page title when pinned to profile"
|
||||||
font: "Font"
|
font: "Font"
|
||||||
fontSerif: "Serif"
|
fontSerif: "Serif"
|
||||||
fontSansSerif: "Sans serif"
|
fontSansSerif: "Sans Serif"
|
||||||
eyeCatchingImageSet: "Set thumbnail"
|
eyeCatchingImageSet: "Set thumbnail"
|
||||||
eyeCatchingImageRemove: "Delete thumbnail"
|
eyeCatchingImageRemove: "Delete thumbnail"
|
||||||
chooseBlock: "Add a block"
|
chooseBlock: "Add a block"
|
||||||
@@ -1549,7 +1620,7 @@ _pages:
|
|||||||
seedRandomPick: "Randomly choose from list (with seed)"
|
seedRandomPick: "Randomly choose from list (with seed)"
|
||||||
_seedRandomPick:
|
_seedRandomPick:
|
||||||
arg1: "Seed"
|
arg1: "Seed"
|
||||||
arg2: "Liste"
|
arg2: "List"
|
||||||
DRPWPM: "Randomly choose from weighted list (Changes once a day for each user)"
|
DRPWPM: "Randomly choose from weighted list (Changes once a day for each user)"
|
||||||
_DRPWPM:
|
_DRPWPM:
|
||||||
arg1: "Text list"
|
arg1: "Text list"
|
||||||
@@ -1629,8 +1700,8 @@ _deck:
|
|||||||
columnMargin: "Margin between columns"
|
columnMargin: "Margin between columns"
|
||||||
columnHeaderHeight: "Column header height"
|
columnHeaderHeight: "Column header height"
|
||||||
addColumn: "Add column"
|
addColumn: "Add column"
|
||||||
swapLeft: "Swap to left"
|
swapLeft: "Swap left"
|
||||||
swapRight: "Swap to right"
|
swapRight: "Swap right"
|
||||||
swapUp: "Swap with above"
|
swapUp: "Swap with above"
|
||||||
swapDown: "Swap with below"
|
swapDown: "Swap with below"
|
||||||
stackLeft: "Stack on left column"
|
stackLeft: "Stack on left column"
|
||||||
|
File diff suppressed because it is too large
Load Diff
@@ -7,6 +7,7 @@ search: "Buscar"
|
|||||||
notifications: "Notificaciones"
|
notifications: "Notificaciones"
|
||||||
username: "Nombre de usuario"
|
username: "Nombre de usuario"
|
||||||
password: "Contraseña"
|
password: "Contraseña"
|
||||||
|
forgotPassword: "Olvidé mi Contraseña"
|
||||||
fetchingAsApObject: "Buscando en el fediverso"
|
fetchingAsApObject: "Buscando en el fediverso"
|
||||||
ok: "OK"
|
ok: "OK"
|
||||||
gotIt: "Entendido"
|
gotIt: "Entendido"
|
||||||
@@ -279,6 +280,7 @@ emptyDrive: "El drive está vacío"
|
|||||||
emptyFolder: "La carpeta está vacía"
|
emptyFolder: "La carpeta está vacía"
|
||||||
unableToDelete: "No se puede borrar"
|
unableToDelete: "No se puede borrar"
|
||||||
inputNewFileName: "Ingrese un nuevo nombre de archivo"
|
inputNewFileName: "Ingrese un nuevo nombre de archivo"
|
||||||
|
inputNewDescription: "Ingrese nueva descripción"
|
||||||
inputNewFolderName: "Ingrese un nuevo nombre de la carpeta"
|
inputNewFolderName: "Ingrese un nuevo nombre de la carpeta"
|
||||||
circularReferenceFolder: "La carpeta de destino es una sub-carpeta de la carpeta que quieres mover."
|
circularReferenceFolder: "La carpeta de destino es una sub-carpeta de la carpeta que quieres mover."
|
||||||
hasChildFilesOrFolders: "No se puede borrar esta carpeta. No está vacía."
|
hasChildFilesOrFolders: "No se puede borrar esta carpeta. No está vacía."
|
||||||
@@ -310,6 +312,8 @@ monthX: "Mes {month}"
|
|||||||
yearX: "Año {year}"
|
yearX: "Año {year}"
|
||||||
pages: "Páginas"
|
pages: "Páginas"
|
||||||
integration: "Integración"
|
integration: "Integración"
|
||||||
|
connectService: "Conectar"
|
||||||
|
disconnectService: "Desconectar"
|
||||||
enableLocalTimeline: "Habilitar linea de tiempo local"
|
enableLocalTimeline: "Habilitar linea de tiempo local"
|
||||||
enableGlobalTimeline: "Habilitar linea de tiempo global"
|
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"
|
disablingTimelinesInfo: "Aunque se desactiven estas lineas de tiempo, por conveniencia el administrador y los moderadores pueden seguir usándolos"
|
||||||
@@ -323,6 +327,7 @@ driveCapacityPerRemoteAccount: "Capacidad del drive por usuario remoto"
|
|||||||
inMb: "En megabytes"
|
inMb: "En megabytes"
|
||||||
iconUrl: "URL de la imagen del avatar"
|
iconUrl: "URL de la imagen del avatar"
|
||||||
bannerUrl: "URL de la imagen del banner"
|
bannerUrl: "URL de la imagen del banner"
|
||||||
|
backgroundImageUrl: "URL de la imagen de fondo"
|
||||||
basicInfo: "Información básica"
|
basicInfo: "Información básica"
|
||||||
pinnedUsers: "Usuarios fijados"
|
pinnedUsers: "Usuarios fijados"
|
||||||
pinnedUsersDescription: "Describir los usuarios que quiere fijar en la página \"Descubrir\" separados por una linea nueva"
|
pinnedUsersDescription: "Describir los usuarios que quiere fijar en la página \"Descubrir\" separados por una linea nueva"
|
||||||
@@ -524,6 +529,9 @@ removeAllFollowing: "Retener todos los siguientes"
|
|||||||
removeAllFollowingDescription: "Cancelar todos los siguientes del servidor {host}. Ejecutar en caso de que esta instancia haya dejado de existir"
|
removeAllFollowingDescription: "Cancelar todos los siguientes del servidor {host}. Ejecutar en caso de que esta instancia haya dejado de existir"
|
||||||
userSuspended: "Este usuario ha sido suspendido."
|
userSuspended: "Este usuario ha sido suspendido."
|
||||||
userSilenced: "Este usuario ha sido silenciado."
|
userSilenced: "Este usuario ha sido silenciado."
|
||||||
|
yourAccountSuspendedTitle: "Esta cuenta ha sido suspendida"
|
||||||
|
yourAccountSuspendedDescription: "Esta cuenta ha sido suspendida debido a violaciones de los términos de servicio del servidor y otras razones. Para más información, póngase en contacto con el administrador. Por favor, no cree una nueva cuenta."
|
||||||
|
menu: "Menú"
|
||||||
divider: "Divisor"
|
divider: "Divisor"
|
||||||
addItem: "Agregar elemento"
|
addItem: "Agregar elemento"
|
||||||
rooms: "Cuartos"
|
rooms: "Cuartos"
|
||||||
@@ -543,6 +551,8 @@ disablePlayer: "Cerrar reproductor"
|
|||||||
expandTweet: "Expandir tweet"
|
expandTweet: "Expandir tweet"
|
||||||
themeEditor: "Editor de temas"
|
themeEditor: "Editor de temas"
|
||||||
description: "Descripción"
|
description: "Descripción"
|
||||||
|
describeFile: "Añade una descripción"
|
||||||
|
enterFileDescription: "Introducir un título"
|
||||||
author: "Autor"
|
author: "Autor"
|
||||||
leaveConfirm: "Hay modificaciones sin guardar. ¿Desea descartarlas?"
|
leaveConfirm: "Hay modificaciones sin guardar. ¿Desea descartarlas?"
|
||||||
manage: "Administrar"
|
manage: "Administrar"
|
||||||
@@ -645,31 +655,92 @@ driveFilesCount: "Cantidad de archivos en el drive"
|
|||||||
driveUsage: "Uso del drive"
|
driveUsage: "Uso del drive"
|
||||||
noCrawle: "Rechazar indexación del crawler"
|
noCrawle: "Rechazar indexación del crawler"
|
||||||
noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, notas, páginas, etc."
|
noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, notas, páginas, etc."
|
||||||
|
lockedAccountInfo: "A menos que configures la visibilidad de tus notas como \"Sólo seguidores\", tus notas serán visibles para cualquiera, incluso si requieres que los seguidores sean aprobados manualmente."
|
||||||
alwaysMarkSensitive: "Marcar los medios de comunicación como contenido sensible por defecto"
|
alwaysMarkSensitive: "Marcar los medios de comunicación como contenido sensible por defecto"
|
||||||
|
loadRawImages: "Cargar las imágenes originales en lugar de mostrar las miniaturas"
|
||||||
|
disableShowingAnimatedImages: "No reproducir imágenes animadas"
|
||||||
verificationEmailSent: "Se le ha enviado un correo electrónico de confirmación. Por favor, acceda al enlace proporcionado en el correo electrónico para completar la configuración."
|
verificationEmailSent: "Se le ha enviado un correo electrónico de confirmación. Por favor, acceda al enlace proporcionado en el correo electrónico para completar la configuración."
|
||||||
notSet: "Sin especificar"
|
notSet: "Sin especificar"
|
||||||
emailVerified: "Su dirección de correo electrónico ha sido verificada."
|
emailVerified: "Su dirección de correo electrónico ha sido verificada."
|
||||||
noteFavoritesCount: "Número de notas favoritas"
|
noteFavoritesCount: "Número de notas favoritas"
|
||||||
pageLikesCount: "Número de favoritos en la página"
|
pageLikesCount: "Número de favoritos en la página"
|
||||||
pageLikedCount: "Número de favoritos de su página"
|
pageLikedCount: "Número de favoritos de su página"
|
||||||
|
reversiCount: "Numero de partidas Reversi"
|
||||||
contact: "Contacto"
|
contact: "Contacto"
|
||||||
|
useSystemFont: "Utilizar la tipografía por defecto del sistema"
|
||||||
clips: "Clip"
|
clips: "Clip"
|
||||||
|
experimentalFeatures: "Características experimentales"
|
||||||
|
developer: "Desarrolladores"
|
||||||
|
makeExplorable: "Hacer visible la cuenta en \"Explorar\""
|
||||||
|
makeExplorableDescription: "Si desactiva esta opción, su cuenta no aparecerá en la sección \"Explorar\"."
|
||||||
|
showGapBetweenNotesInTimeline: "Mostrar un intervalo entre notas en la línea de tiempo"
|
||||||
|
duplicate: "Duplicar"
|
||||||
|
left: "Izquierda"
|
||||||
|
center: "Centrar"
|
||||||
|
wide: "Ancho"
|
||||||
|
narrow: "Estrecho"
|
||||||
|
reloadToApplySetting: "Esta configuración sólo se aplicará después de recargar la página. ¿Recargar ahora?"
|
||||||
|
showTitlebar: "Mostrar la barra de título"
|
||||||
clearCache: "Limpiar caché"
|
clearCache: "Limpiar caché"
|
||||||
|
onlineUsersCount: "{n} usuarios en línea"
|
||||||
|
nUsers: "{n} Usuarios"
|
||||||
|
nNotes: "{n} Notas"
|
||||||
|
sendErrorReports: "Envíar informe de errores"
|
||||||
|
sendErrorReportsDescription: "Si habilita esta opción, ayudará a mejorar la calidad de Misskey compartiendo información detallada sobre los errores cuando se produzca un problema.\nEsto incluye información como la versión de su sistema operativo, el tipo de navegador que utiliza, su historial de actividad, etc."
|
||||||
|
myTheme: "Mi Tema"
|
||||||
backgroundColor: "Fondo"
|
backgroundColor: "Fondo"
|
||||||
accentColor: "Acento"
|
accentColor: "Acento"
|
||||||
textColor: "Texto"
|
textColor: "Texto"
|
||||||
|
saveAs: "Guardar como…"
|
||||||
|
advanced: "Avanzado"
|
||||||
value: "Valores"
|
value: "Valores"
|
||||||
|
createdAt: "Fecha de creación"
|
||||||
|
updatedAt: "Actualizado"
|
||||||
|
saveConfirm: "¿Guardar cambios?"
|
||||||
|
deleteConfirm: "¿Desea eliminarlo?"
|
||||||
|
invalidValue: "Este no es un valor válido."
|
||||||
|
registry: "Registro"
|
||||||
|
closeAccount: "Cerrar cuenta"
|
||||||
|
currentVersion: "Versión actual"
|
||||||
|
latestVersion: "Última versión"
|
||||||
|
youAreRunningUpToDateClient: "Está utilizando la versión más reciente de su cliente."
|
||||||
|
newVersionOfClientAvailable: "Hay una versión más nueva de su cliente disponible."
|
||||||
|
usageAmount: "Uso"
|
||||||
|
capacity: "Capacidad"
|
||||||
|
inUse: "Usado"
|
||||||
|
editCode: "Editar código"
|
||||||
goBack: "Deseleccionar"
|
goBack: "Deseleccionar"
|
||||||
info: "Información"
|
info: "Información"
|
||||||
user: "Usuarios"
|
user: "Usuarios"
|
||||||
administration: "Administrar"
|
administration: "Administrar"
|
||||||
expiration: "Termina el"
|
expiration: "Termina el"
|
||||||
middle: "Mediano"
|
middle: "Mediano"
|
||||||
|
customCssWarn: "Este ajuste sólo debe utilizarse si se sabe lo que hace. Introducir valores inadecuados puede hacer que el cliente deje de funcionar con normalidad."
|
||||||
global: "Global"
|
global: "Global"
|
||||||
|
squareAvatars: "Mostrar iconos cuadrados"
|
||||||
sent: "Enviar"
|
sent: "Enviar"
|
||||||
|
received: "Recibido"
|
||||||
|
searchResult: "Resultados de búsqueda"
|
||||||
hashtags: "Hashtag"
|
hashtags: "Hashtag"
|
||||||
_docs:
|
troubleshooting: "Solución de problemas"
|
||||||
admin: "Administrar"
|
useBlurEffect: "Utilizar efecto de desenfoque en la interfaz de usuario"
|
||||||
|
learnMore: "Ver más"
|
||||||
|
misskeyUpdated: "¡Misskey ha sido actualizado!"
|
||||||
|
whatIsNew: "Mostrar cambios"
|
||||||
|
translate: "Traducir"
|
||||||
|
translatedFrom: "Traducido de {x}"
|
||||||
|
accountDeletionInProgress: "La eliminación de la cuenta está en curso"
|
||||||
|
usernameInfo: "Un nombre que identifique su cuenta de otras en este servidor. Puede utilizar el alfabeto (a~z, A~Z), dígitos (0~9) o guiones bajos (_). Los nombres de usuario no se pueden cambiar posteriormente."
|
||||||
|
aiChanMode: "Modo Ai"
|
||||||
|
keepCw: "Mantener la advertencia de contenido"
|
||||||
|
pubSub: "Cuentas Pub/Sub"
|
||||||
|
lastCommunication: "Última comunicación"
|
||||||
|
resolved: "Resuelto"
|
||||||
|
unresolved: "Sin resolver"
|
||||||
|
controlPanel: "Panel de control"
|
||||||
|
hide: "Ocultar"
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "Eliminar Cuenta"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Deseleccionar"
|
back: "Deseleccionar"
|
||||||
_gallery:
|
_gallery:
|
||||||
@@ -698,6 +769,7 @@ _mfm:
|
|||||||
flip: "Echar de un capirotazo"
|
flip: "Echar de un capirotazo"
|
||||||
flipDescription: "Voltea el contenido hacia arriba / abajo o hacia la izquierda / derecha."
|
flipDescription: "Voltea el contenido hacia arriba / abajo o hacia la izquierda / derecha."
|
||||||
font: "Fuente"
|
font: "Fuente"
|
||||||
|
rotate: "Rotar"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Configuración del juego"
|
gameSettings: "Configuración del juego"
|
||||||
|
@@ -81,6 +81,8 @@ somethingHappened: "Une erreur est survenue"
|
|||||||
retry: "Réessayer"
|
retry: "Réessayer"
|
||||||
pageLoadError: "Le chargement de la page a échoué"
|
pageLoadError: "Le chargement de la page a échoué"
|
||||||
pageLoadErrorDescription: "Cela est généralement causé par le cache du navigateur ou par un problème réseau. Veuillez vider votre cache ou attendre un peu et réessayer."
|
pageLoadErrorDescription: "Cela est généralement causé par le cache du navigateur ou par un problème réseau. Veuillez vider votre cache ou attendre un peu et réessayer."
|
||||||
|
serverIsDead: "Le serveur ne répond pas. Patientez quelques instants puis essayez à nouveau."
|
||||||
|
youShouldUpgradeClient: "Si la page ne s'affiche pas correctement, rechargez-la pour mettre votre client à jour."
|
||||||
enterListName: "Nom de la liste"
|
enterListName: "Nom de la liste"
|
||||||
privacy: "Confidentialité"
|
privacy: "Confidentialité"
|
||||||
makeFollowManuallyApprove: "Accepter manuellement les demandes d’abonnement"
|
makeFollowManuallyApprove: "Accepter manuellement les demandes d’abonnement"
|
||||||
@@ -91,11 +93,11 @@ followRequests: "Demandes d’abonnement"
|
|||||||
unfollow: "Se désabonner"
|
unfollow: "Se désabonner"
|
||||||
followRequestPending: "Demande d'abonnement en attente de confirmation"
|
followRequestPending: "Demande d'abonnement en attente de confirmation"
|
||||||
enterEmoji: "Insérer un émoji"
|
enterEmoji: "Insérer un émoji"
|
||||||
renote: "Partager"
|
renote: "Renoter"
|
||||||
unrenote: "Annuler le partage"
|
unrenote: "Annuler la Renote"
|
||||||
renoted: "Republié !"
|
renoted: "Renoté !"
|
||||||
cantRenote: "Ce message ne peut pas être republié."
|
cantRenote: "Ce message ne peut pas être renoté."
|
||||||
cantReRenote: "Impossible de repartager un partage."
|
cantReRenote: "Impossible de renoter une Renote."
|
||||||
quote: "Citer"
|
quote: "Citer"
|
||||||
pinnedNote: "Note épinglée"
|
pinnedNote: "Note épinglée"
|
||||||
pinned: "Épingler sur le profil"
|
pinned: "Épingler sur le profil"
|
||||||
@@ -136,7 +138,7 @@ settingGuide: "Configuration proposée"
|
|||||||
cacheRemoteFiles: "Mise en cache des fichiers distants"
|
cacheRemoteFiles: "Mise en cache des fichiers distants"
|
||||||
cacheRemoteFilesDescription: "Lorsque cette option est désactivée, les fichiers distants sont chargés directement depuis l’instance distante. La désactiver diminuera certes l’utilisation de l’espace de stockage local mais augmentera le trafic réseau puisque les miniatures ne seront plus générées."
|
cacheRemoteFilesDescription: "Lorsque cette option est désactivée, les fichiers distants sont chargés directement depuis l’instance distante. La désactiver diminuera certes l’utilisation de l’espace de stockage local mais augmentera le trafic réseau puisque les miniatures ne seront plus générées."
|
||||||
flagAsBot: "Ce compte est un robot"
|
flagAsBot: "Ce compte est un robot"
|
||||||
flagAsBotDescription: "Si ce compte est géré de manière automatisée , définissez cette option. Si elle est activée, elle agira comme un marqueur pour les autres développeurs afin d'éviter des chaînes d'interaction sans fin avec d'autres robots et d'ajuster les systèmes internes de Misskey pour traiter ce compte comme un robot."
|
flagAsBotDescription: "Si ce compte est géré de manière automatisée, choisissez cette option. Si elle est activée, elle agira comme un marqueur pour les autres développeurs afin d'éviter des chaînes d'interaction sans fin avec d'autres robots et d'ajuster les systèmes internes de Misskey pour traiter ce compte comme un robot."
|
||||||
flagAsCat: "Ce compte est un chat"
|
flagAsCat: "Ce compte est un chat"
|
||||||
flagAsCatDescription: "Activer l'option \" Je suis un chat \" pour ce compte."
|
flagAsCatDescription: "Activer l'option \" Je suis un chat \" pour ce compte."
|
||||||
autoAcceptFollowed: "Accepter automatiquement les demandes d’abonnement venant d’utilisateur·rice·s que vous suivez"
|
autoAcceptFollowed: "Accepter automatiquement les demandes d’abonnement venant d’utilisateur·rice·s que vous suivez"
|
||||||
@@ -363,7 +365,7 @@ withFiles: "Avec fichiers joints"
|
|||||||
silence: "Mettre en sourdine"
|
silence: "Mettre en sourdine"
|
||||||
silenceConfirm: "Êtes-vous sûr·e de vouloir mettre l’utilisateur·rice en sourdine ?"
|
silenceConfirm: "Êtes-vous sûr·e de vouloir mettre l’utilisateur·rice en sourdine ?"
|
||||||
unsilence: "Annuler la sourdine"
|
unsilence: "Annuler la sourdine"
|
||||||
unsilenceConfirm: "Êtes-vous sûr·e de vouloir annuler la mise en sourdine de cette utilisateur·rice ?"
|
unsilenceConfirm: "Êtes-vous sûr·e de vouloir annuler la mise en sourdine de cet·te utilisateur·rice ?"
|
||||||
popularUsers: "Utilisateur·rice·s populaires"
|
popularUsers: "Utilisateur·rice·s populaires"
|
||||||
recentlyUpdatedUsers: "Utilisateur·rice·s actif·ve·s récemment"
|
recentlyUpdatedUsers: "Utilisateur·rice·s actif·ve·s récemment"
|
||||||
recentlyRegisteredUsers: "Utilisateur·rice·s récemment inscrit·e·s"
|
recentlyRegisteredUsers: "Utilisateur·rice·s récemment inscrit·e·s"
|
||||||
@@ -377,7 +379,7 @@ aboutMisskey: "À propos de Misskey"
|
|||||||
administrator: "Administrateur"
|
administrator: "Administrateur"
|
||||||
token: "Jeton"
|
token: "Jeton"
|
||||||
twoStepAuthentication: "Authentification à deux facteurs"
|
twoStepAuthentication: "Authentification à deux facteurs"
|
||||||
moderator: "Modérateurs"
|
moderator: "Modérateur·rice·s"
|
||||||
nUsersMentioned: "{n} utilisateur·rice·s mentionné·e·s"
|
nUsersMentioned: "{n} utilisateur·rice·s mentionné·e·s"
|
||||||
securityKey: "Clé de sécurité"
|
securityKey: "Clé de sécurité"
|
||||||
securityKeyName: "Nom de la clé"
|
securityKeyName: "Nom de la clé"
|
||||||
@@ -429,7 +431,7 @@ invitationCode: "Code d’invitation"
|
|||||||
checking: "Vérification en cours..."
|
checking: "Vérification en cours..."
|
||||||
available: "Disponible"
|
available: "Disponible"
|
||||||
unavailable: "Non disponible"
|
unavailable: "Non disponible"
|
||||||
usernameInvalidFormat: "Le nom d'utilisateur peut contenir uniquement des lettres, des chiffres et des _"
|
usernameInvalidFormat: "Le nom d'utilisateur peut contenir uniquement des lettres (minuscules et/ou majuscules), des chiffres et des _"
|
||||||
tooShort: "Trop court"
|
tooShort: "Trop court"
|
||||||
tooLong: "Trop long"
|
tooLong: "Trop long"
|
||||||
weakPassword: "Mot de passe faible"
|
weakPassword: "Mot de passe faible"
|
||||||
@@ -495,7 +497,7 @@ objectStorageSetPublicRead: "Régler sur « public » lors de l'envoi"
|
|||||||
serverLogs: "Journal du serveur"
|
serverLogs: "Journal du serveur"
|
||||||
deleteAll: "Supprimer tout"
|
deleteAll: "Supprimer tout"
|
||||||
showFixedPostForm: "Afficher le formulaire de publication en haut du fil d'actualité"
|
showFixedPostForm: "Afficher le formulaire de publication en haut du fil d'actualité"
|
||||||
newNoteRecived: "Vous avez reçu une nouvelle note"
|
newNoteRecived: "Voir les nouvelles notes"
|
||||||
sounds: "Sons"
|
sounds: "Sons"
|
||||||
listen: "Écouter"
|
listen: "Écouter"
|
||||||
none: "Rien"
|
none: "Rien"
|
||||||
@@ -529,6 +531,8 @@ removeAllFollowing: "Retenir tous les abonnements"
|
|||||||
removeAllFollowingDescription: "Se désabonner de tous les comptes de {host}. Veuillez lancer cette action uniquement si l’instance n’existe plus."
|
removeAllFollowingDescription: "Se désabonner de tous les comptes de {host}. Veuillez lancer cette action uniquement si l’instance n’existe plus."
|
||||||
userSuspended: "Cet·te utilisateur·rice a été suspendu·e."
|
userSuspended: "Cet·te utilisateur·rice a été suspendu·e."
|
||||||
userSilenced: "Cette utilisateur·trice a été mis·e en sourdine."
|
userSilenced: "Cette utilisateur·trice a été mis·e en sourdine."
|
||||||
|
yourAccountSuspendedTitle: "Ce compte est suspendu"
|
||||||
|
yourAccountSuspendedDescription: "Ce compte est suspendu car vous avez enfreint les conditions d'utilisation de l'instance, ou pour un motif similaire. Si vous souhaitez connaître en détail les raisons de cette suspension, renseignez-vous auprès de l'administrateur·rice de votre instance. Merci de ne pas créer de nouveau compte."
|
||||||
menu: "Menu"
|
menu: "Menu"
|
||||||
divider: "Séparateur"
|
divider: "Séparateur"
|
||||||
addItem: "Ajouter un élément"
|
addItem: "Ajouter un élément"
|
||||||
@@ -638,9 +642,9 @@ manageAccessTokens: "Gérer les jetons d'accès"
|
|||||||
accountInfo: " Informations du compte "
|
accountInfo: " Informations du compte "
|
||||||
notesCount: "Nombre de notes"
|
notesCount: "Nombre de notes"
|
||||||
repliesCount: "Nombre de réponses envoyées"
|
repliesCount: "Nombre de réponses envoyées"
|
||||||
renotesCount: "Nombre de notes repartagées"
|
renotesCount: "Nombre de notes que vous avez renotées"
|
||||||
repliedCount: "Nombre de réponses reçues"
|
repliedCount: "Nombre de réponses reçues"
|
||||||
renotedCount: "Nombre de Renotes"
|
renotedCount: "Nombre de vos notes renotées"
|
||||||
followingCount: "Nombre de comptes suivis"
|
followingCount: "Nombre de comptes suivis"
|
||||||
followersCount: "Nombre d'abonnés"
|
followersCount: "Nombre d'abonnés"
|
||||||
sentReactionsCount: "Nombre de réactions envoyées"
|
sentReactionsCount: "Nombre de réactions envoyées"
|
||||||
@@ -762,19 +766,58 @@ middle: "Moyen"
|
|||||||
low: "Basse"
|
low: "Basse"
|
||||||
emailNotConfiguredWarning: "Vous n'avez pas configuré d'adresse e-mail."
|
emailNotConfiguredWarning: "Vous n'avez pas configuré d'adresse e-mail."
|
||||||
ratio: "Ratio"
|
ratio: "Ratio"
|
||||||
|
previewNoteText: "Voir l'aperçu"
|
||||||
customCss: "CSS personnalisé"
|
customCss: "CSS personnalisé"
|
||||||
customCssWarn: "Utilisez cette fonctionnalité uniquement si vous savez exactement ce que vous faites. Une configuration inadaptée peut empêcher le client de s'exécuter normalement."
|
customCssWarn: "Utilisez cette fonctionnalité uniquement si vous savez exactement ce que vous faites. Une configuration inadaptée peut empêcher le client de s'exécuter normalement."
|
||||||
global: "Global"
|
global: "Global"
|
||||||
squareAvatars: "Avatars carrés"
|
squareAvatars: "Avatars carrés"
|
||||||
sent: "Envoyer"
|
sent: "Envoyer"
|
||||||
|
received: "Reçu"
|
||||||
|
searchResult: "Résultats de la recherche"
|
||||||
hashtags: "Hashtags"
|
hashtags: "Hashtags"
|
||||||
troubleshooting: "Résolution de problèmes"
|
troubleshooting: "Résolution de problèmes"
|
||||||
_docs:
|
useBlurEffect: "Utiliser des effets de flou dans l'interface"
|
||||||
continueReading: "Lire plus"
|
learnMore: "Plus d'informations"
|
||||||
features: "Fonctionnalités"
|
misskeyUpdated: "Misskey a été mis à jour !"
|
||||||
generalTopics: "Sujets généraux"
|
whatIsNew: "Voir les derniers changements"
|
||||||
advancedTopics: "Sujets avancés"
|
translate: "Traduire"
|
||||||
admin: "Gestion"
|
translatedFrom: "Traduit depuis {x}"
|
||||||
|
accountDeletionInProgress: "La suppression de votre compte est en cours"
|
||||||
|
usernameInfo: "C'est un nom qui identifie votre compte sur l'instance de manière unique. Vous pouvez utiliser des lettres de l'alphabet (minuscules et majuscules), des chiffres (de 0 à 9), ou bien le tiret « _ ». Vous ne pourrez pas modifier votre nom d'utilisateur·rice par la suite."
|
||||||
|
aiChanMode: "Mode Ai"
|
||||||
|
keepCw: "Garder le CW"
|
||||||
|
pubSub: "Comptes Pub/Sub"
|
||||||
|
lastCommunication: "Dernière communication"
|
||||||
|
resolved: "Résolu"
|
||||||
|
unresolved: "En attente"
|
||||||
|
itsOn: "Activé"
|
||||||
|
itsOff: "Désactivé"
|
||||||
|
emailRequiredForSignup: "Une adresse e-mail est nécessaire pour créer un compte"
|
||||||
|
unread: "Non lu"
|
||||||
|
filter: "Filtre"
|
||||||
|
controlPanel: "Panneau de contrôle"
|
||||||
|
manageAccounts: "Gérer les comptes"
|
||||||
|
classic: "Classique"
|
||||||
|
hide: "Masquer"
|
||||||
|
_emailUnavailable:
|
||||||
|
format: "Le format de cette adresse de courriel est invalide"
|
||||||
|
mx: "Ce serveur de courriels est invalide"
|
||||||
|
smtp: "Ce serveur de courriels ne répond pas"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "Public"
|
||||||
|
followers: "Visible uniquement pour les abonné·e·s"
|
||||||
|
private: "Privé"
|
||||||
|
_signup:
|
||||||
|
almostThere: "Bientôt fini"
|
||||||
|
emailAddressInfo: "Insérez votre adresse e-mail."
|
||||||
|
emailSent: "Un courriel de confirmation vient d'être envoyé à l'adresse que vous avez renseignée ({email}). Cliquez sur le lien contenu dans le message pour terminer la création de votre compte."
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "Supprimer le compte"
|
||||||
|
mayTakeTime: "La suppression de compte nécessitant beaucoup de ressources, l'exécution du processus peut prendre du temps, en fonction de la quantité de contenus que vous avez créés et du nombre de fichiers que vous avez téléversés."
|
||||||
|
sendEmail: "Une fois la suppression de votre compte effectuée, un courriel sera envoyé à l'adresse que vous aviez enregistrée."
|
||||||
|
requestAccountDelete: "Demander la suppression de votre compte"
|
||||||
|
started: "La procédure de suppression a commencé."
|
||||||
|
inProgress: "Suppression en cours"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Retour"
|
back: "Retour"
|
||||||
reduceFrequencyOfThisAd: "Voir cette publicité moins souvent"
|
reduceFrequencyOfThisAd: "Voir cette publicité moins souvent"
|
||||||
@@ -875,6 +918,9 @@ _mfm:
|
|||||||
fontDescription: "Il est possible de choisir la police."
|
fontDescription: "Il est possible de choisir la police."
|
||||||
rainbow: "Arc-en-ciel"
|
rainbow: "Arc-en-ciel"
|
||||||
rainbowDescription: "Permet d'afficher le contenu en couleurs arc-en-ciel."
|
rainbowDescription: "Permet d'afficher le contenu en couleurs arc-en-ciel."
|
||||||
|
sparkle: "Paillettes"
|
||||||
|
sparkleDescription: "Ajoute un effet scintillant au contenu."
|
||||||
|
rotate: "Pivoter"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Réglages de la partie"
|
gameSettings: "Réglages de la partie"
|
||||||
@@ -988,7 +1034,7 @@ _theme:
|
|||||||
hashtag: "Hashtags"
|
hashtag: "Hashtags"
|
||||||
mention: "Mentionner"
|
mention: "Mentionner"
|
||||||
mentionMe: "Mentions (Moi)"
|
mentionMe: "Mentions (Moi)"
|
||||||
renote: "Partager"
|
renote: "Renoter"
|
||||||
modalBg: "Modal d'arrière-plan"
|
modalBg: "Modal d'arrière-plan"
|
||||||
divider: "Séparateur"
|
divider: "Séparateur"
|
||||||
scrollbarHandle: "Poignée de la barre de navigation"
|
scrollbarHandle: "Poignée de la barre de navigation"
|
||||||
@@ -1101,6 +1147,10 @@ _permissions:
|
|||||||
"write:user-groups": "Éditer les groupes des utilisateur·rice·s"
|
"write:user-groups": "Éditer les groupes des utilisateur·rice·s"
|
||||||
"read:channels": "Lire les canaux"
|
"read:channels": "Lire les canaux"
|
||||||
"write:channels": "Gérer les canaux"
|
"write:channels": "Gérer les canaux"
|
||||||
|
"read:gallery": "Voir la galerie"
|
||||||
|
"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"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "Autoriser \"{name}\" à accéder à votre compte ?"
|
shareAccess: "Autoriser \"{name}\" à accéder à votre compte ?"
|
||||||
shareAccessAsk: "Voulez-vous vraiment autoriser cette application à accéder à votre compte?"
|
shareAccessAsk: "Voulez-vous vraiment autoriser cette application à accéder à votre compte?"
|
||||||
@@ -1141,6 +1191,7 @@ _widgets:
|
|||||||
jobQueue: "File d’attente"
|
jobQueue: "File d’attente"
|
||||||
serverMetric: "Statistiques du serveur"
|
serverMetric: "Statistiques du serveur"
|
||||||
aiscript: "Console AiScript"
|
aiscript: "Console AiScript"
|
||||||
|
aichan: "Ai"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "Masquer"
|
hide: "Masquer"
|
||||||
show: "Afficher plus …"
|
show: "Afficher plus …"
|
||||||
@@ -1213,7 +1264,7 @@ _charts:
|
|||||||
federationInstancesTotal: "Nombre total d'instances fédérées"
|
federationInstancesTotal: "Nombre total d'instances fédérées"
|
||||||
usersIncDec: "Variation du nombre d'utilisateur·rice·s"
|
usersIncDec: "Variation du nombre d'utilisateur·rice·s"
|
||||||
usersTotal: "Nombre des utilisateur·rice·s au total"
|
usersTotal: "Nombre des utilisateur·rice·s au total"
|
||||||
activeUsers: "Utilisateur·rice·s actif·ve·s"
|
activeUsers: "Nombre d'utilisateurices actif·ve·s"
|
||||||
notesIncDec: "Variation du nombre des notes"
|
notesIncDec: "Variation du nombre des notes"
|
||||||
localNotesIncDec: "Variation du nombre de notes locales"
|
localNotesIncDec: "Variation du nombre de notes locales"
|
||||||
remoteNotesIncDec: "Variation du nombre de notes distantes"
|
remoteNotesIncDec: "Variation du nombre de notes distantes"
|
||||||
|
@@ -81,6 +81,8 @@ somethingHappened: "Terjadi kesalahan"
|
|||||||
retry: "Coba lagi"
|
retry: "Coba lagi"
|
||||||
pageLoadError: "Gagal memuat halaman."
|
pageLoadError: "Gagal memuat halaman."
|
||||||
pageLoadErrorDescription: "Umumnya disebabkan jaringan atau tembolok perambah. Cobalah bersihkan tembolok peramban lalu tunggu sesaat sebelum mencoba kembali."
|
pageLoadErrorDescription: "Umumnya disebabkan jaringan atau tembolok perambah. Cobalah bersihkan tembolok peramban lalu tunggu sesaat sebelum mencoba kembali."
|
||||||
|
serverIsDead: "Tidak ada respon dari server. Mohon tunggu dan coba beberapa saat lagi."
|
||||||
|
youShouldUpgradeClient: "Untuk melihat halaman ini, mohon muat ulang untuk memutakhirkan klienmu."
|
||||||
enterListName: "Masukkan nama daftar"
|
enterListName: "Masukkan nama daftar"
|
||||||
privacy: "Privasi"
|
privacy: "Privasi"
|
||||||
makeFollowManuallyApprove: "Permintaan mengikuti membutuhkan persetujuan"
|
makeFollowManuallyApprove: "Permintaan mengikuti membutuhkan persetujuan"
|
||||||
@@ -529,6 +531,8 @@ removeAllFollowing: "Tahan semua mengikuti"
|
|||||||
removeAllFollowingDescription: "Batal mengikuti semua akun dari {host}. Mohon jalankan ini ketika instansi sudah tidak ada lagi."
|
removeAllFollowingDescription: "Batal mengikuti semua akun dari {host}. Mohon jalankan ini ketika instansi sudah tidak ada lagi."
|
||||||
userSuspended: "Pengguna ini telah dibekukan."
|
userSuspended: "Pengguna ini telah dibekukan."
|
||||||
userSilenced: "Pengguna ini telah dibungkam."
|
userSilenced: "Pengguna ini telah dibungkam."
|
||||||
|
yourAccountSuspendedTitle: "Akun ini dibekukan"
|
||||||
|
yourAccountSuspendedDescription: "Akun ini dibekukan karena melanggar ketentuan penggunaan layanan server atau semacamnya. Hubungi admin apabila ingin tahu alasan lebih lanjut. Mohon untuk tidak membuat akun baru."
|
||||||
menu: "Menu"
|
menu: "Menu"
|
||||||
divider: "Pembagi"
|
divider: "Pembagi"
|
||||||
addItem: "Tambahkan item"
|
addItem: "Tambahkan item"
|
||||||
@@ -616,6 +620,8 @@ reportAbuse: "Laporkan"
|
|||||||
reportAbuseOf: "Laporkan {name}"
|
reportAbuseOf: "Laporkan {name}"
|
||||||
fillAbuseReportDescription: "Mohon isi rincian laporan. Jika laporan ini mengenai catatan yang spesifik, mohon lampirkan serta URL catatan tersebut."
|
fillAbuseReportDescription: "Mohon isi rincian laporan. Jika laporan ini mengenai catatan yang spesifik, mohon lampirkan serta URL catatan tersebut."
|
||||||
abuseReported: "Laporan kamu telah dikirimkan. Terima kasih."
|
abuseReported: "Laporan kamu telah dikirimkan. Terima kasih."
|
||||||
|
reporteeOrigin: "Yang dilaporkan"
|
||||||
|
reporterOrigin: "Pelapor"
|
||||||
send: "Kirim"
|
send: "Kirim"
|
||||||
abuseMarkAsResolved: "Tandai laporan sebagai selesai"
|
abuseMarkAsResolved: "Tandai laporan sebagai selesai"
|
||||||
openInNewTab: "Buka di tab baru"
|
openInNewTab: "Buka di tab baru"
|
||||||
@@ -762,14 +768,70 @@ middle: "Sedang"
|
|||||||
low: "Rendah"
|
low: "Rendah"
|
||||||
emailNotConfiguredWarning: "Alamat surel tidak disetel."
|
emailNotConfiguredWarning: "Alamat surel tidak disetel."
|
||||||
ratio: "Rasio"
|
ratio: "Rasio"
|
||||||
|
previewNoteText: "Tampilkan pratinjau"
|
||||||
customCss: "Custom CSS"
|
customCss: "Custom CSS"
|
||||||
customCssWarn: "Pengaturan ini seharusnya digunakan jika kamu tahu cara kerjanya. Memasukkan nilai yang tidak tepat dapat menyebabkan klien tidak berfungsi semestinya."
|
customCssWarn: "Pengaturan ini seharusnya digunakan jika kamu tahu cara kerjanya. Memasukkan nilai yang tidak tepat dapat menyebabkan klien tidak berfungsi semestinya."
|
||||||
global: "Global"
|
global: "Global"
|
||||||
squareAvatars: "Tampilkan avatar sebagai persegi"
|
squareAvatars: "Tampilkan avatar sebagai persegi"
|
||||||
sent: "Kirim"
|
sent: "Kirim"
|
||||||
|
received: "Diterima"
|
||||||
|
searchResult: "Hasil Penelusuran"
|
||||||
hashtags: "Tagar"
|
hashtags: "Tagar"
|
||||||
_docs:
|
troubleshooting: "Penyelesaian Masalah"
|
||||||
admin: "Manajemen"
|
useBlurEffect: "Gunakan efek blur pada antarmuka"
|
||||||
|
learnMore: "Pelajari lebih lanjut"
|
||||||
|
misskeyUpdated: "Misskey telah dimutakhirkan!"
|
||||||
|
whatIsNew: "Lihat perubahan pemutakhiran"
|
||||||
|
translate: "Terjemahkan"
|
||||||
|
translatedFrom: "Terjemahkan dari {x}"
|
||||||
|
accountDeletionInProgress: "Penghapusan akun sedang dalam proses"
|
||||||
|
usernameInfo: "Nama yang mengidentifikasikan akun kamu dari yang lain pada server ini. Kamu dapat menggunakan alfabet (a~z, A~Z), digit (0~9) atau garis bawah (_). Username tidak dapat diubah setelahnya."
|
||||||
|
aiChanMode: "Mode Ai"
|
||||||
|
keepCw: "Biarkan Peringatan Konten"
|
||||||
|
pubSub: "Akun Pub/Sub"
|
||||||
|
lastCommunication: "Komunikasi terakhir"
|
||||||
|
resolved: "Selesai"
|
||||||
|
unresolved: "Belum selesai"
|
||||||
|
itsOn: "Aktif"
|
||||||
|
itsOff: "Nonaktif"
|
||||||
|
emailRequiredForSignup: "Membutuhkan alamat surel untuk mendaftar"
|
||||||
|
unread: "Belum dibaca"
|
||||||
|
filter: "Saring"
|
||||||
|
controlPanel: "Panel kontrol"
|
||||||
|
manageAccounts: "Kelola Akun"
|
||||||
|
makeReactionsPublic: "Tampilkan riwayat reaksi ke publik"
|
||||||
|
makeReactionsPublicDescription: "Pengaturan ini akan membuat daftar dari semua reaksi masa lalu kamu ditampilkan secara publik."
|
||||||
|
classic: "Klasik"
|
||||||
|
muteThread: "Bisukan thread"
|
||||||
|
unmuteThread: "Suarakan thread"
|
||||||
|
ffVisibility: "Visibilitas Mengikuti/Pengikut"
|
||||||
|
ffVisibilityDescription: "Mengatur siapa yang dapat melihat pengikutmu dan yang kamu ikuti."
|
||||||
|
continueThread: "Lihat lanjutan thread"
|
||||||
|
deleteAccountConfirm: "Akun akan dihapus. Apakah kamu yakin?"
|
||||||
|
incorrectPassword: "Kata sandi salah."
|
||||||
|
voteConfirm: "Konfirmasi suara kamu untuk ({choice})?"
|
||||||
|
hide: "Sembunyikan"
|
||||||
|
_emailUnavailable:
|
||||||
|
used: "Alamat surel ini telah digunakan"
|
||||||
|
format: "Format tidak valid."
|
||||||
|
disposable: "Alamat surel temporer tidak dapat digunakan"
|
||||||
|
mx: "Server alamat surel ini tidak valid"
|
||||||
|
smtp: "Server alamat surel ini tidak merespon"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "Terbitkan"
|
||||||
|
followers: "Tampil untuk pengikut saja"
|
||||||
|
private: "Tersembunyi"
|
||||||
|
_signup:
|
||||||
|
almostThere: "Hampir selesai"
|
||||||
|
emailAddressInfo: "Mohon masukkan alamat surel kamu."
|
||||||
|
emailSent: "Konfirmasi surel telah dikirimkan ke alamat surel kamu ({email}). Mohon klik tautan yang tercantum di dalamnya untuk menyelesaikan pembuatan akun."
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "Hapus akun"
|
||||||
|
mayTakeTime: "Karena penghapusan akun merupakan proses yang berat dan intensif, kemungkinan dapat membutuhkan waktu untuk menyelesaikan tergantung daripada berapa banyak konten yang kamu buat dan berapa banyak berkas yang telah kamu unggah."
|
||||||
|
sendEmail: "Setelah penghapusan akun selesai, pemberitahuan akan dikirimkan ke alamat surel yang terdaftarkan pada akun ini."
|
||||||
|
requestAccountDelete: "Minta penghapusan akun"
|
||||||
|
started: "Penghapusan telah dimulai"
|
||||||
|
inProgress: "Penghapusan sedang dalam proses"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Kembali"
|
back: "Kembali"
|
||||||
reduceFrequencyOfThisAd: "Tampilkan iklan ini lebih sedikit"
|
reduceFrequencyOfThisAd: "Tampilkan iklan ini lebih sedikit"
|
||||||
@@ -868,6 +930,12 @@ _mfm:
|
|||||||
blurDescription: "Konten dapat diburamkan dengan efek ini. Konten dapat ditampilkan dengan jelas dengan melayangkan kursor tetikus di atasnya."
|
blurDescription: "Konten dapat diburamkan dengan efek ini. Konten dapat ditampilkan dengan jelas dengan melayangkan kursor tetikus di atasnya."
|
||||||
font: "Font"
|
font: "Font"
|
||||||
fontDescription: "Setel font yang ditampilkan untuk konten."
|
fontDescription: "Setel font yang ditampilkan untuk konten."
|
||||||
|
rainbow: "Pelangi"
|
||||||
|
rainbowDescription: "Membuat konten muncul dalam warna pelangi."
|
||||||
|
sparkle: "Kelap-kelip"
|
||||||
|
sparkleDescription: "Memberikan konten efek partikel kelap-kelip."
|
||||||
|
rotate: "Putar"
|
||||||
|
rotateDescription: "Putar konten sesuai sudut yang ditentukan."
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Pengaturan permainan"
|
gameSettings: "Pengaturan permainan"
|
||||||
@@ -1094,6 +1162,10 @@ _permissions:
|
|||||||
"write:user-groups": "Sunting atau hapus grup pengguna"
|
"write:user-groups": "Sunting atau hapus grup pengguna"
|
||||||
"read:channels": "Lihat saluran"
|
"read:channels": "Lihat saluran"
|
||||||
"write:channels": "Sunting saluran"
|
"write:channels": "Sunting saluran"
|
||||||
|
"read:gallery": "Lihat galeri"
|
||||||
|
"write:gallery": "Sunting galeri"
|
||||||
|
"read:gallery-likes": "Lihat daftar postingan galeri yang disukai"
|
||||||
|
"write:gallery-likes": "Sunting daftar postingan galeri yang disukai"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "Apakah kamu ingin mengijinkan \"{name}\" untuk mengakses akun ini?"
|
shareAccess: "Apakah kamu ingin mengijinkan \"{name}\" untuk mengakses akun ini?"
|
||||||
shareAccessAsk: "Apakah kamu ingin mengijinkan aplikasi ini untuk mengakses akun kamu?"
|
shareAccessAsk: "Apakah kamu ingin mengijinkan aplikasi ini untuk mengakses akun kamu?"
|
||||||
@@ -1134,6 +1206,7 @@ _widgets:
|
|||||||
jobQueue: "Antrian kerja"
|
jobQueue: "Antrian kerja"
|
||||||
serverMetric: "Statistik server"
|
serverMetric: "Statistik server"
|
||||||
aiscript: "Konsol AiScript"
|
aiscript: "Konsol AiScript"
|
||||||
|
aichan: "Ai"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "Sembunyikan"
|
hide: "Sembunyikan"
|
||||||
show: "Lihat konten"
|
show: "Lihat konten"
|
||||||
|
@@ -19,9 +19,11 @@ const languages = [
|
|||||||
'da-DK',
|
'da-DK',
|
||||||
'de-DE',
|
'de-DE',
|
||||||
'en-US',
|
'en-US',
|
||||||
|
'eo-UY',
|
||||||
'es-ES',
|
'es-ES',
|
||||||
'fr-FR',
|
'fr-FR',
|
||||||
'id-ID',
|
'id-ID',
|
||||||
|
'it-IT',
|
||||||
'ja-JP',
|
'ja-JP',
|
||||||
'ja-KS',
|
'ja-KS',
|
||||||
'kab-KAB',
|
'kab-KAB',
|
||||||
@@ -44,7 +46,10 @@ const primaries = {
|
|||||||
'zh': 'CN',
|
'zh': 'CN',
|
||||||
};
|
};
|
||||||
|
|
||||||
const locales = languages.reduce((a, c) => (a[c] = yaml.load(fs.readFileSync(`${__dirname}/${c}.yml`, 'utf-8')) || {}, a), {});
|
// 何故か文字列にバックスペース文字が混入することがあり、YAMLが壊れるので取り除く
|
||||||
|
const clean = (text) => text.replace(new RegExp(String.fromCodePoint(0x08), 'g'), '');
|
||||||
|
|
||||||
|
const locales = languages.reduce((a, c) => (a[c] = yaml.load(clean(fs.readFileSync(`${__dirname}/${c}.yml`, 'utf-8'))) || {}, a), {});
|
||||||
|
|
||||||
module.exports = Object.entries(locales)
|
module.exports = Object.entries(locales)
|
||||||
.reduce((a, [k ,v]) => (a[k] = (() => {
|
.reduce((a, [k ,v]) => (a[k] = (() => {
|
||||||
|
@@ -482,7 +482,7 @@ objectStorageSetPublicRead: "Imposta \"visibilità pubblica\" al momento di cari
|
|||||||
serverLogs: "Log del server"
|
serverLogs: "Log del server"
|
||||||
deleteAll: "Cancella cronologia"
|
deleteAll: "Cancella cronologia"
|
||||||
showFixedPostForm: "Visualizzare la finestra di pubblicazione in cima alla timeline"
|
showFixedPostForm: "Visualizzare la finestra di pubblicazione in cima alla timeline"
|
||||||
newNoteRecived: "Nuova nota ricevuta"
|
newNoteRecived: "Vedi le nuove note"
|
||||||
sounds: "Impostazioni suoni"
|
sounds: "Impostazioni suoni"
|
||||||
listen: "Ascolta"
|
listen: "Ascolta"
|
||||||
none: "Niente"
|
none: "Niente"
|
||||||
@@ -745,10 +745,9 @@ global: "Federata"
|
|||||||
sent: "Inviare"
|
sent: "Inviare"
|
||||||
hashtags: "Hashtag"
|
hashtags: "Hashtag"
|
||||||
troubleshooting: "Risoluzione problemi"
|
troubleshooting: "Risoluzione problemi"
|
||||||
_docs:
|
hide: "Nascondere"
|
||||||
continueReading: "Leggi di più"
|
_ffVisibility:
|
||||||
features: "Funzionalità"
|
public: "Pubblico"
|
||||||
admin: "Gestione"
|
|
||||||
_ad:
|
_ad:
|
||||||
back: "Indietro"
|
back: "Indietro"
|
||||||
reduceFrequencyOfThisAd: "Visualizza questa pubblicità meno spesso"
|
reduceFrequencyOfThisAd: "Visualizza questa pubblicità meno spesso"
|
||||||
@@ -808,6 +807,7 @@ _mfm:
|
|||||||
font: "Tipo di carattere"
|
font: "Tipo di carattere"
|
||||||
fontDescription: "Puoi scegliere il tipo di carattere per il contenuto."
|
fontDescription: "Puoi scegliere il tipo di carattere per il contenuto."
|
||||||
rainbow: "Arcobaleno"
|
rainbow: "Arcobaleno"
|
||||||
|
rotate: "Ruota"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Impostazioni di gioco"
|
gameSettings: "Impostazioni di gioco"
|
||||||
|
@@ -81,6 +81,8 @@ somethingHappened: "問題が発生しました"
|
|||||||
retry: "再試行"
|
retry: "再試行"
|
||||||
pageLoadError: "ページの読み込みに失敗しました。"
|
pageLoadError: "ページの読み込みに失敗しました。"
|
||||||
pageLoadErrorDescription: "これは通常、ネットワークまたはブラウザキャッシュが原因です。キャッシュをクリアするか、しばらく待ってから再度試してください。"
|
pageLoadErrorDescription: "これは通常、ネットワークまたはブラウザキャッシュが原因です。キャッシュをクリアするか、しばらく待ってから再度試してください。"
|
||||||
|
serverIsDead: "サーバーの応答がありません。しばらく待ってから再度試してください。"
|
||||||
|
youShouldUpgradeClient: "このページを表示するためには、リロードして新しいバージョンのクライアントをご利用ください。"
|
||||||
enterListName: "リスト名を入力"
|
enterListName: "リスト名を入力"
|
||||||
privacy: "プライバシー"
|
privacy: "プライバシー"
|
||||||
makeFollowManuallyApprove: "フォローを承認制にする"
|
makeFollowManuallyApprove: "フォローを承認制にする"
|
||||||
@@ -529,6 +531,8 @@ removeAllFollowing: "フォローを全解除"
|
|||||||
removeAllFollowingDescription: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。"
|
removeAllFollowingDescription: "{host}からのフォローをすべて解除します。そのインスタンスがもう存在しなくなった場合などに実行してください。"
|
||||||
userSuspended: "このユーザーは凍結されています。"
|
userSuspended: "このユーザーは凍結されています。"
|
||||||
userSilenced: "このユーザーはサイレンスされています。"
|
userSilenced: "このユーザーはサイレンスされています。"
|
||||||
|
yourAccountSuspendedTitle: "アカウントが凍結されています"
|
||||||
|
yourAccountSuspendedDescription: "このアカウントは、サーバーの利用規約に違反したなどの理由により、凍結されています。詳細については管理者までお問い合わせください。新しいアカウントを作らないでください。"
|
||||||
menu: "メニュー"
|
menu: "メニュー"
|
||||||
divider: "分割線"
|
divider: "分割線"
|
||||||
addItem: "項目を追加"
|
addItem: "項目を追加"
|
||||||
@@ -588,6 +592,7 @@ smtpSecure: "SMTP 接続に暗黙的なSSL/TLSを使用する"
|
|||||||
smtpSecureInfo: "STARTTLS使用時はオフにします。"
|
smtpSecureInfo: "STARTTLS使用時はオフにします。"
|
||||||
testEmail: "配信テスト"
|
testEmail: "配信テスト"
|
||||||
wordMute: "ワードミュート"
|
wordMute: "ワードミュート"
|
||||||
|
instanceMute: "インスタンスミュート"
|
||||||
userSaysSomething: "{name}が何かを言いました"
|
userSaysSomething: "{name}が何かを言いました"
|
||||||
makeActive: "アクティブにする"
|
makeActive: "アクティブにする"
|
||||||
display: "表示"
|
display: "表示"
|
||||||
@@ -616,6 +621,8 @@ reportAbuse: "通報"
|
|||||||
reportAbuseOf: "{name}を通報する"
|
reportAbuseOf: "{name}を通報する"
|
||||||
fillAbuseReportDescription: "通報理由の詳細を記入してください。対象のノートがある場合はそのURLも記入してください。"
|
fillAbuseReportDescription: "通報理由の詳細を記入してください。対象のノートがある場合はそのURLも記入してください。"
|
||||||
abuseReported: "内容が送信されました。ご報告ありがとうございました。"
|
abuseReported: "内容が送信されました。ご報告ありがとうございました。"
|
||||||
|
reporteeOrigin: "通報先"
|
||||||
|
reporterOrigin: "通報元"
|
||||||
send: "送信"
|
send: "送信"
|
||||||
abuseMarkAsResolved: "対応済みにする"
|
abuseMarkAsResolved: "対応済みにする"
|
||||||
openInNewTab: "新しいタブで開く"
|
openInNewTab: "新しいタブで開く"
|
||||||
@@ -762,6 +769,7 @@ middle: "中"
|
|||||||
low: "低"
|
low: "低"
|
||||||
emailNotConfiguredWarning: "メールアドレスの設定がされていません。"
|
emailNotConfiguredWarning: "メールアドレスの設定がされていません。"
|
||||||
ratio: "比率"
|
ratio: "比率"
|
||||||
|
previewNoteText: "本文をプレビュー"
|
||||||
customCss: "カスタムCSS"
|
customCss: "カスタムCSS"
|
||||||
customCssWarn: "この設定は必ず知識のある方が行ってください。不適切な設定を行うとクライアントが正常に使用できなくなる恐れがあります。"
|
customCssWarn: "この設定は必ず知識のある方が行ってください。不適切な設定を行うとクライアントが正常に使用できなくなる恐れがあります。"
|
||||||
global: "グローバル"
|
global: "グローバル"
|
||||||
@@ -772,14 +780,66 @@ searchResult: "検索結果"
|
|||||||
hashtags: "ハッシュタグ"
|
hashtags: "ハッシュタグ"
|
||||||
troubleshooting: "トラブルシューティング"
|
troubleshooting: "トラブルシューティング"
|
||||||
useBlurEffect: "UIにぼかし効果を使用"
|
useBlurEffect: "UIにぼかし効果を使用"
|
||||||
|
learnMore: "詳しく"
|
||||||
|
misskeyUpdated: "Misskeyが更新されました!"
|
||||||
|
whatIsNew: "更新情報を見る"
|
||||||
|
translate: "翻訳"
|
||||||
|
translatedFrom: "{x}から翻訳"
|
||||||
|
accountDeletionInProgress: "アカウントの削除が進行中です"
|
||||||
|
usernameInfo: "サーバー上であなたのアカウントを一意に識別するための名前。アルファベット(a~z, A~Z)、数字(0~9)、およびアンダーバー(_)が使用できます。ユーザー名は後から変更することは出来ません。"
|
||||||
|
aiChanMode: "藍モード"
|
||||||
|
keepCw: "CWを維持する"
|
||||||
|
pubSub: "Pub/Subのアカウント"
|
||||||
|
lastCommunication: "直近の通信"
|
||||||
|
resolved: "解決済み"
|
||||||
|
unresolved: "未解決"
|
||||||
|
breakFollow: "フォロワーを解除"
|
||||||
|
itsOn: "オンになっています"
|
||||||
|
itsOff: "オフになっています"
|
||||||
|
emailRequiredForSignup: "アカウント登録にメールアドレスを必須にする"
|
||||||
|
unread: "未読"
|
||||||
|
filter: "フィルタ"
|
||||||
|
controlPanel: "コントロールパネル"
|
||||||
|
manageAccounts: "アカウントを管理"
|
||||||
|
makeReactionsPublic: "リアクション一覧を公開する"
|
||||||
|
makeReactionsPublicDescription: "あなたがしたリアクション一覧を誰でも見れるようにします。"
|
||||||
|
classic: "クラシック"
|
||||||
|
muteThread: "スレッドをミュート"
|
||||||
|
unmuteThread: "スレッドのミュートを解除"
|
||||||
|
ffVisibility: "つながりの公開範囲"
|
||||||
|
ffVisibilityDescription: "自分のフォロー/フォロワー情報の公開範囲を設定できます。"
|
||||||
|
continueThread: "さらにスレッドを見る"
|
||||||
|
deleteAccountConfirm: "アカウントが削除されます。よろしいですか?"
|
||||||
|
incorrectPassword: "パスワードが間違っています。"
|
||||||
|
voteConfirm: "「{choice}」に投票しますか?"
|
||||||
|
hide: "隠す"
|
||||||
|
leaveGroup: "グループから抜ける"
|
||||||
|
leaveGroupConfirm: "「{name}」から抜けますか?"
|
||||||
|
|
||||||
_docs:
|
_emailUnavailable:
|
||||||
continueReading: "続きを読む"
|
used: "既に使用されています"
|
||||||
features: "機能"
|
format: "形式が正しくありません"
|
||||||
generalTopics: "一般的なトピック"
|
disposable: "恒久的に使用可能なアドレスではありません"
|
||||||
advancedTopics: "高度なトピック"
|
mx: "正しいメールサーバーではありません"
|
||||||
admin: "管理"
|
smtp: "メールサーバーが応答しません"
|
||||||
translateWarn: "このドキュメントは翻訳されたものです。オリジナルとは内容が異なる場合があります。"
|
|
||||||
|
_ffVisibility:
|
||||||
|
public: "公開"
|
||||||
|
followers: "フォロワーだけに公開"
|
||||||
|
private: "非公開"
|
||||||
|
|
||||||
|
_signup:
|
||||||
|
almostThere: "ほとんど完了です"
|
||||||
|
emailAddressInfo: "あなたが使っているメールアドレスを入力してください。メールアドレスが公開されることはありません。"
|
||||||
|
emailSent: "入力されたメールアドレス({email})宛に確認のメールが送信されました。メールに記載されたリンクにアクセスすると、アカウントの作成が完了します。"
|
||||||
|
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "アカウントの削除"
|
||||||
|
mayTakeTime: "アカウントの削除は負荷のかかる処理であるため、作成したコンテンツの数やアップロードしたファイルの数が多いと完了までに時間がかかることがあります。"
|
||||||
|
sendEmail: "アカウントの削除が完了する際は、登録してあったメールアドレス宛に通知を送信します。"
|
||||||
|
requestAccountDelete: "アカウント削除をリクエスト"
|
||||||
|
started: "削除処理が開始されました。"
|
||||||
|
inProgress: "削除が進行中"
|
||||||
|
|
||||||
_ad:
|
_ad:
|
||||||
back: "戻る"
|
back: "戻る"
|
||||||
@@ -889,6 +949,10 @@ _mfm:
|
|||||||
fontDescription: "内容のフォントを指定することができます。"
|
fontDescription: "内容のフォントを指定することができます。"
|
||||||
rainbow: "レインボー"
|
rainbow: "レインボー"
|
||||||
rainbowDescription: "内容をレインボーにします。"
|
rainbowDescription: "内容をレインボーにします。"
|
||||||
|
sparkle: "キラキラ"
|
||||||
|
sparkleDescription: "キラキラしたパーティクルのエフェクトを追加します。"
|
||||||
|
rotate: "回転"
|
||||||
|
rotateDescription: "指定した角度で回転させます。"
|
||||||
|
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "リバーシ"
|
reversi: "リバーシ"
|
||||||
@@ -961,6 +1025,12 @@ _wordMute:
|
|||||||
hard: "ハード"
|
hard: "ハード"
|
||||||
mutedNotes: "ミュートされたノート"
|
mutedNotes: "ミュートされたノート"
|
||||||
|
|
||||||
|
_instanceMute:
|
||||||
|
instanceMuteDescription: "ミュートしたインスタンスのユーザーへの返信を含めて、設定したインスタンスの全てのノートとRenoteをミュートします。"
|
||||||
|
instanceMuteDescription2: "改行で区切って設定します"
|
||||||
|
title: "設定したインスタンスのノートを隠します。"
|
||||||
|
heading: "ミュートするインスタンス"
|
||||||
|
|
||||||
_theme:
|
_theme:
|
||||||
explore: "テーマを探す"
|
explore: "テーマを探す"
|
||||||
install: "テーマのインストール"
|
install: "テーマのインストール"
|
||||||
@@ -1129,6 +1199,10 @@ _permissions:
|
|||||||
"write:user-groups": "ユーザーグループを操作する"
|
"write:user-groups": "ユーザーグループを操作する"
|
||||||
"read:channels": "チャンネルを見る"
|
"read:channels": "チャンネルを見る"
|
||||||
"write:channels": "チャンネルを操作する"
|
"write:channels": "チャンネルを操作する"
|
||||||
|
"read:gallery": "ギャラリーを見る"
|
||||||
|
"write:gallery": "ギャラリーを操作する"
|
||||||
|
"read:gallery-likes": "ギャラリーのいいねを見る"
|
||||||
|
"write:gallery-likes": "ギャラリーのいいねを操作する"
|
||||||
|
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "「{name}」がアカウントにアクセスすることを許可しますか?"
|
shareAccess: "「{name}」がアカウントにアクセスすることを許可しますか?"
|
||||||
@@ -1173,6 +1247,7 @@ _widgets:
|
|||||||
jobQueue: "ジョブキュー"
|
jobQueue: "ジョブキュー"
|
||||||
serverMetric: "サーバーメトリクス"
|
serverMetric: "サーバーメトリクス"
|
||||||
aiscript: "AiScriptコンソール"
|
aiscript: "AiScriptコンソール"
|
||||||
|
aichan: "藍"
|
||||||
|
|
||||||
_cw:
|
_cw:
|
||||||
hide: "隠す"
|
hide: "隠す"
|
||||||
@@ -1246,6 +1321,8 @@ _exportOrImport:
|
|||||||
muteList: "ミュート"
|
muteList: "ミュート"
|
||||||
blockingList: "ブロック"
|
blockingList: "ブロック"
|
||||||
userLists: "リスト"
|
userLists: "リスト"
|
||||||
|
excludeMutingUsers: "ミュートしているユーザーを除外"
|
||||||
|
excludeInactiveUsers: "使われていないアカウントを除外"
|
||||||
|
|
||||||
_charts:
|
_charts:
|
||||||
federationInstancesIncDec: "連合の増減"
|
federationInstancesIncDec: "連合の増減"
|
||||||
|
@@ -7,6 +7,7 @@ search: "探す"
|
|||||||
notifications: "通知"
|
notifications: "通知"
|
||||||
username: "ユーザー名"
|
username: "ユーザー名"
|
||||||
password: "パスワード"
|
password: "パスワード"
|
||||||
|
forgotPassword: "パスワード忘れてん"
|
||||||
fetchingAsApObject: "今ちと連合に照会しとるで"
|
fetchingAsApObject: "今ちと連合に照会しとるで"
|
||||||
ok: "OKや"
|
ok: "OKや"
|
||||||
gotIt: "ほい"
|
gotIt: "ほい"
|
||||||
@@ -139,6 +140,7 @@ flagAsBotDescription: "もしこのアカウントがプログラムによって
|
|||||||
flagAsCat: "Catやで"
|
flagAsCat: "Catやで"
|
||||||
flagAsCatDescription: "ワレ、猫ちゃんならこのフラグをつけてみ?"
|
flagAsCatDescription: "ワレ、猫ちゃんならこのフラグをつけてみ?"
|
||||||
autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストを勝手に許可しとく"
|
autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストを勝手に許可しとく"
|
||||||
|
addAccount: "アカウントを追加"
|
||||||
loginFailed: "ログインに失敗してしもうた…"
|
loginFailed: "ログインに失敗してしもうた…"
|
||||||
showOnRemote: "リモートで見る"
|
showOnRemote: "リモートで見る"
|
||||||
general: "全般"
|
general: "全般"
|
||||||
@@ -243,7 +245,7 @@ messageRead: "もう読んだ"
|
|||||||
noMoreHistory: "これより過去の履歴はあらへんで"
|
noMoreHistory: "これより過去の履歴はあらへんで"
|
||||||
startMessaging: "チャットやるで"
|
startMessaging: "チャットやるで"
|
||||||
nUsersRead: "{n}人が読んでもうた"
|
nUsersRead: "{n}人が読んでもうた"
|
||||||
agreeTo: "{0}はええで"
|
agreeTo: "{0}に同意したで"
|
||||||
tos: "利用規約"
|
tos: "利用規約"
|
||||||
start: "始める"
|
start: "始める"
|
||||||
home: "ホーム"
|
home: "ホーム"
|
||||||
@@ -278,6 +280,7 @@ emptyDrive: "ドライブにはなんも残っとらん"
|
|||||||
emptyFolder: "ふぉろだーにはなんも残っとらん"
|
emptyFolder: "ふぉろだーにはなんも残っとらん"
|
||||||
unableToDelete: "消そうおもってんけどな、あかんかったわ"
|
unableToDelete: "消そうおもってんけどな、あかんかったわ"
|
||||||
inputNewFileName: "今度のファイル名は何にするん?"
|
inputNewFileName: "今度のファイル名は何にするん?"
|
||||||
|
inputNewDescription: "新しいキャプションを入力しましょ"
|
||||||
inputNewFolderName: "今度のフォルダ名は何にするん?"
|
inputNewFolderName: "今度のフォルダ名は何にするん?"
|
||||||
circularReferenceFolder: "移動先のフォルダーは、移動するフォルダーのサブフォルダーや。"
|
circularReferenceFolder: "移動先のフォルダーは、移動するフォルダーのサブフォルダーや。"
|
||||||
hasChildFilesOrFolders: "このフォルダ、まだなんか入っとるから消されへん"
|
hasChildFilesOrFolders: "このフォルダ、まだなんか入っとるから消されへん"
|
||||||
@@ -343,7 +346,7 @@ antennaSource: "受信ソース(このソースは食われへん)"
|
|||||||
antennaKeywords: "受信キーワード"
|
antennaKeywords: "受信キーワード"
|
||||||
antennaExcludeKeywords: "除外キーワード"
|
antennaExcludeKeywords: "除外キーワード"
|
||||||
antennaKeywordsDescription: "スペースで区切ったるとAND指定で、改行で区切ったるとOR指定や"
|
antennaKeywordsDescription: "スペースで区切ったるとAND指定で、改行で区切ったるとOR指定や"
|
||||||
notifyAntenna: "新しいノートを追加すんで"
|
notifyAntenna: "新しいノートを通知すんで"
|
||||||
withFileAntenna: "なんか添付されたノートだけ"
|
withFileAntenna: "なんか添付されたノートだけ"
|
||||||
enableServiceworker: "ServiceWorkerをつこて"
|
enableServiceworker: "ServiceWorkerをつこて"
|
||||||
antennaUsersDescription: "ユーザー名を改行で区切ったってな"
|
antennaUsersDescription: "ユーザー名を改行で区切ったってな"
|
||||||
@@ -650,8 +653,7 @@ low: "低い"
|
|||||||
global: "グローバル"
|
global: "グローバル"
|
||||||
sent: "送信"
|
sent: "送信"
|
||||||
hashtags: "ハッシュタグ"
|
hashtags: "ハッシュタグ"
|
||||||
_docs:
|
hide: "隠す"
|
||||||
admin: "管理"
|
|
||||||
_ad:
|
_ad:
|
||||||
back: "戻る"
|
back: "戻る"
|
||||||
_gallery:
|
_gallery:
|
||||||
@@ -699,6 +701,7 @@ _mfm:
|
|||||||
spin: "アニメーション(回転)"
|
spin: "アニメーション(回転)"
|
||||||
blur: "ぼかし"
|
blur: "ぼかし"
|
||||||
font: "フォント"
|
font: "フォント"
|
||||||
|
rotate: "回転"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "リバーシ"
|
reversi: "リバーシ"
|
||||||
gameSettings: "対局の設定"
|
gameSettings: "対局の設定"
|
||||||
|
@@ -36,6 +36,7 @@ selectList: "Fren tabdart"
|
|||||||
youHaveNoLists: "Ulac ɣur-k·m ula d yiwet n tabdart"
|
youHaveNoLists: "Ulac ɣur-k·m ula d yiwet n tabdart"
|
||||||
security: "Taɣellist"
|
security: "Taɣellist"
|
||||||
remove: "Kkes"
|
remove: "Kkes"
|
||||||
|
connectService: "Qqen"
|
||||||
userList: "Tibdarin"
|
userList: "Tibdarin"
|
||||||
securityKey: "Tasarutt n tɣellist"
|
securityKey: "Tasarutt n tɣellist"
|
||||||
securityKeyName: "Isem n tsarutt"
|
securityKeyName: "Isem n tsarutt"
|
||||||
|
@@ -81,6 +81,8 @@ somethingHappened: "오류가 발생했습니다"
|
|||||||
retry: "다시 시도"
|
retry: "다시 시도"
|
||||||
pageLoadError: "페이지를 불러오지 못했습니다."
|
pageLoadError: "페이지를 불러오지 못했습니다."
|
||||||
pageLoadErrorDescription: "네트워크 연결 또는 브라우저 캐시로 인해 발생했을 가능성이 높습니다. 캐시를 삭제하거나, 잠시 후 다시 시도해 주세요."
|
pageLoadErrorDescription: "네트워크 연결 또는 브라우저 캐시로 인해 발생했을 가능성이 높습니다. 캐시를 삭제하거나, 잠시 후 다시 시도해 주세요."
|
||||||
|
serverIsDead: "서버로부터 응답이 없습니다. 잠시 후 다시 시도해주세요."
|
||||||
|
youShouldUpgradeClient: "이 페이지를 표시하려면 새로고침하여 새로운 버전의 클라이언트를 이용해 주십시오."
|
||||||
enterListName: "리스트 이름을 입력"
|
enterListName: "리스트 이름을 입력"
|
||||||
privacy: "프라이버시"
|
privacy: "프라이버시"
|
||||||
makeFollowManuallyApprove: "팔로우를 수동으로 승인"
|
makeFollowManuallyApprove: "팔로우를 수동으로 승인"
|
||||||
@@ -529,6 +531,8 @@ removeAllFollowing: "모든 팔로잉 해제"
|
|||||||
removeAllFollowingDescription: "{host}(으)로부터 모든 팔로잉을 해제합니다. 해당 인스턴스가 더 이상 존재하지 않게 된 경우 등에 실행해 주세요."
|
removeAllFollowingDescription: "{host}(으)로부터 모든 팔로잉을 해제합니다. 해당 인스턴스가 더 이상 존재하지 않게 된 경우 등에 실행해 주세요."
|
||||||
userSuspended: "이 계정은 정지된 상태입니다."
|
userSuspended: "이 계정은 정지된 상태입니다."
|
||||||
userSilenced: "이 계정은 사일런스된 상태입니다."
|
userSilenced: "이 계정은 사일런스된 상태입니다."
|
||||||
|
yourAccountSuspendedTitle: "계정이 정지되었습니다"
|
||||||
|
yourAccountSuspendedDescription: "이 계정은 서버의 이용 약관을 위반하거나, 기타 다른 이유로 인해 정지되었습니다. 자세한 사항은 관리자에게 문의해 주십시오. 계정을 새로 생성하지 마십시오."
|
||||||
menu: "메뉴"
|
menu: "메뉴"
|
||||||
divider: "구분선"
|
divider: "구분선"
|
||||||
addItem: "항목 추가"
|
addItem: "항목 추가"
|
||||||
@@ -588,6 +592,7 @@ smtpSecure: "SMTP 연결에 Implicit SSL/TTS 사용"
|
|||||||
smtpSecureInfo: "STARTTLS 사용 시에는 해제합니다."
|
smtpSecureInfo: "STARTTLS 사용 시에는 해제합니다."
|
||||||
testEmail: "이메일 전송 테스트"
|
testEmail: "이메일 전송 테스트"
|
||||||
wordMute: "단어 뮤트"
|
wordMute: "단어 뮤트"
|
||||||
|
instanceMute: "인스턴스 뮤트"
|
||||||
userSaysSomething: "{name}님이 무언가를 말했습니다"
|
userSaysSomething: "{name}님이 무언가를 말했습니다"
|
||||||
makeActive: "활성화"
|
makeActive: "활성화"
|
||||||
display: "표시"
|
display: "표시"
|
||||||
@@ -616,6 +621,8 @@ reportAbuse: "신고"
|
|||||||
reportAbuseOf: "{name}을 신고하기"
|
reportAbuseOf: "{name}을 신고하기"
|
||||||
fillAbuseReportDescription: "신고하려는 이유를 자세히 알려주세요. 특정 게시물을 신고할 때에는 게시물의 URL도 포함해 주세요."
|
fillAbuseReportDescription: "신고하려는 이유를 자세히 알려주세요. 특정 게시물을 신고할 때에는 게시물의 URL도 포함해 주세요."
|
||||||
abuseReported: "신고를 보냈습니다. 신고해 주셔서 감사합니다."
|
abuseReported: "신고를 보냈습니다. 신고해 주셔서 감사합니다."
|
||||||
|
reporteeOrigin: "피신고자"
|
||||||
|
reporterOrigin: "신고자"
|
||||||
send: "전송"
|
send: "전송"
|
||||||
abuseMarkAsResolved: "해결됨으로 표시"
|
abuseMarkAsResolved: "해결됨으로 표시"
|
||||||
openInNewTab: "새 탭에서 열기"
|
openInNewTab: "새 탭에서 열기"
|
||||||
@@ -762,6 +769,7 @@ middle: "보통"
|
|||||||
low: "낮음"
|
low: "낮음"
|
||||||
emailNotConfiguredWarning: "메일 주소가 설정되어 있지 않습니다."
|
emailNotConfiguredWarning: "메일 주소가 설정되어 있지 않습니다."
|
||||||
ratio: "비율"
|
ratio: "비율"
|
||||||
|
previewNoteText: "본문 미리보기"
|
||||||
customCss: "CSS 사용자화"
|
customCss: "CSS 사용자화"
|
||||||
customCssWarn: "이 설정은 기능을 알고 있는 경우에만 사용해야 합니다. 잘못된 값을 입력하면 클라이언트가 정상적으로 작동하지 않을 수 있습니다."
|
customCssWarn: "이 설정은 기능을 알고 있는 경우에만 사용해야 합니다. 잘못된 값을 입력하면 클라이언트가 정상적으로 작동하지 않을 수 있습니다."
|
||||||
global: "글로벌"
|
global: "글로벌"
|
||||||
@@ -770,13 +778,62 @@ sent: "전송"
|
|||||||
received: "수신"
|
received: "수신"
|
||||||
searchResult: "검색 결과"
|
searchResult: "검색 결과"
|
||||||
hashtags: "해시태그"
|
hashtags: "해시태그"
|
||||||
troubleshooting: "트러블 슈팅"
|
troubleshooting: "문제 해결"
|
||||||
_docs:
|
useBlurEffect: "UI에 흐림 효과 사용"
|
||||||
continueReading: "계속 읽기"
|
learnMore: "자세히"
|
||||||
features: "기능"
|
misskeyUpdated: "Misskey가 업데이트 되었습니다!"
|
||||||
generalTopics: "일반 주제"
|
whatIsNew: "패치 정보 보기"
|
||||||
advancedTopics: "심화 주제"
|
translate: "번역"
|
||||||
admin: "관리"
|
translatedFrom: "{x}에서 번역"
|
||||||
|
accountDeletionInProgress: "계정 삭제 작업을 진행하고 있습니다"
|
||||||
|
usernameInfo: "서버상에서 계정을 식별하기 위한 이름. 알파벳(a~z, A~Z), 숫자(0~9) 및 언더바(_)를 사용할 수 있습니다. 사용자명은 나중에 변경할 수 없습니다."
|
||||||
|
aiChanMode: "아이 모드"
|
||||||
|
keepCw: "CW 유지하기"
|
||||||
|
pubSub: "Pub/Sub 계정"
|
||||||
|
lastCommunication: "마지막 통신"
|
||||||
|
resolved: "해결됨"
|
||||||
|
unresolved: "해결되지 않음"
|
||||||
|
breakFollow: "팔로워 해제"
|
||||||
|
itsOn: "켜짐"
|
||||||
|
itsOff: "꺼짐"
|
||||||
|
emailRequiredForSignup: "가입할 때 이메일 주소 입력을 필수로 하기"
|
||||||
|
unread: "읽지 않음"
|
||||||
|
filter: "필터"
|
||||||
|
controlPanel: "제어판"
|
||||||
|
manageAccounts: "계정 관리"
|
||||||
|
makeReactionsPublic: "리액션 목록을 공개하기"
|
||||||
|
makeReactionsPublicDescription: "나의 리액션을 누구나 볼 수 있게 합니다."
|
||||||
|
classic: "클래식"
|
||||||
|
muteThread: "이 글타래를 뮤트"
|
||||||
|
unmuteThread: "글타래 뮤트 해제"
|
||||||
|
ffVisibility: "내 인맥의 공개 범위"
|
||||||
|
ffVisibilityDescription: "나의 팔로우와 팔로워 정보에 대한 공개 범위를 설정할 수 있습니다."
|
||||||
|
continueThread: "이 글타래 이어서 보기"
|
||||||
|
deleteAccountConfirm: "계정이 삭제되고 되돌릴 수 없게 됩니다. 계속하시겠습니까? "
|
||||||
|
incorrectPassword: "비밀번호가 올바르지 않습니다."
|
||||||
|
voteConfirm: "\"{choice}\"에 투표하시겠습니까?"
|
||||||
|
hide: "숨기기"
|
||||||
|
_emailUnavailable:
|
||||||
|
used: "이 메일 주소는 사용중입니다"
|
||||||
|
format: "형식이 올바르지 않습니다"
|
||||||
|
disposable: "임시 이메일 주소는 사용할 수 없습니다"
|
||||||
|
mx: "메일 서버가 올바르지 않습니다"
|
||||||
|
smtp: "메일 서버가 응답하지 않습니다"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "공개"
|
||||||
|
followers: "팔로워에게만 공개"
|
||||||
|
private: "비공개"
|
||||||
|
_signup:
|
||||||
|
almostThere: "거의 다 끝났습니다"
|
||||||
|
emailAddressInfo: "당신이 사용하고 있는 이메일 주소를 입력해 주세요. 이메일 주소는 다른 유저에게 공개되지 않습니다."
|
||||||
|
emailSent: "입력하신 메일 주소({email})로 확인 메일을 보내드렸습니다. 가입을 완료하시려면 보내드린 메일에 있는 링크로 접속해 주세요."
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "계정 삭제"
|
||||||
|
mayTakeTime: "계정 삭제는 서버에 부하를 가하기 때문에, 작성한 콘텐츠나 업로드한 파일의 수가 많으면 완료까지 시간이 걸릴 수 있습니다."
|
||||||
|
sendEmail: "계정 삭제가 완료되면 등록된 이메일 주소로 알림을 보냅니다."
|
||||||
|
requestAccountDelete: "계정 삭제 요청"
|
||||||
|
started: "삭제 작업이 시작되었습니다."
|
||||||
|
inProgress: "삭제 진행 중"
|
||||||
_ad:
|
_ad:
|
||||||
back: "뒤로"
|
back: "뒤로"
|
||||||
reduceFrequencyOfThisAd: "이 광고의 표시 빈도 낮추기"
|
reduceFrequencyOfThisAd: "이 광고의 표시 빈도 낮추기"
|
||||||
@@ -877,6 +934,10 @@ _mfm:
|
|||||||
fontDescription: "내용의 글꼴을 지정할 수 있습니다."
|
fontDescription: "내용의 글꼴을 지정할 수 있습니다."
|
||||||
rainbow: "무지개"
|
rainbow: "무지개"
|
||||||
rainbowDescription: "내용을 무지개로 표시합니다."
|
rainbowDescription: "내용을 무지개로 표시합니다."
|
||||||
|
sparkle: "반짝반짝"
|
||||||
|
sparkleDescription: "반짝이는 파티클 효과를 추가합니다."
|
||||||
|
rotate: "회전"
|
||||||
|
rotateDescription: "지정한 각도로 회전시킵니다."
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "리버시"
|
reversi: "리버시"
|
||||||
gameSettings: "대국 설정"
|
gameSettings: "대국 설정"
|
||||||
@@ -942,6 +1003,11 @@ _wordMute:
|
|||||||
soft: "보통"
|
soft: "보통"
|
||||||
hard: "보다 높은 수준"
|
hard: "보다 높은 수준"
|
||||||
mutedNotes: "뮤트된 노트"
|
mutedNotes: "뮤트된 노트"
|
||||||
|
_instanceMute:
|
||||||
|
instanceMuteDescription: "뮤트한 인스턴스에서 오는 답글을 포함한 모든 노트와 Renote를 뮤트합니다."
|
||||||
|
instanceMuteDescription2: "한 줄에 하나씩 입력해 주세요"
|
||||||
|
title: "지정한 인스턴스의 노트를 숨깁니다."
|
||||||
|
heading: "뮤트할 인스턴스"
|
||||||
_theme:
|
_theme:
|
||||||
explore: "테마 찾아보기"
|
explore: "테마 찾아보기"
|
||||||
install: "테마 설치"
|
install: "테마 설치"
|
||||||
@@ -1098,11 +1164,15 @@ _permissions:
|
|||||||
"read:pages": "페이지를 봅니다"
|
"read:pages": "페이지를 봅니다"
|
||||||
"write:pages": "페이지를 수정합니다"
|
"write:pages": "페이지를 수정합니다"
|
||||||
"read:page-likes": "페이지의 좋아요를 확인합니다"
|
"read:page-likes": "페이지의 좋아요를 확인합니다"
|
||||||
"write:page-likes": "페이지의 좋아요를 추가하거나 삭제합니다"
|
"write:page-likes": "페이지에 좋아요를 추가하거나 취소합니다"
|
||||||
"read:user-groups": "유저 그룹을 조회합니다"
|
"read:user-groups": "유저 그룹을 조회합니다"
|
||||||
"write:user-groups": "유저 그룹을 만들거나, 초대하거나, 이름을 변경하거나, 양도하거나, 삭제합니다"
|
"write:user-groups": "유저 그룹을 만들거나, 초대하거나, 이름을 변경하거나, 양도하거나, 삭제합니다"
|
||||||
"read:channels": "채널을 보기"
|
"read:channels": "채널을 보기"
|
||||||
"write:channels": "채널을 변경하기"
|
"write:channels": "채널을 추가하거나 삭제합니다"
|
||||||
|
"read:gallery": "갤러리를 봅니다"
|
||||||
|
"write:gallery": "갤러리를 추가하거나 삭제합니다"
|
||||||
|
"read:gallery-likes": "갤러리의 좋아요를 확인합니다"
|
||||||
|
"write:gallery-likes": "갤러리에 좋아요를 추가하거나 취소합니다"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "\"{name}\" 이 계정에 접근하는 것을 허용하시겠습니까?"
|
shareAccess: "\"{name}\" 이 계정에 접근하는 것을 허용하시겠습니까?"
|
||||||
shareAccessAsk: "이 애플리케이션이 계정에 접근하는 것을 허용하시겠습니까?"
|
shareAccessAsk: "이 애플리케이션이 계정에 접근하는 것을 허용하시겠습니까?"
|
||||||
@@ -1143,6 +1213,7 @@ _widgets:
|
|||||||
jobQueue: "작업 대기열"
|
jobQueue: "작업 대기열"
|
||||||
serverMetric: "서버 통계"
|
serverMetric: "서버 통계"
|
||||||
aiscript: "AiScript 콘솔"
|
aiscript: "AiScript 콘솔"
|
||||||
|
aichan: "아이"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "숨기기"
|
hide: "숨기기"
|
||||||
show: "더 보기"
|
show: "더 보기"
|
||||||
@@ -1210,6 +1281,8 @@ _exportOrImport:
|
|||||||
muteList: "뮤트"
|
muteList: "뮤트"
|
||||||
blockingList: "차단"
|
blockingList: "차단"
|
||||||
userLists: "리스트"
|
userLists: "리스트"
|
||||||
|
excludeMutingUsers: "뮤트한 유저 제외하기"
|
||||||
|
excludeInactiveUsers: "휴면 중인 계정 제외하기"
|
||||||
_charts:
|
_charts:
|
||||||
federationInstancesIncDec: "연합 인스턴스 수 증감"
|
federationInstancesIncDec: "연합 인스턴스 수 증감"
|
||||||
federationInstancesTotal: "연합 인스턴스 수 합계"
|
federationInstancesTotal: "연합 인스턴스 수 합계"
|
||||||
|
@@ -1,3 +1,337 @@
|
|||||||
---
|
---
|
||||||
_lang_: "Nederlands"
|
_lang_: "Nederlands"
|
||||||
headlineMisskey: "Netwerk verbonden door notities"
|
headlineMisskey: "Netwerk verbonden door notities"
|
||||||
|
introMisskey: "Welkom! Misskey is een open source, gedecentraliseerde microblogdienst.\nMaak \"notities\" om je gedachten te delen met iedereen om je heen. 📡\nMet \"reacties\" kun je ook snel je mening geven over berichten van anderen. 👍\nLaten we een nieuwe wereld verkennen! 🚀"
|
||||||
|
monthAndDay: "{day} {month}"
|
||||||
|
search: "Zoeken"
|
||||||
|
notifications: "Meldingen"
|
||||||
|
username: "Gebruikersnaam"
|
||||||
|
password: "Wachtwoord"
|
||||||
|
forgotPassword: "Wachtwoord vergeten"
|
||||||
|
fetchingAsApObject: "Ophalen vanuit de Fediverse"
|
||||||
|
ok: "Ok"
|
||||||
|
gotIt: "Begrepen"
|
||||||
|
cancel: "Annuleren"
|
||||||
|
enterUsername: "Voer een gebruikersnaam in"
|
||||||
|
renotedBy: "Hergedeeld door {user}"
|
||||||
|
noNotes: "Geen notities"
|
||||||
|
noNotifications: "Geen meldingen"
|
||||||
|
instance: "Server"
|
||||||
|
settings: "Instellingen"
|
||||||
|
basicSettings: "Basisinstellingen"
|
||||||
|
otherSettings: "Overige instellingen"
|
||||||
|
openInWindow: "In een venster openen"
|
||||||
|
profile: "Profiel"
|
||||||
|
timeline: "Tijdlijn"
|
||||||
|
noAccountDescription: "Deze gebruiker heeft nog geen bio geschreven"
|
||||||
|
login: "Inloggen"
|
||||||
|
loggingIn: "Aan het inloggen"
|
||||||
|
logout: "Afmelden"
|
||||||
|
signup: "Registreren"
|
||||||
|
uploading: "Bezig met uploaden"
|
||||||
|
save: "Opslaan"
|
||||||
|
users: "Gebruikers"
|
||||||
|
addUser: "Toevoegen gebruiker"
|
||||||
|
favorite: "Favorieten"
|
||||||
|
favorites: "Toevoegen aan favorieten"
|
||||||
|
unfavorite: "Verwijderen uit favorieten"
|
||||||
|
favorited: "Toegevoegd aan favorieten."
|
||||||
|
alreadyFavorited: "Al toegevoegd aan favorieten"
|
||||||
|
cantFavorite: "Kon niet toevoegen aan favorieten"
|
||||||
|
pin: "Vastmaken aan profielpagina"
|
||||||
|
unpin: "Losmaken van profielpagina"
|
||||||
|
copyContent: "Kopiëren inhoud"
|
||||||
|
copyLink: "Kopiëren link"
|
||||||
|
delete: "Verwijderen"
|
||||||
|
deleteAndEdit: "Verwijderen en bewerken"
|
||||||
|
deleteAndEditConfirm: "Weet je zeker dat je deze notitie wilt verwijderen en dan bewerken? Je verliest alle reacties, herdelingen en antwoorden erop."
|
||||||
|
addToList: "Aan lijst toevoegen"
|
||||||
|
sendMessage: "Verstuur bericht"
|
||||||
|
copyUsername: "Kopiëren gebruikersnaam "
|
||||||
|
searchUser: "Zoeken een gebruiker"
|
||||||
|
reply: "Antwoord"
|
||||||
|
loadMore: "Laad meer"
|
||||||
|
showMore: "Toon meer"
|
||||||
|
youGotNewFollower: "volgde jou"
|
||||||
|
receiveFollowRequest: "Volgverzoek ontvangen"
|
||||||
|
followRequestAccepted: "Volgverzoek geaccepteerd"
|
||||||
|
mention: "Vermelding"
|
||||||
|
mentions: "Vermeldingen"
|
||||||
|
directNotes: "Directe notities"
|
||||||
|
importAndExport: "Import / export"
|
||||||
|
import: "Import"
|
||||||
|
export: "Export"
|
||||||
|
files: "Bestanden"
|
||||||
|
download: "Downloaden"
|
||||||
|
driveFileDeleteConfirm: "Weet je zeker dat je het bestand \"{name}\" wilt verwijderen? Notities met dit bestand als bijlage worden ook verwijderd."
|
||||||
|
unfollowConfirm: "Weet je zeker dat je {name} wilt ontvolgen?"
|
||||||
|
exportRequested: "Je hebt een export aangevraagd. Dit kan een tijdje duren. Het wordt toegevoegd aan je Drive zodra het is voltooid."
|
||||||
|
importRequested: "Je hebt een import aangevraagd. Dit kan even duren."
|
||||||
|
lists: "Lijsten"
|
||||||
|
noLists: "Je hebt geen lijsten"
|
||||||
|
note: "Notitie"
|
||||||
|
notes: "Notities"
|
||||||
|
following: "Volgend"
|
||||||
|
followers: "Volgers"
|
||||||
|
followsYou: "Volgt jou"
|
||||||
|
createList: "Creëer lijst"
|
||||||
|
manageLists: "Beheren lijsten"
|
||||||
|
error: "Fout"
|
||||||
|
somethingHappened: "Er is iets misgegaan."
|
||||||
|
retry: "Probeer opnieuw"
|
||||||
|
pageLoadError: "Pagina laden mislukt"
|
||||||
|
pageLoadErrorDescription: "Dit wordt normaal gesproken veroorzaakt door netwerkfouten of door de cache van de browser. Probeer de cache te wissen en probeer het na een tijdje wachten opnieuw."
|
||||||
|
serverIsDead: "De server reageert niet. Wacht even en probeer het opnieuw."
|
||||||
|
youShouldUpgradeClient: "Werk je client bij om deze pagina te zien."
|
||||||
|
enterListName: "Voer de naam van de lijst in"
|
||||||
|
privacy: "Privacy"
|
||||||
|
makeFollowManuallyApprove: "Volgverzoeken vergen een goedkeuring"
|
||||||
|
defaultNoteVisibility: "Standaard zichtbaarheid"
|
||||||
|
follow: "Volgen"
|
||||||
|
followRequest: "Verzoek om te mogen volgen"
|
||||||
|
followRequests: "Volgverzoeken"
|
||||||
|
unfollow: "Ontvolgen"
|
||||||
|
followRequestPending: "Wachten op goedkeuring volgverzoek"
|
||||||
|
enterEmoji: "Voer een emoji in"
|
||||||
|
renote: "Herdelen"
|
||||||
|
unrenote: "Stop herdelen"
|
||||||
|
renoted: "Herdeeld"
|
||||||
|
cantRenote: "Dit bericht kan niet worden herdeeld"
|
||||||
|
cantReRenote: "Een herdeling kan niet worden herdeeld"
|
||||||
|
quote: "Quote"
|
||||||
|
pinnedNote: "Vastgemaakte notitie"
|
||||||
|
pinned: "Vastmaken aan profielpagina"
|
||||||
|
you: "Jij"
|
||||||
|
clickToShow: "Klik om te bekijken"
|
||||||
|
sensitive: "NSFW"
|
||||||
|
add: "Toevoegen"
|
||||||
|
reaction: "Reacties"
|
||||||
|
reactionSettingDescription: "Configureer welke reacties je wilt weergeven in de reactiekiezer."
|
||||||
|
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"
|
||||||
|
markAsSensitive: "Markeren als NSFW"
|
||||||
|
unmarkAsSensitive: "Geen NSFW"
|
||||||
|
enterFileName: "Invoeren bestandsnaam"
|
||||||
|
mute: "Dempen"
|
||||||
|
unmute: "Stop dempen"
|
||||||
|
block: "Blokkeren"
|
||||||
|
unblock: "Deblokkeren"
|
||||||
|
suspend: "Opschorten"
|
||||||
|
unsuspend: "Heractiveren"
|
||||||
|
blockConfirm: "Weet je zeker dat je dit account wil blokkeren?"
|
||||||
|
searchWith: "Zoeken: {q}"
|
||||||
|
youHaveNoLists: "Je hebt geen lijsten"
|
||||||
|
followConfirm: "Weet je zeker dat je {name} wilt volgen?"
|
||||||
|
proxyAccount: "Proxy account"
|
||||||
|
proxyAccountDescription: "Een proxy-account is een account dat onder bepaalde voorwaarden fungeert als externe volger voor gebruikers. Als een gebruiker bijvoorbeeld een externe gebruiker aan de lijst toevoegt, wordt de activiteit van de externe gebruiker niet aan de server geleverd als geen lokale gebruiker die gebruiker volgt, dus het proxy-account volgt in plaats daarvan."
|
||||||
|
host: "Server"
|
||||||
|
selectUser: "Kies een gebruiker"
|
||||||
|
recipient: "Ontvanger"
|
||||||
|
annotation: "Reacties"
|
||||||
|
federation: "Federatie"
|
||||||
|
instances: "Server"
|
||||||
|
registeredAt: "Geregistreerd op"
|
||||||
|
latestRequestSentAt: "Laatste aanvraag verstuurd"
|
||||||
|
latestRequestReceivedAt: "Laatste aanvraag ontvangen"
|
||||||
|
latestStatus: "Laatste status"
|
||||||
|
storageUsage: "Gebruikte opslagruimte"
|
||||||
|
charts: "Grafieken"
|
||||||
|
perHour: "Per uur"
|
||||||
|
perDay: "Per dag"
|
||||||
|
stopActivityDelivery: "Stop met versturen activiteiten"
|
||||||
|
blockThisInstance: "Blokkeer deze server"
|
||||||
|
operations: "Verwerkingen"
|
||||||
|
software: "Software"
|
||||||
|
version: "Versie"
|
||||||
|
metadata: "Metadata"
|
||||||
|
withNFiles: "{n} bestand(en)"
|
||||||
|
monitor: "Monitor"
|
||||||
|
jobQueue: "Job Queue"
|
||||||
|
cpuAndMemory: "CPU en geheugen"
|
||||||
|
network: "Netwerk"
|
||||||
|
disk: "Schijfruimte"
|
||||||
|
instanceInfo: "Serverinformatie"
|
||||||
|
statistics: "Statistieken"
|
||||||
|
clearQueue: "Wachtrij wissen"
|
||||||
|
clearQueueConfirmTitle: "Weet je zeker dat je de wachtrji leeg wil maken?"
|
||||||
|
clearQueueConfirmText: "Niet-bezorgde biljetten die nog in de wachtrij staan, worden niet gefedereerd. Meestal is deze operatie niet nodig."
|
||||||
|
clearCachedFiles: "Cache opschonen"
|
||||||
|
clearCachedFilesConfirm: "Weet je zeker dat je alle externe bestanden in de cache wilt verwijderen?"
|
||||||
|
blockedInstances: "Geblokkeerde servers"
|
||||||
|
blockedInstancesDescription: "Maak een lijst van de servers die moeten worden geblokkeerd, gescheiden door regeleinden. Geblokkeerde servers kunnen niet meer communiceren met deze server."
|
||||||
|
muteAndBlock: "Gedempt en geblokkeerd"
|
||||||
|
mutedUsers: "Gedempte gebruikers"
|
||||||
|
blockedUsers: "Geblokkeerde gebruikers"
|
||||||
|
noUsers: "Er zijn geen gebruikers."
|
||||||
|
editProfile: "Bewerk Profiel"
|
||||||
|
noteDeleteConfirm: "Ben je zeker dat je dit bericht wil verwijderen?"
|
||||||
|
pinLimitExceeded: "Je kunt geen berichten meer vastprikken"
|
||||||
|
intro: "Installatie van Misskey geëindigd! Maak nu een beheerder aan."
|
||||||
|
done: "Klaar"
|
||||||
|
processing: "Bezig met verwerken"
|
||||||
|
preview: "Voorbeeld"
|
||||||
|
default: "Standaard"
|
||||||
|
noCustomEmojis: "Er zijn geen emojis"
|
||||||
|
noJobs: "Er zijn geen taken"
|
||||||
|
federating: "Federeren"
|
||||||
|
blocked: "Geblokkeerd"
|
||||||
|
suspended: "Opgeschort"
|
||||||
|
all: "Alle"
|
||||||
|
subscribing: "Abonneren"
|
||||||
|
publishing: "Publiceren"
|
||||||
|
notResponding: "Reageert niet"
|
||||||
|
instanceFollowing: "Volgend op server"
|
||||||
|
instanceFollowers: "Volgers op server"
|
||||||
|
instanceUsers: "Gebruikers van deze server"
|
||||||
|
changePassword: "Wachtwoord wijzigen"
|
||||||
|
security: "Beveiliging"
|
||||||
|
retypedNotMatch: "Invoer komt niet overeen"
|
||||||
|
currentPassword: "Huidig wachtwoord"
|
||||||
|
newPassword: "Nieuwe wachtwoord"
|
||||||
|
newPasswordRetype: "Nieuw wachtwoord (herhalen)"
|
||||||
|
attachFile: "Bestanden toevoegen"
|
||||||
|
more: "Meer!"
|
||||||
|
featured: "Uitgelicht"
|
||||||
|
usernameOrUserId: "Gebruikersnaam of id"
|
||||||
|
noSuchUser: "Gebruiker niet gevonden"
|
||||||
|
lookup: "Opzoeken"
|
||||||
|
announcements: "Aankondigingen"
|
||||||
|
imageUrl: "AfbeeldingsURL"
|
||||||
|
remove: "Verwijderen"
|
||||||
|
removed: "Succesvol verwijderd"
|
||||||
|
removeAreYouSure: "Weet je zeker dat je \"{x}\" wil verwijderen?"
|
||||||
|
deleteAreYouSure: "Weet je zeker dat je \"{x}\" wil verwijderen?"
|
||||||
|
resetAreYouSure: "Resetten?"
|
||||||
|
saved: "Opgeslagen"
|
||||||
|
messaging: "Chat"
|
||||||
|
upload: "Uploaden"
|
||||||
|
fromDrive: "Van schijf"
|
||||||
|
fromUrl: "Van URL"
|
||||||
|
uploadFromUrl: "Uploaden vanaf een URL"
|
||||||
|
uploadFromUrlDescription: "URL van het bestand dat je wil uploaden"
|
||||||
|
uploadFromUrlRequested: "Uploadverzoek"
|
||||||
|
uploadFromUrlMayTakeTime: "Het kan even duren voordat het uploaden voltooid is."
|
||||||
|
explore: "Verkennen"
|
||||||
|
games: "Misskey spellen"
|
||||||
|
messageRead: "Lezen"
|
||||||
|
noMoreHistory: "Er is geen verdere geschiedenis"
|
||||||
|
startMessaging: "Start een gesprek"
|
||||||
|
nUsersRead: "gelezen door {n}"
|
||||||
|
agreeTo: "Ik stem in met {0}"
|
||||||
|
tos: "Gebruiksvoorwaarden"
|
||||||
|
start: "Aan de slag"
|
||||||
|
home: "Startpagina"
|
||||||
|
remoteUserCaution: "Aangezien deze gebruiker van een externe server afkomstig is, kan de weergegeven informatie onvolledig zijn."
|
||||||
|
activity: "Activiteit"
|
||||||
|
images: "Afbeeldingen"
|
||||||
|
birthday: "Geboortedatum"
|
||||||
|
yearsOld: "{age} jaar"
|
||||||
|
registeredDate: "Inschrijvingsdatum"
|
||||||
|
location: "Locatie"
|
||||||
|
theme: "Thema's"
|
||||||
|
themeForLightMode: "Thema voor gebruik in de lichte modus"
|
||||||
|
themeForDarkMode: "Thema voor gebruik in de donkere modus"
|
||||||
|
light: "Licht"
|
||||||
|
dark: "Donker"
|
||||||
|
lightThemes: "Licht thema's"
|
||||||
|
darkThemes: "Donkere thema's"
|
||||||
|
syncDeviceDarkMode: "Synchroniseer donkere modus met je apparaatinstellingen"
|
||||||
|
drive: "Schijf"
|
||||||
|
fileName: "Bestandsnaam"
|
||||||
|
selectFile: "Kies een bestand"
|
||||||
|
selectFiles: "Selecteer bestanden"
|
||||||
|
selectFolder: "Kies een map"
|
||||||
|
selectFolders: "Kies mappen"
|
||||||
|
renameFile: "Wijzig bestandsnaam"
|
||||||
|
folderName: "Mapnaam"
|
||||||
|
createFolder: "Map aanmaken"
|
||||||
|
renameFolder: "Map hernoemen"
|
||||||
|
nsfw: "NSFW"
|
||||||
|
pinnedNotes: "Vastgemaakte notitie"
|
||||||
|
userList: "Lijsten"
|
||||||
|
smtpHost: "Server"
|
||||||
|
smtpUser: "Gebruikersnaam"
|
||||||
|
smtpPass: "Wachtwoord"
|
||||||
|
clearCache: "Cache opschonen"
|
||||||
|
user: "Gebruikers"
|
||||||
|
muteThread: "Discussies dempen "
|
||||||
|
unmuteThread: "Dempen van discussie ongedaan maken"
|
||||||
|
hide: "Verbergen"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "volgde jou"
|
||||||
|
_mfm:
|
||||||
|
mention: "Vermelding"
|
||||||
|
quote: "Quote"
|
||||||
|
search: "Zoeken"
|
||||||
|
_theme:
|
||||||
|
keys:
|
||||||
|
mention: "Vermelding"
|
||||||
|
renote: "Herdelen"
|
||||||
|
_sfx:
|
||||||
|
note: "Notities"
|
||||||
|
notification: "Meldingen"
|
||||||
|
chat: "Chat"
|
||||||
|
_widgets:
|
||||||
|
notifications: "Meldingen"
|
||||||
|
timeline: "Tijdlijn"
|
||||||
|
activity: "Activiteit"
|
||||||
|
federation: "Federatie"
|
||||||
|
jobQueue: "Job Queue"
|
||||||
|
_cw:
|
||||||
|
show: "Laad meer"
|
||||||
|
_visibility:
|
||||||
|
home: "Startpagina"
|
||||||
|
followers: "Volgers"
|
||||||
|
_profile:
|
||||||
|
username: "Gebruikersnaam"
|
||||||
|
_exportOrImport:
|
||||||
|
followingList: "Volgend"
|
||||||
|
muteList: "Dempen"
|
||||||
|
blockingList: "Blokkeren"
|
||||||
|
userLists: "Lijsten"
|
||||||
|
excludeMutingUsers: "Negeer gedempte gebruikers"
|
||||||
|
excludeInactiveUsers: "Negeer inactieve gebruikers"
|
||||||
|
_timelines:
|
||||||
|
home: "Startpagina"
|
||||||
|
_rooms:
|
||||||
|
_roomType:
|
||||||
|
default: "Standaard"
|
||||||
|
_furnitures:
|
||||||
|
monitor: "Monitor"
|
||||||
|
_pages:
|
||||||
|
blocks:
|
||||||
|
image: "Afbeeldingen"
|
||||||
|
script:
|
||||||
|
categories:
|
||||||
|
list: "Lijsten"
|
||||||
|
blocks:
|
||||||
|
_join:
|
||||||
|
arg1: "Lijsten"
|
||||||
|
_randomPick:
|
||||||
|
arg1: "Lijsten"
|
||||||
|
_dailyRandomPick:
|
||||||
|
arg1: "Lijsten"
|
||||||
|
_seedRandomPick:
|
||||||
|
arg2: "Lijsten"
|
||||||
|
_pick:
|
||||||
|
arg1: "Lijsten"
|
||||||
|
_listLen:
|
||||||
|
arg1: "Lijsten"
|
||||||
|
types:
|
||||||
|
array: "Lijsten"
|
||||||
|
_notification:
|
||||||
|
youWereFollowed: "volgde jou"
|
||||||
|
_types:
|
||||||
|
follow: "Volgend"
|
||||||
|
mention: "Vermelding"
|
||||||
|
renote: "Herdelen"
|
||||||
|
quote: "Quote"
|
||||||
|
reaction: "Reacties"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "Meldingen"
|
||||||
|
tl: "Tijdlijn"
|
||||||
|
list: "Lijsten"
|
||||||
|
mentions: "Vermeldingen"
|
||||||
|
@@ -738,8 +738,9 @@ ratio: "Stosunek"
|
|||||||
global: "Globalna"
|
global: "Globalna"
|
||||||
sent: "Wyślij"
|
sent: "Wyślij"
|
||||||
hashtags: "Hashtag"
|
hashtags: "Hashtag"
|
||||||
_docs:
|
hide: "Ukryj"
|
||||||
admin: "Zarządzanie"
|
_ffVisibility:
|
||||||
|
public: "Publikuj"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Wróć"
|
back: "Wróć"
|
||||||
reduceFrequencyOfThisAd: "Pokazuj tę reklamę rzadziej"
|
reduceFrequencyOfThisAd: "Pokazuj tę reklamę rzadziej"
|
||||||
@@ -815,6 +816,7 @@ _mfm:
|
|||||||
blur: "Rozmycie"
|
blur: "Rozmycie"
|
||||||
font: "Czcionka"
|
font: "Czcionka"
|
||||||
fontDescription: "Wybiera czcionkę do wyświetlania treści."
|
fontDescription: "Wybiera czcionkę do wyświetlania treści."
|
||||||
|
rotate: "Obróć"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Reversi"
|
reversi: "Reversi"
|
||||||
gameSettings: "Ustawienia gry"
|
gameSettings: "Ustawienia gry"
|
||||||
|
@@ -1,22 +1,33 @@
|
|||||||
---
|
---
|
||||||
_lang_: "Português"
|
_lang_: "Português"
|
||||||
|
headlineMisskey: "Rede conectada por notas"
|
||||||
monthAndDay: "{day}/{month}"
|
monthAndDay: "{day}/{month}"
|
||||||
search: "Pesquisar"
|
search: "Pesquisar"
|
||||||
notifications: "Notificações"
|
notifications: "Notificações"
|
||||||
username: "Nome de usuário"
|
username: "Nome de usuário"
|
||||||
password: "Senha"
|
password: "Senha"
|
||||||
|
forgotPassword: "Esqueci a senha"
|
||||||
|
fetchingAsApObject: "Buscando no Fediverso"
|
||||||
ok: "OK"
|
ok: "OK"
|
||||||
gotIt: "Entendi"
|
gotIt: "Entendi"
|
||||||
cancel: "Cancelar"
|
cancel: "Cancelar"
|
||||||
enterUsername: "Digite o nome de usuário"
|
enterUsername: "Digite o nome de usuário"
|
||||||
renotedBy: "Repostado por {user}"
|
renotedBy: "Repostado por {user}"
|
||||||
noNotes: "Sem posts"
|
noNotes: "Sem posts"
|
||||||
|
noNotifications: "Sem notificações"
|
||||||
|
instance: "Instância"
|
||||||
settings: "Configurações"
|
settings: "Configurações"
|
||||||
basicSettings: "Configurações básicas"
|
basicSettings: "Configurações básicas"
|
||||||
otherSettings: "Outras configurações"
|
otherSettings: "Outras configurações"
|
||||||
|
openInWindow: "Abrir numa janela"
|
||||||
profile: "Perfil"
|
profile: "Perfil"
|
||||||
timeline: "Timeline"
|
timeline: "Timeline"
|
||||||
|
login: "Iniciar sessão"
|
||||||
|
loggingIn: "Iniciando sessão…"
|
||||||
logout: "Sair"
|
logout: "Sair"
|
||||||
|
signup: "Registrar-se"
|
||||||
|
uploading: "Enviando…"
|
||||||
|
save: "Guardar"
|
||||||
users: "Usuários"
|
users: "Usuários"
|
||||||
favorite: "Favoritar"
|
favorite: "Favoritar"
|
||||||
favorites: "Favoritar"
|
favorites: "Favoritar"
|
||||||
|
@@ -81,6 +81,8 @@ somethingHappened: "Что-то пошло не так"
|
|||||||
retry: "Повторить попытку"
|
retry: "Повторить попытку"
|
||||||
pageLoadError: "Не удалось загрузить страницу"
|
pageLoadError: "Не удалось загрузить страницу"
|
||||||
pageLoadErrorDescription: "Обычно это случается из-за сбоев в сети или кэша браузера. Попробуйте очистить кэш, или подождать пару минут, а потом попытаться загрузить страницу снова."
|
pageLoadErrorDescription: "Обычно это случается из-за сбоев в сети или кэша браузера. Попробуйте очистить кэш, или подождать пару минут, а потом попытаться загрузить страницу снова."
|
||||||
|
serverIsDead: "Ответа от сервера нет. Пожалуйста, подождите немного и повторите попытку."
|
||||||
|
youShouldUpgradeClient: "Чтобы просмотреть эту страницу, пожалуйста, обновите ее."
|
||||||
enterListName: "Название списка"
|
enterListName: "Название списка"
|
||||||
privacy: "Конфиденциальность"
|
privacy: "Конфиденциальность"
|
||||||
makeFollowManuallyApprove: "Принимать подписчиков вручную"
|
makeFollowManuallyApprove: "Принимать подписчиков вручную"
|
||||||
@@ -529,6 +531,9 @@ removeAllFollowing: "Удалить всех подписчиков"
|
|||||||
removeAllFollowingDescription: "Отменить все подписки с домена {host}? Пожалуйста, применяйте это действие, если инстанс больше не существует."
|
removeAllFollowingDescription: "Отменить все подписки с домена {host}? Пожалуйста, применяйте это действие, если инстанс больше не существует."
|
||||||
userSuspended: "Эта учётная запись заморожена"
|
userSuspended: "Эта учётная запись заморожена"
|
||||||
userSilenced: "Этот пользователь был заглушен"
|
userSilenced: "Этот пользователь был заглушен"
|
||||||
|
yourAccountSuspendedTitle: "Эта учетная запись заблокирована"
|
||||||
|
yourAccountSuspendedDescription: "Эта учетная запись была заблокирована из-за нарушения условий предоставления услуг сервера. Свяжитесь с администратором, если вы хотите узнать более подробную причину. Пожалуйста, не создавайте новую учетную запись."
|
||||||
|
menu: "Меню"
|
||||||
divider: "Линия-разделитель"
|
divider: "Линия-разделитель"
|
||||||
addItem: "Добавить элемент"
|
addItem: "Добавить элемент"
|
||||||
rooms: "Комната"
|
rooms: "Комната"
|
||||||
@@ -615,6 +620,8 @@ reportAbuse: "Жалоба"
|
|||||||
reportAbuseOf: "Пожаловаться на пользователя {name}"
|
reportAbuseOf: "Пожаловаться на пользователя {name}"
|
||||||
fillAbuseReportDescription: "Опишите, пожалуйста, причину жалобы подробнее. Если речь о конкретной заметке, будьте добры приложить ссылку на неё."
|
fillAbuseReportDescription: "Опишите, пожалуйста, причину жалобы подробнее. Если речь о конкретной заметке, будьте добры приложить ссылку на неё."
|
||||||
abuseReported: "Жалоба отправлена. Большое спасибо за информацию."
|
abuseReported: "Жалоба отправлена. Большое спасибо за информацию."
|
||||||
|
reporteeOrigin: "Куда сообщать"
|
||||||
|
reporterOrigin: "Сообщено"
|
||||||
send: "Отправить"
|
send: "Отправить"
|
||||||
abuseMarkAsResolved: "Отметить жалобу как решённую"
|
abuseMarkAsResolved: "Отметить жалобу как решённую"
|
||||||
openInNewTab: "Открыть в новой вкладке"
|
openInNewTab: "Открыть в новой вкладке"
|
||||||
@@ -761,15 +768,59 @@ middle: "Средне"
|
|||||||
low: "Низкий"
|
low: "Низкий"
|
||||||
emailNotConfiguredWarning: "Не указан адрес электронной почты"
|
emailNotConfiguredWarning: "Не указан адрес электронной почты"
|
||||||
ratio: "Соотношение"
|
ratio: "Соотношение"
|
||||||
|
previewNoteText: "Предварительный просмотр текста"
|
||||||
|
customCss: "Индивидуальный CSS"
|
||||||
|
customCssWarn: "Используйте эту настройку только если знаете, что делаете. Ошибки здесь чреваты тем, что сайт перестанет нормально работать у вас."
|
||||||
global: "Всеобщая"
|
global: "Всеобщая"
|
||||||
|
squareAvatars: "Квадратные аватарки"
|
||||||
sent: "Отправить"
|
sent: "Отправить"
|
||||||
|
received: "Получено"
|
||||||
|
searchResult: "Результаты поиска"
|
||||||
hashtags: "Хэштег"
|
hashtags: "Хэштег"
|
||||||
_docs:
|
troubleshooting: "Разрешение проблем"
|
||||||
continueReading: "Читать подробнее"
|
useBlurEffect: "Размытие в интерфейсе"
|
||||||
features: "Возможности"
|
learnMore: "Подробнее"
|
||||||
generalTopics: "Основные темы"
|
misskeyUpdated: "Misskey обновился!"
|
||||||
advancedTopics: "Дополнительные темы"
|
whatIsNew: "Что новенького?"
|
||||||
admin: "Управление"
|
translate: "Перевод"
|
||||||
|
translatedFrom: "{x}Перевод с английского"
|
||||||
|
accountDeletionInProgress: "В настоящее время выполняется удаление учетной записи"
|
||||||
|
usernameInfo: "Имя, которое отличает вашу учетную запись от других на этом сервере. Вы можете использовать алфавит (a~z, A~Z), цифры (0~9) или символы подчеркивания (_). Имена пользователей не могут быть изменены позже."
|
||||||
|
aiChanMode: "ИИ режим"
|
||||||
|
keepCw: "Сохраняйте Предупреждения о содержимом"
|
||||||
|
lastCommunication: "Последнее сообщение"
|
||||||
|
resolved: "Решен"
|
||||||
|
unresolved: "Неразрешенные"
|
||||||
|
itsOff: "Он выключен!"
|
||||||
|
emailRequiredForSignup: "Требуется адрес электронной почты для регистрации аккаунта"
|
||||||
|
unread: "Непрочитанное"
|
||||||
|
filter: "Фильтры"
|
||||||
|
controlPanel: "Панель управления"
|
||||||
|
manageAccounts: "Управление аккаунтом"
|
||||||
|
makeReactionsPublic: "Опубликовать список реакций"
|
||||||
|
makeReactionsPublicDescription: "Список сделанных вами реакций доступен для просмотра всем желающим."
|
||||||
|
classic: "Классика"
|
||||||
|
unmuteThread: "Отключить звук"
|
||||||
|
ffVisibilityDescription: "Вы можете установить объем вашей следующей/последней информации."
|
||||||
|
hide: "Спрятать"
|
||||||
|
_emailUnavailable:
|
||||||
|
used: "Уже используется"
|
||||||
|
format: "Неправильный формат"
|
||||||
|
smtp: "Почтовый сервер не отвечает"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "Опубликовать"
|
||||||
|
private: "Частный"
|
||||||
|
_signup:
|
||||||
|
almostThere: "Почти готово!"
|
||||||
|
emailAddressInfo: "Пожалуйста, введите адрес электронной почты, который вы используете."
|
||||||
|
emailSent: "На указанный вами адрес электронной почты ({email}) было отправлено письмо с подтверждением. Перейдите по ссылке в электронном письме, чтобы завершить создание учетной записи."
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "Удалить свой аккаунт"
|
||||||
|
mayTakeTime: "Удаление учетной записи - это тяжелый процесс, который может занять много времени, если у вас создано много контента или загружено много файлов."
|
||||||
|
sendEmail: "Мы отправим уведомление на зарегистрированный вами адрес электронной почты, когда ваша учетная запись будет удалена."
|
||||||
|
requestAccountDelete: "Запросить удаление вашей учетной записи"
|
||||||
|
started: "Процесс удаления начался."
|
||||||
|
inProgress: "Удаление в процессе"
|
||||||
_ad:
|
_ad:
|
||||||
back: "Выход"
|
back: "Выход"
|
||||||
reduceFrequencyOfThisAd: "Реже показывать эту рекламу"
|
reduceFrequencyOfThisAd: "Реже показывать эту рекламу"
|
||||||
@@ -870,6 +921,10 @@ _mfm:
|
|||||||
fontDescription: "Так можно писать произвольным шрифтом."
|
fontDescription: "Так можно писать произвольным шрифтом."
|
||||||
rainbow: "Радуга"
|
rainbow: "Радуга"
|
||||||
rainbowDescription: "Заставлять содержимое отображаться в цветах радуги."
|
rainbowDescription: "Заставлять содержимое отображаться в цветах радуги."
|
||||||
|
sparkle: "Блеск"
|
||||||
|
sparkleDescription: "Добавьте эффект искрящихся частиц."
|
||||||
|
rotate: "Повернуть"
|
||||||
|
rotateDescription: "Повернуть на указанный угол."
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Реверси"
|
reversi: "Реверси"
|
||||||
gameSettings: "Настройки игры"
|
gameSettings: "Настройки игры"
|
||||||
@@ -1096,6 +1151,10 @@ _permissions:
|
|||||||
"write:user-groups": "Изменять и удалять группы пользователей"
|
"write:user-groups": "Изменять и удалять группы пользователей"
|
||||||
"read:channels": "Смотреть каналы"
|
"read:channels": "Смотреть каналы"
|
||||||
"write:channels": "Изменять каналы"
|
"write:channels": "Изменять каналы"
|
||||||
|
"read:gallery": "Смотреть галерею"
|
||||||
|
"write:gallery": "Работа с галереей"
|
||||||
|
"read:gallery-likes": "Посмотреть галерею лайков"
|
||||||
|
"write:gallery-likes": "Манипулируйте понравившейся галереей"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "Дать доступ для «{name}» к вашей учётной записи?"
|
shareAccess: "Дать доступ для «{name}» к вашей учётной записи?"
|
||||||
shareAccessAsk: "Уверены, что хотите дать приложению доступ к своей учётной записи?"
|
shareAccessAsk: "Уверены, что хотите дать приложению доступ к своей учётной записи?"
|
||||||
@@ -1136,6 +1195,7 @@ _widgets:
|
|||||||
jobQueue: "Очередь заданий"
|
jobQueue: "Очередь заданий"
|
||||||
serverMetric: "Показатели сервера"
|
serverMetric: "Показатели сервера"
|
||||||
aiscript: "Консоль AiScript"
|
aiscript: "Консоль AiScript"
|
||||||
|
aichan: "Ай"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "Спрятать"
|
hide: "Спрятать"
|
||||||
show: "Показать еще"
|
show: "Показать еще"
|
||||||
|
62
locales/tr-TR.yml
Normal file
62
locales/tr-TR.yml
Normal file
@@ -0,0 +1,62 @@
|
|||||||
|
---
|
||||||
|
_lang_: "Türkçe"
|
||||||
|
introMisskey: "Açık kaynaklı bir dağıtılmış mikroblog hizmeti olan Misskey'e hoş geldiniz.\nMisskey, neler olup bittiğini paylaşmak ve herkese sizden bahsetmek için \"notlar\" oluşturmanıza olanak tanıyan, açık kaynaklı, dağıtılmış bir mikroblog hizmetidir.\nHerkesin notlarına kendi tepkilerinizi hızlıca eklemek için \"Tepkiler\" özelliğini de kullanabilirsiniz👍.\nYeni bir dünyayı keşfedin🚀."
|
||||||
|
monthAndDay: "{month}Ay {day}Gün"
|
||||||
|
search: "Arama"
|
||||||
|
notifications: "Bildirim"
|
||||||
|
username: "Kullanıcı Adı"
|
||||||
|
password: "Şifre"
|
||||||
|
forgotPassword: "şifremi unuttum"
|
||||||
|
ok: "TAMAM"
|
||||||
|
gotIt: "Anladım"
|
||||||
|
cancel: "İptal"
|
||||||
|
enterUsername: "Kullanıcı adınızı giriniz"
|
||||||
|
noNotes: "Notlar mevcut değil."
|
||||||
|
noNotifications: "Bildirim bulunmuyor"
|
||||||
|
settings: "Ayarlar"
|
||||||
|
basicSettings: "Temel Ayarlar"
|
||||||
|
otherSettings: "Diğer Ayarlar"
|
||||||
|
openInWindow: "Bir pencere ile aç"
|
||||||
|
profile: "Profil"
|
||||||
|
timeline: "Zaman çizelgesi"
|
||||||
|
noAccountDescription: "Bu kullanıcı henüz biyografisini yazmadı"
|
||||||
|
login: "Giriş Yap "
|
||||||
|
logout: "Çıkış Yap"
|
||||||
|
signup: "Kayıt Ol"
|
||||||
|
uploading: "Yükleniyor"
|
||||||
|
users: "Kullanıcı"
|
||||||
|
addUser: "Kullanıcı Ekle"
|
||||||
|
favorite: "Favoriler"
|
||||||
|
favorites: "Favoriler"
|
||||||
|
unfavorite: "Favorilerden Kaldır"
|
||||||
|
favorited: "Favorilerime eklendi."
|
||||||
|
alreadyFavorited: "Zaten favorilerinizde kayıtlı."
|
||||||
|
pin: "Sabitlenmiş"
|
||||||
|
unpin: "Sabitlemeyi kaldır"
|
||||||
|
copyContent: "İçeriği kopyala"
|
||||||
|
copyLink: "Bağlantıyı Kopyala"
|
||||||
|
delete: "Sil"
|
||||||
|
deleteAndEdit: "Sil ve yeniden düzenle"
|
||||||
|
deleteAndEditConfirm: "Bu notu silip yeniden düzenlemek istiyor musunuz? Bu nota ilişkin tüm Tepkiler, Yeniden Notlar ve Yanıtlar da silinecektir."
|
||||||
|
addToList: "Listeye ekle"
|
||||||
|
sendMessage: "Mesaj Gönder"
|
||||||
|
copyUsername: "Kullanıcı Adını Kopyala"
|
||||||
|
searchUser: "Kullanıcıları ara"
|
||||||
|
pinned: "Sabitlenmiş"
|
||||||
|
remove: "Sil"
|
||||||
|
smtpUser: "Kullanıcı Adı"
|
||||||
|
smtpPass: "Şifre"
|
||||||
|
user: "Kullanıcı"
|
||||||
|
_mfm:
|
||||||
|
search: "Arama"
|
||||||
|
_sfx:
|
||||||
|
notification: "Bildirim"
|
||||||
|
_widgets:
|
||||||
|
notifications: "Bildirim"
|
||||||
|
timeline: "Zaman çizelgesi"
|
||||||
|
_profile:
|
||||||
|
username: "Kullanıcı Adı"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "Bildirim"
|
||||||
|
tl: "Zaman çizelgesi"
|
@@ -692,8 +692,7 @@ middle: "Середній"
|
|||||||
global: "Глобальна"
|
global: "Глобальна"
|
||||||
sent: "Відправити"
|
sent: "Відправити"
|
||||||
hashtags: "Хештеґ"
|
hashtags: "Хештеґ"
|
||||||
_docs:
|
hide: "Сховати"
|
||||||
admin: "Управління"
|
|
||||||
_ad:
|
_ad:
|
||||||
back: "Назад"
|
back: "Назад"
|
||||||
_gallery:
|
_gallery:
|
||||||
@@ -773,6 +772,7 @@ _mfm:
|
|||||||
blurDescription: "Цей ефект зробить контент розмитим. Контент можна зробити чітким, якщо навести на нього вказівник миші."
|
blurDescription: "Цей ефект зробить контент розмитим. Контент можна зробити чітким, якщо навести на нього вказівник миші."
|
||||||
font: "Шрифт"
|
font: "Шрифт"
|
||||||
fontDescription: "Встановлює шрифт для контенту."
|
fontDescription: "Встановлює шрифт для контенту."
|
||||||
|
rotate: "Обертати"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "Реверсі"
|
reversi: "Реверсі"
|
||||||
gameSettings: "Налаштування гри"
|
gameSettings: "Налаштування гри"
|
||||||
|
@@ -1,20 +1,20 @@
|
|||||||
---
|
---
|
||||||
_lang_: "中文(简体)"
|
_lang_: "中文(简体)"
|
||||||
headlineMisskey: "通过帖子连接在一起的网络"
|
headlineMisskey: "通过帖子连接在一起的网络"
|
||||||
introMisskey: "欢迎!Misskey是一个开源的、去中心化的“微博客”服务。\n通过编写「帖子」来和大家分享你的以及你周围的事情吧!📡\n通过「回应」功能,可以让你快速地对大家的帖子表达反馈👍\n来探索新的世界吧!🚀"
|
introMisskey: "欢迎!Misskey是一个开源的、去中心化的“微博客”服务。\n通过编写「帖文」来和大家分享你的以及你周围的事情吧!📡\n通过「回应」功能,可以让你快速地对大家的帖文表达反馈👍\n来探索新的世界吧!🚀"
|
||||||
monthAndDay: "{month}月 {day}日"
|
monthAndDay: "{month}月 {day}日"
|
||||||
search: "搜索"
|
search: "搜索"
|
||||||
notifications: "通知"
|
notifications: "通知"
|
||||||
username: "用户名"
|
username: "用户名"
|
||||||
password: "密码"
|
password: "密码"
|
||||||
forgotPassword: "重置密码"
|
forgotPassword: "忘记密码"
|
||||||
fetchingAsApObject: "联合查询中"
|
fetchingAsApObject: "联合查询"
|
||||||
ok: "OK"
|
ok: "OK"
|
||||||
gotIt: "我明白了"
|
gotIt: "我明白了"
|
||||||
cancel: "取消"
|
cancel: "取消"
|
||||||
enterUsername: "输入用户名"
|
enterUsername: "输入用户名"
|
||||||
renotedBy: "{user} 转发了"
|
renotedBy: "由 {user} 转推"
|
||||||
noNotes: "没有帖子"
|
noNotes: "没有帖文"
|
||||||
noNotifications: "无通知"
|
noNotifications: "无通知"
|
||||||
instance: "实例"
|
instance: "实例"
|
||||||
settings: "设置"
|
settings: "设置"
|
||||||
@@ -81,6 +81,8 @@ somethingHappened: "出现了一些问题!"
|
|||||||
retry: "重试"
|
retry: "重试"
|
||||||
pageLoadError: "页面加载失败。"
|
pageLoadError: "页面加载失败。"
|
||||||
pageLoadErrorDescription: "这通常是由于网络或浏览器缓存的原因。请清除缓存或等待片刻后重试。"
|
pageLoadErrorDescription: "这通常是由于网络或浏览器缓存的原因。请清除缓存或等待片刻后重试。"
|
||||||
|
serverIsDead: "服务器没有响应。 请稍等片刻,然后重试。"
|
||||||
|
youShouldUpgradeClient: "请重新加载并使用新版本的客户端查看此页面。"
|
||||||
enterListName: "输入列表名称"
|
enterListName: "输入列表名称"
|
||||||
privacy: "隐私"
|
privacy: "隐私"
|
||||||
makeFollowManuallyApprove: "关注者的关注请求需要批准"
|
makeFollowManuallyApprove: "关注者的关注请求需要批准"
|
||||||
@@ -122,9 +124,9 @@ unblockConfirm: "确定要解除拉黑吗?"
|
|||||||
suspendConfirm: "要冻结吗?"
|
suspendConfirm: "要冻结吗?"
|
||||||
unsuspendConfirm: "要解除冻结吗?"
|
unsuspendConfirm: "要解除冻结吗?"
|
||||||
selectList: "选择列表"
|
selectList: "选择列表"
|
||||||
selectAntenna: "天线选择"
|
selectAntenna: "选择天线"
|
||||||
selectWidget: "选择小工具"
|
selectWidget: "选择小工具"
|
||||||
editWidgets: "编辑小工具"
|
editWidgets: "编辑部件"
|
||||||
editWidgetsExit: "完成编辑"
|
editWidgetsExit: "完成编辑"
|
||||||
customEmojis: "自定义表情符号"
|
customEmojis: "自定义表情符号"
|
||||||
emoji: "表情符号"
|
emoji: "表情符号"
|
||||||
@@ -137,9 +139,9 @@ cacheRemoteFiles: "远程文件缓存"
|
|||||||
cacheRemoteFilesDescription: "当禁用此设定时远程文件将直接从远程实例载入。禁用后会减小储存空间需求,但是会增加流量,因为缩略图不会被生成。"
|
cacheRemoteFilesDescription: "当禁用此设定时远程文件将直接从远程实例载入。禁用后会减小储存空间需求,但是会增加流量,因为缩略图不会被生成。"
|
||||||
flagAsBot: "这是一个机器人账号"
|
flagAsBot: "这是一个机器人账号"
|
||||||
flagAsBotDescription: "如果此帐户由程序控制,请启用此项。启用后,此标志可以帮助其他开发人员防止机器人之间产生无限互动的行为,并让Misskey的内部系统将此帐户识别为机器人。"
|
flagAsBotDescription: "如果此帐户由程序控制,请启用此项。启用后,此标志可以帮助其他开发人员防止机器人之间产生无限互动的行为,并让Misskey的内部系统将此帐户识别为机器人。"
|
||||||
flagAsCat: "这个账户是一只猫"
|
flagAsCat: "将这个账户设定为一只猫"
|
||||||
flagAsCatDescription: "如果您想表明此帐户是一只猫,请打开此标志。\n开启后,会在您的头像上出现猫耳朵,并将你的帖子中的「na」替换为「nya」,日文同理。"
|
flagAsCatDescription: "如果您想表明此帐户是一只猫,请打开此标志。"
|
||||||
autoAcceptFollowed: "自动允许关注者的关注"
|
autoAcceptFollowed: "自动允许关注"
|
||||||
addAccount: "添加账户"
|
addAccount: "添加账户"
|
||||||
loginFailed: "登录失败"
|
loginFailed: "登录失败"
|
||||||
showOnRemote: "转到所在实例显示"
|
showOnRemote: "转到所在实例显示"
|
||||||
@@ -529,6 +531,8 @@ removeAllFollowing: "取消所有关注"
|
|||||||
removeAllFollowingDescription: "取消{host}的所有关注者。当实例不存在时执行。"
|
removeAllFollowingDescription: "取消{host}的所有关注者。当实例不存在时执行。"
|
||||||
userSuspended: "该用户已被冻结。"
|
userSuspended: "该用户已被冻结。"
|
||||||
userSilenced: "该用户已被禁言。"
|
userSilenced: "该用户已被禁言。"
|
||||||
|
yourAccountSuspendedTitle: "账户已被冻结"
|
||||||
|
yourAccountSuspendedDescription: "由于违反了服务器的服务条款或其他原因,该账户已被冻结。 您可以与管理员联系以了解更多信息。 请不要创建一个新的帐户。"
|
||||||
menu: "菜单"
|
menu: "菜单"
|
||||||
divider: "分割线"
|
divider: "分割线"
|
||||||
addItem: "添加项目"
|
addItem: "添加项目"
|
||||||
@@ -588,6 +592,7 @@ smtpSecure: "在 SMTP 连接中使用隐式 SSL / TLS"
|
|||||||
smtpSecureInfo: "使用STARTTLS时关闭。"
|
smtpSecureInfo: "使用STARTTLS时关闭。"
|
||||||
testEmail: "邮件发送测试"
|
testEmail: "邮件发送测试"
|
||||||
wordMute: "文字屏蔽"
|
wordMute: "文字屏蔽"
|
||||||
|
instanceMute: "实例的屏蔽"
|
||||||
userSaysSomething: "{name}说了什么"
|
userSaysSomething: "{name}说了什么"
|
||||||
makeActive: "启用"
|
makeActive: "启用"
|
||||||
display: "显示"
|
display: "显示"
|
||||||
@@ -616,6 +621,8 @@ reportAbuse: "举报"
|
|||||||
reportAbuseOf: "举报{name}"
|
reportAbuseOf: "举报{name}"
|
||||||
fillAbuseReportDescription: "请填写举报的详细原因。如果有对方发的帖子,请同时填写URL地址。"
|
fillAbuseReportDescription: "请填写举报的详细原因。如果有对方发的帖子,请同时填写URL地址。"
|
||||||
abuseReported: "内容已发送。感谢您的报告。"
|
abuseReported: "内容已发送。感谢您的报告。"
|
||||||
|
reporteeOrigin: "举报来源"
|
||||||
|
reporterOrigin: "举报者来源"
|
||||||
send: "发送"
|
send: "发送"
|
||||||
abuseMarkAsResolved: "处理完毕"
|
abuseMarkAsResolved: "处理完毕"
|
||||||
openInNewTab: "在新标签页中打开"
|
openInNewTab: "在新标签页中打开"
|
||||||
@@ -762,6 +769,7 @@ middle: "中"
|
|||||||
low: "低"
|
low: "低"
|
||||||
emailNotConfiguredWarning: "电子邮件地址未设置。"
|
emailNotConfiguredWarning: "电子邮件地址未设置。"
|
||||||
ratio: "比率"
|
ratio: "比率"
|
||||||
|
previewNoteText: "预览文本"
|
||||||
customCss: "自定义 CSS"
|
customCss: "自定义 CSS"
|
||||||
customCssWarn: "这些设置必须有相关的基础知识,不当的配置可能导致客户端无法正常使用!"
|
customCssWarn: "这些设置必须有相关的基础知识,不当的配置可能导致客户端无法正常使用!"
|
||||||
global: "全局"
|
global: "全局"
|
||||||
@@ -771,13 +779,61 @@ received: "收取"
|
|||||||
searchResult: "搜索结果"
|
searchResult: "搜索结果"
|
||||||
hashtags: "话题标签"
|
hashtags: "话题标签"
|
||||||
troubleshooting: "故障排除"
|
troubleshooting: "故障排除"
|
||||||
_docs:
|
useBlurEffect: "在UI上使用模糊效果"
|
||||||
continueReading: "继续阅读"
|
learnMore: "更多信息"
|
||||||
features: "特性"
|
misskeyUpdated: "Misskey更新完成!"
|
||||||
generalTopics: "通常提示"
|
whatIsNew: "显示更新信息"
|
||||||
advancedTopics: "进阶提示"
|
translate: "翻译"
|
||||||
admin: "管理"
|
translatedFrom: "从 {x} 翻译"
|
||||||
translateWarn: "本文档是翻译后的文档。内容可能与原文有所不同。"
|
accountDeletionInProgress: "正在删除账户"
|
||||||
|
usernameInfo: "在服务器上唯一标识您的帐户的名称。您可以使用字母 (a ~ z, A ~ Z)、数字 (0 ~ 9) 和下划线 (_)。用户名以后不能更改。"
|
||||||
|
aiChanMode: "小蓝模式"
|
||||||
|
keepCw: "保留CW"
|
||||||
|
pubSub: "Pub/Sub账户"
|
||||||
|
lastCommunication: "最近通信"
|
||||||
|
resolved: "已解决"
|
||||||
|
unresolved: "未解决"
|
||||||
|
breakFollow: "移除关注者"
|
||||||
|
itsOn: "已开启"
|
||||||
|
itsOff: "已关闭"
|
||||||
|
emailRequiredForSignup: "注册账户需要电子邮件地址"
|
||||||
|
unread: "未读"
|
||||||
|
filter: "筛选"
|
||||||
|
controlPanel: "控制面板"
|
||||||
|
manageAccounts: "管理账户"
|
||||||
|
makeReactionsPublic: "将回应设置为公开"
|
||||||
|
makeReactionsPublicDescription: "将您发表过的回应设置成公开可见。"
|
||||||
|
classic: "经典"
|
||||||
|
muteThread: "屏蔽帖子列表"
|
||||||
|
unmuteThread: "取消屏蔽帖子列表"
|
||||||
|
ffVisibility: "连接的可见范围"
|
||||||
|
ffVisibilityDescription: "您可以设置您的关注/关注者信息的公开范围"
|
||||||
|
continueThread: "查看更多帖子"
|
||||||
|
deleteAccountConfirm: "将要删除账户。是否确认?"
|
||||||
|
incorrectPassword: "密码错误"
|
||||||
|
voteConfirm: "确定投给“{choice}” ?"
|
||||||
|
hide: "隐藏"
|
||||||
|
_emailUnavailable:
|
||||||
|
used: "已经被使用过"
|
||||||
|
format: "无效的格式"
|
||||||
|
disposable: "不是永久可用的地址"
|
||||||
|
mx: "邮件服务器不正确"
|
||||||
|
smtp: "邮件服务器没有响应"
|
||||||
|
_ffVisibility:
|
||||||
|
public: "发布"
|
||||||
|
followers: "只有关注你的用户能看到"
|
||||||
|
private: "私密"
|
||||||
|
_signup:
|
||||||
|
almostThere: "即将完成"
|
||||||
|
emailAddressInfo: "请输入您所使用的电子邮件地址"
|
||||||
|
emailSent: "已将确认邮件发送至您输入的电子邮件地址 ({email})。请访问电子邮件中的链接以完成帐户创建。"
|
||||||
|
_accountDelete:
|
||||||
|
accountDelete: "删除帐户"
|
||||||
|
mayTakeTime: "删除账号是一个性能损耗较大的处理,如果账号持有的内容数量和上传的文件数量较多的话,完成需要花费一段时间。"
|
||||||
|
sendEmail: "账户删除完成后,将向注册的电子邮件地址发送通知。"
|
||||||
|
requestAccountDelete: "请求删除账户"
|
||||||
|
started: "账户删除过程已开始。"
|
||||||
|
inProgress: "正在删除"
|
||||||
_ad:
|
_ad:
|
||||||
back: "返回"
|
back: "返回"
|
||||||
reduceFrequencyOfThisAd: "减少此广告的频率"
|
reduceFrequencyOfThisAd: "减少此广告的频率"
|
||||||
@@ -878,6 +934,10 @@ _mfm:
|
|||||||
fontDescription: "可以设置内容所使用的字体。"
|
fontDescription: "可以设置内容所使用的字体。"
|
||||||
rainbow: "彩虹"
|
rainbow: "彩虹"
|
||||||
rainbowDescription: "用彩虹色来显示内容。"
|
rainbowDescription: "用彩虹色来显示内容。"
|
||||||
|
sparkle: "闪光"
|
||||||
|
sparkleDescription: "添加发光粒子效果。"
|
||||||
|
rotate: "旋转"
|
||||||
|
rotateDescription: "旋转指定的角度。"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "黑白棋"
|
reversi: "黑白棋"
|
||||||
gameSettings: "对局设置"
|
gameSettings: "对局设置"
|
||||||
@@ -943,6 +1003,11 @@ _wordMute:
|
|||||||
soft: "软屏蔽"
|
soft: "软屏蔽"
|
||||||
hard: "硬屏蔽"
|
hard: "硬屏蔽"
|
||||||
mutedNotes: "被屏蔽的帖子"
|
mutedNotes: "被屏蔽的帖子"
|
||||||
|
_instanceMute:
|
||||||
|
instanceMuteDescription: "屏蔽配置实例中的所有帖子和转帖,包括实例的用户回复。"
|
||||||
|
instanceMuteDescription2: "设置时用换行符来分隔"
|
||||||
|
title: "隐藏实例已设置的帖子。"
|
||||||
|
heading: "屏蔽实例"
|
||||||
_theme:
|
_theme:
|
||||||
explore: "寻找主题"
|
explore: "寻找主题"
|
||||||
install: "安装主题"
|
install: "安装主题"
|
||||||
@@ -1104,6 +1169,10 @@ _permissions:
|
|||||||
"write:user-groups": "操作用户组"
|
"write:user-groups": "操作用户组"
|
||||||
"read:channels": "查看频道"
|
"read:channels": "查看频道"
|
||||||
"write:channels": "管理频道"
|
"write:channels": "管理频道"
|
||||||
|
"read:gallery": "浏览图库"
|
||||||
|
"write:gallery": "操作图库"
|
||||||
|
"read:gallery-likes": "读取喜欢的图片"
|
||||||
|
"write:gallery-likes": "操作喜欢的图片"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "您要授权允许“{name}”访问您的帐户吗?"
|
shareAccess: "您要授权允许“{name}”访问您的帐户吗?"
|
||||||
shareAccessAsk: "您确定要授权此应用程序访问您的帐户吗?"
|
shareAccessAsk: "您确定要授权此应用程序访问您的帐户吗?"
|
||||||
@@ -1144,6 +1213,7 @@ _widgets:
|
|||||||
jobQueue: "作业队列"
|
jobQueue: "作业队列"
|
||||||
serverMetric: "服务器监控"
|
serverMetric: "服务器监控"
|
||||||
aiscript: "AiScript控制台"
|
aiscript: "AiScript控制台"
|
||||||
|
aichan: "小蓝"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "隐藏"
|
hide: "隐藏"
|
||||||
show: "查看更多"
|
show: "查看更多"
|
||||||
@@ -1211,6 +1281,8 @@ _exportOrImport:
|
|||||||
muteList: "屏蔽"
|
muteList: "屏蔽"
|
||||||
blockingList: "拉黑"
|
blockingList: "拉黑"
|
||||||
userLists: "列表"
|
userLists: "列表"
|
||||||
|
excludeMutingUsers: "排除屏蔽用户"
|
||||||
|
excludeInactiveUsers: "排除不活跃用户"
|
||||||
_charts:
|
_charts:
|
||||||
federationInstancesIncDec: "联合:增加/减少"
|
federationInstancesIncDec: "联合:增加/减少"
|
||||||
federationInstancesTotal: "联合总数"
|
federationInstancesTotal: "联合总数"
|
||||||
|
@@ -754,8 +754,9 @@ ratio: "%"
|
|||||||
global: "公開"
|
global: "公開"
|
||||||
sent: "發送"
|
sent: "發送"
|
||||||
hashtags: "#tag"
|
hashtags: "#tag"
|
||||||
_docs:
|
hide: "隱藏"
|
||||||
admin: "管理"
|
_ffVisibility:
|
||||||
|
public: "發佈"
|
||||||
_ad:
|
_ad:
|
||||||
back: "返回"
|
back: "返回"
|
||||||
reduceFrequencyOfThisAd: "降低此廣告的頻率 "
|
reduceFrequencyOfThisAd: "降低此廣告的頻率 "
|
||||||
@@ -840,6 +841,7 @@ _mfm:
|
|||||||
blur: "模糊"
|
blur: "模糊"
|
||||||
font: "字型"
|
font: "字型"
|
||||||
fontDescription: "您可以設定顯示內容的字型"
|
fontDescription: "您可以設定顯示內容的字型"
|
||||||
|
rotate: "旋轉"
|
||||||
_reversi:
|
_reversi:
|
||||||
reversi: "黑白棋"
|
reversi: "黑白棋"
|
||||||
gameSettings: "對弈設定"
|
gameSettings: "對弈設定"
|
||||||
|
@@ -1,485 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class Init1000000000000 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TYPE "log_level_enum" AS ENUM('error', 'warning', 'info', 'success', 'debug')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "log" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "domain" character varying(64) array NOT NULL DEFAULT '{}'::varchar[], "level" "log_level_enum" NOT NULL, "worker" character varying(8) NOT NULL, "machine" character varying(128) NOT NULL, "message" character varying(1024) NOT NULL, "data" jsonb NOT NULL DEFAULT '{}', CONSTRAINT "PK_350604cbdf991d5930d9e618fbd" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_8e4eb51a35d81b64dda28eed0a" ON "log" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_8cb40cfc8f3c28261e6f887b03" ON "log" ("domain") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_584b536b49e53ac81beb39a177" ON "log" ("level") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "drive_folder" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "name" character varying(128) NOT NULL, "userId" character varying(32), "parentId" character varying(32), CONSTRAINT "PK_7a0c089191f5ebdc214e0af808a" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_02878d441ceae15ce060b73daf" ON "drive_folder" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f4fc06e49c0171c85f1c48060d" ON "drive_folder" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_00ceffb0cdc238b3233294f08f" ON "drive_folder" ("parentId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "drive_file" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32), "userHost" character varying(128), "md5" character varying(32) NOT NULL, "name" character varying(256) NOT NULL, "type" character varying(128) NOT NULL, "size" integer NOT NULL, "comment" character varying(512), "properties" jsonb NOT NULL DEFAULT '{}', "storedInternal" boolean NOT NULL, "url" character varying(512) NOT NULL, "thumbnailUrl" character varying(512), "webpublicUrl" character varying(512), "accessKey" character varying(256), "thumbnailAccessKey" character varying(256), "webpublicAccessKey" character varying(256), "uri" character varying(512), "src" character varying(512), "folderId" character varying(32), "isSensitive" boolean NOT NULL DEFAULT false, "isLink" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_43ddaaaf18c9e68029b7cbb032e" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_c8dfad3b72196dd1d6b5db168a" ON "drive_file" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_860fa6f6c7df5bb887249fba22" ON "drive_file" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_92779627994ac79277f070c91e" ON "drive_file" ("userHost") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_37bb9a1b4585f8a3beb24c62d6" ON "drive_file" ("md5") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a40b8df8c989d7db937ea27cf6" ON "drive_file" ("type") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_d85a184c2540d2deba33daf642" ON "drive_file" ("accessKey") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_e74022ce9a074b3866f70e0d27" ON "drive_file" ("thumbnailAccessKey") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_c55b2b7c284d9fef98026fc88e" ON "drive_file" ("webpublicAccessKey") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e5848eac4940934e23dbc17581" ON "drive_file" ("uri") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_bb90d1956dafc4068c28aa7560" ON "drive_file" ("folderId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE, "lastFetchedAt" TIMESTAMP WITH TIME ZONE, "username" character varying(128) NOT NULL, "usernameLower" character varying(128) NOT NULL, "name" character varying(128), "followersCount" integer NOT NULL DEFAULT 0, "followingCount" integer NOT NULL DEFAULT 0, "notesCount" integer NOT NULL DEFAULT 0, "avatarId" character varying(32), "bannerId" character varying(32), "tags" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], "avatarUrl" character varying(512), "bannerUrl" character varying(512), "avatarColor" character varying(32), "bannerColor" character varying(32), "isSuspended" boolean NOT NULL DEFAULT false, "isSilenced" boolean NOT NULL DEFAULT false, "isLocked" boolean NOT NULL DEFAULT false, "isBot" boolean NOT NULL DEFAULT false, "isCat" boolean NOT NULL DEFAULT false, "isAdmin" boolean NOT NULL DEFAULT false, "isModerator" boolean NOT NULL DEFAULT false, "isVerified" boolean NOT NULL DEFAULT false, "emojis" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], "host" character varying(128), "inbox" character varying(512), "sharedInbox" character varying(512), "featured" character varying(512), "uri" character varying(512), "token" character(16), CONSTRAINT "UQ_a854e557b1b14814750c7c7b0c9" UNIQUE ("token"), CONSTRAINT "REL_58f5c71eaab331645112cf8cfa" UNIQUE ("avatarId"), CONSTRAINT "REL_afc64b53f8db3707ceb34eb28e" UNIQUE ("bannerId"), CONSTRAINT "PK_cace4a159ff9f2512dd42373760" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e11e649824a45d8ed01d597fd9" ON "user" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_80ca6e6ef65fb9ef34ea8c90f4" ON "user" ("updatedAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a27b942a0d6dcff90e3ee9b5e8" ON "user" ("usernameLower") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_fa99d777623947a5b05f394cae" ON "user" ("tags") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3252a5df8d5bbd16b281f7799e" ON "user" ("host") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_be623adaa4c566baf5d29ce0c8" ON "user" ("uri") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_a854e557b1b14814750c7c7b0c" ON "user" ("token") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_5deb01ae162d1d70b80d064c27" ON "user" ("usernameLower", "host") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "app" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32), "secret" character varying(64) NOT NULL, "name" character varying(128) NOT NULL, "description" character varying(512) NOT NULL, "permission" character varying(64) array NOT NULL, "callbackUrl" character varying(512), CONSTRAINT "PK_9478629fc093d229df09e560aea" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_048a757923ed8b157e9895da53" ON "app" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3f5b0899ef90527a3462d7c2cb" ON "app" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f49922d511d666848f250663c4" ON "app" ("secret") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "access_token" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "token" character varying(128) NOT NULL, "hash" character varying(128) NOT NULL, "userId" character varying(32) NOT NULL, "appId" character varying(32) NOT NULL, CONSTRAINT "PK_f20f028607b2603deabd8182d12" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_70ba8f6af34bc924fc9e12adb8" ON "access_token" ("token") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_64c327441248bae40f7d92f34f" ON "access_token" ("hash") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_9949557d0e1b2c19e5344c171e" ON "access_token" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE TYPE "note_visibility_enum" AS ENUM('public', 'home', 'followers', 'specified')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "note" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "replyId" character varying(32), "renoteId" character varying(32), "text" text, "name" character varying(256), "cw" character varying(512), "appId" character varying(32), "userId" character varying(32) NOT NULL, "viaMobile" boolean NOT NULL DEFAULT false, "localOnly" boolean NOT NULL DEFAULT false, "renoteCount" smallint NOT NULL DEFAULT 0, "repliesCount" smallint NOT NULL DEFAULT 0, "reactions" jsonb NOT NULL DEFAULT '{}', "visibility" "note_visibility_enum" NOT NULL, "uri" character varying(512), "score" integer NOT NULL DEFAULT 0, "fileIds" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], "attachedFileTypes" character varying(256) array NOT NULL DEFAULT '{}'::varchar[], "visibleUserIds" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], "mentions" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], "mentionedRemoteUsers" text NOT NULL DEFAULT '[]', "emojis" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], "tags" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], "hasPoll" boolean NOT NULL DEFAULT false, "geo" jsonb DEFAULT null, "userHost" character varying(128), "replyUserId" character varying(32), "replyUserHost" character varying(128), "renoteUserId" character varying(32), "renoteUserHost" character varying(128), CONSTRAINT "PK_96d0c172a4fba276b1bbed43058" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e7c0567f5261063592f022e9b5" ON "note" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_17cb3553c700a4985dff5a30ff" ON "note" ("replyId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_52ccc804d7c69037d558bac4c9" ON "note" ("renoteId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_5b87d9d19127bd5d92026017a7" ON "note" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_153536c67d05e9adb24e99fc2b" ON "note" ("uri") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_51c063b6a133a9cb87145450f5" ON "note" ("fileIds") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_25dfc71b0369b003a4cd434d0b" ON "note" ("attachedFileTypes") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_796a8c03959361f97dc2be1d5c" ON "note" ("visibleUserIds") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_54ebcb6d27222913b908d56fd8" ON "note" ("mentions") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_88937d94d7443d9a99a76fa5c0" ON "note" ("tags") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7125a826ab192eb27e11d358a5" ON "note" ("userHost") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "poll_vote" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, "choice" integer NOT NULL, CONSTRAINT "PK_fd002d371201c472490ba89c6a0" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0fb627e1c2f753262a74f0562d" ON "poll_vote" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_66d2bd2ee31d14bcc23069a89f" ON "poll_vote" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_aecfbd5ef60374918e63ee95fa" ON "poll_vote" ("noteId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_50bd7164c5b78f1f4a42c4d21f" ON "poll_vote" ("userId", "noteId", "choice") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "note_reaction" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, "reaction" character varying(128) NOT NULL, CONSTRAINT "PK_767ec729b108799b587a3fcc9cf" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_01f4581f114e0ebd2bbb876f0b" ON "note_reaction" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_13761f64257f40c5636d0ff95e" ON "note_reaction" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_45145e4953780f3cd5656f0ea6" ON "note_reaction" ("noteId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_ad0c221b25672daf2df320a817" ON "note_reaction" ("userId", "noteId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "note_watching" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, "noteUserId" character varying(32) NOT NULL, CONSTRAINT "PK_49286fdb23725945a74aa27d757" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_318cdf42a9cfc11f479bd802bb" ON "note_watching" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b0134ec406e8d09a540f818288" ON "note_watching" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_03e7028ab8388a3f5e3ce2a861" ON "note_watching" ("noteId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_44499765eec6b5489d72c4253b" ON "note_watching" ("noteUserId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_a42c93c69989ce1d09959df4cf" ON "note_watching" ("userId", "noteId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "note_unread" ("id" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, "noteUserId" character varying(32) NOT NULL, "isSpecified" boolean NOT NULL, CONSTRAINT "PK_1904eda61a784f57e6e51fa9c1f" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_56b0166d34ddae49d8ef7610bb" ON "note_unread" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e637cba4dc4410218c4251260e" ON "note_unread" ("noteId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_d908433a4953cc13216cd9c274" ON "note_unread" ("userId", "noteId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "notification" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "notifieeId" character varying(32) NOT NULL, "notifierId" character varying(32) NOT NULL, "type" character varying(32) NOT NULL, "isRead" boolean NOT NULL DEFAULT false, "noteId" character varying(32), "reaction" character varying(128), "choice" integer, CONSTRAINT "PK_705b6c7cdf9b2c2ff7ac7872cb7" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b11a5e627c41d4dc3170f1d370" ON "notification" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3c601b70a1066d2c8b517094cb" ON "notification" ("notifieeId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "meta" ("id" character varying(32) NOT NULL, "name" character varying(128), "description" character varying(1024), "maintainerName" character varying(128), "maintainerEmail" character varying(128), "announcements" jsonb NOT NULL DEFAULT '[]', "disableRegistration" boolean NOT NULL DEFAULT false, "disableLocalTimeline" boolean NOT NULL DEFAULT false, "disableGlobalTimeline" boolean NOT NULL DEFAULT false, "enableEmojiReaction" boolean NOT NULL DEFAULT true, "useStarForReactionFallback" boolean NOT NULL DEFAULT false, "langs" character varying(64) array NOT NULL DEFAULT '{}'::varchar[], "hiddenTags" character varying(256) array NOT NULL DEFAULT '{}'::varchar[], "blockedHosts" character varying(256) array NOT NULL DEFAULT '{}'::varchar[], "mascotImageUrl" character varying(512) DEFAULT '/assets/ai.png', "bannerUrl" character varying(512), "errorImageUrl" character varying(512) DEFAULT 'https://xn--931a.moe/aiart/yubitun.png', "iconUrl" character varying(512), "cacheRemoteFiles" boolean NOT NULL DEFAULT true, "proxyAccount" character varying(128), "enableRecaptcha" boolean NOT NULL DEFAULT false, "recaptchaSiteKey" character varying(64), "recaptchaSecretKey" character varying(64), "localDriveCapacityMb" integer NOT NULL DEFAULT 1024, "remoteDriveCapacityMb" integer NOT NULL DEFAULT 32, "maxNoteTextLength" integer NOT NULL DEFAULT 500, "summalyProxy" character varying(128), "enableEmail" boolean NOT NULL DEFAULT false, "email" character varying(128), "smtpSecure" boolean NOT NULL DEFAULT false, "smtpHost" character varying(128), "smtpPort" integer, "smtpUser" character varying(128), "smtpPass" character varying(128), "enableServiceWorker" boolean NOT NULL DEFAULT false, "swPublicKey" character varying(128), "swPrivateKey" character varying(128), "enableTwitterIntegration" boolean NOT NULL DEFAULT false, "twitterConsumerKey" character varying(128), "twitterConsumerSecret" character varying(128), "enableGithubIntegration" boolean NOT NULL DEFAULT false, "githubClientId" character varying(128), "githubClientSecret" character varying(128), "enableDiscordIntegration" boolean NOT NULL DEFAULT false, "discordClientId" character varying(128), "discordClientSecret" character varying(128), CONSTRAINT "PK_c4c17a6c2bd7651338b60fc590b" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "following" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "followeeId" character varying(32) NOT NULL, "followerId" character varying(32) NOT NULL, "followerHost" character varying(128), "followerInbox" character varying(512), "followerSharedInbox" character varying(512), "followeeHost" character varying(128), "followeeInbox" character varying(512), "followeeSharedInbox" character varying(512), CONSTRAINT "PK_c76c6e044bdf76ecf8bfb82a645" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_582f8fab771a9040a12961f3e7" ON "following" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_24e0042143a18157b234df186c" ON "following" ("followeeId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_6516c5a6f3c015b4eed39978be" ON "following" ("followerId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_307be5f1d1252e0388662acb96" ON "following" ("followerId", "followeeId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "instance" ("id" character varying(32) NOT NULL, "caughtAt" TIMESTAMP WITH TIME ZONE NOT NULL, "host" character varying(128) NOT NULL, "system" character varying(64), "usersCount" integer NOT NULL DEFAULT 0, "notesCount" integer NOT NULL DEFAULT 0, "followingCount" integer NOT NULL DEFAULT 0, "followersCount" integer NOT NULL DEFAULT 0, "driveUsage" integer NOT NULL DEFAULT 0, "driveFiles" integer NOT NULL DEFAULT 0, "latestRequestSentAt" TIMESTAMP WITH TIME ZONE, "latestStatus" integer, "latestRequestReceivedAt" TIMESTAMP WITH TIME ZONE, "lastCommunicatedAt" TIMESTAMP WITH TIME ZONE NOT NULL, "isNotResponding" boolean NOT NULL DEFAULT false, "isMarkedAsClosed" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_eaf60e4a0c399c9935413e06474" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2cd3b2a6b4cf0b910b260afe08" ON "instance" ("caughtAt") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_8d5afc98982185799b160e10eb" ON "instance" ("host") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "muting" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "muteeId" character varying(32) NOT NULL, "muterId" character varying(32) NOT NULL, CONSTRAINT "PK_2e92d06c8b5c602eeb27ca9ba48" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f86d57fbca33c7a4e6897490cc" ON "muting" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_ec96b4fed9dae517e0dbbe0675" ON "muting" ("muteeId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_93060675b4a79a577f31d260c6" ON "muting" ("muterId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_1eb9d9824a630321a29fd3b290" ON "muting" ("muterId", "muteeId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "sw_subscription" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "endpoint" character varying(512) NOT NULL, "auth" character varying(256) NOT NULL, "publickey" character varying(128) NOT NULL, CONSTRAINT "PK_e8f763631530051b95eb6279b91" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_97754ca6f2baff9b4abb7f853d" ON "sw_subscription" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "blocking" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "blockeeId" character varying(32) NOT NULL, "blockerId" character varying(32) NOT NULL, CONSTRAINT "PK_e5d9a541cc1965ee7e048ea09dd" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b9a354f7941c1e779f3b33aea6" ON "blocking" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2cd4a2743a99671308f5417759" ON "blocking" ("blockeeId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0627125f1a8a42c9a1929edb55" ON "blocking" ("blockerId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_98a1bc5cb30dfd159de056549f" ON "blocking" ("blockerId", "blockeeId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_list" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "name" character varying(128) NOT NULL, CONSTRAINT "PK_87bab75775fd9b1ff822b656402" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b7fcefbdd1c18dce86687531f9" ON "user_list" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_list_joining" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "userListId" character varying(32) NOT NULL, CONSTRAINT "PK_11abb3768da1c5f8de101c9df45" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_d844bfc6f3f523a05189076efa" ON "user_list_joining" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_605472305f26818cc93d1baaa7" ON "user_list_joining" ("userListId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "hashtag" ("id" character varying(32) NOT NULL, "name" character varying(128) NOT NULL, "mentionedUserIds" character varying(32) array NOT NULL, "mentionedUsersCount" integer NOT NULL DEFAULT 0, "mentionedLocalUserIds" character varying(32) array NOT NULL, "mentionedLocalUsersCount" integer NOT NULL DEFAULT 0, "mentionedRemoteUserIds" character varying(32) array NOT NULL, "mentionedRemoteUsersCount" integer NOT NULL DEFAULT 0, "attachedUserIds" character varying(32) array NOT NULL, "attachedUsersCount" integer NOT NULL DEFAULT 0, "attachedLocalUserIds" character varying(32) array NOT NULL, "attachedLocalUsersCount" integer NOT NULL DEFAULT 0, "attachedRemoteUserIds" character varying(32) array NOT NULL, "attachedRemoteUsersCount" integer NOT NULL DEFAULT 0, CONSTRAINT "PK_cb36eb8af8412bfa978f1165d78" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_347fec870eafea7b26c8a73bac" ON "hashtag" ("name") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2710a55f826ee236ea1a62698f" ON "hashtag" ("mentionedUsersCount") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0e206cec573f1edff4a3062923" ON "hashtag" ("mentionedLocalUsersCount") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_4c02d38a976c3ae132228c6fce" ON "hashtag" ("mentionedRemoteUsersCount") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_d57f9030cd3af7f63ffb1c267c" ON "hashtag" ("attachedUsersCount") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0c44bf4f680964145f2a68a341" ON "hashtag" ("attachedLocalUsersCount") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0b03cbcd7e6a7ce068efa8ecc2" ON "hashtag" ("attachedRemoteUsersCount") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "note_favorite" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, CONSTRAINT "PK_af0da35a60b9fa4463a62082b36" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_47f4b1892f5d6ba8efb3057d81" ON "note_favorite" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_0f4fb9ad355f3effff221ef245" ON "note_favorite" ("userId", "noteId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "abuse_user_report" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "reporterId" character varying(32) NOT NULL, "comment" character varying(512) NOT NULL, CONSTRAINT "PK_87873f5f5cc5c321a1306b2d18c" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_db2098070b2b5a523c58181f74" ON "abuse_user_report" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_d049123c413e68ca52abe73420" ON "abuse_user_report" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_04cc96756f89d0b7f9473e8cdf" ON "abuse_user_report" ("reporterId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_5cd442c3b2e74fdd99dae20243" ON "abuse_user_report" ("userId", "reporterId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "registration_ticket" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "code" character varying(64) NOT NULL, CONSTRAINT "PK_f11696b6fafcf3662d4292734f8" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_0ff69e8dfa9fe31bb4a4660f59" ON "registration_ticket" ("code") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "messaging_message" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "recipientId" character varying(32) NOT NULL, "text" character varying(4096), "isRead" boolean NOT NULL DEFAULT false, "fileId" character varying(32), CONSTRAINT "PK_db398fd79dc95d0eb8c30456eaa" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e21cd3646e52ef9c94aaf17c2e" ON "messaging_message" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_5377c307783fce2b6d352e1203" ON "messaging_message" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_cac14a4e3944454a5ce7daa514" ON "messaging_message" ("recipientId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "signin" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "ip" character varying(128) NOT NULL, "headers" jsonb NOT NULL, "success" boolean NOT NULL, CONSTRAINT "PK_9e96ddc025712616fc492b3b588" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2c308dbdc50d94dc625670055f" ON "signin" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "auth_session" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "token" character varying(128) NOT NULL, "userId" character varying(32), "appId" character varying(32) NOT NULL, CONSTRAINT "PK_19354ed146424a728c1112a8cbf" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_62cb09e1129f6ec024ef66e183" ON "auth_session" ("token") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "follow_request" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "followeeId" character varying(32) NOT NULL, "followerId" character varying(32) NOT NULL, "requestId" character varying(128), "followerHost" character varying(128), "followerInbox" character varying(512), "followerSharedInbox" character varying(512), "followeeHost" character varying(128), "followeeInbox" character varying(512), "followeeSharedInbox" character varying(512), CONSTRAINT "PK_53a9aa3725f7a3deb150b39dbfc" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_12c01c0d1a79f77d9f6c15fadd" ON "follow_request" ("followeeId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a7fd92dd6dc519e6fb435dd108" ON "follow_request" ("followerId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_d54a512b822fac7ed52800f6b4" ON "follow_request" ("followerId", "followeeId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "emoji" ("id" character varying(32) NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE, "name" character varying(128) NOT NULL, "host" character varying(128), "url" character varying(512) NOT NULL, "uri" character varying(512), "type" character varying(64), "aliases" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], CONSTRAINT "PK_df74ce05e24999ee01ea0bc50a3" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b37dafc86e9af007e3295c2781" ON "emoji" ("name") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_5900e907bb46516ddf2871327c" ON "emoji" ("host") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_4f4d35e1256c84ae3d1f0eab10" ON "emoji" ("name", "host") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "reversi_game" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "startedAt" TIMESTAMP WITH TIME ZONE, "user1Id" character varying(32) NOT NULL, "user2Id" character varying(32) NOT NULL, "user1Accepted" boolean NOT NULL DEFAULT false, "user2Accepted" boolean NOT NULL DEFAULT false, "black" integer, "isStarted" boolean NOT NULL DEFAULT false, "isEnded" boolean NOT NULL DEFAULT false, "winnerId" character varying(32), "surrendered" character varying(32), "logs" jsonb NOT NULL DEFAULT '[]', "map" character varying(64) array NOT NULL, "bw" character varying(32) NOT NULL, "isLlotheo" boolean NOT NULL DEFAULT false, "canPutEverywhere" boolean NOT NULL DEFAULT false, "loopedBoard" boolean NOT NULL DEFAULT false, "form1" jsonb DEFAULT null, "form2" jsonb DEFAULT null, "crc32" character varying(32), CONSTRAINT "PK_76b30eeba71b1193ad7c5311c3f" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b46ec40746efceac604142be1c" ON "reversi_game" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "reversi_matching" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "parentId" character varying(32) NOT NULL, "childId" character varying(32) NOT NULL, CONSTRAINT "PK_880bd0afbab232f21c8b9d146cf" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b604d92d6c7aec38627f6eaf16" ON "reversi_matching" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3b25402709dd9882048c2bbade" ON "reversi_matching" ("parentId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e247b23a3c9b45f89ec1299d06" ON "reversi_matching" ("childId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_note_pining" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, CONSTRAINT "PK_a6a2dad4ae000abce2ea9d9b103" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_bfbc6f79ba4007b4ce5097f08d" ON "user_note_pining" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_410cd649884b501c02d6e72738" ON "user_note_pining" ("userId", "noteId") `);
|
|
||||||
await queryRunner.query(`CREATE TYPE "poll_notevisibility_enum" AS ENUM('public', 'home', 'followers', 'specified')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "poll" ("noteId" character varying(32) NOT NULL, "expiresAt" TIMESTAMP WITH TIME ZONE, "multiple" boolean NOT NULL, "choices" character varying(128) array NOT NULL DEFAULT '{}'::varchar[], "votes" integer array NOT NULL, "noteVisibility" "poll_notevisibility_enum" NOT NULL, "userId" character varying(32) NOT NULL, "userHost" character varying(128), CONSTRAINT "REL_da851e06d0dfe2ef397d8b1bf1" UNIQUE ("noteId"), CONSTRAINT "PK_da851e06d0dfe2ef397d8b1bf1b" PRIMARY KEY ("noteId"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0610ebcfcfb4a18441a9bcdab2" ON "poll" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7fa20a12319c7f6dc3aed98c0a" ON "poll" ("userHost") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_keypair" ("userId" character varying(32) NOT NULL, "publicKey" character varying(4096) NOT NULL, "privateKey" character varying(4096) NOT NULL, CONSTRAINT "REL_f4853eb41ab722fe05f81cedeb" UNIQUE ("userId"), CONSTRAINT "PK_f4853eb41ab722fe05f81cedeb6" PRIMARY KEY ("userId"))`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_publickey" ("userId" character varying(32) NOT NULL, "keyId" character varying(256) NOT NULL, "keyPem" character varying(4096) NOT NULL, CONSTRAINT "REL_10c146e4b39b443ede016f6736" UNIQUE ("userId"), CONSTRAINT "PK_10c146e4b39b443ede016f6736d" PRIMARY KEY ("userId"))`);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_171e64971c780ebd23fae140bb" ON "user_publickey" ("keyId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_profile" ("userId" character varying(32) NOT NULL, "location" character varying(128), "birthday" character(10), "description" character varying(1024), "fields" jsonb NOT NULL DEFAULT '[]', "url" character varying(512), "email" character varying(128), "emailVerifyCode" character varying(128), "emailVerified" boolean NOT NULL DEFAULT false, "twoFactorTempSecret" character varying(128), "twoFactorSecret" character varying(128), "twoFactorEnabled" boolean NOT NULL DEFAULT false, "password" character varying(128), "clientData" jsonb NOT NULL DEFAULT '{}', "autoWatch" boolean NOT NULL DEFAULT false, "autoAcceptFollowed" boolean NOT NULL DEFAULT false, "alwaysMarkNsfw" boolean NOT NULL DEFAULT false, "carefulBot" boolean NOT NULL DEFAULT false, "twitter" boolean NOT NULL DEFAULT false, "twitterAccessToken" character varying(64) DEFAULT null, "twitterAccessTokenSecret" character varying(64) DEFAULT null, "twitterUserId" character varying(64) DEFAULT null, "twitterScreenName" character varying(64) DEFAULT null, "github" boolean NOT NULL DEFAULT false, "githubAccessToken" character varying(64) DEFAULT null, "githubId" integer DEFAULT null, "githubLogin" character varying(64) DEFAULT null, "discord" boolean NOT NULL DEFAULT false, "discordAccessToken" character varying(64) DEFAULT null, "discordRefreshToken" character varying(64) DEFAULT null, "discordExpiresDate" integer DEFAULT null, "discordId" character varying(64) DEFAULT null, "discordUsername" character varying(64) DEFAULT null, "discordDiscriminator" character varying(64) DEFAULT null, "userHost" character varying(128), CONSTRAINT "REL_51cb79b5555effaf7d69ba1cff" UNIQUE ("userId"), CONSTRAINT "PK_51cb79b5555effaf7d69ba1cff9" PRIMARY KEY ("userId"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_dce530b98e454793dac5ec2f5a" ON "user_profile" ("userHost") `);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__active_users_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__active_users" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__active_users_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_count" bigint NOT NULL, "___remote_count" bigint NOT NULL, CONSTRAINT "PK_317237a9f733b970604a11e314f" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__drive_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__drive" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__drive_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_totalCount" bigint NOT NULL, "___local_totalSize" bigint NOT NULL, "___local_incCount" bigint NOT NULL, "___local_incSize" bigint NOT NULL, "___local_decCount" bigint NOT NULL, "___local_decSize" bigint NOT NULL, "___remote_totalCount" bigint NOT NULL, "___remote_totalSize" bigint NOT NULL, "___remote_incCount" bigint NOT NULL, "___remote_incSize" bigint NOT NULL, "___remote_decCount" bigint NOT NULL, "___remote_decSize" bigint NOT NULL, CONSTRAINT "PK_f96bc548a765cd4b3b354221ce7" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__federation_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__federation" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__federation_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___instance_total" bigint NOT NULL, "___instance_inc" bigint NOT NULL, "___instance_dec" bigint NOT NULL, CONSTRAINT "PK_b39dcd31a0fe1a7757e348e85fd" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__hashtag_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__hashtag" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__hashtag_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_count" bigint NOT NULL, "___remote_count" bigint NOT NULL, CONSTRAINT "PK_c32f1ea2b44a5d2f7881e37f8f9" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__instance_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__instance" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__instance_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___requests_failed" bigint NOT NULL, "___requests_succeeded" bigint NOT NULL, "___requests_received" bigint NOT NULL, "___notes_total" bigint NOT NULL, "___notes_inc" bigint NOT NULL, "___notes_dec" bigint NOT NULL, "___notes_diffs_normal" bigint NOT NULL, "___notes_diffs_reply" bigint NOT NULL, "___notes_diffs_renote" bigint NOT NULL, "___users_total" bigint NOT NULL, "___users_inc" bigint NOT NULL, "___users_dec" bigint NOT NULL, "___following_total" bigint NOT NULL, "___following_inc" bigint NOT NULL, "___following_dec" bigint NOT NULL, "___followers_total" bigint NOT NULL, "___followers_inc" bigint NOT NULL, "___followers_dec" bigint NOT NULL, "___drive_totalFiles" bigint NOT NULL, "___drive_totalUsage" bigint NOT NULL, "___drive_incFiles" bigint NOT NULL, "___drive_incUsage" bigint NOT NULL, "___drive_decFiles" bigint NOT NULL, "___drive_decUsage" bigint NOT NULL, CONSTRAINT "PK_1267c67c7c2d47b4903975f2c00" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__network_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__network" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__network_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___incomingRequests" bigint NOT NULL, "___outgoingRequests" bigint NOT NULL, "___totalTime" bigint NOT NULL, "___incomingBytes" bigint NOT NULL, "___outgoingBytes" bigint NOT NULL, CONSTRAINT "PK_bc4290c2e27fad14ef0c1ca93f3" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__notes_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__notes" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__notes_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_total" bigint NOT NULL, "___local_inc" bigint NOT NULL, "___local_dec" bigint NOT NULL, "___local_diffs_normal" bigint NOT NULL, "___local_diffs_reply" bigint NOT NULL, "___local_diffs_renote" bigint NOT NULL, "___remote_total" bigint NOT NULL, "___remote_inc" bigint NOT NULL, "___remote_dec" bigint NOT NULL, "___remote_diffs_normal" bigint NOT NULL, "___remote_diffs_reply" bigint NOT NULL, "___remote_diffs_renote" bigint NOT NULL, CONSTRAINT "PK_0aec823fa85c7f901bdb3863b14" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__per_user_drive_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__per_user_drive" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__per_user_drive_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___totalCount" bigint NOT NULL, "___totalSize" bigint NOT NULL, "___incCount" bigint NOT NULL, "___incSize" bigint NOT NULL, "___decCount" bigint NOT NULL, "___decSize" bigint NOT NULL, CONSTRAINT "PK_d0ef23d24d666e1a44a0cd3d208" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__per_user_following_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__per_user_following" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__per_user_following_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_followings_total" bigint NOT NULL, "___local_followings_inc" bigint NOT NULL, "___local_followings_dec" bigint NOT NULL, "___local_followers_total" bigint NOT NULL, "___local_followers_inc" bigint NOT NULL, "___local_followers_dec" bigint NOT NULL, "___remote_followings_total" bigint NOT NULL, "___remote_followings_inc" bigint NOT NULL, "___remote_followings_dec" bigint NOT NULL, "___remote_followers_total" bigint NOT NULL, "___remote_followers_inc" bigint NOT NULL, "___remote_followers_dec" bigint NOT NULL, CONSTRAINT "PK_85bb1b540363a29c2fec83bd907" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__per_user_notes_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__per_user_notes" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__per_user_notes_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___total" bigint NOT NULL, "___inc" bigint NOT NULL, "___dec" bigint NOT NULL, "___diffs_normal" bigint NOT NULL, "___diffs_reply" bigint NOT NULL, "___diffs_renote" bigint NOT NULL, CONSTRAINT "PK_334acf6e915af2f29edc11b8e50" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__per_user_reaction_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__per_user_reaction" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__per_user_reaction_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_count" bigint NOT NULL, "___remote_count" bigint NOT NULL, CONSTRAINT "PK_984f54dae441e65b633e8d27a7f" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__test_grouped_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__test_grouped" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__test_grouped_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___foo_total" bigint NOT NULL, "___foo_inc" bigint NOT NULL, "___foo_dec" bigint NOT NULL, CONSTRAINT "PK_f4a2b175d308695af30d4293272" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__test_unique_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__test_unique" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__test_unique_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___foo" bigint NOT NULL, CONSTRAINT "PK_409bac9c97cc612d8500012319d" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__test_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__test" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__test_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___foo_total" bigint NOT NULL, "___foo_inc" bigint NOT NULL, "___foo_dec" bigint NOT NULL, CONSTRAINT "PK_b4bc31dffbd1b785276a3ecfc1e" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE TYPE "__chart__users_span_enum" AS ENUM('hour', 'day')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "__chart__users" ("id" SERIAL NOT NULL, "date" integer NOT NULL, "group" character varying(128), "span" "__chart__users_span_enum" NOT NULL, "unique" jsonb NOT NULL DEFAULT '{}', "___local_total" bigint NOT NULL, "___local_inc" bigint NOT NULL, "___local_dec" bigint NOT NULL, "___remote_total" bigint NOT NULL, "___remote_inc" bigint NOT NULL, "___remote_dec" bigint NOT NULL, CONSTRAINT "PK_4dfcf2c78d03524b9eb2c99d328" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_folder" ADD CONSTRAINT "FK_f4fc06e49c0171c85f1c48060d2" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_folder" ADD CONSTRAINT "FK_00ceffb0cdc238b3233294f08f2" FOREIGN KEY ("parentId") REFERENCES "drive_folder"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_file" ADD CONSTRAINT "FK_860fa6f6c7df5bb887249fba22e" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_file" ADD CONSTRAINT "FK_bb90d1956dafc4068c28aa7560a" FOREIGN KEY ("folderId") REFERENCES "drive_folder"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user" ADD CONSTRAINT "FK_58f5c71eaab331645112cf8cfa5" FOREIGN KEY ("avatarId") REFERENCES "drive_file"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user" ADD CONSTRAINT "FK_afc64b53f8db3707ceb34eb28e2" FOREIGN KEY ("bannerId") REFERENCES "drive_file"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "app" ADD CONSTRAINT "FK_3f5b0899ef90527a3462d7c2cb3" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "access_token" ADD CONSTRAINT "FK_9949557d0e1b2c19e5344c171e9" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "access_token" ADD CONSTRAINT "FK_a3ff16c90cc87a82a0b5959e560" FOREIGN KEY ("appId") REFERENCES "app"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_17cb3553c700a4985dff5a30ff5" FOREIGN KEY ("replyId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_52ccc804d7c69037d558bac4c96" FOREIGN KEY ("renoteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_ec5c201576192ba8904c345c5cc" FOREIGN KEY ("appId") REFERENCES "app"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_5b87d9d19127bd5d92026017a7b" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "poll_vote" ADD CONSTRAINT "FK_66d2bd2ee31d14bcc23069a89f8" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "poll_vote" ADD CONSTRAINT "FK_aecfbd5ef60374918e63ee95fa7" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_reaction" ADD CONSTRAINT "FK_13761f64257f40c5636d0ff95ee" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_reaction" ADD CONSTRAINT "FK_45145e4953780f3cd5656f0ea6a" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_watching" ADD CONSTRAINT "FK_b0134ec406e8d09a540f8182888" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_watching" ADD CONSTRAINT "FK_03e7028ab8388a3f5e3ce2a8619" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_unread" ADD CONSTRAINT "FK_56b0166d34ddae49d8ef7610bb9" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_unread" ADD CONSTRAINT "FK_e637cba4dc4410218c4251260e4" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_3c601b70a1066d2c8b517094cb9" FOREIGN KEY ("notifieeId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_3b4e96eec8d36a8bbb9d02aa710" FOREIGN KEY ("notifierId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_769cb6b73a1efe22ddf733ac453" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "following" ADD CONSTRAINT "FK_24e0042143a18157b234df186c3" FOREIGN KEY ("followeeId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "following" ADD CONSTRAINT "FK_6516c5a6f3c015b4eed39978be5" FOREIGN KEY ("followerId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "muting" ADD CONSTRAINT "FK_ec96b4fed9dae517e0dbbe0675c" FOREIGN KEY ("muteeId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "muting" ADD CONSTRAINT "FK_93060675b4a79a577f31d260c67" FOREIGN KEY ("muterId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "sw_subscription" ADD CONSTRAINT "FK_97754ca6f2baff9b4abb7f853dd" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "blocking" ADD CONSTRAINT "FK_2cd4a2743a99671308f5417759e" FOREIGN KEY ("blockeeId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "blocking" ADD CONSTRAINT "FK_0627125f1a8a42c9a1929edb552" FOREIGN KEY ("blockerId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_list" ADD CONSTRAINT "FK_b7fcefbdd1c18dce86687531f99" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_list_joining" ADD CONSTRAINT "FK_d844bfc6f3f523a05189076efaa" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_list_joining" ADD CONSTRAINT "FK_605472305f26818cc93d1baaa74" FOREIGN KEY ("userListId") REFERENCES "user_list"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_favorite" ADD CONSTRAINT "FK_47f4b1892f5d6ba8efb3057d81a" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_favorite" ADD CONSTRAINT "FK_0e00498f180193423c992bc4370" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD CONSTRAINT "FK_d049123c413e68ca52abe734203" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD CONSTRAINT "FK_04cc96756f89d0b7f9473e8cdf3" FOREIGN KEY ("reporterId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD CONSTRAINT "FK_5377c307783fce2b6d352e1203b" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD CONSTRAINT "FK_cac14a4e3944454a5ce7daa5142" FOREIGN KEY ("recipientId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD CONSTRAINT "FK_535def119223ac05ad3fa9ef64b" FOREIGN KEY ("fileId") REFERENCES "drive_file"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "signin" ADD CONSTRAINT "FK_2c308dbdc50d94dc625670055f7" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "auth_session" ADD CONSTRAINT "FK_c072b729d71697f959bde66ade0" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "auth_session" ADD CONSTRAINT "FK_dbe037d4bddd17b03a1dc778dee" FOREIGN KEY ("appId") REFERENCES "app"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "follow_request" ADD CONSTRAINT "FK_12c01c0d1a79f77d9f6c15fadd2" FOREIGN KEY ("followeeId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "follow_request" ADD CONSTRAINT "FK_a7fd92dd6dc519e6fb435dd108f" FOREIGN KEY ("followerId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_game" ADD CONSTRAINT "FK_f7467510c60a45ce5aca6292743" FOREIGN KEY ("user1Id") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_game" ADD CONSTRAINT "FK_6649a4e8c5d5cf32fb03b5da9f6" FOREIGN KEY ("user2Id") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_matching" ADD CONSTRAINT "FK_3b25402709dd9882048c2bbade0" FOREIGN KEY ("parentId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_matching" ADD CONSTRAINT "FK_e247b23a3c9b45f89ec1299d066" FOREIGN KEY ("childId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_note_pining" ADD CONSTRAINT "FK_bfbc6f79ba4007b4ce5097f08d6" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_note_pining" ADD CONSTRAINT "FK_68881008f7c3588ad7ecae471cf" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "poll" ADD CONSTRAINT "FK_da851e06d0dfe2ef397d8b1bf1b" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_keypair" ADD CONSTRAINT "FK_f4853eb41ab722fe05f81cedeb6" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_publickey" ADD CONSTRAINT "FK_10c146e4b39b443ede016f6736d" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD CONSTRAINT "FK_51cb79b5555effaf7d69ba1cff9" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP CONSTRAINT "FK_51cb79b5555effaf7d69ba1cff9"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_publickey" DROP CONSTRAINT "FK_10c146e4b39b443ede016f6736d"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_keypair" DROP CONSTRAINT "FK_f4853eb41ab722fe05f81cedeb6"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "poll" DROP CONSTRAINT "FK_da851e06d0dfe2ef397d8b1bf1b"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_note_pining" DROP CONSTRAINT "FK_68881008f7c3588ad7ecae471cf"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_note_pining" DROP CONSTRAINT "FK_bfbc6f79ba4007b4ce5097f08d6"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_matching" DROP CONSTRAINT "FK_e247b23a3c9b45f89ec1299d066"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_matching" DROP CONSTRAINT "FK_3b25402709dd9882048c2bbade0"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_game" DROP CONSTRAINT "FK_6649a4e8c5d5cf32fb03b5da9f6"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "reversi_game" DROP CONSTRAINT "FK_f7467510c60a45ce5aca6292743"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "follow_request" DROP CONSTRAINT "FK_a7fd92dd6dc519e6fb435dd108f"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "follow_request" DROP CONSTRAINT "FK_12c01c0d1a79f77d9f6c15fadd2"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "auth_session" DROP CONSTRAINT "FK_dbe037d4bddd17b03a1dc778dee"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "auth_session" DROP CONSTRAINT "FK_c072b729d71697f959bde66ade0"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "signin" DROP CONSTRAINT "FK_2c308dbdc50d94dc625670055f7"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP CONSTRAINT "FK_535def119223ac05ad3fa9ef64b"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP CONSTRAINT "FK_cac14a4e3944454a5ce7daa5142"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP CONSTRAINT "FK_5377c307783fce2b6d352e1203b"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP CONSTRAINT "FK_04cc96756f89d0b7f9473e8cdf3"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP CONSTRAINT "FK_d049123c413e68ca52abe734203"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_favorite" DROP CONSTRAINT "FK_0e00498f180193423c992bc4370"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_favorite" DROP CONSTRAINT "FK_47f4b1892f5d6ba8efb3057d81a"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_list_joining" DROP CONSTRAINT "FK_605472305f26818cc93d1baaa74"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_list_joining" DROP CONSTRAINT "FK_d844bfc6f3f523a05189076efaa"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_list" DROP CONSTRAINT "FK_b7fcefbdd1c18dce86687531f99"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "blocking" DROP CONSTRAINT "FK_0627125f1a8a42c9a1929edb552"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "blocking" DROP CONSTRAINT "FK_2cd4a2743a99671308f5417759e"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "sw_subscription" DROP CONSTRAINT "FK_97754ca6f2baff9b4abb7f853dd"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "muting" DROP CONSTRAINT "FK_93060675b4a79a577f31d260c67"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "muting" DROP CONSTRAINT "FK_ec96b4fed9dae517e0dbbe0675c"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "following" DROP CONSTRAINT "FK_6516c5a6f3c015b4eed39978be5"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "following" DROP CONSTRAINT "FK_24e0042143a18157b234df186c3"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" DROP CONSTRAINT "FK_769cb6b73a1efe22ddf733ac453"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" DROP CONSTRAINT "FK_3b4e96eec8d36a8bbb9d02aa710"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" DROP CONSTRAINT "FK_3c601b70a1066d2c8b517094cb9"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_unread" DROP CONSTRAINT "FK_e637cba4dc4410218c4251260e4"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_unread" DROP CONSTRAINT "FK_56b0166d34ddae49d8ef7610bb9"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_watching" DROP CONSTRAINT "FK_03e7028ab8388a3f5e3ce2a8619"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_watching" DROP CONSTRAINT "FK_b0134ec406e8d09a540f8182888"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_reaction" DROP CONSTRAINT "FK_45145e4953780f3cd5656f0ea6a"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note_reaction" DROP CONSTRAINT "FK_13761f64257f40c5636d0ff95ee"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "poll_vote" DROP CONSTRAINT "FK_aecfbd5ef60374918e63ee95fa7"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "poll_vote" DROP CONSTRAINT "FK_66d2bd2ee31d14bcc23069a89f8"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_5b87d9d19127bd5d92026017a7b"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_ec5c201576192ba8904c345c5cc"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_52ccc804d7c69037d558bac4c96"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_17cb3553c700a4985dff5a30ff5"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "access_token" DROP CONSTRAINT "FK_a3ff16c90cc87a82a0b5959e560"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "access_token" DROP CONSTRAINT "FK_9949557d0e1b2c19e5344c171e9"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "app" DROP CONSTRAINT "FK_3f5b0899ef90527a3462d7c2cb3"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user" DROP CONSTRAINT "FK_afc64b53f8db3707ceb34eb28e2"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user" DROP CONSTRAINT "FK_58f5c71eaab331645112cf8cfa5"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_file" DROP CONSTRAINT "FK_bb90d1956dafc4068c28aa7560a"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_file" DROP CONSTRAINT "FK_860fa6f6c7df5bb887249fba22e"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_folder" DROP CONSTRAINT "FK_00ceffb0cdc238b3233294f08f2"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "drive_folder" DROP CONSTRAINT "FK_f4fc06e49c0171c85f1c48060d2"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__users"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__users_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__test"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__test_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__test_unique"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__test_unique_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__test_grouped"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__test_grouped_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__per_user_reaction"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__per_user_reaction_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__per_user_notes"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__per_user_notes_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__per_user_following"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__per_user_following_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__per_user_drive"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__per_user_drive_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__notes"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__notes_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__network"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__network_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__instance"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__instance_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__hashtag"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__hashtag_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__federation"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__federation_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__drive"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__drive_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "__chart__active_users"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "__chart__active_users_span_enum"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_dce530b98e454793dac5ec2f5a"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_profile"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_171e64971c780ebd23fae140bb"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_publickey"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_keypair"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7fa20a12319c7f6dc3aed98c0a"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0610ebcfcfb4a18441a9bcdab2"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "poll"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "poll_notevisibility_enum"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_410cd649884b501c02d6e72738"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_bfbc6f79ba4007b4ce5097f08d"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_note_pining"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e247b23a3c9b45f89ec1299d06"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3b25402709dd9882048c2bbade"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b604d92d6c7aec38627f6eaf16"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "reversi_matching"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b46ec40746efceac604142be1c"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "reversi_game"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_4f4d35e1256c84ae3d1f0eab10"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5900e907bb46516ddf2871327c"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b37dafc86e9af007e3295c2781"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "emoji"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d54a512b822fac7ed52800f6b4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a7fd92dd6dc519e6fb435dd108"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_12c01c0d1a79f77d9f6c15fadd"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "follow_request"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_62cb09e1129f6ec024ef66e183"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "auth_session"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2c308dbdc50d94dc625670055f"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "signin"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_cac14a4e3944454a5ce7daa514"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5377c307783fce2b6d352e1203"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e21cd3646e52ef9c94aaf17c2e"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "messaging_message"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0ff69e8dfa9fe31bb4a4660f59"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "registration_ticket"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5cd442c3b2e74fdd99dae20243"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_04cc96756f89d0b7f9473e8cdf"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d049123c413e68ca52abe73420"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_db2098070b2b5a523c58181f74"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "abuse_user_report"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0f4fb9ad355f3effff221ef245"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_47f4b1892f5d6ba8efb3057d81"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "note_favorite"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0b03cbcd7e6a7ce068efa8ecc2"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0c44bf4f680964145f2a68a341"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d57f9030cd3af7f63ffb1c267c"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_4c02d38a976c3ae132228c6fce"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0e206cec573f1edff4a3062923"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2710a55f826ee236ea1a62698f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_347fec870eafea7b26c8a73bac"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "hashtag"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_605472305f26818cc93d1baaa7"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d844bfc6f3f523a05189076efa"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_list_joining"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b7fcefbdd1c18dce86687531f9"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_list"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_98a1bc5cb30dfd159de056549f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0627125f1a8a42c9a1929edb55"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2cd4a2743a99671308f5417759"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b9a354f7941c1e779f3b33aea6"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "blocking"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_97754ca6f2baff9b4abb7f853d"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "sw_subscription"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_1eb9d9824a630321a29fd3b290"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_93060675b4a79a577f31d260c6"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_ec96b4fed9dae517e0dbbe0675"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f86d57fbca33c7a4e6897490cc"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "muting"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8d5afc98982185799b160e10eb"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2cd3b2a6b4cf0b910b260afe08"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "instance"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_307be5f1d1252e0388662acb96"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_6516c5a6f3c015b4eed39978be"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_24e0042143a18157b234df186c"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_582f8fab771a9040a12961f3e7"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "following"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "meta"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3c601b70a1066d2c8b517094cb"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b11a5e627c41d4dc3170f1d370"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "notification"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d908433a4953cc13216cd9c274"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e637cba4dc4410218c4251260e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_56b0166d34ddae49d8ef7610bb"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "note_unread"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a42c93c69989ce1d09959df4cf"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_44499765eec6b5489d72c4253b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_03e7028ab8388a3f5e3ce2a861"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b0134ec406e8d09a540f818288"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_318cdf42a9cfc11f479bd802bb"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "note_watching"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_ad0c221b25672daf2df320a817"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_45145e4953780f3cd5656f0ea6"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_13761f64257f40c5636d0ff95e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_01f4581f114e0ebd2bbb876f0b"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "note_reaction"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_50bd7164c5b78f1f4a42c4d21f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_aecfbd5ef60374918e63ee95fa"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_66d2bd2ee31d14bcc23069a89f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0fb627e1c2f753262a74f0562d"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "poll_vote"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7125a826ab192eb27e11d358a5"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_88937d94d7443d9a99a76fa5c0"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_54ebcb6d27222913b908d56fd8"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_796a8c03959361f97dc2be1d5c"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_25dfc71b0369b003a4cd434d0b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_51c063b6a133a9cb87145450f5"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_153536c67d05e9adb24e99fc2b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5b87d9d19127bd5d92026017a7"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_52ccc804d7c69037d558bac4c9"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_17cb3553c700a4985dff5a30ff"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e7c0567f5261063592f022e9b5"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "note"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "note_visibility_enum"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_9949557d0e1b2c19e5344c171e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_64c327441248bae40f7d92f34f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_70ba8f6af34bc924fc9e12adb8"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "access_token"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f49922d511d666848f250663c4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3f5b0899ef90527a3462d7c2cb"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_048a757923ed8b157e9895da53"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "app"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5deb01ae162d1d70b80d064c27"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a854e557b1b14814750c7c7b0c"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_be623adaa4c566baf5d29ce0c8"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3252a5df8d5bbd16b281f7799e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_fa99d777623947a5b05f394cae"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a27b942a0d6dcff90e3ee9b5e8"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_80ca6e6ef65fb9ef34ea8c90f4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e11e649824a45d8ed01d597fd9"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_bb90d1956dafc4068c28aa7560"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e5848eac4940934e23dbc17581"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_c55b2b7c284d9fef98026fc88e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e74022ce9a074b3866f70e0d27"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d85a184c2540d2deba33daf642"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a40b8df8c989d7db937ea27cf6"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_37bb9a1b4585f8a3beb24c62d6"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_92779627994ac79277f070c91e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_860fa6f6c7df5bb887249fba22"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_c8dfad3b72196dd1d6b5db168a"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "drive_file"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_00ceffb0cdc238b3233294f08f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f4fc06e49c0171c85f1c48060d"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_02878d441ceae15ce060b73daf"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "drive_folder"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_584b536b49e53ac81beb39a177"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8cb40cfc8f3c28261e6f887b03"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8e4eb51a35d81b64dda28eed0a"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "log"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "log_level_enum"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,31 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class Pages1556348509290 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TYPE "page_visibility_enum" AS ENUM('public', 'followers', 'specified')`);
|
|
||||||
await queryRunner.query(`CREATE TABLE "page" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL, "title" character varying(256) NOT NULL, "name" character varying(256) NOT NULL, "summary" character varying(256), "alignCenter" boolean NOT NULL, "font" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, "eyeCatchingImageId" character varying(32), "content" jsonb NOT NULL DEFAULT '[]', "variables" jsonb NOT NULL DEFAULT '[]', "visibility" "page_visibility_enum" NOT NULL, "visibleUserIds" character varying(32) array NOT NULL DEFAULT '{}'::varchar[], CONSTRAINT "PK_742f4117e065c5b6ad21b37ba1f" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_fbb4297c927a9b85e9cefa2eb1" ON "page" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_af639b066dfbca78b01a920f8a" ON "page" ("updatedAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b82c19c08afb292de4600d99e4" ON "page" ("name") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_ae1d917992dd0c9d9bbdad06c4" ON "page" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_90148bbc2bf0854428786bfc15" ON "page" ("visibleUserIds") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_2133ef8317e4bdb839c0dcbf13" ON "page" ("userId", "name") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" ADD CONSTRAINT "FK_ae1d917992dd0c9d9bbdad06c4a" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" ADD CONSTRAINT "FK_3126dd7c502c9e4d7597ef7ef10" FOREIGN KEY ("eyeCatchingImageId") REFERENCES "drive_file"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" DROP CONSTRAINT "FK_3126dd7c502c9e4d7597ef7ef10"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" DROP CONSTRAINT "FK_ae1d917992dd0c9d9bbdad06c4a"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2133ef8317e4bdb839c0dcbf13"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_90148bbc2bf0854428786bfc15"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_ae1d917992dd0c9d9bbdad06c4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b82c19c08afb292de4600d99e4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_af639b066dfbca78b01a920f8a"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_fbb4297c927a9b85e9cefa2eb1"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "page"`);
|
|
||||||
await queryRunner.query(`DROP TYPE "page_visibility_enum"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,16 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class UserProfile1556746559567 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "githubId" TYPE VARCHAR(64) USING "githubId"::VARCHAR(64)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "discordExpiresDate" TYPE VARCHAR(64) USING "discordExpiresDate"::VARCHAR(64)`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`UPDATE "user_profile" SET github = FALSE, discord = FALSE`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "githubId" TYPE INTEGER USING NULL`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ALTER COLUMN "discordExpiresDate" TYPE INTEGER USING NULL`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class PinnedUsers1557476068003 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedUsers" character varying(256) array NOT NULL DEFAULT '{}'::varchar[]`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedUsers"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,16 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class AddSomeUrls1557761316509 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "ToSUrl" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "repositoryUrl" character varying(512) NOT NULL DEFAULT 'https://github.com/misskey-dev/misskey'`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "feedbackUrl" character varying(512) DEFAULT 'https://github.com/misskey-dev/misskey/issues/new'`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "feedbackUrl"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "repositoryUrl"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "ToSUrl"`);
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,31 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class ObjectStorageSetting1557932705754 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "useObjectStorage" boolean NOT NULL DEFAULT false`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageBucket" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStoragePrefix" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageBaseUrl" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageEndpoint" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageRegion" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageAccessKey" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageSecretKey" character varying(512)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStoragePort" integer`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageUseSSL" boolean NOT NULL DEFAULT true`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageUseSSL"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStoragePort"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageSecretKey"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageAccessKey"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageRegion"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageEndpoint"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageBaseUrl"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStoragePrefix"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageBucket"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "useObjectStorage"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,23 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class PageLike1558072954435 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "page_like" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "pageId" character varying(32) NOT NULL, CONSTRAINT "PK_813f034843af992d3ae0f43c64c" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0e61efab7f88dbb79c9166dbb4" ON "page_like" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_4ce6fb9c70529b4c8ac46c9bfa" ON "page_like" ("userId", "pageId") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" ADD "likedCount" integer NOT NULL DEFAULT 0`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page_like" ADD CONSTRAINT "FK_0e61efab7f88dbb79c9166dbb48" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page_like" ADD CONSTRAINT "FK_cf8782626dced3176038176a847" FOREIGN KEY ("pageId") REFERENCES "page"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "page_like" DROP CONSTRAINT "FK_cf8782626dced3176038176a847"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page_like" DROP CONSTRAINT "FK_0e61efab7f88dbb79c9166dbb48"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" DROP COLUMN "likedCount"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_4ce6fb9c70529b4c8ac46c9bfa"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0e61efab7f88dbb79c9166dbb4"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "page_like"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,41 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class UserGroup1558103093633 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_group" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "name" character varying(256) NOT NULL, "userId" character varying(32) NOT NULL, "isPrivate" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_3c29fba6fe013ec8724378ce7c9" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_20e30aa35180e317e133d75316" ON "user_group" ("createdAt") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3d6b372788ab01be58853003c9" ON "user_group" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_group_joining" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "userGroupId" character varying(32) NOT NULL, CONSTRAINT "PK_15f2425885253c5507e1599cfe7" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f3a1b4bd0c7cabba958a0c0b23" ON "user_group_joining" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_67dc758bc0566985d1b3d39986" ON "user_group_joining" ("userGroupId") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD "groupId" character varying(32)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD "reads" character varying(32) array NOT NULL DEFAULT '{}'::varchar[]`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ALTER COLUMN "recipientId" DROP NOT NULL`);
|
|
||||||
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."recipientId" IS 'The recipient user ID.'`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2c4be03b446884f9e9c502135b" ON "messaging_message" ("groupId") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD CONSTRAINT "FK_2c4be03b446884f9e9c502135be" FOREIGN KEY ("groupId") REFERENCES "user_group"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group" ADD CONSTRAINT "FK_3d6b372788ab01be58853003c93" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_joining" ADD CONSTRAINT "FK_f3a1b4bd0c7cabba958a0c0b231" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_joining" ADD CONSTRAINT "FK_67dc758bc0566985d1b3d399865" FOREIGN KEY ("userGroupId") REFERENCES "user_group"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_joining" DROP CONSTRAINT "FK_67dc758bc0566985d1b3d399865"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_joining" DROP CONSTRAINT "FK_f3a1b4bd0c7cabba958a0c0b231"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group" DROP CONSTRAINT "FK_3d6b372788ab01be58853003c93"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP CONSTRAINT "FK_2c4be03b446884f9e9c502135be"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2c4be03b446884f9e9c502135b"`);
|
|
||||||
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."recipientId" IS ''`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ALTER COLUMN "recipientId" SET NOT NULL`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP COLUMN "reads"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP COLUMN "groupId"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_67dc758bc0566985d1b3d39986"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f3a1b4bd0c7cabba958a0c0b23"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_group_joining"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3d6b372788ab01be58853003c9"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_20e30aa35180e317e133d75316"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_group"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,25 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class UserGroupInvite1558257926829 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_group_invite" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "userGroupId" character varying(32) NOT NULL, CONSTRAINT "PK_3893884af0d3a5f4d01e7921a97" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_1039988afa3bf991185b277fe0" ON "user_group_invite" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e10924607d058004304611a436" ON "user_group_invite" ("userGroupId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_78787741f9010886796f2320a4" ON "user_group_invite" ("userId", "userGroupId") `);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_d9ecaed8c6dc43f3592c229282" ON "user_group_joining" ("userId", "userGroupId") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_invite" ADD CONSTRAINT "FK_1039988afa3bf991185b277fe03" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_invite" ADD CONSTRAINT "FK_e10924607d058004304611a436a" FOREIGN KEY ("userGroupId") REFERENCES "user_group"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_invite" DROP CONSTRAINT "FK_e10924607d058004304611a436a"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_group_invite" DROP CONSTRAINT "FK_1039988afa3bf991185b277fe03"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d9ecaed8c6dc43f3592c229282"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_78787741f9010886796f2320a4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e10924607d058004304611a436"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_1039988afa3bf991185b277fe0"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_group_invite"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class UserListJoining1558266512381 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_90f7da835e4c10aca6853621e1" ON "user_list_joining" ("userId", "userListId") `);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_90f7da835e4c10aca6853621e1"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,29 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class webauthn1561706992953 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "attestation_challenge" ("id" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, "challenge" character varying(64) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "registrationChallenge" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_d0ba6786e093f1bcb497572a6b5" PRIMARY KEY ("id", "userId"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f1a461a618fa1755692d0e0d59" ON "attestation_challenge" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_47efb914aed1f72dd39a306c7b" ON "attestation_challenge" ("challenge") `);
|
|
||||||
await queryRunner.query(`CREATE TABLE "user_security_key" ("id" character varying NOT NULL, "userId" character varying(32) NOT NULL, "publicKey" character varying NOT NULL, "lastUsed" TIMESTAMP WITH TIME ZONE NOT NULL, "name" character varying(30) NOT NULL, CONSTRAINT "PK_3e508571121ab39c5f85d10c166" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_ff9ca3b5f3ee3d0681367a9b44" ON "user_security_key" ("userId") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0d7718e562dcedd0aa5cf2c9f7" ON "user_security_key" ("publicKey") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD "securityKeysAvailable" boolean NOT NULL DEFAULT false`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "attestation_challenge" ADD CONSTRAINT "FK_f1a461a618fa1755692d0e0d592" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_security_key" ADD CONSTRAINT "FK_ff9ca3b5f3ee3d0681367a9b447" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_security_key" DROP CONSTRAINT "FK_ff9ca3b5f3ee3d0681367a9b447"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "attestation_challenge" DROP CONSTRAINT "FK_f1a461a618fa1755692d0e0d592"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "securityKeysAvailable"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0d7718e562dcedd0aa5cf2c9f7"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_ff9ca3b5f3ee3d0681367a9b44"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "user_security_key"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_47efb914aed1f72dd39a306c7b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f1a461a618fa1755692d0e0d59"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "attestation_challenge"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,201 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class ChartIndexes1561873850023 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0ad37b7ef50f4ddc84363d7ccc" ON "__chart__active_users" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_15e91a03aeeac9dbccdf43fc06" ON "__chart__active_users" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_00ed5f86db1f7efafb1978bf21" ON "__chart__active_users" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_20f57cc8f142c131340ee16742" ON "__chart__active_users" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_9a3ed15a30ab7e3a37702e6e08" ON "__chart__active_users" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_c26e2c1cbb6e911e0554b27416" ON "__chart__active_users" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_13565815f618a1ff53886c5b28" ON "__chart__drive" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3fa0d0f17ca72e3dc80999a032" ON "__chart__drive" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7a170f67425e62a8fabb76c872" ON "__chart__drive" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_6e1df243476e20cbf86572ecc0" ON "__chart__drive" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_3313d7288855ec105b5bbf6c21" ON "__chart__drive" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_06690fc959f1c9fdaf21928222" ON "__chart__drive" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_36cb699c49580d4e6c2e6159f9" ON "__chart__federation" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e447064455928cf627590ef527" ON "__chart__federation" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_76e87c7bfc5d925fcbba405d84" ON "__chart__federation" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2d416e6af791a82e338c79d480" ON "__chart__federation" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_dd907becf76104e4b656659e6b" ON "__chart__federation" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e9cd07672b37d8966cf3709283" ON "__chart__federation" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_07747a1038c05f532a718fe1de" ON "__chart__hashtag" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_fcc181fb8283009c61cc4083ef" ON "__chart__hashtag" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_99a7d2faaef84a6f728d714ad6" ON "__chart__hashtag" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_49975586f50ed7b800fdd88fbd" ON "__chart__hashtag" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_25a97c02003338124b2b75fdbc" ON "__chart__hashtag" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_6d6f156ceefc6bc5f273a0e370" ON "__chart__hashtag" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_6b8f34a1a64b06014b6fb66824" ON "__chart__instance" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_c12f0af4a66cdd30c2287ce8aa" ON "__chart__instance" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_da8a46ba84ca1d8bb5a29bfb63" ON "__chart__instance" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_d0a4f79af5a97b08f37b547197" ON "__chart__instance" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_39ee857ab2f23493037c6b6631" ON "__chart__instance" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f5448d9633cff74208d850aabe" ON "__chart__instance" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a1efd3e0048a5f2793a47360dc" ON "__chart__network" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f8dd01baeded2ffa833e0a610a" ON "__chart__network" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7b5da130992ec9df96712d4290" ON "__chart__network" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_08fac0eb3b11f04c200c0b40dd" ON "__chart__network" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0a905b992fecd2b5c3fb98759e" ON "__chart__network" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_9ff6944f01acb756fdc92d7563" ON "__chart__network" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_42eb716a37d381cdf566192b2b" ON "__chart__notes" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e69096589f11e3baa98ddd64d0" ON "__chart__notes" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7036f2957151588b813185c794" ON "__chart__notes" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0c9a159c5082cbeef3ca6706b5" ON "__chart__notes" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f09d543e3acb16c5976bdb31fa" ON "__chart__notes" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_924fc196c80ca24bae01dd37e4" ON "__chart__notes" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_5f86db6492274e07c1a3cdf286" ON "__chart__per_user_drive" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_328f259961e60c4fa0bfcf55ca" ON "__chart__per_user_drive" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e496ca8096d28f6b9b509264dc" ON "__chart__per_user_drive" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_42ea9381f0fda8dfe0fa1c8b53" ON "__chart__per_user_drive" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_30bf67687f483ace115c5ca642" ON "__chart__per_user_drive" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f2aeafde2ae6fbad38e857631b" ON "__chart__per_user_drive" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7af07790712aa3438ff6773f3b" ON "__chart__per_user_following" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f92dd6d03f8d994f29987f6214" ON "__chart__per_user_following" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_4b3593098b6edc9c5afe36b18b" ON "__chart__per_user_following" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_57b5458d0d3d6d1e7f13d4e57f" ON "__chart__per_user_following" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b77d4dd9562c3a899d9a286fcd" ON "__chart__per_user_following" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_4db3b84c7be0d3464714f3e0b1" ON "__chart__per_user_following" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_84234bd1abb873f07329681c83" ON "__chart__per_user_notes" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_8d2cbbc8114d90d19b44d626b6" ON "__chart__per_user_notes" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_55bf20f366979f2436de99206b" ON "__chart__per_user_notes" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_046feeb12e9ef5f783f409866a" ON "__chart__per_user_notes" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_5048e9daccbbbc6d567bb142d3" ON "__chart__per_user_notes" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f68a5ab958f9f5fa17a32ac23b" ON "__chart__per_user_notes" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f7bf4c62059764c2c2bb40fdab" ON "__chart__per_user_reaction" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_65633a106bce43fc7c5c30a5c7" ON "__chart__per_user_reaction" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_8cf3156fd7a6b15c43459c6e3b" ON "__chart__per_user_reaction" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_edeb73c09c3143a81bcb34d569" ON "__chart__per_user_reaction" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_229a41ad465f9205f1f5703291" ON "__chart__per_user_reaction" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_e316f01a6d24eb31db27f88262" ON "__chart__per_user_reaction" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_0c641990ecf47d2545df4edb75" ON "__chart__test_grouped" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_2be7ec6cebddc14dc11e206686" ON "__chart__test_grouped" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_234dff3c0b56a6150b95431ab9" ON "__chart__test_grouped" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a5133470f4825902e170328ca5" ON "__chart__test_grouped" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b14489029e4b3aaf4bba5fb524" ON "__chart__test_grouped" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_84e661abb7bd1e51b690d4b017" ON "__chart__test_grouped" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_437bab3c6061d90f6bb65fd2cc" ON "__chart__test_unique" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_5c73bf61da4f6e6f15bae88ed1" ON "__chart__test_unique" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_bbfa573a8181018851ed0b6357" ON "__chart__test_unique" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_d70c86baedc68326be11f9c0ce" ON "__chart__test_unique" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a0cd75442dd10d0643a17c4a49" ON "__chart__test_unique" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_66e1e1ecd2f29e57778af35b59" ON "__chart__test_unique" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_b070a906db04b44c67c6c2144d" ON "__chart__test" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_92255988735563f0fe4aba1f05" ON "__chart__test" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_d41cce6aee1a50bfc062038f9b" ON "__chart__test" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_c5870993e25c3d5771f91f5003" ON "__chart__test" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a319e5dbf47e8a17497623beae" ON "__chart__test" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f170de677ea75ad4533de2723e" ON "__chart__test" ("span", "date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_845254b3eaf708ae8a6cac3026" ON "__chart__users" ("date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_7c184198ecf66a8d3ecb253ab3" ON "__chart__users" ("span") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_ed9b95919c672a13008e9487ee" ON "__chart__users" ("group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_f091abb24193d50c653c6b77fc" ON "__chart__users" ("span", "date") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_337e9599f278bd7537fe30876f" ON "__chart__users" ("date", "group") `);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a770a57c70e668cc61590c9161" ON "__chart__users" ("span", "date", "group") `);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a770a57c70e668cc61590c9161"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_337e9599f278bd7537fe30876f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f091abb24193d50c653c6b77fc"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_ed9b95919c672a13008e9487ee"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7c184198ecf66a8d3ecb253ab3"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_845254b3eaf708ae8a6cac3026"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f170de677ea75ad4533de2723e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a319e5dbf47e8a17497623beae"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_c5870993e25c3d5771f91f5003"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d41cce6aee1a50bfc062038f9b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_92255988735563f0fe4aba1f05"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b070a906db04b44c67c6c2144d"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_66e1e1ecd2f29e57778af35b59"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a0cd75442dd10d0643a17c4a49"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d70c86baedc68326be11f9c0ce"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_bbfa573a8181018851ed0b6357"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5c73bf61da4f6e6f15bae88ed1"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_437bab3c6061d90f6bb65fd2cc"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_84e661abb7bd1e51b690d4b017"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b14489029e4b3aaf4bba5fb524"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a5133470f4825902e170328ca5"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_234dff3c0b56a6150b95431ab9"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2be7ec6cebddc14dc11e206686"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0c641990ecf47d2545df4edb75"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e316f01a6d24eb31db27f88262"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_229a41ad465f9205f1f5703291"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_edeb73c09c3143a81bcb34d569"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8cf3156fd7a6b15c43459c6e3b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_65633a106bce43fc7c5c30a5c7"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f7bf4c62059764c2c2bb40fdab"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f68a5ab958f9f5fa17a32ac23b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5048e9daccbbbc6d567bb142d3"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_046feeb12e9ef5f783f409866a"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_55bf20f366979f2436de99206b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8d2cbbc8114d90d19b44d626b6"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_84234bd1abb873f07329681c83"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_4db3b84c7be0d3464714f3e0b1"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_b77d4dd9562c3a899d9a286fcd"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_57b5458d0d3d6d1e7f13d4e57f"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_4b3593098b6edc9c5afe36b18b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f92dd6d03f8d994f29987f6214"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7af07790712aa3438ff6773f3b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f2aeafde2ae6fbad38e857631b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_30bf67687f483ace115c5ca642"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_42ea9381f0fda8dfe0fa1c8b53"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e496ca8096d28f6b9b509264dc"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_328f259961e60c4fa0bfcf55ca"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_5f86db6492274e07c1a3cdf286"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_924fc196c80ca24bae01dd37e4"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f09d543e3acb16c5976bdb31fa"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0c9a159c5082cbeef3ca6706b5"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7036f2957151588b813185c794"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e69096589f11e3baa98ddd64d0"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_42eb716a37d381cdf566192b2b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_9ff6944f01acb756fdc92d7563"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0a905b992fecd2b5c3fb98759e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_08fac0eb3b11f04c200c0b40dd"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7b5da130992ec9df96712d4290"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f8dd01baeded2ffa833e0a610a"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a1efd3e0048a5f2793a47360dc"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_f5448d9633cff74208d850aabe"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_39ee857ab2f23493037c6b6631"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_d0a4f79af5a97b08f37b547197"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_da8a46ba84ca1d8bb5a29bfb63"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_c12f0af4a66cdd30c2287ce8aa"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_6b8f34a1a64b06014b6fb66824"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_6d6f156ceefc6bc5f273a0e370"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_25a97c02003338124b2b75fdbc"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_49975586f50ed7b800fdd88fbd"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_99a7d2faaef84a6f728d714ad6"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_fcc181fb8283009c61cc4083ef"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_07747a1038c05f532a718fe1de"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e9cd07672b37d8966cf3709283"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_dd907becf76104e4b656659e6b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_2d416e6af791a82e338c79d480"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_76e87c7bfc5d925fcbba405d84"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_e447064455928cf627590ef527"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_36cb699c49580d4e6c2e6159f9"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_06690fc959f1c9fdaf21928222"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3313d7288855ec105b5bbf6c21"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_6e1df243476e20cbf86572ecc0"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_7a170f67425e62a8fabb76c872"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_3fa0d0f17ca72e3dc80999a032"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_13565815f618a1ff53886c5b28"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_c26e2c1cbb6e911e0554b27416"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_9a3ed15a30ab7e3a37702e6e08"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_20f57cc8f142c131340ee16742"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_00ed5f86db1f7efafb1978bf21"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_15e91a03aeeac9dbccdf43fc06"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_0ad37b7ef50f4ddc84363d7ccc"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_90148bbc2bf0854428786bfc15"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_88937d94d7443d9a99a76fa5c0"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_54ebcb6d27222913b908d56fd8"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_796a8c03959361f97dc2be1d5c"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_25dfc71b0369b003a4cd434d0b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_51c063b6a133a9cb87145450f5"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_fa99d777623947a5b05f394cae"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_315c779174fe8247ab324f036e"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_c5d46cbfda48b1c33ed852e21b"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8cb40cfc8f3c28261e6f887b03"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class PasswordLessLogin1562422242907 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD COLUMN "usePasswordLessLogin" boolean DEFAULT false NOT NULL`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "usePasswordLessLogin"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,17 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class PinnedPage1562444565093 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD "pinnedPageId" character varying(32)`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD CONSTRAINT "UQ_6dc44f1ceb65b1e72bacef2ca27" UNIQUE ("pinnedPageId")`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD CONSTRAINT "FK_6dc44f1ceb65b1e72bacef2ca27" FOREIGN KEY ("pinnedPageId") REFERENCES "page"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP CONSTRAINT "FK_6dc44f1ceb65b1e72bacef2ca27"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP CONSTRAINT "UQ_6dc44f1ceb65b1e72bacef2ca27"`);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "pinnedPageId"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class PageTitleHideOption1562448332510 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" ADD "hideTitleWhenPinned" boolean NOT NULL DEFAULT false`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "page" DROP COLUMN "hideTitleWhenPinned"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,17 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class ModerationLog1562869971568 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "moderation_log" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "type" character varying(128) NOT NULL, "info" jsonb NOT NULL, CONSTRAINT "PK_d0adca6ecfd068db83e4526cc26" PRIMARY KEY ("id"))`);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_a08ad074601d204e0f69da9a95" ON "moderation_log" ("userId") `);
|
|
||||||
await queryRunner.query(`ALTER TABLE "moderation_log" ADD CONSTRAINT "FK_a08ad074601d204e0f69da9a954" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "moderation_log" DROP CONSTRAINT "FK_a08ad074601d204e0f69da9a954"`);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_a08ad074601d204e0f69da9a95"`);
|
|
||||||
await queryRunner.query(`DROP TABLE "moderation_log"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class UsedUsername1563757595828 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "used_username" ("username" character varying(128) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, CONSTRAINT "PK_78fd79d2d24c6ac2f4cc9a31a5d" PRIMARY KEY ("username"))`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`DROP TABLE "used_username"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class room1565634203341 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" ADD "room" jsonb NOT NULL DEFAULT '{}'`);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "room"`);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,13 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class CustomEmojiCategory1571220798684 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "emoji" ADD "category" character varying(128)`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "emoji" DROP COLUMN "category"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,29 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class nodeinfo1572760203493 implements MigrationInterface {
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "system"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "softwareName" character varying(64) DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "softwareVersion" character varying(64) DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "openRegistrations" boolean DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "name" character varying(256) DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "description" character varying(4096) DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "maintainerName" character varying(128) DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "maintainerEmail" character varying(256) DEFAULT null`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "infoUpdatedAt" TIMESTAMP WITH TIME ZONE`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "infoUpdatedAt"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "maintainerEmail"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "maintainerName"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "description"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "name"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "openRegistrations"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "softwareVersion"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "softwareName"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "instance" ADD "system" character varying(64)`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,14 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class TalkFederationId1576269851876 implements MigrationInterface {
|
|
||||||
name = 'TalkFederationId1576269851876'
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" ADD "uri" character varying(512)`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "messaging_message" DROP COLUMN "uri"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,14 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class ProxyRemoteFiles1576869585998 implements MigrationInterface {
|
|
||||||
name = 'ProxyRemoteFiles1576869585998'
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "proxyRemoteFiles" boolean NOT NULL DEFAULT false`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "proxyRemoteFiles"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,34 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class v121579267006611 implements MigrationInterface {
|
|
||||||
name = 'v121579267006611'
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`CREATE TABLE "announcement" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "text" character varying(8192) NOT NULL, "title" character varying(256) NOT NULL, "imageUrl" character varying(1024), CONSTRAINT "PK_e0ef0550174fd1099a308fd18a0" PRIMARY KEY ("id"))`, undefined);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_118ec703e596086fc4515acb39" ON "announcement" ("createdAt") `, undefined);
|
|
||||||
await queryRunner.query(`CREATE TABLE "announcement_read" ("id" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, "announcementId" character varying(32) NOT NULL, CONSTRAINT "PK_4b90ad1f42681d97b2683890c5e" PRIMARY KEY ("id"))`, undefined);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_8288151386172b8109f7239ab2" ON "announcement_read" ("userId") `, undefined);
|
|
||||||
await queryRunner.query(`CREATE INDEX "IDX_603a7b1e7aa0533c6c88e9bfaf" ON "announcement_read" ("announcementId") `, undefined);
|
|
||||||
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_924fa71815cfa3941d003702a0" ON "announcement_read" ("userId", "announcementId") `, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "isVerified"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "announcements"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "enableEmojiReaction"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement_read" ADD CONSTRAINT "FK_8288151386172b8109f7239ab28" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement_read" ADD CONSTRAINT "FK_603a7b1e7aa0533c6c88e9bfafe" FOREIGN KEY ("announcementId") REFERENCES "announcement"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement_read" DROP CONSTRAINT "FK_603a7b1e7aa0533c6c88e9bfafe"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement_read" DROP CONSTRAINT "FK_8288151386172b8109f7239ab28"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "enableEmojiReaction" boolean NOT NULL DEFAULT true`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "meta" ADD "announcements" jsonb NOT NULL DEFAULT '[]'`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "user" ADD "isVerified" boolean NOT NULL DEFAULT false`, undefined);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_924fa71815cfa3941d003702a0"`, undefined);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_603a7b1e7aa0533c6c88e9bfaf"`, undefined);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_8288151386172b8109f7239ab2"`, undefined);
|
|
||||||
await queryRunner.query(`DROP TABLE "announcement_read"`, undefined);
|
|
||||||
await queryRunner.query(`DROP INDEX "IDX_118ec703e596086fc4515acb39"`, undefined);
|
|
||||||
await queryRunner.query(`DROP TABLE "announcement"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,14 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class v1221579270193251 implements MigrationInterface {
|
|
||||||
name = 'v1221579270193251'
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement_read" ADD "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement_read" DROP COLUMN "createdAt"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,14 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class v1231579282808087 implements MigrationInterface {
|
|
||||||
name = 'v1231579282808087'
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement" ADD "updatedAt" TIMESTAMP WITH TIME ZONE`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "announcement" DROP COLUMN "updatedAt"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
@@ -1,16 +0,0 @@
|
|||||||
import {MigrationInterface, QueryRunner} from "typeorm";
|
|
||||||
|
|
||||||
export class v1241579544426412 implements MigrationInterface {
|
|
||||||
name = 'v1241579544426412'
|
|
||||||
|
|
||||||
public async up(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" ADD "followRequestId" character varying(32)`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_bd7fab507621e635b32cd31892c" FOREIGN KEY ("followRequestId") REFERENCES "follow_request"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
public async down(queryRunner: QueryRunner): Promise<any> {
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" DROP CONSTRAINT "FK_bd7fab507621e635b32cd31892c"`, undefined);
|
|
||||||
await queryRunner.query(`ALTER TABLE "notification" DROP COLUMN "followRequestId"`, undefined);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user