Compare commits
1751 Commits
Author | SHA1 | Date | |
---|---|---|---|
9a4a534c92 | |||
0e89a9f41e | |||
f34920ea87 | |||
5e9cc09fcb | |||
7e93319873 | |||
878f09460c | |||
c9a01aeba5 | |||
2154354a4f | |||
490692316e | |||
3c5d2ecc91 | |||
a8d52c565e | |||
2752afd5f5 | |||
433230413e | |||
b090ff9994 | |||
68ace4a311 | |||
65d6104ad2 | |||
372b42c0bd | |||
06845b3bec | |||
cbcbd6f0a9 | |||
af280f52ab | |||
7674a62d40 | |||
764a158cd7 | |||
cb2a9a29fe | |||
21e1906fbf | |||
4c01dcd8eb | |||
95939e4991 | |||
10af8c8db7 | |||
f29d417b30 | |||
f2e071baaa | |||
34fef37e54 | |||
06e817af59 | |||
55face52d8 | |||
aba867ea14 | |||
0921850a79 | |||
377b0399a0 | |||
49dfcd4227 | |||
0ee1021bcc | |||
e60d13f471 | |||
1baff3f8d7 | |||
1a4de42999 | |||
f5e53afa7a | |||
7886c2aa96 | |||
ad069f0eba | |||
3d68a0988b | |||
3c7a02af1e | |||
3fa1d2bfc0 | |||
a413144bce | |||
bd046f7670 | |||
d8fb729aee | |||
a2557fca87 | |||
78a963fe33 | |||
f3aef8df75 | |||
b0757129d5 | |||
de98718923 | |||
0d1158335f | |||
9860489f88 | |||
25d37302a8 | |||
5f1a6b6f64 | |||
c39f69e5dd | |||
8668bc2609 | |||
65fbca47f9 | |||
53c7077d1d | |||
7eb6038f92 | |||
d6c8b9b994 | |||
8bd80eb2a6 | |||
b36adb6aab | |||
eefbe097c0 | |||
5c6e389cd5 | |||
126826eb5a | |||
9bc0110b86 | |||
10cd4754fd | |||
10f9fd6146 | |||
ffb0dadbc7 | |||
9c1e42cc9b | |||
911dedf3d7 | |||
6a9187c1ba | |||
5cdd9d2027 | |||
70826d326b | |||
0336d640ec | |||
80eefa92ce | |||
f1a861d1c1 | |||
1eda7c8565 | |||
6ce2231e70 | |||
6477ad2cfc | |||
225ec6f5ed | |||
91172654e4 | |||
ebadd7fd3f | |||
2d3248504b | |||
78b12c7b80 | |||
42a6dc44f4 | |||
832eabfeab | |||
2fe22acc0d | |||
554bf821d8 | |||
dcf2c32fd8 | |||
215d7ec1b9 | |||
33bd8fb9d9 | |||
ab9343a788 | |||
263032b680 | |||
cc9bc7703a | |||
90f738608f | |||
d0cf26b342 | |||
51f6708fc6 | |||
c6fcef6e98 | |||
0c3a24318a | |||
868657477c | |||
c77f3e0985 | |||
130a222821 | |||
e0facd97c7 | |||
01eba895d1 | |||
74196a3781 | |||
fdfc23d878 | |||
c4bdf39abc | |||
7e8a0e5c5a | |||
ad14feae94 | |||
2e7458a246 | |||
fd7fe5d96e | |||
d8872ca278 | |||
49e6c2ed75 | |||
f24c7c81c0 | |||
fb7a0b5816 | |||
8bb76da6b5 | |||
20816fd77a | |||
aa7e206329 | |||
a1b9bbb726 | |||
0a64d121d9 | |||
823a0c86d3 | |||
5743d87a43 | |||
871d2bad17 | |||
547da89c7d | |||
4ecd036d0a | |||
b2fb92cf0f | |||
3d73ce63ca | |||
eb267e8a57 | |||
40bfa3ef04 | |||
9b3458fba0 | |||
86eb487a38 | |||
091d6f6a3e | |||
885f8e1856 | |||
c88902e640 | |||
0e45f10d99 | |||
41d7515f85 | |||
3be7eafa6b | |||
9dd1a8fb2e | |||
ecae4c03f9 | |||
ff67fb337e | |||
100a131913 | |||
7fc3e7dd8b | |||
e4bcdd7b4d | |||
bce65e2140 | |||
7747ec5b6d | |||
c3b797b414 | |||
0343c5e692 | |||
1621e5d6fb | |||
6311474fa7 | |||
e0e373c357 | |||
9fff26b900 | |||
d439bc8c2f | |||
fe52f7c392 | |||
82207598f0 | |||
a2bef1fa52 | |||
3762cdc8c0 | |||
b224760aba | |||
cbdd14fa82 | |||
96d6e0f8a2 | |||
a44ad63440 | |||
c3592e8c4a | |||
d153d3b761 | |||
60561578d8 | |||
b8bc96c181 | |||
005d6b4ccf | |||
f972fb6920 | |||
77078f2ce2 | |||
dae6d60163 | |||
264d6afe5d | |||
52c1d87fa2 | |||
dccafca58d | |||
52c12f96d5 | |||
114a9fbdb2 | |||
20e67e7edd | |||
889b52e813 | |||
6c975275f8 | |||
1286dee1ab | |||
fee953b0df | |||
26e7454f0e | |||
edbaa07867 | |||
f7ebf14501 | |||
d00928cf3f | |||
b3a198cae6 | |||
8b87d56a5a | |||
62ac3400da | |||
d54f71774e | |||
a47358f590 | |||
8f2cf066b6 | |||
e3e5a4272b | |||
2dcb3af70f | |||
3a19e9f80e | |||
c6fe798092 | |||
e74a47916d | |||
761071e1ce | |||
9e3610d513 | |||
393ac6c203 | |||
b7a79d25b0 | |||
486f045751 | |||
d6e3ec3218 | |||
078b043cae | |||
296cbc2e5a | |||
a74beaac36 | |||
79f8eb910f | |||
c91eef0030 | |||
7bf9d726d0 | |||
1946ff8ed4 | |||
b4d85d4f69 | |||
a03702d2bd | |||
71d7de4989 | |||
35d9e13dbb | |||
b427842679 | |||
4ae172be57 | |||
e6705b1a65 | |||
bc22cabdb5 | |||
7128b9f16a | |||
8c0490fef1 | |||
882a81636d | |||
24b9be76ba | |||
e763c6e661 | |||
899e2c73d7 | |||
10cb15b000 | |||
873d4bd707 | |||
97dea72c94 | |||
7d49f260b8 | |||
3055e6d8c7 | |||
2c93246860 | |||
360c820b9d | |||
87847c6ed5 | |||
4874f54d4d | |||
ff73efcc08 | |||
4ee64cbd9e | |||
0c40a86fca | |||
f92eed0549 | |||
69ed8cc409 | |||
4fff1279db | |||
d80699e454 | |||
deee1dbf53 | |||
067588845b | |||
b177b0cafc | |||
5679777010 | |||
a70c24cd1e | |||
357f3dd258 | |||
d815838762 | |||
4ceef78599 | |||
d5811633ea | |||
32265da72c | |||
ef94236e7f | |||
2924f0e434 | |||
1e419a9e1f | |||
097ece9dc9 | |||
6b6483c9fc | |||
22049b10ff | |||
de86644cb6 | |||
657aac5bc5 | |||
7ae3640d1a | |||
6fb42857c6 | |||
abf21349cd | |||
ed17af8339 | |||
67f391f6d4 | |||
c6b25f317e | |||
d91fa1a37a | |||
6c3f052996 | |||
33b0c87fb1 | |||
5c490e7521 | |||
54961235a4 | |||
17eca2a18f | |||
137f3ee609 | |||
498f6e9be2 | |||
a5e841f59c | |||
9adab1e85e | |||
4288a843cb | |||
1669f5b265 | |||
1157298eb8 | |||
948a65bf39 | |||
20c076b369 | |||
b67ed64116 | |||
1da3777bfb | |||
ea6aa40b09 | |||
b002651194 | |||
1452512daf | |||
0e7778bebf | |||
698fbdf88b | |||
7b738deabf | |||
3c65e7b76e | |||
3fc427b699 | |||
03667e1fe6 | |||
5cfd000a7d | |||
fa66eac096 | |||
70eb75b7e6 | |||
2f6187a26a | |||
167da988da | |||
6935e647a6 | |||
743eca4a95 | |||
78598a92f9 | |||
94598ab555 | |||
c5bdee086d | |||
c6cfc3f908 | |||
84b488a912 | |||
ec4d5857d8 | |||
4576641105 | |||
572e475b39 | |||
882a30fabe | |||
feec35bf4f | |||
c9fea5a7a0 | |||
00f3a1e1ec | |||
5a8cc7851b | |||
9d81d06853 | |||
4fce5d8066 | |||
329e367bda | |||
ce056bf936 | |||
c6ab5faba6 | |||
6ce0804b43 | |||
a7a6563281 | |||
0a084a3363 | |||
beeb8de6da | |||
e73297f260 | |||
b408ef5ba5 | |||
50539099ab | |||
9a3a77cff0 | |||
cdc07945af | |||
9f9194ab5c | |||
136a087ae7 | |||
b9e91afa26 | |||
f943e39c89 | |||
75bdbff36d | |||
43930e6a84 | |||
57d0c19a98 | |||
66a11378d2 | |||
62b680cadd | |||
1e1ac13999 | |||
d27c454674 | |||
3263eaec32 | |||
de4e9a857c | |||
d838876ab1 | |||
03336f01b5 | |||
d212d693a4 | |||
d17fcd8e48 | |||
49b3ee36bd | |||
100d7adc3d | |||
68b1fea6bb | |||
4de6e1e28a | |||
84f8c34e90 | |||
77567cf114 | |||
3cf8e1917c | |||
84cbabec29 | |||
b88c65ab67 | |||
10782822de | |||
5457172aa5 | |||
d20a2c7080 | |||
c01098de16 | |||
0b14a57d55 | |||
405d104208 | |||
83e3316f06 | |||
2037d4c21d | |||
6cabf052b1 | |||
359e1b2e6e | |||
7b553b13ac | |||
79872ec3e8 | |||
e9df7265fa | |||
1ade89be35 | |||
3356f7113f | |||
e6495ea6e2 | |||
629991443a | |||
6848f05ea5 | |||
e58dd71829 | |||
1afa2f1202 | |||
f322cb444a | |||
69c3c4e3dc | |||
488e6feed9 | |||
40891aca48 | |||
cd0e557991 | |||
679f8ad614 | |||
00c647c736 | |||
1ac6af6ad1 | |||
a5d7099a3c | |||
e9c8a0f5d5 | |||
adcda0889e | |||
95cbcdd379 | |||
a5e8eb4b7b | |||
ed440f80f3 | |||
4e2ef94107 | |||
de690e0622 | |||
062e1a4940 | |||
cc3779b197 | |||
92dc34b51a | |||
f8ee615640 | |||
5dde8b4bdc | |||
2c70055a87 | |||
db8ab8b890 | |||
28da5c5a31 | |||
b345aad52c | |||
aa5af89dfc | |||
9a3a74db34 | |||
328619f1fc | |||
121e12785f | |||
cc3f0737a2 | |||
bc3714139f | |||
9200379997 | |||
0ee664db2b | |||
86487e6f66 | |||
adc2bcc59b | |||
21a54f559a | |||
145e16c266 | |||
68f4edd0ee | |||
7fd6a134d1 | |||
0db8d566e2 | |||
c6f6291fc0 | |||
c2d79450ea | |||
d58ae601f7 | |||
3ad73ad7d9 | |||
f0c4df1cc5 | |||
839784bc8c | |||
b758ec96ef | |||
2f8ceb9d22 | |||
e05ae5ebc2 | |||
ebc43be4b3 | |||
8543278ce3 | |||
9a98de7bd8 | |||
e1d69fb4ad | |||
946f9b4a2b | |||
9a270e59a4 | |||
2112fb3896 | |||
d1bd9fa552 | |||
393bd76959 | |||
97165fbaf5 | |||
feca9940bc | |||
fbbc7d005d | |||
af5b4749b0 | |||
b4e5fe7e71 | |||
1671aef0bd | |||
ffe5a12773 | |||
9ca01b65de | |||
f50ed905a8 | |||
d7156b8cdd | |||
14442ffa18 | |||
d454596c33 | |||
7d510cf780 | |||
8121cbf10c | |||
d34d20c393 | |||
e773c272be | |||
0c072249d8 | |||
d0b7b662b4 | |||
4b5aa286a0 | |||
2310c74d0b | |||
af251bf0c4 | |||
16204ac13b | |||
7c8645fe29 | |||
bd82173caa | |||
2e8a0b0fac | |||
38b7f4364c | |||
3a33e406c7 | |||
8d0c5268d1 | |||
08bec5abd9 | |||
cc4b6e5eea | |||
e6cb07bef4 | |||
249bfcc5f0 | |||
108c4b4342 | |||
38befa51ac | |||
6a76118710 | |||
f049694fa1 | |||
515a6b74a2 | |||
d1291b3b4c | |||
d2abc28a2b | |||
12142f8c5e | |||
41d7a8de66 | |||
c7a65c13aa | |||
fbf0baadba | |||
ea31e62795 | |||
910b145f42 | |||
952a793f80 | |||
46f2ffaa5c | |||
45ba7989c1 | |||
c4cf3331e9 | |||
6d75ca0bcb | |||
050fb55326 | |||
9d1d9c3540 | |||
fdde966808 | |||
c6ce7b1045 | |||
ce743054d6 | |||
99970b6864 | |||
42110bcd33 | |||
9677b0bfb1 | |||
a7762972fa | |||
dda3b4152e | |||
b7aa6d6c1f | |||
909a3b805f | |||
848d2e00e7 | |||
642662941f | |||
0028a529a8 | |||
62131e864b | |||
0c58b43831 | |||
5a3d6c4fba | |||
a031fa3875 | |||
721ed97a83 | |||
944927ac2d | |||
7705749d28 | |||
cf7f42ebc4 | |||
f195968b6d | |||
4d6bffdc8a | |||
f62c6a05a9 | |||
fa550a2a78 | |||
960c27375c | |||
e87b3e2933 | |||
133766bf8c | |||
aa6b25e9e7 | |||
abde13221f | |||
cb17be5e2b | |||
17d62b689d | |||
9bf5dc67f5 | |||
4eab9b4354 | |||
d39c153c57 | |||
e5992742d4 | |||
72ed803c2a | |||
9ec0e59431 | |||
5328ed64f3 | |||
33e8d61d65 | |||
3584786387 | |||
34f662ead5 | |||
2d53481cf5 | |||
10fb029609 | |||
0281961f15 | |||
fede4eeb89 | |||
ab50d5ef20 | |||
f4e02d4a4c | |||
167640df8d | |||
fe01437aa4 | |||
037fce4d6a | |||
db8b824b84 | |||
b71f62535d | |||
e9a1e281b9 | |||
0144408500 | |||
7660839e40 | |||
d1ca851ebe | |||
35a281d443 | |||
c2690fff47 | |||
c3a73a41d1 | |||
b72baa3295 | |||
73ce22c8a4 | |||
c4f7e6659f | |||
0739ae006d | |||
eaa92e784d | |||
48589e0da1 | |||
0044d83801 | |||
50e917d232 | |||
ccd14e0462 | |||
d0c0104546 | |||
cd34ade638 | |||
3f91e33a8c | |||
17cc996288 | |||
385776dc0f | |||
e52278c371 | |||
7ffc8c1eda | |||
1359615c82 | |||
7a7a56940c | |||
bcbe83cb38 | |||
37f983aee3 | |||
77de3f2b9d | |||
f655b54937 | |||
cac99ebdd4 | |||
f0d0a1546a | |||
8e8459fa55 | |||
d53c55ecb5 | |||
ea33d61a90 | |||
2fcc3388dd | |||
ef7f033c32 | |||
7aa54dc92e | |||
d10ad1b413 | |||
34063a0b84 | |||
8c9d975d69 | |||
03b072b894 | |||
d1bed49808 | |||
6c3417d9b5 | |||
ba65226460 | |||
9c9cd168ee | |||
abb3d2a8d9 | |||
637fe8a04b | |||
be321e95e5 | |||
ed46c1486c | |||
c9fcfc6862 | |||
8495e37566 | |||
247bd43ae2 | |||
a6685b1559 | |||
66c4e8064b | |||
9d1fa3f202 | |||
a6985d7dc7 | |||
027c021ac9 | |||
604205ec09 | |||
77db016866 | |||
c6a009dbae | |||
4299e3f90c | |||
19f4812c03 | |||
d01c465a8d | |||
4f1409601e | |||
52cffe0864 | |||
0866d5c055 | |||
78c08f6503 | |||
27d0ac3d75 | |||
a8776002f3 | |||
31aa008566 | |||
9d405b4581 | |||
80c490a18b | |||
30c9c3739f | |||
ee0e7a09e0 | |||
bfd9577f0d | |||
0cada4ca76 | |||
a718ccc0b6 | |||
1fcfd8e645 | |||
c6dd932a0b | |||
b79eed01e0 | |||
3a7dbe9764 | |||
bef2534fa8 | |||
888dcd2559 | |||
2b69fca6bd | |||
7d088d42b4 | |||
f8ad303b13 | |||
3c59c6fc9b | |||
7353d729d7 | |||
62591e0e7a | |||
012f15d84b | |||
e57c6f94d2 | |||
40b27e8ad8 | |||
055e9f21b7 | |||
d7085b17fe | |||
0d4d7c9c0c | |||
99209d36e1 | |||
e2a9a0ff3d | |||
ab166959a4 | |||
ab692cfa3d | |||
c3ae6f3a4a | |||
5ef4a52bbd | |||
582768a5e4 | |||
1852d1cc6f | |||
7a5a541a4e | |||
72b03e009c | |||
1b113c1045 | |||
54959557ea | |||
d44cb7f256 | |||
3d063c95d1 | |||
09cab605fc | |||
666c8c0498 | |||
d3e764d7f9 | |||
7060625adf | |||
21b6e23e98 | |||
a0f794e372 | |||
9195504329 | |||
8c5d9dd549 | |||
580f6a5b6c | |||
74e76b460b | |||
c4570b37b7 | |||
cd0b0012d9 | |||
c055b4d32d | |||
75a9ff832a | |||
b64d3af1f3 | |||
fb6605bb40 | |||
3bfae80fa7 | |||
cb16cb0610 | |||
0baed1a275 | |||
42162c8015 | |||
0fab0c416d | |||
e2e262c8ce | |||
cf6596203b | |||
471911a54f | |||
9394f4f540 | |||
4e968216ad | |||
84a7a9555f | |||
8d12fd152b | |||
629b765abc | |||
63a89fa84a | |||
a3f89236a0 | |||
01560abafb | |||
b5698026ba | |||
6258ce75b7 | |||
6f34c74027 | |||
8add4f359b | |||
d8933c135f | |||
eb350e8d6c | |||
615fedd64d | |||
25bd82ecaa | |||
e0938e5e3a | |||
ec5e6c8443 | |||
25d8077474 | |||
06083f40d9 | |||
ec203f7f79 | |||
1b30d7d47a | |||
d9be9c958f | |||
ed09796e0d | |||
4bfa29c0ab | |||
4804bbb211 | |||
749102f9c2 | |||
0bcb1434b0 | |||
2e537e618c | |||
fe3b7a2ad3 | |||
90db793fd0 | |||
7bd2a6ad61 | |||
745f4d2439 | |||
254cfaea28 | |||
d4da5a1eea | |||
c0f8297414 | |||
834cb2ea1a | |||
d82769abd4 | |||
adf01ed4a4 | |||
09c007b3aa | |||
526ff177aa | |||
0e40d4e796 | |||
172ebab7bd | |||
aa4493fe5c | |||
a68a88f79e | |||
1de7dc94e1 | |||
59cb7992e2 | |||
87b15df47b | |||
6932d86240 | |||
87f61e714a | |||
5762e2d9ba | |||
f0691c8a4f | |||
6d7e4fe2a1 | |||
7dc789f470 | |||
190d1bbf3c | |||
a755dd5f9e | |||
0846a7b94e | |||
d8be0511f1 | |||
fb07116a4c | |||
fe453c15e3 | |||
059aeef6a0 | |||
30e25451d6 | |||
7f0fd55c9a | |||
0e9b496deb | |||
8294c18e70 | |||
39575b4696 | |||
29e9801d5c | |||
eaf83bffb0 | |||
bb25ece745 | |||
754b5629e4 | |||
ee63403548 | |||
87edeb41da | |||
41fe804587 | |||
02466acc4b | |||
8470a64e6b | |||
9939e0f9a9 | |||
ce5f552d0c | |||
7d4c535233 | |||
57cd0fb93f | |||
a15299ae53 | |||
1df7abfbb9 | |||
85a0f696bc | |||
ba3c62bf9c | |||
c17e97b6a6 | |||
2d80cd0e7b | |||
eedc572f0c | |||
2de1df3514 | |||
2d96af1255 | |||
163325ef89 | |||
23979bf09a | |||
7199e6f4e0 | |||
a40f38b2b5 | |||
00a17ed5d4 | |||
b594366f06 | |||
e9284930df | |||
ea7504f564 | |||
c1f6d996f6 | |||
df71dbb024 | |||
f104e9b6cc | |||
e29b5c2326 | |||
925868dcdb | |||
d7df26d92b | |||
42d1c67d56 | |||
c2d7929391 | |||
5864b52a81 | |||
493d32b3dc | |||
ed141338fb | |||
95db488c48 | |||
d5e1e523b6 | |||
cd0f8a4ef9 | |||
6dac505af9 | |||
9d398040cb | |||
aa55acedc9 | |||
eb70d6f226 | |||
36f0963d78 | |||
c3c111529e | |||
2dbab66cfe | |||
01238d6b1a | |||
c34f302b1c | |||
6870262f8d | |||
c54d5e7040 | |||
0ace009a54 | |||
48e8ee440b | |||
9855405b89 | |||
122076e8ea | |||
7c5ac2cbb4 | |||
ccda2181c1 | |||
b5fe4ba9be | |||
fd9c7d525a | |||
080574e13d | |||
ee0a445590 | |||
bb342c7601 | |||
ed17636fb9 | |||
c59d7d941a | |||
377377595a | |||
d63aef9963 | |||
e9b28fa3c0 | |||
be255dc583 | |||
18eb7c6087 | |||
cf29e69813 | |||
132da7e3c0 | |||
26df23bb64 | |||
76389ad619 | |||
7cde8cfbf2 | |||
4eb2ddac4e | |||
dc51eef27c | |||
bff8a23cbc | |||
9c5efb9da0 | |||
48b8320e5e | |||
9b2ed96c1c | |||
69d9aa71f2 | |||
13683780cd | |||
d780e5b251 | |||
917d3d0bd3 | |||
4b19c53697 | |||
2d40a15d2b | |||
2bdcd22ad4 | |||
f73a4e1304 | |||
b265cdbd84 | |||
a04d8b95c2 | |||
0e9a8c0cd4 | |||
5ae8a3c7e8 | |||
70ee172128 | |||
b9febc00f9 | |||
0112e2f7ec | |||
60736bab2a | |||
fb7c4ee21a | |||
e93c06cd00 | |||
0a99345909 | |||
3d08ff7cb4 | |||
057ce73ba1 | |||
66b07578c5 | |||
de3b365563 | |||
7bb8d8b27e | |||
9008664606 | |||
7374905c28 | |||
718e20de60 | |||
73d166323d | |||
3589fc6f4f | |||
feed6c7acc | |||
2522e7388d | |||
09cfd620bb | |||
362e95263d | |||
c6837b9fdf | |||
71878f93e4 | |||
f5d43b1f25 | |||
770e7378be | |||
b9a8620d2f | |||
d1c8b2993e | |||
01e9b3c2f6 | |||
57203de4cb | |||
74d0e83a8a | |||
9eee5644b9 | |||
9fe6f9417e | |||
e7de5f6051 | |||
60d81d74e3 | |||
2701a7e85f | |||
31a0afdaab | |||
9f87545901 | |||
9f94f60ede | |||
0ca3c0bca1 | |||
27611cef77 | |||
30df8ea121 | |||
595ad04ddb | |||
6b8354ccbf | |||
1b9d316e7c | |||
a8adc46f3b | |||
0efa969a15 | |||
14b7f05af4 | |||
cf43dd6ec5 | |||
b5a1fdd4c7 | |||
b32737cdff | |||
8e9717a5fc | |||
3e28b296e3 | |||
056fef70da | |||
55be9cc9d1 | |||
3f2ffcea97 | |||
b07d037cb5 | |||
4feccdfd92 | |||
f1ef85b636 | |||
cf9266eab9 | |||
4a1552fb3c | |||
e5863c2867 | |||
58211fc6a7 | |||
bd54e44b35 | |||
e1f2e364a4 | |||
186b26e103 | |||
74706a8d2c | |||
7e2b6b6369 | |||
1a2de1a051 | |||
83900cbca6 | |||
166bc19131 | |||
da874f3383 | |||
9c30b23358 | |||
b8350d5093 | |||
58f7af8927 | |||
c3b9c7b74b | |||
9415618992 | |||
1c200c9b94 | |||
ce8fa8e423 | |||
a4b7a9db03 | |||
280eeb9d75 | |||
3f71b14637 | |||
705d40ab37 | |||
b39850de01 | |||
b9c5e95b85 | |||
0c1de7b1b6 | |||
0a4499fd03 | |||
b663a47331 | |||
eb275a62a6 | |||
e18caa3396 | |||
eb15d31ebf | |||
e7f1ab2d01 | |||
9d3beb3174 | |||
b6c3399abe | |||
b505874613 | |||
0a28573845 | |||
937df577f1 | |||
e54fd6c2cb | |||
3caea9d33e | |||
b9e9631195 | |||
76bded455a | |||
c94d9210ed | |||
0f5db9558c | |||
35a8c37922 | |||
6ff84a1061 | |||
aae9bc4cf4 | |||
426c2fa5d1 | |||
dab728278c | |||
7555ab097a | |||
5b5b64d251 | |||
eb84445796 | |||
364bd9ae74 | |||
d4b0761549 | |||
f8e06f12fd | |||
320352bf4b | |||
3c66990263 | |||
7cbe95a1cf | |||
c89abda3fb | |||
90348f4ac7 | |||
08293f368f | |||
d5378dab27 | |||
91648d1bd4 | |||
66d6e71f06 | |||
a0ea5776ab | |||
9b73e897df | |||
debc0086fa | |||
065ec8e170 | |||
11f8d742eb | |||
adf4f5410a | |||
8ff2694cad | |||
191c064611 | |||
d327bb8ff1 | |||
80bebea9e6 | |||
cf3fc97202 | |||
5b28d7bf90 | |||
5f8fb43cc9 | |||
6eff6ee451 | |||
c2ab3a15f4 | |||
a100e13a18 | |||
a591a334ed | |||
ca2e53bd6e | |||
d4b4b61535 | |||
440deb4624 | |||
bbb0130522 | |||
b6a4061097 | |||
48c94907c2 | |||
4fd06369d3 | |||
27a17b467d | |||
c25cf7f89a | |||
ade11aa447 | |||
3799708daf | |||
462204e204 | |||
752669bf5e | |||
b08e3f59d3 | |||
443b45e509 | |||
b2bed61088 | |||
be516d3c1e | |||
f5b41e1fbf | |||
e9afc1d867 | |||
a891f7e862 | |||
b715ea4621 | |||
ea13efe495 | |||
37f862947b | |||
ecb0861be4 | |||
624c9f3418 | |||
1b75984046 | |||
157f1c66dc | |||
cb41391bae | |||
acc88825fc | |||
233a837e35 | |||
9e4456ac1b | |||
83e1068da3 | |||
1fd345f563 | |||
37c16e5b45 | |||
ca25b9acc1 | |||
c3022d38f7 | |||
3599f16d22 | |||
3f78f6f6bb | |||
41f66e4299 | |||
0d36b144cf | |||
aa652aac8a | |||
8dbdab4a47 | |||
90c07a220f | |||
23e2a870cc | |||
dc8eb7d4fe | |||
fd363f5617 | |||
1726ff3977 | |||
93aba74463 | |||
99955f0af9 | |||
30cf154542 | |||
f2c33b06cf | |||
f12473e677 | |||
e845db01bf | |||
7f76a73eee | |||
3c2d94ace3 | |||
1e2239f527 | |||
1851daf9fd | |||
f378f26e5e | |||
cda6bc3404 | |||
071c7e6a58 | |||
010e1b3ba4 | |||
66de51c1ca | |||
265d6bda15 | |||
fecb12bae1 | |||
83ec906ee7 | |||
d44fbf58c9 | |||
9c4a789a4e | |||
bfa1705bad | |||
2876f2188c | |||
579c0043c3 | |||
0fa57957a4 | |||
05cb0b0ec5 | |||
4b24e96dfb | |||
c7eab37177 | |||
c7d0b6cb29 | |||
22ee087bb9 | |||
2480fcdc53 | |||
7e093aee5e | |||
dd8413a485 | |||
925f2912a9 | |||
ed00ea0865 | |||
3f19d221b7 | |||
808271838b | |||
ac0950fdef | |||
38f306ba73 | |||
5c1748d63d | |||
c00cddf5b0 | |||
baf3274748 | |||
9e0515e563 | |||
9c0404c407 | |||
0b85177690 | |||
7ec28ced40 | |||
19ae3b66ec | |||
0118dee3e5 | |||
9201714313 | |||
8b9c1efd7e | |||
111eb43fd9 | |||
f2964101d1 | |||
6b2c289029 | |||
fd2573c068 | |||
df0e9d75fe | |||
2bc86756c8 | |||
fb91ab4080 | |||
0b4d29ed1e | |||
2a8c65e2c3 | |||
ffc7f42efc | |||
7c38cda8ee | |||
d3f5001679 | |||
83d9a4b6d9 | |||
9760e08af4 | |||
8d48e4c76e | |||
a1e0c866aa | |||
8380222baf | |||
eda7d60c26 | |||
ddf92c3e2c | |||
9bb528eb6e | |||
9756957ac1 | |||
af0205b77d | |||
3f0da5453d | |||
923c3071f0 | |||
a8584973e2 | |||
886766cca5 | |||
974abbe826 | |||
61bdf51e90 | |||
9bee9d20f7 | |||
7aee3b88eb | |||
d08184f5fe | |||
ae08232bfb | |||
2b5e4b57bd | |||
35ae13a490 | |||
74f55b4d3f | |||
abe9440021 | |||
6a95b94aaa | |||
21ee38d813 | |||
9681a906d5 | |||
2ca760bee6 | |||
da9f916daa | |||
bc05b83a24 | |||
620e0a9df6 | |||
38ad4f7098 | |||
05c7cacdd1 | |||
baa49271df | |||
e2cbe70966 | |||
6a98301cc9 | |||
81f1df7472 | |||
abc296cdcc | |||
4df5ec82ce | |||
3963ed8ff7 | |||
11141c878c | |||
b1a2046a7f | |||
e44322c9bf | |||
2e6462bf1b | |||
667d9c2be3 | |||
34a86229db | |||
7dd8dbeb5b | |||
b5fb98f01a | |||
f6cfa5cbb4 | |||
c1b95838f6 | |||
6cee608c91 | |||
d979fb6dc0 | |||
ca2a33edc9 | |||
ea80d5eac2 | |||
51cf0970b3 | |||
9c8eb93446 | |||
3ac3a45aa5 | |||
36fcc0d5f6 | |||
6667b86650 | |||
9244efe351 | |||
538ca2a7c7 | |||
c5dd9439d5 | |||
2170c27b62 | |||
61582a0a33 | |||
65efe1f42c | |||
b2d3d43c97 | |||
4ce330c59e | |||
4ea60d36e5 | |||
95111ef8a1 | |||
145389768d | |||
be183206e6 | |||
8b853b7970 | |||
5450b78f71 | |||
a3283c71ef | |||
7231f5ff0b | |||
38a68ea946 | |||
bf9486edc2 | |||
aadfafaef9 | |||
c102978dd5 | |||
9784ade84f | |||
677f06961a | |||
57c3ea3dbe | |||
c01210d4fe | |||
64bbfed432 | |||
a482d9b078 | |||
08456dbb89 | |||
ea662b5c49 | |||
58a8fff895 | |||
bb302a90a6 | |||
99e34e9ee2 | |||
f1417c6bb1 | |||
729db347a2 | |||
f2465ca11f | |||
0294061c00 | |||
71e5892308 | |||
a1597047b4 | |||
d6a8889d84 | |||
070f1f3c6e | |||
234294d564 | |||
d1be8b43f6 | |||
0ed94ee52e | |||
f07564a452 | |||
37419886a1 | |||
b9f0a9ed88 | |||
d0f68bb5d1 | |||
11a350a114 | |||
778ac79c44 | |||
766c00c305 | |||
97cdfa662e | |||
4a08d5295e | |||
b77788b947 | |||
729116c9e5 | |||
d57d55a226 | |||
4cccdb8a98 | |||
54045f95ca | |||
ee6c7cbc59 | |||
00508dc778 | |||
a3ff1bfda7 | |||
f57888eb4b | |||
b2c703c173 | |||
9053b9635e | |||
b5e87a46b0 | |||
ddbdb94ba6 | |||
304e3d58ea | |||
ca6a70e555 | |||
9a611b24f3 | |||
77adf26236 | |||
805472482e | |||
01411327b8 | |||
9daa900793 | |||
b862c055ae | |||
7860839220 | |||
e17e8bbb6f | |||
136d0683b0 | |||
0eded8f5a9 | |||
f62eb0fee9 | |||
077bf11e45 | |||
ebdbd6a84a | |||
69975c2fdd | |||
9aac6a65c6 | |||
7d7c206f24 | |||
15690d853c | |||
14ddca3875 | |||
a8b4df6eae | |||
0683fa6b97 | |||
808c680184 | |||
2bb0a61a89 | |||
dfa129febf | |||
3b49d233f8 | |||
f08d7df419 | |||
cd94d79cbb | |||
2314133112 | |||
06a47a7bd3 | |||
05a785ebd0 | |||
2ee5835186 | |||
19e1abe110 | |||
d19441f3ae | |||
6e3ee05cb6 | |||
51476ad06f | |||
1f998168e2 | |||
e72011f1da | |||
0df3e22e51 | |||
5a9530ccd4 | |||
0a4d119d86 | |||
2ee0e07bb6 | |||
533c9a4fe1 | |||
30c000116f | |||
dc649fe420 | |||
4a8ec173ae | |||
26d6fe9a4e | |||
46f5175a0d | |||
f704e7a602 | |||
8cefcaa55f | |||
164c6505f2 | |||
0a1b83c70f | |||
e60048eb96 | |||
8957eec475 | |||
e790af566c | |||
43fe0cd62e | |||
e22a296dc7 | |||
ac19ebc850 | |||
1e0060193a | |||
72271d905d | |||
8d39283d46 | |||
4364122804 | |||
3b6dbd6dc3 | |||
7c61fc37c5 | |||
f530b5237d | |||
9b9b6ade64 | |||
e184c1cdfb | |||
e0e4b43707 | |||
1d70b33894 | |||
44ea1be930 | |||
a1bf54fe16 | |||
88c57359b3 | |||
050564f717 | |||
75d59a9c9b | |||
9139c863bf | |||
84a1ec01bc | |||
36e59c5b5f | |||
5389b16c59 | |||
da3008af1c | |||
6637766554 | |||
2bc63631a4 | |||
5215721942 | |||
d02e14cb94 | |||
fa75b40dfd | |||
f32d8b7069 | |||
90e8527556 | |||
66377d3f27 | |||
c6ae93df80 | |||
55e9099091 | |||
c6ace29446 | |||
b0b885aacd | |||
3615b5d353 | |||
74c71e6283 | |||
9b07c5af05 | |||
cda1803e59 | |||
96eab7e12b | |||
916512fd47 | |||
58d3a37908 | |||
a19e252c9e | |||
63225ed0fd | |||
11cc9cbc7c | |||
36b9a0d42f | |||
e7da10ae58 | |||
f07047d1e8 | |||
c62aff76af | |||
1c20de4e9c | |||
4903eb4a4a | |||
b5981ab544 | |||
00e1dbfdfb | |||
df69ca4d56 | |||
cb631d4abb | |||
3c351d8300 | |||
ca66acac2b | |||
9fcf94b197 | |||
aa34000f0b | |||
d3c0f3c251 | |||
bb7edfee04 | |||
caa14c70ef | |||
3a0f72867f | |||
10d72742f5 | |||
1b9f8a87d3 | |||
d4a630902d | |||
fef5ec874b | |||
f2e347fec1 | |||
cd3c2484ee | |||
6a396ef5e3 | |||
eec1af1f52 | |||
99fc77b678 | |||
8bb311df51 | |||
a77df249c2 | |||
2883bca257 | |||
dd3af6886b | |||
33bcf2d1ea | |||
795fb0eb60 | |||
9e9d378bf1 | |||
4a6b0edce6 | |||
356225af14 | |||
331305e6c7 | |||
917b9475a5 | |||
e895fc954b | |||
6d3e18a6a1 | |||
79354f4faf | |||
28f8933c3c | |||
10356b4041 | |||
6a732ab1cd | |||
47322b35ff | |||
4c6d0386b9 | |||
a448172952 | |||
244ef0cb8f | |||
cc66a1f9c7 | |||
e2183400e5 | |||
afc531bd26 | |||
02cc1891f2 | |||
09e3ddbd57 | |||
d0fff562ea | |||
8ce5366e80 | |||
bfcda7cc02 | |||
c52aeb6618 | |||
f5ebfdca61 | |||
db93838729 | |||
bb835a6e8a | |||
52feba0e3a | |||
a1076c3108 | |||
bad068b20e | |||
ec41d461c0 | |||
a826cd6845 | |||
a950b6193a | |||
2cc4de2b23 | |||
03ef6996ff | |||
d1e5def30e | |||
02fbda2154 | |||
c21694a24a | |||
cb98336b0a | |||
97d25bc6a3 | |||
b36a1a9d0e | |||
cd44ff0aaa | |||
032571c326 | |||
6b890e3f82 | |||
9998845b21 | |||
7ee4385deb | |||
695277c9eb | |||
f014a79f8d | |||
1a6d47a633 | |||
12eed8f859 | |||
549092d9aa | |||
b245393bc4 | |||
dcd43a17ba | |||
b8088dc01a | |||
8e1b90ab43 | |||
614a1d74dd | |||
9ea1ed8559 | |||
3e1e234799 | |||
62f5ecd278 | |||
27733e2119 | |||
6be127e18b | |||
4bf1c23b3c | |||
608b8bb741 | |||
ef01eec36e | |||
5dbdd0e685 | |||
5273050ab3 | |||
fae3b02e5a | |||
3489e4af1e | |||
8e9bd0bbd5 | |||
3725b5bc34 | |||
998a59aa5e | |||
86c017674a | |||
cbae87cd11 | |||
5bc1f8d468 | |||
d3a355e164 | |||
45413c9d28 | |||
082ee8836f | |||
2f5bd5e6d7 | |||
639e0137cc | |||
2f898aa037 | |||
a43a225740 | |||
833c39969b | |||
e25dea27e7 | |||
dac962580b | |||
b12bf78c6d | |||
a44b005f7c | |||
4ea65dbe41 | |||
90ba51ee9c | |||
ecf44084dc | |||
9f49c663f8 | |||
c8c9a67485 | |||
837358df66 | |||
498bc7cebe | |||
9c3a4eb947 | |||
de1ecbaef4 | |||
4eb05efa7c | |||
ffa40227ec | |||
b44e1820a2 | |||
eb461481ed | |||
92f47cc9cb | |||
f82c6f7ab4 | |||
9f32e46921 | |||
eba96282d6 | |||
dd8423fbb5 | |||
76f992906d | |||
402d6de02d | |||
43e3ce1ed5 | |||
15050018f2 | |||
71d6394bc8 | |||
1d6791e4c2 | |||
7f0084a7ed | |||
1374a12f89 | |||
92937b8b3c | |||
d0ed5a8b59 | |||
2b318a1021 | |||
903e93ae01 | |||
06c7fe669c | |||
e2c0ee66e4 | |||
c6c62f956b | |||
8fa27fea6c | |||
03c56f388c | |||
4090922e7e | |||
8061dedba1 | |||
da2112b659 | |||
ed5386771a | |||
d248828523 | |||
fc0b86fe19 | |||
346036ec88 | |||
a5e1ce0e0b | |||
67b39b1a98 | |||
6fb7721798 | |||
0018fd469e | |||
019f7480e8 | |||
8e0b088deb | |||
452005381f | |||
9722ed99a3 | |||
ee6311e83d | |||
1471e52307 | |||
f1fc12d9cc | |||
ebbc42bebc | |||
4785ee8c32 | |||
ab40756c1a | |||
c88e737a84 | |||
def5ea7978 | |||
e69ab45044 | |||
25d0b4bbf1 | |||
f86f5ac6cc | |||
07ce365bfd | |||
f31c94e2ea | |||
933638d035 | |||
b0151afa9a | |||
5bbd4ae703 | |||
f2f7f532a0 | |||
80eedf7449 | |||
1b48e0d6e0 | |||
0420c548da | |||
6e98b75d13 | |||
e772cb00d1 | |||
b5d5275e9b | |||
a2d3d22b6e | |||
1ad8603cc2 | |||
aeaf535ea2 | |||
917726fecc | |||
49a5b4eb14 | |||
8946f3ea18 | |||
1947835c51 | |||
c7c537c8b8 | |||
4e2f954683 | |||
abb0184329 | |||
ee483ecfd3 | |||
99384b4c22 | |||
65503bc68d | |||
ec6aadb5ce | |||
5f642886d9 | |||
4c26e3c54d | |||
3ca3712bae | |||
a471e4b783 | |||
20ac7e62e9 | |||
3e61aa0835 | |||
c18f6fde80 | |||
8b9397a0ce | |||
678ff17d0f | |||
ea2016c208 | |||
b5bdf266d3 | |||
2309680c38 | |||
e99bf569c5 | |||
d3fd0f810a | |||
484dc9b08a | |||
3bd827d7da | |||
d425c72134 | |||
969cd16638 | |||
569be15705 | |||
03f54c5b02 | |||
06ddc8ec50 | |||
1528935008 | |||
7121bdef6b | |||
f6c376f20d | |||
241769d6fc | |||
7727651871 | |||
ce331826ac | |||
ae92c52d61 | |||
54aef5fe6f | |||
d22148b418 | |||
5dc75c9cea | |||
200e82decb | |||
50359dbaf4 | |||
7165f21a62 | |||
8aab828c65 | |||
c9f8c12f5b | |||
a347f8fa49 | |||
2d76bdd0f8 | |||
c5cdd56edb | |||
6901ab39ed | |||
b851b7f431 | |||
ccaa99115c | |||
813de15e85 | |||
fa33181fa9 | |||
d4324dc0cb | |||
ccc27bcc14 | |||
014c1673c6 | |||
3a3319ff52 | |||
5b54ec8fb5 | |||
e690556286 | |||
660956917f | |||
3a5201747b | |||
b338e8a83f | |||
5584d56b6a | |||
c925498120 | |||
75615cf503 | |||
39f708b0fc | |||
ac32077221 | |||
a5902acacd | |||
c7c08b7511 | |||
7de915d47b | |||
9107547501 | |||
95dc76ca19 | |||
49c2a9b372 | |||
b378cabfc7 | |||
4263dbef31 | |||
32fc6ae2eb | |||
238cb0077f | |||
f5a06b6494 | |||
2c01329085 | |||
502de89ab1 | |||
128de6750c | |||
e59e2d9f0b | |||
2504b8391b | |||
330ea7d210 | |||
1edd173a29 | |||
98d873a7f9 | |||
09175b84df | |||
177e19632a | |||
8e6207f3e9 | |||
ff3a97f6cf | |||
b8e155ab40 | |||
b8e7df198d | |||
34311e3181 | |||
46115d3f04 | |||
c1d25d2394 | |||
880cea5a56 | |||
e7205d9cc2 | |||
f456feb3ff | |||
3f83beedb7 | |||
e6c9b1d9bd | |||
b46114f4fa | |||
8d77e2ba22 | |||
cb3900921f | |||
ae2021583d | |||
36cd88e6b7 | |||
517b0908da | |||
b23b3e4d21 | |||
883fc5dde0 | |||
9d044329f6 | |||
d1e9e74cb8 | |||
98a87ee75f | |||
331491077d | |||
913c3a6636 | |||
fbaf5fe355 | |||
804c932f60 | |||
cef6d1d1b6 | |||
e4e7ab1135 | |||
6ca30df8c4 | |||
a340d4ed8e | |||
ca7cb94358 | |||
54779b25f5 | |||
44d7652171 | |||
c9ed15b682 | |||
8faad646ae | |||
1d50bc3382 | |||
da4af041af | |||
e2ff408f2f | |||
50d1500dfc | |||
94441f93a5 | |||
5f712fbf3c | |||
1c757f10e0 | |||
0508d5f643 | |||
d9986b7a2f | |||
3d79e7a136 | |||
52fb1237ec | |||
8a7197726e | |||
b7f5458684 | |||
52710f3810 | |||
a54de07260 | |||
aa2c8d101e | |||
1441fd93b9 | |||
4a585e8920 | |||
8c4245a09d | |||
e4af16989a | |||
5dc0944fe8 | |||
b4d24f4377 | |||
67be47b8db | |||
e382982d32 | |||
b09b74b5da | |||
c628bdb7a6 | |||
2fcf6fb0fd | |||
4f3fc9ffd0 | |||
15839a7399 | |||
26b3a14a63 | |||
f2f0799df1 | |||
6c99c32100 | |||
93d25a2a34 | |||
88f5ec59d7 | |||
586d3c4db7 | |||
f45fb56e15 | |||
8fe153c7c1 | |||
36a8720fbb | |||
9cbfdc94d9 | |||
091923764d | |||
dc39caed1e | |||
bcd7d1f007 | |||
40d4dc0474 | |||
02ac30c0d0 | |||
518bc92673 | |||
a5b92e316c | |||
828c7b66a0 | |||
93474eaa06 | |||
237f366aa2 | |||
714bcf28d5 | |||
420eeb4d68 | |||
bc6daf4a2e | |||
6f7832c09b | |||
bef67fa275 | |||
05d7198667 | |||
df0bfc14e5 | |||
3f28f7451f | |||
dbb9199d6f | |||
72cb3b03af | |||
d0085f00ed | |||
43734f027b | |||
f799375635 | |||
65704bbf01 | |||
9cb3882efa | |||
a0833ca691 | |||
a4f197f608 | |||
bb903cab40 | |||
92f765bc47 | |||
742889a035 | |||
24453ebcc3 | |||
8b8ab1bf5c | |||
e9bc9b8675 | |||
eeaa27c7ca | |||
ccea1755fc | |||
c32a5d602b | |||
2a04f2ca4d | |||
37c80e8ef5 | |||
1dce62e42a | |||
ec222378c4 | |||
ac930a1c6a | |||
5ccd5ad56e | |||
67da90530b | |||
b7f3753615 | |||
d21d38509c | |||
a59e1c0345 | |||
7ab613b394 | |||
c00ab0fbe2 | |||
87451b1223 | |||
d2b61229a3 | |||
980584020a | |||
a43d0dafa5 | |||
d5c1e7e579 | |||
55bdf0d618 | |||
44f7c13ad4 | |||
7bd1a3c8ac | |||
4f1981df03 | |||
8689a998aa | |||
079bb8d722 | |||
65c0b6c7da | |||
84958af4ce | |||
c53b59914b | |||
8ffd9ab2d9 | |||
0305caf504 | |||
3012e4ffe0 | |||
585f3c3d3e | |||
f1d07dfbed | |||
cddfc55110 | |||
a2ce072ae7 | |||
439563c5d6 | |||
962617b4f4 | |||
4a202f0f7e | |||
6e6b12519a | |||
f5f7654f4b | |||
5ac4c48ad1 | |||
7e18fd18b0 | |||
fb30c479ea | |||
f40dcbfe13 | |||
8755b5f353 | |||
691482bb28 | |||
4248bb8ce0 | |||
a5653e33d3 | |||
072dc1c7e6 | |||
d76fceae85 | |||
86107b2710 | |||
a473768bef | |||
f7fe13a177 | |||
acd29d22eb | |||
c228155514 | |||
b601b98d5c | |||
1cd3419688 |
13
.babelrc
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
{
|
||||||
|
"plugins": [
|
||||||
|
[
|
||||||
|
"@babel/plugin-transform-runtime",
|
||||||
|
{
|
||||||
|
"corejs": {
|
||||||
|
"version": 3,
|
||||||
|
"proposals": true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
]
|
||||||
|
}
|
@ -15,7 +15,8 @@ jobs:
|
|||||||
executor: docker
|
executor: docker
|
||||||
steps:
|
steps:
|
||||||
- checkout
|
- checkout
|
||||||
- setup_remote_docker
|
- setup_remote_docker:
|
||||||
|
version: 19.03.13
|
||||||
- run:
|
- run:
|
||||||
name: Build
|
name: Build
|
||||||
command: |
|
command: |
|
||||||
@ -31,7 +32,7 @@ jobs:
|
|||||||
apk update && apk add jq
|
apk update && apk add jq
|
||||||
docker tag misskey/misskey misskey/misskey:$(cat package.json | jq -r .version)
|
docker tag misskey/misskey misskey/misskey:$(cat package.json | jq -r .version)
|
||||||
docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_PASSWORD
|
docker login -u $DOCKERHUB_USERNAME -p $DOCKERHUB_PASSWORD
|
||||||
docker push misskey/misskey
|
docker push -a misskey/misskey
|
||||||
else
|
else
|
||||||
echo -e '\033[0;33mAborted deploying to Docker Hub\033[0;39m'
|
echo -e '\033[0;33mAborted deploying to Docker Hub\033[0;39m'
|
||||||
fi
|
fi
|
||||||
|
@ -88,7 +88,9 @@ redis:
|
|||||||
#elasticsearch:
|
#elasticsearch:
|
||||||
# host: localhost
|
# host: localhost
|
||||||
# port: 9200
|
# port: 9200
|
||||||
# pass: null
|
# ssl: false
|
||||||
|
# user:
|
||||||
|
# pass:
|
||||||
|
|
||||||
# ┌───────────────┐
|
# ┌───────────────┐
|
||||||
#───┘ ID generation └───────────────────────────────────────────
|
#───┘ ID generation └───────────────────────────────────────────
|
||||||
@ -140,6 +142,11 @@ id: 'aid'
|
|||||||
# Proxy for HTTP/HTTPS
|
# Proxy for HTTP/HTTPS
|
||||||
#proxy: http://127.0.0.1:3128
|
#proxy: http://127.0.0.1:3128
|
||||||
|
|
||||||
|
#proxyBypassHosts: [
|
||||||
|
# 'example.com',
|
||||||
|
# '192.0.2.8'
|
||||||
|
#]
|
||||||
|
|
||||||
# Proxy for SMTP/SMTPS
|
# Proxy for SMTP/SMTPS
|
||||||
#proxySmtp: http://127.0.0.1:3128 # use HTTP/1.1 CONNECT
|
#proxySmtp: http://127.0.0.1:3128 # use HTTP/1.1 CONNECT
|
||||||
#proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4
|
#proxySmtp: socks4://127.0.0.1:1080 # use SOCKS4
|
||||||
@ -147,3 +154,6 @@ id: 'aid'
|
|||||||
|
|
||||||
# Media Proxy
|
# Media Proxy
|
||||||
#mediaProxy: https://example.com/proxy
|
#mediaProxy: https://example.com/proxy
|
||||||
|
|
||||||
|
# Sign to ActivityPub GET request (default: false)
|
||||||
|
#signToActivityPubGet: true
|
||||||
|
@ -5,8 +5,10 @@
|
|||||||
.vscode
|
.vscode
|
||||||
Dockerfile
|
Dockerfile
|
||||||
build/
|
build/
|
||||||
|
built/
|
||||||
db/
|
db/
|
||||||
docker-compose.yml
|
docker-compose.yml
|
||||||
elasticsearch/
|
elasticsearch/
|
||||||
node_modules/
|
node_modules/
|
||||||
redis/
|
redis/
|
||||||
|
files/
|
||||||
|
18
.github/workflows/docker.yml
vendored
@ -1,18 +0,0 @@
|
|||||||
name: Docker build
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- master
|
|
||||||
- develop
|
|
||||||
pull_request:
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
build:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
|
|
||||||
steps:
|
|
||||||
- uses: actions/checkout@v1
|
|
||||||
- name: Pull previous build result (for cache)
|
|
||||||
run: docker pull misskey/misskey:latest
|
|
||||||
- name: Build docker container
|
|
||||||
run: docker build --cache-from misskey/misskey:latest -t misskey/misskey .
|
|
15
.github/workflows/nodejs.yml
vendored
@ -12,7 +12,7 @@ jobs:
|
|||||||
|
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
node-version: [11.10.x, 12.x]
|
node-version: [12.x, 14.x, 15.x]
|
||||||
|
|
||||||
services:
|
services:
|
||||||
postgres:
|
postgres:
|
||||||
@ -21,13 +21,14 @@ jobs:
|
|||||||
- 5432:5432
|
- 5432:5432
|
||||||
env:
|
env:
|
||||||
POSTGRES_DB: test-misskey
|
POSTGRES_DB: test-misskey
|
||||||
|
POSTGRES_HOST_AUTH_METHOD: trust
|
||||||
redis:
|
redis:
|
||||||
image: redis:alpine
|
image: redis:alpine
|
||||||
ports:
|
ports:
|
||||||
- 6379:6379
|
- 6379:6379
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v1
|
- uses: actions/checkout@v2
|
||||||
- name: Use Node.js ${{ matrix.node-version }}
|
- name: Use Node.js ${{ matrix.node-version }}
|
||||||
uses: actions/setup-node@v1
|
uses: actions/setup-node@v1
|
||||||
with:
|
with:
|
||||||
@ -40,3 +41,13 @@ jobs:
|
|||||||
run: yarn build
|
run: yarn build
|
||||||
- name: Test
|
- name: Test
|
||||||
run: yarn 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
|
||||||
|
2
.gitignore
vendored
@ -12,7 +12,7 @@ report.*.json
|
|||||||
# config
|
# config
|
||||||
/.config/*
|
/.config/*
|
||||||
!/.config/example.yml
|
!/.config/example.yml
|
||||||
!/.config/mongo_initdb_example.js
|
!/.config/docker_example.env
|
||||||
|
|
||||||
# misskey
|
# misskey
|
||||||
/build
|
/build
|
||||||
|
7
.mocharc.json
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
{
|
||||||
|
"extension": ["ts","js","cjs","mjs"],
|
||||||
|
"require": "ts-node/register",
|
||||||
|
"slow": 1000,
|
||||||
|
"timeout": 30000,
|
||||||
|
"exit": true
|
||||||
|
}
|
@ -1 +1 @@
|
|||||||
v12.11.1
|
v14.15.4
|
||||||
|
1962
CHANGELOG.md
@ -1,6 +1,12 @@
|
|||||||
# Contribution guide
|
# Contribution guide
|
||||||
:v: Thanks for your contributions :v:
|
:v: Thanks for your contributions :v:
|
||||||
|
|
||||||
|
## When you contribute...
|
||||||
|
- 任意のIssueについて、せっかく実装してくださっても、実装方法や設計の認識が揃ってないとマージできない/しないことになりかねないので、初めにそのIssue上で着手することを宣言し、必要に応じて他メンバーと実装方法や設計のすり合わせを行ってください。宣言することは作業が他の人と被るのを防止する効果もあります。
|
||||||
|
- 設計に迷った時はプロジェクトリーダーの判断を仰いでください。
|
||||||
|
- 時間や優先度の都合上、提出してくださったPRが長期間放置されることもありますがご理解ください。
|
||||||
|
- 温度感高めで見てほしいものは責付いてください。
|
||||||
|
|
||||||
## Issues
|
## Issues
|
||||||
Feature suggestions and bug reports are filed in https://github.com/syuilo/misskey/issues .
|
Feature suggestions and bug reports are filed in https://github.com/syuilo/misskey/issues .
|
||||||
|
|
||||||
@ -234,36 +240,6 @@ SQLでは配列のインデックスは**1始まり**。
|
|||||||
MongoDBの時とは違い、findOneでレコードを取得する時に対象レコードが存在しない場合 **`undefined`** が返ってくるので注意。
|
MongoDBの時とは違い、findOneでレコードを取得する時に対象レコードが存在しない場合 **`undefined`** が返ってくるので注意。
|
||||||
MongoDBは`null`で返してきてたので、その感覚で`if (x === null)`とか書くとバグる。代わりに`if (x == null)`と書いてください
|
MongoDBは`null`で返してきてたので、その感覚で`if (x === null)`とか書くとバグる。代わりに`if (x == null)`と書いてください
|
||||||
|
|
||||||
### 簡素な`undefined`チェック
|
|
||||||
データベースからレコードを取得するときに、プログラムの流れ的に(ほぼ)絶対`undefined`にはならない場合でも、`undefined`チェックしないとTypeScriptに怒られます。
|
|
||||||
でもいちいち複数行を費やして、発生するはずのない`undefined`をチェックするのも面倒なので、`ensure`というユーティリティ関数を用意しています。
|
|
||||||
例えば、
|
|
||||||
``` ts
|
|
||||||
const user = await Users.findOne(userId);
|
|
||||||
// この時点で user の型は User | undefined
|
|
||||||
if (user == null) {
|
|
||||||
throw 'missing user';
|
|
||||||
}
|
|
||||||
// この時点で user の型は User
|
|
||||||
```
|
|
||||||
という処理を`ensure`を使うと
|
|
||||||
``` ts
|
|
||||||
const user = await Users.findOne(userId).then(ensure);
|
|
||||||
// この時点で user の型は User
|
|
||||||
```
|
|
||||||
という風に書けます。
|
|
||||||
もちろん`ensure`内部でエラーを握りつぶすようなことはしておらず、万が一`undefined`だった場合はPromiseがRejectされ後続の処理は実行されません。
|
|
||||||
``` ts
|
|
||||||
const user = await Users.findOne(userId).then(ensure);
|
|
||||||
// 万が一 Users.findOne の結果が undefined だったら、ensure でエラーが発生するので
|
|
||||||
// この行に到達することは無い
|
|
||||||
// なので、.then(ensure) は
|
|
||||||
// if (user == null) {
|
|
||||||
// throw 'missing user';
|
|
||||||
// }
|
|
||||||
// の糖衣構文のような扱いです
|
|
||||||
```
|
|
||||||
|
|
||||||
### Migration作成方法
|
### Migration作成方法
|
||||||
```
|
```
|
||||||
npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前
|
npx ts-node ./node_modules/typeorm/cli.js migration:generate -n 変更の名前
|
||||||
|
4
COPYING
@ -13,3 +13,7 @@ https://github.com/twitter/twemoji-parser/blob/master/LICENSE.md
|
|||||||
Emoji keywords for Unicode 11 and below by Mu-An Chiou
|
Emoji keywords for Unicode 11 and below by Mu-An Chiou
|
||||||
License: MIT
|
License: MIT
|
||||||
https://github.com/muan/emojilib/blob/master/LICENSE
|
https://github.com/muan/emojilib/blob/master/LICENSE
|
||||||
|
|
||||||
|
RsaSignature2017 implementation by Transmute Industries Inc
|
||||||
|
License: MIT
|
||||||
|
https://github.com/transmute-industries/RsaSignature2017/blob/master/LICENSE
|
||||||
|
@ -1,9 +1,7 @@
|
|||||||
FROM node:12.11.1-alpine AS base
|
FROM node:14.15.4-alpine AS base
|
||||||
|
|
||||||
ENV NODE_ENV=production
|
ENV NODE_ENV=production
|
||||||
|
|
||||||
RUN npm i -g npm@latest
|
|
||||||
|
|
||||||
WORKDIR /misskey
|
WORKDIR /misskey
|
||||||
|
|
||||||
FROM base AS builder
|
FROM base AS builder
|
||||||
@ -12,6 +10,7 @@ RUN apk add --no-cache \
|
|||||||
autoconf \
|
autoconf \
|
||||||
automake \
|
automake \
|
||||||
file \
|
file \
|
||||||
|
git \
|
||||||
g++ \
|
g++ \
|
||||||
gcc \
|
gcc \
|
||||||
libc-dev \
|
libc-dev \
|
||||||
@ -22,7 +21,7 @@ RUN apk add --no-cache \
|
|||||||
python \
|
python \
|
||||||
zlib-dev
|
zlib-dev
|
||||||
|
|
||||||
COPY package.json ./
|
COPY package.json yarn.lock ./
|
||||||
RUN yarn install
|
RUN yarn install
|
||||||
COPY . ./
|
COPY . ./
|
||||||
RUN yarn build
|
RUN yarn build
|
||||||
|
191
README.md
@ -1,77 +1,62 @@
|
|||||||
<a href="https://xn--931a.moe/"><img src="https://github.com/syuilo/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/></a>
|
[](https://join.misskey.page/)
|
||||||
|
|
||||||
[](https://join.misskey.page/)
|
<h1 align="center">Misskey</h1>
|
||||||
================================================================
|
|
||||||
|
<div align="center">
|
||||||
|
|
||||||
[](https://circleci.com/gh/syuilo/misskey)
|
[](https://circleci.com/gh/syuilo/misskey)
|
||||||
[](https://david-dm.org/syuilo/misskey)
|
[](https://david-dm.org/syuilo/misskey)
|
||||||
[](http://makeapullrequest.com)
|
[](http://makeapullrequest.com)
|
||||||
|
[](https://github.com/humanetech-community/awesome-humane-tech)
|
||||||
|
|
||||||
**A forever evolving, sophisticated microblogging platform.**
|
**A forever evolving, interplanetary microblogging platform.**
|
||||||
|
|
||||||
<p align="justify">
|
|
||||||
<a href="https://join.misskey.page/">Misskey</a> is a decentralized microblogging platform born on Earth.
|
<a href="https://join.misskey.page/">Misskey</a> is a decentralized microblogging platform born on Earth.
|
||||||
Since it exists within the Fediverse (a universe where various social media platforms are organized),
|
Since it exists within the Fediverse (a universe where various social media platforms are organized),
|
||||||
it is mutually linked with other social media platforms.
|
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>
|
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>
|
||||||
</p>
|
|
||||||
|
|
||||||
<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>
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
:sparkles: Features
|
:sparkles: Features
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
<a href="https://xn--931a.moe/"><img src="https://github.com/syuilo/misskey/blob/develop/assets/ai-orig.png?raw=true" align="right" height="320px"/></a>
|
||||||
|
|
||||||
<img src="/assets/about/post.png" align="left" height="200px"/>
|
<h3>Posting</h3>
|
||||||
|
<p>
|
||||||
<h3 align="left">Posting</h3>
|
|
||||||
<p align="justify">
|
|
||||||
Post your ideas, discussion topics, fun moments, or anything else you want to share! Misskey supports text, emoji, pictures, videos, and polls!
|
Post your ideas, discussion topics, fun moments, or anything else you want to share! Misskey supports text, emoji, pictures, videos, and polls!
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
<img src="/assets/about/reaction.png" align="right" height="200px"/>
|
<h3 >Reactions</h3>
|
||||||
|
<p>
|
||||||
<h3 align="right">Reactions</h3>
|
|
||||||
<p align="justify">
|
|
||||||
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”.
|
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>
|
</p>
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
<img src="/assets/about/ui.png" align="left" height="200px"/>
|
<h3>Interface</h3>
|
||||||
|
<p>
|
||||||
<h3 align="left">Interface</h3>
|
|
||||||
<p align="justify">
|
|
||||||
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.
|
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>
|
</p>
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
<img src="/assets/about/drive.png" align="right" width="300px"/>
|
<h3>Misskey Drive</h3>
|
||||||
|
<p>
|
||||||
<h3 align="right">Misskey Drive</h3>
|
|
||||||
<p align="justify">
|
|
||||||
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!
|
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>
|
</p>
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
...and more! Experience Misskey with your own eyes at [misskey.io](https://misskey.io/) or join one of the [other instances](https://joinmisskey.github.io/) that are available.
|
...and more!
|
||||||
|
|
||||||
Screen shots
|
|
||||||
----------------------------------------------------------------
|
|
||||||
### Profile page
|
|
||||||
<img src="/assets/ss/user.jpg" width="500px"/>
|
|
||||||
|
|
||||||
### Explore users
|
|
||||||
<img src="/assets/ss/explore.jpg" width="500px"/>
|
|
||||||
|
|
||||||
:new: What's new
|
|
||||||
----------------------------------------------------------------
|
|
||||||
Please see the [Release notes](./CHANGELOG.md).
|
|
||||||
|
|
||||||
:package: Create your own instance
|
:package: Create your own instance
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
@ -89,6 +74,9 @@ Please see the [Contribution Guide](./CONTRIBUTING.md).
|
|||||||
<td><img src="https://avatars1.githubusercontent.com/u/30769358?s=460&v=4" alt="mei23" 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/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://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>
|
||||||
<tr>
|
<tr>
|
||||||
<td align="center"><a href="https://github.com/syuilo">@syuilo</a></td>
|
<td align="center"><a href="https://github.com/syuilo">@syuilo</a></td>
|
||||||
@ -96,101 +84,120 @@ Please see the [Contribution Guide](./CONTRIBUTING.md).
|
|||||||
<td align="center"><a href="https://github.com/mei23">@mei23</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/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/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>
|
</tr>
|
||||||
</table>
|
</table>
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
To receive updates of this repo, follow [@repo@misskey.io](https://misskey.io/@repo) on fediverse.
|
||||||
|
|
||||||
:heart: Backers
|
: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>
|
||||||
<td><img src="https://c8.patreon.com/2/200/27956229" alt="Oliver Maximilian Seidel" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/27956229" alt="Oliver Maximilian Seidel" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12190916/fb7fa7983c14425f890369535b1506a4/3.png?token-time=2145916800&token-hash=oH_i7gJjNT7Ot6j9JiVwy7ZJIBqACVnzLqlz4YrDAZA%3D" alt="weepjp" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12190916/fb7fa7983c14425f890369535b1506a4/3.png?token-time=2145916800&token-hash=oH_i7gJjNT7Ot6j9JiVwy7ZJIBqACVnzLqlz4YrDAZA%3D" alt="weepjp " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/605366/c9dc408fdcbf412fb183ca5b06235f8d/1.jpeg?token-time=2145916800&token-hash=oaqsjLqOFjWN5I9hm2epOaTXaEtKwQUy5OW-EpAz6-g%3D" alt="Jon Leibowitz" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19045173/cb91c0f345c24d4ebfd05f19906d5e26/1.png?token-time=2145916800&token-hash=o_zKBytJs_AxHwSYw_5R8eD0eSJe3RoTR3kR3Q0syN0%3D" alt="kiritan " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19045173/cb91c0f345c24d4ebfd05f19906d5e26/1.png?token-time=2145916800&token-hash=o_zKBytJs_AxHwSYw_5R8eD0eSJe3RoTR3kR3Q0syN0%3D" alt="kiritan" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/27648259" alt="みなしま " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/24430516/b1964ac5b9f746d2a12ff53dbc9aa40a/1.jpg?token-time=2145916800&token-hash=bmEiMGYpp3bS7hCCbymjGGsHBZM3AXuBOFO3Kro37PU%3D" alt="Eduardo Quiros" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/24430516/b1964ac5b9f746d2a12ff53dbc9aa40a/1.jpg?token-time=2145916800&token-hash=bmEiMGYpp3bS7hCCbymjGGsHBZM3AXuBOFO3Kro37PU%3D" alt="Eduardo Quiros" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/14215107/1cbe1912c26143919fa0faca16f12ce1/3.png?token-time=2145916800&token-hash=Zq1TCK2tdY7xudEm_aV70bc_wxmol6pNj3ZWbpFUNbI%3D" alt="Nesakko" width="100"></td>
|
|
||||||
<td><img src="https://c8.patreon.com/2/200/776209" alt="Denshi" width="100"></td>
|
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
<td><a href="https://www.patreon.com/user?u=20832595">Roujo</a></td>
|
<td><a href="https://www.patreon.com/user?u=20832595">Roujo </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=27956229">Oliver Maximilian Seidel</a></td>
|
<td><a href="https://www.patreon.com/user?u=27956229">Oliver Maximilian Seidel</a></td>
|
||||||
<td><a href="https://www.patreon.com/weepjp">weepjp</a></td>
|
<td><a href="https://www.patreon.com/weepjp">weepjp </a></td>
|
||||||
<td><a href="https://www.patreon.com/jonleibowitz">Jon Leibowitz</a></td>
|
<td><a href="https://www.patreon.com/user?u=19045173">kiritan </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=19045173">kiritan</a></td>
|
<td><a href="https://www.patreon.com/user?u=27648259">みなしま </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=24430516">Eduardo Quiros</a></td>
|
<td><a href="https://www.patreon.com/user?u=24430516">Eduardo Quiros</a></td>
|
||||||
<td><a href="https://www.patreon.com/Nesakko">Nesakko</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/user?u=776209">Denshi</a></td>
|
|
||||||
</tr></table>
|
</tr></table>
|
||||||
<table><tr>
|
<table><tr>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/14215107/1cbe1912c26143919fa0faca16f12ce1/4.jpg?token-time=2145916800&token-hash=BslMqDjTjz8KYANLvxL87agHTugHa0dMPUzT-hwR6Vk%3D" alt="Nesakko" width="100"></td>
|
||||||
|
<td><img src="https://c8.patreon.com/2/200/776209" alt="Demogrognard" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/3075183/c2ae575c604e420297f000ccc396e395/1.jpeg?token-time=2145916800&token-hash=O9qmPtpo6wWb0OuvnkEekhk_1WO2MTdytLr7ZgsAr80%3D" alt="Liaizon Wakest" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/3075183/c2ae575c604e420297f000ccc396e395/1.jpeg?token-time=2145916800&token-hash=O9qmPtpo6wWb0OuvnkEekhk_1WO2MTdytLr7ZgsAr80%3D" alt="Liaizon Wakest" width="100"></td>
|
||||||
<td><img src="https://c8.patreon.com/2/200/557245" alt="mkatze" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/557245" alt="mkatze " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/23915207/25428766ecd745478e600b3d7f871eb2/1.png?token-time=2145916800&token-hash=urCLLA4KjJZX92Y1CxcBP4d8bVTHGkiaPnQZp-Tqz68%3D" alt="kabo2468y" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/23915207/25428766ecd745478e600b3d7f871eb2/1.png?token-time=2145916800&token-hash=urCLLA4KjJZX92Y1CxcBP4d8bVTHGkiaPnQZp-Tqz68%3D" alt="kabo2468y " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/8249688/4aacf36b6b244ab1bc6653591b6640df/2.png?token-time=2145916800&token-hash=1ZEf2w6L34253cZXS_HlVevLEENWS9QqrnxGUAYblPo%3D" alt="AureoleArk" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/8249688/4aacf36b6b244ab1bc6653591b6640df/2.png?token-time=2145916800&token-hash=1ZEf2w6L34253cZXS_HlVevLEENWS9QqrnxGUAYblPo%3D" alt="AureoleArk " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5670915/ee175f0bfb6347ffa4ea101a8c097bff/1.jpg?token-time=2145916800&token-hash=mPLM9CA-riFHx-myr3bLZJuH2xBRHA9se5VbHhLIOuA%3D" alt="osapon" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5670915/ee175f0bfb6347ffa4ea101a8c097bff/1.jpg?token-time=2145916800&token-hash=mPLM9CA-riFHx-myr3bLZJuH2xBRHA9se5VbHhLIOuA%3D" alt="osapon " width="100"></td>
|
||||||
<td><img src="https://c8.patreon.com/2/200/16869916" alt="見当かなみ" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/16869916" alt="見当かなみ " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18899730/6a22797f68254034a854d69ea2445fc8/1.png?token-time=2145916800&token-hash=b_uj57yxo5VzkSOUS7oXE_762dyOTB_oxzbO6lFNG3k%3D" alt="YuzuRyo61" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/36813045/29876ea679d443bcbba3c3f16edab8c2/2.jpeg?token-time=2145916800&token-hash=YCKWnIhrV9rjUCV9KqtJnEqjy_uGYF3WMXftjUdpi7o%3D" alt="Wataru Manji (manji0)" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5788159/af42076ab3354bb49803cfba65f94bee/1.jpg?token-time=2145916800&token-hash=iSaxp_Yr2-ZiU2YVi9rcpZZj9mj3UvNSMrZr4CU4qtA%3D" alt="mewl hayabusa" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/11357794/923ce94cd8c44ba788ee931907881839/1.png?token-time=2145916800&token-hash=9nEQje_eMvUjq9a7L3uBqW-MQbS-rRMaMgd7UYVoFNM%3D" alt="mydarkstar" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/28779508/3cd4cb7f017f4ee0864341e3464d42f9/1.png?token-time=2145916800&token-hash=eGQtR15be44kgvh8fw2Jx8Db4Bv15YBp2ldxh0EKRxA%3D" alt="S Y" width="100"></td>
|
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
|
<td><a href="https://www.patreon.com/Nesakko">Nesakko</a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=776209">Demogrognard</a></td>
|
||||||
<td><a href="https://www.patreon.com/wakest">Liaizon Wakest</a></td>
|
<td><a href="https://www.patreon.com/wakest">Liaizon Wakest</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=557245">mkatze</a></td>
|
<td><a href="https://www.patreon.com/user?u=557245">mkatze </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=23915207">kabo2468y</a></td>
|
<td><a href="https://www.patreon.com/user?u=23915207">kabo2468y </a></td>
|
||||||
<td><a href="https://www.patreon.com/AureoleArk">AureoleArk</a></td>
|
<td><a href="https://www.patreon.com/AureoleArk">AureoleArk </a></td>
|
||||||
<td><a href="https://www.patreon.com/osapon">osapon</a></td>
|
<td><a href="https://www.patreon.com/osapon">osapon </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=16869916">見当かなみ</a></td>
|
<td><a href="https://www.patreon.com/user?u=16869916">見当かなみ </a></td>
|
||||||
<td><a href="https://www.patreon.com/Yuzulia">YuzuRyo61</a></td>
|
<td><a href="https://www.patreon.com/user?u=36813045">Wataru Manji (manji0)</a></td>
|
||||||
<td><a href="https://www.patreon.com/hs_sh_net">mewl hayabusa</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/mydarkstar">mydarkstar</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/user?u=28779508">S Y</a></td>
|
|
||||||
</tr></table>
|
</tr></table>
|
||||||
<table><tr>
|
<table><tr>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18899730/6a22797f68254034a854d69ea2445fc8/1.png?token-time=2145916800&token-hash=b_uj57yxo5VzkSOUS7oXE_762dyOTB_oxzbO6lFNG3k%3D" alt="YuzuRyo61 " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5788159/af42076ab3354bb49803cfba65f94bee/1.jpg?token-time=2145916800&token-hash=iSaxp_Yr2-ZiU2YVi9rcpZZj9mj3UvNSMrZr4CU4qtA%3D" alt="mewl hayabusa" width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/28779508/3cd4cb7f017f4ee0864341e3464d42f9/1.png?token-time=2145916800&token-hash=eGQtR15be44kgvh8fw2Jx8Db4Bv15YBp2ldxh0EKRxA%3D" alt="S Y" width="100"></td>
|
||||||
<td><img src="https://c8.patreon.com/2/200/16542964" alt="Takumi Sugita" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/16542964" alt="Takumi Sugita" width="100"></td>
|
||||||
<td><img src="https://c8.patreon.com/2/200/17866454" alt="sikyosyounin" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/17866454" alt="sikyosyounin " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3.png?token-time=2145916800&token-hash=KjfQL8nf3AIf6WqzLshBYAyX44piAqOAZiYXgZS_H6A%3D" alt="YUKIMOCHI" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5881381/6235ca5d3fb04c8e95ef5b4ff2abcc18/3.png?token-time=2145916800&token-hash=KjfQL8nf3AIf6WqzLshBYAyX44piAqOAZiYXgZS_H6A%3D" alt="YUKIMOCHI" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/26340354/08834cf767b3449e93098ef73a434e2f/2.png?token-time=2145916800&token-hash=nyM8DnKRL8hR47HQ619mUzsqVRpkWZjgtgBU9RY15Uc%3D" alt="totokoro" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/38837364/9421361c54c645ac8f5fc442a40c32e9/1.png?token-time=2145916800&token-hash=TUZB48Nem3BeUPLBH6s3P6WyKBnQOy0xKaDSTBBUNzA%3D" alt="xianon" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19356899/496b4681d33b4520bd7688e0fd19c04d/2.jpeg?token-time=2145916800&token-hash=_sTj3dUBOhn9qwiJ7F19Qd-yWWfUqJC_0jG1h0agEqQ%3D" alt="sheeta.s" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/26340354/08834cf767b3449e93098ef73a434e2f/2.png?token-time=2145916800&token-hash=nyM8DnKRL8hR47HQ619mUzsqVRpkWZjgtgBU9RY15Uc%3D" alt="totokoro " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5827393/59893c191dda408f9cabd0f20a3a5627/1.jpeg?token-time=2145916800&token-hash=i9N05vOph-eP1LTLb9_npATjYOpntL0ZsHNaZFSsPmE%3D" alt="motcha" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13737140/1adf7835017d479280d90fe8d30aade2/1.png?token-time=2145916800&token-hash=0pdle8h5pDZrww0BDOjdz6zO-HudeGTh36a3qi1biVU%3D" alt="Satsuki Yanagi" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17880724/311738c8a48f4a6b9443c2445a75adde/1.jpg?token-time=2145916800&token-hash=nVAntpybQrznE0rg05keLrSE6ogPKJXB13rmrJng42c%3D" alt="takimura" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13100201/fc5be4fa90444f09a9c8a06f72385272/1.png?token-time=2145916800&token-hash=i8PjlgfOB2LPEdbtWyx8ZPsBKhGcNZqcw_FQmH71UGU%3D" alt="aqz tamaina" width="100"></td>
|
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
|
<td><a href="https://www.patreon.com/Yuzulia">YuzuRyo61 </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/hs_sh_net">mewl hayabusa</a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=28779508">S Y</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=16542964">Takumi Sugita</a></td>
|
<td><a href="https://www.patreon.com/user?u=16542964">Takumi Sugita</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=17866454">sikyosyounin</a></td>
|
<td><a href="https://www.patreon.com/user?u=17866454">sikyosyounin </a></td>
|
||||||
<td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td>
|
<td><a href="https://www.patreon.com/yukimochi">YUKIMOCHI</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=26340354">totokoro</a></td>
|
<td><a href="https://www.patreon.com/user?u=38837364">xianon</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=19356899">sheeta.s</a></td>
|
<td><a href="https://www.patreon.com/user?u=26340354">totokoro </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=5827393">motcha</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/user?u=13737140">Satsuki Yanagi</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/takimura">takimura</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/aqz">aqz tamaina</a></td>
|
|
||||||
</tr></table>
|
</tr></table>
|
||||||
<table><tr>
|
<table><tr>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/19356899/496b4681d33b4520bd7688e0fd19c04d/2.jpeg?token-time=2145916800&token-hash=_sTj3dUBOhn9qwiJ7F19Qd-yWWfUqJC_0jG1h0agEqQ%3D" alt="sheeta.s " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5827393/59893c191dda408f9cabd0f20a3a5627/1.jpeg?token-time=2145916800&token-hash=i9N05vOph-eP1LTLb9_npATjYOpntL0ZsHNaZFSsPmE%3D" alt="motcha " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/20494440/540beaf2445f408ea6597bc61e077bb3/1.png?token-time=2145916800&token-hash=UJ0JQge64Bx9XmN_qYA1inMQhrWf4U91fqz7VAKJeSg%3D" alt="axtuki1 " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13737140/1adf7835017d479280d90fe8d30aade2/1.png?token-time=2145916800&token-hash=0pdle8h5pDZrww0BDOjdz6zO-HudeGTh36a3qi1biVU%3D" alt="Satsuki Yanagi" width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/17880724/311738c8a48f4a6b9443c2445a75adde/1.jpg?token-time=2145916800&token-hash=nVAntpybQrznE0rg05keLrSE6ogPKJXB13rmrJng42c%3D" alt="takimura " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/13100201/fc5be4fa90444f09a9c8a06f72385272/1.png?token-time=2145916800&token-hash=i8PjlgfOB2LPEdbtWyx8ZPsBKhGcNZqcw_FQmH71UGU%3D" alt="aqz tamaina" width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/9109588/e3cffc48d20a4e43afe04123e696781d/3.png?token-time=2145916800&token-hash=T_VIUA0IFIbleZv4pIjiszZGnQonwn34sLCYFIhakBo%3D" alt="nafuchoco " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/16900731/619ab87cc08448439222631ebb26802f/1.gif?token-time=2145916800&token-hash=o27K7M02s1z-LkDUEO5Oa7cu-GviRXeOXxryi4o_6VU%3D" alt="Atsuko Tominaga" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/16900731/619ab87cc08448439222631ebb26802f/1.gif?token-time=2145916800&token-hash=o27K7M02s1z-LkDUEO5Oa7cu-GviRXeOXxryi4o_6VU%3D" alt="Atsuko Tominaga" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4389829/9f709180ac714651a70f74a82f3ffdb9/3.png?token-time=2145916800&token-hash=FTm3WVom4dJ9NwWMU4OpCL_8Yc13WiwEbKrDPyTZTPs%3D" alt="natalie" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4389829/9f709180ac714651a70f74a82f3ffdb9/3.png?token-time=2145916800&token-hash=FTm3WVom4dJ9NwWMU4OpCL_8Yc13WiwEbKrDPyTZTPs%3D" alt="natalie" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5923936/2a743cbfbff946c2af3f09026047c0da/2.png?token-time=2145916800&token-hash=h6yphW1qnM0n_NOWaf8qtszMRLXEwIxfk5beu4RxdT0%3D" alt="noellabo" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/26144593/9514b10a5c1b42a3af58621aee213d1d/1.png?token-time=2145916800&token-hash=v1PYRsjzu4c_mndN4Hvi_dlispZJsuGRCQeNS82pUSM%3D" alt="EBISUME" width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/2384390/5681180e1efb46a8b28e0e8d4c8b9037/1.jpg?token-time=2145916800&token-hash=SJcMy-Q1BcS940-LFUVOMfR7-5SgrzsEQGhYb3yowFk%3D" alt="CG" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5923936/2a743cbfbff946c2af3f09026047c0da/2.png?token-time=2145916800&token-hash=h6yphW1qnM0n_NOWaf8qtszMRLXEwIxfk5beu4RxdT0%3D" alt="noellabo " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18072312/98e894d960314fa7bc236a72a39488fe/1.jpg?token-time=2145916800&token-hash=7bkMqTwHPRsJPGAq42PYdDXDZBVGLqdgr1ZmBxX8GFQ%3D" alt="Hekovic" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/24641572/b4fd175424814f15b0ca9178d2d2d2e4/1.png?token-time=2145916800&token-hash=e2fyqdbuJbpCckHcwux7rbuW6OPkKdERcus0u2wIEWU%3D" alt="uroco @99" width="100"></td>
|
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/4503830/ccf2cc867ea64de0b524bb2e24b9a1cb/1.jpeg?token-time=2145916800&token-hash=L55UhJ0rcuNAH3w_ryeeGN4hC6taoOixyAhraEi0bzw%3D" alt="dansup" width="100"></td>
|
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=19356899">sheeta.s </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=5827393">motcha </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=20494440">axtuki1 </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=13737140">Satsuki Yanagi</a></td>
|
||||||
|
<td><a href="https://www.patreon.com/takimura">takimura </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/aqz">aqz tamaina</a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=9109588">nafuchoco </a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=16900731">Atsuko Tominaga</a></td>
|
<td><a href="https://www.patreon.com/user?u=16900731">Atsuko Tominaga</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=4389829">natalie</a></td>
|
<td><a href="https://www.patreon.com/user?u=4389829">natalie</a></td>
|
||||||
<td><a href="https://www.patreon.com/noellabo">noellabo</a></td>
|
<td><a href="https://www.patreon.com/user?u=26144593">EBISUME</a></td>
|
||||||
<td><a href="https://www.patreon.com/Corset">CG</a></td>
|
<td><a href="https://www.patreon.com/noellabo">noellabo </a></td>
|
||||||
<td><a href="https://www.patreon.com/hekovic">Hekovic</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/user?u=24641572">uroco @99</a></td>
|
|
||||||
<td><a href="https://www.patreon.com/dansup">dansup</a></td>
|
|
||||||
</tr></table>
|
</tr></table>
|
||||||
<table><tr>
|
<table><tr>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/2384390/5681180e1efb46a8b28e0e8d4c8b9037/1.jpg?token-time=2145916800&token-hash=SJcMy-Q1BcS940-LFUVOMfR7-5SgrzsEQGhYb3yowFk%3D" alt="CG " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/18072312/98e894d960314fa7bc236a72a39488fe/1.jpg?token-time=2145916800&token-hash=7bkMqTwHPRsJPGAq42PYdDXDZBVGLqdgr1ZmBxX8GFQ%3D" alt="Hekovic " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/24641572/b4fd175424814f15b0ca9178d2d2d2e4/1.png?token-time=2145916800&token-hash=e2fyqdbuJbpCckHcwux7rbuW6OPkKdERcus0u2wIEWU%3D" alt="uroco @99" width="100"></td>
|
||||||
|
<td><img src="https://c8.patreon.com/2/200/14661394" alt="Chandler " width="100"></td>
|
||||||
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1.png?token-time=2145916800&token-hash=hBayGfOmQH3kRMdNnDe4oCZD_9fsJWSt29xXR3KRMVk%3D" alt="Nokotaro Takeda" width="100"></td>
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/5731881/4b6038e6cda34c04b83a5fcce3806a93/1.png?token-time=2145916800&token-hash=hBayGfOmQH3kRMdNnDe4oCZD_9fsJWSt29xXR3KRMVk%3D" alt="Nokotaro Takeda" width="100"></td>
|
||||||
<td><img src="https://c8.patreon.com/2/200/23932002" alt="nenohi" width="100"></td>
|
<td><img src="https://c8.patreon.com/2/200/23932002" alt="nenohi " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/9481273/7fa89168e72943859c3d3c96e424ed31/4.jpeg?token-time=2145916800&token-hash=5w1QV1qXe-NdWbdFmp1H7O_-QBsSiV0haumk3XTHIEg%3D" alt="Efertone " width="100"></td>
|
||||||
|
<td><img src="https://c10.patreonusercontent.com/3/eyJ3IjoyMDB9/patreon-media/p/user/12531784/93a45137841849329ba692da92ac7c60/1.jpeg?token-time=2145916800&token-hash=vGe7wXGqmA8Q7m-kDNb6fyGdwk-Dxk4F-ut8ZZu51RM%3D" alt="Takashi Shibuya" width="100"></td>
|
||||||
</tr><tr>
|
</tr><tr>
|
||||||
|
<td><a href="https://www.patreon.com/Corset">CG </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/hekovic">Hekovic </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=24641572">uroco @99</a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=14661394">Chandler </a></td>
|
||||||
<td><a href="https://www.patreon.com/takenoko">Nokotaro Takeda</a></td>
|
<td><a href="https://www.patreon.com/takenoko">Nokotaro Takeda</a></td>
|
||||||
<td><a href="https://www.patreon.com/user?u=23932002">nenohi</a></td>
|
<td><a href="https://www.patreon.com/user?u=23932002">nenohi </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/efertone">Efertone </a></td>
|
||||||
|
<td><a href="https://www.patreon.com/user?u=12531784">Takashi Shibuya</a></td>
|
||||||
</tr></table>
|
</tr></table>
|
||||||
|
|
||||||
**Last updated:** Wed, 05 Feb 2020 00:42:12 UTC
|
**Last updated:** Sun, 26 Jul 2020 07:00:10 UTC
|
||||||
<!-- PATREON_END -->
|
<!-- PATREON_END -->
|
||||||
|
|
||||||
[backer-url]: #backers
|
[backer-url]: #backers
|
||||||
|
74
assets/about/banner.svg
Normal file
After Width: | Height: | Size: 35 KiB |
Before Width: | Height: | Size: 15 KiB After Width: | Height: | Size: 9.6 KiB |
BIN
assets/banner.afdesign
Normal file
Before Width: | Height: | Size: 11 KiB After Width: | Height: | Size: 9.1 KiB |
Before Width: | Height: | Size: 9.8 KiB After Width: | Height: | Size: 7.5 KiB |
Before Width: | Height: | Size: 47 KiB After Width: | Height: | Size: 20 KiB |
BIN
assets/mi-white.afdesign
Normal file
BIN
assets/mi-white.png
Normal file
After Width: | Height: | Size: 18 KiB |
BIN
assets/mi.afdesign
Normal file
@ -1,3 +1,7 @@
|
|||||||
files:
|
files:
|
||||||
- source: /locales/ja-JP.yml
|
- source: /locales/ja-JP.yml
|
||||||
translation: /locales/%locale%.yml
|
translation: /locales/%locale%.yml
|
||||||
|
update_option: update_as_unapproved
|
||||||
|
- source: /src/docs/ja-JP/*.md
|
||||||
|
translation: /src/docs/%locale%/%original_file_name%
|
||||||
|
update_option: update_as_unapproved
|
||||||
|
@ -13,6 +13,8 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- internal_network
|
- internal_network
|
||||||
- external_network
|
- external_network
|
||||||
|
volumes:
|
||||||
|
- ./files:/misskey/files
|
||||||
|
|
||||||
redis:
|
redis:
|
||||||
restart: always
|
restart: always
|
||||||
@ -24,7 +26,7 @@ services:
|
|||||||
|
|
||||||
db:
|
db:
|
||||||
restart: always
|
restart: always
|
||||||
image: postgres:11.2-alpine
|
image: postgres:12.2-alpine
|
||||||
networks:
|
networks:
|
||||||
- internal_network
|
- internal_network
|
||||||
env_file:
|
env_file:
|
||||||
|
@ -4,3 +4,30 @@ Docs for users are located in `src/docs`.
|
|||||||
|
|
||||||
これらのドキュメントはMisskeyの開発者またはMisskeyインスタンス運営者向けです。
|
これらのドキュメントはMisskeyの開発者またはMisskeyインスタンス運営者向けです。
|
||||||
利用者向けのドキュメントは`src/docs`にあります。
|
利用者向けのドキュメントは`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)
|
||||||
|
@ -3,7 +3,8 @@ Docker Guide
|
|||||||
|
|
||||||
This guide describes how to install and setup Misskey with Docker.
|
This guide describes how to install and setup Misskey with Docker.
|
||||||
|
|
||||||
[Japanese version also available - 日本語版もあります](./docker.ja.md)
|
- [Japanese version also available - 日本語版もあります](./docker.ja.md)
|
||||||
|
- [Simplified Chinese version also available - 简体中文版同样可用](./docker.zh.md)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -3,8 +3,9 @@ Guide Docker
|
|||||||
|
|
||||||
Ce guide explique comment installer et configurer Misskey avec Docker.
|
Ce guide explique comment installer et configurer Misskey avec Docker.
|
||||||
|
|
||||||
[Version japonaise également disponible - Japanese version also available - 日本語版もあります](./docker.ja.md)
|
- [Version japonaise également disponible - Japanese version also available - 日本語版もあります](./docker.ja.md)
|
||||||
[Version anglaise également disponible - English version also available - 英語版もあります](./docker.en.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)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -3,7 +3,8 @@ Dockerを使ったMisskey構築方法
|
|||||||
|
|
||||||
このガイドはDockerを使ったMisskeyセットアップ方法について解説します。
|
このガイドはDockerを使ったMisskeyセットアップ方法について解説します。
|
||||||
|
|
||||||
[英語版もあります - English version also available](./docker.en.md)
|
- [英語版もあります - English version also available](./docker.en.md)
|
||||||
|
- [简体中文版同样可用 - Simplified Chinese version also available](./docker.zh.md)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
|
96
docs/docker.zh.md
Normal file
@ -0,0 +1,96 @@
|
|||||||
|
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/syuilo/misskey.git`
|
||||||
|
|
||||||
|
2. 进入 misskey 文件夹。
|
||||||
|
|
||||||
|
`cd misskey`
|
||||||
|
|
||||||
|
3. 检查 [最新发布版](https://github.com/syuilo/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`
|
||||||
|
|
||||||
|
----------------------------------------------------------------
|
||||||
|
|
||||||
|
如果您有任何疑问或是困惑,欢迎与我们联系!
|
@ -39,8 +39,8 @@ server {
|
|||||||
#ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
|
#ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key;
|
||||||
|
|
||||||
# SSL protocol settings
|
# SSL protocol settings
|
||||||
ssl_protocols TLSv1 TLSv1.2;
|
ssl_protocols TLSv1.2;
|
||||||
ssl_ciphers ECDHE-RSA-AES256-GCM-SHA384:ECDHE-RSA-AES128-GCM-SHA256:ECDHE-RSA-AES256-SHA384:ECDHE-RSA-AES128-SHA256:ECDHE-RSA-AES256-SHA:ECDHE-RSA-AES128-SHA:AES128-SHA;
|
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;
|
ssl_prefer_server_ciphers on;
|
||||||
|
|
||||||
# Change to your upload limit
|
# Change to your upload limit
|
||||||
@ -50,11 +50,13 @@ server {
|
|||||||
location / {
|
location / {
|
||||||
proxy_pass http://127.0.0.1:3000;
|
proxy_pass http://127.0.0.1:3000;
|
||||||
proxy_set_header Host $host;
|
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-Real-IP $remote_addr;
|
||||||
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
|
||||||
proxy_set_header X-Forwarded-Proto https;
|
proxy_set_header X-Forwarded-Proto https;
|
||||||
proxy_http_version 1.1;
|
|
||||||
proxy_redirect off;
|
|
||||||
|
|
||||||
# For WebSocket
|
# For WebSocket
|
||||||
proxy_set_header Upgrade $http_upgrade;
|
proxy_set_header Upgrade $http_upgrade;
|
||||||
|
14
docs/manage.zh.md
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
# 运营指南
|
||||||
|
|
||||||
|
## 检查任务队列的状态
|
||||||
|
即将到来……
|
||||||
|
|
||||||
|
## 设置用户为管理员
|
||||||
|
``` shell
|
||||||
|
node built/tools/mark-admin (用户名)
|
||||||
|
```
|
||||||
|
|
||||||
|
样例
|
||||||
|
``` shell
|
||||||
|
node built/tools/mark-admin @syuilo
|
||||||
|
```
|
@ -4,7 +4,8 @@ Misskey Setup and Installation Guide
|
|||||||
We thank you for your interest in setting up your Misskey server!
|
We thank you for your interest in setting up your Misskey server!
|
||||||
This guide describes how to install and setup Misskey.
|
This guide describes how to install and setup Misskey.
|
||||||
|
|
||||||
[Japanese version also available - 日本語版もあります](./setup.ja.md)
|
- [Japanese version also available - 日本語版もあります](./setup.ja.md)
|
||||||
|
- [Simplified Chinese version also available - 简体中文版同样可用](./setup.zh.md)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
@ -22,8 +23,8 @@ adduser --disabled-password --disabled-login misskey
|
|||||||
Please install and setup these softwares:
|
Please install and setup these softwares:
|
||||||
|
|
||||||
#### Dependencies :package:
|
#### Dependencies :package:
|
||||||
* **[Node.js](https://nodejs.org/en/)** >= 11.10.1
|
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** >= 10
|
* **[PostgreSQL](https://www.postgresql.org/)** (>= 10)
|
||||||
* **[Redis](https://redis.io/)**
|
* **[Redis](https://redis.io/)**
|
||||||
|
|
||||||
##### Optional
|
##### Optional
|
||||||
|
@ -4,7 +4,9 @@ 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 !
|
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.
|
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)
|
- [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)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
@ -22,8 +24,8 @@ adduser --disabled-password --disabled-login misskey
|
|||||||
Installez les paquets suivants :
|
Installez les paquets suivants :
|
||||||
|
|
||||||
#### Dépendences :package:
|
#### Dépendences :package:
|
||||||
* **[Node.js](https://nodejs.org/en/)** >= 11.10.1
|
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** >= 10
|
* **[PostgreSQL](https://www.postgresql.org/)** (>= 10)
|
||||||
* **[Redis](https://redis.io/)**
|
* **[Redis](https://redis.io/)**
|
||||||
|
|
||||||
##### Optionnels
|
##### Optionnels
|
||||||
|
@ -4,7 +4,8 @@ Misskey構築の手引き
|
|||||||
Misskeyサーバーの構築にご関心をお寄せいただきありがとうございます!
|
Misskeyサーバーの構築にご関心をお寄せいただきありがとうございます!
|
||||||
このガイドではMisskeyのインストール・セットアップ方法について解説します。
|
このガイドではMisskeyのインストール・セットアップ方法について解説します。
|
||||||
|
|
||||||
[英語版もあります - English version also available](./setup.en.md)
|
- [英語版もあります - English version also available](./setup.en.md)
|
||||||
|
- [简体中文版同样可用 - Simplified Chinese version also available](./setup.zh.md)
|
||||||
|
|
||||||
----------------------------------------------------------------
|
----------------------------------------------------------------
|
||||||
|
|
||||||
@ -22,7 +23,7 @@ adduser --disabled-password --disabled-login misskey
|
|||||||
これらのソフトウェアをインストール・設定してください:
|
これらのソフトウェアをインストール・設定してください:
|
||||||
|
|
||||||
#### 依存関係 :package:
|
#### 依存関係 :package:
|
||||||
* **[Node.js](https://nodejs.org/en/)** (11.10.1以上)
|
* **[Node.js](https://nodejs.org/en/)** (12.x, 14.x)
|
||||||
* **[PostgreSQL](https://www.postgresql.org/)** (10以上)
|
* **[PostgreSQL](https://www.postgresql.org/)** (10以上)
|
||||||
* **[Redis](https://redis.io/)**
|
* **[Redis](https://redis.io/)**
|
||||||
|
|
||||||
|
146
docs/setup.zh.md
Normal file
@ -0,0 +1,146 @@
|
|||||||
|
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/syuilo/misskey.git`
|
||||||
|
|
||||||
|
3. 进入 misskey 文件夹。
|
||||||
|
|
||||||
|
`cd misskey`
|
||||||
|
|
||||||
|
4. 检查 [最新发布版](https://github.com/syuilo/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` )
|
||||||
|
|
||||||
|
----------------------------------------------------------------
|
||||||
|
|
||||||
|
如果您有任何疑问或是困惑,欢迎与我们联系!
|
53
gulpfile.ts
@ -5,14 +5,13 @@
|
|||||||
import * as fs from 'fs';
|
import * as fs from 'fs';
|
||||||
import * as gulp from 'gulp';
|
import * as gulp from 'gulp';
|
||||||
import * as ts from 'gulp-typescript';
|
import * as ts from 'gulp-typescript';
|
||||||
import * as mocha from 'gulp-mocha';
|
|
||||||
import * as rimraf from 'rimraf';
|
import * as rimraf from 'rimraf';
|
||||||
import * as rename from 'gulp-rename';
|
import * as rename from 'gulp-rename';
|
||||||
const cleanCSS = require('gulp-clean-css');
|
import * as replace from 'gulp-replace';
|
||||||
const sass = require('gulp-dart-sass');
|
const terser = require('gulp-terser');
|
||||||
const fiber = require('fibers');
|
const cssnano = require('gulp-cssnano');
|
||||||
|
|
||||||
const locales = require('./locales');
|
const locales: { [x: string]: any } = require('./locales');
|
||||||
const meta = require('./package.json');
|
const meta = require('./package.json');
|
||||||
|
|
||||||
gulp.task('build:ts', () => {
|
gulp.task('build:ts', () => {
|
||||||
@ -29,17 +28,39 @@ gulp.task('build:copy:views', () =>
|
|||||||
gulp.src('./src/server/web/views/**/*').pipe(gulp.dest('./built/server/web/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/client/assets/fonts/'))
|
||||||
|
);
|
||||||
|
|
||||||
gulp.task('build:copy:locales', cb => {
|
gulp.task('build:copy:locales', cb => {
|
||||||
fs.mkdirSync('./built/client/assets/locales', { recursive: true });
|
fs.mkdirSync('./built/client/assets/locales', { recursive: true });
|
||||||
|
|
||||||
|
const v = { '_version_': meta.version };
|
||||||
|
|
||||||
for (const [lang, locale] of Object.entries(locales)) {
|
for (const [lang, locale] of Object.entries(locales)) {
|
||||||
fs.writeFileSync(`./built/client/assets/locales/${lang}.${meta.version}.json`, JSON.stringify(locale), 'utf-8');
|
fs.writeFileSync(`./built/client/assets/locales/${lang}.${meta.version}.json`, JSON.stringify({ ...locale, ...v }), 'utf-8');
|
||||||
}
|
}
|
||||||
|
|
||||||
cb();
|
cb();
|
||||||
});
|
});
|
||||||
|
|
||||||
gulp.task('build:copy', gulp.parallel('build:copy:views', 'build:copy:locales', () =>
|
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())
|
||||||
|
.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([
|
gulp.src([
|
||||||
'./src/emojilist.json',
|
'./src/emojilist.json',
|
||||||
'./src/server/web/views/**/*',
|
'./src/server/web/views/**/*',
|
||||||
@ -56,13 +77,6 @@ gulp.task('cleanall', gulp.parallel('clean', cb =>
|
|||||||
rimraf('./node_modules', cb)
|
rimraf('./node_modules', cb)
|
||||||
));
|
));
|
||||||
|
|
||||||
gulp.task('build:client:styles', () =>
|
|
||||||
gulp.src('./src/client/style.scss')
|
|
||||||
.pipe(sass({ fiber }))
|
|
||||||
.pipe(cleanCSS())
|
|
||||||
.pipe(gulp.dest('./built/client/assets/'))
|
|
||||||
);
|
|
||||||
|
|
||||||
gulp.task('copy:client', () =>
|
gulp.task('copy:client', () =>
|
||||||
gulp.src([
|
gulp.src([
|
||||||
'./assets/**/*',
|
'./assets/**/*',
|
||||||
@ -82,7 +96,6 @@ gulp.task('copy:docs', () =>
|
|||||||
);
|
);
|
||||||
|
|
||||||
gulp.task('build:client', gulp.parallel(
|
gulp.task('build:client', gulp.parallel(
|
||||||
'build:client:styles',
|
|
||||||
'copy:client',
|
'copy:client',
|
||||||
'copy:docs'
|
'copy:docs'
|
||||||
));
|
));
|
||||||
@ -93,14 +106,4 @@ gulp.task('build', gulp.parallel(
|
|||||||
'build:client',
|
'build:client',
|
||||||
));
|
));
|
||||||
|
|
||||||
gulp.task('mocha', () =>
|
|
||||||
gulp.src('./test/**/*.ts')
|
|
||||||
.pipe(mocha({
|
|
||||||
exit: true,
|
|
||||||
require: 'ts-node/register'
|
|
||||||
} as any))
|
|
||||||
);
|
|
||||||
|
|
||||||
gulp.task('test', gulp.task('mocha'));
|
|
||||||
|
|
||||||
gulp.task('default', gulp.task('build'));
|
gulp.task('default', gulp.task('build'));
|
||||||
|
611
locales/ar-SA.yml
Normal file
@ -0,0 +1,611 @@
|
|||||||
|
---
|
||||||
|
_lang_: "العربية"
|
||||||
|
introMisskey: "اهلا بك! ميسكي هو منصة تدوين مصغر لا مركزية ومفتوحة المصدر.\nيمكنك مشاركة \"ملاحظات\" عن ما يجري حولك، وإخبار الجميع عن نفسك 📡\nتسمح لك \"الانفعالات\" بتعبير عن شعورك حول ملاحظات الآخرين 👍\nاكتشف عالمًا جديدًا 🚀"
|
||||||
|
monthAndDay: "{day}/{month}"
|
||||||
|
search: "البحث"
|
||||||
|
notifications: "الإشعارات"
|
||||||
|
username: "اسم المستخدم"
|
||||||
|
password: "الكلمة السرية"
|
||||||
|
fetchingAsApObject: "جارٍ جلبه مِن الفديفرس…"
|
||||||
|
ok: " حسناً"
|
||||||
|
gotIt: "فهِمت"
|
||||||
|
cancel: " إلغاء"
|
||||||
|
enterUsername: "أدخِل إسم مسخدم"
|
||||||
|
noNotes: "لم يتم العثور على أية ملاحظات"
|
||||||
|
noNotifications: "ليس هناك أية اشعارات"
|
||||||
|
instance: "مثيل الخادم"
|
||||||
|
settings: "الاعدادات"
|
||||||
|
basicSettings: "الاعدادات الأساسية"
|
||||||
|
otherSettings: "إعدادات أخرى"
|
||||||
|
openInWindow: "افتح في نافذة جديدة"
|
||||||
|
profile: "الملف التعريفي"
|
||||||
|
timeline: "الخيط الزمني"
|
||||||
|
noAccountDescription: "لم يكتب هذا المستخدم سيرته بعد."
|
||||||
|
login: "لِج"
|
||||||
|
loggingIn: "جارٍ تسجيل الدخول"
|
||||||
|
logout: "الخروج"
|
||||||
|
signup: "أنشئ حسابًا"
|
||||||
|
uploading: "عملية الإرسال جارية"
|
||||||
|
save: "حفظ"
|
||||||
|
users: "المستخدمون"
|
||||||
|
addUser: "اضافة مستخدم"
|
||||||
|
favorite: "إضافة إلى المفضلة"
|
||||||
|
favorites: "المفضلات"
|
||||||
|
unfavorite: "إزالة من المفضلة"
|
||||||
|
favorited: "تمت الإضافة إلى المفضلة."
|
||||||
|
alreadyFavorited: "تمت إضافته بالفعل إلى المفضلة."
|
||||||
|
cantFavorite: "تعذرت الإضافة إلى المفضلة."
|
||||||
|
pin: "دبّسها على الصفحة الشخصية"
|
||||||
|
unpin: "ألغ تثبيتها من ملفك الشخصي"
|
||||||
|
copyContent: "انسخ المحتوى"
|
||||||
|
copyLink: "انسخ الرابط"
|
||||||
|
delete: "حذف"
|
||||||
|
deleteAndEdit: "إزالة وإعادة الصياغة"
|
||||||
|
deleteAndEditConfirm: "أمتأكد من حذف الملاحظة؟ ستفقد كل مشاركاتها، والتفاعلات، والردود عليها."
|
||||||
|
addToList: "أضفه إلى قائمة"
|
||||||
|
sendMessage: "أرسل رسالة"
|
||||||
|
copyUsername: "انسخ اسم المستخدم"
|
||||||
|
searchUser: "ابحث عن مستخدمين"
|
||||||
|
reply: "رد"
|
||||||
|
loadMore: "عرض المزيد"
|
||||||
|
showMore: "عرض المزيد"
|
||||||
|
youGotNewFollower: "يتابعك"
|
||||||
|
receiveFollowRequest: "تلقيت طلب متابعة"
|
||||||
|
followRequestAccepted: "قُبل طلب المتابعة"
|
||||||
|
mention: "أشر الى"
|
||||||
|
mentions: "الإشارات"
|
||||||
|
directNotes: "الملاحظات المباشرة"
|
||||||
|
importAndExport: "إستورد / صدر"
|
||||||
|
import: "استيراد"
|
||||||
|
export: "تصدير"
|
||||||
|
files: "الملفات"
|
||||||
|
download: "تنزيل"
|
||||||
|
driveFileDeleteConfirm: "أمتأكد من حذف ملف {name}؟ كل الملاحظات المُرفق بها هذا الملف ستحذف."
|
||||||
|
unfollowConfirm: "أمتأكد من إلغاء متابعة {name}؟"
|
||||||
|
lists: "القوائم"
|
||||||
|
noLists: "ليس لديك أية قائمة"
|
||||||
|
note: "ملاحظة"
|
||||||
|
notes: "الملاحظات"
|
||||||
|
following: "المتابَعون"
|
||||||
|
followers: "المتابِعين"
|
||||||
|
followsYou: "يتابعك"
|
||||||
|
createList: "إنشاء قائمة"
|
||||||
|
manageLists: "إدارة القوائم"
|
||||||
|
error: "خطأ"
|
||||||
|
somethingHappened: "حدث خطأ"
|
||||||
|
retry: "حاول مجددًا"
|
||||||
|
pageLoadError: "فشل تحميل الصفحة"
|
||||||
|
enterListName: "اسم القائمة"
|
||||||
|
privacy: "الخصوصية"
|
||||||
|
makeFollowManuallyApprove: "القبول يدويا طلبات الإشتراك"
|
||||||
|
defaultNoteVisibility: "مدى الرؤية الافتراضي"
|
||||||
|
follow: "تابِع"
|
||||||
|
followRequest: "طلب اشتراك"
|
||||||
|
followRequests: "طلبات الإشتراك"
|
||||||
|
unfollow: "إلغاء الاشتراك"
|
||||||
|
followRequestPending: "طلبات الإشتراك المعلّقة"
|
||||||
|
enterEmoji: "أدخل إيموجي"
|
||||||
|
unrenote: "إلغاء مشاركة الملاحظة"
|
||||||
|
quote: "اقتبس"
|
||||||
|
pinnedNote: "ملاحظة مدبسة"
|
||||||
|
pinned: "دبّسها على الصفحة الشخصية"
|
||||||
|
you: "أنت"
|
||||||
|
clickToShow: "اضغط للعرض"
|
||||||
|
sensitive: "محتوى حساس"
|
||||||
|
add: "إضافة"
|
||||||
|
reaction: "تفاعل"
|
||||||
|
rememberNoteVisibility: "تذكر إعدادت مدى رؤية الملاحظات"
|
||||||
|
attachCancel: "أزل المرفق"
|
||||||
|
enterFileName: "ادخل اسم الملف"
|
||||||
|
mute: "اكتم"
|
||||||
|
unmute: "إلغاء الكتم"
|
||||||
|
block: "احجب"
|
||||||
|
unblock: "إلغاء الحجب"
|
||||||
|
suspend: "علِق"
|
||||||
|
unsuspend: "ألغ التعليق"
|
||||||
|
blockConfirm: "أمتأكد من حجب هذا الحساب؟"
|
||||||
|
unblockConfirm: "أمتأكد من إلغاء حجب هذا الحساب؟"
|
||||||
|
selectList: "اختر قائمة"
|
||||||
|
editWidgetsExit: "تم"
|
||||||
|
customEmojis: "إيموجي مخصص"
|
||||||
|
addEmoji: "إضافة إيموجي"
|
||||||
|
cacheRemoteFiles: "خزن مؤقتا الملفات البعيدة"
|
||||||
|
autoAcceptFollowed: "اقبل طلبات المتابعة تلقائيا من الحسابات المتابَعة"
|
||||||
|
addAcount: "إضافة حساب"
|
||||||
|
loginFailed: "فشل الولوج"
|
||||||
|
showOnRemote: "رؤيته على مثيل الخادم البُعدي"
|
||||||
|
general: "الرئيسية"
|
||||||
|
wallpaper: "خلفية الشاشة"
|
||||||
|
setWallpaper: "استخدم خلفية الشاشة"
|
||||||
|
removeWallpaper: "إزالة خلفية الشاشة"
|
||||||
|
searchWith: "البحث: {q}"
|
||||||
|
youHaveNoLists: "لا تمتلك أية قائمة"
|
||||||
|
followConfirm: "أتريد متابعة {name}؟"
|
||||||
|
proxyAccount: "حساب وكيل البروكسي"
|
||||||
|
host: "المضيف"
|
||||||
|
selectUser: "حدّد مستخدمًا"
|
||||||
|
recipient: "المرسَل إليه·ها"
|
||||||
|
annotation: "التعليقات"
|
||||||
|
federation: "الفديرالية"
|
||||||
|
instances: "مثيل الخادم"
|
||||||
|
latestRequestSentAt: "آخر طلب أرسِل في"
|
||||||
|
latestRequestReceivedAt: "آخر طلب تُلقي في"
|
||||||
|
storageUsage: "مساحة التخزين المستخدمة"
|
||||||
|
charts: "المنحنيات البيانية"
|
||||||
|
perHour: "في الساعة"
|
||||||
|
perDay: "في اليوم"
|
||||||
|
stopActivityDelivery: "وقف إرسال النشاط"
|
||||||
|
blockThisInstance: "احجب مثيل الخادم هذا"
|
||||||
|
operations: "الإجراءات"
|
||||||
|
software: "البرنامج"
|
||||||
|
version: "الإصدار"
|
||||||
|
metadata: "البيانات الوصفية"
|
||||||
|
withNFiles: "{n} ملف (ملفات)"
|
||||||
|
monitor: "شاشة التحكم"
|
||||||
|
jobQueue: "قائمة الانتظار"
|
||||||
|
cpuAndMemory: "وحدة المعالجة المركزية والذاكرة"
|
||||||
|
network: "الشبكة"
|
||||||
|
disk: "قرص التخزين"
|
||||||
|
instanceInfo: "معلومات مثيل الخادم"
|
||||||
|
statistics: "الإحصائيات"
|
||||||
|
clearQueue: "تفريغ قائمة الإنتظار"
|
||||||
|
muteAndBlock: "تم كتمها / تم حجبها"
|
||||||
|
mutedUsers: "الحسابات التي تم كتمها"
|
||||||
|
blockedUsers: "الحسابات التي تم حظرها"
|
||||||
|
noUsers: "ليس هناك مستخدمون"
|
||||||
|
editProfile: "تعديل الملف التعريفي"
|
||||||
|
noteDeleteConfirm: "هل تريد حذف هذه الملاحظة؟"
|
||||||
|
pinLimitExceeded: "لا يمكنك تدبيس الملاحظات بعد الآن."
|
||||||
|
intro: "لقد انتهت عملية تنصيب Misskey. الرجاء إنشاء حساب إداري."
|
||||||
|
done: "تمّ"
|
||||||
|
processing: "المعالجة جارية"
|
||||||
|
preview: "معاينة"
|
||||||
|
default: "افتراضي"
|
||||||
|
noCustomEmojis: "ليس هناك إيموجيات"
|
||||||
|
federating: "الفديرالية جارية"
|
||||||
|
blocked: "محجوب"
|
||||||
|
suspended: "مُعلّق"
|
||||||
|
all: "الكل"
|
||||||
|
notResponding: "لا يستجيب"
|
||||||
|
changePassword: "تغيير الكلمة السرية"
|
||||||
|
security: "الأمان"
|
||||||
|
more: "المزيد!"
|
||||||
|
featured: "المتداولة"
|
||||||
|
usernameOrUserId: "اسم المستخدم أو معرّفه"
|
||||||
|
noSuchUser: "لم يُعثَر على المستخدم"
|
||||||
|
lookup: "البحث"
|
||||||
|
announcements: "الإعلانات"
|
||||||
|
imageUrl: "عنوان URL للصورة"
|
||||||
|
remove: "حذف"
|
||||||
|
removed: "تم حذفه بنجاح"
|
||||||
|
removeAreYouSure: "متأكد من أنك تريد حذف {x}؟"
|
||||||
|
deleteAreYouSure: "متأكد من أنك تريد حذف {x}؟"
|
||||||
|
resetAreYouSure: "هل تريد إعادة التعيين؟"
|
||||||
|
saved: "تم حفظه"
|
||||||
|
messaging: "الدردشة"
|
||||||
|
upload: "تحميل"
|
||||||
|
fromDrive: "من المخزن"
|
||||||
|
fromUrl: "من عنوان URL"
|
||||||
|
uploadFromUrl: "التحميل عبر URL"
|
||||||
|
uploadFromUrlDescription: "رابط الملف المراد تحميله "
|
||||||
|
uploadFromUrlRequested: "الرفع مطلوب"
|
||||||
|
uploadFromUrlMayTakeTime: "سيستغرق بعض الوقت لاتمام الرفع "
|
||||||
|
explore: "استكشاف"
|
||||||
|
games: "ألعاب Misskey"
|
||||||
|
messageRead: "مقروءة"
|
||||||
|
noMoreHistory: "لا يوجد المزيد من التاريخ"
|
||||||
|
startMessaging: "ابدأ الدردشة"
|
||||||
|
nUsersRead: "تمت القراءة من {n}"
|
||||||
|
agreeTo: "اوافق على {0}"
|
||||||
|
tos: "شروط الخدمة"
|
||||||
|
start: "البداية"
|
||||||
|
home: "الرئيسي"
|
||||||
|
activity: "النشاط"
|
||||||
|
images: "الصور"
|
||||||
|
birthday: "تاريخ الميلاد"
|
||||||
|
yearsOld: "{age} سنة"
|
||||||
|
registeredDate: "انظم في"
|
||||||
|
location: "المكان"
|
||||||
|
theme: "المظهر"
|
||||||
|
themeForLightMode: "الحلة في الوضع الفاتح"
|
||||||
|
themeForDarkMode: "الحلة في الوضع الداكن"
|
||||||
|
light: "فاتح"
|
||||||
|
dark: "داكن"
|
||||||
|
lightThemes: "الحلة الفاتحة"
|
||||||
|
darkThemes: "الحلة الداكنة"
|
||||||
|
syncDeviceDarkMode: "مطابقة الوضع المضلمومع اعدادات الجهاز"
|
||||||
|
drive: "قرص التخرين"
|
||||||
|
fileName: "اسم الملف"
|
||||||
|
selectFile: "اختر ملفًا"
|
||||||
|
selectFiles: "اختر ملفات"
|
||||||
|
selectFolder: "اختر مجلدًا"
|
||||||
|
selectFolders: "اختر مجلدات"
|
||||||
|
renameFile: "إعادة تسمية الملف"
|
||||||
|
folderName: "اسم المجلد"
|
||||||
|
createFolder: "أنشئ مجلدًا"
|
||||||
|
renameFolder: "إعادة تسمية المجلد"
|
||||||
|
deleteFolder: "احذف هذا المجلد"
|
||||||
|
addFile: "إضافة ملف"
|
||||||
|
emptyDrive: "قرص التخزين فارغ"
|
||||||
|
emptyFolder: "هذا المجلد فارغ"
|
||||||
|
unableToDelete: "لا يمكن حذفه"
|
||||||
|
inputNewFileName: "ادخل الإسم الجديد للملف"
|
||||||
|
inputNewFolderName: "ادخل الإسم الجديد للمجلد"
|
||||||
|
hasChildFilesOrFolders: "الان الملف غير فارغ. لا يمكن حذفه"
|
||||||
|
copyUrl: "انسخ عنوان URL"
|
||||||
|
rename: "إعادة التسمية"
|
||||||
|
avatar: "الصورة الرمزية"
|
||||||
|
banner: "الصورة الرأسية"
|
||||||
|
nsfw: "محتوى حساس"
|
||||||
|
whenServerDisconnected: "عند فقدان الاتصال بالخادم"
|
||||||
|
disconnectedFromServer: "قُطِع الإتصال بالخادم"
|
||||||
|
reload: "انعش"
|
||||||
|
doNothing: "تجاهل"
|
||||||
|
reloadConfirm: "هل ترغب في تحديث الجدول الزمني؟"
|
||||||
|
watch: "راقب"
|
||||||
|
unwatch: "إلغاء المراقبة"
|
||||||
|
accept: "السماح"
|
||||||
|
reject: "رفض"
|
||||||
|
normal: "عادي"
|
||||||
|
instanceName: "اسم مثيل الخادم"
|
||||||
|
instanceDescription: "وصف مثيل الخادم"
|
||||||
|
maintainerName: "المدير"
|
||||||
|
maintainerEmail: "عنوان بريد المدير الإلكتروني"
|
||||||
|
tosUrl: "عنوان URL لشروط الخدمة"
|
||||||
|
thisYear: "هذا العام"
|
||||||
|
thisMonth: "هذا الشهر"
|
||||||
|
today: "اليوم"
|
||||||
|
dayX: "{day}"
|
||||||
|
monthX: "{month}"
|
||||||
|
yearX: "{year}"
|
||||||
|
pages: "الصفحات"
|
||||||
|
integration: "دمج"
|
||||||
|
connectSerice: "أوصل"
|
||||||
|
disconnectSerice: "قطع الاتصال"
|
||||||
|
enableLocalTimeline: "تفعيل الخيط المحلي"
|
||||||
|
enableGlobalTimeline: "تفعيل الخيط الزمني الشامل"
|
||||||
|
disablingTimelinesInfo: "سيتمكن المسؤولون ومن تعديل دائمًا و من الوصول إلى جميع المخططات الزمنية ، حتى إذا لم يتم تمكينها."
|
||||||
|
registration: "إنشاء حساب"
|
||||||
|
enableRegistration: "تفعيل إنشاء الحسابات الجديدة"
|
||||||
|
invite: "دعوة"
|
||||||
|
basicInfo: "المعلومات الأساسية "
|
||||||
|
pinnedNotes: "ملاحظة مدبسة"
|
||||||
|
hcaptchaSiteKey: "مفتاح الموقع"
|
||||||
|
hcaptchaSecretKey: "المفتاح السري"
|
||||||
|
recaptcha: "reCAPTCHA"
|
||||||
|
enableRecaptcha: "تمكين reCAPTCHA"
|
||||||
|
recaptchaSiteKey: "مفتاح الموقع"
|
||||||
|
recaptchaSecretKey: "المفتاح السري"
|
||||||
|
antennas: "الهوائيات"
|
||||||
|
manageAntennas: "إدارة الهوائيات"
|
||||||
|
name: "الإسم"
|
||||||
|
antennaSource: "مصدر الهوائي"
|
||||||
|
antennaKeywords: "الكلمات المفتاحية للإستقبال"
|
||||||
|
withReplies: "بالردود"
|
||||||
|
notesAndReplies: "الملاحظات والردود"
|
||||||
|
withFiles: "بالمرفقات"
|
||||||
|
silence: "اكتم"
|
||||||
|
unsilence: "إلغاء الكتم"
|
||||||
|
popularUsers: "المستخدمون الشائعون"
|
||||||
|
exploreFediverse: "استكشف الفديفرس"
|
||||||
|
popularTags: "الوسوم الرائجة"
|
||||||
|
userList: "القوائم"
|
||||||
|
about: "عن"
|
||||||
|
aboutMisskey: "عن Misskey"
|
||||||
|
administrator: "المدير"
|
||||||
|
token: "الرمز المميز"
|
||||||
|
twoStepAuthentication: "الإستيثاق بعاملَيْن"
|
||||||
|
moderator: "مشرِف"
|
||||||
|
nUsersMentioned: "{n} مستخدمين تمت الإشارة إليهم"
|
||||||
|
securityKey: "مفتاح الأمان"
|
||||||
|
securityKeyName: "اسم المفتاح"
|
||||||
|
lastUsed: "آخر استخدام"
|
||||||
|
unregister: "إلغاء التسجيل"
|
||||||
|
passwordLessLogin: "لِج مِن دون كلمة سرية"
|
||||||
|
resetPassword: "أعد تعيين كلمتك السرية"
|
||||||
|
newPasswordIs: "كلمتك السرية الجديدة هي {password}"
|
||||||
|
share: "شارِك"
|
||||||
|
notFound: "غير موجود"
|
||||||
|
cacheClear: "مسح ذاكرة التخزين المؤقت"
|
||||||
|
markAsReadAllNotifications: "وضع جميع الإشعارات كأنها مقروءة"
|
||||||
|
help: "المساعدة"
|
||||||
|
inputMessageHere: "اكتب رسالتك هنا"
|
||||||
|
close: "اغلق"
|
||||||
|
group: "الفريق"
|
||||||
|
groups: "الفِرَق"
|
||||||
|
createGroup: "انشئ فريقًا"
|
||||||
|
invites: "دعوة"
|
||||||
|
groupName: "اسم الفريق"
|
||||||
|
members: "الأعضاء"
|
||||||
|
transfer: "نقل"
|
||||||
|
messagingWithUser: "الدردشة مع مستخدم آخر"
|
||||||
|
messagingWithGroup: "دردشة جماعية"
|
||||||
|
title: "العنوان"
|
||||||
|
text: "النص"
|
||||||
|
enable: "تشغيل"
|
||||||
|
next: "التالية"
|
||||||
|
retype: "أعد الكتابة"
|
||||||
|
noteOf: "ملاحظات {user}"
|
||||||
|
inviteToGroup: "دعوة إلى فريق"
|
||||||
|
noMessagesYet: "ليس هناك رسائل بعد"
|
||||||
|
newMessageExists: "لقد تلقيت رسالة جديدة"
|
||||||
|
invitations: "دعوة"
|
||||||
|
invitationCode: "رمز الدعوة"
|
||||||
|
checking: "التحقق جارٍ"
|
||||||
|
available: "متوفر"
|
||||||
|
unavailable: "غير متوفر"
|
||||||
|
tooShort: "قصير جدًا"
|
||||||
|
tooLong: "طويل جدًا"
|
||||||
|
weakPassword: "الكلمة السرية ضعيفة"
|
||||||
|
normalPassword: "الكلمة السرية جيدة"
|
||||||
|
strongPassword: "الكلمة السرية قوية"
|
||||||
|
passwordMatched: "التطابق صحيح!"
|
||||||
|
passwordNotMatched: "غير متطابقتان"
|
||||||
|
signinWith: "الولوج عبر {x}"
|
||||||
|
or: "أو"
|
||||||
|
uiLanguage: "لغة واجهة المستخدم"
|
||||||
|
aboutX: "عن {x}"
|
||||||
|
useOsNativeEmojis: "استخدم الإيموجيات الخاصة بنظام التشغيل"
|
||||||
|
youHaveNoGroups: "لا تمتلك أية فِرَق"
|
||||||
|
noHistory: "السجل فارغ"
|
||||||
|
signinHistory: "تاريخ تسجيل الدخول"
|
||||||
|
doing: "انتظر لحظة"
|
||||||
|
category: "الفئات"
|
||||||
|
tags: "الوسوم"
|
||||||
|
docSource: "مصدر هذا المستند"
|
||||||
|
createAccount: "أنشئ حسابًا"
|
||||||
|
existingAcount: "الحسابات الموجودة"
|
||||||
|
regenerate: "أعِد التوليد"
|
||||||
|
fontSize: "حجم الخط"
|
||||||
|
openImageInNewTab: "إفتح الصورة بصفحة جديدة"
|
||||||
|
dashboard: "لوحة التحكم"
|
||||||
|
local: "المحلي"
|
||||||
|
remote: "بُعدي"
|
||||||
|
total: "المجموع"
|
||||||
|
weekOverWeekChanges: "أسبوعيا"
|
||||||
|
dayOverDayChanges: "يوميا"
|
||||||
|
appearance: "المظهر"
|
||||||
|
accountSettings: "إعدادات الحساب"
|
||||||
|
promotion: "ترقية"
|
||||||
|
promote: "روِّج"
|
||||||
|
numberOfDays: "عدد الأيام"
|
||||||
|
hideThisNote: "إخفاء هذه الملاحظة"
|
||||||
|
deleteAll: "حذف الكل"
|
||||||
|
sounds: "الرنات"
|
||||||
|
listen: "استمع"
|
||||||
|
none: "لا شيء"
|
||||||
|
volume: "مستوى الصوت"
|
||||||
|
details: "التفاصيل"
|
||||||
|
chooseEmoji: "اختر إيموجي"
|
||||||
|
recentUsed: "المستخدمة مؤخرا"
|
||||||
|
install: "التثبيت"
|
||||||
|
uninstall: "إلغاء التثبيت"
|
||||||
|
installedApps: "التطبيقات المُخوّلة"
|
||||||
|
lastUsedDate: "آخر استخدام"
|
||||||
|
state: "الحالة"
|
||||||
|
sort: "ترتيب حسب"
|
||||||
|
output: "الخارجة"
|
||||||
|
updateRemoteUser: "تحديث المعلومات عن المستخدم البعيد"
|
||||||
|
deleteAllFiles: "حذف كافة الملفات"
|
||||||
|
userSuspended: "تم تعليق هذا المستخدم."
|
||||||
|
userSilenced: "تم إسكات هذا المستخدم."
|
||||||
|
sidebar: "الشريط الجانبي"
|
||||||
|
addItem: "إضافة عنصر"
|
||||||
|
rooms: "الغرفة"
|
||||||
|
relays: "المُرَحلات"
|
||||||
|
addRelay: "إضافة مُرحّل"
|
||||||
|
addedRelays: "المرحلات التي تم إضافتها"
|
||||||
|
deletedNote: "ملاحظة محذوفة"
|
||||||
|
invisibleNote: "ملاحظة مخفية"
|
||||||
|
poll: "استطلاع رأي"
|
||||||
|
useCw: "إخفاء المحتوى"
|
||||||
|
themeEditor: "مصمم القوالب"
|
||||||
|
manage: "إدارة "
|
||||||
|
plugins: "الإضافات"
|
||||||
|
width: "العرض"
|
||||||
|
height: "الإرتفاع"
|
||||||
|
large: "كبير"
|
||||||
|
medium: "متوسط"
|
||||||
|
small: "صغير"
|
||||||
|
permission: "أذونات"
|
||||||
|
enableAll: "تشغيل الكل"
|
||||||
|
disableAll: "تعطيل الكل"
|
||||||
|
tokenRequested: "منح حق الوصول إلى الحساب"
|
||||||
|
notificationType: "أنواع الإشعارات"
|
||||||
|
edit: "التعديل"
|
||||||
|
email: "البريد الإلكتروني "
|
||||||
|
emailAddress: "عنوان البريد الالكتروني"
|
||||||
|
smtpHost: "المضيف"
|
||||||
|
smtpPort: "المنفذ"
|
||||||
|
smtpUser: "اسم المستخدم"
|
||||||
|
smtpPass: "الكلمة السرية"
|
||||||
|
makeActive: "تفعيل"
|
||||||
|
display: "المظهر"
|
||||||
|
copy: "نسخ"
|
||||||
|
metrics: "المقاييس"
|
||||||
|
public: "للعامة"
|
||||||
|
currentVersion: "الإصدار الحالي"
|
||||||
|
latestVersion: "آخر نسخة مستقرة"
|
||||||
|
usageAmount: "الإستخدام"
|
||||||
|
capacity: "السعة"
|
||||||
|
inUse: "مستخدم"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "يتابعك"
|
||||||
|
_mfm:
|
||||||
|
mention: "أشر الى"
|
||||||
|
quote: "اقتبس"
|
||||||
|
emoji: "إيموجي مخصص"
|
||||||
|
search: "البحث"
|
||||||
|
_reversi:
|
||||||
|
total: "المجموع"
|
||||||
|
_channel:
|
||||||
|
featured: "المتداوَلة"
|
||||||
|
_sidebar:
|
||||||
|
full: "كامل"
|
||||||
|
icon: "الصورة الرمزية"
|
||||||
|
hide: "إخفاء"
|
||||||
|
_theme:
|
||||||
|
explore: "استكشف قوالب المظهر"
|
||||||
|
install: "تنصيب قالب"
|
||||||
|
manage: "إدارة القوالب"
|
||||||
|
code: "شيفرة القالب"
|
||||||
|
installed: "تم تنصيب {name}"
|
||||||
|
make: "إنشاء قالب"
|
||||||
|
alpha: "الشفافية"
|
||||||
|
keys:
|
||||||
|
mention: "أشر الى"
|
||||||
|
messageBg: "خلفية الدردشة"
|
||||||
|
_sfx:
|
||||||
|
note: "الملاحظات"
|
||||||
|
noteMy: "ملاحظتي"
|
||||||
|
notification: "الإشعارات"
|
||||||
|
chat: "الدردشة"
|
||||||
|
_ago:
|
||||||
|
unknown: "مجهول"
|
||||||
|
future: "المستقبَل"
|
||||||
|
justNow: "اللحظة"
|
||||||
|
secondsAgo: "منذ {n} ثوانٍ"
|
||||||
|
minutesAgo: "منذ {n} دقائق"
|
||||||
|
hoursAgo: "منذ {n} ساعة"
|
||||||
|
daysAgo: "منذ {n} أيام"
|
||||||
|
weeksAgo: "منذ {n} أسابيع"
|
||||||
|
monthsAgo: "منذ {n} أشهر"
|
||||||
|
yearsAgo: "منذ {n} سنوات"
|
||||||
|
_time:
|
||||||
|
second: "ثا"
|
||||||
|
minute: "د"
|
||||||
|
hour: "سا"
|
||||||
|
day: "ي"
|
||||||
|
_tutorial:
|
||||||
|
title: "كيف تستخدم Misskey"
|
||||||
|
step1_1: "مرحبًا!"
|
||||||
|
_2fa:
|
||||||
|
registerKey: "تسجيل مفتاح أمان جديد"
|
||||||
|
_permissions:
|
||||||
|
"write:account": "تعديل معلومات حسابك"
|
||||||
|
"read:notifications": "اظهر الإشعارات"
|
||||||
|
_weekday:
|
||||||
|
sunday: "الأحد"
|
||||||
|
monday: "الإثنين"
|
||||||
|
tuesday: "الثلاثاء"
|
||||||
|
wednesday: "الأربعاء"
|
||||||
|
thursday: "الخميس"
|
||||||
|
friday: "الجمعة"
|
||||||
|
saturday: "السبت"
|
||||||
|
_widgets:
|
||||||
|
memo: "ملاحظة لاصقة"
|
||||||
|
notifications: "الإشعارات"
|
||||||
|
timeline: "الخيط الزمني"
|
||||||
|
calendar: "التقويم"
|
||||||
|
trends: "المتداوَلة"
|
||||||
|
clock: "الساعة"
|
||||||
|
rss: "تدفق RSS"
|
||||||
|
activity: "النشاط"
|
||||||
|
photos: "الصور"
|
||||||
|
federation: "الفديرالية"
|
||||||
|
jobQueue: "قائمة الانتظار"
|
||||||
|
_cw:
|
||||||
|
hide: "إخفاء"
|
||||||
|
show: "عرض المزيد"
|
||||||
|
chars: "{count} أحرف"
|
||||||
|
files: "{count} ملفات"
|
||||||
|
_poll:
|
||||||
|
noOnlyOneChoice: "تحتاج إلى خيارَين على الأقل"
|
||||||
|
choiceN: "الخيار {n}"
|
||||||
|
noMore: "لا يمكنك إضافة خيارات أخرى"
|
||||||
|
canMultipleVote: "السماح بالإجابات المتعددة"
|
||||||
|
expiration: "ينتهي استطلاع الرأي في"
|
||||||
|
infinite: "أبدًا"
|
||||||
|
at: "تاريخ الإنتهاء"
|
||||||
|
after: "ينتهي بعد…"
|
||||||
|
deadlineDate: "تاريخ الانتهاء"
|
||||||
|
deadlineTime: "سا"
|
||||||
|
duration: "المدة"
|
||||||
|
votesCount: "{n} أصوات"
|
||||||
|
totalVotes: "المجموع {n} أصوات"
|
||||||
|
vote: "قم بالتصويت"
|
||||||
|
showResult: "اعرض النتائج"
|
||||||
|
voted: "تم التصويت"
|
||||||
|
closed: "انتهى"
|
||||||
|
remainingDays: "{d} أيام و {h} ساعات متبقية"
|
||||||
|
remainingHours: "{h} ساعات و {m} دقائق متبقية"
|
||||||
|
remainingMinutes: "{m} دقائق و {s} ثوانٍ متبقية"
|
||||||
|
remainingSeconds: "{s} ثوانٍ متبقية"
|
||||||
|
_visibility:
|
||||||
|
public: "للعامة"
|
||||||
|
home: "الرئيسي"
|
||||||
|
followers: "المتابِعين"
|
||||||
|
specified: "مباشرة"
|
||||||
|
localOnly: "المحلي فقط"
|
||||||
|
_postForm:
|
||||||
|
replyPlaceholder: "رد على هذه الملاحظة…"
|
||||||
|
quotePlaceholder: "اقتبس هذه الملاحظة…"
|
||||||
|
_profile:
|
||||||
|
name: "الإسم"
|
||||||
|
username: "اسم المستخدم"
|
||||||
|
youCanIncludeHashtags: "يمكنك أيضًا إضافة وسوم إلى نبذتك التعريفية."
|
||||||
|
_exportOrImport:
|
||||||
|
allNotes: "كل الملاحظات"
|
||||||
|
followingList: "المتابَعون"
|
||||||
|
muteList: "اكتم"
|
||||||
|
blockingList: "احجب"
|
||||||
|
userLists: "القوائم"
|
||||||
|
_charts:
|
||||||
|
usersTotal: "مجموع عدد المستخدمين والمستخدمات"
|
||||||
|
activeUsers: "المستخدمون النشطون"
|
||||||
|
_timelines:
|
||||||
|
home: "الرئيسي"
|
||||||
|
local: "المحلي"
|
||||||
|
social: "الاجتماعي"
|
||||||
|
global: "الشامل"
|
||||||
|
_rooms:
|
||||||
|
_roomType:
|
||||||
|
default: "افتراضي"
|
||||||
|
_furnitures:
|
||||||
|
monitor: "شاشة التحكم"
|
||||||
|
banknote: "أوراق نقدية"
|
||||||
|
_pages:
|
||||||
|
blocks:
|
||||||
|
image: "الصور"
|
||||||
|
script:
|
||||||
|
categories:
|
||||||
|
list: "القوائم"
|
||||||
|
blocks:
|
||||||
|
_strReplace:
|
||||||
|
arg1: "نص"
|
||||||
|
arg3: "استُبدِل بـ"
|
||||||
|
_join:
|
||||||
|
arg1: "القوائم"
|
||||||
|
arg2: "فاصل"
|
||||||
|
add: "إضافة"
|
||||||
|
_randomPick:
|
||||||
|
arg1: "القوائم"
|
||||||
|
_dailyRandomPick:
|
||||||
|
arg1: "القوائم"
|
||||||
|
_seedRandomPick:
|
||||||
|
arg2: "القوائم"
|
||||||
|
_pick:
|
||||||
|
arg1: "القوائم"
|
||||||
|
_listLen:
|
||||||
|
arg1: "القوائم"
|
||||||
|
types:
|
||||||
|
array: "القوائم"
|
||||||
|
_notification:
|
||||||
|
youGotPoll: "شارك {name} في استطلاع الرأي"
|
||||||
|
youGotMessagingMessageFromUser: "لقد تلقيت رسالة مِن {name}"
|
||||||
|
youGotMessagingMessageFromGroup: "لقد أرسِلَت رسالة إلى الفريق {name}"
|
||||||
|
youWereFollowed: "يتابعك"
|
||||||
|
_types:
|
||||||
|
follow: "المتابَعون"
|
||||||
|
mention: "أشر الى"
|
||||||
|
quote: "اقتبس"
|
||||||
|
reaction: "تفاعل"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "الإشعارات"
|
||||||
|
tl: "الخيط الزمني"
|
||||||
|
antenna: "الهوائيات"
|
||||||
|
list: "القوائم"
|
||||||
|
mentions: "الإشارات"
|
||||||
|
direct: "مباشرة"
|
1561
locales/de-DE.yml
@ -1,6 +1,6 @@
|
|||||||
---
|
---
|
||||||
_lang_: "Español"
|
_lang_: "Español"
|
||||||
introMisskey: "¡Bienvenido/a! Misskey es un servicio de microblogging descentralizado de código abierto. Escribe \"notas\" para compartir lo que te ocurre ahora o para contar sobre ti a todos. 📡\nCon la función de \"reacciones\", puedes también añadir una reacción rápida a las notas de todos.👍\nExplora un nuevo mundo.🚀"
|
introMisskey: "¡Bienvenido/a! Misskey es un servicio de microblogging descentralizado de código abierto.\nEscribe \"notas\" para compartir lo que te ocurre ahora o para contar sobre ti a todos 📡\nCon la función de \"reacciones\", puedes también añadir una reacción rápida a las notas de todos 👍\nExplora un nuevo mundo 🚀"
|
||||||
monthAndDay: "{day}/{month}"
|
monthAndDay: "{day}/{month}"
|
||||||
search: "Buscar"
|
search: "Buscar"
|
||||||
notifications: "Notificaciones"
|
notifications: "Notificaciones"
|
||||||
@ -16,6 +16,9 @@ noNotes: "No hay notas"
|
|||||||
noNotifications: "No hay notificaciones"
|
noNotifications: "No hay notificaciones"
|
||||||
instance: "Instancia"
|
instance: "Instancia"
|
||||||
settings: "Configuración"
|
settings: "Configuración"
|
||||||
|
basicSettings: "Configuración Básica"
|
||||||
|
otherSettings: "Configuración avanzada"
|
||||||
|
openInWindow: "Abrir en una ventana"
|
||||||
profile: "Perfil"
|
profile: "Perfil"
|
||||||
timeline: "Linea de tiempo"
|
timeline: "Linea de tiempo"
|
||||||
noAccountDescription: "Este usuario no tiene una descripción"
|
noAccountDescription: "Este usuario no tiene una descripción"
|
||||||
@ -26,23 +29,31 @@ signup: "Registrarse"
|
|||||||
uploading: "Cargando"
|
uploading: "Cargando"
|
||||||
save: "Guardar"
|
save: "Guardar"
|
||||||
users: "Usuarios"
|
users: "Usuarios"
|
||||||
addUser: "Añadir usuario"
|
addUser: "Agregar usuario"
|
||||||
favorite: "Favorito"
|
favorite: "Favorito"
|
||||||
favorites: "Favoritos"
|
favorites: "Favoritos"
|
||||||
unfavorite: "Quitar de favoritos"
|
unfavorite: "Quitar de favoritos"
|
||||||
|
favorited: "Añadido a favoritos"
|
||||||
|
alreadyFavorited: "Ya había sido añadido a favoritos"
|
||||||
|
cantFavorite: "No fue añadido a favoritos"
|
||||||
pin: "Fijar"
|
pin: "Fijar"
|
||||||
unpin: "Desfijar"
|
unpin: "Desfijar"
|
||||||
copyContent: "Copiar contenido"
|
copyContent: "Copiar contenido"
|
||||||
copyLink: "Copiar enlace"
|
copyLink: "Copiar enlace"
|
||||||
delete: "Borrar"
|
delete: "Borrar"
|
||||||
|
deleteAndEdit: "Borrar y editar"
|
||||||
|
deleteAndEditConfirm: "¿Quieres borrar y editar este nota? Las reacciones, renotes, respuestas y todo desaparecerán."
|
||||||
addToList: "Agregar a lista"
|
addToList: "Agregar a lista"
|
||||||
sendMessage: "Énviar mensaje"
|
sendMessage: "Énviar mensaje"
|
||||||
copyUsername: "Copiar nombre de usuario"
|
copyUsername: "Copiar nombre de usuario"
|
||||||
|
searchUser: "Búsqueda de usuarios"
|
||||||
reply: "Responder"
|
reply: "Responder"
|
||||||
loadMore: "Ver más"
|
loadMore: "Ver más"
|
||||||
|
showMore: "Ver más"
|
||||||
youGotNewFollower: "te ha seguido"
|
youGotNewFollower: "te ha seguido"
|
||||||
receiveFollowRequest: "Recibiste una solicitud de seguimiento"
|
receiveFollowRequest: "Recibiste una solicitud de seguimiento"
|
||||||
followRequestAccepted: "La solicitud de seguimiento fue aceptada"
|
followRequestAccepted: "La solicitud de seguimiento fue aceptada"
|
||||||
|
mention: "Menciones"
|
||||||
mentions: "Menciones"
|
mentions: "Menciones"
|
||||||
directNotes: "Notas directas"
|
directNotes: "Notas directas"
|
||||||
importAndExport: "Importar y Exportar"
|
importAndExport: "Importar y Exportar"
|
||||||
@ -58,13 +69,16 @@ lists: "Listas"
|
|||||||
noLists: "No tiene listas"
|
noLists: "No tiene listas"
|
||||||
note: "Notas"
|
note: "Notas"
|
||||||
notes: "Notas"
|
notes: "Notas"
|
||||||
following: "Sigue"
|
following: "Siguiendo"
|
||||||
followers: "Seguidores"
|
followers: "Seguidores"
|
||||||
followsYou: "Te sigue"
|
followsYou: "Te sigue"
|
||||||
createList: "Crear lista"
|
createList: "Crear lista"
|
||||||
manageLists: "Administrar listas"
|
manageLists: "Administrar listas"
|
||||||
error: "Ocurrió un problema"
|
error: "Error"
|
||||||
|
somethingHappened: "Ocurrió un error"
|
||||||
retry: "Reintentar"
|
retry: "Reintentar"
|
||||||
|
pageLoadError: "Error al leer la página"
|
||||||
|
pageLoadErrorDescription: "Normalmente es debido a la red o al caché del navegador. Por favor limpie el caché o intente más tarde."
|
||||||
enterListName: "Ingrese nombre de lista"
|
enterListName: "Ingrese nombre de lista"
|
||||||
privacy: "Privacidad"
|
privacy: "Privacidad"
|
||||||
makeFollowManuallyApprove: "Aprobar manualmente las solicitudes de seguimiento"
|
makeFollowManuallyApprove: "Aprobar manualmente las solicitudes de seguimiento"
|
||||||
@ -77,16 +91,20 @@ followRequestPending: "Solicitudes de seguimiento pendientes"
|
|||||||
enterEmoji: "Ingresar emojis"
|
enterEmoji: "Ingresar emojis"
|
||||||
renote: "Renotar"
|
renote: "Renotar"
|
||||||
unrenote: "Quitar renota"
|
unrenote: "Quitar renota"
|
||||||
|
renoted: "Renotado"
|
||||||
|
cantRenote: "No se puede renotar este post"
|
||||||
|
cantReRenote: "No se puede renotar una renota"
|
||||||
quote: "Citar"
|
quote: "Citar"
|
||||||
pinnedNote: "Nota fijada"
|
pinnedNote: "Nota fijada"
|
||||||
|
pinned: "Fijar"
|
||||||
you: "Tú"
|
you: "Tú"
|
||||||
clickToShow: "Click para ver"
|
clickToShow: "Click para ver"
|
||||||
sensitive: "Marcado como sensible"
|
sensitive: "Marcado como sensible"
|
||||||
add: "Añadir"
|
add: "Agregar"
|
||||||
reaction: "Reacción"
|
reaction: "Reacción"
|
||||||
reactionSettingDescription: "Elegir las reacciones mostradas en el seleccionador de reacciones, separadas por una nueva linea"
|
reactionSettingDescription: "Asigne sus reacción favoritas que desean anclar en el selector de reacciones."
|
||||||
|
reactionSettingDescription2: "Arrastre para reordenar, click para borrar, apriete la tecla + para añadir."
|
||||||
rememberNoteVisibility: "Recordar visibilidad"
|
rememberNoteVisibility: "Recordar visibilidad"
|
||||||
renameFile: "Renombrar archivo"
|
|
||||||
attachCancel: "Quitar adjunto"
|
attachCancel: "Quitar adjunto"
|
||||||
markAsSensitive: "Marcar como sensible"
|
markAsSensitive: "Marcar como sensible"
|
||||||
unmarkAsSensitive: "Desmarcar como sensible"
|
unmarkAsSensitive: "Desmarcar como sensible"
|
||||||
@ -102,20 +120,29 @@ unblockConfirm: "¿Quiere dejar de bloquear esta cuenta?"
|
|||||||
suspendConfirm: "¿Quiere suspender esta cuenta?"
|
suspendConfirm: "¿Quiere suspender esta cuenta?"
|
||||||
unsuspendConfirm: "¿Quiere dejar de suspender esta cuenta?"
|
unsuspendConfirm: "¿Quiere dejar de suspender esta cuenta?"
|
||||||
selectList: "Seleccione una lista"
|
selectList: "Seleccione una lista"
|
||||||
|
selectAntenna: "Seleccionar antena"
|
||||||
|
selectWidget: "Seleccionar widget"
|
||||||
|
editWidgets: "Editar widgets"
|
||||||
|
editWidgetsExit: "Terminar edición"
|
||||||
customEmojis: "Emojis personalizados"
|
customEmojis: "Emojis personalizados"
|
||||||
|
emoji: "Emoji"
|
||||||
emojiName: "Nombre del emoji"
|
emojiName: "Nombre del emoji"
|
||||||
emojiUrl: "URL de la imágen del emoji"
|
emojiUrl: "URL de la imágen del emoji"
|
||||||
addEmoji: "Añadir emoji"
|
addEmoji: "Agregar emoji"
|
||||||
|
settingGuide: "Configuración sugerida"
|
||||||
cacheRemoteFiles: "Mantener en cache los archivos remotos"
|
cacheRemoteFiles: "Mantener en cache los archivos remotos"
|
||||||
cacheRemoteFilesDescription: "Si desactiva esta configuración, Los archivos remotos se cargarán desde el link directo sin usar la caché. Con eso se puede ahorrar almacenamiento del servidor, pero eso aumentará el tráfico al no crear miniaturas."
|
cacheRemoteFilesDescription: "Si desactiva esta configuración, Los archivos remotos se cargarán desde el link directo sin usar la caché. Con eso se puede ahorrar almacenamiento del servidor, pero eso aumentará el tráfico al no crear miniaturas."
|
||||||
flagAsBot: "Esta cuenta es un bot"
|
flagAsBot: "Esta cuenta es un bot"
|
||||||
|
flagAsBotDescription: "En caso de que esta cuenta fuera usada por un programa, active esta opción. Al hacerlo, esta opción servirá para otros desarrolladores para evitar cadenas infinitas de reacciones, y ajustará los sistemas internos de Misskey para que trate a esta cuenta como un bot."
|
||||||
flagAsCat: "Esta cuenta es un gato"
|
flagAsCat: "Esta cuenta es un gato"
|
||||||
|
flagAsCatDescription: "En caso de que declare que esta cuenta es de un gato, active esta opción."
|
||||||
autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de los usuarios que sigues"
|
autoAcceptFollowed: "Aceptar automáticamente las solicitudes de seguimiento de los usuarios que sigues"
|
||||||
addAcount: "Añadir cuenta"
|
addAcount: "Agregar cuenta"
|
||||||
loginFailed: "Error al iniciar sesión."
|
loginFailed: "Error al iniciar sesión."
|
||||||
showOnRemote: "Ver en una instancia remota"
|
showOnRemote: "Ver en una instancia remota"
|
||||||
general: "General"
|
general: "General"
|
||||||
wallpaper: "Fondo de pantalla"
|
wallpaper: "Fondo de pantalla"
|
||||||
|
setWallpaper: "Establecer fondo de pantalla"
|
||||||
removeWallpaper: "Quitar fondo de pantalla"
|
removeWallpaper: "Quitar fondo de pantalla"
|
||||||
searchWith: "Buscar: {q}"
|
searchWith: "Buscar: {q}"
|
||||||
youHaveNoLists: "No tienes listas"
|
youHaveNoLists: "No tienes listas"
|
||||||
@ -168,8 +195,8 @@ intro: "¡La instalación de Misskey ha terminado! Crea el usuario administrador
|
|||||||
done: "Terminado"
|
done: "Terminado"
|
||||||
processing: "Procesando"
|
processing: "Procesando"
|
||||||
preview: "Vista previa"
|
preview: "Vista previa"
|
||||||
|
default: "Predeterminado"
|
||||||
noCustomEmojis: "No hay emojis personalizados"
|
noCustomEmojis: "No hay emojis personalizados"
|
||||||
customEmojisOfRemote: "Emojis remotos"
|
|
||||||
noJobs: "No hay trabajos"
|
noJobs: "No hay trabajos"
|
||||||
federating: "Federando"
|
federating: "Federando"
|
||||||
blocked: "Bloqueando"
|
blocked: "Bloqueando"
|
||||||
@ -198,15 +225,20 @@ imageUrl: "URL de la imágen"
|
|||||||
remove: "Borrar"
|
remove: "Borrar"
|
||||||
removed: "Borrado"
|
removed: "Borrado"
|
||||||
removeAreYouSure: "¿Desea borrar \"{x}\"?"
|
removeAreYouSure: "¿Desea borrar \"{x}\"?"
|
||||||
|
deleteAreYouSure: "¿Desea borrar \"{x}\"?"
|
||||||
|
resetAreYouSure: "¿Desea reestablecer?"
|
||||||
saved: "Guardado"
|
saved: "Guardado"
|
||||||
messaging: "Chat"
|
messaging: "Chat"
|
||||||
upload: "Subir"
|
upload: "Subir"
|
||||||
fromDrive: "Desde el drive"
|
fromDrive: "Desde el drive"
|
||||||
fromUrl: "Desde la URL"
|
fromUrl: "Desde la URL"
|
||||||
|
uploadFromUrl: "Subir desde una URL"
|
||||||
|
uploadFromUrlDescription: "URL del fichero que quieres subir"
|
||||||
|
uploadFromUrlRequested: "Subida solicitada"
|
||||||
|
uploadFromUrlMayTakeTime: "Subir el fichero puede tardar un tiempo."
|
||||||
explore: "Explorar"
|
explore: "Explorar"
|
||||||
games: "Misskey Games"
|
games: "Misskey Games"
|
||||||
messageRead: "Ya leído"
|
messageRead: "Ya leído"
|
||||||
recentUsedEmojis: "Emojis usados recientemente"
|
|
||||||
noMoreHistory: "El historial se ha acabado"
|
noMoreHistory: "El historial se ha acabado"
|
||||||
startMessaging: "Iniciar chat"
|
startMessaging: "Iniciar chat"
|
||||||
nUsersRead: "Leído por {n} personas"
|
nUsersRead: "Leído por {n} personas"
|
||||||
@ -222,28 +254,47 @@ yearsOld: "{age} años"
|
|||||||
registeredDate: "Fecha de registro"
|
registeredDate: "Fecha de registro"
|
||||||
location: "Lugar"
|
location: "Lugar"
|
||||||
theme: "Tema"
|
theme: "Tema"
|
||||||
|
themeForLightMode: "Tema para usar en Modo Linterna"
|
||||||
|
themeForDarkMode: "Tema para usar en Modo Oscuro"
|
||||||
|
light: "Linterna"
|
||||||
|
dark: "Oscuro"
|
||||||
lightThemes: "Tema claro"
|
lightThemes: "Tema claro"
|
||||||
darkThemes: "Tema oscuro"
|
darkThemes: "Tema oscuro"
|
||||||
|
syncDeviceDarkMode: "Sincronice el Modo Oscuro con la configuración de su dispositivo"
|
||||||
drive: "Drive"
|
drive: "Drive"
|
||||||
|
fileName: "Nombre de archivo"
|
||||||
selectFile: "Elegir archivo"
|
selectFile: "Elegir archivo"
|
||||||
selectFiles: "Elegir archivos"
|
selectFiles: "Elegir archivos"
|
||||||
renameFolder: "Renombrar carpeta"
|
selectFolder: "Seleccione una carpeta"
|
||||||
|
selectFolders: "Seleccione carpetas"
|
||||||
|
renameFile: "Renombrar archivo"
|
||||||
|
folderName: "Nombre de la carpeta"
|
||||||
createFolder: "Crear carpeta"
|
createFolder: "Crear carpeta"
|
||||||
|
renameFolder: "Renombrar carpeta"
|
||||||
deleteFolder: "Borrar carpeta"
|
deleteFolder: "Borrar carpeta"
|
||||||
addFile: "Añadir archivo"
|
addFile: "Agregar archivo"
|
||||||
emptyDrive: "El drive está vacío"
|
emptyDrive: "El drive está vacío"
|
||||||
emptyFolder: "La carpeta está vacía"
|
emptyFolder: "La carpeta está vacía"
|
||||||
|
unableToDelete: "No se puede borrar"
|
||||||
|
inputNewFileName: "Ingrese un nuevo nombre de archivo"
|
||||||
|
inputNewFolderName: "Ingrese un nuevo nombre de la carpeta"
|
||||||
|
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."
|
||||||
copyUrl: "Copiar URL"
|
copyUrl: "Copiar URL"
|
||||||
rename: "Renombrar"
|
rename: "Renombrar"
|
||||||
avatar: "Avatar"
|
avatar: "Avatar"
|
||||||
banner: "Banner"
|
banner: "Banner"
|
||||||
nsfw: "Marcado como sensible"
|
nsfw: "Marcado como sensible"
|
||||||
|
whenServerDisconnected: "Cuando se pierda la conexión con el servidor"
|
||||||
disconnectedFromServer: "Desconectado del servidor"
|
disconnectedFromServer: "Desconectado del servidor"
|
||||||
|
reload: "Recargar"
|
||||||
|
doNothing: "No hacer nada"
|
||||||
reloadConfirm: "¿Desea recargar?"
|
reloadConfirm: "¿Desea recargar?"
|
||||||
watch: "Ver"
|
watch: "Ver"
|
||||||
unwatch: "Dejar de ver"
|
unwatch: "Dejar de ver"
|
||||||
accept: "Aceptar"
|
accept: "Aceptar"
|
||||||
reject: "Rechazar"
|
reject: "Rechazar"
|
||||||
|
normal: "Normal"
|
||||||
instanceName: "Nombre de la instancia"
|
instanceName: "Nombre de la instancia"
|
||||||
instanceDescription: "Descripción de la instancia"
|
instanceDescription: "Descripción de la instancia"
|
||||||
maintainerName: "Nombre del administrador"
|
maintainerName: "Nombre del administrador"
|
||||||
@ -275,15 +326,25 @@ bannerUrl: "URL de la imagen del banner"
|
|||||||
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"
|
||||||
|
pinnedPages: "Páginas fijadas"
|
||||||
|
pinnedPagesDescription: "Describa las rutas de las páginas que desea fijar a la página principal de la instancia, separadas por lineas nuevas"
|
||||||
|
pinnedClipId: "Id del clip fijado"
|
||||||
|
pinnedNotes: "Nota fijada"
|
||||||
|
hcaptcha: "hCaptcha"
|
||||||
|
enableHcaptcha: "Habilitar hCaptcha"
|
||||||
|
hcaptchaSiteKey: "Clave del sitio"
|
||||||
|
hcaptchaSecretKey: "Clave secreta"
|
||||||
recaptcha: "reCAPTCHA"
|
recaptcha: "reCAPTCHA"
|
||||||
enableRecaptcha: "activar reCAPTCHA"
|
enableRecaptcha: "activar reCAPTCHA"
|
||||||
recaptchaSiteKey: "Clave del sitio"
|
recaptchaSiteKey: "Clave del sitio"
|
||||||
recaptchaSecretKey: "Clave secreta"
|
recaptchaSecretKey: "Clave secreta"
|
||||||
|
avoidMultiCaptchaConfirm: "El uso de múltiples Captchas puede causar interferencia. ¿Desea desactivar el otro Captcha? Puede dejar múltiples Captchas habilitadas presionando cancelar."
|
||||||
antennas: "Antenas"
|
antennas: "Antenas"
|
||||||
manageAntennas: "Administrar antenas"
|
manageAntennas: "Administrar antenas"
|
||||||
name: "Nombre"
|
name: "Nombre"
|
||||||
antennaSource: "Origen de la antena"
|
antennaSource: "Origen de la antena"
|
||||||
antennaKeywords: "Palabras clave de la antena"
|
antennaKeywords: "Palabras clave para recibir"
|
||||||
|
antennaExcludeKeywords: "Palabras clave para excluir"
|
||||||
antennaKeywordsDescription: "Separar con espacios es una declaración AND, separar con una linea nueva es una declaración OR"
|
antennaKeywordsDescription: "Separar con espacios es una declaración AND, separar con una linea nueva es una declaración OR"
|
||||||
notifyAntenna: "Notificar nueva nota"
|
notifyAntenna: "Notificar nueva nota"
|
||||||
withFileAntenna: "Sólo notas con archivos adjuntados"
|
withFileAntenna: "Sólo notas con archivos adjuntados"
|
||||||
@ -297,6 +358,7 @@ notesAndReplies: "Notas y respuestas"
|
|||||||
withFiles: "Adjuntos"
|
withFiles: "Adjuntos"
|
||||||
silence: "Silenciar"
|
silence: "Silenciar"
|
||||||
silenceConfirm: "¿Desea silenciar al usuario?"
|
silenceConfirm: "¿Desea silenciar al usuario?"
|
||||||
|
unsilence: "Dejar de silenciar"
|
||||||
unsilenceConfirm: "¿Desea dejar de silenciar al usuario?"
|
unsilenceConfirm: "¿Desea dejar de silenciar al usuario?"
|
||||||
popularUsers: "Usuarios populares"
|
popularUsers: "Usuarios populares"
|
||||||
recentlyUpdatedUsers: "Usuarios activos recientemente"
|
recentlyUpdatedUsers: "Usuarios activos recientemente"
|
||||||
@ -308,12 +370,6 @@ popularTags: "Etiquetas populares"
|
|||||||
userList: "Lista"
|
userList: "Lista"
|
||||||
about: "Información"
|
about: "Información"
|
||||||
aboutMisskey: "Sobre Misskey"
|
aboutMisskey: "Sobre Misskey"
|
||||||
aboutMisskeyText: "Misskey es un software de código abierto, desarrollado por syuilo desde el 2014"
|
|
||||||
misskeyMembers: "Es creado y mantenido por los miembros aquí listados:"
|
|
||||||
misskeySource: "El código fuente está disponible aquí:"
|
|
||||||
misskeyDonate: "Puedes contribuir al desarrollo de Misskey donando aquí:"
|
|
||||||
morePatrons: "Muchas más personas nos apoyan. Muchas gracias🥰"
|
|
||||||
patrons: "Patrocinadores"
|
|
||||||
administrator: "Administrador"
|
administrator: "Administrador"
|
||||||
token: "Token"
|
token: "Token"
|
||||||
twoStepAuthentication: "Autenticación de dos factores"
|
twoStepAuthentication: "Autenticación de dos factores"
|
||||||
@ -327,11 +383,6 @@ unregister: "Cancelar registro"
|
|||||||
passwordLessLogin: "Iniciar sesión sin contraseña"
|
passwordLessLogin: "Iniciar sesión sin contraseña"
|
||||||
resetPassword: "Resetear contraseña"
|
resetPassword: "Resetear contraseña"
|
||||||
newPasswordIs: "La nueva contraseña es \"{password}\""
|
newPasswordIs: "La nueva contraseña es \"{password}\""
|
||||||
post: "Nota"
|
|
||||||
posted: "Posteado"
|
|
||||||
autoReloadWhenDisconnected: "Recargar automáticamente cuando el servidor está desconectado"
|
|
||||||
autoNoteWatch: "Ver nota automáticamente"
|
|
||||||
autoNoteWatchDescription: "Recibe notificaciones sobre las notas de otros usuarios que a los que respondiste y reaccionaste"
|
|
||||||
reduceUiAnimation: "Reducir la animación de la UI"
|
reduceUiAnimation: "Reducir la animación de la UI"
|
||||||
share: "Compartir"
|
share: "Compartir"
|
||||||
notFound: "No se encuentra"
|
notFound: "No se encuentra"
|
||||||
@ -369,6 +420,7 @@ noMessagesYet: "Aún no hay chat"
|
|||||||
newMessageExists: "Tienes un mensaje nuevo"
|
newMessageExists: "Tienes un mensaje nuevo"
|
||||||
onlyOneFileCanBeAttached: "Solo se puede añadir un archivo al mensaje"
|
onlyOneFileCanBeAttached: "Solo se puede añadir un archivo al mensaje"
|
||||||
signinRequired: "Iniciar sesión"
|
signinRequired: "Iniciar sesión"
|
||||||
|
invitations: "Invitar"
|
||||||
invitationCode: "Código de invitación"
|
invitationCode: "Código de invitación"
|
||||||
checking: "Comprobando"
|
checking: "Comprobando"
|
||||||
available: "Disponible"
|
available: "Disponible"
|
||||||
@ -382,9 +434,391 @@ strongPassword: "Muy buena contraseña"
|
|||||||
passwordMatched: "Correcto"
|
passwordMatched: "Correcto"
|
||||||
passwordNotMatched: "Las contraseñas no son las mismas"
|
passwordNotMatched: "Las contraseñas no son las mismas"
|
||||||
signinWith: "Inicie sesión con {x}"
|
signinWith: "Inicie sesión con {x}"
|
||||||
|
signinFailed: "Autenticación fallida. Asegúrate de haber usado el nombre de usuario y contraseña correctos."
|
||||||
tapSecurityKey: "Toque la clave de seguridad"
|
tapSecurityKey: "Toque la clave de seguridad"
|
||||||
or: "O"
|
or: "O"
|
||||||
uiLanguage: "Idioma de visualización de la interfaz"
|
uiLanguage: "Idioma de visualización de la interfaz"
|
||||||
|
groupInvited: "Invitado al grupo"
|
||||||
|
aboutX: "Acerca de {x}"
|
||||||
|
useOsNativeEmojis: "Usa los emojis nativos de la plataforma"
|
||||||
|
youHaveNoGroups: "Sin grupos"
|
||||||
|
joinOrCreateGroup: "Obtenga una invitación para unirse al grupos o puede crear su propio grupo."
|
||||||
|
noHistory: "No hay datos en el historial"
|
||||||
|
signinHistory: "Historial de ingresos"
|
||||||
|
disableAnimatedMfm: "Deshabilitar MFM que tiene animaciones"
|
||||||
|
doing: "Voy en camino"
|
||||||
|
category: "Categoría"
|
||||||
|
tags: "Etiqueta"
|
||||||
|
docSource: "Fuente de este documento"
|
||||||
|
createAccount: "Crear cuenta"
|
||||||
|
existingAcount: "Cuentas existentes"
|
||||||
|
regenerate: "Regenerar"
|
||||||
|
fontSize: "Tamaño de la letra"
|
||||||
|
noFollowRequests: "No hay solicitudes de seguimiento"
|
||||||
|
openImageInNewTab: "Abrir imagen en nueva pestaña"
|
||||||
|
dashboard: "Panel de control"
|
||||||
|
local: "Local"
|
||||||
|
remote: "Remoto"
|
||||||
|
total: "Total"
|
||||||
|
weekOverWeekChanges: "Dif semanal"
|
||||||
|
dayOverDayChanges: "Dif diaria"
|
||||||
|
appearance: "Apariencia"
|
||||||
|
clientSettings: "Configuración del cliente"
|
||||||
|
accountSettings: "Ajustes de cuenta"
|
||||||
|
promotion: "Promovido"
|
||||||
|
promote: "Promover"
|
||||||
|
numberOfDays: "Cantidad de dias"
|
||||||
|
hideThisNote: "Ocultar esta nota"
|
||||||
|
showFeaturedNotesInTimeline: "Mostrar notas destacadas en la línea de tiempo"
|
||||||
|
objectStorage: "Almacenamiento de objetos"
|
||||||
|
useObjectStorage: "Usar almacenamiento de objetos"
|
||||||
|
objectStorageBaseUrl: "Base URL"
|
||||||
|
objectStorageBaseUrlDesc: "Prefijo de URL utilizado para construir URL para hacer referencia a objetos (medios). Especifique su URL si está utilizando un CDN o Proxy; de lo contrario, especifique la dirección a la que se puede acceder públicamente de acuerdo con la guía de servicio que va a utilizar. i.g 'https://<bucket>.s3.amazonaws.com' para AWS S3 y 'https://storage.googleapis.com/<bucket>' para GCS."
|
||||||
|
objectStorageBucket: "Bucket"
|
||||||
|
objectStorageBucketDesc: "Especifique el nombre del depósito utilizado en el servicio configurado."
|
||||||
|
objectStoragePrefix: "Prefix"
|
||||||
|
objectStoragePrefixDesc: "Los archivos se almacenarán en el directorio de este prefijo."
|
||||||
|
objectStorageEndpoint: "Endpoint"
|
||||||
|
objectStorageEndpointDesc: "Deje esto en blanco si está utilizando AWS S3; de lo contrario, especifique el punto final como '<host>' o '<host>: <port>' de acuerdo con la guía de servicio que va a utilizar."
|
||||||
|
objectStorageRegion: "Region"
|
||||||
|
objectStorageRegionDesc: "Especifique una región como 'xx-east-1'. Si su servicio no tiene distinción sobre regiones, déjelo en blanco o complete con 'us-east-1'."
|
||||||
|
objectStorageUseSSL: "Usar SSL"
|
||||||
|
objectStorageUseSSLDesc: "Desactive esto si no va a usar HTTPS para la conexión API"
|
||||||
|
objectStorageUseProxy: "Conectarse a través de Proxy"
|
||||||
|
objectStorageUseProxyDesc: "Desactive esto si no va a usar Proxy para la conexión de Almacenamiento de objetos"
|
||||||
|
objectStorageSetPublicRead: "Seleccionar \"public-read\" al subir "
|
||||||
|
serverLogs: "Registros del servidor"
|
||||||
|
deleteAll: "Eliminar todos"
|
||||||
|
showFixedPostForm: "Mostrar el formulario de las entradas encima de la línea de tiempo"
|
||||||
|
newNoteRecived: "Tienes una nota nuevo"
|
||||||
|
sounds: "Sonidos"
|
||||||
|
listen: "Escuchar"
|
||||||
|
none: "Ninguna"
|
||||||
|
showInPage: "Mostrar en la página"
|
||||||
|
popout: "Popout"
|
||||||
|
volume: "Volumen"
|
||||||
|
masterVolume: "Volumen principal"
|
||||||
|
details: "Detalles"
|
||||||
|
chooseEmoji: "Elije un emoji"
|
||||||
|
unableToProcess: "La operación no se puede llevar a cabo"
|
||||||
|
recentUsed: "Usado recientemente"
|
||||||
|
install: "Instalación"
|
||||||
|
uninstall: "Desinstalar"
|
||||||
|
installedApps: "Aplicaciones Autorizadas"
|
||||||
|
nothing: "No hay nada que ver aqui"
|
||||||
|
installedDate: "Autorizado"
|
||||||
|
lastUsedDate: "Utilizado el"
|
||||||
|
state: "Estado"
|
||||||
|
sort: "Ordenar"
|
||||||
|
ascendingOrder: "Ascendente"
|
||||||
|
descendingOrder: "Descendente"
|
||||||
|
scratchpad: "Scratch pad"
|
||||||
|
scratchpadDescription: "Scratchpad proporciona un entorno experimental para AiScript. Puede escribir, ejecutar y verificar los resultados que interactúan con Misskey."
|
||||||
|
output: "Salida"
|
||||||
|
script: "Script"
|
||||||
|
disablePagesScript: "Deshabilitar AiScript en Páginas"
|
||||||
|
updateRemoteUser: "Actualizar información de usuario remoto"
|
||||||
|
deleteAllFiles: "Borrar todos los archivos"
|
||||||
|
deleteAllFilesConfirm: "¿Desea borrar todos los archivos?"
|
||||||
|
removeAllFollowing: "Retener todos los siguientes"
|
||||||
|
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."
|
||||||
|
userSilenced: "Este usuario ha sido silenciado."
|
||||||
|
sidebar: "Barra lateral"
|
||||||
|
divider: "Divisor"
|
||||||
|
addItem: "Agregar elemento"
|
||||||
|
rooms: "Cuartos"
|
||||||
|
relays: "Relés"
|
||||||
|
addRelay: "Agregar relé"
|
||||||
|
inboxUrl: "Inbox URL"
|
||||||
|
addedRelays: "Relés añadidos"
|
||||||
|
serviceworkerInfo: "Se necesita activar para usar las notificaciones push"
|
||||||
|
deletedNote: "Nota eliminada"
|
||||||
|
invisibleNote: "Nota oculta"
|
||||||
|
enableInfiniteScroll: "Activar scroll infinito"
|
||||||
|
visibility: "Visibilidad"
|
||||||
|
poll: "Encuesta"
|
||||||
|
useCw: "Esconder contenidos"
|
||||||
|
enablePlayer: "Abrir reproductor"
|
||||||
|
disablePlayer: "Cerrar reproductor"
|
||||||
|
expandTweet: "Expandir tweet"
|
||||||
|
themeEditor: "Editor de temas"
|
||||||
|
description: "Descripción"
|
||||||
|
author: "Autor"
|
||||||
|
leaveConfirm: "Hay modificaciones sin guardar. ¿Desea descartarlas?"
|
||||||
|
manage: "Administrar"
|
||||||
|
plugins: "Plugins"
|
||||||
|
deck: "Deck"
|
||||||
|
undeck: "Quitar deck"
|
||||||
|
useBlurEffectForModal: "Usar efecto borroso en modales"
|
||||||
|
useFullReactionPicker: "Reacción"
|
||||||
|
width: "Ancho"
|
||||||
|
height: "Altura"
|
||||||
|
large: "Grande"
|
||||||
|
medium: "Mediano"
|
||||||
|
small: "Pequeño"
|
||||||
|
generateAccessToken: "Generar token de acceso"
|
||||||
|
permission: "Permisos"
|
||||||
|
enableAll: "Activar todo"
|
||||||
|
disableAll: "Desactivar todo"
|
||||||
|
tokenRequested: "Permiso de acceso a la cuenta"
|
||||||
|
pluginTokenRequestedDescription: "Este plugin podrá usar los permisos descritos aquí"
|
||||||
|
notificationType: "Tipo de notificación"
|
||||||
|
edit: "Editar"
|
||||||
|
useStarForReactionFallback: "En caso de que los emojis de reacciones no sean claros, usar en su lugar una estrella"
|
||||||
|
emailConfig: "Configuración del servidor de correos"
|
||||||
|
enableEmail: "Activar el envío de correos electrónicos"
|
||||||
|
emailConfigInfo: "Usar en caso de validación de correo electrónico y pedido de contraseña"
|
||||||
|
email: "Correo"
|
||||||
|
emailAddress: "Correo electrónico"
|
||||||
|
smtpConfig: "Configuración del servidor SMTP"
|
||||||
|
smtpHost: "Host"
|
||||||
|
smtpPort: "Puerto"
|
||||||
|
smtpUser: "Nombre de usuario"
|
||||||
|
smtpPass: "Contraseña"
|
||||||
|
emptyToDisableSmtpAuth: "Deje el nombre del usuario y la contraseña en blanco para deshabilitar la autenticación SMTP"
|
||||||
|
smtpSecure: "Usar SSL/TLS implícito en la conexión SMTP"
|
||||||
|
smtpSecureInfo: "Apagar cuando se use STARTTLS"
|
||||||
|
testEmail: "Prueba de envío"
|
||||||
|
wordMute: "Silenciar palabras"
|
||||||
|
userSaysSomething: "{name} dijo algo"
|
||||||
|
makeActive: "Activar"
|
||||||
|
display: "Apariencia"
|
||||||
|
copy: "Copiar"
|
||||||
|
metrics: "Métricas"
|
||||||
|
overview: "Resumen"
|
||||||
|
logs: "Registros"
|
||||||
|
delayed: "atrasado"
|
||||||
|
database: "Base de datos"
|
||||||
|
channel: "Canal"
|
||||||
|
create: "Crear"
|
||||||
|
notificationSetting: "Ajustes de Notificaciones"
|
||||||
|
notificationSettingDesc: "Por favor elija el tipo de notificación a mostrar"
|
||||||
|
useGlobalSetting: "Usar ajustes globales"
|
||||||
|
useGlobalSettingDesc: "Al activarse, se usará la configuración de notificaciones de la cuenta, al desactivarse se pueden hacer configuraciones particulares."
|
||||||
|
other: "Otro"
|
||||||
|
regenerateLoginToken: "Regenerar token de login"
|
||||||
|
regenerateLoginTokenDescription: "Regenerar el token usado internamente durante el login. No siempre es necesario hacerlo. Al hacerlo de nuevo, se deslogueará en todos los dispositivos."
|
||||||
|
setMultipleBySeparatingWithSpace: "Puedes añadir mas de uno, separado por espacios."
|
||||||
|
fileIdOrUrl: "Id del archivo o URL"
|
||||||
|
chatOpenBehavior: "Comportamiento al abrir el chat"
|
||||||
|
behavior: "Comportamiento"
|
||||||
|
sample: "Muestra"
|
||||||
|
abuseReports: "Reportes"
|
||||||
|
reportAbuse: "Reportar"
|
||||||
|
reportAbuseOf: "Reportar a {name}"
|
||||||
|
fillAbuseReportDescription: "Ingrese los detalles del reporte. Si hay una nota en particular, ingrese la URL de esta."
|
||||||
|
abuseReported: "Se ha enviado el reporte. Muchas gracias."
|
||||||
|
send: "Enviar"
|
||||||
|
abuseMarkAsResolved: "Marcar reporte como resuelto"
|
||||||
|
openInNewTab: "Abrir en una Nueva Pestaña"
|
||||||
|
openInSideView: "Abrir en una vista al costado"
|
||||||
|
defaultNavigationBehaviour: "Navegación por defecto"
|
||||||
|
editTheseSettingsMayBreakAccount: "Editar estas configuraciones puede dañar su cuenta."
|
||||||
|
instanceTicker: "Información de notas de la instancia"
|
||||||
|
waitingFor: "Esperando a {x}"
|
||||||
|
random: "Aleatorio"
|
||||||
|
system: "Sistema"
|
||||||
|
switchUi: "Cambiar interfaz de usuario"
|
||||||
|
desktop: "Escritorio"
|
||||||
|
clip: "Clip"
|
||||||
|
createNew: "Crear"
|
||||||
|
optional: "Opcional"
|
||||||
|
createNewClip: "Crear clip nuevo"
|
||||||
|
public: "Público"
|
||||||
|
i18nInfo: "Misskey está siendo traducido a varios idiomas gracias a voluntarios. Se puede colaborar traduciendo en {link}"
|
||||||
|
manageAccessTokens: "Administrar tokens de acceso"
|
||||||
|
accountInfo: "Información de la Cuenta"
|
||||||
|
notesCount: "Cantidad de notas"
|
||||||
|
repliesCount: "Cantidad de respuestas hechas"
|
||||||
|
renotesCount: "Cantidad de renotas hechas"
|
||||||
|
repliedCount: "Cantidad de respuestas recibidas"
|
||||||
|
renotedCount: "Cantidad de renotas recibidas"
|
||||||
|
followingCount: "Cantidad de seguidos"
|
||||||
|
followersCount: "Cantidad de seguidores"
|
||||||
|
sentReactionsCount: "Cantidad de reacciones hechas"
|
||||||
|
receivedReactionsCount: "Cantidad de reacciones recibidas"
|
||||||
|
pollVotesCount: "Cantidad de votaciones hechas"
|
||||||
|
pollVotedCount: "Cantidad de votaciones recibidas"
|
||||||
|
yes: "Si"
|
||||||
|
no: "No"
|
||||||
|
driveFilesCount: "Cantidad de archivos en el drive"
|
||||||
|
driveUsage: "Uso del drive"
|
||||||
|
noCrawle: "Rechazar indexación del crawler"
|
||||||
|
noCrawleDescription: "Pedir a los motores de búsqueda que no indexen tu perfil, notas, páginas, etc."
|
||||||
|
clips: "Clip"
|
||||||
|
clearCache: "Limpiar caché"
|
||||||
|
backgroundColor: "Fondo"
|
||||||
|
accentColor: "Acento"
|
||||||
|
textColor: "Texto"
|
||||||
|
value: "Valores"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "te ha seguido"
|
||||||
|
_registry:
|
||||||
|
key: "Clave"
|
||||||
|
keys: "Clave"
|
||||||
|
_mfm:
|
||||||
|
cheatSheet: "Hoja de referencia de MFM"
|
||||||
|
intro: "MFM es un lenguaje de marcado dedicado que se puede usar en varios lugares dentro de Misskey. Aquí puede ver una lista de sintaxis disponibles en MFM."
|
||||||
|
mention: "Menciones"
|
||||||
|
mentionDescription: "El signo @ seguido de un nombre de usuario se puede utilizar para notificar a un usuario en particular."
|
||||||
|
hashtag: "Hashtag"
|
||||||
|
url: "URL"
|
||||||
|
link: "Vínculo"
|
||||||
|
bold: "Negrita"
|
||||||
|
center: "Centrar"
|
||||||
|
blockCode: "Código (bloque)"
|
||||||
|
blockCodeDescription: "Código de resaltado de sintaxis, como programas de varias líneas con bloques."
|
||||||
|
quote: "Citar"
|
||||||
|
emoji: "Emojis personalizados"
|
||||||
|
search: "Buscar"
|
||||||
|
flip: "Echar de un capirotazo"
|
||||||
|
flipDescription: "Voltea el contenido hacia arriba / abajo o hacia la izquierda / derecha."
|
||||||
|
font: "Fuente"
|
||||||
|
_reversi:
|
||||||
|
reversi: "Reversi"
|
||||||
|
gameSettings: "Configuración del juego"
|
||||||
|
chooseBoard: "Elegir tablero"
|
||||||
|
blackOrWhite: "Blancas/Negras"
|
||||||
|
blackIs: "{name} juega con fichas negras"
|
||||||
|
rules: "Reglas"
|
||||||
|
botSettings: "Opciones del bot"
|
||||||
|
thisGameIsStartedSoon: "El juego empezará en segundos"
|
||||||
|
waitingForOther: "Esperando el turno del adversario"
|
||||||
|
waitingForMe: "Esperando mi turno"
|
||||||
|
waitingBoth: "Prepárate"
|
||||||
|
ready: "Listo"
|
||||||
|
cancelReady: "No estoy listo"
|
||||||
|
opponentTurn: "Turno del adversario"
|
||||||
|
myTurn: "Mi turno"
|
||||||
|
turnOf: "Turno de {name}"
|
||||||
|
pastTurnOf: "Turno de {name}"
|
||||||
|
surrender: "Rendirse"
|
||||||
|
surrendered: "Por rendirse"
|
||||||
|
drawn: "Empate"
|
||||||
|
won: "{name} ha ganado"
|
||||||
|
black: "Negro"
|
||||||
|
white: "Blanco"
|
||||||
|
total: "Total"
|
||||||
|
turnCount: "Turno {count}"
|
||||||
|
myGames: "Mis juegos"
|
||||||
|
allGames: "Todos los juegos"
|
||||||
|
ended: "Finalizado"
|
||||||
|
playing: "Jugando"
|
||||||
|
isLlotheo: "El que tenga menos fichas gana (LLoTheO)"
|
||||||
|
loopedMap: "Mapa en bucle"
|
||||||
|
canPutEverywhere: "Puedes colocar donde quieras"
|
||||||
|
_instanceTicker:
|
||||||
|
none: "No mostrar"
|
||||||
|
remote: "Mostrar a usuarios remotos"
|
||||||
|
always: "Mostrar siempre"
|
||||||
|
_serverDisconnectedBehavior:
|
||||||
|
reload: "Recargar automáticamente"
|
||||||
|
dialog: "Mostrar diálogo de advertencia"
|
||||||
|
quiet: "Advertencia discreta"
|
||||||
|
_channel:
|
||||||
|
create: "Crear canal"
|
||||||
|
edit: "Editar canal"
|
||||||
|
setBanner: "Elegir banner"
|
||||||
|
removeBanner: "Borrar banner"
|
||||||
|
featured: "Tendencias"
|
||||||
|
owned: "Dueño"
|
||||||
|
following: "Siguiendo"
|
||||||
|
usersCount: "{n} participantes"
|
||||||
|
notesCount: "{n} notas"
|
||||||
|
_sidebar:
|
||||||
|
full: "Completo"
|
||||||
|
icon: "Avatar"
|
||||||
|
hide: "Ocultar"
|
||||||
|
_wordMute:
|
||||||
|
muteWords: "Palabras que silenciar"
|
||||||
|
muteWordsDescription: "Separar con espacios indica una declaracion And, separar con lineas nuevas indica una declaracion Or。"
|
||||||
|
muteWordsDescription2: "Encerrar las palabras clave entre numerales para usar expresiones regulares"
|
||||||
|
softDescription: "Ocultar en la linea de tiempo las notas que cumplen las condiciones"
|
||||||
|
hardDescription: "Evitar que se agreguen a la linea de tiempo las notas que cumplen las condiciones. Las notas no agregadas seguirán quitadas aunque cambien las condiciones."
|
||||||
|
soft: "Suave"
|
||||||
|
hard: "Duro"
|
||||||
|
mutedNotes: "Notas silenciadas"
|
||||||
|
_theme:
|
||||||
|
explore: "Explorar temas"
|
||||||
|
install: "Instalar tema"
|
||||||
|
manage: "Gestor de temas"
|
||||||
|
code: "Código del tema"
|
||||||
|
installed: "{name} ha sido instalado"
|
||||||
|
alreadyInstalled: "Este tema ya está instalado"
|
||||||
|
invalid: "El formato del tema no es válido"
|
||||||
|
make: "Crear tema"
|
||||||
|
base: "Base"
|
||||||
|
addConstant: "Agregar constante"
|
||||||
|
constant: "Constante"
|
||||||
|
defaultValue: "Valor predeterminado"
|
||||||
|
color: "Color"
|
||||||
|
refProp: "Hacer referencia a propiedad"
|
||||||
|
refConst: "Hacer referencia a constante"
|
||||||
|
key: "Clave"
|
||||||
|
func: "funciones"
|
||||||
|
funcKind: "Tipo de función"
|
||||||
|
argument: "Argumento"
|
||||||
|
basedProp: "Nombre de la propiedad referenciada"
|
||||||
|
alpha: "Opacidad"
|
||||||
|
darken: "Oscuridad"
|
||||||
|
lighten: "Brillo"
|
||||||
|
inputConstantName: "Por favor ingrese el nombre de la constante"
|
||||||
|
importInfo: "Pegando el código del tema aquí, puede importarlo al editor"
|
||||||
|
deleteConstantConfirm: "¿Desea borrar la constante {const}?"
|
||||||
|
keys:
|
||||||
|
accent: "Acento"
|
||||||
|
bg: "Fondo"
|
||||||
|
fg: "Texto"
|
||||||
|
focus: "Enfoque"
|
||||||
|
indicator: "Indicador"
|
||||||
|
panel: "Panel"
|
||||||
|
shadow: "Sombra"
|
||||||
|
header: "Cabezal"
|
||||||
|
navBg: "Fondo de la barra lateral"
|
||||||
|
navFg: "Texto de la barra lateral"
|
||||||
|
navHoverFg: "Texto de la barra lateral (hover)"
|
||||||
|
navActive: "Texto de la barra lateral (activo)"
|
||||||
|
navIndicator: "Indicador de la barra lateral"
|
||||||
|
link: "Vínculo"
|
||||||
|
hashtag: "Hashtag"
|
||||||
|
mention: "Menciones"
|
||||||
|
mentionMe: "Menciones (yo)"
|
||||||
|
renote: "Renotar"
|
||||||
|
modalBg: "Fondo modal"
|
||||||
|
divider: "Divisor"
|
||||||
|
scrollbarHandle: "Cuadro de la barra de desplazamiento"
|
||||||
|
scrollbarHandleHover: "Cuadro de la barra de desplazamiento (hover)"
|
||||||
|
dateLabelFg: "Texto de la etiqueta de fecha"
|
||||||
|
infoBg: "Fondo de información"
|
||||||
|
infoFg: "Texto de información"
|
||||||
|
infoWarnBg: "Fondo de advertencias"
|
||||||
|
infoWarnFg: "Texto de advertencias"
|
||||||
|
cwBg: "Fondo del botón CW"
|
||||||
|
cwFg: "Texto del botón CW"
|
||||||
|
cwHoverBg: "Fondo del botón CW (hover)"
|
||||||
|
toastBg: "Fondo de notificaciones"
|
||||||
|
toastFg: "Texto de notificaciones"
|
||||||
|
buttonBg: "Fondo de botón"
|
||||||
|
buttonHoverBg: "Fondo de botón (hover)"
|
||||||
|
inputBorder: "Borde de los campos de entrada"
|
||||||
|
listItemHoverBg: "Fondo de elemento de listas (hover)"
|
||||||
|
driveFolderBg: "Fondo de capeta del drive"
|
||||||
|
wallpaperOverlay: "Transparencia del fondo de pantalla"
|
||||||
|
badge: "Medalla"
|
||||||
|
messageBg: "Fondo de chat"
|
||||||
|
accentDarken: "Acento (oscuro)"
|
||||||
|
accentLighten: "Acento (claro)"
|
||||||
|
fgHighlighted: "Texto resaltado"
|
||||||
|
_sfx:
|
||||||
|
note: "Notas"
|
||||||
|
noteMy: "Nota (a mí mismo)"
|
||||||
|
notification: "Notificaciones"
|
||||||
|
chat: "Chat"
|
||||||
|
chatBg: "Chat (Fondo)"
|
||||||
|
antenna: "Antena receptora"
|
||||||
|
channel: "Notificaciones del canal"
|
||||||
_ago:
|
_ago:
|
||||||
unknown: "Desconocido"
|
unknown: "Desconocido"
|
||||||
future: "Futuro"
|
future: "Futuro"
|
||||||
@ -460,14 +894,21 @@ _permissions:
|
|||||||
"write:page-likes": "Administrar páginas que te gustan"
|
"write:page-likes": "Administrar páginas que te gustan"
|
||||||
"read:user-groups": "Ver grupos de usuarios"
|
"read:user-groups": "Ver grupos de usuarios"
|
||||||
"write:user-groups": "Administrar grupos de usuarios"
|
"write:user-groups": "Administrar grupos de usuarios"
|
||||||
|
"read:channels": "Ver canal"
|
||||||
|
"write:channels": "Modificar canal"
|
||||||
_auth:
|
_auth:
|
||||||
shareAccess: "¿Desea permitir el acceso a la cuenta \"{name}\"?"
|
shareAccess: "¿Desea permitir el acceso a la cuenta \"{name}\"?"
|
||||||
|
shareAccessAsk: "¿Está seguro de que desea autorizar esta aplicación para acceder a su cuenta?"
|
||||||
permissionAsk: "Esta aplicación requiere los siguientes permisos"
|
permissionAsk: "Esta aplicación requiere los siguientes permisos"
|
||||||
|
pleaseGoBack: "Por favor, vuelve a la aplicación"
|
||||||
|
callback: "Volviendo a la aplicación"
|
||||||
|
denied: "Acceso denegado"
|
||||||
_antennaSources:
|
_antennaSources:
|
||||||
all: "Todas las notas"
|
all: "Todas las notas"
|
||||||
homeTimeline: "Notas de los usuarios que sigues"
|
homeTimeline: "Notas de los usuarios que sigues"
|
||||||
users: "Notas de un usuario o varios"
|
users: "Notas de un usuario o varios"
|
||||||
userList: "Notas de los usuarios de una lista"
|
userList: "Notas de los usuarios de una lista"
|
||||||
|
userGroup: "Notas de los usuarios de una grupo"
|
||||||
_weekday:
|
_weekday:
|
||||||
sunday: "Domingo"
|
sunday: "Domingo"
|
||||||
monday: "Lunes"
|
monday: "Lunes"
|
||||||
@ -484,12 +925,18 @@ _widgets:
|
|||||||
trends: "Tendencias"
|
trends: "Tendencias"
|
||||||
clock: "Reloj"
|
clock: "Reloj"
|
||||||
rss: "Lector RSS"
|
rss: "Lector RSS"
|
||||||
|
activity: "Actividad"
|
||||||
|
photos: "Fotos"
|
||||||
|
digitalClock: "Reloj digital"
|
||||||
|
federation: "Federación"
|
||||||
|
postForm: "Formulario"
|
||||||
|
button: "Botón"
|
||||||
|
jobQueue: "Cola de trabajos"
|
||||||
_cw:
|
_cw:
|
||||||
hide: "Ocultar"
|
hide: "Ocultar"
|
||||||
show: "Ver más"
|
show: "Ver más"
|
||||||
chars: "{count} caracteres"
|
chars: "{count} caracteres"
|
||||||
files: "{count} archivos"
|
files: "{count} archivos"
|
||||||
poll: "Encuesta"
|
|
||||||
_poll:
|
_poll:
|
||||||
noOnlyOneChoice: "Se necesitan al menos 2 opciones"
|
noOnlyOneChoice: "Se necesitan al menos 2 opciones"
|
||||||
choiceN: "Opción {n}"
|
choiceN: "Opción {n}"
|
||||||
@ -522,9 +969,11 @@ _visibility:
|
|||||||
specified: "Mensaje directo"
|
specified: "Mensaje directo"
|
||||||
specifiedDescription: "Visible sólo para los usuarios elegidos"
|
specifiedDescription: "Visible sólo para los usuarios elegidos"
|
||||||
localOnly: "Solo local"
|
localOnly: "Solo local"
|
||||||
|
localOnlyDescription: "Oculto para usuarios remotos"
|
||||||
_postForm:
|
_postForm:
|
||||||
replyPlaceholder: "Responder a esta nota"
|
replyPlaceholder: "Responder a esta nota"
|
||||||
quotePlaceholder: "Citar esta nota"
|
quotePlaceholder: "Citar esta nota"
|
||||||
|
channelPlaceholder: "Postear en el canal"
|
||||||
_placeholders:
|
_placeholders:
|
||||||
a: "¿Qué haces?"
|
a: "¿Qué haces?"
|
||||||
b: "¿Te pasó algo?"
|
b: "¿Te pasó algo?"
|
||||||
@ -537,7 +986,6 @@ _profile:
|
|||||||
username: "Nombre de usuario"
|
username: "Nombre de usuario"
|
||||||
description: "Descripción"
|
description: "Descripción"
|
||||||
youCanIncludeHashtags: "Puedes añadir hashtags"
|
youCanIncludeHashtags: "Puedes añadir hashtags"
|
||||||
metadata: "Información adicional"
|
|
||||||
metadataLabel: "Etiqueta"
|
metadataLabel: "Etiqueta"
|
||||||
metadataContent: "Contenido"
|
metadataContent: "Contenido"
|
||||||
_exportOrImport:
|
_exportOrImport:
|
||||||
@ -563,63 +1011,120 @@ _charts:
|
|||||||
_instanceCharts:
|
_instanceCharts:
|
||||||
requests: "Pedidos"
|
requests: "Pedidos"
|
||||||
users: "Variación de usuarios"
|
users: "Variación de usuarios"
|
||||||
usersTotal: "Total de usuarios"
|
usersTotal: "Total acumulado de usuarios"
|
||||||
notes: "Variación de la cantidad de notas"
|
notes: "Variación de la cantidad de notas"
|
||||||
notesTotal: "Estimación de notas"
|
notesTotal: "Total acumulado de la cantidad de notas"
|
||||||
ff: "Variación de cantidad de seguidos/seguidores"
|
ff: "Variación de cantidad de seguidos/seguidores"
|
||||||
ffTotal: "Total de seguidos/seguidores"
|
ffTotal: "Total acumulado de cantidad de seguidos/seguidores"
|
||||||
cacheSize: "Variación del tamaño de la caché"
|
cacheSize: "Variación del tamaño de la caché"
|
||||||
cacheSizeTotal: "Total del tamaño de la caché"
|
cacheSizeTotal: "Total acumulado del tamaño de la caché"
|
||||||
files: "Variación de cantidad de archivos"
|
files: "Variación de cantidad de archivos"
|
||||||
filesTotal: "Total de archivos"
|
filesTotal: "Total acumulado de cantidad de archivos"
|
||||||
_timelines:
|
_timelines:
|
||||||
home: "Inicio"
|
home: "Inicio"
|
||||||
local: "Local"
|
local: "Local"
|
||||||
social: "Social"
|
social: "Social"
|
||||||
global: "Global"
|
global: "Global"
|
||||||
|
_rooms:
|
||||||
|
roomOf: "Cuarto de {user}"
|
||||||
|
addFurniture: "Colocar muebles"
|
||||||
|
translate: "Mover"
|
||||||
|
rotate: "Rotar"
|
||||||
|
exit: "Deseleccionar"
|
||||||
|
remove: "Quitar"
|
||||||
|
clear: "Quitar todo"
|
||||||
|
clearConfirm: "¿Quiere quitar todos los muebles?"
|
||||||
|
leaveConfirm: "Hay modificaciones sin guardar. ¿Desea irse?"
|
||||||
|
chooseImage: "Escoger una imagen"
|
||||||
|
roomType: "Estilo de cuarto"
|
||||||
|
carpetColor: "Color de piso"
|
||||||
|
_roomType:
|
||||||
|
default: "Predeterminado"
|
||||||
|
washitsu: "Estilo japonés"
|
||||||
|
_furnitures:
|
||||||
|
milk: "Cartón de leche"
|
||||||
|
bed: "Cama"
|
||||||
|
low-table: "Mesa chica"
|
||||||
|
desk: "Escritorio"
|
||||||
|
chair: "Silla"
|
||||||
|
chair2: "Silla 2"
|
||||||
|
fan: "Ventilador"
|
||||||
|
pc: "Computadora"
|
||||||
|
plant: "Planta decorativa"
|
||||||
|
plant2: "Planta decorativa 2"
|
||||||
|
eraser: "Goma de borrar"
|
||||||
|
pencil: "lápiz"
|
||||||
|
pudding: "Pudín"
|
||||||
|
cardboard-box: "Caja de cartón"
|
||||||
|
cardboard-box2: "Caja de cartón 2"
|
||||||
|
cardboard-box3: "Caja de cartón 3"
|
||||||
|
book: "Libro"
|
||||||
|
book2: "Libro 2"
|
||||||
|
piano: "Piano"
|
||||||
|
facial-tissue: "Caja de pañuelos"
|
||||||
|
server: "Servidor"
|
||||||
|
moon: "Luna"
|
||||||
|
corkboard: "Pizarra de corcho"
|
||||||
|
mousepad: "Alfombrilla de ratón"
|
||||||
|
monitor: "Monitor"
|
||||||
|
keyboard: "Teclado"
|
||||||
|
carpet-stripe: "Alfombra (a rayas)"
|
||||||
|
mat: "Tapete"
|
||||||
|
color-box: "Caja de colores"
|
||||||
|
wall-clock: "Reloj de pared"
|
||||||
|
photoframe: "Fotograma"
|
||||||
|
cube: "Cubo"
|
||||||
|
tv: "Televisor"
|
||||||
|
pinguin: "Pinguino"
|
||||||
|
rubik-cube: "Cubo rubik"
|
||||||
|
poster-h: "Poster (horizontal)"
|
||||||
|
poster-v: "Poster (vertical)"
|
||||||
|
sofa: "Sillón"
|
||||||
|
spiral: "Escalera en espiral"
|
||||||
|
bin: "Papelera"
|
||||||
|
cup-noodle: "Taza de sopa de fideos"
|
||||||
|
holo-display: "Poster holográfico"
|
||||||
|
energy-drink: "Bebida energética"
|
||||||
|
doll-ai: "Muñeca"
|
||||||
|
banknote: "Billetes"
|
||||||
_pages:
|
_pages:
|
||||||
newPage: "Crear página"
|
newPage: "Crear página"
|
||||||
editPage: "Editar página"
|
editPage: "Editar página"
|
||||||
readPage: "Viendo la fuente"
|
readPage: "Viendo la fuente"
|
||||||
page-created: "La página fue creada"
|
created: "La página fue creada"
|
||||||
page-updated: "La página fue actualizada"
|
updated: "La página fue actualizada"
|
||||||
name-already-exists: "La URL de la página seleccionada ya existe"
|
deleted: "La página borrada"
|
||||||
title-invalid-name: "URL inválida"
|
nameAlreadyExists: "La URL de la página especificada ya existe"
|
||||||
text-invalid-name: "Verifique que no tenga espacios en blanco"
|
invalidNameTitle: "URL inválida"
|
||||||
|
invalidNameText: "Verifique que no tenga espacios en blanco"
|
||||||
editThisPage: "Editar esta página"
|
editThisPage: "Editar esta página"
|
||||||
viewSource: "Ver la fuente"
|
viewSource: "Ver la fuente"
|
||||||
viewPage: "Ver página"
|
viewPage: "Ver página"
|
||||||
like: "Me gusta"
|
like: "Me gusta"
|
||||||
unlike: "Quitar me gusta"
|
unlike: "Quitar me gusta"
|
||||||
liked-pages: "Páginas que me gustan"
|
my: "Mis páginas"
|
||||||
my-pages: "Mis páginas"
|
liked: "Páginas que me gustan"
|
||||||
inspector: "Inspector"
|
inspector: "Inspector"
|
||||||
|
contents: "Contenido"
|
||||||
content: "Bloque de página"
|
content: "Bloque de página"
|
||||||
variables: "Variables"
|
variables: "Variables"
|
||||||
variables-info: "Puedes crear una página dinámica usando variables. Al escribir el <b>{ nombre de la variable }</b> dentro del texto, se puede embeber el valor de la variable allí. Por ejemplo, si en el texto <b>¡Hola { thing } mundo!</b> el valor de la variable (thing) es <b>ai</b>, el texto se vuelve <b>¡Hola ai mundo!</b>"
|
|
||||||
variables-info2: "La evaluación de las variables (el cálculo de los valores) se hace de arriba a abajo, por eso una variable no puede referenciar a otra que esté debajo. Por ejemplo, cuando se definen las variables <b>A、B、C</b>, <b>C</b> puede referenciar a <b>A</b> o <b>B</b>, pero <b>A</b> no puede referenciar a <b>B</b> ni a <b>C</b>."
|
|
||||||
variables-info3: "Para recibir la entrada del usuario, agregue un bloque \"entrada de usuario\" en la página, y configure el nombre de las variables que desea almacenar en el campo \"nombre de variables\" (Las variables se crearán automáticamente). Se ejecutaran acciones en base a la entrada del usuario de esas variables."
|
|
||||||
variables-info4: "Al usar funciones, se pueden agrupar el cálculo de valores de forma reutilizable. Para crear una función, se crea una variable de tipo \"función\". A la función de le puede configurar un slot (argumento), y el valor del slot está disponible como variable dentro de la función. También existen funciones que usan funciones como argumentos bajo el estandar AiScript (llamadas funciones de orden superior). Además de las funciones definidas previamente, se pueden definir funciones al momento en los slots de las funciones de orden superior."
|
|
||||||
more-details: "Más detalles"
|
|
||||||
title: "Título"
|
title: "Título"
|
||||||
url: "URL de la página"
|
url: "URL de la página"
|
||||||
summary: "Resumen de la página"
|
summary: "Resumen de la página"
|
||||||
alignCenter: "Centrar"
|
alignCenter: "Centrar"
|
||||||
hide-title-when-pinned: "Ocultar el título de la página al fijarse"
|
hideTitleWhenPinned: "Ocultar el título de la página al fijarse"
|
||||||
font: "Fuente"
|
font: "Fuente"
|
||||||
fontSerif: "Serif"
|
fontSerif: "Serif"
|
||||||
fontSansSerif: "Sans Serif"
|
fontSansSerif: "Sans Serif"
|
||||||
set-eye-catching-image: "Elegir imagen llamativa"
|
eyeCatchingImageSet: "Elegir imagen llamativa"
|
||||||
remove-eye-catching-image: "Borrar imagen llamativa"
|
eyeCatchingImageRemove: "Borrar imagen llamativa"
|
||||||
chooseBlock: "Agregar bloque"
|
chooseBlock: "Agregar bloque"
|
||||||
selectType: "Elegir tipo"
|
selectType: "Elegir tipo"
|
||||||
enterVariableName: "Ingrese el nombre de la variable"
|
enterVariableName: "Ingrese el nombre de la variable"
|
||||||
the-variable-name-is-already-used: "El nombre de la variable ya está en uso"
|
variableNameIsAlreadyUsed: "El nombre de la variable ya está en uso"
|
||||||
content-blocks: "Contenido"
|
contentBlocks: "Contenido"
|
||||||
input-blocks: "Entrada"
|
inputBlocks: "Entrada"
|
||||||
special-blocks: "Especial"
|
specialBlocks: "Especial"
|
||||||
post-from-post-form: "Postear este contenido"
|
|
||||||
posted-from-post-form: "Posteado"
|
|
||||||
blocks:
|
blocks:
|
||||||
text: "Texto"
|
text: "Texto"
|
||||||
textarea: "Área de texto"
|
textarea: "Área de texto"
|
||||||
@ -632,6 +1137,8 @@ _pages:
|
|||||||
post: "Formulario"
|
post: "Formulario"
|
||||||
_post:
|
_post:
|
||||||
text: "Contenido"
|
text: "Contenido"
|
||||||
|
attachCanvasImage: "Nota con lienzo como imagen"
|
||||||
|
canvasId: "Lienzo ID"
|
||||||
textInput: "Entrada de texto"
|
textInput: "Entrada de texto"
|
||||||
_textInput:
|
_textInput:
|
||||||
name: "Nombre de variable"
|
name: "Nombre de variable"
|
||||||
@ -647,6 +1154,11 @@ _pages:
|
|||||||
name: "Nombre de variable"
|
name: "Nombre de variable"
|
||||||
text: "Título"
|
text: "Título"
|
||||||
default: "Valor predeterminado"
|
default: "Valor predeterminado"
|
||||||
|
canvas: "Lienzo"
|
||||||
|
_canvas:
|
||||||
|
id: "Lienzo ID"
|
||||||
|
width: "Ancho"
|
||||||
|
height: "Altura"
|
||||||
switch: "Interruptor"
|
switch: "Interruptor"
|
||||||
_switch:
|
_switch:
|
||||||
name: "Nombre de variable"
|
name: "Nombre de variable"
|
||||||
@ -672,6 +1184,9 @@ _pages:
|
|||||||
message: "Mensaje mostrado al apretar"
|
message: "Mensaje mostrado al apretar"
|
||||||
variable: "Variable a enviar"
|
variable: "Variable a enviar"
|
||||||
no-variable: "Ninguna"
|
no-variable: "Ninguna"
|
||||||
|
callAiScript: "Invocar AiScript"
|
||||||
|
_callAiScript:
|
||||||
|
functionName: "Nombre de la función"
|
||||||
radioButton: "Botón de opción"
|
radioButton: "Botón de opción"
|
||||||
_radioButton:
|
_radioButton:
|
||||||
name: "Nombre de variable"
|
name: "Nombre de variable"
|
||||||
@ -832,6 +1347,7 @@ _pages:
|
|||||||
_splitStrByLine:
|
_splitStrByLine:
|
||||||
arg1: "Texto"
|
arg1: "Texto"
|
||||||
ref: "Variables"
|
ref: "Variables"
|
||||||
|
aiScriptVar: "Variable de AiScript"
|
||||||
fn: "funciones"
|
fn: "funciones"
|
||||||
_fn:
|
_fn:
|
||||||
slots: "Slots"
|
slots: "Slots"
|
||||||
@ -853,3 +1369,51 @@ _pages:
|
|||||||
enviromentVariables: "Variables de entorno"
|
enviromentVariables: "Variables de entorno"
|
||||||
pageVariables: "Items de la página"
|
pageVariables: "Items de la página"
|
||||||
argVariables: "Slot de entrada"
|
argVariables: "Slot de entrada"
|
||||||
|
_relayStatus:
|
||||||
|
requesting: "Pendiente"
|
||||||
|
accepted: "Aceptar"
|
||||||
|
rejected: "Rechazada"
|
||||||
|
_notification:
|
||||||
|
fileUploaded: "Archivo subido"
|
||||||
|
youGotMention: "Mención de {name}"
|
||||||
|
youGotReply: "Respuesta de {name}"
|
||||||
|
youGotQuote: "Citado por {name}"
|
||||||
|
youRenoted: "Renotado por {name}"
|
||||||
|
youGotPoll: "Encuestado por {name}"
|
||||||
|
youGotMessagingMessageFromUser: "{name} comenzó un chat contigo"
|
||||||
|
youGotMessagingMessageFromGroup: "Tienes un chat de {name}"
|
||||||
|
youWereFollowed: "te ha seguido"
|
||||||
|
youReceivedFollowRequest: "Has mandado una solicitud de seguimiento"
|
||||||
|
yourFollowRequestAccepted: "Tu solicitud de seguimiento fue aceptada"
|
||||||
|
youWereInvitedToGroup: "Invitado al grupo"
|
||||||
|
_types:
|
||||||
|
all: "Todo"
|
||||||
|
follow: "Siguiendo"
|
||||||
|
mention: "Menciones"
|
||||||
|
reply: "Respuestas"
|
||||||
|
renote: "Renotar"
|
||||||
|
quote: "Citar"
|
||||||
|
reaction: "Reacción"
|
||||||
|
pollVote: "Votado en la encuesta"
|
||||||
|
receiveFollowRequest: "Recibió una solicitud de seguimiento"
|
||||||
|
followRequestAccepted: "El seguimiento fue aceptado"
|
||||||
|
groupInvited: "Invitado al grupo"
|
||||||
|
app: "Notificaciones desde aplicaciones"
|
||||||
|
_deck:
|
||||||
|
alwaysShowMainColumn: "Siempre mostrar la columna principal"
|
||||||
|
columnAlign: "Alinear columnas"
|
||||||
|
addColumn: "Agregar columna"
|
||||||
|
swapLeft: "Mover a la izquierda"
|
||||||
|
swapRight: "Mover a la derecha"
|
||||||
|
swapUp: "Mover arriba"
|
||||||
|
swapDown: "Mover abajo"
|
||||||
|
stackLeft: "Apilar a la izquierda"
|
||||||
|
popRight: "Sacar a la derecha"
|
||||||
|
_columns:
|
||||||
|
widgets: "Widgets"
|
||||||
|
notifications: "Notificaciones"
|
||||||
|
tl: "Linea de tiempo"
|
||||||
|
antenna: "Antenas"
|
||||||
|
list: "Listas"
|
||||||
|
mentions: "Menciones"
|
||||||
|
direct: "Mensaje directo"
|
||||||
|
1055
locales/fr-FR.yml
1
locales/ht-HT.yml
Normal file
@ -0,0 +1 @@
|
|||||||
|
---
|
257
locales/id-ID.yml
Normal file
@ -0,0 +1,257 @@
|
|||||||
|
---
|
||||||
|
_lang_: "Bahasa Jepang"
|
||||||
|
headlineMisskey: "Catatan terhubung jaringan"
|
||||||
|
introMisskey: "Selamat datang! Misskey adalah perangkat mikroblog tercatu bersifat sumber terbuka.\nMulailah menuliskan catatan, bagikan peristiwa terkini, serta ceritakan segala tentangmu.📡\nTunjukkan juga reaksimu pada catatan pengguna lain.👍\nMari jelajahi dunia baru🚀"
|
||||||
|
monthAndDay: "{day} {month}"
|
||||||
|
search: "Pencarian"
|
||||||
|
notifications: "Notifikasi"
|
||||||
|
username: "Nama Pengguna"
|
||||||
|
password: "Kata sandi"
|
||||||
|
ok: "OK"
|
||||||
|
gotIt: "Saya mengerti"
|
||||||
|
cancel: "Batalkan"
|
||||||
|
enterUsername: "Masukkan nama pengguna"
|
||||||
|
renotedBy: "direnote oleh {user}"
|
||||||
|
noNotes: "Tidak ada notes"
|
||||||
|
noNotifications: "Tidak ada notifikasi"
|
||||||
|
settings: "Pengaturan"
|
||||||
|
basicSettings: "Pengaturan umum"
|
||||||
|
otherSettings: "Pengaturan lainnya"
|
||||||
|
openInWindow: "Buka di jendela"
|
||||||
|
profile: "Profil"
|
||||||
|
timeline: "Linimasa"
|
||||||
|
noAccountDescription: "Pengguna ini belum menulis bio"
|
||||||
|
login: "Masuk"
|
||||||
|
loggingIn: "Sedang masuk"
|
||||||
|
logout: "Keluar"
|
||||||
|
signup: "Daftar"
|
||||||
|
uploading: "Sedang mengunggah"
|
||||||
|
save: "Simpan"
|
||||||
|
users: "Pengguna"
|
||||||
|
addUser: "Tambah pengguna"
|
||||||
|
favorite: "Favorit"
|
||||||
|
favorites: "Favorit"
|
||||||
|
unfavorite: "Hapus favorit"
|
||||||
|
favorited: "Ditambahkan ke favorit"
|
||||||
|
alreadyFavorited: "Telah ditambahkan ke favorit"
|
||||||
|
cantFavorite: "Tidak dapat menambahkan ke favorit"
|
||||||
|
pin: "Sematkan ke profil"
|
||||||
|
unpin: "Lepas sematan dari profil"
|
||||||
|
copyContent: "Salin konten"
|
||||||
|
copyLink: "Salin tautan"
|
||||||
|
delete: "Hapus"
|
||||||
|
deleteAndEdit: "Hapus dan sunting"
|
||||||
|
addToList: "Tambahkan ke daftar"
|
||||||
|
sendMessage: "Kirim pesan"
|
||||||
|
copyUsername: "Salin nama pengguna"
|
||||||
|
searchUser: "Cari pengguna"
|
||||||
|
reply: "Balas"
|
||||||
|
loadMore: "Selebihnya"
|
||||||
|
showMore: "Selebihnya"
|
||||||
|
youGotNewFollower: "Sedang mengikuti"
|
||||||
|
receiveFollowRequest: "Permintaan mengikuti terkirim"
|
||||||
|
mention: "Panggilan"
|
||||||
|
files: "Berkas"
|
||||||
|
download: "Unduh"
|
||||||
|
driveFileDeleteConfirm: "Hapus {name}? Catatan dengan berkas terkait juga akan terhapus."
|
||||||
|
unfollowConfirm: "Berhenti mengikuti {name}?"
|
||||||
|
following: "Ikuti"
|
||||||
|
followers: "Pengikut"
|
||||||
|
followsYou: "Mengikuti Anda"
|
||||||
|
error: "Galat"
|
||||||
|
somethingHappened: "Terjadi kesalahan"
|
||||||
|
retry: "Coba lagi"
|
||||||
|
pageLoadError: "Gagal memuat halaman."
|
||||||
|
pageLoadErrorDescription: "Umumnya disebabkan jaringan atau tembolok perambah. Cobalah bersihkan tembolok peramban lalu tunggu sesaat sebelum mencoba kembali."
|
||||||
|
privacy: "Keleluasaan"
|
||||||
|
follow: "Ikuti"
|
||||||
|
unfollow: "Berhenti mengikuti"
|
||||||
|
cantReRenote: "Renote tidak dapat direnote"
|
||||||
|
quote: "Kutip"
|
||||||
|
pinnedNote: "Note yang disematkan"
|
||||||
|
pinned: "Sematkan ke profil"
|
||||||
|
you: "Anda"
|
||||||
|
clickToShow: "Klik untuk melihat"
|
||||||
|
sensitive: "Konten sensitif"
|
||||||
|
add: "Tambahkan"
|
||||||
|
reaction: "Reaksi"
|
||||||
|
reactionSettingDescription: "Masukkan reaksi favorit yang ingin anda sematkan pada bilah reaksi"
|
||||||
|
reactionSettingDescription2: "Geser untuk memindah urutkan, klik untuk menghapus, tekan \"+\" untuk menambahkan"
|
||||||
|
rememberNoteVisibility: "Ingat pengaturan visibilitas note"
|
||||||
|
attachCancel: "Hapus lampiran"
|
||||||
|
markAsSensitive: "Tandai sebagai konten sensitif"
|
||||||
|
unmarkAsSensitive: "Hapus tanda konten sensitif"
|
||||||
|
enterFileName: "Masukkan nama berkas"
|
||||||
|
mute: "Bisukan"
|
||||||
|
unmute: "Hapus bisukan"
|
||||||
|
block: "Blokir"
|
||||||
|
unblock: "Buka blokir"
|
||||||
|
suspend: "Bekukan"
|
||||||
|
unsuspend: "Buka pembekuan"
|
||||||
|
blockConfirm: "Apakah anda yakin ingin memblokir akun ini?"
|
||||||
|
unblockConfirm: "Apakah anda yakin ingin membuka blokir akun ini?"
|
||||||
|
suspendConfirm: "Apakah anda yakin ingin membekukan akun ini?"
|
||||||
|
unsuspendConfirm: "Apakah anda yakin ingin membuka pembekuan akun ini?"
|
||||||
|
selectList: "Pilih daftar"
|
||||||
|
selectAntenna: "Pilih Antena"
|
||||||
|
selectWidget: "Pilih gawit"
|
||||||
|
editWidgets: "Sunting gawit"
|
||||||
|
editWidgetsExit: "Selesai"
|
||||||
|
customEmojis: "Emoji kustom"
|
||||||
|
emoji: "Emoji"
|
||||||
|
emojiName: "Nama emoji"
|
||||||
|
emojiUrl: "URL Emoji"
|
||||||
|
addEmoji: "Tambahkan emoji"
|
||||||
|
settingGuide: "Pengaturan rekomendasi"
|
||||||
|
cacheRemoteFiles: "Tembolokkan berkas remote"
|
||||||
|
flagAsBot: "Atur akun ini sebagai Bot"
|
||||||
|
flagAsCat: "Atur akun ini sebagai kucing"
|
||||||
|
autoAcceptFollowed: "Setujui otomatis permintaan mengikuti dari pengguna yang anda ikuti"
|
||||||
|
addAcount: "Tambahkan akun"
|
||||||
|
loginFailed: "Gagal untuk masuk"
|
||||||
|
showOnRemote: "Lihat profil asli"
|
||||||
|
general: "Umum"
|
||||||
|
wallpaper: "Wallpaper"
|
||||||
|
setWallpaper: "Atur wallpaper"
|
||||||
|
removeWallpaper: "Hapus wallpaper"
|
||||||
|
intro: "Instalasi Misskey telah selesai! Mohon untuk membuat pengguna admin."
|
||||||
|
done: "Selesai"
|
||||||
|
processing: "Memproses"
|
||||||
|
preview: "Pratinjau"
|
||||||
|
default: "Bawaan"
|
||||||
|
noCustomEmojis: "Tidak ada emoji kustom"
|
||||||
|
federating: "memfederasi"
|
||||||
|
blocked: "Diblokir"
|
||||||
|
all: "Semua"
|
||||||
|
subscribing: "Berlangganan"
|
||||||
|
publishing: "Sedang menyiarkan langsung"
|
||||||
|
notResponding: "Tidak ada respon"
|
||||||
|
instanceFollowing: "Mengikuti instance"
|
||||||
|
instanceFollowers: "Pengikut instance"
|
||||||
|
instanceUsers: "Pengguna pada instance ini"
|
||||||
|
changePassword: "Ubah kata sandi"
|
||||||
|
security: "Keamanan"
|
||||||
|
retypedNotMatch: "Input tidak sama"
|
||||||
|
currentPassword: "Kata sandi saat ini"
|
||||||
|
newPassword: "Kata sandi baru"
|
||||||
|
newPasswordRetype: "Ulangi kata sandi baru"
|
||||||
|
attachFile: "Lampirkan berkas"
|
||||||
|
more: "Lagi !"
|
||||||
|
featured: "Sorotan"
|
||||||
|
usernameOrUserId: "Nama pengguna atau User ID"
|
||||||
|
noSuchUser: "Pengguna tidak ditemukan"
|
||||||
|
lookup: "Mencari"
|
||||||
|
announcements: "Pengumuman"
|
||||||
|
imageUrl: "URL Gambar"
|
||||||
|
remove: "Hapus"
|
||||||
|
removed: "Telah dihapus"
|
||||||
|
removeAreYouSure: "Apakah anda yakin ingin menghapus \"{x}\"?"
|
||||||
|
deleteAreYouSure: "Apakah anda yakin ingin menghapus \"{x}\"?"
|
||||||
|
saved: "Telah disimpan"
|
||||||
|
messaging: "Pesan"
|
||||||
|
upload: "Unggah"
|
||||||
|
fromDrive: "Dari Drive"
|
||||||
|
fromUrl: "Dari URL"
|
||||||
|
uploadFromUrl: "Unggah dari URL"
|
||||||
|
uploadFromUrlDescription: "URL berkas yang ingin anda unggah"
|
||||||
|
uploadFromUrlRequested: "Pengunggahan telah diminta"
|
||||||
|
uploadFromUrlMayTakeTime: "Membutuhkan beberapa waktu hingga pengunggahan selesai"
|
||||||
|
explore: "Jelajahi"
|
||||||
|
games: "Permainan Misskey"
|
||||||
|
messageRead: "Telah dibaca"
|
||||||
|
noMoreHistory: "Tidak ada sejarah lagi"
|
||||||
|
startMessaging: "Mulai mengirim pesan"
|
||||||
|
nUsersRead: "Dibaca oleh {n}"
|
||||||
|
nsfw: "Konten sensitif"
|
||||||
|
watch: "Tonton"
|
||||||
|
unwatch: "Batal tonton"
|
||||||
|
accept: "Terima"
|
||||||
|
reject: "Tolak"
|
||||||
|
normal: "Normal"
|
||||||
|
instanceName: "Nama instance"
|
||||||
|
instanceDescription: "Tentang instance"
|
||||||
|
maintainerName: "Pengelola"
|
||||||
|
maintainerEmail: "Surel pengelola"
|
||||||
|
tosUrl: "URL Syarat dan Ketentuan"
|
||||||
|
thisYear: "Tahun ini"
|
||||||
|
thisMonth: "Bulan ini"
|
||||||
|
today: "Hari ini"
|
||||||
|
dayX: "{day}"
|
||||||
|
monthX: "{month}"
|
||||||
|
yearX: "{year}"
|
||||||
|
pages: "Halaman"
|
||||||
|
integration: "Integrasi"
|
||||||
|
connectSerice: "Sambungkan"
|
||||||
|
disconnectSerice: "Putuskan"
|
||||||
|
enableLocalTimeline: "Nyalakan linimasa lokal"
|
||||||
|
enableGlobalTimeline: "Nyalakan linimasa global"
|
||||||
|
registration: "Pendaftaran"
|
||||||
|
enableRegistration: "Nyalakan pendaftaran pengguna baru"
|
||||||
|
invite: "Undang"
|
||||||
|
proxyRemoteFiles: "Proksi berkas remote"
|
||||||
|
driveCapacityPerLocalAccount: "Kapasitas drive per pengguna lokal"
|
||||||
|
driveCapacityPerRemoteAccount: "Kapasitas drive per pengguna remote"
|
||||||
|
inMb: "dalam Megabytes"
|
||||||
|
iconUrl: "URL Gambar ikon"
|
||||||
|
bannerUrl: "URL Banner"
|
||||||
|
basicInfo: "Informasi Umum"
|
||||||
|
pinnedUsers: "Pengguna yang disematkan"
|
||||||
|
pinnedPages: "Halaman yang disematkan"
|
||||||
|
pinnedNotes: "Note yang disematkan"
|
||||||
|
hcaptcha: "hCaptcha"
|
||||||
|
enableHcaptcha: "Nyalakan hCaptcha"
|
||||||
|
hcaptchaSiteKey: "Site Key"
|
||||||
|
hcaptchaSecretKey: "Secret Key"
|
||||||
|
recaptcha: "reCAPTCHA"
|
||||||
|
enableRecaptcha: "Nyalakan reCAPTCHA"
|
||||||
|
recaptchaSiteKey: "Site key"
|
||||||
|
recaptchaSecretKey: "Secret Key"
|
||||||
|
antennas: "Antena"
|
||||||
|
manageAntennas: "Pengelola Antena"
|
||||||
|
notFound: "Tidak dapat ditemukan"
|
||||||
|
invites: "Undang"
|
||||||
|
invitations: "Undang"
|
||||||
|
smtpUser: "Nama Pengguna"
|
||||||
|
smtpPass: "Kata sandi"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "Sedang mengikuti"
|
||||||
|
_mfm:
|
||||||
|
mention: "Panggilan"
|
||||||
|
quote: "Kutip"
|
||||||
|
emoji: "Emoji kustom"
|
||||||
|
search: "Pencarian"
|
||||||
|
_theme:
|
||||||
|
keys:
|
||||||
|
mention: "Panggilan"
|
||||||
|
_sfx:
|
||||||
|
notification: "Notifikasi"
|
||||||
|
chat: "Pesan"
|
||||||
|
_widgets:
|
||||||
|
notifications: "Notifikasi"
|
||||||
|
timeline: "Linimasa"
|
||||||
|
_cw:
|
||||||
|
show: "Selebihnya"
|
||||||
|
_visibility:
|
||||||
|
followers: "Pengikut"
|
||||||
|
_profile:
|
||||||
|
username: "Nama Pengguna"
|
||||||
|
_exportOrImport:
|
||||||
|
followingList: "Ikuti"
|
||||||
|
muteList: "Bisukan"
|
||||||
|
blockingList: "Blokir"
|
||||||
|
_rooms:
|
||||||
|
_roomType:
|
||||||
|
default: "Bawaan"
|
||||||
|
_notification:
|
||||||
|
youWereFollowed: "Sedang mengikuti"
|
||||||
|
_types:
|
||||||
|
follow: "Ikuti"
|
||||||
|
mention: "Panggilan"
|
||||||
|
quote: "Kutip"
|
||||||
|
reaction: "Reaksi"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "Notifikasi"
|
||||||
|
tl: "Linimasa"
|
||||||
|
antenna: "Antena"
|
@ -14,19 +14,27 @@ const merge = (...args) => args.reduce((a, c) => ({
|
|||||||
}), {});
|
}), {});
|
||||||
|
|
||||||
const languages = [
|
const languages = [
|
||||||
//'cs-CZ',
|
'ar-SA',
|
||||||
//'da-DK',
|
'cs-CZ',
|
||||||
//'de-DE',
|
'da-DK',
|
||||||
|
'de-DE',
|
||||||
'en-US',
|
'en-US',
|
||||||
'es-ES',
|
'es-ES',
|
||||||
'fr-FR',
|
'fr-FR',
|
||||||
'ja-JP',
|
'ja-JP',
|
||||||
'ja-KS',
|
'ja-KS',
|
||||||
|
'kab-KAB',
|
||||||
|
'kn-IN',
|
||||||
'ko-KR',
|
'ko-KR',
|
||||||
//'nl-NL',
|
'nl-NL',
|
||||||
//'pl-PL',
|
'no-NO',
|
||||||
|
'pl-PL',
|
||||||
|
'pt-PT',
|
||||||
|
'ru-RU',
|
||||||
|
'ug-CN',
|
||||||
|
'uk-UA',
|
||||||
'zh-CN',
|
'zh-CN',
|
||||||
//'zh-TW',
|
'zh-TW',
|
||||||
];
|
];
|
||||||
|
|
||||||
const primaries = {
|
const primaries = {
|
||||||
@ -35,7 +43,7 @@ const primaries = {
|
|||||||
'zh': 'CN',
|
'zh': 'CN',
|
||||||
};
|
};
|
||||||
|
|
||||||
const locales = languages.reduce((a, c) => (a[c] = yaml.safeLoad(fs.readFileSync(`${__dirname}/${c}.yml`, 'utf-8')) || {}, a), {});
|
const locales = languages.reduce((a, c) => (a[c] = yaml.load(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] = (() => {
|
||||||
|
577
locales/it-IT.yml
Normal file
@ -0,0 +1,577 @@
|
|||||||
|
---
|
||||||
|
_lang_: "Italiano"
|
||||||
|
monthAndDay: "{day}/{month}"
|
||||||
|
search: "Cerca"
|
||||||
|
notifications: "Notifiche"
|
||||||
|
username: "Nome utente"
|
||||||
|
password: "Password"
|
||||||
|
ok: "OK"
|
||||||
|
cancel: "Annulla"
|
||||||
|
enterUsername: "Inserisci un nome utente"
|
||||||
|
renotedBy: "Rinotta da {user}"
|
||||||
|
noNotes: "Nessuna note"
|
||||||
|
noNotifications: "Nessuna notifica"
|
||||||
|
instance: "Istanza"
|
||||||
|
settings: "Impostazioni"
|
||||||
|
basicSettings: "Impostazioni generali"
|
||||||
|
otherSettings: "Altre impostazioni"
|
||||||
|
profile: "Profilo"
|
||||||
|
timeline: "Timeline"
|
||||||
|
login: "Accedi"
|
||||||
|
logout: "Logout"
|
||||||
|
signup: "Iscriviti"
|
||||||
|
uploading: "Caricamento..."
|
||||||
|
save: "Salva"
|
||||||
|
users: "Utente"
|
||||||
|
favorite: "Segnalibri"
|
||||||
|
favorites: "Segnalibri"
|
||||||
|
unfavorite: "Rimuovi Nota dai segnalibri"
|
||||||
|
favorited: "Nota salvato nei segnalibri."
|
||||||
|
alreadyFavorited: "Tweet salvato nei segnalibri."
|
||||||
|
pin: "Fissa sul profilo"
|
||||||
|
unpin: "Non fissare più sul profilo"
|
||||||
|
copyContent: "Copia il contenuto del Nota"
|
||||||
|
copyLink: "Copia link"
|
||||||
|
delete: "Elimina"
|
||||||
|
deleteAndEdit: "Elimina & Modifica"
|
||||||
|
addToList: "Aggiungi alla lista"
|
||||||
|
sendMessage: "Invia messaggio"
|
||||||
|
copyUsername: "Copia nome utente"
|
||||||
|
searchUser: "Cerca Utente"
|
||||||
|
reply: "Rispondi"
|
||||||
|
loadMore: "Mostra altre"
|
||||||
|
showMore: "Mostra altre"
|
||||||
|
youGotNewFollower: "Nuovo seguace"
|
||||||
|
receiveFollowRequest: "Nuova richiesta di essere seguito"
|
||||||
|
mention: "Menzioni"
|
||||||
|
mentions: "Menzioni"
|
||||||
|
directNotes: "Note diretti"
|
||||||
|
importAndExport: "Importa ed Esporta"
|
||||||
|
import: "Importa"
|
||||||
|
export: "Esporta"
|
||||||
|
files: "Allegato"
|
||||||
|
download: "Scarica"
|
||||||
|
lists: "Liste"
|
||||||
|
noLists: "Qui non c'è ancora niente"
|
||||||
|
note: "Nota"
|
||||||
|
notes: "Nota"
|
||||||
|
following: "Seiguiti"
|
||||||
|
followers: "Seguaci"
|
||||||
|
followsYou: "Ti segue"
|
||||||
|
createList: "Crea una nuova lista"
|
||||||
|
manageLists: "Modifica lista"
|
||||||
|
error: "Errore"
|
||||||
|
somethingHappened: "Qualcosa è andato storto."
|
||||||
|
retry: "Riprova"
|
||||||
|
enterListName: "Inserisci il nome della lista"
|
||||||
|
privacy: "Privacy"
|
||||||
|
follow: "Segui"
|
||||||
|
followRequest: "Richiesta di seguire"
|
||||||
|
followRequests: "Richiesta di seguire"
|
||||||
|
unfollow: "Smetti di seguire"
|
||||||
|
followRequestPending: "In sospeso"
|
||||||
|
renote: "Rinotta"
|
||||||
|
unrenote: "Annulla rinotta"
|
||||||
|
quote: "Cita Nota"
|
||||||
|
pinned: "Fissa sul profilo"
|
||||||
|
you: "Tu"
|
||||||
|
clickToShow: "Clicca per visualizzare"
|
||||||
|
sensitive: "Contenuto sensibile"
|
||||||
|
add: "Aggiungi"
|
||||||
|
reaction: "Reazione"
|
||||||
|
attachCancel: "Rimuovi allegato"
|
||||||
|
markAsSensitive: "Segna come sensibile"
|
||||||
|
unmarkAsSensitive: "Segna come non sensibile"
|
||||||
|
mute: "Silenzia"
|
||||||
|
unmute: "Riattiva"
|
||||||
|
block: "Blocca"
|
||||||
|
unblock: "Sblocca"
|
||||||
|
suspend: "Sospendi"
|
||||||
|
unsuspend: "Annulla la sospensione dell'account"
|
||||||
|
blockConfirm: "Vuoi bloccare?"
|
||||||
|
unblockConfirm: "Vuoi sbloccare?"
|
||||||
|
editWidgetsExit: "Modifica fine"
|
||||||
|
emoji: "Emoji"
|
||||||
|
addAcount: "Aggiungi un account esistente"
|
||||||
|
general: "Generali"
|
||||||
|
wallpaper: "Sfondo"
|
||||||
|
setWallpaper: "Imposta sfondo"
|
||||||
|
searchWith: "Cerca: {q}"
|
||||||
|
annotation: "Descrizione"
|
||||||
|
federation: "Federazione"
|
||||||
|
instances: "Istanza"
|
||||||
|
storageUsage: "Volume di dischi"
|
||||||
|
charts: "Grafici"
|
||||||
|
perHour: "All'ora"
|
||||||
|
perDay: "al giorno"
|
||||||
|
software: "Software"
|
||||||
|
version: "Versione"
|
||||||
|
metadata: "Metadato"
|
||||||
|
network: "Rete"
|
||||||
|
disk: "Disco"
|
||||||
|
statistics: "Statistiche"
|
||||||
|
blockedInstances: "Istanza bloccati"
|
||||||
|
muteAndBlock: "Silenziamento e blocco"
|
||||||
|
mutedUsers: "Account silenziati"
|
||||||
|
blockedUsers: "Account bloccati"
|
||||||
|
editProfile: "Modifica profilo"
|
||||||
|
noteDeleteConfirm: "Eliminare questo Nota?"
|
||||||
|
done: "Fine"
|
||||||
|
processing: "In elaborazione"
|
||||||
|
blocked: "Bloccati"
|
||||||
|
all: "Tutti"
|
||||||
|
notResponding: "Nessuna risposta"
|
||||||
|
changePassword: "Aggiorna Password"
|
||||||
|
security: "Sicurezza"
|
||||||
|
retypedNotMatch: "Le password non corrispondono."
|
||||||
|
currentPassword: "Password attuale"
|
||||||
|
newPassword: "Nuova Password"
|
||||||
|
newPasswordRetype: "Conferma nuova password"
|
||||||
|
more: "Altri!"
|
||||||
|
lookup: "Cercare"
|
||||||
|
announcements: "Annuncio"
|
||||||
|
imageUrl: "URL dell'immagine"
|
||||||
|
remove: "Elimina"
|
||||||
|
removed: "Il tuo Tweet è stato eliminato"
|
||||||
|
removeAreYouSure: "Eliminare \"{x}\"?"
|
||||||
|
deleteAreYouSure: "Eliminare \"{x}\"?"
|
||||||
|
resetAreYouSure: "Reimposta"
|
||||||
|
saved: "Salvato"
|
||||||
|
messaging: "Messaggi"
|
||||||
|
upload: "Carica"
|
||||||
|
uploadFromUrl: "Incolla URL immagine"
|
||||||
|
explore: "Esplora"
|
||||||
|
games: "Misskey Giochi"
|
||||||
|
messageRead: "Visualizzato"
|
||||||
|
startMessaging: "Nuovo messaggio"
|
||||||
|
tos: "Termini di servizio"
|
||||||
|
home: "Home"
|
||||||
|
images: "Immagini"
|
||||||
|
birthday: "Compleanno"
|
||||||
|
yearsOld: "{age}Anni"
|
||||||
|
registeredDate: "Iscrizione a.."
|
||||||
|
location: "Posizione"
|
||||||
|
theme: "Tema"
|
||||||
|
light: "Chiaro"
|
||||||
|
dark: "Scuro"
|
||||||
|
lightThemes: "Tema Chiaro"
|
||||||
|
darkThemes: "Tema Scuro"
|
||||||
|
drive: "Drive"
|
||||||
|
fileName: "Nome dell'allegato"
|
||||||
|
copyUrl: "Copia URL"
|
||||||
|
rename: "Modifica nome"
|
||||||
|
avatar: "Foto del profilo"
|
||||||
|
banner: "Foto d'intestazione"
|
||||||
|
nsfw: "Contenuti sensibili"
|
||||||
|
reload: "Ricarica"
|
||||||
|
watch: "Osserva"
|
||||||
|
unwatch: "Smetti di Osserva"
|
||||||
|
accept: "Accetta"
|
||||||
|
reject: "Rifiuta"
|
||||||
|
normal: "Normale"
|
||||||
|
instanceName: "Nome dell'istanza"
|
||||||
|
instanceDescription: "Descrizione dell'istanza"
|
||||||
|
maintainerName: "Nome dell'Amministratore"
|
||||||
|
maintainerEmail: "Indirizzo e-mail dell'Amministratore"
|
||||||
|
tosUrl: "Termini di servizio URL"
|
||||||
|
thisYear: "Anno"
|
||||||
|
thisMonth: "Mese"
|
||||||
|
today: "Oggi"
|
||||||
|
dayX: "{day}"
|
||||||
|
monthX: "{month}"
|
||||||
|
yearX: "{year}"
|
||||||
|
integration: "App collegate"
|
||||||
|
connectSerice: "Connetti"
|
||||||
|
disconnectSerice: "Disconnetti"
|
||||||
|
registration: "Iscriviti"
|
||||||
|
invite: "Invita"
|
||||||
|
bannerUrl: "indirizzo Foto d'intestazione"
|
||||||
|
basicInfo: "Informazioni fondamentali"
|
||||||
|
hcaptcha: "hCaptcha"
|
||||||
|
enableHcaptcha: "Abilita hCaptcha"
|
||||||
|
recaptcha: "reCAPTCHA"
|
||||||
|
enableRecaptcha: "Abilita reCAPTCHA"
|
||||||
|
name: "Nome"
|
||||||
|
serviceworker: "ServiceWorker"
|
||||||
|
exploreFediverse: "Esplora Fediverse"
|
||||||
|
popularTags: "Tag di tendenza"
|
||||||
|
userList: "Liste"
|
||||||
|
about: "Informazioni"
|
||||||
|
aboutMisskey: "Informazioni di Misskey"
|
||||||
|
administrator: "Amministratore"
|
||||||
|
token: "Token"
|
||||||
|
twoStepAuthentication: "Autenticazione a due fattori"
|
||||||
|
moderator: "Moderatore"
|
||||||
|
lastUsed: "Ultima attività"
|
||||||
|
unregister: "Disattiva account"
|
||||||
|
resetPassword: "Reimposta password"
|
||||||
|
share: "Condividi"
|
||||||
|
cacheClear: "Svuota cache"
|
||||||
|
help: "Guida"
|
||||||
|
close: "Chiudi"
|
||||||
|
group: "Gruppo"
|
||||||
|
groups: "Gruppi"
|
||||||
|
createGroup: "Nuovo gruppo"
|
||||||
|
invites: "Invita"
|
||||||
|
transfer: "Trasferisci"
|
||||||
|
title: "Titolo"
|
||||||
|
next: "Avanti"
|
||||||
|
invitations: "Invita"
|
||||||
|
invitationCode: "Codice di invito"
|
||||||
|
available: "Consigliati"
|
||||||
|
unavailable: "Il nome utente è già in uso"
|
||||||
|
usernameInvalidFormat: "Il nome utente può contenere solo lettere, numeri e '_'"
|
||||||
|
tooShort: "Troppo breve"
|
||||||
|
tooLong: "Troppo lungo"
|
||||||
|
passwordNotMatched: "Le password non corrispondono."
|
||||||
|
signinHistory: "Cronologia di accesso all'account"
|
||||||
|
tags: "Tag"
|
||||||
|
createAccount: "Crea il tuo account"
|
||||||
|
existingAcount: "Account esistente"
|
||||||
|
local: "Locale"
|
||||||
|
remote: "Remoto"
|
||||||
|
accountSettings: "Impostazioni Account"
|
||||||
|
promote: "Pubblicizza"
|
||||||
|
objectStorageBucket: "Bucket"
|
||||||
|
objectStorageEndpoint: "Endpoint"
|
||||||
|
objectStorageRegion: "Region"
|
||||||
|
serverLogs: "Log del server"
|
||||||
|
deleteAll: "Cancella cronologia"
|
||||||
|
volume: "Volume"
|
||||||
|
details: "Dettagli"
|
||||||
|
install: "Installa"
|
||||||
|
uninstall: "Disinstalla"
|
||||||
|
installedDate: "Data installazione"
|
||||||
|
sort: "Ordina per"
|
||||||
|
visibility: "Privacy dei post"
|
||||||
|
poll: "Sondaggio"
|
||||||
|
useCw: "Nascondere media"
|
||||||
|
description: "Descrizione"
|
||||||
|
author: "Autore"
|
||||||
|
width: "Larghezza"
|
||||||
|
height: "Altezza"
|
||||||
|
large: "Grande"
|
||||||
|
medium: "Predefinito"
|
||||||
|
small: "Piccolo"
|
||||||
|
edit: "Modifica"
|
||||||
|
email: "Email"
|
||||||
|
smtpUser: "Nome utente"
|
||||||
|
smtpPass: "Password"
|
||||||
|
wordMute: "Parole silenziate"
|
||||||
|
display: "Visualizza"
|
||||||
|
copy: "Copia"
|
||||||
|
logs: "Log"
|
||||||
|
database: "Base di dati"
|
||||||
|
channel: "Canale"
|
||||||
|
notificationSetting: "impostazioni delle notifiche"
|
||||||
|
other: "Avanzate"
|
||||||
|
abuseReports: "Segnala"
|
||||||
|
reportAbuse: "Segnala"
|
||||||
|
reportAbuseOf: "Segnala {name}"
|
||||||
|
send: "Inviare"
|
||||||
|
openInNewTab: "Apri in una nuova scheda"
|
||||||
|
random: "Casuale"
|
||||||
|
system: "Sistema"
|
||||||
|
desktop: "Desktop"
|
||||||
|
optional: "Opzionale"
|
||||||
|
public: "Pubblico"
|
||||||
|
yes: "Sì"
|
||||||
|
no: "No"
|
||||||
|
contact: "Contatti"
|
||||||
|
developer: "Sviluppatore"
|
||||||
|
duplicate: "Duplica"
|
||||||
|
left: "Sinistra"
|
||||||
|
center: "Centro"
|
||||||
|
wide: "Largo"
|
||||||
|
nNotes: "{n}Nota"
|
||||||
|
backgroundColor: "Sfondo"
|
||||||
|
value: "Valore"
|
||||||
|
saveConfirm: "Vuoi salvare le modifiche?"
|
||||||
|
deleteConfirm: "Rimuovere?"
|
||||||
|
registry: "Registro"
|
||||||
|
closeAccount: "Disattiva account"
|
||||||
|
currentVersion: "Versione attuale"
|
||||||
|
latestVersion: "Ultima versione"
|
||||||
|
editCode: "Modifica codice"
|
||||||
|
apply: "Applica"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "Nuovo seguace"
|
||||||
|
_registry:
|
||||||
|
key: "Dati"
|
||||||
|
keys: "Dati"
|
||||||
|
_aboutMisskey:
|
||||||
|
morePatrons: "Ci sono molti altri che ci sostengono. Grazie 🥰"
|
||||||
|
_mfm:
|
||||||
|
mention: "Menzioni"
|
||||||
|
url: "URL"
|
||||||
|
link: "Link"
|
||||||
|
bold: "Grassetto"
|
||||||
|
blockCode: "Codice(blocco)"
|
||||||
|
inlineMath: "Espressione matematica(Immersione)"
|
||||||
|
blockMath: "Espressione matematica(blocco)"
|
||||||
|
quote: "Cita il nota"
|
||||||
|
search: "Cerca"
|
||||||
|
blur: "Sfocatura"
|
||||||
|
font: "Tipo di carattere"
|
||||||
|
_reversi:
|
||||||
|
black: "Nero"
|
||||||
|
white: "Bianco"
|
||||||
|
ended: "Esci"
|
||||||
|
_channel:
|
||||||
|
featured: "Tendenze"
|
||||||
|
_sidebar:
|
||||||
|
icon: "Foto del profilo"
|
||||||
|
hide: "Nascondere"
|
||||||
|
_theme:
|
||||||
|
constant: "Costante"
|
||||||
|
defaultValue: "Valore predefinito"
|
||||||
|
color: "Colore"
|
||||||
|
func: "Funzione"
|
||||||
|
darken: "Scuro"
|
||||||
|
lighten: "Chiaro"
|
||||||
|
keys:
|
||||||
|
bg: "Sfondo"
|
||||||
|
shadow: "Ombra"
|
||||||
|
mention: "Menzioni"
|
||||||
|
renote: "Rinotta"
|
||||||
|
divider: "Interruzione di linea"
|
||||||
|
_sfx:
|
||||||
|
note: "Nota"
|
||||||
|
notification: "Notifiche"
|
||||||
|
chat: "Messaggi"
|
||||||
|
_ago:
|
||||||
|
unknown: "Sconosciuto"
|
||||||
|
future: "Futuro"
|
||||||
|
justNow: "Ora"
|
||||||
|
secondsAgo: "{n}s fa"
|
||||||
|
minutesAgo: "{n}min fa"
|
||||||
|
hoursAgo: "{n}h fa"
|
||||||
|
daysAgo: "{1} giorni fa"
|
||||||
|
weeksAgo: "{n} settimane fa"
|
||||||
|
monthsAgo: "{n} mesi fa"
|
||||||
|
yearsAgo: "{n} anni fa"
|
||||||
|
_time:
|
||||||
|
second: "s"
|
||||||
|
minute: "min"
|
||||||
|
hour: "ore"
|
||||||
|
day: "giorni"
|
||||||
|
_tutorial:
|
||||||
|
title: "Come usare Misskey"
|
||||||
|
step1_1: "Benvenuto"
|
||||||
|
_permissions:
|
||||||
|
"read:blocks": "Visualizza gli account che hai bloccato."
|
||||||
|
"write:blocks": "Gestisci gli account che hai bloccato."
|
||||||
|
"read:favorites": "Visualizza Segnalibri"
|
||||||
|
"write:favorites": "Gestisci Segnalibri"
|
||||||
|
"write:following": "Seguiti/ Smetti di seguire"
|
||||||
|
"read:notifications": "Visualizza notifiche"
|
||||||
|
_weekday:
|
||||||
|
sunday: "Domenica"
|
||||||
|
monday: "Lunedì"
|
||||||
|
tuesday: "Martedì"
|
||||||
|
wednesday: "Mercoledì"
|
||||||
|
thursday: "Giovedì"
|
||||||
|
friday: "Venerdì"
|
||||||
|
saturday: "Sabato"
|
||||||
|
_widgets:
|
||||||
|
memo: "Memo"
|
||||||
|
notifications: "Notifiche"
|
||||||
|
timeline: "Timeline"
|
||||||
|
calendar: "Calendario"
|
||||||
|
trends: "Tendenze"
|
||||||
|
clock: "Orologio"
|
||||||
|
rss: "Aggregatore rss"
|
||||||
|
activity: "Attività"
|
||||||
|
photos: "Foto"
|
||||||
|
digitalClock: "Orologio digitale"
|
||||||
|
federation: "Federazione"
|
||||||
|
_cw:
|
||||||
|
hide: "Nascondere"
|
||||||
|
show: "Mostra altre"
|
||||||
|
_poll:
|
||||||
|
noMore: "Hai aggiunto il numero massimo di opzioni."
|
||||||
|
canMultipleVote: "Risposte multiple"
|
||||||
|
expiration: "Scadenza"
|
||||||
|
infinite: "Permanente"
|
||||||
|
deadlineDate: "Data di scadenza"
|
||||||
|
deadlineTime: "h"
|
||||||
|
voted: "Votato"
|
||||||
|
closed: "Terminato"
|
||||||
|
_visibility:
|
||||||
|
public: "Pubblico"
|
||||||
|
home: "Home"
|
||||||
|
followers: "Seguaci"
|
||||||
|
localOnly: "Solo Locale"
|
||||||
|
localOnlyDescription: "Solo locale"
|
||||||
|
_postForm:
|
||||||
|
replyPlaceholder: "Nota la tua risposta.."
|
||||||
|
quotePlaceholder: "Cita Nota..."
|
||||||
|
_profile:
|
||||||
|
name: "Nome"
|
||||||
|
username: "Nome utente"
|
||||||
|
description: "Bio"
|
||||||
|
metadata: "Metadati"
|
||||||
|
metadataLabel: "Etichetta"
|
||||||
|
metadataContent: "Contenuto"
|
||||||
|
_exportOrImport:
|
||||||
|
followingList: "Seiguiti"
|
||||||
|
muteList: "Silenzia"
|
||||||
|
blockingList: "Blocca"
|
||||||
|
userLists: "Liste"
|
||||||
|
_timelines:
|
||||||
|
home: "Home"
|
||||||
|
local: "Locale"
|
||||||
|
_rooms:
|
||||||
|
_roomType:
|
||||||
|
washitsu: "Washitsu"
|
||||||
|
_furnitures:
|
||||||
|
milk: "Cartone del latte"
|
||||||
|
bed: "Letto"
|
||||||
|
low-table: "Tavolino Coffee"
|
||||||
|
desk: "Tavolo"
|
||||||
|
chair: "Sedia"
|
||||||
|
chair2: "Sedia 2"
|
||||||
|
fan: "Ventilatore"
|
||||||
|
pc: "PC"
|
||||||
|
plant: "Pianta da appartamento"
|
||||||
|
plant2: "Pianta da appartamento2"
|
||||||
|
eraser: "Gomma"
|
||||||
|
pencil: "Matita"
|
||||||
|
pudding: "Pudding"
|
||||||
|
book: "Libro"
|
||||||
|
book2: "Libro2"
|
||||||
|
piano: "Pianoforte"
|
||||||
|
server: "Server"
|
||||||
|
moon: "Luna"
|
||||||
|
corkboard: "Bacheca"
|
||||||
|
mousepad: "Tappetino per il mouse"
|
||||||
|
monitor: "Monitor "
|
||||||
|
keyboard: "Tastiera"
|
||||||
|
mat: "Zerbino"
|
||||||
|
color-box: "Libreria"
|
||||||
|
wall-clock: "Orologio da parete"
|
||||||
|
photoframe: "Cornice"
|
||||||
|
cube: "Cubo"
|
||||||
|
tv: "Televisore"
|
||||||
|
pinguin: "Pinguini"
|
||||||
|
bin: "Cestino"
|
||||||
|
cup-noodle: "Noodle istantanei"
|
||||||
|
_pages:
|
||||||
|
like: "Mi piace"
|
||||||
|
unlike: "Togli Mi piace"
|
||||||
|
variables: "Variabili"
|
||||||
|
title: "Titolo"
|
||||||
|
font: "Tipo di carattere"
|
||||||
|
blocks:
|
||||||
|
image: "Immagini"
|
||||||
|
if: "Se"
|
||||||
|
_if:
|
||||||
|
variable: "Variabili"
|
||||||
|
_post:
|
||||||
|
text: "Contenuto"
|
||||||
|
_textInput:
|
||||||
|
text: "Titolo"
|
||||||
|
_textareaInput:
|
||||||
|
text: "Titolo"
|
||||||
|
_numberInput:
|
||||||
|
text: "Titolo"
|
||||||
|
_switch:
|
||||||
|
text: "Titolo"
|
||||||
|
_counter:
|
||||||
|
text: "Titolo"
|
||||||
|
_button:
|
||||||
|
text: "Titolo"
|
||||||
|
_action:
|
||||||
|
_dialog:
|
||||||
|
content: "Contenuto"
|
||||||
|
_radioButton:
|
||||||
|
title: "Titolo"
|
||||||
|
script:
|
||||||
|
categories:
|
||||||
|
comparison: "Metodo comparativo"
|
||||||
|
random: "Aleatorietà"
|
||||||
|
value: "Valore"
|
||||||
|
fn: "Funzione"
|
||||||
|
list: "Liste"
|
||||||
|
blocks:
|
||||||
|
_join:
|
||||||
|
arg1: "Liste"
|
||||||
|
_add:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_subtract:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_multiply:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_divide:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_mod:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_eq:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
notEq: "A non è uguale a B"
|
||||||
|
_notEq:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
and: "A e B"
|
||||||
|
_and:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
or: "A o B"
|
||||||
|
_or:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_lt:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_gt:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_ltEq:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_gtEq:
|
||||||
|
arg1: "A"
|
||||||
|
arg2: "B"
|
||||||
|
_if:
|
||||||
|
arg1: "Se"
|
||||||
|
random: "Aleatorietà"
|
||||||
|
_randomPick:
|
||||||
|
arg1: "Liste"
|
||||||
|
_dailyRandomPick:
|
||||||
|
arg1: "Liste"
|
||||||
|
_seedRandomPick:
|
||||||
|
arg2: "Liste"
|
||||||
|
_pick:
|
||||||
|
arg1: "Liste"
|
||||||
|
_listLen:
|
||||||
|
arg1: "Liste"
|
||||||
|
ref: "Variabili"
|
||||||
|
fn: "Funzione"
|
||||||
|
types:
|
||||||
|
array: "Liste"
|
||||||
|
_notification:
|
||||||
|
youGotQuote: "{name} ha citato il tuo Nota e ha detto"
|
||||||
|
youRenoted: "{name} ha rinotta"
|
||||||
|
youGotPoll: "{name} ha volluto."
|
||||||
|
youWereFollowed: "Nuovo seguace"
|
||||||
|
_types:
|
||||||
|
all: "Tutto"
|
||||||
|
follow: "Seiguiti"
|
||||||
|
mention: "Menzioni"
|
||||||
|
reply: "Rispondi"
|
||||||
|
renote: "Rinotta"
|
||||||
|
quote: "Cita il nota"
|
||||||
|
reaction: "Reazione"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "Notifiche"
|
||||||
|
tl: "Timeline"
|
||||||
|
list: "Liste"
|
||||||
|
mentions: "Menzioni"
|
@ -1,71 +1,113 @@
|
|||||||
---
|
---
|
||||||
_lang_: "日本語 (関西弁)"
|
_lang_: "日本語 (関西弁)"
|
||||||
introMisskey: "ようこそ!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作成しぃ、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素はよ反応を追加することもできます✌\n新しい世界を探検しよう🚀"
|
introMisskey: "ようお越し!Misskeyは、オープンソースの分散型マイクロブログサービスやねん。\n「ノート」を作って、いま起こっとることを共有したり、あんたについて皆に発信しよう📡\n「リアクション」機能で、皆のノートに素早く反応を追加したりもできるで✌\nほな新しい世界を探検しよか🚀"
|
||||||
monthAndDay: "{month}月 {day}日"
|
monthAndDay: "{month}月 {day}日"
|
||||||
search: "探す"
|
search: "探す"
|
||||||
notifications: "通知"
|
notifications: "通知"
|
||||||
username: "ユーザー名"
|
username: "ユーザー名"
|
||||||
password: "パスワード"
|
password: "パスワード"
|
||||||
fetchingAsApObject: "連合に照会中"
|
fetchingAsApObject: "今ちと連合に照会しとるで"
|
||||||
ok: "おっけー"
|
ok: "OKや"
|
||||||
gotIt: "ほい"
|
gotIt: "ほい"
|
||||||
cancel: "やめとくわ"
|
cancel: "やめとく"
|
||||||
enterUsername: "ユーザー名を入れてや"
|
enterUsername: "ユーザー名を入れてや"
|
||||||
renotedBy: "{user}がRenote"
|
renotedBy: "{user}がRenote"
|
||||||
noNotes: "ノートはあらへん"
|
noNotes: "ノートはあらへん"
|
||||||
noNotifications: "通知はあらへん"
|
noNotifications: "通知はあらへん"
|
||||||
instance: "インスタンス"
|
instance: "インスタンス"
|
||||||
settings: "設定"
|
settings: "設定"
|
||||||
|
basicSettings: "基本設定"
|
||||||
|
otherSettings: "その他の設定"
|
||||||
|
openInWindow: "ウィンドウで開くで"
|
||||||
profile: "プロフィール"
|
profile: "プロフィール"
|
||||||
timeline: "タイムライン"
|
timeline: "タイムライン"
|
||||||
noAccountDescription: "自己紹介はあらへん"
|
noAccountDescription: "自己紹介食ってもた"
|
||||||
login: "ログイン"
|
login: "ログイン"
|
||||||
loggingIn: "ログインしとります"
|
loggingIn: "ログインしよるで"
|
||||||
logout: "ログアウト"
|
logout: "ログアウト"
|
||||||
signup: "新規登録"
|
signup: "新規登録"
|
||||||
uploading: "アップロードしとります"
|
uploading: "アップロードしとるで"
|
||||||
save: "保存"
|
save: "保存"
|
||||||
users: "ユーザー"
|
users: "ユーザー"
|
||||||
addUser: "ユーザー増やす"
|
addUser: "ユーザーを追加や"
|
||||||
favorite: "お気に入り"
|
favorite: "お気に入り"
|
||||||
favorites: "お気に入り"
|
favorites: "お気に入り"
|
||||||
unfavorite: "お気に入りやめる"
|
unfavorite: "やっぱ気に入らん"
|
||||||
pin: "ピン留め"
|
favorited: "お気に入りに登録したで"
|
||||||
unpin: "ピン留めやめる"
|
alreadyFavorited: "もうお気に入りに入れとるがな。"
|
||||||
|
cantFavorite: "アカン、お気に入り登録できへんかったで。"
|
||||||
|
pin: "ピン留めしとく"
|
||||||
|
unpin: "やっぱピン留めせん"
|
||||||
copyContent: "内容をコピー"
|
copyContent: "内容をコピー"
|
||||||
copyLink: "リンクをコピー"
|
copyLink: "リンクをコピー"
|
||||||
delete: "ほかす"
|
delete: "ほかす"
|
||||||
|
deleteAndEdit: "ほかして直す"
|
||||||
|
deleteAndEditConfirm: "このノートをほかして書き直すんか?このノートへのリアクション、Renote、返信も全部消えてまうで。"
|
||||||
addToList: "リストに入れたる"
|
addToList: "リストに入れたる"
|
||||||
reply: "返す"
|
sendMessage: "メッセージを送る"
|
||||||
loadMore: "もっとあるやろ!"
|
copyUsername: "ユーザー名をコピー"
|
||||||
|
searchUser: "ユーザーを検索"
|
||||||
|
reply: "返事"
|
||||||
|
loadMore: "まだまだあるで!"
|
||||||
|
showMore: "まだまだあるで!"
|
||||||
|
youGotNewFollower: "フォローされたで"
|
||||||
|
receiveFollowRequest: "フォローリクエストされたで"
|
||||||
|
followRequestAccepted: "フォローが承認されたで"
|
||||||
|
mention: "メンション"
|
||||||
mentions: "あんた宛て"
|
mentions: "あんた宛て"
|
||||||
directNotes: "ダイレクト投稿"
|
directNotes: "ダイレクト投稿"
|
||||||
|
importAndExport: "インポートとエクスポート"
|
||||||
import: "インポート"
|
import: "インポート"
|
||||||
export: "エクスポート"
|
export: "エクスポート"
|
||||||
files: "ファイル"
|
files: "ファイル"
|
||||||
download: "ダウンロード"
|
download: "ダウンロード"
|
||||||
|
driveFileDeleteConfirm: "ファイル「{name}」を消してしもうてええか?このファイルを添付したノートも消えてまうで。"
|
||||||
|
unfollowConfirm: "{name}のフォローを解除してもええんか?"
|
||||||
|
exportRequested: "エクスポートしてな、ってリクエストしたけど、これ多分めっちゃ時間かかるで。エクスポート終わったら「ドライブ」に突っ込んどくで。"
|
||||||
|
importRequested: "インポートしてな、ってリクエストしたけど、これ多分めっちゃ時間かかるで。"
|
||||||
lists: "リスト"
|
lists: "リスト"
|
||||||
noLists: "リストはあらへん"
|
noLists: "リストなんてあらへんで"
|
||||||
|
note: "ノート"
|
||||||
|
notes: "ノート"
|
||||||
|
following: "フォロー"
|
||||||
|
followers: "フォロワー"
|
||||||
followsYou: "フォローされとるで"
|
followsYou: "フォローされとるで"
|
||||||
error: "問題が発生してん"
|
createList: "リスト作る"
|
||||||
|
manageLists: "リストの管理"
|
||||||
|
error: "エラー"
|
||||||
|
somethingHappened: "なんかアカンことが起こったで"
|
||||||
|
retry: "もっぺんやる?"
|
||||||
|
pageLoadError: "ページの読み込みに失敗してしもうたで…"
|
||||||
|
pageLoadErrorDescription: "これは普通、ネットワークかブラウザキャッシュが原因やからね。キャッシュをクリアするか、もうちっとだけ待ってくれへんか?"
|
||||||
enterListName: "リスト名を入れてや"
|
enterListName: "リスト名を入れてや"
|
||||||
privacy: "プライバシーってなんや?オカンの年齢か?"
|
privacy: "プライバシー"
|
||||||
makeFollowManuallyApprove: "他人のフォローは許可してからや!"
|
makeFollowManuallyApprove: "ええって言わなフォローできへんようにする"
|
||||||
defaultNoteVisibility: "もとからの公開範囲"
|
defaultNoteVisibility: "もとからの公開範囲"
|
||||||
follow: "フォロー"
|
follow: "フォロー"
|
||||||
followRequest: "フォロー許してくれや!言うてみる"
|
followRequest: "フォローを頼む"
|
||||||
followRequests: "フォロー許してくれや!"
|
followRequests: "フォロー申請"
|
||||||
|
unfollow: "フォローやめる"
|
||||||
followRequestPending: "フォロー許してくれるん待っとる"
|
followRequestPending: "フォロー許してくれるん待っとる"
|
||||||
enterEmoji: "絵文字を入れてや"
|
enterEmoji: "絵文字を入れてや"
|
||||||
|
renote: "Renote"
|
||||||
|
unrenote: "Renoteやめる"
|
||||||
|
renoted: "Renoteしたで。"
|
||||||
|
cantRenote: "この投稿はRenoteできへんらしい。"
|
||||||
|
cantReRenote: "Renote自体はRenoteできへんで。"
|
||||||
|
quote: "引用"
|
||||||
|
pinnedNote: "ピン留めされとるノート"
|
||||||
|
pinned: "ピン留めしとく"
|
||||||
you: "あんた"
|
you: "あんた"
|
||||||
clickToShow: "押してみ、見せたるわ"
|
clickToShow: "押したら見えるで"
|
||||||
sensitive: "見たらあかんで"
|
sensitive: "ちょっとアカンやつやで"
|
||||||
add: "増やす"
|
add: "増やす"
|
||||||
reaction: "リアクション"
|
reaction: "リアクション"
|
||||||
renameFile: "ファイル名をいらう"
|
reactionSettingDescription: "リアクションピッカーに出しとくリアクションを選んでや。"
|
||||||
attachCancel: "くっつけるのやめよか"
|
reactionSettingDescription2: "ドラッグで並び替え、クリックで削除、+を押して追加やで。"
|
||||||
markAsSensitive: "ちょっと見せられへんわ"
|
rememberNoteVisibility: "公開範囲覚えといて"
|
||||||
unmarkAsSensitive: "別にええんじゃね?"
|
attachCancel: "のっけるのやめる"
|
||||||
|
markAsSensitive: "ちょっとこれはアカン"
|
||||||
|
unmarkAsSensitive: "そこまでアカンことないやろ"
|
||||||
enterFileName: "ファイル名を入れてや"
|
enterFileName: "ファイル名を入れてや"
|
||||||
mute: "ミュート"
|
mute: "ミュート"
|
||||||
unmute: "ミュートやめたる"
|
unmute: "ミュートやめたる"
|
||||||
@ -73,44 +115,383 @@ block: "ブロック"
|
|||||||
unblock: "ブロックやめたる"
|
unblock: "ブロックやめたる"
|
||||||
suspend: "凍結"
|
suspend: "凍結"
|
||||||
unsuspend: "溶かす"
|
unsuspend: "溶かす"
|
||||||
|
blockConfirm: "ブロックしてもええんか?"
|
||||||
|
unblockConfirm: "ブロックやめたるってほんまか?"
|
||||||
|
suspendConfirm: "凍結してしもうてええか?"
|
||||||
|
unsuspendConfirm: "解凍するけどええか?"
|
||||||
|
selectList: "リストを選ぶ"
|
||||||
|
selectAntenna: "アンテナを選ぶ"
|
||||||
|
selectWidget: "ウィジェットを選ぶ"
|
||||||
|
editWidgets: "ウィジェットをいじる"
|
||||||
|
editWidgetsExit: "編集終ったで"
|
||||||
customEmojis: "カスタム絵文字"
|
customEmojis: "カスタム絵文字"
|
||||||
|
emoji: "絵文字"
|
||||||
|
emojiName: "絵文字名"
|
||||||
|
emojiUrl: "絵文字画像URL"
|
||||||
|
addEmoji: "絵文字を追加"
|
||||||
|
settingGuide: "ええ感じの設定"
|
||||||
cacheRemoteFiles: "リモートのファイルをキャッシュする"
|
cacheRemoteFiles: "リモートのファイルをキャッシュする"
|
||||||
cacheRemoteFilesDescription: "この設定をチャラにすると、リモートファイルをキャッシュせず直リンクするようになります。サーバーのストレージを節約できますが、サムネイルが生成されへんので通信量が増加します。"
|
cacheRemoteFilesDescription: "この設定を切っとくと、リモートファイルをキャッシュせず直リンクするようになるで。サーバーの容量は節約できるけど、サムネイルが作られんくなるから通信量が増えるで。"
|
||||||
loginFailed: "ログインに失敗してん"
|
flagAsBot: "Botやで"
|
||||||
|
flagAsBotDescription: "もしこのアカウントがプログラムによって運用されるんやったら、このフラグをオンにしてたのむで。オンにすると、反応の連鎖を防ぐためのフラグとして他の開発者に役立ったり、Misskeyのシステム上での扱いがBotに合ったもんになるんやで。"
|
||||||
|
flagAsCat: "Catやで"
|
||||||
|
flagAsCatDescription: "ワレ、猫ちゃんならこのフラグをつけてみ?"
|
||||||
|
autoAcceptFollowed: "フォローしとるユーザーからのフォローリクエストを勝手に許可しとく"
|
||||||
|
addAcount: "アカウント追加"
|
||||||
|
loginFailed: "ログインに失敗してしもうた…"
|
||||||
|
showOnRemote: "リモートで見る"
|
||||||
|
general: "全般"
|
||||||
wallpaper: "壁紙"
|
wallpaper: "壁紙"
|
||||||
removeWallpaper: "壁紙ほかす"
|
setWallpaper: "壁紙を設定"
|
||||||
youHaveNoLists: "リストはあらへん"
|
removeWallpaper: "壁紙を削除"
|
||||||
|
searchWith: "検索: {q}"
|
||||||
|
youHaveNoLists: "リストがあらへんで?"
|
||||||
|
followConfirm: "{name}をフォローしてええか?"
|
||||||
|
proxyAccount: "プロキシアカウント"
|
||||||
proxyAccountDescription: "プロキシアカウントは、代わりにフォローしてくれるアカウントや。例えば、551に豚まんが無いときやったり、ユーザーがリモートユーザーをアカウントに入れたとき、リストに入れられたユーザーが誰からもフォローされてないと寂しいやん。寂しいし、アクティビティも配達されへんから、プロキシアカウントがフォローしてくれるで。ええやつやん…"
|
proxyAccountDescription: "プロキシアカウントは、代わりにフォローしてくれるアカウントや。例えば、551に豚まんが無いときやったり、ユーザーがリモートユーザーをアカウントに入れたとき、リストに入れられたユーザーが誰からもフォローされてないと寂しいやん。寂しいし、アクティビティも配達されへんから、プロキシアカウントがフォローしてくれるで。ええやつやん…"
|
||||||
host: "ホスト"
|
host: "ホスト"
|
||||||
|
selectUser: "ユーザーを選ぶ"
|
||||||
|
recipient: "宛先"
|
||||||
|
annotation: "注釈"
|
||||||
federation: "連合"
|
federation: "連合"
|
||||||
instances: "インスタンス"
|
instances: "インスタンス"
|
||||||
|
registeredAt: "初観測"
|
||||||
|
latestRequestSentAt: "ちょっと前のリクエスト送信"
|
||||||
|
latestRequestReceivedAt: "ちょっと前のリクエスト受信"
|
||||||
|
latestStatus: "ちょっと前のステータス"
|
||||||
|
storageUsage: "ストレージ使うた量"
|
||||||
charts: "チャート"
|
charts: "チャート"
|
||||||
perHour: "1時間ごと"
|
perHour: "1時間ごと"
|
||||||
perDay: "1日ごと"
|
perDay: "1日ごと"
|
||||||
|
stopActivityDelivery: "アクティビティの配送をやめる"
|
||||||
|
blockThisInstance: "このインスタンスをブロック"
|
||||||
operations: "操作"
|
operations: "操作"
|
||||||
|
software: "ソフトウェア"
|
||||||
version: "バージョン"
|
version: "バージョン"
|
||||||
|
metadata: "メタデータ"
|
||||||
|
withNFiles: "{n}個のファイル"
|
||||||
|
monitor: "モニター"
|
||||||
|
jobQueue: "ジョブキュー"
|
||||||
|
cpuAndMemory: "CPUとメモリ"
|
||||||
network: "ネットワーク"
|
network: "ネットワーク"
|
||||||
|
disk: "ディスク"
|
||||||
|
instanceInfo: "インスタンス情報"
|
||||||
statistics: "統計"
|
statistics: "統計"
|
||||||
|
clearQueue: "キューにさいなら"
|
||||||
|
clearQueueConfirmTitle: "キューをクリアしまっか?"
|
||||||
clearQueueConfirmText: "未配達の投稿は配送されなくなるで。通常この操作を行う必要はあらへんや。"
|
clearQueueConfirmText: "未配達の投稿は配送されなくなるで。通常この操作を行う必要はあらへんや。"
|
||||||
|
clearCachedFiles: "キャッシュにさいなら"
|
||||||
|
clearCachedFilesConfirm: "キャッシュされとるリモートファイルをみんなほかしてええか?"
|
||||||
|
blockedInstances: "インスタンスブロック"
|
||||||
|
blockedInstancesDescription: "ブロックしたいインスタンスのホストを改行で区切って設定してな。ブロックされてもうたインスタンスとはもう金輪際やり取りできひんくなるで。"
|
||||||
muteAndBlock: "ミュートとブロック"
|
muteAndBlock: "ミュートとブロック"
|
||||||
|
mutedUsers: "ミュートしたユーザー"
|
||||||
|
blockedUsers: "ブロックしたユーザー"
|
||||||
noUsers: "ユーザーはおらへん"
|
noUsers: "ユーザーはおらへん"
|
||||||
|
editProfile: "プロフィールをいじる"
|
||||||
|
noteDeleteConfirm: "このノートを削除しまっか?"
|
||||||
pinLimitExceeded: "これ以上ピン留めできひん"
|
pinLimitExceeded: "これ以上ピン留めできひん"
|
||||||
intro: "Misskeyのインストールが完了してん!管理者アカウントを作ってや。"
|
intro: "Misskeyのインストールが完了してん!管理者アカウントを作ってや。"
|
||||||
|
done: "でけた"
|
||||||
|
processing: "処理しとる"
|
||||||
|
preview: "プレビュー"
|
||||||
|
default: "デフォルト"
|
||||||
noCustomEmojis: "絵文字はあらへん"
|
noCustomEmojis: "絵文字はあらへん"
|
||||||
noJobs: "ジョブはあらへん"
|
noJobs: "ジョブはあらへん"
|
||||||
|
federating: "連合しとる"
|
||||||
|
blocked: "ブロックしとる"
|
||||||
|
suspended: "配信せぇへん"
|
||||||
all: "みな"
|
all: "みな"
|
||||||
|
subscribing: "購読しとる"
|
||||||
|
publishing: "配信しとる"
|
||||||
|
notResponding: "応答してへんで"
|
||||||
|
instanceFollowing: "インスタンスのフォロー"
|
||||||
|
instanceFollowers: "インスタンスのフォロワー\n"
|
||||||
|
instanceUsers: "インスタンスのユーザー"
|
||||||
|
changePassword: "パスワード変える"
|
||||||
|
security: "セキュリティ"
|
||||||
retypedNotMatch: "そやないねん。"
|
retypedNotMatch: "そやないねん。"
|
||||||
|
currentPassword: "今のパスワード"
|
||||||
|
newPassword: "今度のパスワード"
|
||||||
|
newPasswordRetype: "今度のパスワード(もっぺん入れて)"
|
||||||
|
attachFile: "ファイルのっける"
|
||||||
|
more: "他のやつ!"
|
||||||
|
featured: "ハイライト"
|
||||||
|
usernameOrUserId: "ユーザー名かユーザーID"
|
||||||
|
noSuchUser: "ユーザーが見つからへんで"
|
||||||
|
lookup: "見てきて"
|
||||||
|
announcements: "お知らせ"
|
||||||
|
imageUrl: "画像URL"
|
||||||
remove: "ほかす"
|
remove: "ほかす"
|
||||||
|
removed: "削除したで!"
|
||||||
|
removeAreYouSure: "「{x}」はほかしてええか?"
|
||||||
|
deleteAreYouSure: "「{x}」はほかしてええか?"
|
||||||
|
resetAreYouSure: "リセットしてええん?"
|
||||||
|
saved: "保存したで!"
|
||||||
|
messaging: "チャット"
|
||||||
|
upload: "アップロード"
|
||||||
|
fromDrive: "ドライブから"
|
||||||
|
fromUrl: "URLから"
|
||||||
|
uploadFromUrl: "URLアップロード"
|
||||||
|
uploadFromUrlDescription: "このURLのファイルをアップロードしたいねん"
|
||||||
|
uploadFromUrlRequested: "アップロードしたい言うといたで"
|
||||||
|
uploadFromUrlMayTakeTime: "アップロード終わるんにちょい時間かかるかもしれへんわ。"
|
||||||
|
explore: "みつける"
|
||||||
|
games: "Misskey Games"
|
||||||
|
messageRead: "もう読んだ"
|
||||||
noMoreHistory: "これより過去の履歴はあらへんで"
|
noMoreHistory: "これより過去の履歴はあらへんで"
|
||||||
nsfw: "見たらあかんで"
|
startMessaging: "チャットやるで"
|
||||||
|
nUsersRead: "{n}人が読んでもうた"
|
||||||
|
agreeTo: "{0}はええで"
|
||||||
|
tos: "利用規約"
|
||||||
|
start: "始める"
|
||||||
|
home: "ホーム"
|
||||||
|
remoteUserCaution: "リモートユーザーやから、足りひん情報あるかもしれへん。"
|
||||||
|
activity: "アクティビティ"
|
||||||
|
images: "画像"
|
||||||
|
birthday: "生まれた日"
|
||||||
|
yearsOld: "{age}歳"
|
||||||
|
registeredDate: "始めた日"
|
||||||
|
location: "場所"
|
||||||
|
theme: "テーマ"
|
||||||
|
themeForLightMode: "ライトモードではこのテーマつこて"
|
||||||
|
themeForDarkMode: "ダークモードではこのテーマつこて"
|
||||||
|
light: "ライト"
|
||||||
|
dark: "ダーク"
|
||||||
|
lightThemes: "デイゲーム"
|
||||||
|
darkThemes: "ナイトゲーム"
|
||||||
|
syncDeviceDarkMode: "デバイスのダークモードと一緒にする"
|
||||||
|
drive: "ドライブ"
|
||||||
|
fileName: "ファイル名"
|
||||||
|
selectFile: "ファイル選んでや"
|
||||||
|
selectFiles: "ファイル選んでや"
|
||||||
|
selectFolder: "フォルダ選んでや"
|
||||||
|
selectFolders: "フォルダ選んでや"
|
||||||
|
renameFile: "ファイル名をいらう"
|
||||||
|
folderName: "フォルダー名"
|
||||||
|
createFolder: "フォルダー作る"
|
||||||
|
renameFolder: "フォルダー名を変える"
|
||||||
|
deleteFolder: "フォルダーを消してまう"
|
||||||
|
addFile: "ファイルを追加"
|
||||||
|
emptyDrive: "ドライブにはなんも残っとらん"
|
||||||
|
emptyFolder: "ふぉろだーにはなんも残っとらん"
|
||||||
|
unableToDelete: "消そうおもってんけどな、あかんかったわ"
|
||||||
|
inputNewFileName: "今度のファイル名は何にするん?"
|
||||||
|
inputNewFolderName: "今度のフォルダ名は何にするん?"
|
||||||
|
circularReferenceFolder: "移動先のフォルダーは、移動するフォルダーのサブフォルダーや。"
|
||||||
|
hasChildFilesOrFolders: "このフォルダ、まだなんか入っとるから消されへん"
|
||||||
|
copyUrl: "URLをコピー"
|
||||||
|
rename: "名前を変えるで"
|
||||||
|
avatar: "アイコン"
|
||||||
|
banner: "バナー"
|
||||||
|
nsfw: "閲覧注意"
|
||||||
|
whenServerDisconnected: "サーバーとの接続が切れたとき"
|
||||||
|
disconnectedFromServer: "サーバーとの通信が切れたで"
|
||||||
|
reload: "リロード"
|
||||||
|
doNothing: "何もせんとく"
|
||||||
|
reloadConfirm: "リロードしてええか?"
|
||||||
|
watch: "ウォッチ"
|
||||||
|
unwatch: "ウォッチやめる"
|
||||||
|
accept: "ええで"
|
||||||
|
reject: "あかん"
|
||||||
|
normal: "ええ感じ"
|
||||||
|
instanceName: "インスタンス名"
|
||||||
|
instanceDescription: "インスタンスの紹介"
|
||||||
|
maintainerName: "管理者の名前"
|
||||||
|
maintainerEmail: "管理者のメールアドレス"
|
||||||
|
tosUrl: "利用規約のURL"
|
||||||
|
thisYear: "今年"
|
||||||
|
thisMonth: "今月"
|
||||||
|
today: "今日"
|
||||||
|
dayX: "{day}日"
|
||||||
|
monthX: "{month}月"
|
||||||
|
yearX: "{year}年"
|
||||||
|
pages: "ページ"
|
||||||
|
integration: "連携"
|
||||||
|
connectSerice: "つなげる"
|
||||||
|
disconnectSerice: "切ってまう"
|
||||||
|
enableLocalTimeline: "ローカルタイムラインを使えるようにする"
|
||||||
|
enableGlobalTimeline: "グローバルタイムラインを使えるようにする"
|
||||||
|
disablingTimelinesInfo: "ここらへんのタイムラインを使えんようにしてしもても、管理者とモデレーターは使えるままになってるで、そうやなかったら不便やからな。"
|
||||||
|
registration: "登録"
|
||||||
|
enableRegistration: "一見さんでも誰でもいらっしゃ~い"
|
||||||
|
invite: "来てや"
|
||||||
|
proxyRemoteFiles: "リモートのファイルをプロキシする"
|
||||||
|
proxyRemoteFilesDescription: "この設定を有効にしたら、保存してなかったり容量が足らんくて消されたリモートファイルをローカルでプロキシして、サムネイルを作るようになるで。サーバーの容量には関係ないで。"
|
||||||
|
driveCapacityPerLocalAccount: "ローカルユーザーひとりあたりのドライブ容量"
|
||||||
|
driveCapacityPerRemoteAccount: "リモートユーザーひとりあたりのドライブ容量"
|
||||||
|
inMb: "メガバイト単位"
|
||||||
|
iconUrl: "アイコン画像のURL"
|
||||||
|
bannerUrl: "バナー画像のURL"
|
||||||
|
basicInfo: "基本情報"
|
||||||
|
pinnedUsers: "ピン留めしたユーザー"
|
||||||
|
pinnedUsersDescription: "「みつける」ページとかにピン留めしたいユーザーをここに書けばええんやで。他ん人との名前は改行で区切ればええんやで。"
|
||||||
|
pinnedPages: "ピン留めページ"
|
||||||
|
pinnedNotes: "ピン留めされとるノート"
|
||||||
|
hcaptcha: "hCaptcha(キャプチャ)"
|
||||||
|
enableHcaptcha: "hCaptcha(キャプチャ)をつけとく"
|
||||||
|
hcaptchaSiteKey: "サイトキー"
|
||||||
|
hcaptchaSecretKey: "シークレットキー"
|
||||||
|
recaptcha: "reCAPTCHA"
|
||||||
|
enableRecaptcha: "reCAPTCHA(リキャプチャ)を有効にする"
|
||||||
|
recaptchaSiteKey: "サイトキー"
|
||||||
|
recaptchaSecretKey: "シークレットキー"
|
||||||
|
avoidMultiCaptchaConfirm: "ぎょうさんのCaptchaをつこてしまうと、仲良うせんことがあるんや。他のCaptchaをなおしとこか?別にキャンセルしてもろうたらCaptchaは消されへんで済むけど知らんで。"
|
||||||
|
antennas: "アンテナ"
|
||||||
|
manageAntennas: "アンテナいじる"
|
||||||
|
name: "名前"
|
||||||
|
antennaSource: "受信ソース(このソースは食われへん)"
|
||||||
|
antennaKeywords: "受信キーワード"
|
||||||
|
antennaExcludeKeywords: "除外キーワード"
|
||||||
|
antennaKeywordsDescription: "スペースで区切ったるとAND指定で、改行で区切ったるとOR指定や"
|
||||||
|
notifyAntenna: "新しいノートを追加すんで"
|
||||||
|
withFileAntenna: "なんか添付されたノートだけ"
|
||||||
|
serviceworker: "ServiceWorker"
|
||||||
|
enableServiceworker: "ServiceWorkerをつこて"
|
||||||
|
antennaUsersDescription: "ユーザー名を改行で区切ったってな"
|
||||||
|
caseSensitive: "大文字と小文字は別もんや"
|
||||||
|
withReplies: "返信も入れたって"
|
||||||
|
connectedTo: "次のアカウントに繋がっとるで"
|
||||||
|
notesAndReplies: "投稿と返信"
|
||||||
|
withFiles: "ファイル付いとる"
|
||||||
|
silence: "サイレンス"
|
||||||
|
silenceConfirm: "サイレンスしよか?"
|
||||||
|
unsilence: "サイレンスやめるで"
|
||||||
|
unsilenceConfirm: "サイレンスやめよか?"
|
||||||
|
popularUsers: "人気のユーザー"
|
||||||
|
recentlyUpdatedUsers: "ちょっと前に投稿したばっかりのユーザー"
|
||||||
|
recentlyRegisteredUsers: "ちょっと前に始めたばっかりのユーザー"
|
||||||
|
recentlyDiscoveredUsers: "最近見っけたユーザー"
|
||||||
|
exploreUsersCount: "{count}もユーザーおるで"
|
||||||
|
exploreFediverse: "Fediverseを探ってみる"
|
||||||
|
popularTags: "人気のタグ"
|
||||||
userList: "リスト"
|
userList: "リスト"
|
||||||
about: "情報"
|
about: "情報"
|
||||||
aboutMisskey: "Misskeyってなんや?"
|
aboutMisskey: "Misskeyってなんや?"
|
||||||
|
administrator: "管理者"
|
||||||
|
token: "トークン"
|
||||||
|
twoStepAuthentication: "二段階認証"
|
||||||
|
moderator: "モデレーター"
|
||||||
|
nUsersMentioned: "{n}人が投稿"
|
||||||
|
securityKey: "セキュリティキー"
|
||||||
|
securityKeyName: "キーの名前"
|
||||||
|
registerSecurityKey: "セキュリティキーを登録するで"
|
||||||
|
lastUsed: "最後につこうた日"
|
||||||
|
unregister: "登録やめる"
|
||||||
|
passwordLessLogin: "パスワード無くてもログインできるようにする"
|
||||||
|
resetPassword: "パスワードをリセット"
|
||||||
|
newPasswordIs: "今度のパスワードは「{password}」や"
|
||||||
|
reduceUiAnimation: "UIの動きやアニメーションを減らす"
|
||||||
|
share: "わけわけ"
|
||||||
|
notFound: "見つからへんね"
|
||||||
notFoundDescription: "指定されたURLに該当するページはあらへんやった。"
|
notFoundDescription: "指定されたURLに該当するページはあらへんやった。"
|
||||||
|
uploadFolder: "とりあえずアップロードしたやつ置いとく所"
|
||||||
|
cacheClear: "キャッシュをほかす"
|
||||||
|
markAsReadAllNotifications: "通知はもう全て読んだわっ"
|
||||||
|
markAsReadAllUnreadNotes: "投稿は全て読んだわっ"
|
||||||
|
markAsReadAllTalkMessages: "チャットはもうぜんぶ読んだわっ"
|
||||||
|
help: "ヘルプ"
|
||||||
|
inputMessageHere: "ここにメッセージ書いてや"
|
||||||
close: "さいなら"
|
close: "さいなら"
|
||||||
|
group: "グループ"
|
||||||
|
groups: "グループ"
|
||||||
|
createGroup: "グループを作るで"
|
||||||
|
ownedGroups: "所有しとるグループ"
|
||||||
joinedGroups: "参加しとるグループ"
|
joinedGroups: "参加しとるグループ"
|
||||||
|
invites: "来てや"
|
||||||
|
groupName: "グループ名"
|
||||||
|
members: "メンバー"
|
||||||
|
transfer: "譲渡"
|
||||||
|
messagingWithUser: "ユーザーとチャット"
|
||||||
|
messagingWithGroup: "グループでチャット"
|
||||||
|
title: "タイトル"
|
||||||
|
text: "テキスト"
|
||||||
|
enable: "有効にするで"
|
||||||
|
next: "次"
|
||||||
|
retype: "もっかい入力"
|
||||||
|
noteOf: "{user}のノート"
|
||||||
|
inviteToGroup: "グループに招く"
|
||||||
|
maxNoteTextLength: "ノートの文字数制限"
|
||||||
|
quoteAttached: "引用付いとるで"
|
||||||
|
quoteQuestion: "引用として添付してもええか?"
|
||||||
|
noMessagesYet: "まだチャットはあらへんで"
|
||||||
|
newMessageExists: "新しいメッセージがきたで"
|
||||||
|
onlyOneFileCanBeAttached: "すまん、メッセージに添付できるファイルはひとつだけなんや。"
|
||||||
|
signinRequired: "ログインしてくれへん?"
|
||||||
|
invitations: "来てや"
|
||||||
|
invitationCode: "招待コード"
|
||||||
|
checking: "確認しとるで"
|
||||||
|
available: "利用できる\n"
|
||||||
|
unavailable: "利用できん"
|
||||||
|
usernameInvalidFormat: "a~z、A~Z、0~9、_が使えるで"
|
||||||
|
tooShort: "短すぎやろ!"
|
||||||
|
tooLong: "長すぎやろ!"
|
||||||
|
weakPassword: "へぼいパスワード"
|
||||||
|
normalPassword: "普通のパスワード"
|
||||||
|
strongPassword: "ええ感じのパスワード"
|
||||||
|
passwordMatched: "よし!一致や!"
|
||||||
|
passwordNotMatched: "一致しとらんで?"
|
||||||
|
signinWith: "{x}でログイン"
|
||||||
|
or: "それか"
|
||||||
|
uiLanguage: "UIの表示言語"
|
||||||
|
groupInvited: "グループに招待されとるで"
|
||||||
|
aboutX: "{x}について"
|
||||||
|
useOsNativeEmojis: "OSネイティブの絵文字を使う"
|
||||||
|
youHaveNoGroups: "グループがあらへんねぇ。"
|
||||||
|
noHistory: "履歴はあらへんねぇ。"
|
||||||
|
signinHistory: "ログイン履歴"
|
||||||
|
disableAnimatedMfm: "動きがやかましいMFMを止める"
|
||||||
|
doing: "やっとるがな"
|
||||||
|
category: "カテゴリ"
|
||||||
|
tags: "タグ"
|
||||||
|
docSource: "このドキュメントのソース"
|
||||||
|
createAccount: "アカウントを作成"
|
||||||
|
existingAcount: "既存のアカウント"
|
||||||
|
regenerate: "再生成"
|
||||||
|
fontSize: "フォントサイズ"
|
||||||
|
noFollowRequests: "フォロー申請はあらへんで"
|
||||||
|
openImageInNewTab: "画像を新しいタブで開く"
|
||||||
|
dashboard: "ダッシュボード"
|
||||||
|
local: "ローカル"
|
||||||
|
remote: "リモート"
|
||||||
|
scratchpadDescription: "スクラッチパッドではAiScriptを色々試すことができるんや。Misskeyに対して色々できるコードを書いて動かしてみたり、結果を見たりできるで。"
|
||||||
|
leaveConfirm: "未保存の変更があるで!ほかしてええか?"
|
||||||
|
emailConfigInfo: "メールアドレスの確認とかパスワードリセットの時に使うで"
|
||||||
|
smtpHost: "ホスト"
|
||||||
|
smtpUser: "ユーザー名"
|
||||||
|
smtpPass: "パスワード"
|
||||||
|
notificationSettingDesc: "表示する通知の種類えらんでや。"
|
||||||
|
emailVerified: "メールアドレスは確認されたで"
|
||||||
|
pageLikesCount: "Pageにええやんと思った数"
|
||||||
|
pageLikedCount: "Pageにええやんと思ってくれた数"
|
||||||
|
reloadToApplySetting: "設定はページリロード後に反映されるで。今リロードしとくか?"
|
||||||
|
clearCache: "キャッシュをほかす"
|
||||||
|
onlineUsersCount: "{n}人が起きとるで"
|
||||||
|
sendErrorReportsDescription: "オンにしたら、なんか変なことが起きたときにエラーの詳細がMisskeyに共有されて、ソフトウェアの品質向上に役立てられるんや。エラー情報には、OSのバージョン、ブラウザの種類、行動履歴などが含まれるで。"
|
||||||
|
youAreRunningUpToDateClient: "今使ってるクライアントが最新やで!"
|
||||||
|
newVersionOfClientAvailable: "新しいバージョンのクライアントが使えるで。"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "フォローされたで"
|
||||||
|
_mfm:
|
||||||
|
mention: "メンション"
|
||||||
|
quote: "引用"
|
||||||
|
emoji: "カスタム絵文字"
|
||||||
|
search: "探す"
|
||||||
|
_channel:
|
||||||
|
notesCount: "{n}こ投稿があるで"
|
||||||
|
_sidebar:
|
||||||
|
icon: "アイコン"
|
||||||
|
_theme:
|
||||||
|
keys:
|
||||||
|
mention: "メンション"
|
||||||
|
renote: "Renote"
|
||||||
|
_sfx:
|
||||||
|
note: "ノート"
|
||||||
|
notification: "通知"
|
||||||
|
chat: "チャット"
|
||||||
_ago:
|
_ago:
|
||||||
unknown: "謎"
|
unknown: "わからん"
|
||||||
future: "未来"
|
future: "未来"
|
||||||
justNow: "たった今"
|
justNow: "たった今"
|
||||||
secondsAgo: "{n}秒前"
|
secondsAgo: "{n}秒前"
|
||||||
@ -125,8 +506,13 @@ _time:
|
|||||||
minute: "分"
|
minute: "分"
|
||||||
hour: "時間"
|
hour: "時間"
|
||||||
day: "日"
|
day: "日"
|
||||||
|
_tutorial:
|
||||||
|
step3_1: "プロフィール設定はええ感じにできたか?"
|
||||||
_2fa:
|
_2fa:
|
||||||
alreadyRegistered: "もう設定終わっとるわ"
|
alreadyRegistered: "もう設定終わっとるわ。"
|
||||||
|
_permissions:
|
||||||
|
"read:page-likes": "ページのええやんを見る"
|
||||||
|
"write:page-likes": "ページのええやんを操作する"
|
||||||
_auth:
|
_auth:
|
||||||
permissionAsk: "このアプリは次の権限を要求しとるで"
|
permissionAsk: "このアプリは次の権限を要求しとるで"
|
||||||
_antennaSources:
|
_antennaSources:
|
||||||
@ -135,21 +521,41 @@ _antennaSources:
|
|||||||
_widgets:
|
_widgets:
|
||||||
notifications: "通知"
|
notifications: "通知"
|
||||||
timeline: "タイムライン"
|
timeline: "タイムライン"
|
||||||
|
activity: "アクティビティ"
|
||||||
|
federation: "連合"
|
||||||
|
jobQueue: "ジョブキュー"
|
||||||
_cw:
|
_cw:
|
||||||
show: "もっとあるやろ!"
|
show: "続き見して!"
|
||||||
_poll:
|
_poll:
|
||||||
noMore: "これ以上追加でけへん"
|
noMore: "これ以上追加でけへん"
|
||||||
deadlineTime: "時間"
|
deadlineTime: "時間"
|
||||||
_visibility:
|
_visibility:
|
||||||
publicDescription: "みなのユーザーに公開"
|
publicDescription: "みなのユーザーに公開"
|
||||||
|
home: "ホーム"
|
||||||
|
followers: "フォロワー"
|
||||||
_profile:
|
_profile:
|
||||||
|
name: "名前"
|
||||||
username: "ユーザー名"
|
username: "ユーザー名"
|
||||||
_exportOrImport:
|
_exportOrImport:
|
||||||
allNotes: "全てのノート"
|
allNotes: "全てのノート"
|
||||||
|
followingList: "フォロー"
|
||||||
muteList: "ミュート"
|
muteList: "ミュート"
|
||||||
blockingList: "ブロック"
|
blockingList: "ブロック"
|
||||||
userLists: "リスト"
|
userLists: "リスト"
|
||||||
|
_timelines:
|
||||||
|
home: "ホーム"
|
||||||
|
_rooms:
|
||||||
|
leaveConfirm: "未保存の変更があるけど、移動してええか?"
|
||||||
|
_roomType:
|
||||||
|
default: "デフォルト"
|
||||||
|
_furnitures:
|
||||||
|
monitor: "モニター"
|
||||||
_pages:
|
_pages:
|
||||||
|
like: "ええやん"
|
||||||
|
unlike: "良くないわ"
|
||||||
|
liked: "ええと思ったページ"
|
||||||
|
blocks:
|
||||||
|
image: "画像"
|
||||||
script:
|
script:
|
||||||
categories:
|
categories:
|
||||||
list: "リスト"
|
list: "リスト"
|
||||||
@ -168,3 +574,23 @@ _pages:
|
|||||||
arg1: "リスト"
|
arg1: "リスト"
|
||||||
types:
|
types:
|
||||||
array: "リスト"
|
array: "リスト"
|
||||||
|
_notification:
|
||||||
|
youWereFollowed: "フォローされたで"
|
||||||
|
youReceivedFollowRequest: "フォロー許可してほしいみたいやな"
|
||||||
|
yourFollowRequestAccepted: "フォローさせてもろたで"
|
||||||
|
youWereInvitedToGroup: "グループに招待されとるで"
|
||||||
|
_types:
|
||||||
|
follow: "フォロー"
|
||||||
|
mention: "メンション"
|
||||||
|
renote: "Renote"
|
||||||
|
quote: "引用"
|
||||||
|
reaction: "リアクション"
|
||||||
|
receiveFollowRequest: "フォロー許可してほしいみたいやで"
|
||||||
|
followRequestAccepted: "フォローが受理されたで"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "通知"
|
||||||
|
tl: "タイムライン"
|
||||||
|
antenna: "アンテナ"
|
||||||
|
list: "リスト"
|
||||||
|
mentions: "あんた宛て"
|
||||||
|
100
locales/kab-KAB.yml
Normal file
@ -0,0 +1,100 @@
|
|||||||
|
---
|
||||||
|
_lang_: "Taqbaylit"
|
||||||
|
monthAndDay: "{day}/{month}"
|
||||||
|
search: "Nadi"
|
||||||
|
notifications: "Ilɣuyen"
|
||||||
|
username: "Isem n umseqdac"
|
||||||
|
password: "Awal uffir"
|
||||||
|
ok: "IH"
|
||||||
|
settings: "Iɣewwaṛen"
|
||||||
|
profile: "Amaɣnu"
|
||||||
|
save: "Sekles"
|
||||||
|
delete: "Kkes"
|
||||||
|
addToList: "Rnu ɣer tebdart"
|
||||||
|
reply: "Err"
|
||||||
|
loadMore: "Wali ugar"
|
||||||
|
showMore: "Wali ugar"
|
||||||
|
youGotNewFollower: "Yeṭṭafaṛ-ik·em-id"
|
||||||
|
mention: "Bder"
|
||||||
|
import: "Kter"
|
||||||
|
export: "Sifeḍ"
|
||||||
|
files: "Ifuyla"
|
||||||
|
download: "Sider"
|
||||||
|
lists: "Tibdarin"
|
||||||
|
noLists: "Ulac ɣur-k·m ula d yiwet n tabdart"
|
||||||
|
following: "Ig ṭṭafaṛ"
|
||||||
|
followers: "Imeḍfaṛen"
|
||||||
|
followsYou: "Yeṭṭafaṛ-ik·em-id"
|
||||||
|
createList: "Snulfu-d tabdart"
|
||||||
|
enterListName: "Isem n tebdart"
|
||||||
|
follow: "Ḍfeṛ"
|
||||||
|
you: "Kečči·mmi"
|
||||||
|
selectList: "Fren tabdart"
|
||||||
|
youHaveNoLists: "Ulac ɣur-k·m ula d yiwet n tabdart"
|
||||||
|
remove: "Kkes"
|
||||||
|
userList: "Tibdarin"
|
||||||
|
uiLanguage: "Tutlayt n wegrudem"
|
||||||
|
smtpUser: "Isem n umseqdac"
|
||||||
|
smtpPass: "Awal uffir"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "Yeṭṭafaṛ-ik·em-id"
|
||||||
|
_mfm:
|
||||||
|
mention: "Bder"
|
||||||
|
search: "Nadi"
|
||||||
|
font: "Tasefsit"
|
||||||
|
_theme:
|
||||||
|
keys:
|
||||||
|
mention: "Bder"
|
||||||
|
_sfx:
|
||||||
|
notification: "Ilɣuyen"
|
||||||
|
_widgets:
|
||||||
|
notifications: "Ilɣuyen"
|
||||||
|
_cw:
|
||||||
|
show: "Wali ugar"
|
||||||
|
_visibility:
|
||||||
|
followers: "Imeḍfaṛen"
|
||||||
|
_profile:
|
||||||
|
username: "Isem n umseqdac"
|
||||||
|
_exportOrImport:
|
||||||
|
followingList: "Ig ṭṭafaṛ"
|
||||||
|
muteList: "Sgugem"
|
||||||
|
blockingList: "Seḥbes"
|
||||||
|
userLists: "Tibdarin"
|
||||||
|
_pages:
|
||||||
|
contents: "Agbur"
|
||||||
|
font: "Tasefsit"
|
||||||
|
fontSerif: "Serif"
|
||||||
|
fontSansSerif: "Sans Serif"
|
||||||
|
eyeCatchingImageRemove: "Kkes tugna i d-ijebden"
|
||||||
|
selectType: "Fren anaw"
|
||||||
|
contentBlocks: "Agbur"
|
||||||
|
inputBlocks: "Anekcum"
|
||||||
|
specialBlocks: "Uzzig"
|
||||||
|
script:
|
||||||
|
categories:
|
||||||
|
list: "Tibdarin"
|
||||||
|
blocks:
|
||||||
|
_join:
|
||||||
|
arg1: "Tibdarin"
|
||||||
|
_randomPick:
|
||||||
|
arg1: "Tibdarin"
|
||||||
|
_dailyRandomPick:
|
||||||
|
arg1: "Tibdarin"
|
||||||
|
_seedRandomPick:
|
||||||
|
arg2: "Tibdarin"
|
||||||
|
_pick:
|
||||||
|
arg1: "Tibdarin"
|
||||||
|
_listLen:
|
||||||
|
arg1: "Tibdarin"
|
||||||
|
types:
|
||||||
|
array: "Tibdarin"
|
||||||
|
_notification:
|
||||||
|
youWereFollowed: "Yeṭṭafaṛ-ik·em-id"
|
||||||
|
_types:
|
||||||
|
follow: "Ig ṭṭafaṛ"
|
||||||
|
mention: "Bder"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "Ilɣuyen"
|
||||||
|
list: "Tibdarin"
|
@ -1,2 +1,81 @@
|
|||||||
---
|
---
|
||||||
_lang_: "ಕನ್ನಡ"
|
_lang_: "ಕನ್ನಡ"
|
||||||
|
introMisskey: "ಸ್ವಾಗತ! Misskey ಓಪನ್ ಸೋರ್ಸ್ ಒಕ್ಕೂಟ ಮೈಕ್ರೋಬ್ಲಾಗಿಂಗ್ ಸೇವೆಯಾಗಿದೆ.\n ಏನಾಗುತ್ತಿದೆ ಎಂಬುದನ್ನು ಹಂಚಿಕೊಳ್ಳಲು ಅಥವಾ ನಿಮ್ಮ ಬಗ್ಗೆ ಎಲ್ಲರಿಗೂ ಹೇಳಲು \"ಟಿಪ್ಪಣಿ\"ಗಳನ್ನು ರಚಿಸಿ📡\n \"ಸ್ಪಂದನೆ\" ಕ್ರಿಯೆಯೊಂದಿಗೆ, ನೀವು ಎಲ್ಲರ ಟಿಪ್ಪಣಿಗಳಿಗೆ ತ್ವರಿತವಾಗಿ ಸ್ಪಂದನೆಗಳನ್ನು ಕೂಡ ಸೇರಿಸಬಹುದು.👍\n ಹೊಸ ಜಗತ್ತನ್ನು ಅನ್ವೇಷಿಸಿ🚀"
|
||||||
|
monthAndDay: "{month}ನೇ ತಿಂಗಳ {day}ನೇ ದಿನ"
|
||||||
|
search: "ಹುಡುಕು"
|
||||||
|
notifications: "ಅಧಿಸೂಚನೆಗಳು"
|
||||||
|
username: "ಬಳಕೆಹೆಸರು"
|
||||||
|
password: "ಗುಪ್ತಪದ"
|
||||||
|
fetchingAsApObject: "ಒಕ್ಕೂಟದಿಂದ ಪಡೆಯಲಾಗುತ್ತಿದೆ..."
|
||||||
|
ok: "ಸರಿ"
|
||||||
|
gotIt: "ಅರ್ಥವಾಯಿತು!"
|
||||||
|
cancel: "ರದ್ದು"
|
||||||
|
enterUsername: "ಬಳಕೆಹೆಸರನ್ನು ಭರ್ತಿ ಮಾಡಿ"
|
||||||
|
renotedBy: "{user} ಪುನರಾವರ್ತಿಸಿದರು"
|
||||||
|
noNotes: "ಟಿಪ್ಪಣಿಗಳಿಲ್ಲ"
|
||||||
|
noNotifications: "ಅಧಿಸೂಚನೆಗಳಿಲ್ಲ"
|
||||||
|
instance: "ನಿದರ್ಶನ"
|
||||||
|
settings: "ಸಿದ್ಧತೆಗಳು"
|
||||||
|
profile: "ಪ್ರೊಫೈಲು"
|
||||||
|
timeline: "ಸಮಯಸಾಲು"
|
||||||
|
noAccountDescription: "ಇವರು ಸ್ವಯಂ ಪರಿಚಯ ರಚಿಸಿಲ್ಲ"
|
||||||
|
login: "ಪ್ರವೇಶ"
|
||||||
|
loggingIn: "ಪ್ರವೇಶಿಸುತ್ತಾ..."
|
||||||
|
logout: "ಆಚೆಗೆ"
|
||||||
|
signup: "ನೋಂದಣಿ"
|
||||||
|
uploading: "ಅಪ್ಲೋಡಾಗುತ್ತಿದೆ"
|
||||||
|
save: "ಉಳಿಸಿ"
|
||||||
|
users: "ಬಳಕೆದಾರ"
|
||||||
|
addUser: "ಬಳಕೆದಾರರನ್ನು ಸೇರಿಸಿ"
|
||||||
|
favorite: "ಮೆಚ್ಚಿನ"
|
||||||
|
favorites: "ಮೆಚ್ಚಿನವುಗಳು"
|
||||||
|
unfavorite: "ಮೆಚ್ಚುಗೆ ಅಳಿಸು"
|
||||||
|
pin: "ಪ್ರೊಫ಼ೈಲಿಗೆ ಅಂಟಿಸು"
|
||||||
|
unpin: "ಪ್ರೊಫ಼ೈಲಿಂದ ಅಂಟುತೆಗೆ"
|
||||||
|
copyContent: "ವಿಷಯವನ್ನು ನಕಲಿಸು"
|
||||||
|
copyLink: "ಲಿಂಕನ್ನು ನಕಲಿಸು"
|
||||||
|
delete: "ಅಳಿಸು"
|
||||||
|
addToList: "ಪಟ್ಟಿಗೆ ಸೇರಿಸು"
|
||||||
|
sendMessage: "ಸಂದೇಶ ಕಳುಹಿಸು"
|
||||||
|
copyUsername: "ಬಳಕೆಹೆಸರು ನಕಲಿಸು"
|
||||||
|
reply: "ಉತ್ತರಿಸು"
|
||||||
|
loadMore: "ಇನ್ನಷ್ಟು ನೋಡು"
|
||||||
|
showMore: "ಇನ್ನಷ್ಟು ನೋಡು"
|
||||||
|
youGotNewFollower: "ಹಿಂಬಾಲಿಸಿದರು"
|
||||||
|
receiveFollowRequest: "ಹಿಂಬಾಲನೆ ವಿನಂತಿ ಬಂದಿದೆ"
|
||||||
|
followRequestAccepted: "ಹಿಂಬಾಲನೆ ವಿನಂತಿ ಸ್ವೀಕರಿಸಲಾಯಿತು"
|
||||||
|
mentions: "ಹೆಸರಿಸಿದ"
|
||||||
|
directNotes: "ನೇರ ಟಿಪ್ಪಣಿಗಳು"
|
||||||
|
importAndExport: "ಆಮದು/ರಫ್ತು"
|
||||||
|
import: "ಆಮದು"
|
||||||
|
export: "ರಫ್ತು"
|
||||||
|
files: "ಕಡತಗಳು"
|
||||||
|
download: "ಜಾಲದಿಂದಿಳಿಸು"
|
||||||
|
driveFileDeleteConfirm: "\"{name}\" ಕಡತವನ್ನು ಅಳಿಸಲು ನೀವು ಬಯಸುವಿರಾ? ಈ ನೋಡಿರಿ ಲಗತ್ತಿಸಲಾದ ಟಿಪ್ಪಣಿ ಸಹ ಕಣ್ಮರೆಯಾಗುತ್ತದೆ."
|
||||||
|
unfollowConfirm: "{name}ಅನ್ನು ಹಿಂಬಾಲಿಸದಿರುವುದೇ?"
|
||||||
|
pinned: "ಪ್ರೊಫ಼ೈಲಿಗೆ ಅಂಟಿಸು"
|
||||||
|
instances: "ನಿದರ್ಶನ"
|
||||||
|
remove: "ಅಳಿಸು"
|
||||||
|
smtpUser: "ಬಳಕೆಹೆಸರು"
|
||||||
|
smtpPass: "ಗುಪ್ತಪದ"
|
||||||
|
_email:
|
||||||
|
_follow:
|
||||||
|
title: "ಹಿಂಬಾಲಿಸಿದರು"
|
||||||
|
_mfm:
|
||||||
|
search: "ಹುಡುಕು"
|
||||||
|
_sfx:
|
||||||
|
notification: "ಅಧಿಸೂಚನೆಗಳು"
|
||||||
|
_widgets:
|
||||||
|
notifications: "ಅಧಿಸೂಚನೆಗಳು"
|
||||||
|
timeline: "ಸಮಯಸಾಲು"
|
||||||
|
_cw:
|
||||||
|
show: "ಇನ್ನಷ್ಟು ನೋಡು"
|
||||||
|
_profile:
|
||||||
|
username: "ಬಳಕೆಹೆಸರು"
|
||||||
|
_notification:
|
||||||
|
youWereFollowed: "ಹಿಂಬಾಲಿಸಿದರು"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "ಅಧಿಸೂಚನೆಗಳು"
|
||||||
|
tl: "ಸಮಯಸಾಲು"
|
||||||
|
mentions: "ಹೆಸರಿಸಿದ"
|
||||||
|
1366
locales/pl-PL.yml
@ -1,2 +1,31 @@
|
|||||||
---
|
---
|
||||||
_lang_: "Português"
|
_lang_: "Português"
|
||||||
|
monthAndDay: "{day}/{month}"
|
||||||
|
search: "Pesquisar"
|
||||||
|
notifications: "Notificações"
|
||||||
|
username: "Nome de usuário"
|
||||||
|
password: "Senha"
|
||||||
|
ok: "OK"
|
||||||
|
cancel: "Cancelar"
|
||||||
|
enterUsername: "Digite o nome de usuário"
|
||||||
|
renotedBy: "Repostado por {user}"
|
||||||
|
settings: "Configurações"
|
||||||
|
basicSettings: "Configurações básicas"
|
||||||
|
otherSettings: "Outras configurações"
|
||||||
|
profile: "Perfil"
|
||||||
|
timeline: "Timeline"
|
||||||
|
smtpUser: "Nome de usuário"
|
||||||
|
smtpPass: "Senha"
|
||||||
|
_mfm:
|
||||||
|
search: "Pesquisar"
|
||||||
|
_sfx:
|
||||||
|
notification: "Notificações"
|
||||||
|
_widgets:
|
||||||
|
notifications: "Notificações"
|
||||||
|
timeline: "Timeline"
|
||||||
|
_profile:
|
||||||
|
username: "Nome de usuário"
|
||||||
|
_deck:
|
||||||
|
_columns:
|
||||||
|
notifications: "Notificações"
|
||||||
|
tl: "Timeline"
|
||||||
|
1562
locales/ru-RU.yml
1
locales/th-TH.yml
Normal file
@ -0,0 +1 @@
|
|||||||
|
---
|
5
locales/ug-CN.yml
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
---
|
||||||
|
_lang_: "ياپونچە"
|
||||||
|
search: "ئىزدەش"
|
||||||
|
_mfm:
|
||||||
|
search: "ئىزدەش"
|
1493
locales/uk-UA.yml
Normal file
1425
locales/zh-TW.yml
28
migration/1581695816408-user-group-antenna.ts
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class userGroupAntenna1581695816408 implements MigrationInterface {
|
||||||
|
name = 'userGroupAntenna1581695816408'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ADD "userGroupJoiningId" character varying(32)`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TYPE "public"."antenna_src_enum" RENAME TO "antenna_src_enum_old"`, undefined);
|
||||||
|
await queryRunner.query(`CREATE TYPE "antenna_src_enum" AS ENUM('home', 'all', 'users', 'list', 'group')`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ALTER COLUMN "src" TYPE "antenna_src_enum" USING "src"::"text"::"antenna_src_enum"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TYPE "antenna_src_enum_old"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" DROP COLUMN "users"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ADD "users" character varying(1024) array NOT NULL DEFAULT '{}'::varchar[]`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ADD CONSTRAINT "FK_ccbf5a8c0be4511133dcc50ddeb" FOREIGN KEY ("userGroupJoiningId") REFERENCES "user_group_joining"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" DROP CONSTRAINT "FK_ccbf5a8c0be4511133dcc50ddeb"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" DROP COLUMN "users"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ADD "users" character varying array NOT NULL DEFAULT '{}'`, undefined);
|
||||||
|
await queryRunner.query(`CREATE TYPE "antenna_src_enum_old" AS ENUM('home', 'all', 'users', 'list')`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ALTER COLUMN "src" TYPE "antenna_src_enum_old" USING "src"::"text"::"antenna_src_enum_old"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TYPE "antenna_src_enum"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TYPE "antenna_src_enum_old" RENAME TO "antenna_src_enum"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" DROP COLUMN "userGroupJoiningId"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1581708415836-drive-user-folder-id-index.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class driveUserFolderIdIndex1581708415836 implements MigrationInterface {
|
||||||
|
name = 'driveUserFolderIdIndex1581708415836'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_55720b33a61a7c806a8215b825" ON "drive_file" ("userId", "folderId", "id") `, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_55720b33a61a7c806a8215b825"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
28
migration/1581979837262-promo.ts
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class promo1581979837262 implements MigrationInterface {
|
||||||
|
name = 'promo1581979837262'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`CREATE TABLE "promo_note" ("noteId" character varying(32) NOT NULL, "expiresAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, CONSTRAINT "REL_e263909ca4fe5d57f8d4230dd5" UNIQUE ("noteId"), CONSTRAINT "PK_e263909ca4fe5d57f8d4230dd5c" PRIMARY KEY ("noteId"))`, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_83f0862e9bae44af52ced7099e" ON "promo_note" ("userId") `, undefined);
|
||||||
|
await queryRunner.query(`CREATE TABLE "promo_read" ("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_61917c1541002422b703318b7c9" PRIMARY KEY ("id"))`, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_9657d55550c3d37bfafaf7d4b0" ON "promo_read" ("userId") `, undefined);
|
||||||
|
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_2882b8a1a07c7d281a98b6db16" ON "promo_read" ("userId", "noteId") `, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "promo_note" ADD CONSTRAINT "FK_e263909ca4fe5d57f8d4230dd5c" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "promo_read" ADD CONSTRAINT "FK_9657d55550c3d37bfafaf7d4b05" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "promo_read" ADD CONSTRAINT "FK_a46a1a603ecee695d7db26da5f4" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "promo_read" DROP CONSTRAINT "FK_a46a1a603ecee695d7db26da5f4"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "promo_read" DROP CONSTRAINT "FK_9657d55550c3d37bfafaf7d4b05"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "promo_note" DROP CONSTRAINT "FK_e263909ca4fe5d57f8d4230dd5c"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_2882b8a1a07c7d281a98b6db16"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_9657d55550c3d37bfafaf7d4b0"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TABLE "promo_read"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_83f0862e9bae44af52ced7099e"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TABLE "promo_note"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1582019042083-featured-injecttion.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class featuredInjecttion1582019042083 implements MigrationInterface {
|
||||||
|
name = 'featuredInjecttion1582019042083'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "injectFeaturedNote" boolean NOT NULL DEFAULT true`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "injectFeaturedNote"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1582210532752-antenna-exclude.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class antennaExclude1582210532752 implements MigrationInterface {
|
||||||
|
name = 'antennaExclude1582210532752'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" ADD "excludeKeywords" jsonb NOT NULL DEFAULT '[]'`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "antenna" DROP COLUMN "excludeKeywords"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1582875306439-note-reaction-length.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class noteReactionLength1582875306439 implements MigrationInterface {
|
||||||
|
name = 'noteReactionLength1582875306439'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(130)`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(128)`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
36
migration/1585361548360-miauth.ts
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class miauth1585361548360 implements MigrationInterface {
|
||||||
|
name = 'miauth1585361548360'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "lastUsedAt" TIMESTAMP WITH TIME ZONE DEFAULT null`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "session" character varying(128) DEFAULT null`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "name" character varying(128) DEFAULT null`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "description" character varying(512) DEFAULT null`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "iconUrl" character varying(512) DEFAULT null`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "permission" character varying(64) array NOT NULL DEFAULT '{}'::varchar[]`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD "fetched" boolean NOT NULL DEFAULT false`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP CONSTRAINT "FK_a3ff16c90cc87a82a0b5959e560"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ALTER COLUMN "appId" DROP NOT NULL`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ALTER COLUMN "appId" SET DEFAULT null`, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_bf3a053c07d9fb5d87317c56ee" ON "access_token" ("session") `, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD CONSTRAINT "FK_a3ff16c90cc87a82a0b5959e560" FOREIGN KEY ("appId") REFERENCES "app"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP CONSTRAINT "FK_a3ff16c90cc87a82a0b5959e560"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_bf3a053c07d9fb5d87317c56ee"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ALTER COLUMN "appId" DROP DEFAULT`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ALTER COLUMN "appId" SET NOT NULL`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" ADD CONSTRAINT "FK_a3ff16c90cc87a82a0b5959e560" FOREIGN KEY ("appId") REFERENCES "app"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "fetched"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "permission"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "iconUrl"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "description"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "name"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "session"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "access_token" DROP COLUMN "lastUsedAt"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
48
migration/1585385921215-custom-notification.ts
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class customNotification1585385921215 implements MigrationInterface {
|
||||||
|
name = 'customNotification1585385921215'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD "customBody" character varying(2048)`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD "customHeader" character varying(256)`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD "customIcon" character varying(1024)`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD "appAccessTokenId" character varying(32)`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" DROP CONSTRAINT "FK_3b4e96eec8d36a8bbb9d02aa710"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ALTER COLUMN "notifierId" DROP NOT NULL`, undefined);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."notifierId" IS 'The ID of sender user of the Notification.'`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TYPE "public"."notification_type_enum" RENAME TO "notification_type_enum_old"`, undefined);
|
||||||
|
await queryRunner.query(`CREATE TYPE "notification_type_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ALTER COLUMN "type" TYPE "notification_type_enum" USING "type"::"text"::"notification_type_enum"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TYPE "notification_type_enum_old"`, undefined);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."type" IS 'The type of the Notification.'`, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_3b4e96eec8d36a8bbb9d02aa71" ON "notification" ("notifierId") `, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_33f33cc8ef29d805a97ff4628b" ON "notification" ("type") `, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_080ab397c379af09b9d2169e5b" ON "notification" ("isRead") `, undefined);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_e22bf6bda77b6adc1fd9e75c8c" ON "notification" ("appAccessTokenId") `, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_3b4e96eec8d36a8bbb9d02aa710" FOREIGN KEY ("notifierId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_e22bf6bda77b6adc1fd9e75c8c9" FOREIGN KEY ("appAccessTokenId") REFERENCES "access_token"("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_e22bf6bda77b6adc1fd9e75c8c9"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" DROP CONSTRAINT "FK_3b4e96eec8d36a8bbb9d02aa710"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_e22bf6bda77b6adc1fd9e75c8c"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_080ab397c379af09b9d2169e5b"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_33f33cc8ef29d805a97ff4628b"`, undefined);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_3b4e96eec8d36a8bbb9d02aa71"`, undefined);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."type" IS ''`, undefined);
|
||||||
|
await queryRunner.query(`CREATE TYPE "notification_type_enum_old" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited')`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ALTER COLUMN "type" TYPE "notification_type_enum_old" USING "type"::"text"::"notification_type_enum_old"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TYPE "notification_type_enum"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TYPE "notification_type_enum_old" RENAME TO "notification_type_enum"`, undefined);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."notifierId" IS ''`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ALTER COLUMN "notifierId" SET NOT NULL`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" ADD CONSTRAINT "FK_3b4e96eec8d36a8bbb9d02aa710" FOREIGN KEY ("notifierId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" DROP COLUMN "appAccessTokenId"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" DROP COLUMN "customIcon"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" DROP COLUMN "customHeader"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "notification" DROP COLUMN "customBody"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
15
migration/1585772678853-ap-url.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
/* tslint:disable:quotemark class-name indent */
|
||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class apUrl1585772678853 implements MigrationInterface {
|
||||||
|
name = 'apUrl1585772678853'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "note" ADD "url" character varying(512)`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "note" DROP COLUMN "url"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1586624197029-AddObjectStorageUseProxy.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from 'typeorm';
|
||||||
|
|
||||||
|
export class AddObjectStorageUseProxy1586624197029 implements MigrationInterface {
|
||||||
|
name = 'AddObjectStorageUseProxy1586624197029'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageUseProxy" boolean NOT NULL DEFAULT true`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageUseProxy"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
12
migration/1586641139527-remote-reaction.ts
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class remoteReaction1586641139527 implements MigrationInterface {
|
||||||
|
name = 'remoteReaction1586641139527'
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(260)`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<any> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_reaction" ALTER COLUMN "reaction" TYPE character varying(130)`, undefined);
|
||||||
|
}
|
||||||
|
}
|
14
migration/1586708940386-pageAiScript.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class pageAiScript1586708940386 implements MigrationInterface {
|
||||||
|
name = 'pageAiScript1586708940386'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "page" ADD "script" character varying(16384) NOT NULL DEFAULT ''`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "page" DROP COLUMN "script"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
18
migration/1588044505511-hCaptcha.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class hCaptcha1588044505511 implements MigrationInterface {
|
||||||
|
name = 'hCaptcha1588044505511'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "enableHcaptcha" boolean NOT NULL DEFAULT false`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "hcaptchaSiteKey" character varying(64)`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "hcaptchaSecretKey" character varying(64)`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "hcaptchaSecretKey"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "hcaptchaSiteKey"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "enableHcaptcha"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
18
migration/1589023282116-pubRelay.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class pubRelay1589023282116 implements MigrationInterface {
|
||||||
|
name = 'pubRelay1589023282116'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE TYPE "relay_status_enum" AS ENUM('requesting', 'accepted', 'rejected')`, undefined);
|
||||||
|
await queryRunner.query(`CREATE TABLE "relay" ("id" character varying(32) NOT NULL, "inbox" character varying(512) NOT NULL, "status" "relay_status_enum" NOT NULL, CONSTRAINT "PK_78ebc9cfddf4292633b7ba57aee" PRIMARY KEY ("id"))`, undefined);
|
||||||
|
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_0d9a1738f2cf7f3b1c3334dfab" ON "relay" ("inbox") `, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_0d9a1738f2cf7f3b1c3334dfab"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TABLE "relay"`, undefined);
|
||||||
|
await queryRunner.query(`DROP TYPE "relay_status_enum"`, undefined);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1595075960584-blurhash.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class blurhash1595075960584 implements MigrationInterface {
|
||||||
|
name = 'blurhash1595075960584'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "drive_file" ADD "blurhash" character varying(128)`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "drive_file" DROP COLUMN "blurhash"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
20
migration/1595077605646-blurhash-for-avatar-banner.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class blurhashForAvatarBanner1595077605646 implements MigrationInterface {
|
||||||
|
name = 'blurhashForAvatarBanner1595077605646'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "avatarColor"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "bannerColor"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" ADD "avatarBlurhash" character varying(128)`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" ADD "bannerBlurhash" character varying(128)`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "bannerBlurhash"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "avatarBlurhash"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" ADD "bannerColor" character varying(32)`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" ADD "avatarColor" character varying(32)`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1595676934834-instance-icon-url.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class instanceIconUrl1595676934834 implements MigrationInterface {
|
||||||
|
name = 'instanceIconUrl1595676934834'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "iconUrl" character varying(256) DEFAULT null`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "iconUrl"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
30
migration/1595771249699-word-mute.ts
Normal file
@ -0,0 +1,30 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class wordMute1595771249699 implements MigrationInterface {
|
||||||
|
name = 'wordMute1595771249699'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE TABLE "muted_note" ("id" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, "userId" character varying(32) NOT NULL, CONSTRAINT "PK_897e2eff1c0b9b64e55ca1418a4" PRIMARY KEY ("id"))`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_70ab9786313d78e4201d81cdb8" ON "muted_note" ("noteId") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_d8e07aa18c2d64e86201601aec" ON "muted_note" ("userId") `);
|
||||||
|
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_a8c6bfd637d3f1d67a27c48e27" ON "muted_note" ("noteId", "userId") `);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "enableWordMute" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "mutedWords" jsonb NOT NULL DEFAULT '[]'`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_3befe6f999c86aff06eb0257b4" ON "user_profile" ("enableWordMute") `);
|
||||||
|
await queryRunner.query(`ALTER TABLE "muted_note" ADD CONSTRAINT "FK_70ab9786313d78e4201d81cdb89" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "muted_note" ADD CONSTRAINT "FK_d8e07aa18c2d64e86201601aec1" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "muted_note" DROP CONSTRAINT "FK_d8e07aa18c2d64e86201601aec1"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "muted_note" DROP CONSTRAINT "FK_70ab9786313d78e4201d81cdb89"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_3befe6f999c86aff06eb0257b4"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "mutedWords"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "enableWordMute"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_a8c6bfd637d3f1d67a27c48e27"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_d8e07aa18c2d64e86201601aec"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_70ab9786313d78e4201d81cdb8"`);
|
||||||
|
await queryRunner.query(`DROP TABLE "muted_note"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
18
migration/1595782306083-word-mute2.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class wordMute21595782306083 implements MigrationInterface {
|
||||||
|
name = 'wordMute21595782306083'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE TYPE "muted_note_reason_enum" AS ENUM('word', 'manual', 'spam', 'other')`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "muted_note" ADD "reason" "muted_note_reason_enum" NOT NULL`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_636e977ff90b23676fb5624b25" ON "muted_note" ("reason") `);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_636e977ff90b23676fb5624b25"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "muted_note" DROP COLUMN "reason"`);
|
||||||
|
await queryRunner.query(`DROP TYPE "muted_note_reason_enum"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
58
migration/1596548170836-channel.ts
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class channel1596548170836 implements MigrationInterface {
|
||||||
|
name = 'channel1596548170836'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE TABLE "channel" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "lastNotedAt" TIMESTAMP WITH TIME ZONE, "userId" character varying(32) NOT NULL, "name" character varying(128) NOT NULL, "description" character varying(2048), "bannerId" character varying(32), "notesCount" integer NOT NULL DEFAULT 0, "usersCount" integer NOT NULL DEFAULT 0, CONSTRAINT "PK_590f33ee6ee7d76437acf362e39" PRIMARY KEY ("id"))`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_71cb7b435b7c0d4843317e7e16" ON "channel" ("createdAt") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_29ef80c6f13bcea998447fce43" ON "channel" ("lastNotedAt") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_823bae55bd81b3be6e05cff438" ON "channel" ("userId") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_0f58c11241e649d2a638a8de94" ON "channel" ("notesCount") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_094b86cd36bb805d1aa1e8cc9a" ON "channel" ("usersCount") `);
|
||||||
|
await queryRunner.query(`CREATE TABLE "channel_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, CONSTRAINT "PK_8b104be7f7415113f2a02cd5bdd" PRIMARY KEY ("id"))`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_11e71f2511589dcc8a4d3214f9" ON "channel_following" ("createdAt") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_0e43068c3f92cab197c3d3cd86" ON "channel_following" ("followeeId") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_6d8084ec9496e7334a4602707e" ON "channel_following" ("followerId") `);
|
||||||
|
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_2e230dd45a10e671d781d99f3e" ON "channel_following" ("followerId", "followeeId") `);
|
||||||
|
await queryRunner.query(`CREATE TABLE "channel_note_pining" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "channelId" character varying(32) NOT NULL, "noteId" character varying(32) NOT NULL, CONSTRAINT "PK_44f7474496bcf2e4b741681146d" PRIMARY KEY ("id"))`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_8125f950afd3093acb10d2db8a" ON "channel_note_pining" ("channelId") `);
|
||||||
|
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_f36fed37d6d4cdcc68c803cd9c" ON "channel_note_pining" ("channelId", "noteId") `);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note" ADD "channelId" character varying(32) DEFAULT null`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_f22169eb10657bded6d875ac8f" ON "note" ("channelId") `);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel" ADD CONSTRAINT "FK_823bae55bd81b3be6e05cff4383" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel" ADD CONSTRAINT "FK_999da2bcc7efadbfe0e92d3bc19" FOREIGN KEY ("bannerId") REFERENCES "drive_file"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_f22169eb10657bded6d875ac8f9" FOREIGN KEY ("channelId") REFERENCES "channel"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" ADD CONSTRAINT "FK_0e43068c3f92cab197c3d3cd86e" FOREIGN KEY ("followeeId") REFERENCES "channel"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" ADD CONSTRAINT "FK_6d8084ec9496e7334a4602707e1" FOREIGN KEY ("followerId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_note_pining" ADD CONSTRAINT "FK_8125f950afd3093acb10d2db8a8" FOREIGN KEY ("channelId") REFERENCES "channel"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_note_pining" ADD CONSTRAINT "FK_10b19ef67d297ea9de325cd4502" FOREIGN KEY ("noteId") REFERENCES "note"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_note_pining" DROP CONSTRAINT "FK_10b19ef67d297ea9de325cd4502"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_note_pining" DROP CONSTRAINT "FK_8125f950afd3093acb10d2db8a8"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" DROP CONSTRAINT "FK_6d8084ec9496e7334a4602707e1"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" DROP CONSTRAINT "FK_0e43068c3f92cab197c3d3cd86e"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_f22169eb10657bded6d875ac8f9"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel" DROP CONSTRAINT "FK_999da2bcc7efadbfe0e92d3bc19"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel" DROP CONSTRAINT "FK_823bae55bd81b3be6e05cff4383"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_f22169eb10657bded6d875ac8f"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note" DROP COLUMN "channelId"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_f36fed37d6d4cdcc68c803cd9c"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_8125f950afd3093acb10d2db8a"`);
|
||||||
|
await queryRunner.query(`DROP TABLE "channel_note_pining"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_2e230dd45a10e671d781d99f3e"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_6d8084ec9496e7334a4602707e"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_0e43068c3f92cab197c3d3cd86"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_11e71f2511589dcc8a4d3214f9"`);
|
||||||
|
await queryRunner.query(`DROP TABLE "channel_following"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_094b86cd36bb805d1aa1e8cc9a"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_0f58c11241e649d2a638a8de94"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_823bae55bd81b3be6e05cff438"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_29ef80c6f13bcea998447fce43"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_71cb7b435b7c0d4843317e7e16"`);
|
||||||
|
await queryRunner.query(`DROP TABLE "channel"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1596786425167-channel2.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class channel21596786425167 implements MigrationInterface {
|
||||||
|
name = 'channel21596786425167'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" ADD "readCursor" TIMESTAMP WITH TIME ZONE NOT NULL`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" DROP COLUMN "readCursor"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1597230137744-objectStorageSetPublicRead.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class objectStorageSetPublicRead1597230137744 implements MigrationInterface {
|
||||||
|
name = 'objectStorageSetPublicRead1597230137744'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "objectStorageSetPublicRead" boolean NOT NULL DEFAULT false`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "objectStorageSetPublicRead"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
16
migration/1597236229720-IncludingNotificationTypes.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class IncludingNotificationTypes1597236229720 implements MigrationInterface {
|
||||||
|
name = 'IncludingNotificationTypes1597236229720'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE TYPE "user_profile_includingnotificationtypes_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "includingNotificationTypes" "user_profile_includingnotificationtypes_enum" array`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "includingNotificationTypes"`);
|
||||||
|
await queryRunner.query(`DROP TYPE "user_profile_includingnotificationtypes_enum"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1597385880794-add-sensitive-index.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class addSensitiveIndex1597385880794 implements MigrationInterface {
|
||||||
|
name = 'addSensitiveIndex1597385880794'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_a7eba67f8b3fa27271e85d2e26" ON "drive_file" ("isSensitive") `);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_a7eba67f8b3fa27271e85d2e26"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
27
migration/1597459042300-channel-unread.ts
Normal file
@ -0,0 +1,27 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class channelUnread1597459042300 implements MigrationInterface {
|
||||||
|
name = 'channelUnread1597459042300'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`TRUNCATE TABLE "note_unread"`, undefined);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" DROP COLUMN "readCursor"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_unread" ADD "isMentioned" boolean NOT NULL`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_unread" ADD "noteChannelId" character varying(32)`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_25b1dd384bec391b07b74b861c" ON "note_unread" ("isMentioned") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_89a29c9237b8c3b6b3cbb4cb30" ON "note_unread" ("isSpecified") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_29e8c1d579af54d4232939f994" ON "note_unread" ("noteUserId") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_6a57f051d82c6d4036c141e107" ON "note_unread" ("noteChannelId") `);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_6a57f051d82c6d4036c141e107"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_29e8c1d579af54d4232939f994"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_89a29c9237b8c3b6b3cbb4cb30"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_25b1dd384bec391b07b74b861c"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_unread" DROP COLUMN "noteChannelId"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "note_unread" DROP COLUMN "isMentioned"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "channel_following" ADD "readCursor" TIMESTAMP WITH TIME ZONE NOT NULL`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
16
migration/1597893996136-ChannelNoteIdDescIndex.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class ChannelNoteIdDescIndex1597893996136 implements MigrationInterface {
|
||||||
|
name = 'ChannelNoteIdDescIndex1597893996136'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_f22169eb10657bded6d875ac8f"`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_note_on_channelId_and_id_desc" ON "note" ("channelId", "id" desc)`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_note_on_channelId_and_id_desc"`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_f22169eb10657bded6d875ac8f" ON "note" ("channelId") `);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
20
migration/1600353287890-mutingNotificationTypes.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class mutingNotificationTypes1600353287890 implements MigrationInterface {
|
||||||
|
name = 'mutingNotificationTypes1600353287890'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "includingNotificationTypes"`);
|
||||||
|
await queryRunner.query(`DROP TYPE "public"."user_profile_includingnotificationtypes_enum"`);
|
||||||
|
await queryRunner.query(`CREATE TYPE "user_profile_mutingnotificationtypes_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "mutingNotificationTypes" "user_profile_mutingnotificationtypes_enum" array NOT NULL DEFAULT '{}'`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "mutingNotificationTypes"`);
|
||||||
|
await queryRunner.query(`DROP TYPE "user_profile_mutingnotificationtypes_enum"`);
|
||||||
|
await queryRunner.query(`CREATE TYPE "public"."user_profile_includingnotificationtypes_enum" AS ENUM('follow', 'mention', 'reply', 'renote', 'quote', 'reaction', 'pollVote', 'receiveFollowRequest', 'followRequestAccepted', 'groupInvited', 'app')`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "includingNotificationTypes" "user_profile_includingnotificationtypes_enum" array`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
32
migration/1603094348345-refine-abuse-user-report.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class refineAbuseUserReport1603094348345 implements MigrationInterface {
|
||||||
|
name = 'refineAbuseUserReport1603094348345'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP CONSTRAINT "FK_d049123c413e68ca52abe734203"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_d049123c413e68ca52abe73420"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_5cd442c3b2e74fdd99dae20243"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" RENAME COLUMN "userId" TO "targetUserId"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "assigneeId" character varying(32)`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "resolved" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "comment"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "comment" character varying(2048) NOT NULL DEFAULT '{}'::varchar[]`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_2b15aaf4a0dc5be3499af7ab6a" ON "abuse_user_report" ("resolved") `);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD CONSTRAINT "FK_08b883dd5fdd6f9c4c1572b36de" FOREIGN KEY ("assigneeId") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE NO ACTION`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP CONSTRAINT "FK_08b883dd5fdd6f9c4c1572b36de"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_2b15aaf4a0dc5be3499af7ab6a"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "comment"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "comment" character varying(512) NOT NULL DEFAULT '{}'::varchar[]`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "resolved"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "assigneeId"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" RENAME COLUMN "targetUserId" TO "userId"`);
|
||||||
|
await queryRunner.query(`CREATE UNIQUE INDEX "IDX_5cd442c3b2e74fdd99dae20243" ON "abuse_user_report" ("userId", "reporterId") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_d049123c413e68ca52abe73420" ON "abuse_user_report" ("userId") `);
|
||||||
|
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`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
20
migration/1603095701770-refine-abuse-user-report2.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class refineAbuseUserReport21603095701770 implements MigrationInterface {
|
||||||
|
name = 'refineAbuseUserReport21603095701770'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "targetUserHost" character varying(128)`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" ADD "reporterHost" character varying(128)`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_4ebbf7f93cdc10e8d1ef2fc6cd" ON "abuse_user_report" ("targetUserHost") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_f8d8b93740ad12c4ce8213a199" ON "abuse_user_report" ("reporterHost") `);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_f8d8b93740ad12c4ce8213a199"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_4ebbf7f93cdc10e8d1ef2fc6cd"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "reporterHost"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "abuse_user_report" DROP COLUMN "targetUserHost"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1603776877564-instance-theme-color.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class instanceThemeColor1603776877564 implements MigrationInterface {
|
||||||
|
name = 'instanceThemeColor1603776877564'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "themeColor" character varying(64) DEFAULT null`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "themeColor"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1603781553011-instance-favicon.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class instanceFavicon1603781553011 implements MigrationInterface {
|
||||||
|
name = 'instanceFavicon1603781553011'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" ADD "faviconUrl" character varying(256) DEFAULT null`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "instance" DROP COLUMN "faviconUrl"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1604821689616-delete-auto-watch.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class deleteAutoWatch1604821689616 implements MigrationInterface {
|
||||||
|
name = 'deleteAutoWatch1604821689616'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "autoWatch"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "autoWatch" boolean NOT NULL DEFAULT false`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
15
migration/1605408848373-clip-description.ts
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class clipDescription1605408848373 implements MigrationInterface {
|
||||||
|
name = 'clipDescription1605408848373'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "clip" ADD "description" character varying(2048) DEFAULT null`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
|
||||||
|
await queryRunner.query(`ALTER TABLE "clip" DROP COLUMN "description"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
434
migration/1605408971051-comments.ts
Normal file
@ -0,0 +1,434 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class comments1605408971051 implements MigrationInterface {
|
||||||
|
name = 'comments1605408971051'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "log"."createdAt" IS 'The created date of the Log.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."createdAt" IS 'The created date of the DriveFolder.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."name" IS 'The name of the DriveFolder.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."parentId" IS 'The parent folder ID. If null, it means the DriveFolder is located in root.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."createdAt" IS 'The created date of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userHost" IS 'The host of owner. It will be null if the user in local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."md5" IS 'The MD5 hash of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."name" IS 'The file name of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."type" IS 'The content type (MIME) of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."size" IS 'The file size (bytes) of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."comment" IS 'The comment of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."blurhash" IS 'The BlurHash string.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."properties" IS 'The any properties of the DriveFile. For example, it includes image width/height.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."url" IS 'The URL of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."thumbnailUrl" IS 'The URL of the thumbnail of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."webpublicUrl" IS 'The URL of the webpublic of the DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."uri" IS 'The URI of the DriveFile. it will be null when the DriveFile is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."folderId" IS 'The parent folder ID. If null, it means the DriveFile is located in root.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isSensitive" IS 'Whether the DriveFile is NSFW.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isLink" IS 'Whether the DriveFile is direct link to remote server.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."createdAt" IS 'The created date of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."updatedAt" IS 'The updated date of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."username" IS 'The username of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."usernameLower" IS 'The username (lowercased) of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."name" IS 'The name of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."followersCount" IS 'The count of followers.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."followingCount" IS 'The count of following.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."notesCount" IS 'The count of notes.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."avatarId" IS 'The ID of avatar DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."bannerId" IS 'The ID of banner DriveFile.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isSuspended" IS 'Whether the User is suspended.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isSilenced" IS 'Whether the User is silenced.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isLocked" IS 'Whether the User is locked.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isBot" IS 'Whether the User is a bot.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isCat" IS 'Whether the User is a cat.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isAdmin" IS 'Whether the User is the admin.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isModerator" IS 'Whether the User is a moderator.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."host" IS 'The host of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."inbox" IS 'The inbox URL of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."sharedInbox" IS 'The sharedInbox URL of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."featured" IS 'The featured URL of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."uri" IS 'The URI of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."token" IS 'The native access token of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."createdAt" IS 'The created date of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."secret" IS 'The secret key of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."name" IS 'The name of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."description" IS 'The description of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."permission" IS 'The permission of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."callbackUrl" IS 'The callbackUrl of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."createdAt" IS 'The created date of the AccessToken.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."lastUsedAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."session" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."appId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."iconUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."createdAt" IS 'The created date of the Channel.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."name" IS 'The name of the Channel.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."description" IS 'The description of the Channel.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."bannerId" IS 'The ID of banner Channel.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."notesCount" IS 'The count of notes.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."usersCount" IS 'The count of users.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."createdAt" IS 'The created date of the Note.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."replyId" IS 'The ID of reply target.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."renoteId" IS 'The ID of renote target.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."userId" IS 'The ID of author.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."uri" IS 'The URI of a note. it will be null when the note is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."url" IS 'The human readable url of a note. it will be null when the note is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."channelId" IS 'The ID of source channel.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."userHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll_vote"."createdAt" IS 'The created date of the PollVote.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_reaction"."createdAt" IS 'The created date of the NoteReaction.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."createdAt" IS 'The created date of the NoteWatching.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."userId" IS 'The watcher ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteId" IS 'The target Note ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteUserId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteUserId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteChannelId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."createdAt" IS 'The created date of the FollowRequest.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeId" IS 'The followee user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerId" IS 'The follower user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."requestId" IS 'id of Follow Activity.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerSharedInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeSharedInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group"."createdAt" IS 'The created date of the UserGroup.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group"."userId" IS 'The ID of owner.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."createdAt" IS 'The created date of the UserGroupInvitation.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userId" IS 'The user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userGroupId" IS 'The group ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."createdAt" IS 'The created date of the Notification.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."notifieeId" IS 'The ID of recipient user of the Notification.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."isRead" IS 'Whether the Notification is read.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "meta"."localDriveCapacityMb" IS 'Drive capacity of a local user (MB)'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "meta"."remoteDriveCapacityMb" IS 'Drive capacity of a remote user (MB)'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "meta"."maxNoteTextLength" IS 'Max allowed note text length in characters'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."createdAt" IS 'The created date of the Following.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeId" IS 'The followee user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerId" IS 'The follower user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerSharedInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeSharedInbox" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."caughtAt" IS 'The caught date of the Instance.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."host" IS 'The host of the Instance.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."usersCount" IS 'The count of the users of the Instance.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."notesCount" IS 'The count of the notes of the Instance.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareName" IS 'The software of the Instance.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareVersion" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."openRegistrations" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerName" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerEmail" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."iconUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."faviconUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."themeColor" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muting"."createdAt" IS 'The created date of the Muting.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muting"."muteeId" IS 'The mutee user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muting"."muterId" IS 'The muter user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "blocking"."createdAt" IS 'The created date of the Blocking.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockeeId" IS 'The blockee user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockerId" IS 'The blocker user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list"."createdAt" IS 'The created date of the UserList.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list"."name" IS 'The name of the UserList.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."createdAt" IS 'The created date of the UserListJoining.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userId" IS 'The user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userListId" IS 'The list ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."createdAt" IS 'The created date of the UserGroupJoining.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userId" IS 'The user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userGroupId" IS 'The group ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_favorite"."createdAt" IS 'The created date of the NoteFavorite.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."createdAt" IS 'The created date of the AbuseUserReport.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."targetUserHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."reporterHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."createdAt" IS 'The created date of the MessagingMessage.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."userId" IS 'The sender user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."groupId" IS 'The recipient group ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "signin"."createdAt" IS 'The created date of the Signin.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "auth_session"."createdAt" IS 'The created date of the AuthSession.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."createdAt" IS 'The created date of the ReversiGame.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."startedAt" IS 'The started date of the ReversiGame.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form1" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form2" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_matching"."createdAt" IS 'The created date of the ReversiMatching.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_note_pining"."createdAt" IS 'The created date of the UserNotePinings.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."noteVisibility" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."userId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."userHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_keypair"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_publickey"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "page"."createdAt" IS 'The created date of the Page.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "page"."updatedAt" IS 'The updated date of the Page.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "page"."userId" IS 'The ID of author.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."location" IS 'The location of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."birthday" IS 'The birthday (YYYY-MM-DD) of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."description" IS 'The description (bio) of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."url" IS 'Remote URL of the user.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."email" IS 'The email address of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."password" IS 'The password hash of the User. It will be null if the origin of the user is local.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."clientData" IS 'The client-specific data of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."room" IS 'The room data of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userHost" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."id" IS 'Variable-length id given to navigator.credentials.get()'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."publicKey" IS 'Variable-length public key used to verify attestations (hex-encoded).'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."lastUsed" IS 'The date of the last time the UserSecurityKey was successfully validated.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."name" IS 'User-defined name for this key'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."challenge" IS 'Hex-encoded sha256 hash of the challenge.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."createdAt" IS 'The date challenge was created for expiry purposes.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."registrationChallenge" IS 'Indicates that the challenge is only for registration purposes if true to prevent the challenge for being used as authentication.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "moderation_log"."createdAt" IS 'The created date of the ModerationLog.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "announcement"."createdAt" IS 'The created date of the Announcement.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "announcement"."updatedAt" IS 'The updated date of the Announcement.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "announcement_read"."createdAt" IS 'The created date of the AnnouncementRead.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."createdAt" IS 'The created date of the Clip.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."name" IS 'The name of the Clip.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."description" IS 'The description of the Clip.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip_note"."noteId" IS 'The note ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip_note"."clipId" IS 'The clip ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna"."createdAt" IS 'The created date of the Antenna.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna"."userId" IS 'The owner ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna"."name" IS 'The name of the Antenna.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."noteId" IS 'The note ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."antennaId" IS 'The antenna ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "promo_note"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "promo_note"."userId" IS '[Denormalized]'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "promo_read"."createdAt" IS 'The created date of the PromoRead.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muted_note"."noteId" IS 'The note ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muted_note"."userId" IS 'The user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muted_note"."reason" IS 'The reason of the MutedNote.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_following"."createdAt" IS 'The created date of the ChannelFollowing.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followeeId" IS 'The followee channel ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followerId" IS 'The follower user ID.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_note_pining"."createdAt" IS 'The created date of the ChannelNotePining.'`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_note_pining"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followerId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_following"."followeeId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel_following"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muted_note"."reason" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muted_note"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muted_note"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "promo_read"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "promo_note"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "promo_note"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."antennaId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna_note"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "antenna"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip_note"."clipId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip_note"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "clip"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "announcement_read"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "announcement"."updatedAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "announcement"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "moderation_log"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."registrationChallenge" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "attestation_challenge"."challenge" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."lastUsed" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."publicKey" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_security_key"."id" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."room" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."clientData" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."password" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."email" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."url" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."description" IS 'The description (bio) of the User.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."birthday" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."location" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "page"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "page"."updatedAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "page"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_publickey"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_keypair"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."userHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."noteVisibility" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_note_pining"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_matching"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form2" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."form1" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."startedAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "reversi_game"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "auth_session"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "signin"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."groupId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "messaging_message"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."reporterHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."targetUserHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "abuse_user_report"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_favorite"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userGroupId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_joining"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userListId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list_joining"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_list"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockerId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "blocking"."blockeeId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "blocking"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muting"."muterId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muting"."muteeId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "muting"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."themeColor" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."faviconUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."iconUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerEmail" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."maintainerName" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."openRegistrations" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareVersion" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."softwareName" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."notesCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."usersCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."host" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "instance"."caughtAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeSharedInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerSharedInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followerId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."followeeId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "following"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "meta"."maxNoteTextLength" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "meta"."remoteDriveCapacityMb" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "meta"."localDriveCapacityMb" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."isRead" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."notifieeId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "notification"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userGroupId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group_invitation"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_group"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeSharedInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerSharedInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."requestId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followerId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."followeeId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "follow_request"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteChannelId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_unread"."noteUserId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteUserId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."noteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_watching"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note_reaction"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "poll_vote"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."renoteUserId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."replyUserId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."userHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."channelId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."url" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."uri" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."renoteId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."replyId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "note"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."usersCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."notesCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."bannerId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "channel"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."iconUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."appId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."session" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."lastUsedAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "access_token"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."callbackUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."permission" IS 'The permission of the App.'`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."description" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."secret" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "app"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."token" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."uri" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."featured" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."sharedInbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."inbox" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."host" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isModerator" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isAdmin" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isCat" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isBot" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isLocked" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isSilenced" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isSuspended" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."bannerId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."avatarId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."notesCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."followingCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."followersCount" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."usernameLower" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."username" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."updatedAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isLink" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."isSensitive" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."folderId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."uri" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."webpublicUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."thumbnailUrl" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."url" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."properties" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."blurhash" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."comment" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."size" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."type" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."md5" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userHost" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_file"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."parentId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."userId" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."name" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "drive_folder"."createdAt" IS NULL`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "log"."createdAt" IS NULL`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1605585339718-instance-pinned-pages.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class instancePinnedPages1605585339718 implements MigrationInterface {
|
||||||
|
name = 'instancePinnedPages1605585339718'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedPages" character varying(512) array NOT NULL DEFAULT '{"/featured", "/channels", "/explore", "/pages", "/about-misskey"}'::varchar[]`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedPages"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
16
migration/1605965516823-instance-images.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class instanceImages1605965516823 implements MigrationInterface {
|
||||||
|
name = 'instanceImages1605965516823'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "backgroundImageUrl" character varying(512)`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "logoImageUrl" character varying(512)`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "logoImageUrl"`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "backgroundImageUrl"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
16
migration/1606191203881-no-crawle.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class noCrawle1606191203881 implements MigrationInterface {
|
||||||
|
name = 'noCrawle1606191203881'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" ADD "noCrawle" boolean NOT NULL DEFAULT false`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."noCrawle" IS 'Whether reject index by crawler.'`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user_profile"."noCrawle" IS 'Whether reject index by crawler.'`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user_profile" DROP COLUMN "noCrawle"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
14
migration/1607151207216-instance-pinned-clip.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class instancePinnedClip1607151207216 implements MigrationInterface {
|
||||||
|
name = 'instancePinnedClip1607151207216'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" ADD "pinnedClipId" character varying(32)`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "meta" DROP COLUMN "pinnedClipId"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
18
migration/1607353487793-isExplorable.ts
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class isExplorable1607353487793 implements MigrationInterface {
|
||||||
|
name = 'isExplorable1607353487793'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" ADD "isExplorable" boolean NOT NULL DEFAULT true`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isExplorable" IS 'Whether the User is explorable.'`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_d5a1b83c7cab66f167e6888188" ON "user" ("isExplorable") `);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_d5a1b83c7cab66f167e6888188"`);
|
||||||
|
await queryRunner.query(`COMMENT ON COLUMN "user"."isExplorable" IS 'Whether the User is explorable.'`);
|
||||||
|
await queryRunner.query(`ALTER TABLE "user" DROP COLUMN "isExplorable"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
22
migration/1610277136869-registry.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
import {MigrationInterface, QueryRunner} from "typeorm";
|
||||||
|
|
||||||
|
export class registry1610277136869 implements MigrationInterface {
|
||||||
|
name = 'registry1610277136869'
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`CREATE TABLE "registry_item" ("id" character varying(32) NOT NULL, "createdAt" TIMESTAMP WITH TIME ZONE NOT NULL, "updatedAt" TIMESTAMP WITH TIME ZONE NOT NULL, "userId" character varying(32) NOT NULL, "key" character varying(1024) NOT NULL, "scope" character varying(1024) array NOT NULL DEFAULT '{}'::varchar[], "domain" character varying(512), CONSTRAINT "PK_64b3f7e6008b4d89b826cd3af95" PRIMARY KEY ("id")); COMMENT ON COLUMN "registry_item"."createdAt" IS 'The created date of the RegistryItem.'; COMMENT ON COLUMN "registry_item"."updatedAt" IS 'The updated date of the RegistryItem.'; COMMENT ON COLUMN "registry_item"."userId" IS 'The owner ID.'; COMMENT ON COLUMN "registry_item"."key" IS 'The key of the RegistryItem.'`);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_fb9d21ba0abb83223263df6bcb" ON "registry_item" ("userId") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_22baca135bb8a3ea1a83d13df3" ON "registry_item" ("scope") `);
|
||||||
|
await queryRunner.query(`CREATE INDEX "IDX_0a72bdfcdb97c0eca11fe7ecad" ON "registry_item" ("domain") `);
|
||||||
|
await queryRunner.query(`ALTER TABLE "registry_item" ADD CONSTRAINT "FK_fb9d21ba0abb83223263df6bcb3" FOREIGN KEY ("userId") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE NO ACTION`);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(`ALTER TABLE "registry_item" DROP CONSTRAINT "FK_fb9d21ba0abb83223263df6bcb3"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_0a72bdfcdb97c0eca11fe7ecad"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_22baca135bb8a3ea1a83d13df3"`);
|
||||||
|
await queryRunner.query(`DROP INDEX "IDX_fb9d21ba0abb83223263df6bcb"`);
|
||||||
|
await queryRunner.query(`DROP TABLE "registry_item"`);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|