Compare commits
1555 Commits
2dbfb07008
...
6da09c3368
Author | SHA1 | Date | |
---|---|---|---|
6da09c3368 | |||
43c25b1f68 | |||
f13c5dcbaf | |||
2fcd090b11 | |||
4aa53beaea | |||
25a22ad3ae | |||
ae217ce27c | |||
17dea0aa5a | |||
bd142218c1 | |||
ce8d0b3b57 | |||
8f7edcef22 | |||
2f526f7a80 | |||
2780b3e3a4 | |||
2785b074f8 | |||
8a693fed37 | |||
6f5585ffd7 | |||
c9f6590353 | |||
3f1cac2251 | |||
3a8f1f6304 | |||
a5c265b6aa | |||
ea79782a93 | |||
882673c260 | |||
668bb3e6f4 | |||
7331e44a1c | |||
1ffdb19c8e | |||
5c62d91960 | |||
7615a3103f | |||
2ecdd683ac | |||
a9b78d1974 | |||
e6c23e69cc | |||
c81a47c764 | |||
4bbc1d84ce | |||
f7cb9ec504 | |||
28363a5416 | |||
f1be6d5181 | |||
b75fdbbd32 | |||
9ce2142d99 | |||
4f24247aa7 | |||
0eec20d203 | |||
adeb9af502 | |||
c577773e07 | |||
b8396daca2 | |||
eaddf5318a | |||
aee9a61fb1 | |||
81b5ed160b | |||
49b79d0457 | |||
8ce1797480 | |||
650aa089d9 | |||
2c689f2b73 | |||
aac5d41fd6 | |||
57187f26ae | |||
7446048d5d | |||
d3ee4d589b | |||
fda832cd83 | |||
30f31828ae | |||
cd7a663733 | |||
3b024450ff | |||
e22ef85386 | |||
e206175a50 | |||
76d469675e | |||
3496d3948a | |||
00b325d521 | |||
2077e00eae | |||
a1427a52b3 | |||
40a47b076d | |||
f041701765 | |||
d9bedbb473 | |||
013bba50bc | |||
5f0657a30c | |||
435b30be11 | |||
73863561d2 | |||
67696d08da | |||
1b00b91767 | |||
68c2bdb98e | |||
54852ecb56 | |||
8c4b2107b5 | |||
111df607bc | |||
b8b76e870d | |||
41c89abe68 | |||
24e7556f85 | |||
8cc7bad1ea | |||
2357385162 | |||
31b92b16ed | |||
3ad4ab2940 | |||
5ab81abaa6 | |||
1b651519a3 | |||
ba07172a65 | |||
72e045e744 | |||
2cedbae206 | |||
a6b033c4f6 | |||
dc96a72173 | |||
38141edbea | |||
9b0e243350 | |||
52cc8ab73b | |||
ea4e66c74c | |||
f4826bae52 | |||
7471513269 | |||
ae37c44cc0 | |||
424e219c53 | |||
bae7644d6f | |||
f2ccce05b8 | |||
89ffe6875f | |||
7284210bf7 | |||
4fcc92e532 | |||
2c259c5c6f | |||
39d25b9699 | |||
5df1ead001 | |||
2d4f28dcde | |||
dd55ba2d77 | |||
c9f7d9baff | |||
504a2e91e2 | |||
40e882004e | |||
e394a6b0fa | |||
8cf82a8449 | |||
0d922b75af | |||
ba0a8069c4 | |||
d37699bc08 | |||
ac087749e3 | |||
ddc9f5f595 | |||
35bba685fa | |||
e52fa44d3f | |||
f74d6f9ebb | |||
ae358cae4c | |||
b572b8989f | |||
5800a973cb | |||
44ce5471b3 | |||
e05b57cd5d | |||
ecdf8f2b47 | |||
1c5681c199 | |||
20fd25258a | |||
00bb538fd0 | |||
12bdbaaba8 | |||
821a135033 | |||
0ff37c0075 | |||
0a73050de1 | |||
a25dbf839a | |||
e16b6ee6e1 | |||
5c5d7eb04f | |||
fc3898fe64 | |||
71384e6f39 | |||
d95c9d28a8 | |||
bb7d25dfc9 | |||
d5c0f086bd | |||
892e0a5623 | |||
cb294cf411 | |||
9ad452a19b | |||
623a5be8a6 | |||
d1cd9a016e | |||
7d5d3b3c29 | |||
bcec6c5ab2 | |||
6384265cbd | |||
f12276eff8 | |||
c6160a1c38 | |||
07c20da08f | |||
4eefd0a205 | |||
78bc1359e0 | |||
1956c2ecfd | |||
ade2369b5d | |||
0d2ea97eb1 | |||
08fa51d0bb | |||
7d10518e94 | |||
1069cfb570 | |||
14e5b06029 | |||
1ea8a4042d | |||
fad55e0948 | |||
262ca4131d | |||
c7e0500529 | |||
686d0b6dbb | |||
59c27a6cbb | |||
e2cbe0983a | |||
3b0cc45588 | |||
061f43788c | |||
fe00a3893d | |||
5d4f72698d | |||
96ede22abb | |||
2cc8fcc4aa | |||
98900c33d4 | |||
7dc9a812f6 | |||
7a14d5f7e4 | |||
909d516ed4 | |||
52825cb4c4 | |||
dbc72adaf9 | |||
ba5a288b2d | |||
84043abbda | |||
f212888e90 | |||
50c0fd6738 | |||
5b5c9ddc74 | |||
cb992f693c | |||
ede41166ae | |||
caa7b6f326 | |||
0a6dff0618 | |||
9b4ade4542 | |||
0153c2a027 | |||
1a0f7c15ad | |||
d5bf306884 | |||
4cd2fde6f2 | |||
259e7876ad | |||
760c7deba3 | |||
83306949ac | |||
c0cd0dc74d | |||
f7b0a0bef1 | |||
a9d668cc78 | |||
15df9990da | |||
91ddb406ab | |||
d9d42105d6 | |||
7924085c94 | |||
672186e549 | |||
053dfb3e2b | |||
f1efb8d277 | |||
b6e958fdcf | |||
885b3a12b9 | |||
fc05daefb5 | |||
7faa42882b | |||
fc22a3e83f | |||
8ddc71188f | |||
b77a5c3eb4 | |||
6a6e2cd2a2 | |||
01c04fe2c2 | |||
e60f3e1a99 | |||
665316c14d | |||
fef14d96c7 | |||
c8087a7827 | |||
5a59dff817 | |||
e9554c32c9 | |||
d2f935df1d | |||
ed30d888fa | |||
606bd0be60 | |||
d29d7c40cd | |||
1e3cfca58d | |||
d6632bb0ea | |||
3fe4991fcf | |||
0c583574e1 | |||
7432e47f7a | |||
25f2ad1b97 | |||
391e41d6d6 | |||
cda1b91b77 | |||
50cc2be3d1 | |||
7c43b41f0b | |||
36313fe35b | |||
820674a7ad | |||
9bd8d974b3 | |||
9af5abaf0b | |||
25f45cf116 | |||
b948b2c7cb | |||
d2702dfe9c | |||
7397b38763 | |||
9e738253e7 | |||
120044f3da | |||
142a563a80 | |||
abd5768044 | |||
f1173853f3 | |||
ef8461733b | |||
b8f80a8d25 | |||
c19af39d8a | |||
e1381cfc5c | |||
efe1ea5c3c | |||
09edf251ee | |||
dcb6fa32a1 | |||
08ee1e1f63 | |||
b3e4b9675a | |||
0ee87b8116 | |||
1191024609 | |||
8f9de98c35 | |||
dc8b87e008 | |||
03e831b607 | |||
2e5046f8c3 | |||
7b638617f1 | |||
ec6ff7380e | |||
a0f7625c34 | |||
7e88b703d8 | |||
ad6976a407 | |||
39e1f2c0fc | |||
5a33a494e8 | |||
6389133575 | |||
919f97c9a0 | |||
e9f7ea0afa | |||
ee9a68e40c | |||
75b37fe376 | |||
3a2461322d | |||
550b4ce420 | |||
28a7884ad9 | |||
a7bdcc1216 | |||
7d3723592b | |||
075915e3b7 | |||
931c73d3c1 | |||
3263a0b98e | |||
586a221eb9 | |||
63b958dcc6 | |||
976ec30417 | |||
0c8c03153b | |||
23b247d1c3 | |||
dd534919d7 | |||
8fc51cf63e | |||
f6335590c5 | |||
a60910be69 | |||
f83f61f7ac | |||
0b93270d7b | |||
886e231091 | |||
4c402f6af4 | |||
a0dec23f2d | |||
591f54f64d | |||
5a89cecc5e | |||
540b2b74cc | |||
d19181016f | |||
13d1576dad | |||
6cea1c3472 | |||
893c2e4fd3 | |||
9daf83ce9b | |||
9075d7f37d | |||
7a13d8b8ac | |||
60b81bb6ca | |||
faa1cbeaf6 | |||
a12fbf7ff3 | |||
a2f4b4cd3d | |||
7150faa09c | |||
5acfff1152 | |||
921bf15419 | |||
36c37e0c62 | |||
3b1d636322 | |||
d4c16b8704 | |||
02123bda98 | |||
5dc49352e8 | |||
1fc1e478f8 | |||
3a60229e5c | |||
98de6ad464 | |||
1eeef896fe | |||
e8c256bcff | |||
a30b9e6927 | |||
728130908e | |||
5cd5fa8403 | |||
62975b0ef2 | |||
cc0b16c0ae | |||
43d5409937 | |||
ad15b7b256 | |||
61555657c3 | |||
dfce85a09f | |||
b48467c3f8 | |||
b515292b1c | |||
60e1427ffe | |||
b2dd95affa | |||
a04dc06aab | |||
0b84e0d056 | |||
83c187e3ac | |||
7a680dd9b7 | |||
5dedf5e500 | |||
43fa22470c | |||
6fd057fd00 | |||
e6036b8266 | |||
7e8aee61ba | |||
d2a74d1936 | |||
c4b85ef25a | |||
08738e6551 | |||
da02df20c3 | |||
6e830f7774 | |||
bbd3e75399 | |||
6cd0e1e35f | |||
1550ce2764 | |||
4aedf7f650 | |||
aba4a482f0 | |||
811a9f01bc | |||
2b8126b780 | |||
26f4532d47 | |||
16b12e1545 | |||
4e1263c1f8 | |||
93dd1b5973 | |||
31b88da9d5 | |||
da3d390187 | |||
67a9f6269e | |||
bc67be2b91 | |||
4132e7a468 | |||
25fecc1945 | |||
a077418af0 | |||
2e81803a52 | |||
fe39ead790 | |||
d385296e0d | |||
7ecf143e4c | |||
ffad9c523b | |||
21b16ef822 | |||
80103bef38 | |||
6c023f832b | |||
73df36ca72 | |||
523247f0fe | |||
89e7420237 | |||
16d0d17169 | |||
9592292dba | |||
bf80001c80 | |||
4e7f0f9f04 | |||
85eb09806f | |||
8fc96477e7 | |||
0c68a53e1e | |||
ad1389b20a | |||
1564c297bb | |||
5b516b1dbb | |||
e88cd16644 | |||
40a1263066 | |||
2588ac1a16 | |||
8d4a16a71c | |||
ba760bb340 | |||
86a27b51ad | |||
ac1ebac112 | |||
f4fddb2921 | |||
b26a5ce0fa | |||
6c1df6471a | |||
53c7da87a6 | |||
a609e545b6 | |||
4e3302ea0d | |||
4faa43766d | |||
bfc11495f3 | |||
46d34c53e6 | |||
2bb5785dfa | |||
cc5711b2df | |||
243bcba726 | |||
cb816bde66 | |||
04cdd3e8ec | |||
f23ecaff6a | |||
f9c484c642 | |||
d2feade9cf | |||
9b62ba6dfe | |||
d4a5a8051a | |||
b6e52849ca | |||
6a9cea4e78 | |||
1d5eda8d25 | |||
1f9536694c | |||
6bad4754e2 | |||
9d4a515571 | |||
82ab0c8504 | |||
5b169c908b | |||
2d73a4bc58 | |||
e38a699324 | |||
0426dacfad | |||
a0f6f2e73e | |||
bb2eda5c28 | |||
d1a28b4c20 | |||
b4a380e9de | |||
d7c757d63e | |||
1b13c76d2e | |||
1cc76937d7 | |||
da65f0bea7 | |||
a86cd93fb8 | |||
e15e17732d | |||
9024fc1226 | |||
8fbcdd371e | |||
fbcfa46beb | |||
6f1fcc9357 | |||
1f1cad322c | |||
769b73e8a3 | |||
3cfe7d61fc | |||
47b0302811 | |||
02dded6caa | |||
02a76cfcfd | |||
cbe6e1dbb3 | |||
c1b649af94 | |||
571339f530 | |||
7c7ebd9b86 | |||
7eb5a0775c | |||
d9c9ab6cee | |||
7c56cb3132 | |||
8de58aa39d | |||
0a0d2c98e8 | |||
62386e4c9e | |||
b88c557c6b | |||
0ec7991a20 | |||
7e6cdaf025 | |||
ed2f4fdcc2 | |||
d47335ccad | |||
d275760596 | |||
08eaedede1 | |||
303c9fb23f | |||
fb362f91ac | |||
0a4f0d616a | |||
33102a76da | |||
250ad8843d | |||
c2e4c0e1fa | |||
1cd729531d | |||
eae1affb21 | |||
f81192b4c3 | |||
747a15f0e0 | |||
14266a1ca4 | |||
541208a6bd | |||
113d72f59f | |||
b561f6ffd3 | |||
2643ca11e6 | |||
35e3e912df | |||
0b95f39c22 | |||
67f57a7f90 | |||
dc9658f532 | |||
b1e6a53692 | |||
9743d2f40c | |||
7d69d1b402 | |||
708d3892a7 | |||
b16e8fdb58 | |||
dc7cdc3252 | |||
e22e58f5b8 | |||
a120debac6 | |||
1301730ed8 | |||
4f37f68bd7 | |||
0d6974a6d2 | |||
5a844cd31e | |||
e0686ac1d9 | |||
914d4506e2 | |||
0df88fd5a0 | |||
085fb95ce3 | |||
f430e06f80 | |||
8827d4c142 | |||
9b73189e1d | |||
0aa49510b2 | |||
691e0dd44a | |||
8e91db7fb1 | |||
2e0c550ee7 | |||
be2e715eb1 | |||
7b1b3fe8cf | |||
49819b64db | |||
5e27b5790c | |||
be64528b4f | |||
8db7343dda | |||
ce06f7d783 | |||
cb91800088 | |||
8386768708 | |||
3b96690d0c | |||
c4c3976c8c | |||
5cd85d9bb7 | |||
f2e90e91e0 | |||
5971334ec7 | |||
6c7dee4bcd | |||
a3bfaf6336 | |||
e99c916df1 | |||
c09d794ed8 | |||
05ffc8b0d7 | |||
7bf7744efb | |||
e87c79780a | |||
cfff24518e | |||
6e523beec3 | |||
f93192bc28 | |||
e0fb149466 | |||
46bd4d71d0 | |||
32651f7811 | |||
c666cebe60 | |||
f3e47bd899 | |||
09d72ffb16 | |||
120b60c5ee | |||
f5337904e4 | |||
9fb493bf18 | |||
c6221872e2 | |||
752172ab54 | |||
d52d6a9e41 | |||
61035d5007 | |||
405db86750 | |||
b8b1b7bb84 | |||
c56b915dee | |||
43fa4b457d | |||
1ca7118027 | |||
364a5e99db | |||
a4c36afcc2 | |||
62f3598c25 | |||
bb97539a28 | |||
46b1b66dbf | |||
cbe4b60a90 | |||
de807e6378 | |||
67f727e3b3 | |||
8ff54c2eba | |||
74990093fd | |||
077c9ff0c9 | |||
3b3d0231bc | |||
fb19176201 | |||
838c73cbba | |||
332ab6641c | |||
3c35dbcb5f | |||
f514c2caf0 | |||
281dd91e6a | |||
045085c92c | |||
56cfc57641 | |||
3f971f6dec | |||
37188c76b8 | |||
c649230982 | |||
5c6ac25945 | |||
4a5014eab5 | |||
4d7c5f5672 | |||
b3d7dfb9a5 | |||
ca366e5437 | |||
5c3227ac4c | |||
a569068fb0 | |||
27c8990aea | |||
f3f0859e0b | |||
379c84b7ab | |||
ce5aa016e1 | |||
199ac64202 | |||
4277b0c3aa | |||
02afde3eec | |||
0279b3dee9 | |||
6fa7b45294 | |||
c07ce083d1 | |||
08d06064ce | |||
2b8a71231e | |||
ffbab95c20 | |||
5479618f1c | |||
ced14a73d7 | |||
3f6760dc0d | |||
e0d992f452 | |||
676ce83dab | |||
fc00bf13bf | |||
777d0d45c6 | |||
ba3dacdbde | |||
80796a87c7 | |||
571f95546a | |||
bcb75d65a3 | |||
118d736aa9 | |||
98f99c536e | |||
dcd47c391c | |||
c8a3fea091 | |||
6adf76c689 | |||
9901d82fea | |||
170998da1a | |||
5cf71baf55 | |||
64e56fd97c | |||
2db2f280d5 | |||
cad4b2f7b8 | |||
518c463761 | |||
21227453e5 | |||
d493946ba4 | |||
581b96c32f | |||
27f3f62082 | |||
500feedc43 | |||
fc0703005d | |||
57020d406f | |||
1dfb0ce81c | |||
d45e9d6af2 | |||
43f9be367f | |||
e2891a660a | |||
7345e3af69 | |||
2cb0027f56 | |||
64cdb6ee80 | |||
98f26cb9d6 | |||
72817daa3b | |||
dbc9efd62b | |||
e088bb722b | |||
917b801eb6 | |||
0dbb864d7d | |||
9bf7529dda | |||
3d97170ad0 | |||
dc69116572 | |||
58a8ce0420 | |||
dbda317c6d | |||
2f1ec8e144 | |||
00395118f9 | |||
c261bf8759 | |||
5afa4fa838 | |||
a1b5ec94fb | |||
f5f18518da | |||
9d93eaf810 | |||
4ae78e7ed6 | |||
35a726a961 | |||
89e105afbe | |||
9692f0614d | |||
b58cabdc41 | |||
0ba3fe3b2a | |||
246acb8646 | |||
da9baf2be8 | |||
35de254bd2 | |||
58e5f0d9c5 | |||
5b2b73da92 | |||
f5091110c2 | |||
9e47cde90c | |||
ec16e7c0e6 | |||
5ae0331993 | |||
0f33c53d5c | |||
e75a87a581 | |||
44b53fd00b | |||
99bab9881d | |||
aa8b02caf8 | |||
19c5667d9f | |||
c88267f858 | |||
6de1676337 | |||
d6c54badb8 | |||
21cb18fb4b | |||
1972762500 | |||
1dd48e4a8b | |||
04cb1b130a | |||
c5306dcec8 | |||
7c0b5be70f | |||
8b02c28547 | |||
c222775bdb | |||
5a79111fab | |||
d77bebe843 | |||
1208163ba0 | |||
acf8049327 | |||
202e86199e | |||
746ffe1cef | |||
cca29aab4a | |||
8d3389aebd | |||
38ff790bef | |||
eaff54c4e3 | |||
7ae59a53ed | |||
a7ab14b3b3 | |||
90e05fd835 | |||
4e6719c586 | |||
3f2b0b9422 | |||
c98fcaeebb | |||
c05b7fe60f | |||
7562ff0e64 | |||
b660e312b7 | |||
74b4eddcf7 | |||
cb99227569 | |||
29cd461132 | |||
2abae3d273 | |||
e584d3188c | |||
1ede164450 | |||
cb7643a74e | |||
67a6bc3ea9 | |||
094b219581 | |||
58b119250a | |||
994e9cf346 | |||
404e937872 | |||
20b095c7c5 | |||
104ce7c64f | |||
7371070cde | |||
b0978d0e37 | |||
77ccd7201b | |||
308401b9e5 | |||
9faad72ec0 | |||
31c1928789 | |||
a7c985a590 | |||
dd3a61c725 | |||
d7d3dc679c | |||
8e05c282b1 | |||
40eb9578e7 | |||
30d2d93494 | |||
b4121cb6fd | |||
4d4f352ed9 | |||
4eea232581 | |||
5b8f307d4c | |||
4e5041af13 | |||
c664907dbf | |||
bb69b916a8 | |||
999c56a284 | |||
7e22b7090e | |||
f5837b77d6 | |||
c7739ef9c4 | |||
35cf140cb2 | |||
8ce516ae9f | |||
a1947d2bb1 | |||
2468a3736d | |||
d454aafe7e | |||
9648d88fb1 | |||
7ebf4d51ca | |||
4a90394c38 | |||
309844e6d8 | |||
d063bc3ed3 | |||
e0304d2999 | |||
7feeffb245 | |||
f4dd54a808 | |||
3e8f977ef0 | |||
4c9417ff70 | |||
c6348a2e4a | |||
c88b1c0197 | |||
004e87c986 | |||
f56054ecc1 | |||
e4a37f344e | |||
d05fbe6e45 | |||
03839fc0fe | |||
a20cdbd5c7 | |||
3dd34619ec | |||
df791c7e54 | |||
1cd4f705fd | |||
1c67be8db0 | |||
eee0a32d03 | |||
2cd18fd4bf | |||
45c63baa5c | |||
b85a2709e8 | |||
bc4b036c76 | |||
d03506df51 | |||
4de03b0c11 | |||
32c60bf2d0 | |||
32ac54d830 | |||
4bcf5e07c0 | |||
3ca277e2b2 | |||
f3f148a0db | |||
c711208237 | |||
3a7fc22f51 | |||
54b9a0320b | |||
a5fb1e53a9 | |||
a1fb0f848c | |||
3f9783f288 | |||
e99fcfddb5 | |||
f19cd54195 | |||
938b2bae23 | |||
4a67771bfa | |||
b1cf8ee4df | |||
fce82deabc | |||
e0d4646c18 | |||
be394b573d | |||
7ca25b7297 | |||
b29a68d467 | |||
1f7b6a63bb | |||
3a42849759 | |||
e6855d3125 | |||
c98a0a99a6 | |||
a0da13cf6b | |||
8bf4408e64 | |||
bf5e2facb4 | |||
e558a83783 | |||
d1eb1ec0f4 | |||
19529e2aa1 | |||
71ec402adc | |||
aeba70f2a6 | |||
47c15d330f | |||
407f46c043 | |||
35991bc0e1 | |||
d658908abe | |||
12337be827 | |||
38c599d681 | |||
2eb7de84df | |||
42919a2be3 | |||
6459614f34 | |||
89adffe72e | |||
9e11b0e317 | |||
e6f8f8520c | |||
a6bbbd738f | |||
62012286a0 | |||
f4591b2cc7 | |||
c7f1c30f89 | |||
1031bc1801 | |||
b864d87344 | |||
9526daa5b7 | |||
5d428ac8af | |||
035c9dbfa7 | |||
1b9ec3a214 | |||
eb583330df | |||
0a91484fa0 | |||
696c56b6be | |||
6a2ca1a6b6 | |||
7486ebdc10 | |||
7f846f153d | |||
9e71610711 | |||
f70a64891c | |||
de28a375c8 | |||
4ce3b27e65 | |||
48be5a534d | |||
dd851c8eeb | |||
ee6061d3dd | |||
67a6899ed7 | |||
9898e5483a | |||
08b45a32a5 | |||
1723aa0697 | |||
19e3e49fdc | |||
1d49fdbd8d | |||
2673c667b5 | |||
b4afb5fa5b | |||
6736187be6 | |||
4b2e920957 | |||
45efa4ec87 | |||
947ad55185 | |||
c5506577d0 | |||
622cdeaad6 | |||
cd9fc0ddec | |||
bffbde4639 | |||
36eced28b8 | |||
2eab25e7c1 | |||
298973a7e3 | |||
1506068f7c | |||
c31c264b0b | |||
2c297da755 | |||
f37dd2cbc6 | |||
51ad2f522a | |||
0c82974986 | |||
8968c63fcc | |||
e22df99abd | |||
6ec6c6e317 | |||
c4870a16d4 | |||
302eed95f7 | |||
560e297274 | |||
35e15a13fb | |||
d1e6a16cde | |||
b8ead0539f | |||
182a3a4663 | |||
6c9d3d42d3 | |||
710f9eecb2 | |||
df48ae8e00 | |||
8ac6d0ef04 | |||
ee0f8cd3c9 | |||
e63092c708 | |||
2636b19171 | |||
30587f09b5 | |||
dd504f522f | |||
af3151d4db | |||
ec9345efa6 | |||
5bc466de55 | |||
695fc58187 | |||
c6af5266cd | |||
02b26f5969 | |||
4ab03594cb | |||
fc3dad8cea | |||
099141e0e5 | |||
f1f92ccc29 | |||
3c7725183e | |||
f42861c58d | |||
5747518ada | |||
4796bafafe | |||
b5df3cb104 | |||
b3097da6f9 | |||
31c8256bc6 | |||
97fbf70fa6 | |||
3f6480c127 | |||
134cbacf31 | |||
36a83d13f8 | |||
428884c621 | |||
22e0bb58d9 | |||
7e0923d53f | |||
3e7c1f0bd7 | |||
5b6e29b70a | |||
9003bcf981 | |||
ed24d06e0c | |||
bc3bdf3cb0 | |||
b60bbca8e4 | |||
174fa49b23 | |||
a82127092b | |||
63df9ffe2f | |||
eda9ea962d | |||
fbded95f65 | |||
36f8162793 | |||
268d441c48 | |||
aae5f006f9 | |||
6a86eeda10 | |||
5d6e02bef3 | |||
73e9190ce7 | |||
eb50618fe8 | |||
ec61cdac83 | |||
6adbdfc107 | |||
3596b5e165 | |||
b8208974a4 | |||
0a13d7625f | |||
2911895cdb | |||
e81d775791 | |||
e45dbc9f6d | |||
705b2d4c41 | |||
1df5003643 | |||
753702da0e | |||
163a85c78f | |||
e01040a2e8 | |||
6d009a3e0f | |||
3333d4af88 | |||
5004471770 | |||
4462ad6bf0 | |||
1052f6fde0 | |||
86cba639fc | |||
8640afc82e | |||
4376eedb96 | |||
b42373d834 | |||
f95f846ef8 | |||
9cbad559a1 | |||
557ef9acc9 | |||
3a90e0f7f2 | |||
93a3c6ee59 | |||
51905cee45 | |||
409f27c058 | |||
eea07a8e6d | |||
cb7b92282c | |||
cf5beafec0 | |||
008c8dbf36 | |||
3c20ffc22b | |||
cfe159235a | |||
5704a433f0 | |||
0c83cbffe3 | |||
05f2cf9202 | |||
cc61f7b160 | |||
6197ae3fe0 | |||
298cf77a57 | |||
22e960d8f8 | |||
8378edc95f | |||
58a8169189 | |||
1b72a1e72d | |||
6422892efc | |||
2ee28e2db2 | |||
f8a1b7ea56 | |||
0183d33261 | |||
1abd9d2ee2 | |||
bb654d6e34 | |||
4b161b0d65 | |||
a06e6c7f47 | |||
17d7432f0e | |||
405161998e | |||
78e9ee651f | |||
9dfe39b83d | |||
ed9d20b291 | |||
9f2d2d4ac1 | |||
e6a4467557 | |||
34521c228b | |||
6503016676 | |||
0840086a0a | |||
afb6913a2f | |||
e7d65f2d12 | |||
e84a7e8c2a | |||
ad414f33c9 | |||
bb64d08eaf | |||
6057146a41 | |||
e9f2b828d8 | |||
9d86ef767a | |||
9a4f2a4492 | |||
a3fa8ec29a | |||
70aacc8a5e | |||
b54005c540 | |||
badf0dd57f | |||
a2a1d852e9 | |||
5e1c292927 | |||
ae33a6bce1 | |||
82684cd6cd | |||
84b38beb9a | |||
b2758f2cdd | |||
e014729206 | |||
6ba26e65b8 | |||
ea4c597ac4 | |||
56fb9be0f7 | |||
642baa1f2a | |||
960171c4e0 | |||
d165a96220 | |||
46180d7d5b | |||
81279dad9e | |||
e424b7bacb | |||
da1416c07f | |||
94e3dde2e3 | |||
dd7bea4bd1 | |||
ce16cd12ec | |||
d081f8e80c | |||
06818a96c3 | |||
1dbc9bd472 | |||
c4657c4661 | |||
86141eb363 | |||
fad760f46a | |||
3cc469c0b7 | |||
fc5e60e97b | |||
3e314d2fc6 | |||
9f23bee6e4 | |||
c822baa9c6 | |||
2164787499 | |||
7c6d872964 | |||
aa429be4d9 | |||
72dbc7377b | |||
a8a9f93e09 | |||
c66e841c38 | |||
1f5b66838d | |||
2db0913889 | |||
2f95ad77e6 | |||
508d84b2b7 | |||
fac76a33df | |||
073da9735d | |||
c9f74cc55f | |||
42e22ed91b | |||
1ec8b62b58 | |||
e153787ac7 | |||
a862c4255b | |||
48c745fbbd | |||
63921ccfca | |||
5056c95d60 | |||
00eb6b01ff | |||
a2f119e18e | |||
d68572ea44 | |||
9ed97caf7b | |||
df69573fee | |||
6d0a4da888 | |||
2b5b5eab4e | |||
b00c2070d7 | |||
75ca10896c | |||
a1f6e6e871 | |||
ae3925bba5 | |||
e96bb4c5e6 | |||
371309e775 | |||
f1fa1f0b62 | |||
e81c911b49 | |||
02084331e3 | |||
bb4ec093ad | |||
04e47660f4 | |||
e731ea58d5 | |||
e038890bb7 | |||
aa6eb7fcf1 | |||
14ae901ba1 | |||
a74212c3af | |||
a923a79b46 | |||
20141026d1 | |||
7b26c08dff | |||
54aea9dbee | |||
1530209266 | |||
229e7dcee5 | |||
c6c4d93b3b | |||
fe2e00f861 | |||
ebbe8f98b7 | |||
6ce160ef0b | |||
3452699750 | |||
88235fbc6c | |||
c836b0ee8d | |||
8c9e4c46a0 | |||
8452d3fdf2 | |||
aa39f3f482 | |||
30a7f93685 | |||
8050389d32 | |||
d395de3aa1 | |||
113436afd5 | |||
f159c9938d | |||
f9740e180e | |||
ab235e24ad | |||
19dfdbc03f | |||
d1c00cf1f6 | |||
52db2b3da1 | |||
b5f184388a | |||
72b68abe7f | |||
9d6166d7d6 | |||
e9e5bb12b9 | |||
2c308d300a | |||
dbf863fbd2 | |||
5cc1f87511 | |||
9f027df909 | |||
013aee01f5 | |||
41919bdaea | |||
97e3ff1901 | |||
6288b5cc51 | |||
5d457f99e7 | |||
7e73283949 | |||
3f6901fd82 | |||
692a633dc8 | |||
9cbd0c34a7 | |||
97c519990b | |||
129f63cf11 | |||
b4e332ccdc | |||
067d72ec85 | |||
ed2e1de008 | |||
c1895e7f85 | |||
6b131a3985 | |||
8b4309f117 | |||
f7170343f7 | |||
196219383e | |||
41f3cbf727 | |||
bcfe5fee2d | |||
98c4a22580 | |||
5fee309797 | |||
4df7faef6d | |||
6c42371d37 | |||
21c7c28447 | |||
595508a91f | |||
64c8c2afdf | |||
c5ef0cfe20 | |||
a275f0a719 | |||
7220027332 | |||
d3231c7a7d | |||
e5978d74c7 | |||
8b26d488ad | |||
140ac947b5 | |||
7fd1f1424a | |||
508be7a742 | |||
e68f781f9d | |||
573050c6ef | |||
52e925559e | |||
3c84a22b32 | |||
53bd34ed8d | |||
5ddc9d2c09 | |||
9e0090c068 | |||
5f0a3d392a | |||
ee8cf83722 | |||
68b9a9796c | |||
4ad3cc2cc1 | |||
990b65b859 | |||
cfc639ffe4 | |||
30d10c60d2 | |||
fdaff43039 | |||
ca32134830 | |||
63c8a90880 | |||
9ec7925ec5 | |||
15fc205d04 | |||
837c2dd24a | |||
3d6dae7774 | |||
e186395198 | |||
5144654067 | |||
f2d8650d36 | |||
705deadef8 | |||
b5a2fb5492 | |||
59a822ee87 | |||
5c166be3fc | |||
5c26ba5f5d | |||
35995633ae | |||
64b5f93a6a | |||
059a111282 | |||
6ed440718d | |||
7ee07535f5 | |||
9066a6133c | |||
350999fcca | |||
667f384bfc | |||
75c4cc70c6 | |||
4dbb7dd3da | |||
24d2d0481a | |||
5f832cb75a | |||
86b6be0668 | |||
06a1db4f24 | |||
2bc0abbc50 | |||
ff6d14a022 | |||
38d09084a3 | |||
f842e7b813 | |||
70f2489710 | |||
ddc3c0db03 | |||
ba98327463 | |||
15d24a77c7 | |||
f2c1ecd19b | |||
6fa7c23bb9 | |||
b659aa5c0f | |||
f667d6dd25 | |||
25f6f7a406 | |||
9a50101bbd | |||
4a348f8bca | |||
57ab2a4294 | |||
c55d70b6d4 | |||
ac99ab55c5 | |||
3d13db1f2c | |||
0219d200a5 | |||
76cc8eaff8 | |||
e9861b11f3 | |||
1edb7b6464 | |||
3cf9edf7cc | |||
544ce206d7 | |||
6ecc9c4cba | |||
156e3fa101 | |||
a670d478f8 | |||
4c6334ea13 | |||
9bbb55b2bb | |||
2ba3069b07 | |||
63f5d94a02 | |||
96d2cddb54 | |||
fe48fcf9de | |||
b79c2e8d71 | |||
38f04616d2 | |||
e31d90eadb | |||
7e971a2ec6 | |||
ff7e31ab9d | |||
b218a7f218 | |||
d3cc999866 | |||
4097808b95 | |||
12d6080a48 | |||
f59e11281c | |||
3c1a3b1091 | |||
dad3404ac5 | |||
5d7985dcff | |||
18c078f8c2 | |||
ba967386f4 | |||
cc5c3426fe | |||
2183c5e60c | |||
0985ddb3ff | |||
f879b2c9bc | |||
66b7253986 | |||
b5f33124be | |||
7faba0de5e | |||
735835193d | |||
07cdc1fc97 | |||
32e6126552 | |||
09a612670a | |||
a87de6cdaf | |||
9c23a4511d | |||
a966993c54 | |||
1b7075aebb | |||
a2fce0e89d | |||
1d556b78c1 | |||
d8333af805 | |||
3cda8b65cd | |||
794378ed29 | |||
241624027f | |||
0a45bdd3b7 | |||
97aecc8fc1 | |||
a6449da557 | |||
41bc148040 | |||
858151807f | |||
93fa957921 | |||
911ed3d6ba | |||
d9ab0bb60d | |||
8fcdd87473 | |||
eff605b1f3 | |||
a905cdfd09 | |||
33b8680dfd | |||
d0a2357fbd | |||
762bd7a847 | |||
6478b5ba5f | |||
3a98b958d3 | |||
bf2c19b2e0 | |||
cc7fce3d36 | |||
f984e385c8 | |||
ecfbf317ae | |||
6f9e15ea57 | |||
13cb8bb395 | |||
7ad8894871 | |||
737422330a | |||
639d160c24 | |||
91effb3576 | |||
367d9149aa | |||
6bcf5cb823 | |||
06df62a2b5 | |||
4073400bfb | |||
e231907b3c | |||
8ee58aaf18 | |||
bed13f71bd | |||
5291401de0 | |||
0c6efe50c3 | |||
acf52a9783 | |||
9ff89a970a | |||
bbfec06a3d | |||
9f18222a06 | |||
8835cd6c3b | |||
5c8708f4c9 | |||
8cc9471a7b | |||
8ed94037d5 | |||
58f56c7d7d | |||
f2c02a79b9 | |||
b0fe1927d5 | |||
7a556d1588 | |||
532a46d188 | |||
8d9e0b4eae | |||
8c06f96531 | |||
148c1c7e1a | |||
e53b875e79 | |||
3111c2fd5c | |||
f1da323b07 | |||
e73a94e7d6 | |||
0ecdb0252a | |||
9e434c15dc | |||
e468870e87 | |||
7e8a44c15b | |||
592e829347 | |||
e5b887b462 | |||
8d49ea29d2 | |||
00ddc9cfd7 | |||
51b128c678 | |||
bb98046846 | |||
28d55c8c5d | |||
407e6389b3 | |||
98e50a49f0 | |||
6fd4839441 | |||
61af2e8006 | |||
4a5abd1527 | |||
db1dc143f1 | |||
9e726eadee | |||
60c7bc90e6 | |||
aee420152f | |||
f0563df991 | |||
15eb840792 | |||
8cfac0b02a | |||
7538f6a346 | |||
579b7065bd | |||
ede8896721 | |||
cba656383e | |||
26aa38341f | |||
d84866cf8c | |||
e659a03140 | |||
bcd2b1c523 | |||
54033b5e5a | |||
d440b9a63f | |||
3a0c18713e | |||
447f9daa9f | |||
8dbbf882a8 | |||
bca6abf4ab | |||
903ecc2a76 | |||
5c57d8de20 | |||
93af6f0564 | |||
527622df4a | |||
a9178e6982 | |||
bd455e75c0 | |||
7e322c21b3 | |||
c3075d3eba | |||
1b4eaa6a10 | |||
ddeef9387f | |||
7bfc3c0ae0 | |||
0ac247550b | |||
e92d25a258 | |||
e9699b8e55 | |||
82f3e4ad86 | |||
89a31e43b2 | |||
14b76e48f0 | |||
7315048474 | |||
0ea93bfba1 | |||
b4d2d0dd31 | |||
fd055193ac | |||
01bbf40418 | |||
08dafd6d70 | |||
8bb33dccd1 | |||
ff092833ae | |||
8b5a49fb5c | |||
4a645bec27 | |||
f87c105518 | |||
81d2d4b70e | |||
3624792bd6 | |||
b3f8c0e0c3 | |||
248148af99 | |||
91d63213ae | |||
451ba407d7 | |||
52c062adb6 | |||
f604185b10 | |||
c822d5fa94 | |||
1359b171af | |||
2f7789e397 | |||
6fd76829b0 | |||
3748adf2fd | |||
37131a6785 | |||
969becfc15 | |||
c312d11dab | |||
76de49a25c | |||
d29a84ae46 | |||
a39029f953 | |||
767629ed2c | |||
55ff23c6c3 | |||
66353e6117 | |||
f991b553ce | |||
4f62ab6168 | |||
300825dcac | |||
b9bb525fe9 | |||
e95c678141 | |||
fba4a70dc2 | |||
9f943650a9 | |||
f20caf4c3a | |||
31a3c7cf50 | |||
6e2ab6c3af | |||
9678618dd4 | |||
6ac734d39d | |||
706444bdb2 | |||
31fbe70ec7 | |||
ef309cbcd3 | |||
755bbac496 | |||
f68dd99518 | |||
00cd346255 | |||
f693032109 | |||
5fbdcd4a26 | |||
037dac988e | |||
508d1923f1 | |||
fc1a857045 | |||
d2efdbd7ab | |||
1407a2883c | |||
3e1c280a3c | |||
a35f281123 | |||
58573fe329 | |||
dc28a65e21 | |||
394a351784 | |||
9f1c93eb91 | |||
c5a52271df | |||
1f63fe96c5 | |||
283a33715f | |||
23992c31c6 | |||
302619a5de | |||
cab469621d | |||
f6b9f8d476 | |||
582e05fcff | |||
d2b02d07b4 | |||
8d5876d5f2 | |||
7edaeb215d | |||
8c0a19755c | |||
e562dbd59c | |||
40783db161 | |||
9f9898d47a | |||
420bd9bcf9 | |||
6a5266c6b8 | |||
ff1409e626 | |||
30ce6f1ed3 | |||
f9f85e3865 | |||
201d5ac364 | |||
0da2391c49 | |||
b731f8a0ad | |||
968c935bf7 | |||
2bdb492834 | |||
031ef6a05a | |||
05a324fba4 | |||
8a50101eea | |||
8a6ff014d6 | |||
75f8b3374e | |||
3951a77318 | |||
4f6c1ec556 | |||
4c3f2441f7 | |||
721ffcfe06 | |||
0af73775be | |||
6d911a8f39 | |||
353be860b7 | |||
db3604b479 | |||
ad225e4cff | |||
1f06089e5e | |||
2468089d70 | |||
Jonathan Lamothe | 32755444ed | ||
d0b8d78cad | |||
818a7fb451 | |||
5386180c0b | |||
2632875bab | |||
993d45d2f5 | |||
80afe13a26 | |||
c5a4a07a55 | |||
99a92db0aa | |||
d4b25cb3ff | |||
e9a8882f84 | |||
241c221e4b | |||
01632b11c7 | |||
14b83def60 | |||
24e7605c60 | |||
ed6a537dc5 | |||
70540e59e1 | |||
50988bf5f1 | |||
09ce625d50 | |||
ae45a177a5 | |||
3e3f48e5ec | |||
8ec3f17138 | |||
e8a2dd285b | |||
e9b9058e16 | |||
60211fdd8d | |||
f3ad2c4ad9 | |||
a7cce4013c | |||
141c55fe7f | |||
7b3e8767ec | |||
ab29f91c2d | |||
dfaa4b89c7 | |||
b5a1f13d7c | |||
fc600b2dbf | |||
ec7e295158 | |||
94933daf14 | |||
1906ed00ae | |||
5b9db55e81 | |||
483cc45712 | |||
9278c79917 | |||
921e070b22 | |||
3f80b7a7eb | |||
3385147f25 | |||
03bebf57c5 | |||
7d9d1ce65d | |||
bfefca0cb0 | |||
7f5381165e | |||
bd7760a860 | |||
d3e872b06b | |||
64027f9dbc | |||
14a6fb61a9 | |||
13b6a80d5b | |||
d46b8e69b3 | |||
2fc7c9f064 | |||
649bbaa4c3 | |||
d971a2cc5c | |||
f5433b25d8 | |||
4246ffc892 | |||
9d69045a89 | |||
33da0c196a | |||
0a738c8ce3 | |||
fc09017dd1 | |||
70674f2ecc | |||
1129e8f17d | |||
b12e4f711f | |||
a42ddafbbb | |||
89b6c4c73f | |||
50164b65ea | |||
34d3c51e93 | |||
4f7740264e | |||
4f6e02357a | |||
18351a4439 | |||
68c0408af5 | |||
5966f0cc62 | |||
332b6f21ca | |||
7e03072082 | |||
f98cb3a5df | |||
cee8dc2a3b | |||
7b02585b97 | |||
5b23c1c67f | |||
ae99f82c28 | |||
ced6680c6a | |||
fa37537762 |
|
@ -1,7 +1,7 @@
|
||||||
name: my-friendica
|
name: my-friendica
|
||||||
type: php
|
type: php
|
||||||
docroot: ""
|
docroot: ""
|
||||||
php_version: "7.3"
|
php_version: "7.4"
|
||||||
webserver_type: apache-fpm
|
webserver_type: apache-fpm
|
||||||
router_http_port: "80"
|
router_http_port: "80"
|
||||||
router_https_port: "443"
|
router_https_port: "443"
|
||||||
|
@ -17,7 +17,7 @@ use_dns_when_possible: true
|
||||||
composer_version: "1"
|
composer_version: "1"
|
||||||
web_environment: []
|
web_environment: []
|
||||||
nodejs_version: "16"
|
nodejs_version: "16"
|
||||||
webimage_extra_packages: [php7.3-gmp]
|
webimage_extra_packages: [php7.4-gmp]
|
||||||
|
|
||||||
# Key features of ddev's config.yaml:
|
# Key features of ddev's config.yaml:
|
||||||
|
|
||||||
|
|
|
@ -19,7 +19,7 @@ robots.txt
|
||||||
/doc/cache
|
/doc/cache
|
||||||
|
|
||||||
#ignore reports, should be generated with every build
|
#ignore reports, should be generated with every build
|
||||||
report/
|
/report/
|
||||||
|
|
||||||
#ignore config files from eclipse, we don't want IDE files in our repository
|
#ignore config files from eclipse, we don't want IDE files in our repository
|
||||||
.project
|
.project
|
||||||
|
@ -33,7 +33,7 @@ report/
|
||||||
#ignore NetBeans IDE's private files (at least)
|
#ignore NetBeans IDE's private files (at least)
|
||||||
/nbproject/private/
|
/nbproject/private/
|
||||||
|
|
||||||
Ignore config files from VSCode
|
#Ignore config files from VSCode
|
||||||
/.vscode/
|
/.vscode/
|
||||||
|
|
||||||
#ignore smarty cache
|
#ignore smarty cache
|
||||||
|
@ -83,8 +83,9 @@ venv/
|
||||||
#Ignore temporary installed phpunit
|
#Ignore temporary installed phpunit
|
||||||
/bin/phpunit
|
/bin/phpunit
|
||||||
|
|
||||||
#Ignore cache file
|
#Ignore cache files
|
||||||
.php_cs.cache
|
.php_cs.cache
|
||||||
|
.php-cs-fixer.cache
|
||||||
|
|
||||||
#ignore avatar picture cache path
|
#ignore avatar picture cache path
|
||||||
/avatar
|
/avatar
|
||||||
|
|
|
@ -0,0 +1,93 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
$finder = PhpCsFixer\Finder::create()
|
||||||
|
->in(__DIR__)
|
||||||
|
->notPath('addon')
|
||||||
|
->notPath('bin/dev')
|
||||||
|
->notPath('config')
|
||||||
|
->notPath('doc')
|
||||||
|
->notPath('images')
|
||||||
|
->notPath('mods')
|
||||||
|
->notPath('spec')
|
||||||
|
->notPath('vendor')
|
||||||
|
->notPath('view/asset')
|
||||||
|
->notPath('lang')
|
||||||
|
->notPath('view/smarty3/compiled');
|
||||||
|
|
||||||
|
$config = new PhpCsFixer\Config();
|
||||||
|
return $config
|
||||||
|
->setRules([
|
||||||
|
'@PSR1' => true,
|
||||||
|
'@PSR2' => true,
|
||||||
|
'@PSR12' => true,
|
||||||
|
'align_multiline_comment' => true,
|
||||||
|
'array_indentation' => true,
|
||||||
|
'array_syntax' => [
|
||||||
|
'syntax' => 'short',
|
||||||
|
],
|
||||||
|
'binary_operator_spaces' => [
|
||||||
|
'default' => 'single_space',
|
||||||
|
'operators' => [
|
||||||
|
'=>' => 'align_single_space_minimal',
|
||||||
|
'=' => 'align_single_space_minimal',
|
||||||
|
'??' => 'align_single_space_minimal',
|
||||||
|
],
|
||||||
|
],
|
||||||
|
'blank_line_after_namespace' => true,
|
||||||
|
'braces' => [
|
||||||
|
'position_after_anonymous_constructs' => 'same',
|
||||||
|
'position_after_control_structures' => 'same',
|
||||||
|
'position_after_functions_and_oop_constructs' => 'next',
|
||||||
|
],
|
||||||
|
'elseif' => true,
|
||||||
|
'encoding' => true,
|
||||||
|
'full_opening_tag' => true,
|
||||||
|
'function_declaration' => [
|
||||||
|
'closure_function_spacing' => 'one',
|
||||||
|
],
|
||||||
|
'indentation_type' => true,
|
||||||
|
'line_ending' => true,
|
||||||
|
'list_syntax' => [
|
||||||
|
'syntax' => 'long',
|
||||||
|
],
|
||||||
|
'lowercase_keywords' => true,
|
||||||
|
'method_argument_space' => [],
|
||||||
|
'no_closing_tag' => true,
|
||||||
|
'no_spaces_after_function_name' => true,
|
||||||
|
'no_spaces_inside_parenthesis' => true,
|
||||||
|
'no_trailing_whitespace' => true,
|
||||||
|
'no_trailing_whitespace_in_comment' => true,
|
||||||
|
'no_unused_imports' => true,
|
||||||
|
'single_blank_line_at_eof' => true,
|
||||||
|
'single_class_element_per_statement' => true,
|
||||||
|
'single_import_per_statement' => true,
|
||||||
|
'single_line_after_imports' => true,
|
||||||
|
'switch_case_space' => true,
|
||||||
|
'ternary_operator_spaces' => false,
|
||||||
|
'visibility_required' => [
|
||||||
|
'elements' => ['property', 'method']
|
||||||
|
],
|
||||||
|
'new_with_braces' => true,
|
||||||
|
])
|
||||||
|
->setFinder($finder)
|
||||||
|
->setIndent("\t");
|
|
@ -6,6 +6,7 @@ require_once __DIR__ . '/bin/dev/php-cs-fixer/vendor/autoload.php';
|
||||||
|
|
||||||
$finder = PhpCsFixer\Finder::create()
|
$finder = PhpCsFixer\Finder::create()
|
||||||
->in(__DIR__)
|
->in(__DIR__)
|
||||||
|
->notPath('addon')
|
||||||
->notPath('bin/dev')
|
->notPath('bin/dev')
|
||||||
->notPath('config')
|
->notPath('config')
|
||||||
->notPath('doc')
|
->notPath('doc')
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
pipeline:
|
steps:
|
||||||
restore_cache:
|
restore_cache:
|
||||||
image: meltwater/drone-cache:dev
|
image: meltwater/drone-cache:dev
|
||||||
settings:
|
settings:
|
||||||
|
|
|
@ -11,11 +11,11 @@ labels:
|
||||||
|
|
||||||
skip_clone: true
|
skip_clone: true
|
||||||
|
|
||||||
pipeline:
|
steps:
|
||||||
clone:
|
clone:
|
||||||
image: alpine/git
|
image: alpine/git
|
||||||
commands:
|
commands:
|
||||||
- git clone $CI_REPO_LINK .
|
- git clone $CI_REPO_CLONE_URL .
|
||||||
- git checkout $CI_COMMIT_BRANCH
|
- git checkout $CI_COMMIT_BRANCH
|
||||||
- git fetch origin $CI_COMMIT_REF
|
- git fetch origin $CI_COMMIT_REF
|
||||||
- git merge $CI_COMMIT_SHA
|
- git merge $CI_COMMIT_SHA
|
||||||
|
@ -39,7 +39,7 @@ pipeline:
|
||||||
branch: [ develop, '*-rc' ]
|
branch: [ develop, '*-rc' ]
|
||||||
event: push
|
event: push
|
||||||
composer_install:
|
composer_install:
|
||||||
image: friendicaci/php7.4:php7.4.33
|
image: friendicaci/php8.2:php8.2.16
|
||||||
commands:
|
commands:
|
||||||
- export COMPOSER_HOME=.composer
|
- export COMPOSER_HOME=.composer
|
||||||
- composer validate
|
- composer validate
|
||||||
|
|
|
@ -1,12 +1,17 @@
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- PHP_MAJOR_VERSION: 7.4
|
- PHP_MAJOR_VERSION: 8.2
|
||||||
PHP_VERSION: 7.4.33
|
PHP_VERSION: 8.2.16
|
||||||
|
|
||||||
branches:
|
when:
|
||||||
exclude: [ stable ]
|
- branch:
|
||||||
|
exclude: [ stable ]
|
||||||
|
|
||||||
pipeline:
|
# This forces CI executions at the "opensocial" labeled location (because of much more power...)
|
||||||
|
labels:
|
||||||
|
location: opensocial
|
||||||
|
|
||||||
|
steps:
|
||||||
db_version_match:
|
db_version_match:
|
||||||
image: friendicaci/transifex
|
image: friendicaci/transifex
|
||||||
commands:
|
commands:
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
pipeline:
|
steps:
|
||||||
check:
|
check:
|
||||||
image: friendicaci/php-cs
|
image: friendicaci/php-cs
|
||||||
commands:
|
commands:
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
pipeline:
|
steps:
|
||||||
build_xgettext:
|
build_xgettext:
|
||||||
image: friendicaci/transifex
|
image: friendicaci/transifex
|
||||||
commands:
|
commands:
|
||||||
|
@ -8,5 +8,6 @@ pipeline:
|
||||||
commands:
|
commands:
|
||||||
- /check-messages.sh
|
- /check-messages.sh
|
||||||
|
|
||||||
branches:
|
when:
|
||||||
exclude: [ stable ]
|
- branch:
|
||||||
|
exclude: [ stable ]
|
||||||
|
|
|
@ -1,24 +1,25 @@
|
||||||
matrix:
|
matrix:
|
||||||
include:
|
include:
|
||||||
- PHP_MAJOR_VERSION: 7.3
|
|
||||||
PHP_VERSION: 7.3.33
|
|
||||||
- PHP_MAJOR_VERSION: 7.4
|
- PHP_MAJOR_VERSION: 7.4
|
||||||
PHP_VERSION: 7.4.33
|
PHP_VERSION: 7.4.33
|
||||||
- PHP_MAJOR_VERSION: 8.0
|
- PHP_MAJOR_VERSION: 8.0
|
||||||
PHP_VERSION: 8.0.25
|
PHP_VERSION: 8.0.30
|
||||||
- PHP_MAJOR_VERSION: 8.1
|
- PHP_MAJOR_VERSION: 8.1
|
||||||
PHP_VERSION: 8.1.12
|
PHP_VERSION: 8.1.27
|
||||||
|
- PHP_MAJOR_VERSION: 8.2
|
||||||
|
PHP_VERSION: 8.2.16
|
||||||
|
- PHP_MAJOR_VERSION: 8.3
|
||||||
|
PHP_VERSION: 8.3.3
|
||||||
|
|
||||||
# This forces PHP Unit executions at the "opensocial" labeled location (because of much more power...)
|
# This forces PHP Unit executions at the "opensocial" labeled location (because of much more power...)
|
||||||
labels:
|
labels:
|
||||||
location: opensocial
|
location: opensocial
|
||||||
|
|
||||||
pipeline:
|
steps:
|
||||||
php-lint:
|
php-lint:
|
||||||
image: php:${PHP_MAJOR_VERSION}
|
image: php:${PHP_MAJOR_VERSION}
|
||||||
group: lint
|
|
||||||
commands:
|
commands:
|
||||||
- ./bin/composer.phar run lint
|
- find . -name \*.php -not -path './vendor/*' -not -path './view/asset/*' -print0 | xargs -0 -n1 php -l
|
||||||
restore_cache:
|
restore_cache:
|
||||||
image: meltwater/drone-cache:dev
|
image: meltwater/drone-cache:dev
|
||||||
settings:
|
settings:
|
||||||
|
@ -64,19 +65,19 @@ pipeline:
|
||||||
- cp config/local-sample.config.php config/local.config.php
|
- cp config/local-sample.config.php config/local.config.php
|
||||||
- if ! bin/wait-for-connection $MYSQL_HOST $MYSQL_PORT 300; then echo "[ERROR] Waited 300 seconds, no response" >&2; exit 1; fi
|
- if ! bin/wait-for-connection $MYSQL_HOST $MYSQL_PORT 300; then echo "[ERROR] Waited 300 seconds, no response" >&2; exit 1; fi
|
||||||
- mysql -h$MYSQL_HOST -P$MYSQL_PORT -p$MYSQL_PASSWORD -u$MYSQL_USER $MYSQL_DATABASE < database.sql
|
- mysql -h$MYSQL_HOST -P$MYSQL_PORT -p$MYSQL_PASSWORD -u$MYSQL_USER $MYSQL_DATABASE < database.sql
|
||||||
- if [ "${PHP_MAJOR_VERSION}" = "7.4" -a "${CI_REPO}" = "friendica/friendica" ]; then
|
- if [ "${PHP_MAJOR_VERSION}" = "8.2" -a "${CI_REPO}" = "friendica/friendica" ]; then
|
||||||
phpenmod xdebug;
|
phpenmod xdebug;
|
||||||
export XDEBUG_MODE=coverage;
|
export XDEBUG_MODE=coverage;
|
||||||
phpunit --configuration tests/phpunit.xml --coverage-clover clover.xml;
|
phpunit --configuration tests/phpunit.xml -d memory_limit=-1 --coverage-clover clover.xml;
|
||||||
else
|
else
|
||||||
phpunit --configuration tests/phpunit.xml;
|
phpunit --configuration tests/phpunit.xml -d memory_limit=-1;
|
||||||
fi
|
fi
|
||||||
codecov:
|
codecov:
|
||||||
image: friendicaci/codecov
|
image: friendicaci/codecov
|
||||||
when:
|
when:
|
||||||
matrix:
|
matrix:
|
||||||
PHP_MAJOR_VERSION: 7.4
|
PHP_MAJOR_VERSION: 8.2
|
||||||
PHP_VERSION: 7.4.33
|
PHP_VERSION: 8.2.16
|
||||||
repo:
|
repo:
|
||||||
- friendica/friendica
|
- friendica/friendica
|
||||||
commands:
|
commands:
|
||||||
|
|
|
@ -9,11 +9,11 @@ labels:
|
||||||
|
|
||||||
skip_clone: true
|
skip_clone: true
|
||||||
|
|
||||||
pipeline:
|
steps:
|
||||||
clone:
|
clone:
|
||||||
image: alpine/git
|
image: alpine/git
|
||||||
commands:
|
commands:
|
||||||
- git clone $CI_REPO_LINK .
|
- git clone $CI_REPO_CLONE_URL .
|
||||||
- git checkout $CI_COMMIT_BRANCH
|
- git checkout $CI_COMMIT_BRANCH
|
||||||
- git fetch origin $CI_COMMIT_REF
|
- git fetch origin $CI_COMMIT_REF
|
||||||
- git merge $CI_COMMIT_SHA
|
- git merge $CI_COMMIT_SHA
|
||||||
|
@ -37,7 +37,7 @@ pipeline:
|
||||||
branch: stable
|
branch: stable
|
||||||
event: tag
|
event: tag
|
||||||
composer_install:
|
composer_install:
|
||||||
image: friendicaci/php7.4:php7.4.33
|
image: friendicaci/php8.2:php8.2.16
|
||||||
commands:
|
commands:
|
||||||
- export COMPOSER_HOME=.composer
|
- export COMPOSER_HOME=.composer
|
||||||
- composer validate
|
- composer validate
|
||||||
|
|
181
CHANGELOG
|
@ -1,3 +1,184 @@
|
||||||
|
Version 2024.03 (2024-03-21)
|
||||||
|
Friendica Core
|
||||||
|
Updates to the translations AR, BG, CS, DE, EO, ES, FR, GD, HU, IS, IT, JA, PL, RO, RU, SV
|
||||||
|
Updates to the themes (frio, vier) [annando, foss-, haheute, MrPetovan, Raroun, toddy15]
|
||||||
|
Improved the channel feature [annando]
|
||||||
|
Improved the search performance [annando]
|
||||||
|
Improved spam detection [annando]
|
||||||
|
Improved the account overview on the moderation page [annando]
|
||||||
|
Improved account creation via CLI console [mexon]
|
||||||
|
Improved the Mastodon compatible API [annando, MrPetovan]
|
||||||
|
Improved logging of the system load value [annando]
|
||||||
|
Improved image handling [annando]
|
||||||
|
Improved detection of user activity [annando]
|
||||||
|
Improved display of embedded videos [annando]
|
||||||
|
Fixed an issue that could lead to empty URLs in the server block list [annando]
|
||||||
|
Fixed XSS attacks [leoOliver, MrPetovan, snajafov]
|
||||||
|
Fixed an issue when importing emails [annando]
|
||||||
|
Fixed an issue that blocked users could still use the API [annando]
|
||||||
|
Fixed an issue when fetching remote content [annando, arcanicanis]
|
||||||
|
Fixed an issue with unescaped HTML characters for RSS feeds [MrPetovan, r1pu5u]
|
||||||
|
Fixed an issue when showing the post preview [annando]
|
||||||
|
General code cleanup [annando, MrPetovan]
|
||||||
|
Updated the PasswordExposed usage [mexon]
|
||||||
|
Removed fpostit (Friendica post bookmarklet) [MrPetovan]
|
||||||
|
Removed the possibility for users to follow relays directly [annando]
|
||||||
|
Removed unused OEmbed functionality [annando]
|
||||||
|
Removed legacy schemes from frio theme [MrPetovan]
|
||||||
|
Added blur effect to sensitive images and user setting against it [annando]
|
||||||
|
Added account type Channel Relay [annando]
|
||||||
|
Added OCR generated image descriptions via tesseract addon [annando]
|
||||||
|
Added WebP and BMP support [annando]
|
||||||
|
Added blocked email addresses for registration [annando]
|
||||||
|
|
||||||
|
Friendica Addons
|
||||||
|
advancedcontentfilter
|
||||||
|
Updated dependency for PHP8.2 compatibility [MrPetovan]
|
||||||
|
blockbot
|
||||||
|
Fixed an issue preventing the creation of previews on remote systems [annando]
|
||||||
|
Updated block lists [annando]
|
||||||
|
bluesky
|
||||||
|
Overhaul of the Bluesky connector [annando]
|
||||||
|
Fixed problem with empty quoted shares [annando]
|
||||||
|
openstreetmap
|
||||||
|
Fix a config problem [haheute]
|
||||||
|
pnut:
|
||||||
|
Connector addon was added [spacenerdmo]
|
||||||
|
tesseract
|
||||||
|
Added the addon to generate image descriptions from images via OCR [annando]
|
||||||
|
tumblr
|
||||||
|
Improved handling of quoted shares [annando]
|
||||||
|
url_replace
|
||||||
|
Added addon to replace URLs from Twitter, Youtube and some others using 12ft.io [toddy15]
|
||||||
|
Fixed an issue with empty config vars [MrPetovan]
|
||||||
|
|
||||||
|
Closed Issues
|
||||||
|
903, 7732, 8768, 11142, 13220, 13293, 13765, 13768, 13809,
|
||||||
|
13814, 13814, 13818, 13819, 13822, 13823, 13828, 13837, 13839,
|
||||||
|
13844, 13845, 13859, 13863, 13873, 13877, 13886, 13887, 13897,
|
||||||
|
13899, 13905, 13909, 13922, 13925, 13930, 13939, 13940, 13946,
|
||||||
|
13947, 13949, 13950, 13953, 13955, 13959, 13968, 13969, 13972,
|
||||||
|
13984, 13985, 13986
|
||||||
|
|
||||||
|
Version 2023.12 (2023-12-24)
|
||||||
|
Friendica Core
|
||||||
|
Raised minimal PHP version to 7.4
|
||||||
|
Updates to the translations AR, BG, CA, CS, DE, EN GB, EN US, EO, ES, ET, FI, FR, GD, HU, IS, IT, JA, NL, PL, RO, RU, SV
|
||||||
|
Updates to the themes (frio, vier) [AlfredSK, annando, anubis2814, haheute, foss-, MrPetovan, Raroun, xundeenergie]
|
||||||
|
Updates to the documentation [AndyHee, BirdboyBolu, foss-, MrPetovan]
|
||||||
|
Fixed a bug in notification links [annando, keithhacks]
|
||||||
|
Fixed a bug in content negotiation [GidiKroon]
|
||||||
|
Fixed the link in invitations [Raroun]
|
||||||
|
Fixed 0Auth connection with Buffer and redirection problems [annando, HankG]
|
||||||
|
Fixed a visibility bug with Calendar entries [MrPetovan]
|
||||||
|
Fixed a JsonLD parsing issue [annando]
|
||||||
|
Fixed confusion about nickname and username [MrPetovan, Raroun]
|
||||||
|
Fixed a problem with viewing remote contact profiles [MrPetovan]
|
||||||
|
Fixed a bug with previewing linked postings [annando]
|
||||||
|
Fixed a problem parsing Mastodon WebFingers [MrPetovan]
|
||||||
|
Fixed a bug that could lead to deleting your own account unintended [MrPetovan]
|
||||||
|
Fixed redirection in 2FA settings page [MrPetovan]
|
||||||
|
Fixed a problem with distributing some comments [annando]
|
||||||
|
Fixed a bug that caused public groups not being able to hide members [annando]
|
||||||
|
Fixed RSS/Atom feed of group accounts [MrPetovan]
|
||||||
|
Fixed a bug that prevented bi-directional delivery of DMs [annando]
|
||||||
|
Fixed a bug in privacy settings for remote-self [annando]
|
||||||
|
Fixed a bug that prevented the selection of photos with captions [Raroun]
|
||||||
|
Fixed a bug in Magic Auth [git-marijus]
|
||||||
|
Fixed a bug convertig local tags to external on receiving updates to the post [annando]
|
||||||
|
Improved Bluesky connector core [annando]
|
||||||
|
Improved SSL handling of reverse http proxies [MrPetovan]
|
||||||
|
Improved performance [annando]
|
||||||
|
Improved language detection [annando]
|
||||||
|
Improved display of contact relationships [annando]
|
||||||
|
Improved display of notifications [annando, MrPetovan]
|
||||||
|
Improved Mastodon compatible API [annando, gudzpoz, HankG, MrPetovan, Quix0r]
|
||||||
|
Improved federation with Diaspora, Firefish, GoToSocial, Lemmy, Pixelfed, Threads [annando]
|
||||||
|
Improved display of quoted posts [annando]
|
||||||
|
Improved BBCode conversion [annando]
|
||||||
|
Improved addon hook loading [annando, nupplaphil]
|
||||||
|
Improved handling of relay servers [annando]
|
||||||
|
Improved blocked users feature [MrPetovan]
|
||||||
|
Improved robots.txt to include ChatGPT and Google Extended [annando, haheute]
|
||||||
|
Improved handling of resizing images [annando]
|
||||||
|
Improved the image grid at the end of postings [MrPetovan]
|
||||||
|
Improved raw content output [annando]
|
||||||
|
Improved handling of smileys [gudzpoz]
|
||||||
|
Improved the admin panel [annando]
|
||||||
|
Improved handling of the background worker [annando]
|
||||||
|
Improved the processing of relayed posts [annando]
|
||||||
|
Improved compatibility with Mastodon Clients [annando]
|
||||||
|
Improved nodeinfo [MrPetovan]
|
||||||
|
Improved the federation statistics in the admin panel [annando]
|
||||||
|
General code cleanup [AlfredSK, annando, jlamothe, mexon, MrPetovan, nupplaphil, Quix0r, toddy15]
|
||||||
|
Renamed "group" to "circle"
|
||||||
|
Renamed "forum" to "group"
|
||||||
|
Added possibility to hide the server block list [MrPetovan, Quix0r]
|
||||||
|
Added creation of moderation reports [AlfredSK, annando, MrPetovan]
|
||||||
|
Added user controlled ignore server functionality [MrPetovan]
|
||||||
|
Added support for Unix domain sockets to Redis [MrPetovan]
|
||||||
|
Added user controlled channels for the network stream [annando]
|
||||||
|
Added support of MacOS emoji picker in text fields [MrPetovan]
|
||||||
|
Added lazy loading for images [FarisKarim, xundeenergie]
|
||||||
|
Added image caption display in Fancybox gallery [MrPetovan]
|
||||||
|
Added shortcut (ctrl+enter) to send postings using Frio theme [xundeenergie]
|
||||||
|
Added support for CORS requests to nodeinfo [palant]
|
||||||
|
Added setting for servers that should only receive limited profile information [annando]
|
||||||
|
|
||||||
|
Friendica Addons
|
||||||
|
Updates to the translation AR, CS, DE, ES, ET, FR, HU, IT, JA, NL, PL, RU, SV, ZH CN
|
||||||
|
Advancedcontentfilter
|
||||||
|
General code cleanup [MrPetovan]
|
||||||
|
Audon
|
||||||
|
Added audon addon [loma-one]
|
||||||
|
Blockem
|
||||||
|
Deprecated the addon [AndyHee]
|
||||||
|
Bluesky
|
||||||
|
Added bidirectional communication to the Bluesky connector [annando]
|
||||||
|
Added support for pinned postings [annando]
|
||||||
|
Added support for transmitted language [annando]
|
||||||
|
Improved thread handling [annando]
|
||||||
|
Improved handling of hashtags [annando]
|
||||||
|
Improved image uploading [annando]
|
||||||
|
CLD
|
||||||
|
Added addon for detection of the language of postings using CLD2 library [annando]
|
||||||
|
invidious
|
||||||
|
Added addon [loma-one]
|
||||||
|
langfilter
|
||||||
|
Use two letter codes for detected languages [annando]
|
||||||
|
Mailstream
|
||||||
|
Improved error handling [mexon]
|
||||||
|
Monolog
|
||||||
|
General code cleanup [nupplaphil]
|
||||||
|
NSFW
|
||||||
|
General code cleanup [MrPetovan]
|
||||||
|
pageheader
|
||||||
|
Improved styling of message box [loma-one]
|
||||||
|
s3_storage
|
||||||
|
Bumped library version [MrPetovan]
|
||||||
|
Showmore Dyn
|
||||||
|
Improved styling on mobile devices [csolisr]
|
||||||
|
Smileybutton
|
||||||
|
Improved conversation from float to int [MrPetovan]
|
||||||
|
Tumblr
|
||||||
|
Improved the import of feeds [annando]
|
||||||
|
Twitter
|
||||||
|
Improved image uploading [annando]
|
||||||
|
Removed the import of postings from Twitter [annando]
|
||||||
|
|
||||||
|
Closed Issues
|
||||||
|
8542, 10369, 12530, 12743, 12815, 13020, 13039, 13114, 13129,
|
||||||
|
13173, 13174, 13180, 13182, 13184, 13195, 13201, 13209, 13216,
|
||||||
|
13217, 13221, 13228, 13240, 13288, 13232, 13240, 13265, 13277,
|
||||||
|
13286, 13287, 13289, 13304, 13311, 13312, 13316, 13318, 13332,
|
||||||
|
13333, 13334, 13343, 13352, 13353, 13355, 13359, 13363, 13365,
|
||||||
|
13367, 13369, 13370, 13378, 13389, 13398, 13403, 13439, 13440,
|
||||||
|
13455, 13457, 13462, 13467, 13471, 13478, 13486, 13506, 13511,
|
||||||
|
13515, 13520, 13524, 13534, 13535, 13542, 13554, 13556, 13560,
|
||||||
|
13566, 13573, 13577, 13588, 13603, 13607, 13615, 13617, 13621,
|
||||||
|
13624, 13625, 13627, 13637, 13639, 13649, 13662, 13665, 13673,
|
||||||
|
13693, 13699, 13719, 13720, 13731, 13748
|
||||||
|
|
||||||
Version 2023.05 (2023-05-23)
|
Version 2023.05 (2023-05-23)
|
||||||
Friendica Core
|
Friendica Core
|
||||||
Updates to the translations HU, PL
|
Updates to the translations HU, PL
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
# How to Contribute
|
# How to Contribute
|
||||||
|
|
||||||
If you want to contribute to the project, you don’t need to have coding experience. There are a number of tasks listed in the issue tracker with the label “[Junior Jobs](https://github.com/friendica/friendica/issues?q=is%3Aopen+is%3Aissue+label%3A%22Junior+Jobs%22)” we think are good for new contributors. But you are by no means limited to these – if you find a solution to a problem (even a new one) please make a pull request at [github](https://github.com/friendica/friendica) or let us know in the [development forum](https://forum.friendi.ca/profile/developers).
|
If you want to contribute to the project, you don’t need to have coding experience. There are a number of tasks listed in the issue tracker with the label “[Junior Jobs](https://github.com/friendica/friendica/issues?q=is%3Aopen+is%3Aissue+label%3A%22Junior+Jobs%22)” we think are good for new contributors. But you are by no means limited to these – if you find a solution to a problem (even a new one) please make a pull request at [github](https://github.com/friendica/friendica) or let us know in the [development group](https://forum.friendi.ca/profile/developers).
|
||||||
|
|
||||||
Contribution to Friendica is also not limited to coding. Any contribution to the [documentation](https://github.com/friendica/friendica/tree/develop/doc), the [translation](https://app.transifex.com/Friendica/friendica/dashboard/) or advertisement materials is welcome or reporting a problem. You don’t need to deal with Git(Hub) or Transifex if you don’t like to. Just [get in touch](https://forum.friendi.ca/profile/helpers) with us and we will get the materials to the appropriate places.
|
Contribution to Friendica is also not limited to coding. Any contribution to the [documentation](https://github.com/friendica/friendica/tree/develop/doc), the [translation](https://app.transifex.com/Friendica/friendica/dashboard/) or advertisement materials is welcome or reporting a problem. You don’t need to deal with Git(Hub) or Transifex if you don’t like to. Just [get in touch](https://forum.friendi.ca/profile/helpers) with us and we will get the materials to the appropriate places.
|
||||||
|
|
26
CREDITS.txt
|
@ -31,6 +31,8 @@ Angristan
|
||||||
Anthronaut
|
Anthronaut
|
||||||
Anton
|
Anton
|
||||||
Antron Samurai
|
Antron Samurai
|
||||||
|
Anubis2814
|
||||||
|
arcanicanis
|
||||||
Arian - Cazare Muncitori
|
Arian - Cazare Muncitori
|
||||||
Asher Pen
|
Asher Pen
|
||||||
atjn
|
atjn
|
||||||
|
@ -51,6 +53,7 @@ BinkaDroid
|
||||||
Bjoessi
|
Bjoessi
|
||||||
bkil
|
bkil
|
||||||
bob lebonche
|
bob lebonche
|
||||||
|
Boluwatife Victor
|
||||||
Boris Daniel Martinez Millàn
|
Boris Daniel Martinez Millàn
|
||||||
bufalo1973
|
bufalo1973
|
||||||
ButterflyOfFire
|
ButterflyOfFire
|
||||||
|
@ -69,8 +72,8 @@ Christian Wiwie
|
||||||
Cohan Robinson
|
Cohan Robinson
|
||||||
Colby Sollars
|
Colby Sollars
|
||||||
Copiis
|
Copiis
|
||||||
Copiis Praeesse
|
|
||||||
CrystalStiletto
|
CrystalStiletto
|
||||||
|
csolisr
|
||||||
Cyboulette
|
Cyboulette
|
||||||
Cyryl Sochacki
|
Cyryl Sochacki
|
||||||
czarnystokrotek
|
czarnystokrotek
|
||||||
|
@ -98,6 +101,7 @@ Eelco Maljaars
|
||||||
effex7
|
effex7
|
||||||
Elena
|
Elena
|
||||||
emilia.krawczyk
|
emilia.krawczyk
|
||||||
|
Entropy Engineer
|
||||||
Eric Côté
|
Eric Côté
|
||||||
Erich
|
Erich
|
||||||
erik
|
erik
|
||||||
|
@ -108,10 +112,12 @@ F1per 3y
|
||||||
Fabian Dost
|
Fabian Dost
|
||||||
Fabio Comuni
|
Fabio Comuni
|
||||||
Farida Khalaf
|
Farida Khalaf
|
||||||
|
Faris
|
||||||
felixgilles
|
felixgilles
|
||||||
Filip Bugaj
|
Filip Bugaj
|
||||||
Filip H.F. "FiXato" Slagter
|
Filip H.F. "FiXato" Slagter
|
||||||
Finn Dean
|
Finn Dean
|
||||||
|
Florent C.
|
||||||
FlxAlbroscheit
|
FlxAlbroscheit
|
||||||
foss-
|
foss-
|
||||||
Francesco Apruzzese
|
Francesco Apruzzese
|
||||||
|
@ -121,24 +127,29 @@ Gerhard Seeber
|
||||||
gerhard6380
|
gerhard6380
|
||||||
Gert Cauwenberg
|
Gert Cauwenberg
|
||||||
Gidi Kroon
|
Gidi Kroon
|
||||||
|
git-marijus
|
||||||
GLComo
|
GLComo
|
||||||
greeneyedred
|
greeneyedred
|
||||||
Gregory Smith
|
Gregory Smith
|
||||||
Grischa Brockhaus
|
Grischa Brockhaus
|
||||||
|
groen
|
||||||
gudzpoz
|
gudzpoz
|
||||||
GunChleoc
|
GunChleoc
|
||||||
guzzisti
|
guzzisti
|
||||||
Haakon Meland Eriksen
|
Haakon Meland Eriksen
|
||||||
|
haheute
|
||||||
Hank Grabowski
|
Hank Grabowski
|
||||||
Hannes Heute
|
Hannes Heute
|
||||||
Hans Meine
|
Hans Meine
|
||||||
Hauke
|
Hauke
|
||||||
Hauke Altmann
|
Hauke Altmann
|
||||||
|
Henrik Härkönen
|
||||||
Herbert Thielen
|
Herbert Thielen
|
||||||
hlad
|
hlad
|
||||||
hoergen
|
hoergen
|
||||||
Hubert Kościański
|
Hubert Kościański
|
||||||
Hypolite Petovan
|
Hypolite Petovan
|
||||||
|
ike
|
||||||
Ilmari
|
Ilmari
|
||||||
ImgBotApp
|
ImgBotApp
|
||||||
irhen
|
irhen
|
||||||
|
@ -156,6 +167,7 @@ Johannes Schwab
|
||||||
John Brazil
|
John Brazil
|
||||||
John Mortensen
|
John Mortensen
|
||||||
Jonatan Nyberg
|
Jonatan Nyberg
|
||||||
|
Jonathan Lamothe
|
||||||
Jonny Tischbein
|
Jonny Tischbein
|
||||||
Josef Moravek
|
Josef Moravek
|
||||||
Josh Soref
|
Josh Soref
|
||||||
|
@ -168,11 +180,13 @@ Karolina
|
||||||
Kastal András
|
Kastal András
|
||||||
Keenan Pepper
|
Keenan Pepper
|
||||||
Keith Fernie
|
Keith Fernie
|
||||||
|
keithhacks
|
||||||
Klaus Weidenbach
|
Klaus Weidenbach
|
||||||
Koyu Berteon
|
Koyu Berteon
|
||||||
kPherox
|
kPherox
|
||||||
Kris
|
Kris
|
||||||
Kristoffer Grundström
|
Kristoffer Grundström
|
||||||
|
ktlinux
|
||||||
KulikAlex
|
KulikAlex
|
||||||
Lea1995polish
|
Lea1995polish
|
||||||
Leberwurscht
|
Leberwurscht
|
||||||
|
@ -211,6 +225,7 @@ Michal Šupler
|
||||||
Michalina
|
Michalina
|
||||||
Mike Macgirvin
|
Mike Macgirvin
|
||||||
miqrogroove
|
miqrogroove
|
||||||
|
Morgan McMillian
|
||||||
mpanhans
|
mpanhans
|
||||||
mytbk
|
mytbk
|
||||||
nathilia-peirce
|
nathilia-peirce
|
||||||
|
@ -244,8 +259,10 @@ Pierre Bernardeau
|
||||||
Pierre Rudloff
|
Pierre Rudloff
|
||||||
Piotr Blonkowski
|
Piotr Blonkowski
|
||||||
Piotr Strębski
|
Piotr Strębski
|
||||||
|
pixelroot
|
||||||
pokerazor
|
pokerazor
|
||||||
R C
|
R C
|
||||||
|
r1pu5u
|
||||||
Rabuzarus
|
Rabuzarus
|
||||||
Radek
|
Radek
|
||||||
Rafael Garau
|
Rafael Garau
|
||||||
|
@ -254,6 +271,7 @@ Rain Hawk
|
||||||
Rainulf Pineda
|
Rainulf Pineda
|
||||||
Ralf Thees
|
Ralf Thees
|
||||||
ralph van der honing
|
ralph van der honing
|
||||||
|
Raroun
|
||||||
Ratten
|
Ratten
|
||||||
rcmaniac
|
rcmaniac
|
||||||
RealKinetix
|
RealKinetix
|
||||||
|
@ -269,6 +287,7 @@ Roland Häder
|
||||||
Ruud Schilders
|
Ruud Schilders
|
||||||
rwa
|
rwa
|
||||||
Ryan Voots
|
Ryan Voots
|
||||||
|
S. Brusch
|
||||||
S.Krumbholz
|
S.Krumbholz
|
||||||
Sakałoŭ Alaksiej
|
Sakałoŭ Alaksiej
|
||||||
Sam
|
Sam
|
||||||
|
@ -281,9 +300,11 @@ Senex Petrovic
|
||||||
Seth
|
Seth
|
||||||
SickShark X
|
SickShark X
|
||||||
Silke Meyer
|
Silke Meyer
|
||||||
|
Simon
|
||||||
Simon L'nu
|
Simon L'nu
|
||||||
Simon Rupf
|
Simon Rupf
|
||||||
Simó Albert i Beltran
|
Simó Albert i Beltran
|
||||||
|
snajafov
|
||||||
softmetz
|
softmetz
|
||||||
soko1
|
soko1
|
||||||
Spencer Dub
|
Spencer Dub
|
||||||
|
@ -314,6 +335,7 @@ TiMESPLiNTER
|
||||||
Tino
|
Tino
|
||||||
Tobias Diekershoff
|
Tobias Diekershoff
|
||||||
Tobias Hößl
|
Tobias Hößl
|
||||||
|
Tobias Quathamer
|
||||||
Tom
|
Tom
|
||||||
Tom Aurlund
|
Tom Aurlund
|
||||||
Tom Hu
|
Tom Hu
|
||||||
|
@ -324,6 +346,7 @@ Torbjörn Andersson
|
||||||
TORminator
|
TORminator
|
||||||
trebor
|
trebor
|
||||||
tschlotfeldt
|
tschlotfeldt
|
||||||
|
tslmuun
|
||||||
Tubuntu
|
Tubuntu
|
||||||
Tupambae.org
|
Tupambae.org
|
||||||
U-SOUND\mike
|
U-SOUND\mike
|
||||||
|
@ -345,6 +368,7 @@ Waldemar Stoczkowski
|
||||||
Walter Bulbazor
|
Walter Bulbazor
|
||||||
Wanting Chen
|
Wanting Chen
|
||||||
Wil Tur
|
Wil Tur
|
||||||
|
Wladimir Palant
|
||||||
Wouter Broers
|
Wouter Broers
|
||||||
Xiaofei Xu
|
Xiaofei Xu
|
||||||
XMPPはいいぞ
|
XMPPはいいぞ
|
||||||
|
|
54
README.md
|
@ -1,46 +1,30 @@
|
||||||
Friendica Social Communications Server
|
Friendica - your open and free social network
|
||||||
======================================
|
=============================================
|
||||||
|
|
||||||
Welcome to the free social web.
|
Welcome to the free social web. Friendica is a platform for decentralised social communication linking to other independent social and corporate services.
|
||||||
|
|
||||||
Friendica is a decentralised communications platform that integrates social communication. Our platform links to independent social projects and corporate services.
|
Friendica connects you to a federated communications network of thousands of servers called the Fediverse.
|
||||||
|
Through various protocols you can interact with anyone on [Friendica]( https://friendi.ca), [Mastodon](https://joinmastodon.org), [Lemmy](https://join-lemmy.org/), [Diaspora](https://diasporafoundation.org), [Misskey](https://join.misskey.page), [Peertube](https://joinpeertube.org/), [Pixelfed](https://pixelfed.org/), [Pleroma](https://pleroma.social) and many more.
|
||||||
|
Receiving content from Tumblr, WordPress and RSS is also possible.
|
||||||
|
Friendica allows to import and mirror your content via add-ons such as ITTT and Buffer.
|
||||||
|
You can control the privacy scope of your content.
|
||||||
|
|
||||||
Our mission is to free friends, family and colleagues from data-harvesting corporations; we aim for social communication to be free and open, while flowing between any provider as easily as email does.
|
Being part of the Fediverse allows you to be free from data-harvesting corporations.
|
||||||
|
Enjoy open social communication, independent of any specific provider.
|
||||||
|
|
||||||
Friendica connects you effortlessly to a federated communications network of several thousand servers, with more than half a million user registrations. You can directly connect to anyone on [Friendica]( https://friendi.ca), [Mastodon](https://joinmastodon.org/), [Diaspora](https://diasporafoundation.org/), [GnuSocial](https://gnu.io/social/), [Pleroma](https://pleroma.social/), or [Hubzilla](https://hubzilla.org/), regardless where each user profile is hosted.
|
[Join Friendica](https://dir.friendica.social/servers) today or set up [your own Friendica instance](doc/Install.md).
|
||||||
|
|
||||||
With Friendica, you can also fully interact with anyone on Twitter and receive any content from Tumblr, Wordpress or RSS. Friendica allows you to integrate most things on the web via a range of addons such as ITTT, Buffer; you will be able to easily control your own data as you decide.
|
### Friendica on desktop
|
||||||
|
|
||||||
Join today and [get your Friendica profile!](https://dir.friendica.social/servers 'Join Friendica today!')
|
![Frio theme in desktop browser](images/screenshots/friendica-2023-12-frio-desktop.png?raw=true "Frio theme in desktop browser")
|
||||||
|
|
||||||
Have a look at the [installation documentation](doc/Install.md) for further information about installing and using Friendica.
|
### Friendica on mobile
|
||||||
|
|
||||||
### Friendica Screenshots
|
<p float="left">
|
||||||
|
<img src="images/screenshots/friendica-2023-10-frio-mobile-timeline-dark-blue.png" width="370" alt="frio on mobile, dark color scheme">
|
||||||
| ![Frio theme in mobile browser](images/screenshots/friendica-frio-mobile-profile-1.png?raw=true "Frio theme in mobile browser") ![Frio theme in mobile browser](images/screenshots/friendica-frio-mobile-profile-2.png?raw=true "Frio theme in mobile browser")
|
<img src="images/screenshots/friendica-2023-10-frio-mobile-options-light-blue.png" width="370" alt="frio on mobile, light color scheme">
|
||||||
|:--:|
|
</p>
|
||||||
|*Frio theme, mobile browser. Timeline and composer view.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-green-profile-1.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Frio theme, desktop browser. Timeline view, contact info popped up, control menu open.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-green-profile-2.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Frio theme, desktop browser. Menu open for controlling individual posts.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-red-profile-3.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Frio theme, desktop browser. Profile view, notification menu open.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-red-profile-2.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Number of new posts, in total and by group.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-red-profile-1.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Calender with popup of event.*|
|
|
||||||
|![Frio theme default colour in standard browser on tablet](images/screenshots/friendica-frio-default-profile-1.png?raw=true "Frio theme default colour in standard browser on tablet")
|
|
||||||
|*Notifications menu and private messages counter, standard browser on tablet.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-brown-profile-2.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Number of visible contacts, standard browser.*|
|
|
||||||
|![Frio theme in desktop browser](images/screenshots/friendica-frio-brown-profile-1.png?raw=true "Frio theme in desktop browser")
|
|
||||||
|*Network posts chronologically ordered, standard browser.*|
|
|
||||||
|![Vier theme in desktop browser](images/screenshots/friendica-vier-profile.png?raw=true "Vier theme in desktop browser")
|
|
||||||
|*Vier theme, desktop browser. Public timeline view.*|
|
|
||||||
|![Vier theme in desktop browser](images/screenshots/friendica-vier-community.png?raw=true "Vier theme in desktop browser")
|
|
||||||
|*Vier theme, desktop browser. Community post displayed.*|
|
|
||||||
|
|
||||||
## Endorsements
|
## Endorsements
|
||||||
|
|
||||||
- [![Awesome Humane Tech](images/humane-tech-badge.svg)](https://github.com/humanetech-community/awesome-humane-tech) On August 12th 2020, Friendica was added to [the curated Awesome Humane Tech directory](https://github.com/humanetech-community/awesome-humane-tech) in [the "Fediverse" category](https://github.com/humanetech-community/awesome-humane-tech#fediverse).
|
- Friendica is listed on [![Awesome Humane Tech](images/humane-tech-badge.svg)](https://codeberg.org/teaserbot-labs/delightful-humane-design) in the [Fediverse category](https://codeberg.org/teaserbot-labs/delightful-humane-design#fediverse).
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env php
|
#!/usr/bin/env php
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* @copyright Copyright (C) 2010-2023, the Friendica project
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
*
|
*
|
||||||
* @license GNU AGPL version 3 or any later version
|
* @license GNU AGPL version 3 or any later version
|
||||||
*
|
*
|
||||||
|
@ -58,6 +58,7 @@ if (php_sapi_name() !== 'cli') {
|
||||||
|
|
||||||
use Dice\Dice;
|
use Dice\Dice;
|
||||||
use Friendica\App\Mode;
|
use Friendica\App\Mode;
|
||||||
|
use Friendica\Core\Logger\Capability\LogChannel;
|
||||||
use Friendica\Security\ExAuth;
|
use Friendica\Security\ExAuth;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
|
@ -78,7 +79,10 @@ chdir($directory);
|
||||||
require dirname(__DIR__) . '/vendor/autoload.php';
|
require dirname(__DIR__) . '/vendor/autoload.php';
|
||||||
|
|
||||||
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
||||||
$dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['auth_ejabberd']]);
|
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
||||||
|
$addonLoader = $dice->create(\Friendica\Core\Addon\Capability\ICanLoadAddons::class);
|
||||||
|
$dice = $dice->addRules($addonLoader->getActiveAddonConfig('dependencies'));
|
||||||
|
$dice = $dice->addRule(LoggerInterface::class,['constructParams' => [LogChannel::AUTH_JABBERED]]);
|
||||||
|
|
||||||
\Friendica\DI::init($dice);
|
\Friendica\DI::init($dice);
|
||||||
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env php
|
#!/usr/bin/env php
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* @copyright Copyright (C) 2010-2023, the Friendica project
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
*
|
*
|
||||||
* @license GNU AGPL version 3 or any later version
|
* @license GNU AGPL version 3 or any later version
|
||||||
*
|
*
|
||||||
|
@ -26,13 +26,17 @@ if (php_sapi_name() !== 'cli') {
|
||||||
}
|
}
|
||||||
|
|
||||||
use Dice\Dice;
|
use Dice\Dice;
|
||||||
|
use Friendica\Core\Logger\Capability\LogChannel;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
use Psr\Log\LoggerInterface;
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
require dirname(__DIR__) . '/vendor/autoload.php';
|
require dirname(__DIR__) . '/vendor/autoload.php';
|
||||||
|
|
||||||
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
||||||
$dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['console']]);
|
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
||||||
|
$addonLoader = $dice->create(\Friendica\Core\Addon\Capability\ICanLoadAddons::class);
|
||||||
|
$dice = $dice->addRules($addonLoader->getActiveAddonConfig('dependencies'));
|
||||||
|
$dice = $dice->addRule(LoggerInterface::class, ['constructParams' => [LogChannel::CONSOLE]]);
|
||||||
|
|
||||||
/// @fixme Necessary until Hooks inside the Logger can get loaded without the DI-class
|
/// @fixme Necessary until Hooks inside the Logger can get loaded without the DI-class
|
||||||
DI::init($dice);
|
DI::init($dice);
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env php
|
#!/usr/bin/env php
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* @copyright Copyright (C) 2010-2023, the Friendica project
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
*
|
*
|
||||||
* @license GNU AGPL version 3 or any later version
|
* @license GNU AGPL version 3 or any later version
|
||||||
*
|
*
|
||||||
|
@ -60,7 +60,10 @@ if (!file_exists('index.php') && (sizeof($_SERVER['argv']) != 0)) {
|
||||||
require dirname(__DIR__) . '/vendor/autoload.php';
|
require dirname(__DIR__) . '/vendor/autoload.php';
|
||||||
|
|
||||||
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
||||||
$dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['daemon']]);
|
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
||||||
|
$addonLoader = $dice->create(\Friendica\Core\Addon\Capability\ICanLoadAddons::class);
|
||||||
|
$dice = $dice->addRules($addonLoader->getActiveAddonConfig('dependencies'));
|
||||||
|
$dice = $dice->addRule(LoggerInterface::class, ['constructParams' => [Logger\Capability\LogChannel::DAEMON]]);
|
||||||
|
|
||||||
DI::init($dice);
|
DI::init($dice);
|
||||||
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
||||||
|
@ -160,9 +163,14 @@ if (!$foreground) {
|
||||||
exit(1);
|
exit(1);
|
||||||
} elseif ($pid) {
|
} elseif ($pid) {
|
||||||
// The parent process continues here
|
// The parent process continues here
|
||||||
|
if (!file_put_contents($pidfile, $pid)) {
|
||||||
|
echo "Pid file wasn't written.\n";
|
||||||
|
Logger::warning('Could not store pid file');
|
||||||
|
posix_kill($pid, SIGTERM);
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
echo 'Child process started with pid ' . $pid . ".\n";
|
echo 'Child process started with pid ' . $pid . ".\n";
|
||||||
Logger::notice('Child process started', ['pid' => $pid]);
|
Logger::notice('Child process started', ['pid' => $pid]);
|
||||||
file_put_contents($pidfile, $pid);
|
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* @copyright Copyright (C) 2010-2023, the Friendica project
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
*
|
*
|
||||||
* @license GNU AGPL version 3 or any later version
|
* @license GNU AGPL version 3 or any later version
|
||||||
*
|
*
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/php
|
#!/usr/bin/php
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* @copyright Copyright (C) 2010-2023, the Friendica project
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
*
|
*
|
||||||
* @license GNU AGPL version 3 or any later version
|
* @license GNU AGPL version 3 or any later version
|
||||||
*
|
*
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!/usr/bin/env php
|
#!/usr/bin/env php
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* @copyright Copyright (C) 2010-2023, the Friendica project
|
* @copyright Copyright (C) 2010-2024, the Friendica project
|
||||||
*
|
*
|
||||||
* @license GNU AGPL version 3 or any later version
|
* @license GNU AGPL version 3 or any later version
|
||||||
*
|
*
|
||||||
|
@ -29,6 +29,7 @@ if (php_sapi_name() !== 'cli') {
|
||||||
use Dice\Dice;
|
use Dice\Dice;
|
||||||
use Friendica\App;
|
use Friendica\App;
|
||||||
use Friendica\App\Mode;
|
use Friendica\App\Mode;
|
||||||
|
use Friendica\Core\Logger\Capability\LogChannel;
|
||||||
use Friendica\Core\Update;
|
use Friendica\Core\Update;
|
||||||
use Friendica\Core\Worker;
|
use Friendica\Core\Worker;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
|
@ -54,7 +55,10 @@ if (!file_exists("index.php") && (sizeof($_SERVER["argv"]) != 0)) {
|
||||||
require dirname(__DIR__) . '/vendor/autoload.php';
|
require dirname(__DIR__) . '/vendor/autoload.php';
|
||||||
|
|
||||||
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
$dice = (new Dice())->addRules(include __DIR__ . '/../static/dependencies.config.php');
|
||||||
$dice = $dice->addRule(LoggerInterface::class,['constructParams' => ['worker']]);
|
/** @var \Friendica\Core\Addon\Capability\ICanLoadAddons $addonLoader */
|
||||||
|
$addonLoader = $dice->create(\Friendica\Core\Addon\Capability\ICanLoadAddons::class);
|
||||||
|
$dice = $dice->addRules($addonLoader->getActiveAddonConfig('dependencies'));
|
||||||
|
$dice = $dice->addRule(LoggerInterface::class, ['constructParams' => [LogChannel::WORKER]]);
|
||||||
|
|
||||||
DI::init($dice);
|
DI::init($dice);
|
||||||
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
\Friendica\Core\Logger\Handler\ErrorHandler::register($dice->create(\Psr\Log\LoggerInterface::class));
|
||||||
|
|
|
@ -13,7 +13,7 @@
|
||||||
"issues": "https://github.com/friendica/friendica/issues"
|
"issues": "https://github.com/friendica/friendica/issues"
|
||||||
},
|
},
|
||||||
"require": {
|
"require": {
|
||||||
"php": ">=7.3",
|
"php": ">=7.4",
|
||||||
"ext-ctype": "*",
|
"ext-ctype": "*",
|
||||||
"ext-curl": "*",
|
"ext-curl": "*",
|
||||||
"ext-dom": "*",
|
"ext-dom": "*",
|
||||||
|
@ -29,12 +29,12 @@
|
||||||
"ext-xml": "*",
|
"ext-xml": "*",
|
||||||
"asika/simple-console": "^1.0",
|
"asika/simple-console": "^1.0",
|
||||||
"bacon/bacon-qr-code": "^2.0.0",
|
"bacon/bacon-qr-code": "^2.0.0",
|
||||||
"divineomega/password_exposed": "^2.8",
|
"divineomega/password_exposed": "^3",
|
||||||
"enyo/dropzone": "^5.9",
|
"enyo/dropzone": "^5.9",
|
||||||
"ezyang/htmlpurifier": "^4.7",
|
"ezyang/htmlpurifier": "^4.7",
|
||||||
"friendica/json-ld": "^1.0",
|
"friendica/json-ld": "^1.0",
|
||||||
"geekwright/po": "^2.0",
|
"geekwright/po": "^2.0",
|
||||||
"guzzlehttp/guzzle": "^6.5",
|
"guzzlehttp/guzzle": "^7",
|
||||||
"guzzlehttp/oauth-subscriber": "^0.6",
|
"guzzlehttp/oauth-subscriber": "^0.6",
|
||||||
"kornrunner/blurhash": "^1.2",
|
"kornrunner/blurhash": "^1.2",
|
||||||
"league/html-to-markdown": "^4.8",
|
"league/html-to-markdown": "^4.8",
|
||||||
|
@ -44,7 +44,7 @@
|
||||||
"mattwright/urlresolver": "^2.0",
|
"mattwright/urlresolver": "^2.0",
|
||||||
"michelf/php-markdown": "^1.7",
|
"michelf/php-markdown": "^1.7",
|
||||||
"minishlink/web-push": "^6.0",
|
"minishlink/web-push": "^6.0",
|
||||||
"mobiledetect/mobiledetectlib": "^2.8",
|
"mobiledetect/mobiledetectlib": "^3.74",
|
||||||
"nikic/fast-route": "^1.3",
|
"nikic/fast-route": "^1.3",
|
||||||
"paragonie/hidden-string": "^1.0",
|
"paragonie/hidden-string": "^1.0",
|
||||||
"patrickschur/language-detection": "^5.0.0",
|
"patrickschur/language-detection": "^5.0.0",
|
||||||
|
@ -53,7 +53,7 @@
|
||||||
"pragmarx/google2fa": "^5.0",
|
"pragmarx/google2fa": "^5.0",
|
||||||
"pragmarx/recovery": "^0.2",
|
"pragmarx/recovery": "^0.2",
|
||||||
"psr/clock": "^1.0",
|
"psr/clock": "^1.0",
|
||||||
"psr/container": "^1.0",
|
"psr/container": "^2.0",
|
||||||
"psr/log": "^1.1",
|
"psr/log": "^1.1",
|
||||||
"seld/cli-prompt": "^1.0",
|
"seld/cli-prompt": "^1.0",
|
||||||
"smarty/smarty": "^4",
|
"smarty/smarty": "^4",
|
||||||
|
@ -77,6 +77,12 @@
|
||||||
"npm-asset/textcomplete": "^0.18.2",
|
"npm-asset/textcomplete": "^0.18.2",
|
||||||
"npm-asset/typeahead.js": "^0.11.1"
|
"npm-asset/typeahead.js": "^0.11.1"
|
||||||
},
|
},
|
||||||
|
"suggest": {
|
||||||
|
"ext-imagick": "For faster image processing",
|
||||||
|
"ext-redis": "To use Redis as a locking or caching provider",
|
||||||
|
"ext-pdo": "To use PDO as a database driver, has priority over mysqli unless database.disable_pdo is set",
|
||||||
|
"ext-mysqli": "To use mysqli as a databse driver"
|
||||||
|
},
|
||||||
"repositories": [
|
"repositories": [
|
||||||
{
|
{
|
||||||
"type": "vcs",
|
"type": "vcs",
|
||||||
|
@ -96,7 +102,7 @@
|
||||||
},
|
},
|
||||||
"config": {
|
"config": {
|
||||||
"platform": {
|
"platform": {
|
||||||
"php": "7.3"
|
"php": "7.4"
|
||||||
},
|
},
|
||||||
"autoloader-suffix": "Friendica",
|
"autoloader-suffix": "Friendica",
|
||||||
"optimize-autoloader": true,
|
"optimize-autoloader": true,
|
||||||
|
@ -129,11 +135,13 @@
|
||||||
"mockery/mockery": "^1.3",
|
"mockery/mockery": "^1.3",
|
||||||
"mikey179/vfsstream": "^1.6",
|
"mikey179/vfsstream": "^1.6",
|
||||||
"phpunit/phpunit": "^9",
|
"phpunit/phpunit": "^9",
|
||||||
"dms/phpunit-arraysubset-asserts": "^0.3.1"
|
"dms/phpunit-arraysubset-asserts": "^0.3.1",
|
||||||
|
"friendsofphp/php-cs-fixer": "^3.46"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "phpunit",
|
"test": "phpunit",
|
||||||
"lint": "find . -name \\*.php -not -path './vendor/*' -not -path './view/asset/*' -print0 | xargs -0 -n1 php -l",
|
"lint": "find . -name \\*.php -not -path './vendor/*' -not -path './view/asset/*' -print0 | xargs -0 -n1 php -l",
|
||||||
|
"docker:translate": "docker run --rm -v $PWD:/data -w /data friendicaci/transifex bin/run_xgettext.sh",
|
||||||
"cs:install": "@composer install --working-dir=bin/dev/php-cs-fixer",
|
"cs:install": "@composer install --working-dir=bin/dev/php-cs-fixer",
|
||||||
"cs:check": [
|
"cs:check": [
|
||||||
"@cs:install",
|
"@cs:install",
|
||||||
|
@ -142,6 +150,8 @@
|
||||||
"cs:fix": [
|
"cs:fix": [
|
||||||
"@cs:install",
|
"@cs:install",
|
||||||
"bin/dev/php-cs-fixer/vendor/bin/php-cs-fixer fix"
|
"bin/dev/php-cs-fixer/vendor/bin/php-cs-fixer fix"
|
||||||
]
|
],
|
||||||
|
"cs:check-v3": "vendor/bin/php-cs-fixer check --diff",
|
||||||
|
"cs:fix-v3": "vendor/bin/php-cs-fixer fix"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
455
database.sql
|
@ -1,6 +1,6 @@
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
-- Friendica 2023.05 (Giant Rhubarb)
|
-- Friendica 2024.03 (Yellow Archangel)
|
||||||
-- DB_UPDATE_VERSION 1518
|
-- DB_UPDATE_VERSION 1557
|
||||||
-- ------------------------------------------
|
-- ------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
|
@ -73,8 +73,6 @@ CREATE TABLE IF NOT EXISTS `user` (
|
||||||
`blockwall` boolean NOT NULL DEFAULT '0' COMMENT 'Prohibit contacts to post to the profile page of the user',
|
`blockwall` boolean NOT NULL DEFAULT '0' COMMENT 'Prohibit contacts to post to the profile page of the user',
|
||||||
`hidewall` boolean NOT NULL DEFAULT '0' COMMENT 'Hide profile details from unknown viewers',
|
`hidewall` boolean NOT NULL DEFAULT '0' COMMENT 'Hide profile details from unknown viewers',
|
||||||
`blocktags` boolean NOT NULL DEFAULT '0' COMMENT 'Prohibit contacts to tag the post of this user',
|
`blocktags` boolean NOT NULL DEFAULT '0' COMMENT 'Prohibit contacts to tag the post of this user',
|
||||||
`unkmail` boolean NOT NULL DEFAULT '0' COMMENT 'Permit unknown people to send private mails to this user',
|
|
||||||
`cntunkmail` int unsigned NOT NULL DEFAULT 10 COMMENT '',
|
|
||||||
`notify-flags` smallint unsigned NOT NULL DEFAULT 65535 COMMENT 'email notification options',
|
`notify-flags` smallint unsigned NOT NULL DEFAULT 65535 COMMENT 'email notification options',
|
||||||
`page-flags` tinyint unsigned NOT NULL DEFAULT 0 COMMENT 'page/profile type',
|
`page-flags` tinyint unsigned NOT NULL DEFAULT 0 COMMENT 'page/profile type',
|
||||||
`account-type` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '',
|
`account-type` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '',
|
||||||
|
@ -101,6 +99,19 @@ CREATE TABLE IF NOT EXISTS `user` (
|
||||||
FOREIGN KEY (`parent-uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`parent-uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='The local users';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='The local users';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE user-gserver
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `user-gserver` (
|
||||||
|
`uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner User id',
|
||||||
|
`gsid` int unsigned NOT NULL DEFAULT 0 COMMENT 'Gserver id',
|
||||||
|
`ignored` boolean NOT NULL DEFAULT '0' COMMENT 'server accounts are ignored for the user',
|
||||||
|
PRIMARY KEY(`uid`,`gsid`),
|
||||||
|
INDEX `gsid` (`gsid`),
|
||||||
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`gsid`) REFERENCES `gserver` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='User settings about remote servers';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE item-uri
|
-- TABLE item-uri
|
||||||
--
|
--
|
||||||
|
@ -160,8 +171,8 @@ CREATE TABLE IF NOT EXISTS `contact` (
|
||||||
`archive` boolean NOT NULL DEFAULT '0' COMMENT '',
|
`archive` boolean NOT NULL DEFAULT '0' COMMENT '',
|
||||||
`unsearchable` boolean NOT NULL DEFAULT '0' COMMENT 'Contact prefers to not be searchable',
|
`unsearchable` boolean NOT NULL DEFAULT '0' COMMENT 'Contact prefers to not be searchable',
|
||||||
`sensitive` boolean NOT NULL DEFAULT '0' COMMENT 'Contact posts sensitive content',
|
`sensitive` boolean NOT NULL DEFAULT '0' COMMENT 'Contact posts sensitive content',
|
||||||
`baseurl` varbinary(383) DEFAULT '' COMMENT 'baseurl of the contact',
|
`baseurl` varbinary(383) DEFAULT '' COMMENT 'baseurl of the contact from the gserver record, can be missing',
|
||||||
`gsid` int unsigned COMMENT 'Global Server ID',
|
`gsid` int unsigned COMMENT 'Global Server ID, can be missing',
|
||||||
`bd` date NOT NULL DEFAULT '0001-01-01' COMMENT '',
|
`bd` date NOT NULL DEFAULT '0001-01-01' COMMENT '',
|
||||||
`reason` text COMMENT '',
|
`reason` text COMMENT '',
|
||||||
`self` boolean NOT NULL DEFAULT '0' COMMENT '1 if the contact is the user him/her self',
|
`self` boolean NOT NULL DEFAULT '0' COMMENT '1 if the contact is the user him/her self',
|
||||||
|
@ -190,7 +201,7 @@ CREATE TABLE IF NOT EXISTS `contact` (
|
||||||
`confirm` varbinary(383) COMMENT '',
|
`confirm` varbinary(383) COMMENT '',
|
||||||
`poco` varbinary(383) COMMENT '',
|
`poco` varbinary(383) COMMENT '',
|
||||||
`writable` boolean NOT NULL DEFAULT '0' COMMENT '',
|
`writable` boolean NOT NULL DEFAULT '0' COMMENT '',
|
||||||
`forum` boolean NOT NULL DEFAULT '0' COMMENT 'contact is a forum. Deprecated, use \'contact-type\' = \'community\' and \'manually-approve\' = false instead',
|
`forum` boolean NOT NULL DEFAULT '0' COMMENT 'contact is a group. Deprecated, use \'contact-type\' = \'community\' and \'manually-approve\' = false instead',
|
||||||
`prv` boolean NOT NULL DEFAULT '0' COMMENT 'contact is a private group. Deprecated, use \'contact-type\' = \'community\' and \'manually-approve\' = true instead',
|
`prv` boolean NOT NULL DEFAULT '0' COMMENT 'contact is a private group. Deprecated, use \'contact-type\' = \'community\' and \'manually-approve\' = true instead',
|
||||||
`bdyear` varchar(4) NOT NULL DEFAULT '' COMMENT '',
|
`bdyear` varchar(4) NOT NULL DEFAULT '' COMMENT '',
|
||||||
`site-pubkey` text COMMENT 'Deprecated',
|
`site-pubkey` text COMMENT 'Deprecated',
|
||||||
|
@ -252,9 +263,9 @@ CREATE TABLE IF NOT EXISTS `permissionset` (
|
||||||
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
|
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
|
||||||
`uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner id of this permission set',
|
`uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner id of this permission set',
|
||||||
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
|
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
|
||||||
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed groups',
|
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed circles',
|
||||||
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
||||||
`deny_gid` mediumtext COMMENT 'Access Control - list of denied groups',
|
`deny_gid` mediumtext COMMENT 'Access Control - list of denied circles',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
INDEX `uid_allow_cid_allow_gid_deny_cid_deny_gid` (`uid`,`allow_cid`(50),`allow_gid`(30),`deny_cid`(50),`deny_gid`(30)),
|
INDEX `uid_allow_cid_allow_gid_deny_cid_deny_gid` (`uid`,`allow_cid`(50),`allow_gid`(30),`deny_cid`(50),`deny_gid`(30)),
|
||||||
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
@ -457,9 +468,9 @@ CREATE TABLE IF NOT EXISTS `attach` (
|
||||||
`created` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'creation time',
|
`created` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'creation time',
|
||||||
`edited` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'last edit time',
|
`edited` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'last edit time',
|
||||||
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>',
|
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>',
|
||||||
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed groups',
|
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed circles',
|
||||||
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
||||||
`deny_gid` mediumtext COMMENT 'Access Control - list of denied groups',
|
`deny_gid` mediumtext COMMENT 'Access Control - list of denied circles',
|
||||||
`backend-class` tinytext COMMENT 'Storage backend class',
|
`backend-class` tinytext COMMENT 'Storage backend class',
|
||||||
`backend-ref` text COMMENT 'Storage backend data reference',
|
`backend-ref` text COMMENT 'Storage backend data reference',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
|
@ -479,6 +490,30 @@ CREATE TABLE IF NOT EXISTS `cache` (
|
||||||
INDEX `k_expires` (`k`,`expires`)
|
INDEX `k_expires` (`k`,`expires`)
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Stores temporary data';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Stores temporary data';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE channel
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `channel` (
|
||||||
|
`id` int unsigned NOT NULL auto_increment COMMENT '',
|
||||||
|
`uid` mediumint unsigned NOT NULL COMMENT 'User id',
|
||||||
|
`label` varchar(64) NOT NULL COMMENT 'Channel label',
|
||||||
|
`description` varchar(64) COMMENT 'Channel description',
|
||||||
|
`circle` int COMMENT 'Circle or channel that this channel is based on',
|
||||||
|
`access-key` varchar(1) COMMENT 'Access key',
|
||||||
|
`include-tags` varchar(1023) COMMENT 'Comma separated list of tags that will be included in the channel',
|
||||||
|
`exclude-tags` varchar(1023) COMMENT 'Comma separated list of tags that aren\'t allowed in the channel',
|
||||||
|
`min-size` int unsigned COMMENT 'Minimum post size',
|
||||||
|
`max-size` int unsigned COMMENT 'Maximum post size',
|
||||||
|
`full-text-search` varchar(1023) COMMENT 'Full text search pattern, see https://mariadb.com/kb/en/full-text-index-overview/#in-boolean-mode',
|
||||||
|
`media-type` smallint unsigned COMMENT 'Filtered media types',
|
||||||
|
`languages` mediumtext COMMENT 'Desired languages',
|
||||||
|
`publish` boolean COMMENT 'publish channel content',
|
||||||
|
`valid` boolean COMMENT 'Set, when the full-text-search is valid',
|
||||||
|
PRIMARY KEY(`id`),
|
||||||
|
INDEX `uid` (`uid`),
|
||||||
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='User defined Channels';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE config
|
-- TABLE config
|
||||||
--
|
--
|
||||||
|
@ -497,9 +532,14 @@ CREATE TABLE IF NOT EXISTS `config` (
|
||||||
CREATE TABLE IF NOT EXISTS `contact-relation` (
|
CREATE TABLE IF NOT EXISTS `contact-relation` (
|
||||||
`cid` int unsigned NOT NULL DEFAULT 0 COMMENT 'contact the related contact had interacted with',
|
`cid` int unsigned NOT NULL DEFAULT 0 COMMENT 'contact the related contact had interacted with',
|
||||||
`relation-cid` int unsigned NOT NULL DEFAULT 0 COMMENT 'related contact who had interacted with the contact',
|
`relation-cid` int unsigned NOT NULL DEFAULT 0 COMMENT 'related contact who had interacted with the contact',
|
||||||
`last-interaction` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last interaction',
|
`last-interaction` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last interaction by relation-cid on cid',
|
||||||
`follow-updated` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last update of the contact relationship',
|
`follow-updated` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT 'Date of the last update of the contact relationship',
|
||||||
`follows` boolean NOT NULL DEFAULT '0' COMMENT '',
|
`follows` boolean NOT NULL DEFAULT '0' COMMENT 'if true, relation-cid follows cid',
|
||||||
|
`score` smallint unsigned COMMENT 'score for interactions of cid on relation-cid',
|
||||||
|
`relation-score` smallint unsigned COMMENT 'score for interactions of relation-cid on cid',
|
||||||
|
`thread-score` smallint unsigned COMMENT 'score for interactions of cid on threads of relation-cid',
|
||||||
|
`relation-thread-score` smallint unsigned COMMENT 'score for interactions of relation-cid on threads of cid',
|
||||||
|
`post-score` smallint unsigned COMMENT 'score for the amount of posts from cid that can be seen by relation-cid',
|
||||||
PRIMARY KEY(`cid`,`relation-cid`),
|
PRIMARY KEY(`cid`,`relation-cid`),
|
||||||
INDEX `relation-cid` (`relation-cid`),
|
INDEX `relation-cid` (`relation-cid`),
|
||||||
FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
@ -662,9 +702,9 @@ CREATE TABLE IF NOT EXISTS `event` (
|
||||||
`nofinish` boolean NOT NULL DEFAULT '0' COMMENT 'if event does have no end this is 1',
|
`nofinish` boolean NOT NULL DEFAULT '0' COMMENT 'if event does have no end this is 1',
|
||||||
`ignore` boolean NOT NULL DEFAULT '0' COMMENT '0 or 1',
|
`ignore` boolean NOT NULL DEFAULT '0' COMMENT '0 or 1',
|
||||||
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
|
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
|
||||||
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed groups',
|
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed circles',
|
||||||
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
||||||
`deny_gid` mediumtext COMMENT 'Access Control - list of denied groups',
|
`deny_gid` mediumtext COMMENT 'Access Control - list of denied circles',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
INDEX `uid_start` (`uid`,`start`),
|
INDEX `uid_start` (`uid`,`start`),
|
||||||
INDEX `cid` (`cid`),
|
INDEX `cid` (`cid`),
|
||||||
|
@ -716,29 +756,29 @@ CREATE TABLE IF NOT EXISTS `group` (
|
||||||
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
|
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
|
||||||
`uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner User id',
|
`uid` mediumint unsigned NOT NULL DEFAULT 0 COMMENT 'Owner User id',
|
||||||
`visible` boolean NOT NULL DEFAULT '0' COMMENT '1 indicates the member list is not private',
|
`visible` boolean NOT NULL DEFAULT '0' COMMENT '1 indicates the member list is not private',
|
||||||
`deleted` boolean NOT NULL DEFAULT '0' COMMENT '1 indicates the group has been deleted',
|
`deleted` boolean NOT NULL DEFAULT '0' COMMENT '1 indicates the circle has been deleted',
|
||||||
`cid` int unsigned COMMENT 'Contact id of forum. When this field is filled then the members are synced automatically.',
|
`cid` int unsigned COMMENT 'Contact id of group. When this field is filled then the members are synced automatically.',
|
||||||
`name` varchar(255) NOT NULL DEFAULT '' COMMENT 'human readable name of group',
|
`name` varchar(255) NOT NULL DEFAULT '' COMMENT 'human readable name of circle',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
INDEX `uid` (`uid`),
|
INDEX `uid` (`uid`),
|
||||||
INDEX `cid` (`cid`),
|
INDEX `cid` (`cid`),
|
||||||
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='privacy groups, group info';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='privacy circles, circle info';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE group_member
|
-- TABLE group_member
|
||||||
--
|
--
|
||||||
CREATE TABLE IF NOT EXISTS `group_member` (
|
CREATE TABLE IF NOT EXISTS `group_member` (
|
||||||
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
|
`id` int unsigned NOT NULL auto_increment COMMENT 'sequential ID',
|
||||||
`gid` int unsigned NOT NULL DEFAULT 0 COMMENT 'groups.id of the associated group',
|
`gid` int unsigned NOT NULL DEFAULT 0 COMMENT 'group.id of the associated circle',
|
||||||
`contact-id` int unsigned NOT NULL DEFAULT 0 COMMENT 'contact.id of the member assigned to the associated group',
|
`contact-id` int unsigned NOT NULL DEFAULT 0 COMMENT 'contact.id of the member assigned to the associated circle',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
INDEX `contactid` (`contact-id`),
|
INDEX `contactid` (`contact-id`),
|
||||||
UNIQUE INDEX `gid_contactid` (`gid`,`contact-id`),
|
UNIQUE INDEX `gid_contactid` (`gid`,`contact-id`),
|
||||||
FOREIGN KEY (`gid`) REFERENCES `group` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`gid`) REFERENCES `group` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`contact-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`contact-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='privacy groups, member info';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='privacy circles, member info';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE gserver-tag
|
-- TABLE gserver-tag
|
||||||
|
@ -1114,9 +1154,9 @@ CREATE TABLE IF NOT EXISTS `photo` (
|
||||||
`scale` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '',
|
`scale` tinyint unsigned NOT NULL DEFAULT 0 COMMENT '',
|
||||||
`profile` boolean NOT NULL DEFAULT '0' COMMENT '',
|
`profile` boolean NOT NULL DEFAULT '0' COMMENT '',
|
||||||
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
|
`allow_cid` mediumtext COMMENT 'Access Control - list of allowed contact.id \'<19><78>\'',
|
||||||
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed groups',
|
`allow_gid` mediumtext COMMENT 'Access Control - list of allowed circles',
|
||||||
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
`deny_cid` mediumtext COMMENT 'Access Control - list of denied contact.id',
|
||||||
`deny_gid` mediumtext COMMENT 'Access Control - list of denied groups',
|
`deny_gid` mediumtext COMMENT 'Access Control - list of denied circles',
|
||||||
`accessible` boolean NOT NULL DEFAULT '0' COMMENT 'Make photo publicly accessible, ignoring permissions',
|
`accessible` boolean NOT NULL DEFAULT '0' COMMENT 'Make photo publicly accessible, ignoring permissions',
|
||||||
`backend-class` tinytext COMMENT 'Storage backend class',
|
`backend-class` tinytext COMMENT 'Storage backend class',
|
||||||
`backend-ref` text COMMENT 'Storage backend data reference',
|
`backend-ref` text COMMENT 'Storage backend data reference',
|
||||||
|
@ -1200,6 +1240,23 @@ CREATE TABLE IF NOT EXISTS `post-category` (
|
||||||
FOREIGN KEY (`tid`) REFERENCES `tag` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT
|
FOREIGN KEY (`tid`) REFERENCES `tag` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='post relation to categories';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='post relation to categories';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE post-counts
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `post-counts` (
|
||||||
|
`uri-id` int unsigned NOT NULL COMMENT 'Id of the item-uri table entry that contains the item uri',
|
||||||
|
`vid` smallint unsigned NOT NULL COMMENT 'Id of the verb table entry that contains the activity verbs',
|
||||||
|
`reaction` varchar(4) NOT NULL COMMENT 'Emoji Reaction',
|
||||||
|
`parent-uri-id` int unsigned COMMENT 'Id of the item-uri table that contains the parent uri',
|
||||||
|
`count` int unsigned DEFAULT 0 COMMENT 'Number of activities',
|
||||||
|
PRIMARY KEY(`uri-id`,`vid`,`reaction`),
|
||||||
|
INDEX `vid` (`vid`),
|
||||||
|
INDEX `parent-uri-id` (`parent-uri-id`),
|
||||||
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`vid`) REFERENCES `verb` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT,
|
||||||
|
FOREIGN KEY (`parent-uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Original remote activity';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE post-collection
|
-- TABLE post-collection
|
||||||
--
|
--
|
||||||
|
@ -1227,6 +1284,7 @@ CREATE TABLE IF NOT EXISTS `post-content` (
|
||||||
`location` varchar(255) NOT NULL DEFAULT '' COMMENT 'text location where this item originated',
|
`location` varchar(255) NOT NULL DEFAULT '' COMMENT 'text location where this item originated',
|
||||||
`coord` varchar(255) NOT NULL DEFAULT '' COMMENT 'longitude/latitude pair representing location where this item originated',
|
`coord` varchar(255) NOT NULL DEFAULT '' COMMENT 'longitude/latitude pair representing location where this item originated',
|
||||||
`language` text COMMENT 'Language information about this post',
|
`language` text COMMENT 'Language information about this post',
|
||||||
|
`sensitive` boolean COMMENT 'If true, this post contains sensitive content',
|
||||||
`app` varchar(255) NOT NULL DEFAULT '' COMMENT 'application which generated this item',
|
`app` varchar(255) NOT NULL DEFAULT '' COMMENT 'application which generated this item',
|
||||||
`rendered-hash` varchar(32) NOT NULL DEFAULT '' COMMENT '',
|
`rendered-hash` varchar(32) NOT NULL DEFAULT '' COMMENT '',
|
||||||
`rendered-html` mediumtext COMMENT 'item.body converted to html',
|
`rendered-html` mediumtext COMMENT 'item.body converted to html',
|
||||||
|
@ -1239,7 +1297,6 @@ CREATE TABLE IF NOT EXISTS `post-content` (
|
||||||
PRIMARY KEY(`uri-id`),
|
PRIMARY KEY(`uri-id`),
|
||||||
INDEX `plink` (`plink`(191)),
|
INDEX `plink` (`plink`(191)),
|
||||||
INDEX `resource-id` (`resource-id`),
|
INDEX `resource-id` (`resource-id`),
|
||||||
FULLTEXT INDEX `title-content-warning-body` (`title`,`content-warning`,`body`),
|
|
||||||
INDEX `quote-uri-id` (`quote-uri-id`),
|
INDEX `quote-uri-id` (`quote-uri-id`),
|
||||||
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`quote-uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`quote-uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
@ -1283,6 +1340,30 @@ CREATE TABLE IF NOT EXISTS `post-delivery-data` (
|
||||||
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Delivery data for items';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Delivery data for items';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE post-engagement
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `post-engagement` (
|
||||||
|
`uri-id` int unsigned NOT NULL COMMENT 'Id of the item-uri table entry that contains the item uri',
|
||||||
|
`owner-id` int unsigned NOT NULL DEFAULT 0 COMMENT 'Item owner',
|
||||||
|
`contact-type` tinyint NOT NULL DEFAULT 0 COMMENT 'Person, organisation, news, community, relay',
|
||||||
|
`media-type` tinyint NOT NULL DEFAULT 0 COMMENT 'Type of media in a bit array (1 = image, 2 = video, 4 = audio',
|
||||||
|
`language` char(2) COMMENT 'Language information about this post in the ISO 639-1 format',
|
||||||
|
`searchtext` mediumtext COMMENT 'Simplified text for the full text search',
|
||||||
|
`size` int unsigned COMMENT 'Body size',
|
||||||
|
`created` datetime COMMENT '',
|
||||||
|
`network` char(4) COMMENT '',
|
||||||
|
`restricted` boolean NOT NULL DEFAULT '0' COMMENT 'If true, this post is either unlisted or not from a federated network',
|
||||||
|
`comments` mediumint unsigned COMMENT 'Number of comments',
|
||||||
|
`activities` mediumint unsigned COMMENT 'Number of activities (like, dislike, ...)',
|
||||||
|
PRIMARY KEY(`uri-id`),
|
||||||
|
INDEX `owner-id` (`owner-id`),
|
||||||
|
INDEX `created` (`created`),
|
||||||
|
FULLTEXT INDEX `searchtext` (`searchtext`),
|
||||||
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`owner-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Engagement data per post';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE post-history
|
-- TABLE post-history
|
||||||
--
|
--
|
||||||
|
@ -1384,6 +1465,26 @@ CREATE TABLE IF NOT EXISTS `post-question-option` (
|
||||||
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Question option';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Question option';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE post-searchindex
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `post-searchindex` (
|
||||||
|
`uri-id` int unsigned NOT NULL COMMENT 'Id of the item-uri table entry that contains the item uri',
|
||||||
|
`owner-id` int unsigned NOT NULL DEFAULT 0 COMMENT 'Item owner',
|
||||||
|
`media-type` tinyint NOT NULL DEFAULT 0 COMMENT 'Type of media in a bit array (1 = image, 2 = video, 4 = audio',
|
||||||
|
`language` char(2) COMMENT 'Language information about this post in the ISO 639-1 format',
|
||||||
|
`searchtext` mediumtext COMMENT 'Simplified text for the full text search',
|
||||||
|
`size` int unsigned COMMENT 'Body size',
|
||||||
|
`created` datetime COMMENT '',
|
||||||
|
`restricted` boolean NOT NULL DEFAULT '0' COMMENT 'If true, this post is either unlisted or not from a federated network',
|
||||||
|
PRIMARY KEY(`uri-id`),
|
||||||
|
INDEX `owner-id` (`owner-id`),
|
||||||
|
INDEX `created` (`created`),
|
||||||
|
FULLTEXT INDEX `searchtext` (`searchtext`),
|
||||||
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`owner-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Content for all posts';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE post-tag
|
-- TABLE post-tag
|
||||||
--
|
--
|
||||||
|
@ -1476,7 +1577,8 @@ CREATE TABLE IF NOT EXISTS `post-user` (
|
||||||
INDEX `event-id` (`event-id`),
|
INDEX `event-id` (`event-id`),
|
||||||
INDEX `psid` (`psid`),
|
INDEX `psid` (`psid`),
|
||||||
INDEX `author-id_uid` (`author-id`,`uid`),
|
INDEX `author-id_uid` (`author-id`,`uid`),
|
||||||
INDEX `author-id_received` (`author-id`,`received`),
|
INDEX `author-id_created` (`author-id`,`created`),
|
||||||
|
INDEX `owner-id_created` (`owner-id`,`created`),
|
||||||
INDEX `parent-uri-id_uid` (`parent-uri-id`,`uid`),
|
INDEX `parent-uri-id_uid` (`parent-uri-id`,`uid`),
|
||||||
INDEX `uid_wall_received` (`uid`,`wall`,`received`),
|
INDEX `uid_wall_received` (`uid`,`wall`,`received`),
|
||||||
INDEX `uid_contactid` (`uid`,`contact-id`),
|
INDEX `uid_contactid` (`uid`,`contact-id`),
|
||||||
|
@ -1536,11 +1638,18 @@ CREATE TABLE IF NOT EXISTS `post-thread-user` (
|
||||||
INDEX `psid` (`psid`),
|
INDEX `psid` (`psid`),
|
||||||
INDEX `post-user-id` (`post-user-id`),
|
INDEX `post-user-id` (`post-user-id`),
|
||||||
INDEX `commented` (`commented`),
|
INDEX `commented` (`commented`),
|
||||||
|
INDEX `received` (`received`),
|
||||||
|
INDEX `author-id_created` (`author-id`,`created`),
|
||||||
|
INDEX `owner-id_created` (`owner-id`,`created`),
|
||||||
INDEX `uid_received` (`uid`,`received`),
|
INDEX `uid_received` (`uid`,`received`),
|
||||||
INDEX `uid_wall_received` (`uid`,`wall`,`received`),
|
INDEX `uid_wall_received` (`uid`,`wall`,`received`),
|
||||||
INDEX `uid_commented` (`uid`,`commented`),
|
INDEX `uid_commented` (`uid`,`commented`),
|
||||||
|
INDEX `uid_created` (`uid`,`created`),
|
||||||
INDEX `uid_starred` (`uid`,`starred`),
|
INDEX `uid_starred` (`uid`,`starred`),
|
||||||
INDEX `uid_mention` (`uid`,`mention`),
|
INDEX `uid_mention` (`uid`,`mention`),
|
||||||
|
INDEX `contact-id_commented` (`contact-id`,`commented`),
|
||||||
|
INDEX `contact-id_received` (`contact-id`,`received`),
|
||||||
|
INDEX `contact-id_created` (`contact-id`,`created`),
|
||||||
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`conversation-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`conversation-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`owner-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT,
|
FOREIGN KEY (`owner-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE RESTRICT,
|
||||||
|
@ -1586,7 +1695,7 @@ CREATE TABLE IF NOT EXISTS `profile` (
|
||||||
`profile-name` varchar(255) COMMENT 'Deprecated',
|
`profile-name` varchar(255) COMMENT 'Deprecated',
|
||||||
`is-default` boolean COMMENT 'Deprecated',
|
`is-default` boolean COMMENT 'Deprecated',
|
||||||
`hide-friends` boolean NOT NULL DEFAULT '0' COMMENT 'Hide friend list from viewers of this profile',
|
`hide-friends` boolean NOT NULL DEFAULT '0' COMMENT 'Hide friend list from viewers of this profile',
|
||||||
`name` varchar(255) NOT NULL DEFAULT '' COMMENT '',
|
`name` varchar(255) NOT NULL DEFAULT '' COMMENT 'Unused in favor of user.username',
|
||||||
`pdesc` varchar(255) COMMENT 'Deprecated',
|
`pdesc` varchar(255) COMMENT 'Deprecated',
|
||||||
`dob` varchar(32) NOT NULL DEFAULT '0000-00-00' COMMENT 'Day of birth',
|
`dob` varchar(32) NOT NULL DEFAULT '0000-00-00' COMMENT 'Day of birth',
|
||||||
`address` varchar(255) NOT NULL DEFAULT '' COMMENT '',
|
`address` varchar(255) NOT NULL DEFAULT '' COMMENT '',
|
||||||
|
@ -1627,7 +1736,6 @@ CREATE TABLE IF NOT EXISTS `profile` (
|
||||||
`net-publish` boolean NOT NULL DEFAULT '0' COMMENT 'publish profile in global directory',
|
`net-publish` boolean NOT NULL DEFAULT '0' COMMENT 'publish profile in global directory',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
INDEX `uid_is-default` (`uid`,`is-default`),
|
INDEX `uid_is-default` (`uid`,`is-default`),
|
||||||
FULLTEXT INDEX `pub_keywords` (`pub_keywords`),
|
|
||||||
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='user profiles data';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='user profiles data';
|
||||||
|
|
||||||
|
@ -1695,19 +1803,34 @@ CREATE TABLE IF NOT EXISTS `report` (
|
||||||
`uid` mediumint unsigned COMMENT 'Reporting user',
|
`uid` mediumint unsigned COMMENT 'Reporting user',
|
||||||
`reporter-id` int unsigned COMMENT 'Reporting contact',
|
`reporter-id` int unsigned COMMENT 'Reporting contact',
|
||||||
`cid` int unsigned NOT NULL COMMENT 'Reported contact',
|
`cid` int unsigned NOT NULL COMMENT 'Reported contact',
|
||||||
|
`gsid` int unsigned COMMENT 'Reported contact server',
|
||||||
`comment` text COMMENT 'Report',
|
`comment` text COMMENT 'Report',
|
||||||
`category` varchar(20) COMMENT 'Category of the report (spam, violation, other)',
|
`category-id` int unsigned NOT NULL DEFAULT 1 COMMENT 'Report category, one of Entity Report::CATEGORY_*',
|
||||||
`rules` text COMMENT 'Violated rules',
|
|
||||||
`forward` boolean COMMENT 'Forward the report to the remote server',
|
`forward` boolean COMMENT 'Forward the report to the remote server',
|
||||||
`created` datetime NOT NULL DEFAULT '0001-01-01 00:00:00' COMMENT '',
|
`public-remarks` text COMMENT 'Remarks shared with the reporter',
|
||||||
`status` tinyint unsigned COMMENT 'Status of the report',
|
`private-remarks` text COMMENT 'Remarks shared with the moderation team',
|
||||||
|
`last-editor-uid` mediumint unsigned COMMENT 'Last editor user',
|
||||||
|
`assigned-uid` mediumint unsigned COMMENT 'Assigned moderator user',
|
||||||
|
`status` tinyint unsigned NOT NULL COMMENT 'Status of the report, one of Entity Report::STATUS_*',
|
||||||
|
`resolution` tinyint unsigned COMMENT 'Resolution of the report, one of Entity Report::RESOLUTION_*',
|
||||||
|
`created` datetime(6) NOT NULL DEFAULT '0001-01-01 00:00:00.000000' COMMENT '',
|
||||||
|
`edited` datetime(6) COMMENT 'Last time the report has been edited',
|
||||||
PRIMARY KEY(`id`),
|
PRIMARY KEY(`id`),
|
||||||
INDEX `uid` (`uid`),
|
INDEX `uid` (`uid`),
|
||||||
INDEX `cid` (`cid`),
|
INDEX `cid` (`cid`),
|
||||||
INDEX `reporter-id` (`reporter-id`),
|
INDEX `reporter-id` (`reporter-id`),
|
||||||
|
INDEX `gsid` (`gsid`),
|
||||||
|
INDEX `last-editor-uid` (`last-editor-uid`),
|
||||||
|
INDEX `assigned-uid` (`assigned-uid`),
|
||||||
|
INDEX `status-resolution` (`status`,`resolution`),
|
||||||
|
INDEX `created` (`created`),
|
||||||
|
INDEX `edited` (`edited`),
|
||||||
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`reporter-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`reporter-id`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`cid`) REFERENCES `contact` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`gsid`) REFERENCES `gserver` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`last-editor-uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
|
FOREIGN KEY (`assigned-uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='';
|
||||||
|
|
||||||
--
|
--
|
||||||
|
@ -1721,7 +1844,18 @@ CREATE TABLE IF NOT EXISTS `report-post` (
|
||||||
INDEX `uri-id` (`uri-id`),
|
INDEX `uri-id` (`uri-id`),
|
||||||
FOREIGN KEY (`rid`) REFERENCES `report` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
FOREIGN KEY (`rid`) REFERENCES `report` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE,
|
||||||
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`uri-id`) REFERENCES `item-uri` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Individual posts attached to a moderation report';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE report-rule
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `report-rule` (
|
||||||
|
`rid` int unsigned NOT NULL COMMENT 'Report id',
|
||||||
|
`line-id` int unsigned NOT NULL COMMENT 'Terms of service rule line number, may become invalid after a TOS change.',
|
||||||
|
`text` text NOT NULL COMMENT 'Terms of service rule text recorded at the time of the report',
|
||||||
|
PRIMARY KEY(`rid`,`line-id`),
|
||||||
|
FOREIGN KEY (`rid`) REFERENCES `report` (`id`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Terms of service rule lines relevant to a moderation report';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE search
|
-- TABLE search
|
||||||
|
@ -1782,6 +1916,16 @@ CREATE TABLE IF NOT EXISTS `subscription` (
|
||||||
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
FOREIGN KEY (`uid`) REFERENCES `user` (`uid`) ON UPDATE RESTRICT ON DELETE CASCADE
|
||||||
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Push Subscription for the API';
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Push Subscription for the API';
|
||||||
|
|
||||||
|
--
|
||||||
|
-- TABLE check-full-text-search
|
||||||
|
--
|
||||||
|
CREATE TABLE IF NOT EXISTS `check-full-text-search` (
|
||||||
|
`pid` int unsigned NOT NULL COMMENT 'The ID of the process',
|
||||||
|
`searchtext` mediumtext COMMENT 'Simplified text for the full text search',
|
||||||
|
PRIMARY KEY(`pid`),
|
||||||
|
FULLTEXT INDEX `searchtext` (`searchtext`)
|
||||||
|
) DEFAULT COLLATE utf8mb4_general_ci COMMENT='Check for a full text search match in user defined channels before storing the message in the system';
|
||||||
|
|
||||||
--
|
--
|
||||||
-- TABLE userd
|
-- TABLE userd
|
||||||
--
|
--
|
||||||
|
@ -1804,12 +1948,13 @@ CREATE TABLE IF NOT EXISTS `user-contact` (
|
||||||
`collapsed` boolean COMMENT 'Posts from this contact are collapsed',
|
`collapsed` boolean COMMENT 'Posts from this contact are collapsed',
|
||||||
`hidden` boolean COMMENT 'This contact is hidden from the others',
|
`hidden` boolean COMMENT 'This contact is hidden from the others',
|
||||||
`is-blocked` boolean COMMENT 'User is blocked by this contact',
|
`is-blocked` boolean COMMENT 'User is blocked by this contact',
|
||||||
|
`channel-frequency` tinyint unsigned COMMENT 'Controls the frequency of the appearance of this contact in channels',
|
||||||
`pending` boolean COMMENT '',
|
`pending` boolean COMMENT '',
|
||||||
`rel` tinyint unsigned COMMENT 'The kind of the relation between the user and the contact',
|
`rel` tinyint unsigned COMMENT 'The kind of the relation between the user and the contact',
|
||||||
`info` mediumtext COMMENT '',
|
`info` mediumtext COMMENT '',
|
||||||
`notify_new_posts` boolean COMMENT '',
|
`notify_new_posts` boolean COMMENT '',
|
||||||
`remote_self` boolean COMMENT '',
|
`remote_self` tinyint unsigned COMMENT '0 => No mirroring, 1-2 => Mirror as own post, 3 => Mirror as reshare',
|
||||||
`fetch_further_information` tinyint unsigned COMMENT '',
|
`fetch_further_information` tinyint unsigned COMMENT '0 => None, 1 => Fetch information, 3 => Fetch keywords, 2 => Fetch both',
|
||||||
`ffi_keyword_denylist` text COMMENT '',
|
`ffi_keyword_denylist` text COMMENT '',
|
||||||
`subhub` boolean COMMENT '',
|
`subhub` boolean COMMENT '',
|
||||||
`hub-verify` varbinary(383) COMMENT '',
|
`hub-verify` varbinary(383) COMMENT '',
|
||||||
|
@ -1872,7 +2017,130 @@ CREATE VIEW `application-view` AS SELECT
|
||||||
`application-token`.`follow` AS `follow`,
|
`application-token`.`follow` AS `follow`,
|
||||||
`application-token`.`push` AS `push`
|
`application-token`.`push` AS `push`
|
||||||
FROM `application-token`
|
FROM `application-token`
|
||||||
INNER JOIN `application` ON `application-token`.`application-id` = `application`.`id`;
|
INNER JOIN `application` ON `application-token`.`application-id` = `application`.`id`
|
||||||
|
INNER JOIN `user` ON `user`.`uid` = `application-token`.`uid` AND `user`.`verified` AND NOT `user`.`blocked` AND NOT `user`.`account_removed` AND NOT `user`.`account_expired`;
|
||||||
|
|
||||||
|
--
|
||||||
|
-- VIEW circle-member-view
|
||||||
|
--
|
||||||
|
DROP VIEW IF EXISTS `circle-member-view`;
|
||||||
|
CREATE VIEW `circle-member-view` AS SELECT
|
||||||
|
`group_member`.`id` AS `id`,
|
||||||
|
`group`.`uid` AS `uid`,
|
||||||
|
`group_member`.`contact-id` AS `contact-id`,
|
||||||
|
`contact`.`uri-id` AS `contact-uri-id`,
|
||||||
|
`contact`.`url` AS `contact-link`,
|
||||||
|
`contact`.`addr` AS `contact-addr`,
|
||||||
|
`contact`.`name` AS `contact-name`,
|
||||||
|
`contact`.`nick` AS `contact-nick`,
|
||||||
|
`contact`.`thumb` AS `contact-avatar`,
|
||||||
|
`contact`.`network` AS `contact-network`,
|
||||||
|
`contact`.`blocked` AS `contact-blocked`,
|
||||||
|
`contact`.`hidden` AS `contact-hidden`,
|
||||||
|
`contact`.`readonly` AS `contact-readonly`,
|
||||||
|
`contact`.`archive` AS `contact-archive`,
|
||||||
|
`contact`.`pending` AS `contact-pending`,
|
||||||
|
`contact`.`self` AS `contact-self`,
|
||||||
|
`contact`.`rel` AS `contact-rel`,
|
||||||
|
`contact`.`contact-type` AS `contact-contact-type`,
|
||||||
|
`group_member`.`gid` AS `circle-id`,
|
||||||
|
`group`.`visible` AS `circle-visible`,
|
||||||
|
`group`.`deleted` AS `circle-deleted`,
|
||||||
|
`group`.`name` AS `circle-name`
|
||||||
|
FROM `group_member`
|
||||||
|
INNER JOIN `contact` ON `group_member`.`contact-id` = `contact`.`id`
|
||||||
|
INNER JOIN `group` ON `group_member`.`gid` = `group`.`id`;
|
||||||
|
|
||||||
|
--
|
||||||
|
-- VIEW post-counts-view
|
||||||
|
--
|
||||||
|
DROP VIEW IF EXISTS `post-counts-view`;
|
||||||
|
CREATE VIEW `post-counts-view` AS SELECT
|
||||||
|
`post-counts`.`uri-id` AS `uri-id`,
|
||||||
|
`post-counts`.`vid` AS `vid`,
|
||||||
|
`verb`.`name` AS `verb`,
|
||||||
|
`post-counts`.`reaction` AS `reaction`,
|
||||||
|
`post-counts`.`parent-uri-id` AS `parent-uri-id`,
|
||||||
|
`post-counts`.`count` AS `count`
|
||||||
|
FROM `post-counts`
|
||||||
|
INNER JOIN `verb` ON `verb`.`id` = `post-counts`.`vid`;
|
||||||
|
|
||||||
|
--
|
||||||
|
-- VIEW post-timeline-view
|
||||||
|
--
|
||||||
|
DROP VIEW IF EXISTS `post-timeline-view`;
|
||||||
|
CREATE VIEW `post-timeline-view` AS SELECT
|
||||||
|
`post-user`.`uid` AS `uid`,
|
||||||
|
`post-user`.`uri-id` AS `uri-id`,
|
||||||
|
`post-user`.`gravity` AS `gravity`,
|
||||||
|
`post-user`.`created` AS `created`,
|
||||||
|
`post-user`.`edited` AS `edited`,
|
||||||
|
`post-thread-user`.`commented` AS `commented`,
|
||||||
|
`post-user`.`received` AS `received`,
|
||||||
|
`post-thread-user`.`changed` AS `changed`,
|
||||||
|
`post-user`.`private` AS `private`,
|
||||||
|
`post-user`.`visible` AS `visible`,
|
||||||
|
`post-user`.`deleted` AS `deleted`,
|
||||||
|
`post-user`.`origin` AS `origin`,
|
||||||
|
`post-user`.`global` AS `global`,
|
||||||
|
`post-user`.`network` AS `network`,
|
||||||
|
`post-user`.`protocol` AS `protocol`,
|
||||||
|
`post-user`.`vid` AS `vid`,
|
||||||
|
`post-user`.`contact-id` AS `contact-id`,
|
||||||
|
`contact`.`blocked` AS `contact-blocked`,
|
||||||
|
`contact`.`readonly` AS `contact-readonly`,
|
||||||
|
`contact`.`pending` AS `contact-pending`,
|
||||||
|
`contact`.`rel` AS `contact-rel`,
|
||||||
|
`contact`.`uid` AS `contact-uid`,
|
||||||
|
`contact`.`self` AS `self`,
|
||||||
|
`post-user`.`author-id` AS `author-id`,
|
||||||
|
`author`.`blocked` AS `author-blocked`,
|
||||||
|
`author`.`hidden` AS `author-hidden`,
|
||||||
|
`author`.`gsid` AS `author-gsid`,
|
||||||
|
`post-user`.`owner-id` AS `owner-id`,
|
||||||
|
`owner`.`blocked` AS `owner-blocked`,
|
||||||
|
`owner`.`gsid` AS `owner-gsid`,
|
||||||
|
`post-user`.`causer-id` AS `causer-id`,
|
||||||
|
`causer`.`blocked` AS `causer-blocked`,
|
||||||
|
`causer`.`gsid` AS `causer-gsid`
|
||||||
|
FROM `post-user`
|
||||||
|
LEFT JOIN `post-thread-user` ON `post-thread-user`.`uri-id` = `post-user`.`parent-uri-id` AND `post-thread-user`.`uid` = `post-user`.`uid`
|
||||||
|
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-user`.`contact-id`
|
||||||
|
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post-user`.`author-id`
|
||||||
|
STRAIGHT_JOIN `contact` AS `owner` ON `owner`.`id` = `post-user`.`owner-id`
|
||||||
|
LEFT JOIN `contact` AS `causer` ON `causer`.`id` = `post-user`.`causer-id`;
|
||||||
|
|
||||||
|
--
|
||||||
|
-- VIEW post-searchindex-user-view
|
||||||
|
--
|
||||||
|
DROP VIEW IF EXISTS `post-searchindex-user-view`;
|
||||||
|
CREATE VIEW `post-searchindex-user-view` AS SELECT
|
||||||
|
`post-thread-user`.`uid` AS `uid`,
|
||||||
|
`post-searchindex`.`uri-id` AS `uri-id`,
|
||||||
|
`post-searchindex`.`owner-id` AS `owner-id`,
|
||||||
|
`post-searchindex`.`media-type` AS `media-type`,
|
||||||
|
`post-searchindex`.`language` AS `language`,
|
||||||
|
`post-searchindex`.`searchtext` AS `searchtext`,
|
||||||
|
`post-searchindex`.`size` AS `size`,
|
||||||
|
`post-thread-user`.`commented` AS `commented`,
|
||||||
|
`post-thread-user`.`received` AS `received`,
|
||||||
|
`post-thread-user`.`created` AS `created`,
|
||||||
|
`post-thread-user`.`network` AS `network`,
|
||||||
|
`post-searchindex`.`language` AS `restricted`,
|
||||||
|
0 AS `comments`,
|
||||||
|
0 AS `activities`
|
||||||
|
FROM `post-thread-user`
|
||||||
|
INNER JOIN `post-searchindex` ON `post-searchindex`.`uri-id` = `post-thread-user`.`uri-id`
|
||||||
|
INNER JOIN `post-user` ON `post-user`.`id` = `post-thread-user`.`post-user-id`
|
||||||
|
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
||||||
|
STRAIGHT_JOIN `contact` AS `authorcontact` ON `authorcontact`.`id` = `post-thread-user`.`author-id`
|
||||||
|
STRAIGHT_JOIN `contact` AS `ownercontact` ON `ownercontact`.`id` = `post-thread-user`.`owner-id`
|
||||||
|
WHERE `post-user`.`visible` AND NOT `post-user`.`deleted`
|
||||||
|
AND (NOT `contact`.`readonly` AND NOT `contact`.`blocked` AND NOT `contact`.`pending`)
|
||||||
|
AND (`post-thread-user`.`hidden` IS NULL OR NOT `post-thread-user`.`hidden`)
|
||||||
|
AND NOT `authorcontact`.`blocked` AND NOT `ownercontact`.`blocked`
|
||||||
|
AND NOT EXISTS(SELECT `cid` FROM `user-contact` WHERE `uid` = `post-thread-user`.`uid` AND `cid` IN (`authorcontact`.`id`, `ownercontact`.`id`) AND (`blocked` OR `ignored`))
|
||||||
|
AND NOT EXISTS(SELECT `gsid` FROM `user-gserver` WHERE `uid` = `post-thread-user`.`uid` AND `gsid` IN (`authorcontact`.`gsid`, `ownercontact`.`gsid`) AND `ignored`);
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW post-user-view
|
-- VIEW post-user-view
|
||||||
|
@ -1882,7 +2150,7 @@ CREATE VIEW `post-user-view` AS SELECT
|
||||||
`post-user`.`id` AS `id`,
|
`post-user`.`id` AS `id`,
|
||||||
`post-user`.`id` AS `post-user-id`,
|
`post-user`.`id` AS `post-user-id`,
|
||||||
`post-user`.`uid` AS `uid`,
|
`post-user`.`uid` AS `uid`,
|
||||||
`parent-post`.`id` AS `parent`,
|
`post-thread-user`.`post-user-id` AS `parent`,
|
||||||
`item-uri`.`uri` AS `uri`,
|
`item-uri`.`uri` AS `uri`,
|
||||||
`post-user`.`uri-id` AS `uri-id`,
|
`post-user`.`uri-id` AS `uri-id`,
|
||||||
`parent-item-uri`.`uri` AS `parent-uri`,
|
`parent-item-uri`.`uri` AS `parent-uri`,
|
||||||
|
@ -1931,6 +2199,7 @@ CREATE VIEW `post-user-view` AS SELECT
|
||||||
`post-content`.`plink` AS `plink`,
|
`post-content`.`plink` AS `plink`,
|
||||||
`post-content`.`location` AS `location`,
|
`post-content`.`location` AS `location`,
|
||||||
`post-content`.`coord` AS `coord`,
|
`post-content`.`coord` AS `coord`,
|
||||||
|
`post-content`.`sensitive` AS `sensitive`,
|
||||||
`post-content`.`app` AS `app`,
|
`post-content`.`app` AS `app`,
|
||||||
`post-content`.`object-type` AS `object-type`,
|
`post-content`.`object-type` AS `object-type`,
|
||||||
`post-content`.`object` AS `object`,
|
`post-content`.`object` AS `object`,
|
||||||
|
@ -1968,23 +2237,28 @@ CREATE VIEW `post-user-view` AS SELECT
|
||||||
`author`.`addr` AS `author-addr`,
|
`author`.`addr` AS `author-addr`,
|
||||||
IF (`contact`.`url` = `author`.`url` AND `contact`.`name` != '', `contact`.`name`, `author`.`name`) AS `author-name`,
|
IF (`contact`.`url` = `author`.`url` AND `contact`.`name` != '', `contact`.`name`, `author`.`name`) AS `author-name`,
|
||||||
`author`.`nick` AS `author-nick`,
|
`author`.`nick` AS `author-nick`,
|
||||||
|
`author`.`alias` AS `author-alias`,
|
||||||
IF (`contact`.`url` = `author`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `author`.`thumb`) AS `author-avatar`,
|
IF (`contact`.`url` = `author`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `author`.`thumb`) AS `author-avatar`,
|
||||||
`author`.`network` AS `author-network`,
|
`author`.`network` AS `author-network`,
|
||||||
`author`.`blocked` AS `author-blocked`,
|
`author`.`blocked` AS `author-blocked`,
|
||||||
`author`.`hidden` AS `author-hidden`,
|
`author`.`hidden` AS `author-hidden`,
|
||||||
`author`.`updated` AS `author-updated`,
|
`author`.`updated` AS `author-updated`,
|
||||||
|
`author`.`contact-type` AS `author-contact-type`,
|
||||||
`author`.`gsid` AS `author-gsid`,
|
`author`.`gsid` AS `author-gsid`,
|
||||||
|
`author`.`baseurl` AS `author-baseurl`,
|
||||||
`post-user`.`owner-id` AS `owner-id`,
|
`post-user`.`owner-id` AS `owner-id`,
|
||||||
`owner`.`uri-id` AS `owner-uri-id`,
|
`owner`.`uri-id` AS `owner-uri-id`,
|
||||||
`owner`.`url` AS `owner-link`,
|
`owner`.`url` AS `owner-link`,
|
||||||
`owner`.`addr` AS `owner-addr`,
|
`owner`.`addr` AS `owner-addr`,
|
||||||
IF (`contact`.`url` = `owner`.`url` AND `contact`.`name` != '', `contact`.`name`, `owner`.`name`) AS `owner-name`,
|
IF (`contact`.`url` = `owner`.`url` AND `contact`.`name` != '', `contact`.`name`, `owner`.`name`) AS `owner-name`,
|
||||||
`owner`.`nick` AS `owner-nick`,
|
`owner`.`nick` AS `owner-nick`,
|
||||||
|
`owner`.`alias` AS `owner-alias`,
|
||||||
IF (`contact`.`url` = `owner`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `owner`.`thumb`) AS `owner-avatar`,
|
IF (`contact`.`url` = `owner`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `owner`.`thumb`) AS `owner-avatar`,
|
||||||
`owner`.`network` AS `owner-network`,
|
`owner`.`network` AS `owner-network`,
|
||||||
`owner`.`blocked` AS `owner-blocked`,
|
`owner`.`blocked` AS `owner-blocked`,
|
||||||
`owner`.`hidden` AS `owner-hidden`,
|
`owner`.`hidden` AS `owner-hidden`,
|
||||||
`owner`.`updated` AS `owner-updated`,
|
`owner`.`updated` AS `owner-updated`,
|
||||||
|
`owner`.`gsid` AS `owner-gsid`,
|
||||||
`owner`.`contact-type` AS `owner-contact-type`,
|
`owner`.`contact-type` AS `owner-contact-type`,
|
||||||
`post-user`.`causer-id` AS `causer-id`,
|
`post-user`.`causer-id` AS `causer-id`,
|
||||||
`causer`.`uri-id` AS `causer-uri-id`,
|
`causer`.`uri-id` AS `causer-uri-id`,
|
||||||
|
@ -1992,10 +2266,12 @@ CREATE VIEW `post-user-view` AS SELECT
|
||||||
`causer`.`addr` AS `causer-addr`,
|
`causer`.`addr` AS `causer-addr`,
|
||||||
`causer`.`name` AS `causer-name`,
|
`causer`.`name` AS `causer-name`,
|
||||||
`causer`.`nick` AS `causer-nick`,
|
`causer`.`nick` AS `causer-nick`,
|
||||||
|
`causer`.`alias` AS `causer-alias`,
|
||||||
`causer`.`thumb` AS `causer-avatar`,
|
`causer`.`thumb` AS `causer-avatar`,
|
||||||
`causer`.`network` AS `causer-network`,
|
`causer`.`network` AS `causer-network`,
|
||||||
`causer`.`blocked` AS `causer-blocked`,
|
`causer`.`blocked` AS `causer-blocked`,
|
||||||
`causer`.`hidden` AS `causer-hidden`,
|
`causer`.`hidden` AS `causer-hidden`,
|
||||||
|
`causer`.`gsid` AS `causer-gsid`,
|
||||||
`causer`.`contact-type` AS `causer-contact-type`,
|
`causer`.`contact-type` AS `causer-contact-type`,
|
||||||
`post-delivery-data`.`postopts` AS `postopts`,
|
`post-delivery-data`.`postopts` AS `postopts`,
|
||||||
`post-delivery-data`.`inform` AS `inform`,
|
`post-delivery-data`.`inform` AS `inform`,
|
||||||
|
@ -2025,14 +2301,14 @@ CREATE VIEW `post-user-view` AS SELECT
|
||||||
EXISTS(SELECT `id` FROM `post-media` WHERE `post-media`.`uri-id` = `post-user`.`uri-id`) AS `has-media`,
|
EXISTS(SELECT `id` FROM `post-media` WHERE `post-media`.`uri-id` = `post-user`.`uri-id`) AS `has-media`,
|
||||||
`diaspora-interaction`.`interaction` AS `signed_text`,
|
`diaspora-interaction`.`interaction` AS `signed_text`,
|
||||||
`parent-item-uri`.`guid` AS `parent-guid`,
|
`parent-item-uri`.`guid` AS `parent-guid`,
|
||||||
`parent-post`.`network` AS `parent-network`,
|
`post-thread-user`.`network` AS `parent-network`,
|
||||||
`parent-post`.`author-id` AS `parent-author-id`,
|
`post-thread-user`.`author-id` AS `parent-author-id`,
|
||||||
`parent-post-author`.`url` AS `parent-author-link`,
|
`parent-post-author`.`url` AS `parent-author-link`,
|
||||||
`parent-post-author`.`name` AS `parent-author-name`,
|
`parent-post-author`.`name` AS `parent-author-name`,
|
||||||
`parent-post-author`.`nick` AS `parent-author-nick`,
|
`parent-post-author`.`nick` AS `parent-author-nick`,
|
||||||
`parent-post-author`.`network` AS `parent-author-network`
|
`parent-post-author`.`network` AS `parent-author-network`
|
||||||
FROM `post-user`
|
FROM `post-user`
|
||||||
STRAIGHT_JOIN `post-thread-user` ON `post-thread-user`.`uri-id` = `post-user`.`parent-uri-id` AND `post-thread-user`.`uid` = `post-user`.`uid`
|
INNER JOIN `post-thread-user` ON `post-thread-user`.`uri-id` = `post-user`.`parent-uri-id` AND `post-thread-user`.`uid` = `post-user`.`uid`
|
||||||
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-user`.`contact-id`
|
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-user`.`contact-id`
|
||||||
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post-user`.`author-id`
|
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post-user`.`author-id`
|
||||||
STRAIGHT_JOIN `contact` AS `owner` ON `owner`.`id` = `post-user`.`owner-id`
|
STRAIGHT_JOIN `contact` AS `owner` ON `owner`.`id` = `post-user`.`owner-id`
|
||||||
|
@ -2050,8 +2326,7 @@ CREATE VIEW `post-user-view` AS SELECT
|
||||||
LEFT JOIN `post-delivery-data` ON `post-delivery-data`.`uri-id` = `post-user`.`uri-id` AND `post-user`.`origin`
|
LEFT JOIN `post-delivery-data` ON `post-delivery-data`.`uri-id` = `post-user`.`uri-id` AND `post-user`.`origin`
|
||||||
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post-user`.`uri-id`
|
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post-user`.`uri-id`
|
||||||
LEFT JOIN `permissionset` ON `permissionset`.`id` = `post-user`.`psid`
|
LEFT JOIN `permissionset` ON `permissionset`.`id` = `post-user`.`psid`
|
||||||
LEFT JOIN `post-user` AS `parent-post` ON `parent-post`.`uri-id` = `post-user`.`parent-uri-id` AND `parent-post`.`uid` = `post-user`.`uid`
|
LEFT JOIN `contact` AS `parent-post-author` ON `parent-post-author`.`id` = `post-thread-user`.`author-id`;
|
||||||
LEFT JOIN `contact` AS `parent-post-author` ON `parent-post-author`.`id` = `parent-post`.`author-id`;
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW post-thread-user-view
|
-- VIEW post-thread-user-view
|
||||||
|
@ -2061,7 +2336,7 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
`post-user`.`id` AS `id`,
|
`post-user`.`id` AS `id`,
|
||||||
`post-user`.`id` AS `post-user-id`,
|
`post-user`.`id` AS `post-user-id`,
|
||||||
`post-thread-user`.`uid` AS `uid`,
|
`post-thread-user`.`uid` AS `uid`,
|
||||||
`parent-post`.`id` AS `parent`,
|
`post-thread-user`.`post-user-id` AS `parent`,
|
||||||
`item-uri`.`uri` AS `uri`,
|
`item-uri`.`uri` AS `uri`,
|
||||||
`post-thread-user`.`uri-id` AS `uri-id`,
|
`post-thread-user`.`uri-id` AS `uri-id`,
|
||||||
`parent-item-uri`.`uri` AS `parent-uri`,
|
`parent-item-uri`.`uri` AS `parent-uri`,
|
||||||
|
@ -2109,6 +2384,7 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
`post-content`.`plink` AS `plink`,
|
`post-content`.`plink` AS `plink`,
|
||||||
`post-content`.`location` AS `location`,
|
`post-content`.`location` AS `location`,
|
||||||
`post-content`.`coord` AS `coord`,
|
`post-content`.`coord` AS `coord`,
|
||||||
|
`post-content`.`sensitive` AS `sensitive`,
|
||||||
`post-content`.`app` AS `app`,
|
`post-content`.`app` AS `app`,
|
||||||
`post-content`.`object-type` AS `object-type`,
|
`post-content`.`object-type` AS `object-type`,
|
||||||
`post-content`.`object` AS `object`,
|
`post-content`.`object` AS `object`,
|
||||||
|
@ -2130,6 +2406,7 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
`contact`.`pending` AS `contact-pending`,
|
`contact`.`pending` AS `contact-pending`,
|
||||||
`contact`.`rel` AS `contact-rel`,
|
`contact`.`rel` AS `contact-rel`,
|
||||||
`contact`.`uid` AS `contact-uid`,
|
`contact`.`uid` AS `contact-uid`,
|
||||||
|
`contact`.`gsid` AS `contact-gsid`,
|
||||||
`contact`.`contact-type` AS `contact-contact-type`,
|
`contact`.`contact-type` AS `contact-contact-type`,
|
||||||
IF (`post-user`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `contact`.`writable`) AS `writable`,
|
IF (`post-user`.`network` IN ('apub', 'dfrn', 'dspr', 'stat'), true, `contact`.`writable`) AS `writable`,
|
||||||
`contact`.`self` AS `self`,
|
`contact`.`self` AS `self`,
|
||||||
|
@ -2146,11 +2423,13 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
`author`.`addr` AS `author-addr`,
|
`author`.`addr` AS `author-addr`,
|
||||||
IF (`contact`.`url` = `author`.`url` AND `contact`.`name` != '', `contact`.`name`, `author`.`name`) AS `author-name`,
|
IF (`contact`.`url` = `author`.`url` AND `contact`.`name` != '', `contact`.`name`, `author`.`name`) AS `author-name`,
|
||||||
`author`.`nick` AS `author-nick`,
|
`author`.`nick` AS `author-nick`,
|
||||||
|
`author`.`alias` AS `author-alias`,
|
||||||
IF (`contact`.`url` = `author`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `author`.`thumb`) AS `author-avatar`,
|
IF (`contact`.`url` = `author`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `author`.`thumb`) AS `author-avatar`,
|
||||||
`author`.`network` AS `author-network`,
|
`author`.`network` AS `author-network`,
|
||||||
`author`.`blocked` AS `author-blocked`,
|
`author`.`blocked` AS `author-blocked`,
|
||||||
`author`.`hidden` AS `author-hidden`,
|
`author`.`hidden` AS `author-hidden`,
|
||||||
`author`.`updated` AS `author-updated`,
|
`author`.`updated` AS `author-updated`,
|
||||||
|
`author`.`contact-type` AS `author-contact-type`,
|
||||||
`author`.`gsid` AS `author-gsid`,
|
`author`.`gsid` AS `author-gsid`,
|
||||||
`post-thread-user`.`owner-id` AS `owner-id`,
|
`post-thread-user`.`owner-id` AS `owner-id`,
|
||||||
`owner`.`uri-id` AS `owner-uri-id`,
|
`owner`.`uri-id` AS `owner-uri-id`,
|
||||||
|
@ -2158,11 +2437,13 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
`owner`.`addr` AS `owner-addr`,
|
`owner`.`addr` AS `owner-addr`,
|
||||||
IF (`contact`.`url` = `owner`.`url` AND `contact`.`name` != '', `contact`.`name`, `owner`.`name`) AS `owner-name`,
|
IF (`contact`.`url` = `owner`.`url` AND `contact`.`name` != '', `contact`.`name`, `owner`.`name`) AS `owner-name`,
|
||||||
`owner`.`nick` AS `owner-nick`,
|
`owner`.`nick` AS `owner-nick`,
|
||||||
|
`owner`.`alias` AS `owner-alias`,
|
||||||
IF (`contact`.`url` = `owner`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `owner`.`thumb`) AS `owner-avatar`,
|
IF (`contact`.`url` = `owner`.`url` AND `contact`.`thumb` != '', `contact`.`thumb`, `owner`.`thumb`) AS `owner-avatar`,
|
||||||
`owner`.`network` AS `owner-network`,
|
`owner`.`network` AS `owner-network`,
|
||||||
`owner`.`blocked` AS `owner-blocked`,
|
`owner`.`blocked` AS `owner-blocked`,
|
||||||
`owner`.`hidden` AS `owner-hidden`,
|
`owner`.`hidden` AS `owner-hidden`,
|
||||||
`owner`.`updated` AS `owner-updated`,
|
`owner`.`updated` AS `owner-updated`,
|
||||||
|
`owner`.`gsid` AS `owner-gsid`,
|
||||||
`owner`.`contact-type` AS `owner-contact-type`,
|
`owner`.`contact-type` AS `owner-contact-type`,
|
||||||
`post-thread-user`.`causer-id` AS `causer-id`,
|
`post-thread-user`.`causer-id` AS `causer-id`,
|
||||||
`causer`.`uri-id` AS `causer-uri-id`,
|
`causer`.`uri-id` AS `causer-uri-id`,
|
||||||
|
@ -2170,10 +2451,12 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
`causer`.`addr` AS `causer-addr`,
|
`causer`.`addr` AS `causer-addr`,
|
||||||
`causer`.`name` AS `causer-name`,
|
`causer`.`name` AS `causer-name`,
|
||||||
`causer`.`nick` AS `causer-nick`,
|
`causer`.`nick` AS `causer-nick`,
|
||||||
|
`causer`.`alias` AS `causer-alias`,
|
||||||
`causer`.`thumb` AS `causer-avatar`,
|
`causer`.`thumb` AS `causer-avatar`,
|
||||||
`causer`.`network` AS `causer-network`,
|
`causer`.`network` AS `causer-network`,
|
||||||
`causer`.`blocked` AS `causer-blocked`,
|
`causer`.`blocked` AS `causer-blocked`,
|
||||||
`causer`.`hidden` AS `causer-hidden`,
|
`causer`.`hidden` AS `causer-hidden`,
|
||||||
|
`causer`.`gsid` AS `causer-gsid`,
|
||||||
`causer`.`contact-type` AS `causer-contact-type`,
|
`causer`.`contact-type` AS `causer-contact-type`,
|
||||||
`post-delivery-data`.`postopts` AS `postopts`,
|
`post-delivery-data`.`postopts` AS `postopts`,
|
||||||
`post-delivery-data`.`inform` AS `inform`,
|
`post-delivery-data`.`inform` AS `inform`,
|
||||||
|
@ -2203,11 +2486,12 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
EXISTS(SELECT `id` FROM `post-media` WHERE `post-media`.`uri-id` = `post-thread-user`.`uri-id`) AS `has-media`,
|
EXISTS(SELECT `id` FROM `post-media` WHERE `post-media`.`uri-id` = `post-thread-user`.`uri-id`) AS `has-media`,
|
||||||
`diaspora-interaction`.`interaction` AS `signed_text`,
|
`diaspora-interaction`.`interaction` AS `signed_text`,
|
||||||
`parent-item-uri`.`guid` AS `parent-guid`,
|
`parent-item-uri`.`guid` AS `parent-guid`,
|
||||||
`parent-post`.`network` AS `parent-network`,
|
`post-thread-user`.`network` AS `parent-network`,
|
||||||
`parent-post`.`author-id` AS `parent-author-id`,
|
`post-thread-user`.`author-id` AS `parent-author-id`,
|
||||||
`parent-post-author`.`url` AS `parent-author-link`,
|
`author`.`url` AS `parent-author-link`,
|
||||||
`parent-post-author`.`name` AS `parent-author-name`,
|
`author`.`name` AS `parent-author-name`,
|
||||||
`parent-post-author`.`network` AS `parent-author-network`
|
`author`.`nick` AS `parent-author-nick`,
|
||||||
|
`author`.`network` AS `parent-author-network`
|
||||||
FROM `post-thread-user`
|
FROM `post-thread-user`
|
||||||
INNER JOIN `post-user` ON `post-user`.`id` = `post-thread-user`.`post-user-id`
|
INNER JOIN `post-user` ON `post-user`.`id` = `post-thread-user`.`post-user-id`
|
||||||
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
||||||
|
@ -2226,9 +2510,7 @@ CREATE VIEW `post-thread-user-view` AS SELECT
|
||||||
LEFT JOIN `item-uri` AS `quote-item-uri` ON `quote-item-uri`.`id` = `post-content`.`quote-uri-id`
|
LEFT JOIN `item-uri` AS `quote-item-uri` ON `quote-item-uri`.`id` = `post-content`.`quote-uri-id`
|
||||||
LEFT JOIN `post-delivery-data` ON `post-delivery-data`.`uri-id` = `post-thread-user`.`uri-id` AND `post-thread-user`.`origin`
|
LEFT JOIN `post-delivery-data` ON `post-delivery-data`.`uri-id` = `post-thread-user`.`uri-id` AND `post-thread-user`.`origin`
|
||||||
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post-thread-user`.`uri-id`
|
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post-thread-user`.`uri-id`
|
||||||
LEFT JOIN `permissionset` ON `permissionset`.`id` = `post-thread-user`.`psid`
|
LEFT JOIN `permissionset` ON `permissionset`.`id` = `post-thread-user`.`psid`;
|
||||||
LEFT JOIN `post-user` AS `parent-post` ON `parent-post`.`uri-id` = `post-user`.`parent-uri-id` AND `parent-post`.`uid` = `post-thread-user`.`uid`
|
|
||||||
LEFT JOIN `contact` AS `parent-post-author` ON `parent-post-author`.`id` = `parent-post`.`author-id`;
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW post-view
|
-- VIEW post-view
|
||||||
|
@ -2273,6 +2555,7 @@ CREATE VIEW `post-view` AS SELECT
|
||||||
`post-content`.`plink` AS `plink`,
|
`post-content`.`plink` AS `plink`,
|
||||||
`post-content`.`location` AS `location`,
|
`post-content`.`location` AS `location`,
|
||||||
`post-content`.`coord` AS `coord`,
|
`post-content`.`coord` AS `coord`,
|
||||||
|
`post-content`.`sensitive` AS `sensitive`,
|
||||||
`post-content`.`app` AS `app`,
|
`post-content`.`app` AS `app`,
|
||||||
`post-content`.`object-type` AS `object-type`,
|
`post-content`.`object-type` AS `object-type`,
|
||||||
`post-content`.`object` AS `object`,
|
`post-content`.`object` AS `object`,
|
||||||
|
@ -2310,11 +2593,13 @@ CREATE VIEW `post-view` AS SELECT
|
||||||
`author`.`addr` AS `author-addr`,
|
`author`.`addr` AS `author-addr`,
|
||||||
`author`.`name` AS `author-name`,
|
`author`.`name` AS `author-name`,
|
||||||
`author`.`nick` AS `author-nick`,
|
`author`.`nick` AS `author-nick`,
|
||||||
|
`author`.`alias` AS `author-alias`,
|
||||||
`author`.`thumb` AS `author-avatar`,
|
`author`.`thumb` AS `author-avatar`,
|
||||||
`author`.`network` AS `author-network`,
|
`author`.`network` AS `author-network`,
|
||||||
`author`.`blocked` AS `author-blocked`,
|
`author`.`blocked` AS `author-blocked`,
|
||||||
`author`.`hidden` AS `author-hidden`,
|
`author`.`hidden` AS `author-hidden`,
|
||||||
`author`.`updated` AS `author-updated`,
|
`author`.`updated` AS `author-updated`,
|
||||||
|
`author`.`contact-type` AS `author-contact-type`,
|
||||||
`author`.`gsid` AS `author-gsid`,
|
`author`.`gsid` AS `author-gsid`,
|
||||||
`post`.`owner-id` AS `owner-id`,
|
`post`.`owner-id` AS `owner-id`,
|
||||||
`owner`.`uri-id` AS `owner-uri-id`,
|
`owner`.`uri-id` AS `owner-uri-id`,
|
||||||
|
@ -2322,23 +2607,27 @@ CREATE VIEW `post-view` AS SELECT
|
||||||
`owner`.`addr` AS `owner-addr`,
|
`owner`.`addr` AS `owner-addr`,
|
||||||
`owner`.`name` AS `owner-name`,
|
`owner`.`name` AS `owner-name`,
|
||||||
`owner`.`nick` AS `owner-nick`,
|
`owner`.`nick` AS `owner-nick`,
|
||||||
|
`owner`.`alias` AS `owner-alias`,
|
||||||
`owner`.`thumb` AS `owner-avatar`,
|
`owner`.`thumb` AS `owner-avatar`,
|
||||||
`owner`.`network` AS `owner-network`,
|
`owner`.`network` AS `owner-network`,
|
||||||
`owner`.`blocked` AS `owner-blocked`,
|
`owner`.`blocked` AS `owner-blocked`,
|
||||||
`owner`.`hidden` AS `owner-hidden`,
|
`owner`.`hidden` AS `owner-hidden`,
|
||||||
`owner`.`updated` AS `owner-updated`,
|
`owner`.`updated` AS `owner-updated`,
|
||||||
`owner`.`contact-type` AS `owner-contact-type`,
|
`owner`.`contact-type` AS `owner-contact-type`,
|
||||||
|
`owner`.`gsid` AS `owner-gsid`,
|
||||||
`post`.`causer-id` AS `causer-id`,
|
`post`.`causer-id` AS `causer-id`,
|
||||||
`causer`.`uri-id` AS `causer-uri-id`,
|
`causer`.`uri-id` AS `causer-uri-id`,
|
||||||
`causer`.`url` AS `causer-link`,
|
`causer`.`url` AS `causer-link`,
|
||||||
`causer`.`addr` AS `causer-addr`,
|
`causer`.`addr` AS `causer-addr`,
|
||||||
`causer`.`name` AS `causer-name`,
|
`causer`.`name` AS `causer-name`,
|
||||||
`causer`.`nick` AS `causer-nick`,
|
`causer`.`nick` AS `causer-nick`,
|
||||||
|
`causer`.`alias` AS `causer-alias`,
|
||||||
`causer`.`thumb` AS `causer-avatar`,
|
`causer`.`thumb` AS `causer-avatar`,
|
||||||
`causer`.`network` AS `causer-network`,
|
`causer`.`network` AS `causer-network`,
|
||||||
`causer`.`blocked` AS `causer-blocked`,
|
`causer`.`blocked` AS `causer-blocked`,
|
||||||
`causer`.`hidden` AS `causer-hidden`,
|
`causer`.`hidden` AS `causer-hidden`,
|
||||||
`causer`.`contact-type` AS `causer-contact-type`,
|
`causer`.`contact-type` AS `causer-contact-type`,
|
||||||
|
`causer`.`gsid` AS `causer-gsid`,
|
||||||
`post-question`.`id` AS `question-id`,
|
`post-question`.`id` AS `question-id`,
|
||||||
`post-question`.`multiple` AS `question-multiple`,
|
`post-question`.`multiple` AS `question-multiple`,
|
||||||
`post-question`.`voters` AS `question-voters`,
|
`post-question`.`voters` AS `question-voters`,
|
||||||
|
@ -2347,10 +2636,11 @@ CREATE VIEW `post-view` AS SELECT
|
||||||
EXISTS(SELECT `id` FROM `post-media` WHERE `post-media`.`uri-id` = `post`.`uri-id`) AS `has-media`,
|
EXISTS(SELECT `id` FROM `post-media` WHERE `post-media`.`uri-id` = `post`.`uri-id`) AS `has-media`,
|
||||||
`diaspora-interaction`.`interaction` AS `signed_text`,
|
`diaspora-interaction`.`interaction` AS `signed_text`,
|
||||||
`parent-item-uri`.`guid` AS `parent-guid`,
|
`parent-item-uri`.`guid` AS `parent-guid`,
|
||||||
`parent-post`.`network` AS `parent-network`,
|
`post-thread`.`network` AS `parent-network`,
|
||||||
`parent-post`.`author-id` AS `parent-author-id`,
|
`post-thread`.`author-id` AS `parent-author-id`,
|
||||||
`parent-post-author`.`url` AS `parent-author-link`,
|
`parent-post-author`.`url` AS `parent-author-link`,
|
||||||
`parent-post-author`.`name` AS `parent-author-name`,
|
`parent-post-author`.`name` AS `parent-author-name`,
|
||||||
|
`parent-post-author`.`nick` AS `parent-author-nick`,
|
||||||
`parent-post-author`.`network` AS `parent-author-network`
|
`parent-post-author`.`network` AS `parent-author-network`
|
||||||
FROM `post`
|
FROM `post`
|
||||||
STRAIGHT_JOIN `post-thread` ON `post-thread`.`uri-id` = `post`.`parent-uri-id`
|
STRAIGHT_JOIN `post-thread` ON `post-thread`.`uri-id` = `post`.`parent-uri-id`
|
||||||
|
@ -2367,8 +2657,7 @@ CREATE VIEW `post-view` AS SELECT
|
||||||
LEFT JOIN `post-content` ON `post-content`.`uri-id` = `post`.`uri-id`
|
LEFT JOIN `post-content` ON `post-content`.`uri-id` = `post`.`uri-id`
|
||||||
LEFT JOIN `item-uri` AS `quote-item-uri` ON `quote-item-uri`.`id` = `post-content`.`quote-uri-id`
|
LEFT JOIN `item-uri` AS `quote-item-uri` ON `quote-item-uri`.`id` = `post-content`.`quote-uri-id`
|
||||||
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post`.`uri-id`
|
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post`.`uri-id`
|
||||||
LEFT JOIN `post` AS `parent-post` ON `parent-post`.`uri-id` = `post`.`parent-uri-id`
|
LEFT JOIN `contact` AS `parent-post-author` ON `parent-post-author`.`id` = `post-thread`.`author-id`;
|
||||||
LEFT JOIN `contact` AS `parent-post-author` ON `parent-post-author`.`id` = `parent-post`.`author-id`;
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW post-thread-view
|
-- VIEW post-thread-view
|
||||||
|
@ -2413,6 +2702,7 @@ CREATE VIEW `post-thread-view` AS SELECT
|
||||||
`post-content`.`plink` AS `plink`,
|
`post-content`.`plink` AS `plink`,
|
||||||
`post-content`.`location` AS `location`,
|
`post-content`.`location` AS `location`,
|
||||||
`post-content`.`coord` AS `coord`,
|
`post-content`.`coord` AS `coord`,
|
||||||
|
`post-content`.`sensitive` AS `sensitive`,
|
||||||
`post-content`.`app` AS `app`,
|
`post-content`.`app` AS `app`,
|
||||||
`post-content`.`object-type` AS `object-type`,
|
`post-content`.`object-type` AS `object-type`,
|
||||||
`post-content`.`object` AS `object`,
|
`post-content`.`object` AS `object`,
|
||||||
|
@ -2450,11 +2740,13 @@ CREATE VIEW `post-thread-view` AS SELECT
|
||||||
`author`.`addr` AS `author-addr`,
|
`author`.`addr` AS `author-addr`,
|
||||||
`author`.`name` AS `author-name`,
|
`author`.`name` AS `author-name`,
|
||||||
`author`.`nick` AS `author-nick`,
|
`author`.`nick` AS `author-nick`,
|
||||||
|
`author`.`alias` AS `author-alias`,
|
||||||
`author`.`thumb` AS `author-avatar`,
|
`author`.`thumb` AS `author-avatar`,
|
||||||
`author`.`network` AS `author-network`,
|
`author`.`network` AS `author-network`,
|
||||||
`author`.`blocked` AS `author-blocked`,
|
`author`.`blocked` AS `author-blocked`,
|
||||||
`author`.`hidden` AS `author-hidden`,
|
`author`.`hidden` AS `author-hidden`,
|
||||||
`author`.`updated` AS `author-updated`,
|
`author`.`updated` AS `author-updated`,
|
||||||
|
`author`.`contact-type` AS `author-contact-type`,
|
||||||
`author`.`gsid` AS `author-gsid`,
|
`author`.`gsid` AS `author-gsid`,
|
||||||
`post-thread`.`owner-id` AS `owner-id`,
|
`post-thread`.`owner-id` AS `owner-id`,
|
||||||
`owner`.`uri-id` AS `owner-uri-id`,
|
`owner`.`uri-id` AS `owner-uri-id`,
|
||||||
|
@ -2462,11 +2754,13 @@ CREATE VIEW `post-thread-view` AS SELECT
|
||||||
`owner`.`addr` AS `owner-addr`,
|
`owner`.`addr` AS `owner-addr`,
|
||||||
`owner`.`name` AS `owner-name`,
|
`owner`.`name` AS `owner-name`,
|
||||||
`owner`.`nick` AS `owner-nick`,
|
`owner`.`nick` AS `owner-nick`,
|
||||||
|
`owner`.`alias` AS `owner-alias`,
|
||||||
`owner`.`thumb` AS `owner-avatar`,
|
`owner`.`thumb` AS `owner-avatar`,
|
||||||
`owner`.`network` AS `owner-network`,
|
`owner`.`network` AS `owner-network`,
|
||||||
`owner`.`blocked` AS `owner-blocked`,
|
`owner`.`blocked` AS `owner-blocked`,
|
||||||
`owner`.`hidden` AS `owner-hidden`,
|
`owner`.`hidden` AS `owner-hidden`,
|
||||||
`owner`.`updated` AS `owner-updated`,
|
`owner`.`updated` AS `owner-updated`,
|
||||||
|
`owner`.`gsid` AS `owner-gsid`,
|
||||||
`owner`.`contact-type` AS `owner-contact-type`,
|
`owner`.`contact-type` AS `owner-contact-type`,
|
||||||
`post-thread`.`causer-id` AS `causer-id`,
|
`post-thread`.`causer-id` AS `causer-id`,
|
||||||
`causer`.`uri-id` AS `causer-uri-id`,
|
`causer`.`uri-id` AS `causer-uri-id`,
|
||||||
|
@ -2474,10 +2768,12 @@ CREATE VIEW `post-thread-view` AS SELECT
|
||||||
`causer`.`addr` AS `causer-addr`,
|
`causer`.`addr` AS `causer-addr`,
|
||||||
`causer`.`name` AS `causer-name`,
|
`causer`.`name` AS `causer-name`,
|
||||||
`causer`.`nick` AS `causer-nick`,
|
`causer`.`nick` AS `causer-nick`,
|
||||||
|
`causer`.`alias` AS `causer-alias`,
|
||||||
`causer`.`thumb` AS `causer-avatar`,
|
`causer`.`thumb` AS `causer-avatar`,
|
||||||
`causer`.`network` AS `causer-network`,
|
`causer`.`network` AS `causer-network`,
|
||||||
`causer`.`blocked` AS `causer-blocked`,
|
`causer`.`blocked` AS `causer-blocked`,
|
||||||
`causer`.`hidden` AS `causer-hidden`,
|
`causer`.`hidden` AS `causer-hidden`,
|
||||||
|
`causer`.`gsid` AS `causer-gsid`,
|
||||||
`causer`.`contact-type` AS `causer-contact-type`,
|
`causer`.`contact-type` AS `causer-contact-type`,
|
||||||
`post-question`.`id` AS `question-id`,
|
`post-question`.`id` AS `question-id`,
|
||||||
`post-question`.`multiple` AS `question-multiple`,
|
`post-question`.`multiple` AS `question-multiple`,
|
||||||
|
@ -2489,11 +2785,12 @@ CREATE VIEW `post-thread-view` AS SELECT
|
||||||
(SELECT COUNT(DISTINCT(`author-id`)) FROM `post` WHERE `parent-uri-id` = `post-thread`.`uri-id` AND `gravity` = 6) AS `total-actors`,
|
(SELECT COUNT(DISTINCT(`author-id`)) FROM `post` WHERE `parent-uri-id` = `post-thread`.`uri-id` AND `gravity` = 6) AS `total-actors`,
|
||||||
`diaspora-interaction`.`interaction` AS `signed_text`,
|
`diaspora-interaction`.`interaction` AS `signed_text`,
|
||||||
`parent-item-uri`.`guid` AS `parent-guid`,
|
`parent-item-uri`.`guid` AS `parent-guid`,
|
||||||
`parent-post`.`network` AS `parent-network`,
|
`post-thread`.`network` AS `parent-network`,
|
||||||
`parent-post`.`author-id` AS `parent-author-id`,
|
`post-thread`.`author-id` AS `parent-author-id`,
|
||||||
`parent-post-author`.`url` AS `parent-author-link`,
|
`author`.`url` AS `parent-author-link`,
|
||||||
`parent-post-author`.`name` AS `parent-author-name`,
|
`author`.`name` AS `parent-author-name`,
|
||||||
`parent-post-author`.`network` AS `parent-author-network`
|
`author`.`nick` AS `parent-author-nick`,
|
||||||
|
`author`.`network` AS `parent-author-network`
|
||||||
FROM `post-thread`
|
FROM `post-thread`
|
||||||
INNER JOIN `post` ON `post`.`uri-id` = `post-thread`.`uri-id`
|
INNER JOIN `post` ON `post`.`uri-id` = `post-thread`.`uri-id`
|
||||||
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post-thread`.`author-id`
|
STRAIGHT_JOIN `contact` AS `author` ON `author`.`id` = `post-thread`.`author-id`
|
||||||
|
@ -2508,9 +2805,7 @@ CREATE VIEW `post-thread-view` AS SELECT
|
||||||
LEFT JOIN `diaspora-interaction` ON `diaspora-interaction`.`uri-id` = `post-thread`.`uri-id`
|
LEFT JOIN `diaspora-interaction` ON `diaspora-interaction`.`uri-id` = `post-thread`.`uri-id`
|
||||||
LEFT JOIN `post-content` ON `post-content`.`uri-id` = `post-thread`.`uri-id`
|
LEFT JOIN `post-content` ON `post-content`.`uri-id` = `post-thread`.`uri-id`
|
||||||
LEFT JOIN `item-uri` AS `quote-item-uri` ON `quote-item-uri`.`id` = `post-content`.`quote-uri-id`
|
LEFT JOIN `item-uri` AS `quote-item-uri` ON `quote-item-uri`.`id` = `post-content`.`quote-uri-id`
|
||||||
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post-thread`.`uri-id`
|
LEFT JOIN `post-question` ON `post-question`.`uri-id` = `post-thread`.`uri-id`;
|
||||||
LEFT JOIN `post` AS `parent-post` ON `parent-post`.`uri-id` = `post`.`parent-uri-id`
|
|
||||||
LEFT JOIN `contact` AS `parent-post-author` ON `parent-post-author`.`id` = `parent-post`.`author-id`;
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW category-view
|
-- VIEW category-view
|
||||||
|
@ -2587,7 +2882,7 @@ CREATE VIEW `tag-view` AS SELECT
|
||||||
DROP VIEW IF EXISTS `network-item-view`;
|
DROP VIEW IF EXISTS `network-item-view`;
|
||||||
CREATE VIEW `network-item-view` AS SELECT
|
CREATE VIEW `network-item-view` AS SELECT
|
||||||
`post-user`.`uri-id` AS `uri-id`,
|
`post-user`.`uri-id` AS `uri-id`,
|
||||||
`parent-post`.`id` AS `parent`,
|
`post-thread-user`.`post-user-id` AS `parent`,
|
||||||
`post-user`.`received` AS `received`,
|
`post-user`.`received` AS `received`,
|
||||||
`post-thread-user`.`commented` AS `commented`,
|
`post-thread-user`.`commented` AS `commented`,
|
||||||
`post-user`.`created` AS `created`,
|
`post-user`.`created` AS `created`,
|
||||||
|
@ -2600,17 +2895,16 @@ CREATE VIEW `network-item-view` AS SELECT
|
||||||
`post-user`.`contact-id` AS `contact-id`,
|
`post-user`.`contact-id` AS `contact-id`,
|
||||||
`ownercontact`.`contact-type` AS `contact-type`
|
`ownercontact`.`contact-type` AS `contact-type`
|
||||||
FROM `post-user`
|
FROM `post-user`
|
||||||
STRAIGHT_JOIN `post-thread-user` ON `post-thread-user`.`uri-id` = `post-user`.`parent-uri-id` AND `post-thread-user`.`uid` = `post-user`.`uid`
|
INNER JOIN `post-thread-user` ON `post-thread-user`.`uri-id` = `post-user`.`parent-uri-id` AND `post-thread-user`.`uid` = `post-user`.`uid`
|
||||||
INNER JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
||||||
LEFT JOIN `user-contact` AS `author` ON `author`.`uid` = `post-thread-user`.`uid` AND `author`.`cid` = `post-thread-user`.`author-id`
|
STRAIGHT_JOIN `contact` AS `authorcontact` ON `authorcontact`.`id` = `post-thread-user`.`author-id`
|
||||||
LEFT JOIN `user-contact` AS `owner` ON `owner`.`uid` = `post-thread-user`.`uid` AND `owner`.`cid` = `post-thread-user`.`owner-id`
|
STRAIGHT_JOIN `contact` AS `ownercontact` ON `ownercontact`.`id` = `post-thread-user`.`owner-id`
|
||||||
INNER JOIN `contact` AS `ownercontact` ON `ownercontact`.`id` = `post-thread-user`.`owner-id`
|
|
||||||
LEFT JOIN `post-user` AS `parent-post` ON `parent-post`.`uri-id` = `post-user`.`parent-uri-id` AND `parent-post`.`uid` = `post-user`.`uid`
|
|
||||||
WHERE `post-user`.`visible` AND NOT `post-user`.`deleted`
|
WHERE `post-user`.`visible` AND NOT `post-user`.`deleted`
|
||||||
AND (NOT `contact`.`readonly` AND NOT `contact`.`blocked` AND NOT `contact`.`pending`)
|
AND (NOT `contact`.`readonly` AND NOT `contact`.`blocked` AND NOT `contact`.`pending`)
|
||||||
AND (`post-user`.`hidden` IS NULL OR NOT `post-user`.`hidden`)
|
AND (`post-user`.`hidden` IS NULL OR NOT `post-user`.`hidden`)
|
||||||
AND (`author`.`blocked` IS NULL OR NOT `author`.`blocked`)
|
AND NOT `authorcontact`.`blocked` AND NOT `ownercontact`.`blocked`
|
||||||
AND (`owner`.`blocked` IS NULL OR NOT `owner`.`blocked`);
|
AND NOT EXISTS(SELECT `cid` FROM `user-contact` WHERE `uid` = `post-thread-user`.`uid` AND `cid` IN (`authorcontact`.`id`, `ownercontact`.`id`) AND (`blocked` OR `ignored`))
|
||||||
|
AND NOT EXISTS(SELECT `gsid` FROM `user-gserver` WHERE `uid` = `post-thread-user`.`uid` AND `gsid` IN (`authorcontact`.`gsid`, `ownercontact`.`gsid`) AND `ignored`);
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW network-thread-view
|
-- VIEW network-thread-view
|
||||||
|
@ -2618,7 +2912,7 @@ CREATE VIEW `network-item-view` AS SELECT
|
||||||
DROP VIEW IF EXISTS `network-thread-view`;
|
DROP VIEW IF EXISTS `network-thread-view`;
|
||||||
CREATE VIEW `network-thread-view` AS SELECT
|
CREATE VIEW `network-thread-view` AS SELECT
|
||||||
`post-thread-user`.`uri-id` AS `uri-id`,
|
`post-thread-user`.`uri-id` AS `uri-id`,
|
||||||
`parent-post`.`id` AS `parent`,
|
`post-thread-user`.`post-user-id` AS `parent`,
|
||||||
`post-thread-user`.`received` AS `received`,
|
`post-thread-user`.`received` AS `received`,
|
||||||
`post-thread-user`.`commented` AS `commented`,
|
`post-thread-user`.`commented` AS `commented`,
|
||||||
`post-thread-user`.`created` AS `created`,
|
`post-thread-user`.`created` AS `created`,
|
||||||
|
@ -2631,15 +2925,14 @@ CREATE VIEW `network-thread-view` AS SELECT
|
||||||
FROM `post-thread-user`
|
FROM `post-thread-user`
|
||||||
INNER JOIN `post-user` ON `post-user`.`id` = `post-thread-user`.`post-user-id`
|
INNER JOIN `post-user` ON `post-user`.`id` = `post-thread-user`.`post-user-id`
|
||||||
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
STRAIGHT_JOIN `contact` ON `contact`.`id` = `post-thread-user`.`contact-id`
|
||||||
LEFT JOIN `user-contact` AS `author` ON `author`.`uid` = `post-thread-user`.`uid` AND `author`.`cid` = `post-thread-user`.`author-id`
|
STRAIGHT_JOIN `contact` AS `authorcontact` ON `authorcontact`.`id` = `post-thread-user`.`author-id`
|
||||||
LEFT JOIN `user-contact` AS `owner` ON `owner`.`uid` = `post-thread-user`.`uid` AND `owner`.`cid` = `post-thread-user`.`owner-id`
|
STRAIGHT_JOIN `contact` AS `ownercontact` ON `ownercontact`.`id` = `post-thread-user`.`owner-id`
|
||||||
LEFT JOIN `contact` AS `ownercontact` ON `ownercontact`.`id` = `post-thread-user`.`owner-id`
|
|
||||||
LEFT JOIN `post-user` AS `parent-post` ON `parent-post`.`uri-id` = `post-user`.`parent-uri-id` AND `parent-post`.`uid` = `post-user`.`uid`
|
|
||||||
WHERE `post-user`.`visible` AND NOT `post-user`.`deleted`
|
WHERE `post-user`.`visible` AND NOT `post-user`.`deleted`
|
||||||
AND (NOT `contact`.`readonly` AND NOT `contact`.`blocked` AND NOT `contact`.`pending`)
|
AND (NOT `contact`.`readonly` AND NOT `contact`.`blocked` AND NOT `contact`.`pending`)
|
||||||
AND (`post-thread-user`.`hidden` IS NULL OR NOT `post-thread-user`.`hidden`)
|
AND (`post-thread-user`.`hidden` IS NULL OR NOT `post-thread-user`.`hidden`)
|
||||||
AND (`author`.`blocked` IS NULL OR NOT `author`.`blocked`)
|
AND NOT `authorcontact`.`blocked` AND NOT `ownercontact`.`blocked`
|
||||||
AND (`owner`.`blocked` IS NULL OR NOT `owner`.`blocked`);
|
AND NOT EXISTS(SELECT `cid` FROM `user-contact` WHERE `uid` = `post-thread-user`.`uid` AND `cid` IN (`authorcontact`.`id`, `ownercontact`.`id`) AND (`blocked` OR `ignored`))
|
||||||
|
AND NOT EXISTS(SELECT `gsid` FROM `user-gserver` WHERE `uid` = `post-thread-user`.`uid` AND `gsid` IN (`authorcontact`.`gsid`, `ownercontact`.`gsid`) AND `ignored`);
|
||||||
|
|
||||||
--
|
--
|
||||||
-- VIEW owner-view
|
-- VIEW owner-view
|
||||||
|
@ -2736,8 +3029,6 @@ CREATE VIEW `owner-view` AS SELECT
|
||||||
`user`.`blockwall` AS `blockwall`,
|
`user`.`blockwall` AS `blockwall`,
|
||||||
`user`.`hidewall` AS `hidewall`,
|
`user`.`hidewall` AS `hidewall`,
|
||||||
`user`.`blocktags` AS `blocktags`,
|
`user`.`blocktags` AS `blocktags`,
|
||||||
`user`.`unkmail` AS `unkmail`,
|
|
||||||
`user`.`cntunkmail` AS `cntunkmail`,
|
|
||||||
`user`.`notify-flags` AS `notify-flags`,
|
`user`.`notify-flags` AS `notify-flags`,
|
||||||
`user`.`page-flags` AS `page-flags`,
|
`user`.`page-flags` AS `page-flags`,
|
||||||
`user`.`account-type` AS `account-type`,
|
`user`.`account-type` AS `account-type`,
|
||||||
|
|
|
@ -454,7 +454,7 @@ Ex: Wed May 23 06:01:13 +0000 2007
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>allow_gid</code></td>
|
<td><code>allow_gid</code></td>
|
||||||
<td>String (angle-brackets escaped integers)</td>
|
<td>String (angle-brackets escaped integers)</td>
|
||||||
<td>Optional. List of allowed group ids</td>
|
<td>Optional. List of allowed circle ids</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -466,7 +466,7 @@ Ex: Wed May 23 06:01:13 +0000 2007
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>deny_gid</code></td>
|
<td><code>deny_gid</code></td>
|
||||||
<td>String (angle-brackets escaped integers)</td>
|
<td>String (angle-brackets escaped integers)</td>
|
||||||
<td>Optional. List of disallowed group ids</td>
|
<td>Optional. List of disallowed circle ids</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
</tbody>
|
</tbody>
|
||||||
|
@ -984,7 +984,7 @@ Identical to [the Twitter Media Object](https://developer.twitter.com/en/docs/tw
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>allow_gid</code></td>
|
<td><code>allow_gid</code></td>
|
||||||
<td>String (ACL)</td>
|
<td>String (ACL)</td>
|
||||||
<td>List of contact group ids wrapped in angle brackets allowed to access the photo.</td>
|
<td>List of contact circle ids wrapped in angle brackets allowed to access the photo.</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
|
@ -996,7 +996,7 @@ Identical to [the Twitter Media Object](https://developer.twitter.com/en/docs/tw
|
||||||
<tr>
|
<tr>
|
||||||
<td><code>deny_gid</code></td>
|
<td><code>deny_gid</code></td>
|
||||||
<td>String (ACL)</td>
|
<td>String (ACL)</td>
|
||||||
<td>List of contact group ids wrapped in angle brackets forbidden to access the photo.</td>
|
<td>List of contact circle ids wrapped in angle brackets forbidden to access the photo.</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
<tr>
|
<tr>
|
||||||
|
|
|
@ -39,8 +39,8 @@ Create a new event for the current logged in user.
|
||||||
- `publish` : (optional) create message for event
|
- `publish` : (optional) create message for event
|
||||||
- `allow_cid` : (optional) ACL-formatted list of allowed contact ids if private event
|
- `allow_cid` : (optional) ACL-formatted list of allowed contact ids if private event
|
||||||
- `allow_gid` : (optional) ACL-formatted list of disallowed contact ids if private event
|
- `allow_gid` : (optional) ACL-formatted list of disallowed contact ids if private event
|
||||||
- `deny_cid` : (optional) ACL-formatted list of allowed group ids if private event
|
- `deny_cid` : (optional) ACL-formatted list of allowed circle ids if private event
|
||||||
- `deny_gid` : (optional) ACL-formatted list of disallowed group ids if private event
|
- `deny_gid` : (optional) ACL-formatted list of disallowed circle ids if private event
|
||||||
|
|
||||||
### POST api/friendica/event_delete
|
### POST api/friendica/event_delete
|
||||||
|
|
||||||
|
@ -323,33 +323,37 @@ On error:
|
||||||
|
|
||||||
---
|
---
|
||||||
|
|
||||||
### GET api/friendica/group_show
|
### GET api/friendica/circle_show
|
||||||
|
|
||||||
Return all or a specified group of the user with the containing contacts as array.
|
Alternatively: GET api/friendica/group_show (Backward compatibility)
|
||||||
|
|
||||||
|
Return all or a specified circle of the user with the containing contacts as array.
|
||||||
|
|
||||||
#### Parameters
|
#### Parameters
|
||||||
|
|
||||||
* `gid`: optional, if not given, API returns all groups of the user
|
* `gid`: optional, if not given, API returns all circles of the user
|
||||||
|
|
||||||
#### Return values
|
#### Return values
|
||||||
|
|
||||||
Array of:
|
Array of:
|
||||||
|
|
||||||
* `name`: name of the group
|
* `name`: name of the circle
|
||||||
* `gid`: id of the group
|
* `gid`: id of the circle
|
||||||
* `user`: array of [Contacts](help/API-Entities#Contact)
|
* `user`: array of [Contacts](help/API-Entities#Contact)
|
||||||
|
|
||||||
### POST api/friendica/group_create
|
### POST api/friendica/circle_create
|
||||||
|
|
||||||
Create the group with the posted array of contacts as members.
|
Alternatively: POST api/friendica/group_create
|
||||||
|
|
||||||
|
Create the circle with the posted array of contacts as members.
|
||||||
|
|
||||||
#### Parameters
|
#### Parameters
|
||||||
|
|
||||||
* `name`: name of the group to be created
|
* `name`: name of the circle to be created
|
||||||
|
|
||||||
#### POST data
|
#### POST data
|
||||||
|
|
||||||
JSON data as Array like the result of [GET api/friendica/group_show](#GET+api%2Ffriendica%2Fgroup_show):
|
JSON data as Array like the result of [GET api/friendica/circle_show](#GET+api%2Ffriendica%2Fcircle_show):
|
||||||
|
|
||||||
* `gid`
|
* `gid`
|
||||||
* `name`
|
* `name`
|
||||||
|
@ -360,23 +364,25 @@ JSON data as Array like the result of [GET api/friendica/group_show](#GET+api%2F
|
||||||
Array of:
|
Array of:
|
||||||
|
|
||||||
* `success`: true if successfully created or reactivated
|
* `success`: true if successfully created or reactivated
|
||||||
* `gid`: gid of the created group
|
* `gid`: gid of the created circle
|
||||||
* `name`: name of the created group
|
* `name`: name of the created circle
|
||||||
* `status`: "missing user" | "reactivated" | "ok"
|
* `status`: "missing user" | "reactivated" | "ok"
|
||||||
* `wrong users`: array of users, which were not available in the contact table
|
* `wrong users`: array of users, which were not available in the contact table
|
||||||
|
|
||||||
### POST api/friendica/group_update
|
### POST api/friendica/circle_update
|
||||||
|
|
||||||
Update the group with the posted array of contacts as members (post all members of the group to the call; function will remove members not posted).
|
Alternatively: POST api/friendica/group_update
|
||||||
|
|
||||||
|
Update the circle with the posted array of contacts as members (post all members of the circle to the call; function will remove members not posted).
|
||||||
|
|
||||||
#### Parameters
|
#### Parameters
|
||||||
|
|
||||||
* `gid`: id of the group to be changed
|
* `gid`: id of the circle to be changed
|
||||||
* `name`: name of the group to be changed
|
* `name`: name of the circle to be changed
|
||||||
|
|
||||||
#### POST data
|
#### POST data
|
||||||
|
|
||||||
JSON data as array like the result of [GET api/friendica/group_show](#GET+api%2Ffriendica%2Fgroup_show):
|
JSON data as array like the result of [GET api/friendica/circle_show](#GET+api%2Ffriendica%2Fcircle_show):
|
||||||
|
|
||||||
* `gid`
|
* `gid`
|
||||||
* `name`
|
* `name`
|
||||||
|
@ -387,27 +393,29 @@ JSON data as array like the result of [GET api/friendica/group_show](#GET+api%2F
|
||||||
Array of:
|
Array of:
|
||||||
|
|
||||||
* `success`: true if successfully updated
|
* `success`: true if successfully updated
|
||||||
* `gid`: gid of the changed group
|
* `gid`: gid of the changed circle
|
||||||
* `name`: name of the changed group
|
* `name`: name of the changed circle
|
||||||
* `status`: "missing user" | "ok"
|
* `status`: "missing user" | "ok"
|
||||||
* `wrong users`: array of users, which were not available in the contact table
|
* `wrong users`: array of users, which were not available in the contact table
|
||||||
|
|
||||||
### POST api/friendica/group_delete
|
### POST api/friendica/circle_delete
|
||||||
|
|
||||||
Delete the specified group of contacts; API call need to include the correct gid AND name of the group to be deleted.
|
Alternatively: POST api/friendica/group_delete
|
||||||
|
|
||||||
|
Delete the specified circle of contacts; API call need to include the correct gid AND name of the circle to be deleted.
|
||||||
|
|
||||||
#### Parameters
|
#### Parameters
|
||||||
|
|
||||||
* `gid`: id of the group to be deleted
|
* `gid`: id of the circle to be deleted
|
||||||
* `name`: name of the group to be deleted
|
* `name`: name of the circle to be deleted
|
||||||
|
|
||||||
#### Return values
|
#### Return values
|
||||||
|
|
||||||
Array of:
|
Array of:
|
||||||
|
|
||||||
* `success`: true if successfully deleted
|
* `success`: true if successfully deleted
|
||||||
* `gid`: gid of the deleted group
|
* `gid`: gid of the deleted circle
|
||||||
* `name`: name of the deleted group
|
* `name`: name of the deleted circle
|
||||||
* `status`: "deleted" if successfully deleted
|
* `status`: "deleted" if successfully deleted
|
||||||
* `wrong users`: empty array
|
* `wrong users`: empty array
|
||||||
|
|
||||||
|
@ -556,7 +564,7 @@ Alias of [`api/friendica/photo/update`](#POST+api%2Ffriendica%2Fphoto%2Fupdate)
|
||||||
|
|
||||||
Saves data for the scales 0-2 to database (see above for scale description).
|
Saves data for the scales 0-2 to database (see above for scale description).
|
||||||
Call adds non-public entries to items table to enable authenticated contacts to comment/like the photo.
|
Call adds non-public entries to items table to enable authenticated contacts to comment/like the photo.
|
||||||
Client should pay attention to the fact that updated access rights are not transferred to the contacts. i.e. public photos remain publicly visible if they have been commented/liked before setting visibility back to a limited group.
|
Client should pay attention to the fact that updated access rights are not transferred to the contacts. i.e. public photos remain publicly visible if they have been commented/liked before setting visibility back to a limited circle.
|
||||||
Currently it is best to inform user that updating rights is not the right way to do this, and offer a solution to add photo as a new photo with the new rights instead.
|
Currently it is best to inform user that updating rights is not the right way to do this, and offer a solution to add photo as a new photo with the new rights instead.
|
||||||
|
|
||||||
#### Parameters
|
#### Parameters
|
||||||
|
|
|
@ -11,21 +11,7 @@ Authentication is the same as described in [Using the APIs](help/api#Authenticat
|
||||||
|
|
||||||
## Clients
|
## Clients
|
||||||
|
|
||||||
### Supported apps
|
Please find a list of supported apps at [FAQ](help/FAQ#clients).
|
||||||
|
|
||||||
For supported apps please have a look at the [FAQ](help/FAQ#clients)
|
|
||||||
|
|
||||||
### Unsupported apps
|
|
||||||
|
|
||||||
#### Android
|
|
||||||
|
|
||||||
- [Fedilab](https://framagit.org/tom79/fedilab) Automatically uses the legacy API, see issue: https://framagit.org/tom79/fedilab/-/issues/520
|
|
||||||
- [Mammut](https://github.com/jamiesanson/Mammut) There are problems with the token request, see issue https://github.com/jamiesanson/Mammut/issues/19
|
|
||||||
|
|
||||||
#### iOS
|
|
||||||
|
|
||||||
- [Mast](https://github.com/Beesitech/Mast) Doesn't accept the entered instance name. Claims that it is invalid (Message is: "Not a valid instance (may be closed or dead)")
|
|
||||||
- [Toot!](https://apps.apple.com/app/toot/id1229021451)
|
|
||||||
|
|
||||||
## Entities
|
## Entities
|
||||||
|
|
||||||
|
@ -170,7 +156,8 @@ Example:
|
||||||
|
|
||||||
- [`GET /api/v1/followed_tags`](https://docs.joinmastodon.org/methods/followed_tags/)
|
- [`GET /api/v1/followed_tags`](https://docs.joinmastodon.org/methods/followed_tags/)
|
||||||
- [`GET /api/v1/instance`](https://docs.joinmastodon.org/methods/instance/#v1)
|
- [`GET /api/v1/instance`](https://docs.joinmastodon.org/methods/instance/#v1)
|
||||||
- `GET /api/v1/instance/rules` Undocumented, returns Terms of Service
|
- [`GET /api/v1/instance/extended_description`](https://docs.joinmastodon.org/methods/instance/#extended_description)
|
||||||
|
- [`GET /api/v1/instance/rules`](https://docs.joinmastodon.org/methods/instance/#rules)
|
||||||
- [`GET /api/v1/instance/peers`](https://docs.joinmastodon.org/methods/instance#list-of-connected-domains)
|
- [`GET /api/v1/instance/peers`](https://docs.joinmastodon.org/methods/instance#list-of-connected-domains)
|
||||||
- [`GET /api/v1/lists`](https://docs.joinmastodon.org/methods/timelines/lists/)
|
- [`GET /api/v1/lists`](https://docs.joinmastodon.org/methods/timelines/lists/)
|
||||||
- [`POST /api/v1/lists`](https://docs.joinmastodon.org/methods/timelines/lists/)
|
- [`POST /api/v1/lists`](https://docs.joinmastodon.org/methods/timelines/lists/)
|
||||||
|
@ -211,7 +198,7 @@ Example:
|
||||||
- `title`: Explicitly sets the title for a post status, ignored if used on a comment status. For post statuses the legacy behavior is to use any "spoiler text" as the title if it is provided. If both the title and spoiler text are provided for a post status then they will each be used for their respective roles. If no title is provided then the legacy behavior will persist. If you want to create a post with no title but spoiler text then explicitly set the title but set it to an empty string `""`.
|
- `title`: Explicitly sets the title for a post status, ignored if used on a comment status. For post statuses the legacy behavior is to use any "spoiler text" as the title if it is provided. If both the title and spoiler text are provided for a post status then they will each be used for their respective roles. If no title is provided then the legacy behavior will persist. If you want to create a post with no title but spoiler text then explicitly set the title but set it to an empty string `""`.
|
||||||
- [`POST /api/v1/statuses`](https://docs.joinmastodon.org/methods/statuses/#create)
|
- [`POST /api/v1/statuses`](https://docs.joinmastodon.org/methods/statuses/#create)
|
||||||
- Does not support `polls` argument as Friendica does not have polls
|
- Does not support `polls` argument as Friendica does not have polls
|
||||||
- Additionally to the static values `public`, `unlisted` and `private`, the `visibility` parameter can contain a numeric value with a group id.
|
- Additionally to the static values `public`, `unlisted` and `private`, the `visibility` parameter can contain a numeric value with a circle id.
|
||||||
- Additional field `quote_id` for the post that is being quote reshared
|
- Additional field `quote_id` for the post that is being quote reshared
|
||||||
- Additional fields `friendica` for Friendica specific parameters:
|
- Additional fields `friendica` for Friendica specific parameters:
|
||||||
- `title`: Explicitly sets the title for a post status, ignored if used on a comment status. For post statuses the legacy behavior is to use any "spoiler text" as the title if it is provided. If both the title and spoiler text are provided for a post status then they will each be used for their respective roles. If no title is provided then the legacy behavior will persist. If you want to create a post with no title but spoiler text then explicitly set the title but set it to an empty string `""`.
|
- `title`: Explicitly sets the title for a post status, ignored if used on a comment status. For post statuses the legacy behavior is to use any "spoiler text" as the title if it is provided. If both the title and spoiler text are provided for a post status then they will each be used for their respective roles. If no title is provided then the legacy behavior will persist. If you want to create a post with no title but spoiler text then explicitly set the title but set it to an empty string `""`.
|
||||||
|
@ -314,7 +301,6 @@ They refer to features or data that don't exist in Friendica yet.
|
||||||
- [`PUT /api/v1/filters/:id`](https://docs.joinmastodon.org/methods/accounts/filters/)
|
- [`PUT /api/v1/filters/:id`](https://docs.joinmastodon.org/methods/accounts/filters/)
|
||||||
- [`DELETE /api/v1/filters/:id`](https://docs.joinmastodon.org/methods/accounts/filters/)
|
- [`DELETE /api/v1/filters/:id`](https://docs.joinmastodon.org/methods/accounts/filters/)
|
||||||
- [`GET /api/v1/instance/activity`](https://docs.joinmastodon.org/methods/instance#weekly-activity)
|
- [`GET /api/v1/instance/activity`](https://docs.joinmastodon.org/methods/instance#weekly-activity)
|
||||||
- [`POST /api/v1/markers`](https://docs.joinmastodon.org/methods/timelines/markers/)
|
|
||||||
- [`PUT /api/v1/scheduled_statuses/:id`](https://docs.joinmastodon.org/methods/statuses/scheduled_statuses/)
|
- [`PUT /api/v1/scheduled_statuses/:id`](https://docs.joinmastodon.org/methods/statuses/scheduled_statuses/)
|
||||||
- [`GET /api/v1/statuses/{id:\d+}/history`](https://github.com/mastodon/mastodon/pull/16697)
|
- [`GET /api/v1/statuses/{id:\d+}/history`](https://github.com/mastodon/mastodon/pull/16697)
|
||||||
- [`GET /api/v1/streaming`](https://docs.joinmastodon.org/methods/timelines/streaming/)
|
- [`GET /api/v1/streaming`](https://docs.joinmastodon.org/methods/timelines/streaming/)
|
||||||
|
|
|
@ -16,6 +16,7 @@ General
|
||||||
-------
|
-------
|
||||||
* p - Profile
|
* p - Profile
|
||||||
* n - Network
|
* n - Network
|
||||||
|
* l - Channel
|
||||||
* c - Community
|
* c - Community
|
||||||
* s - Search
|
* s - Search
|
||||||
* a - Admin
|
* a - Admin
|
||||||
|
@ -28,6 +29,19 @@ General
|
||||||
* l - Local community
|
* l - Local community
|
||||||
* g - Global community
|
* g - Global community
|
||||||
|
|
||||||
|
../channel
|
||||||
|
--------
|
||||||
|
* y - for you
|
||||||
|
* f - followers
|
||||||
|
* r - sharers of sharers
|
||||||
|
* q - quiet sharers
|
||||||
|
* h - what's hot
|
||||||
|
* i - Images
|
||||||
|
* v - Videos
|
||||||
|
* d - Audio
|
||||||
|
* g - Posts in your language
|
||||||
|
* o - Hot posts in your language
|
||||||
|
|
||||||
../profile
|
../profile
|
||||||
--------
|
--------
|
||||||
* m - Status Messages and Posts
|
* m - Status Messages and Posts
|
||||||
|
@ -48,7 +62,7 @@ General
|
||||||
* i - Only show ignored contacts
|
* i - Only show ignored contacts
|
||||||
* y - Only show archived contacts
|
* y - Only show archived contacts
|
||||||
* h - Only show hidden contacts
|
* h - Only show hidden contacts
|
||||||
* e - Edit contact groups
|
* e - Edit contact circles
|
||||||
|
|
||||||
../contact (single contact view)
|
../contact (single contact view)
|
||||||
-------------------------------
|
-------------------------------
|
||||||
|
|
|
@ -23,10 +23,10 @@ If you do not have an OpenID address or do not wish to use OpenID, leave this fi
|
||||||
If you have an OpenID account elsewhere and wish to use it, enter the address into this field and click 'Register'.
|
If you have an OpenID account elsewhere and wish to use it, enter the address into this field and click 'Register'.
|
||||||
Friendica will attempt to extract as much information as possible from your OpenID provider and return to this page with those items already filled in.
|
Friendica will attempt to extract as much information as possible from your OpenID provider and return to this page with those items already filled in.
|
||||||
|
|
||||||
### Your Full Name
|
### Your Display Name
|
||||||
|
|
||||||
Please provide your full name **as you would like it to be displayed on this system**.
|
Please provide your display name **as you would like it to be displayed on this system**.
|
||||||
Most people use their real name for this, but you're under no obligation to do so yourself.
|
Some people use their real name for this, but you're under no obligation to do so yourself.
|
||||||
|
|
||||||
### Email Address
|
### Email Address
|
||||||
|
|
||||||
|
@ -101,7 +101,7 @@ See Also
|
||||||
|
|
||||||
* [Global Directory](help/Making-Friends#The+Directories)
|
* [Global Directory](help/Making-Friends#The+Directories)
|
||||||
|
|
||||||
* [Groups and Privacy](help/Groups-and-Privacy)
|
* [Circles and Privacy](help/Circles-and-Privacy)
|
||||||
|
|
||||||
* [Move Account](help/Move-Account)
|
* [Move Account](help/Move-Account)
|
||||||
|
|
||||||
|
|
|
@ -221,6 +221,15 @@ Please note: body contents are bbcode - not HTML
|
||||||
Called when receiving a post from another source. This may also be used to post local activity or system generated messages.
|
Called when receiving a post from another source. This may also be used to post local activity or system generated messages.
|
||||||
`$b` is the item array of information to be stored in the database and the item body is bbcode.
|
`$b` is the item array of information to be stored in the database and the item body is bbcode.
|
||||||
|
|
||||||
|
### detect_languages
|
||||||
|
Called after the language detection. This can be used for alternative language detection methods.
|
||||||
|
`$data` is an array:
|
||||||
|
|
||||||
|
- **text**: The text that is analyzed.
|
||||||
|
- **detected**: (input/output) Array of language codes detected in the related text. The array key is the language code, the array value the probability.
|
||||||
|
- **uri-id**: The Uri-Id of the item.
|
||||||
|
- **author-id**: The id of the author contact.
|
||||||
|
|
||||||
### addon_settings
|
### addon_settings
|
||||||
Called when generating the HTML for the addon settings page.
|
Called when generating the HTML for the addon settings page.
|
||||||
`$data` is an array containing:
|
`$data` is an array containing:
|
||||||
|
@ -800,6 +809,7 @@ Here is a complete list of all hook callbacks with file locations (as of 24-Sep-
|
||||||
|
|
||||||
### src/Model/Item.php
|
### src/Model/Item.php
|
||||||
|
|
||||||
|
Hook::callAll('detect_languages', $item);
|
||||||
Hook::callAll('post_local', $item);
|
Hook::callAll('post_local', $item);
|
||||||
Hook::callAll('post_remote', $item);
|
Hook::callAll('post_remote', $item);
|
||||||
Hook::callAll('post_local_end', $posted_item);
|
Hook::callAll('post_local_end', $posted_item);
|
||||||
|
|
|
@ -376,8 +376,8 @@ code</code></td>
|
||||||
[li] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/ul]<br>
|
[/ul]<br>
|
||||||
[list]<br>
|
[list]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listbullet" style="list-style-type: circle;">
|
<ul class="listbullet" style="list-style-type: circle;">
|
||||||
|
@ -388,12 +388,12 @@ code</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[ol]<br>
|
<td>[ol]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/ol]<br>
|
[/ol]<br>
|
||||||
[list=1]<br>
|
[list=1]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listdecimal" style="list-style-type: decimal;">
|
<ul class="listdecimal" style="list-style-type: decimal;">
|
||||||
|
@ -404,8 +404,8 @@ code</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=]<br>
|
<td>[list=]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listnone" style="list-style-type: none;">
|
<ul class="listnone" style="list-style-type: none;">
|
||||||
|
@ -416,8 +416,8 @@ code</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=i]<br>
|
<td>[list=i]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listlowerroman" style="list-style-type: lower-roman;">
|
<ul class="listlowerroman" style="list-style-type: lower-roman;">
|
||||||
|
@ -428,8 +428,8 @@ code</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=I]<br>
|
<td>[list=I]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listupperroman" style="list-style-type: upper-roman;">
|
<ul class="listupperroman" style="list-style-type: upper-roman;">
|
||||||
|
@ -440,8 +440,8 @@ code</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=a]<br>
|
<td>[list=a]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listloweralpha" style="list-style-type: lower-alpha;">
|
<ul class="listloweralpha" style="list-style-type: lower-alpha;">
|
||||||
|
@ -452,8 +452,8 @@ code</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=A]<br>
|
<td>[list=A]<br>
|
||||||
[*] First list element<br>
|
[li] First list element<br>
|
||||||
[*] Second list element<br>
|
[li] Second list element<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listupperalpha" style="list-style-type: upper-alpha;">
|
<ul class="listupperalpha" style="list-style-type: upper-alpha;">
|
||||||
|
|
|
@ -6,7 +6,7 @@ Bugs and Issues
|
||||||
If your server has a support page, you should report any bugs/issues you encounter there first.
|
If your server has a support page, you should report any bugs/issues you encounter there first.
|
||||||
Reporting to your support page before reporting to the developers makes their job easier, as they don't have to deal with bug reports that might not have anything to do with them.
|
Reporting to your support page before reporting to the developers makes their job easier, as they don't have to deal with bug reports that might not have anything to do with them.
|
||||||
Reducing the workload in this way helps us get new features faster.
|
Reducing the workload in this way helps us get new features faster.
|
||||||
You can also contact the [friendica support forum](https://forum.friendi.ca/profile/helpers) and report your problem there.
|
You can also contact the [friendica support group](https://forum.friendi.ca/profile/helpers) and report your problem there.
|
||||||
Bugs are rarely limited to one person, and the chances are somebody from another node has encountered the problem too, and will be able to help you.
|
Bugs are rarely limited to one person, and the chances are somebody from another node has encountered the problem too, and will be able to help you.
|
||||||
|
|
||||||
If you're a technical user, or your site doesn't have a support page, you'll need to use the [Bug Tracker](https://github.com/friendica/friendica/issues).
|
If you're a technical user, or your site doesn't have a support page, you'll need to use the [Bug Tracker](https://github.com/friendica/friendica/issues).
|
||||||
|
|
|
@ -0,0 +1,99 @@
|
||||||
|
Channels
|
||||||
|
=====
|
||||||
|
|
||||||
|
* [Home](help)
|
||||||
|
|
||||||
|
Channels are a way to discover new content or to display content that you might have missed otherwise.
|
||||||
|
There are several predefined channels, additionally you can create your own channels, based on some rules.
|
||||||
|
Channels only display posts from the last 24 hours (this value can be changed by the admin).
|
||||||
|
|
||||||
|
In the display settings in the section "Timelines" you can define which channels and other timelines you want to see in the "Channels" widget on the network page and which channels should appear in the menu bar at the top of the page.
|
||||||
|
|
||||||
|
Also in the display settings in the section "Channels" you can define all the languages that you want to see in your channels. Here you can select more than one language.
|
||||||
|
|
||||||
|
On the contact page you can define the channel frequency for every contact. The options are:
|
||||||
|
|
||||||
|
* Default frequency: Posts by this contact are displayed in the "for you" channel if you interact often with this contact or if a post reached some level of interaction.
|
||||||
|
* Display all posts of this contact: All posts from this contact will appear on the "for you" channel.
|
||||||
|
* Display only few posts: When a contact creates a lot of posts in a short period, this setting reduces the number of displayed posts in every channel.
|
||||||
|
* Never display posts: Posts from this contact will never be displayed in any channel.
|
||||||
|
|
||||||
|
Predefined Channels
|
||||||
|
---
|
||||||
|
|
||||||
|
* For you: Posts from contacts you interact with and who interact with you. In detail, it consists of:
|
||||||
|
* Posts from people you interact with on a more than average level.
|
||||||
|
* Posts from the accounts that you follow with a more than average number of interactions-
|
||||||
|
* Posts from accounts where you activated "notify on new posts" or where you have set the channel frequency accordingly.
|
||||||
|
* Discover: Posts from contacts you don't follow, but that might be of interest for you to follow. In detail, it consists of:
|
||||||
|
* Posts from people you don't follow but you interact with on a more than average level.
|
||||||
|
* Posts from people you don't follow but that interact with you on a more than average level.
|
||||||
|
* Popular posts from people you don't follow but you interacted with or who interacted with you on any level.
|
||||||
|
* What's Hot: Posts with a more than average number of interactions.
|
||||||
|
* Language: Posts in your language.
|
||||||
|
* Followers: Posts from your followers that you don't follow.
|
||||||
|
* Sharers of sharers: Posts from accounts that are followed by accounts that you follow.
|
||||||
|
* Quiet sharers: Posts from accounts that you follow but who don't post very often.
|
||||||
|
* Images: Posts with images.
|
||||||
|
* Audio: Posts with audio.
|
||||||
|
* Videos: Posts with videos.
|
||||||
|
|
||||||
|
User defined Channels
|
||||||
|
---
|
||||||
|
|
||||||
|
In the "Channels" settings you can create your own channels.
|
||||||
|
|
||||||
|
Each channel is defined by these values:
|
||||||
|
|
||||||
|
* Label: This value is mandatory and is used for the menu label.
|
||||||
|
* Description: A short description of the content. This can help to keep the overview, when you have got a lot of channels.
|
||||||
|
* Access Key: When you want to access this channel via an access key, you can define it here. Pay attention to not use an already used one.
|
||||||
|
* Circle: This defines the data source for this channel. By default it is set to the public timeline. There are some predefined values, like the accounts that you follow or the accounts that follow you. Also all of your circles can be selected.
|
||||||
|
* Include Tags: Comma separated list of tags. A post will be used when it contains any of the listed tags.
|
||||||
|
* Exclude Tags: Comma separated list of tags. If a post contain any of these tags, then it will not be part of nthis channel.
|
||||||
|
* Full Text Search: This can be used to include or exclude content, based on the content and some additional keywords. It uses the "boolean mode" operators from MariaDB: https://mariadb.com/kb/en/full-text-index-overview/#in-boolean-mode
|
||||||
|
* Images, Videos, Audio: When selected, you will see content with the selected media type. This can be combined. If none of these fields are checked, you will see any content, with or without attacked media.
|
||||||
|
|
||||||
|
Additional keywords for the full text search
|
||||||
|
---
|
||||||
|
|
||||||
|
Additionally to the search for content, there are keywords that can be used in the full text search.
|
||||||
|
Alternatives are presented with "|".
|
||||||
|
|
||||||
|
* from - Use "from:nickname" or "from:nickname@domain.tld" to search for posts from a specific author.
|
||||||
|
* to - Use "from:nickname" or "from:nickname@domain.tld" to search for posts with the given contact as receiver.
|
||||||
|
* group - Use "group:nickname" or "group:nickname@domain.tld" to search for group post of the given group.
|
||||||
|
* application | relay - Use "application:nickname" or "application:nickname@domain.tld" to search for posts that had been reshared by the given relay application.
|
||||||
|
* server - Use "server:hostname" to search for posts from a specific server. In the case of group postings, the search text contains both the hostname of the group server and the author's hostname.
|
||||||
|
* source - The ActivityPub type of the post source. Use this for example to include or exclude group posts or posts from services (aka bots).
|
||||||
|
* source:person - The post is created by a regular user account.
|
||||||
|
* source:organization - The post is created by an organisation.
|
||||||
|
* source:group - The post is created by or distributed via a group.
|
||||||
|
* source:service | source:news - The posts originates from a service account. This source type is often used to mark bot accounts.
|
||||||
|
* source:application | source:relay - The post is created by an application. This is most likely unused in the fediverse for post creation.
|
||||||
|
* tag - Use "tag:tagname" to search for a specific tag.
|
||||||
|
* media - With this keyword you can search for attached media.
|
||||||
|
* media:image | media:photo | media:picture - The post contains an image
|
||||||
|
* media:video - The post contains a video
|
||||||
|
* media:audio - The post contains audio
|
||||||
|
* media:card - The post contains a link preview card
|
||||||
|
* media:post - The post links another post, means it is a quoted post
|
||||||
|
* network | net - Use this to include or exclude some networks from your channel.
|
||||||
|
* network:apub | network:activitypub - ActivityPub (Used by the systems in the Fediverse)
|
||||||
|
* network:dfrn | network:friendica - Legacy Friendica protocol. Nowayday Friendica mostly uses ActivityPub.
|
||||||
|
* network:dspr | network:diaspora - The Diaspora protocol is mainly used by Diaspora itself. Some other systems support the protocol as well like Hubzilla, Socialhome or Ganggo.
|
||||||
|
* network:feed - RSS/Atom feeds
|
||||||
|
* network:mail - Mails that had been imported via IMAP.
|
||||||
|
* network:stat | network:ostatus - The OStatus protocol is mainly used by old GNU Social installations.
|
||||||
|
* network:dscs | network:discourse - Posts that are received by the Discourse connector.
|
||||||
|
* network:tmbl | network:tumblr - Posts that are received by the Tumblr connector.
|
||||||
|
* network:bsky | network:bluesky - Posts that are received by the Bluesky connector.
|
||||||
|
* platform - Use this to include or exclude some platforms from your channel, e.g. "+platform:friendica". In the case of group postings, the search text contains both the platform of the group server and the author's platform.
|
||||||
|
* visibility - You have the choice between different visibilities. You can only see unlisted or private posts that you have the access for.
|
||||||
|
* visibility:public
|
||||||
|
* visibility:unlisted
|
||||||
|
* visibility:private
|
||||||
|
* language | lang - Use "language:code" to search for posts with the given language in the [ISO 639-1](https://en.wikipedia.org/wiki/ISO_639-1) format.
|
||||||
|
|
||||||
|
Remember that you can combine these kerywords.
|
||||||
|
So for example you can create a channel with all posts that talk about the Fediverse - that aren't posted in the Fediverse with the search terms: "fediverse -network:apub -network:dfrn"
|
|
@ -1,55 +1,55 @@
|
||||||
Groups and Privacy
|
Circles and Privacy
|
||||||
==================
|
==================
|
||||||
|
|
||||||
* [Home](help)
|
* [Home](help)
|
||||||
|
|
||||||
|
|
||||||
Groups are merely collections of friends.
|
Circles are merely collections of friends.
|
||||||
But Friendica uses these to unlock some very powerful features.
|
But Friendica uses these to unlock some very powerful features.
|
||||||
|
|
||||||
**Setting Up Groups**
|
**Setting Up Circles**
|
||||||
|
|
||||||
To create a group, visit your Friendica "Contacts" page and select "Create a new group".
|
To create a circle, visit your Friendica "Contacts" page and select "Create a new circle".
|
||||||
Give the group a name.
|
Give the circle a name.
|
||||||
|
|
||||||
This brings you to a page where you can select the group members.
|
This brings you to a page where you can select the circle members.
|
||||||
|
|
||||||
You will have two boxes on this page.
|
You will have two boxes on this page.
|
||||||
The top box is the roster of current group members.
|
The top box is the roster of current circle members.
|
||||||
Below that is another box containing all of your friends who are *not* members of the group.
|
Below that is another box containing all of your friends who are *not* members of the circle.
|
||||||
|
|
||||||
If you click on a photo of a person who isn't in the group, they will be put into the group.
|
If you click on a photo of a person who isn't in the circle, they will be put into the circle.
|
||||||
If you click on a photo of a person who is in the group, they will be removed from it.
|
If you click on a photo of a person who is in the circle, they will be removed from it.
|
||||||
|
|
||||||
**Access Control**
|
**Access Control**
|
||||||
|
|
||||||
Once you have created a group, you may use it in any access control list.
|
Once you have created a circle, you may use it in any access control list.
|
||||||
This is the little lock icon beneath the status update box on your home page.
|
This is the little lock icon beneath the status update box on your home page.
|
||||||
If you click this you can select who can see and who can *not* see the post you are about to make..
|
If you click this, you can select who can see and who can *not* see the post you are about to make...
|
||||||
These can be individual people or groups.
|
These can be individual people or circles.
|
||||||
|
|
||||||
On your "Network" page you will find posts and conversation from everybody in your network.
|
On your "Network" page, you will find posts and conversations from everybody in your network.
|
||||||
You may select an individual group on this page to show conversations pertaining only to members of that group.
|
You may select an individual circle on this page to show conversations pertaining only to members of that circle.
|
||||||
|
|
||||||
But wait, there's more...
|
But wait, there's more...
|
||||||
|
|
||||||
If you look carefully when visiting a group from your Network page, the lock icon under the status update box has an exclamation mark next to it.
|
If you look carefully when visiting a circle from your Network page, the lock icon under the status update box has an exclamation mark next to it.
|
||||||
This is meant to draw attention to that lock.
|
This is meant to draw attention to that lock.
|
||||||
Click the lock.
|
Click the lock.
|
||||||
You will see that since you are only viewing a certain group of people, your status updates while on that screen default to only being seen by that same group of people.
|
You will see that since you are only viewing a certain circle of people, your status updates while on that screen default to only being seen by that same circle of people.
|
||||||
This is how you keep your future employers from seeing what you write to your drinking buddies.
|
This is how you keep your future employers from seeing what you write to your drinking buddies.
|
||||||
You can over-ride this setting, but this makes it easy to separate your conversations into different friend circles.
|
You can override this setting, but this makes it easy to separate your conversations into different friend circles.
|
||||||
|
|
||||||
**Default Post Privacy**
|
**Default Post Privacy**
|
||||||
|
|
||||||
By default, Friendica assumes that you want all of your posts to be private.
|
By default, Friendica assumes that you want all of your posts to be private.
|
||||||
Therefore, when you sign up, Friendica creates a group for you that it will automatically add all of your contacts to.
|
Therefore, when you sign up, Friendica creates a circle for you that it will automatically add all of your contacts to.
|
||||||
All of your posts are restricted to that group by default.
|
All of your posts are restricted to that circle by default.
|
||||||
|
|
||||||
Note that this behaviour can be overridden by your site admin, in which case your posts will be "public" (i.e. visible to the entire Internet) by default.
|
Note that this behaviour can be overridden by your site admin, in which case your posts will be "public" (i.e., visible to the entire Internet) by default.
|
||||||
|
|
||||||
If you want your posts to be "public" by default, you can change your default post permissions on your Settings page.
|
If you want your posts to be "public" by default, you can change your default post permissions on your Settings page.
|
||||||
You also have the option there to change which groups you post to by default, or to change which group your new contacts get placed into by default.
|
You also have the option to change which circles you post to by default or which circle your new contacts get placed into by default.
|
||||||
|
|
||||||
**Privacy Concerns To Be Aware Of**
|
**Privacy Concerns To Be Aware Of**
|
||||||
|
|
||||||
|
@ -60,19 +60,17 @@ This is a trust issue you need to be aware of.
|
||||||
No software in the world can prevent your friends from leaking your confidential and trusted communications.
|
No software in the world can prevent your friends from leaking your confidential and trusted communications.
|
||||||
Only a wise choice of friends.
|
Only a wise choice of friends.
|
||||||
|
|
||||||
But it isn't as clear cut when dealing with GNU Social and other network providers.
|
But it isn't as clear-cut when dealing with GNU Social and other network providers.
|
||||||
If you look at the Contact Edit page for any person, we will tell you whether or not they are members of an insecure network where you should exercise caution.
|
If you look at the Contact Edit page for any person, we will tell you whether or not they are members of an insecure network where you should exercise caution.
|
||||||
|
|
||||||
Once you have created a post, you can not change the permissions assigned.
|
Once you have created a post, you can not change the permissions assigned.
|
||||||
Within seconds it has been delivered to lots of people - and perhaps everybody it was addressed to.
|
Within seconds it has been delivered to lots of people - and perhaps everybody it was addressed to.
|
||||||
If you mistakenly created a message and wish you could take it back, the best you can do is to delete it.
|
If you mistakenly created a message and wish to take it back, the best you can do is delete it.
|
||||||
We will send out a delete notification to everybody who received the message - and this should wipe out the message with the same speed it was initially propagated.
|
We will send out a delete notification to everybody who received the message - and this should wipe out the message with the same speed as it was initially propagated.
|
||||||
In most cases it will be completely wiped from the Internet - in under a minute.
|
In most cases, it will be completely wiped from the Internet - in under a minute.
|
||||||
Again, this applies to Friendica networks.
|
Again, this applies to Friendica networks.
|
||||||
Once a message spreads to other networks, it may not be removed quickly and in some cases it may not be removed at all.
|
Once a message spreads to other networks, it may not be removed quickly, and in some cases, it may not be removed at all.
|
||||||
|
|
||||||
In case you haven't yet figured this out, we are encouraging you to encourage your friends to use Friendica - because all these privacy features work much better within a privacy-aware network.
|
|
||||||
Many of the other social networks Friendica can connect to have no privacy controls.
|
|
||||||
|
|
||||||
|
|
||||||
Profiles, Photos, and Privacy
|
Profiles, Photos, and Privacy
|
|
@ -13,14 +13,14 @@ Whether you feel like an expert or like a newbie - join us with your ideas!
|
||||||
|
|
||||||
## Contact us
|
## Contact us
|
||||||
|
|
||||||
The discussion of Friendica development takes place in the following Friendica forums:
|
The discussion of Friendica development takes place in the following Friendica groups:
|
||||||
|
|
||||||
* The main [forum for Friendica development](https://forum.friendi.ca/profile/developers)
|
* The main [group for Friendica development](https://forum.friendi.ca/profile/developers)
|
||||||
|
|
||||||
## Help other users
|
## Help other users
|
||||||
|
|
||||||
Remember the questions you had when you first tried Friendica?
|
Remember the questions you had when you first tried Friendica?
|
||||||
A good place to start can be to help new people find their way around Friendica in the [general support forum](https://forum.friendi.ca/profile/helpers).
|
A good place to start can be to help new people find their way around Friendica in the [general support group](https://forum.friendi.ca/profile/helpers).
|
||||||
Welcome them, answer their questions, point them to documentation or ping other helpers directly if you can't help but think you know who can.
|
Welcome them, answer their questions, point them to documentation or ping other helpers directly if you can't help but think you know who can.
|
||||||
|
|
||||||
## Translation
|
## Translation
|
||||||
|
@ -33,10 +33,10 @@ If you don't want to translate the UI, or it is already done to your satisfactio
|
||||||
Are you good at designing things?
|
Are you good at designing things?
|
||||||
If you have seen Friendica you probably have ideas to improve it, haven't you?
|
If you have seen Friendica you probably have ideas to improve it, haven't you?
|
||||||
|
|
||||||
* If you would like to work with us on enhancing the user interface, please join the [forum for Friendica development](https://forum.friendi.ca/profile/developers).
|
* If you would like to work with us on enhancing the user interface, please join the [group for Friendica development](https://forum.friendi.ca/profile/developers).
|
||||||
* Make plans for a better Friendica interface design and share them with us.
|
* Make plans for a better Friendica interface design and share them with us.
|
||||||
* Tell us if you are able to realize your ideas or what kind of help you need.
|
* Tell us if you are able to realize your ideas or what kind of help you need.
|
||||||
We can't promise we have the right skills in the group but we'll try.
|
We can't promise we have the right skills in the group, but we'll try.
|
||||||
* Choose a thing to start with, e.g. work on the icon set of your favorite theme
|
* Choose a thing to start with, e.g. work on the icon set of your favorite theme
|
||||||
|
|
||||||
## Programming
|
## Programming
|
||||||
|
@ -72,7 +72,7 @@ just place it into `.git/hooks/post-merge` and make it executable.
|
||||||
|
|
||||||
### Coding standards
|
### Coding standards
|
||||||
|
|
||||||
For the sake of consistency between contribution and general code readability, Friendica follows the widespread [PSR-2 coding standards](http://www.php-fig.org/psr/psr-2/) to the exception of a few rules.
|
For the sake of consistency between contribution and general code readability, Friendica follows the widespread [PSR-2 coding standards](http://www.php-fig.org/psr/psr-2/) excepted a few rules.
|
||||||
Here's a few primers if you are new to Friendica or to the PSR-2 coding standards:
|
Here's a few primers if you are new to Friendica or to the PSR-2 coding standards:
|
||||||
|
|
||||||
* Indentation is tabs, period (not PSR-2).
|
* Indentation is tabs, period (not PSR-2).
|
||||||
|
@ -88,7 +88,7 @@ Here's a few primers if you are new to Friendica or to the PSR-2 coding standard
|
||||||
Don't worry, you don't have to know by heart the PSR-2 coding standards to start contributing to Friendica.
|
Don't worry, you don't have to know by heart the PSR-2 coding standards to start contributing to Friendica.
|
||||||
There are a few tools you can use to check or fix your files before you commit.
|
There are a few tools you can use to check or fix your files before you commit.
|
||||||
|
|
||||||
For documentation we use the standard of *one sentence per line* for the `md` files in the `/doc` and `/doc/$lng` subdirectories.
|
For documentation, we use the standard of *one sentence per line* for the `md` files in the `/doc` and `/doc/$lng` subdirectories.
|
||||||
|
|
||||||
#### Check with [PHP Code Sniffer](https://github.com/squizlabs/PHP_CodeSniffer)
|
#### Check with [PHP Code Sniffer](https://github.com/squizlabs/PHP_CodeSniffer)
|
||||||
|
|
||||||
|
@ -113,7 +113,7 @@ If the command-line tools `diff` and `patch` are unavailable for you, `phpcbf` c
|
||||||
|
|
||||||
### Code documentation
|
### Code documentation
|
||||||
|
|
||||||
If you are interested in having the documentation of the Friendica code outside of the code files, you can use [Doxygen](http://doxygen.org) to generate it.
|
If you are interested in having the documentation of the Friendica code outside the code files, you can use [Doxygen](http://doxygen.org) to generate it.
|
||||||
The configuration file for Doxygen is located in the base directory of the project sources.
|
The configuration file for Doxygen is located in the base directory of the project sources.
|
||||||
Run
|
Run
|
||||||
|
|
||||||
|
@ -126,7 +126,7 @@ If you find missing documentation, don't hesitate to contact us and write it dow
|
||||||
|
|
||||||
### Issues
|
### Issues
|
||||||
|
|
||||||
Have a look at our [issue tracker](https://github.com/friendica/friendica) on github!
|
Have a look at our [issue tracker](https://github.com/friendica/friendica) on GitHub!
|
||||||
|
|
||||||
* Try to reproduce a bug that needs more inquiries and write down what you find out.
|
* Try to reproduce a bug that needs more inquiries and write down what you find out.
|
||||||
* If a bug looks fixed, ask the bug reporters for feedback to find out if the bug can be closed.
|
* If a bug looks fixed, ask the bug reporters for feedback to find out if the bug can be closed.
|
||||||
|
@ -143,13 +143,13 @@ If you want to get involved here:
|
||||||
* Look at the first steps that were made (e.g. the clean theme).
|
* Look at the first steps that were made (e.g. the clean theme).
|
||||||
Ask us to find out whom to talk to about their experiences.
|
Ask us to find out whom to talk to about their experiences.
|
||||||
* Talk to design people if you know any.
|
* Talk to design people if you know any.
|
||||||
* Let us know about your plans [in the dev forum](https://forum.friendi.ca/profile/developers)
|
* Let us know about your plans [in the dev group](https://forum.friendi.ca/profile/developers)
|
||||||
Do not worry about cross-posting.
|
Do not worry about cross-posting.
|
||||||
|
|
||||||
### Client software
|
### Client software
|
||||||
|
|
||||||
As Friendica is using a [Twitter/GNU Social compatible API](help/api) any of the clients for those platforms should work with Friendica as well.
|
As Friendica is using a [Twitter/GNU Social compatible API](help/api) any of the clients for those platforms should work with Friendica as well.
|
||||||
Furthermore there are several client projects, especially for use with Friendica.
|
Furthermore, there are several client projects, especially for use with Friendica.
|
||||||
If you are interested in improving those clients, please contact the developers of the clients directly.
|
If you are interested in improving those clients, please contact the developers of the clients directly.
|
||||||
|
|
||||||
* Android / LinageOS: **Friendiqa** [src](https://git.friendi.ca/lubuwest/Friendiqa)/[Google Play](https://play.google.com/store/apps/details?id=org.qtproject.friendiqa) developed by [Marco R](https://freunde.ma-nic.de/profile/marco)
|
* Android / LinageOS: **Friendiqa** [src](https://git.friendi.ca/lubuwest/Friendiqa)/[Google Play](https://play.google.com/store/apps/details?id=org.qtproject.friendiqa) developed by [Marco R](https://freunde.ma-nic.de/profile/marco)
|
||||||
|
|
|
@ -42,7 +42,7 @@ The listed emails need to be separated by a comma like this:
|
||||||
'admin_email' => 'mail1@example.com,mail2@example.com',
|
'admin_email' => 'mail1@example.com,mail2@example.com',
|
||||||
```
|
```
|
||||||
|
|
||||||
<a name="dbupdate">
|
<a name="dbupdate"></a>
|
||||||
### The Database structure seems not to be updated. What can I do?
|
### The Database structure seems not to be updated. What can I do?
|
||||||
|
|
||||||
Please have a look at the Admin panel under [DB updates](/admin/dbsync/) and follow the link to *check database structure*.
|
Please have a look at the Admin panel under [DB updates](/admin/dbsync/) and follow the link to *check database structure*.
|
||||||
|
@ -52,4 +52,4 @@ You can manually execute the structure update from the CLI in the base directory
|
||||||
|
|
||||||
bin/console dbstructure update
|
bin/console dbstructure update
|
||||||
|
|
||||||
if there occur any errors, please contact the [support forum](https://forum.friendi.ca/profile/helpers).
|
if there occur any errors, please contact the [Friendica Support group](https://forum.friendi.ca/profile/helpers) or discuss in the [Friendica Admins group](https://forum.friendi.ca/profile/admins).
|
||||||
|
|
42
doc/FAQ.md
|
@ -4,14 +4,14 @@ Frequently Asked Questions - FAQ
|
||||||
* [Home](help)
|
* [Home](help)
|
||||||
|
|
||||||
* **[Where I can find help?](help/FAQ#help)**
|
* **[Where I can find help?](help/FAQ#help)**
|
||||||
* **[Why do I getting warnings about certificates?](help/FAQ#ssl)**
|
* **[Why do I get warnings about certificates?](help/FAQ#ssl)**
|
||||||
* **[How can I upload images, files, links, videos and sound files to posts?](help/FAQ#upload)**
|
* **[How can I upload images, files, links, videos and sound files to posts?](help/FAQ#upload)**
|
||||||
* **[Is it possible to have different avatars per profile?](help/FAQ#avatars)**
|
* **[Is it possible to have different avatars per profile?](help/FAQ#avatars)**
|
||||||
* **[How can I view Friendica in a certain language?](help/FAQ#language)**
|
* **[How can I view Friendica in a certain language?](help/FAQ#language)**
|
||||||
* **[How do blocked, ignored, archived and hidden contacts behave?](help/FAQ#contacts)**
|
* **[How do blocked, ignored, archived and hidden contacts behave?](help/FAQ#contacts)**
|
||||||
* **[What happens when an account is removed? Is it truly deleted?](help/FAQ#removed)**
|
* **[What happens when an account is removed? Is it truly deleted?](help/FAQ#removed)**
|
||||||
* **[Can I subscribe to a hashtag?](help/FAQ#hashtag)**
|
* **[Can I subscribe to a hashtag?](help/FAQ#hashtag)**
|
||||||
* **[How to create a RSS feed of the stream?](help/FAQ#rss)**
|
* **[How to create an RSS feed of the stream?](help/FAQ#rss)**
|
||||||
* **[What friendica clients can I use?](help/FAQ#clients)**
|
* **[What friendica clients can I use?](help/FAQ#clients)**
|
||||||
|
|
||||||
|
|
||||||
|
@ -21,7 +21,7 @@ Frequently Asked Questions - FAQ
|
||||||
|
|
||||||
If this FAQ does not answer your question you can always reach out to the community via the following options:
|
If this FAQ does not answer your question you can always reach out to the community via the following options:
|
||||||
|
|
||||||
* Friendica Support Forum: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
* Friendica Support Group: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
||||||
* Community chat rooms (the IRC, Matrix and XMPP rooms are bridged) these public chats are logged [from IRC](https://gnusociarg.nsupdate.info/2021/%23friendica/) and [Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/)
|
* Community chat rooms (the IRC, Matrix and XMPP rooms are bridged) these public chats are logged [from IRC](https://gnusociarg.nsupdate.info/2021/%23friendica/) and [Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/)
|
||||||
* XMPP: support(at)forum.friendi.ca
|
* XMPP: support(at)forum.friendi.ca
|
||||||
* IRC: #friendica at [libera.chat](https://web.libera.chat/?channels=#friendica)
|
* IRC: #friendica at [libera.chat](https://web.libera.chat/?channels=#friendica)
|
||||||
|
@ -66,7 +66,7 @@ If this doesn't work, try to add the link by typing: [url=http://example.com]*se
|
||||||
You can also add video and audio files to posts.
|
You can also add video and audio files to posts.
|
||||||
However, instead of a direct upload you have to use one of the following methods:
|
However, instead of a direct upload you have to use one of the following methods:
|
||||||
|
|
||||||
1. Add the video or audio link of a hoster (Youtube, Vimeo, Soundcloud and anyone else with oembed/opengraph-support). Videos will be shown with a preview image you can click on to start. SoundCloud directly inserts a player to your post.
|
1. Add the video or audio link of a hoster (YouTube, Vimeo, Soundcloud and anyone else with oembed/opengraph-support). Videos will be shown with a preview image you can click on to start. SoundCloud directly inserts a player to your post.
|
||||||
|
|
||||||
2. If you have your own server, you can upload multimedia files via FTP and insert the URL.
|
2. If you have your own server, you can upload multimedia files via FTP and insert the URL.
|
||||||
|
|
||||||
|
@ -107,33 +107,33 @@ When a certain language is forced, the language remains until session is closed.
|
||||||
|
|
||||||
Direct communication will be blocked.
|
Direct communication will be blocked.
|
||||||
Blocked contacts are not included in delivery, and their own posts to you are not imported.
|
Blocked contacts are not included in delivery, and their own posts to you are not imported.
|
||||||
However their conversations with your friends will still be visible in your stream.
|
However, their conversations with your friends will still be visible in your stream.
|
||||||
If you remove a contact completely, they can send you another friend request.
|
If you remove a contact completely, they can send you another friend request.
|
||||||
Blocked contacts cannot do this. They cannot communicate with you directly, only through friends.
|
Blocked contacts cannot do this. They cannot communicate with you directly, only through friends.
|
||||||
|
|
||||||
##### Ignored
|
##### Ignored
|
||||||
|
|
||||||
Ignored contacts are included in delivery and will receive your posts and private messages.
|
Ignored contacts are included in delivery and will receive your posts and private messages.
|
||||||
However we do not import their posts or private messages to you.
|
However, we do not import their posts or private messages to you.
|
||||||
Like blocking you will still see this person's comments to posts made by your friends.
|
Like blocking, you will still see this person's comments to posts made by your friends.
|
||||||
|
|
||||||
An addon called "blockem" can be installed to collapse/hide all posts from a particular person in your stream if you desire complete blocking of an individual, including their conversations with your other friends.
|
An addon called "blockem" can be installed to collapse/hide all posts from a particular person in your stream if you desire complete blocking of an individual, including their conversations with your other friends.
|
||||||
|
|
||||||
##### Archived
|
##### Archived
|
||||||
|
|
||||||
Communication is not possible and will not be attempted.
|
Communication is not possible and will not be attempted.
|
||||||
However unlike blocking, existing posts this person made before being archived will be visible in your stream.
|
However, unlike blocking, existing posts this person made before being archived will be visible in your stream.
|
||||||
|
|
||||||
##### Hidden
|
##### Hidden
|
||||||
|
|
||||||
Contact not be displayed in your public friend list.
|
Contact not be displayed in your public friend list.
|
||||||
However a hidden contact will appear normally in conversations and this may expose their hidden status to anybody who can see the conversation.
|
However, a hidden contact will appear normally in conversations and this may expose their hidden status to anybody who can see the conversation.
|
||||||
|
|
||||||
<a name="removed"></a>
|
<a name="removed"></a>
|
||||||
### What happens when an account is removed?
|
### What happens when an account is removed?
|
||||||
|
|
||||||
If you remove your account, it will be scheduled for permanent deletion in *seven days*.
|
If you remove your account, it will be scheduled for permanent deletion in *seven days*.
|
||||||
As soon as you activate the deletion process you won't be able to login any more.
|
As soon as you activate the deletion process you won't be able to log in anymore.
|
||||||
Only the administrator of your node can halt this process prior to permanent deletion.
|
Only the administrator of your node can halt this process prior to permanent deletion.
|
||||||
|
|
||||||
After the elapsed time of seven days, all your posts, messages, photos, and personal information stored on your node will be deleted.
|
After the elapsed time of seven days, all your posts, messages, photos, and personal information stored on your node will be deleted.
|
||||||
|
@ -143,12 +143,12 @@ Your username cannot be reissued for future sign-ups for security reasons.
|
||||||
<a name="hashtag"></a>
|
<a name="hashtag"></a>
|
||||||
### Can I follow a hashtag?
|
### Can I follow a hashtag?
|
||||||
|
|
||||||
Yes. Simply add the hash tag to your saved searches.
|
Yes. Simply add the hashtag to your saved searches.
|
||||||
The posts will appear on your network page.
|
The posts will appear on your network page.
|
||||||
For technical reasons, your answers to such posts won't appear on the "personal" tab in the network page and the whole thread isn't accessible via the API.
|
For technical reasons, your answers to such posts won't appear on the "personal" tab in the network page and the whole thread isn't accessible via the API.
|
||||||
|
|
||||||
<a name="rss"></a>
|
<a name="rss"></a>
|
||||||
### How to create a RSS feed of the stream?
|
### How to create an RSS feed of the stream?
|
||||||
|
|
||||||
If you want to share your public page via rss you can use one of the following links:
|
If you want to share your public page via rss you can use one of the following links:
|
||||||
|
|
||||||
|
@ -178,12 +178,12 @@ The available features are client specific and may differ.
|
||||||
#### Android
|
#### Android
|
||||||
|
|
||||||
* [AndStatus](http://andstatus.org) ([F-Droid](https://f-droid.org/repository/browse/?fdid=org.andstatus.app), [Google Play](https://play.google.com/store/apps/details?id=org.andstatus.app))
|
* [AndStatus](http://andstatus.org) ([F-Droid](https://f-droid.org/repository/browse/?fdid=org.andstatus.app), [Google Play](https://play.google.com/store/apps/details?id=org.andstatus.app))
|
||||||
* [Fedi](https://github.com/Big-Fig/Fediverse.app) ([Google Play](https://play.google.com/store/apps/details?id=com.fediverse.app))
|
|
||||||
* [Fedilab](https://fedilab.app) ([F-Droid](https://f-droid.org/app/fr.gouv.etalab.mastodon), [Google Play](https://play.google.com/store/apps/details?id=app.fedilab.android))
|
* [Fedilab](https://fedilab.app) ([F-Droid](https://f-droid.org/app/fr.gouv.etalab.mastodon), [Google Play](https://play.google.com/store/apps/details?id=app.fedilab.android))
|
||||||
* [Friendiqa](https://git.friendi.ca/lubuwest/Friendiqa) ([F-Droid](https://git.friendi.ca/lubuwest/Friendiqa#install), [Google Play](https://play.google.com/store/apps/details?id=org.qtproject.friendiqa))
|
* [Friendiqa](https://git.friendi.ca/lubuwest/Friendiqa) ([F-Droid](https://git.friendi.ca/lubuwest/Friendiqa#install), [Google Play](https://play.google.com/store/apps/details?id=org.qtproject.friendiqa))
|
||||||
* [Husky](https://git.sr.ht/~captainepoch/husky) ([F-Droid](https://f-droid.org/repository/browse/?fdid=su.xash.husky), [Google Play](https://play.google.com/store/apps/details?id=su.xash.husky))
|
* [Husky](https://codeberg.org/husky/husky) ([F-Droid](https://f-droid.org/repository/browse/?fdid=su.xash.husky), [Google Play](https://play.google.com/store/apps/details?id=su.xash.husky))
|
||||||
* [Mastodon](https://github.com/mastodon/mastodon-android) ([F-Droid](https://f-droid.org/en/packages/org.joinmastodon.android/), [Google Play](https://play.google.com/store/apps/details?id=org.joinmastodon.android))
|
* [Mastodon](https://github.com/mastodon/mastodon-android) ([F-Droid](https://f-droid.org/en/packages/org.joinmastodon.android/), [Google Play](https://play.google.com/store/apps/details?id=org.joinmastodon.android))
|
||||||
* [Subway Tooter](https://github.com/tateisu/SubwayTooter) ([F-Droid](https://android.izzysoft.de/repo/apk/jp.juggler.subwaytooter))
|
* [Pachli](https://pachli.app/) ([F-Droid](https://f-droid.org/en/packages/app.pachli/), [Google Play](https://play.google.com/store/apps/details?id=app.pachli))
|
||||||
|
* [Subway Tooter](https://github.com/tateisu/SubwayTooter) ([F-Droid via Izzy](https://android.izzysoft.de/repo/apk/jp.juggler.subwaytooter.noFcm))
|
||||||
* [Tooot](https://tooot.app/) ([Google Play](https://play.google.com/store/apps/details?id=com.xmflsct.app.tooot))
|
* [Tooot](https://tooot.app/) ([Google Play](https://play.google.com/store/apps/details?id=com.xmflsct.app.tooot))
|
||||||
* [Tusky](https://tusky.app) ([F-Droid](https://f-droid.org/repository/browse/?fdid=com.keylesspalace.tusky), [Google Play](https://play.google.com/store/apps/details?id=com.keylesspalace.tusky))
|
* [Tusky](https://tusky.app) ([F-Droid](https://f-droid.org/repository/browse/?fdid=com.keylesspalace.tusky), [Google Play](https://play.google.com/store/apps/details?id=com.keylesspalace.tusky))
|
||||||
* [TwidereX](https://github.com/TwidereProject/TwidereX-Android) ([F-Droid](https://f-droid.org/en/packages/com.twidere.twiderex/), [Google Play](https://play.google.com/store/apps/details?id=com.twidere.twiderex))
|
* [TwidereX](https://github.com/TwidereProject/TwidereX-Android) ([F-Droid](https://f-droid.org/en/packages/com.twidere.twiderex/), [Google Play](https://play.google.com/store/apps/details?id=com.twidere.twiderex))
|
||||||
|
@ -191,10 +191,10 @@ The available features are client specific and may differ.
|
||||||
|
|
||||||
#### iOS
|
#### iOS
|
||||||
|
|
||||||
* [Mastodon](https://joinmastodon.org/apps) ([AppStore](https://apps.apple.com/us/app/mastodon-for-iphone/id1571998974))
|
* [Mastodon](https://joinmastodon.org/apps) ([App Store](https://apps.apple.com/us/app/mastodon-for-iphone/id1571998974))
|
||||||
* [Stella*](https://www.stella-app.net/) ([AppStore](https://apps.apple.com/us/app/stella-for-mastodon-twitter/id921372048))
|
* [Stella*](https://www.stella-app.net/) ([App Store](https://apps.apple.com/us/app/stella-for-mastodon-twitter/id921372048))
|
||||||
* [Tooot](https://github.com/tooot-app) ([AppStore](https://apps.apple.com/app/id1549772269)
|
* [Tooot](https://github.com/tooot-app) ([App Store](https://apps.apple.com/app/id1549772269))
|
||||||
* [TwidereX](https://github.com/TwidereProject/TwidereX-iOS) ([AppStore](https://apps.apple.com/app/twidere-x/id1530314034))
|
* [TwidereX](https://github.com/TwidereProject/TwidereX-iOS) ([App Store](https://apps.apple.com/app/twidere-x/id1530314034))
|
||||||
|
|
||||||
#### Linux
|
#### Linux
|
||||||
|
|
||||||
|
@ -206,12 +206,12 @@ The available features are client specific and may differ.
|
||||||
#### macOS
|
#### macOS
|
||||||
|
|
||||||
* [TheDesk](https://thedesk.top/en/) ([GitHub](https://github.com/cutls/TheDesk))
|
* [TheDesk](https://thedesk.top/en/) ([GitHub](https://github.com/cutls/TheDesk))
|
||||||
* [Whalebird](https://whalebird.social/en/desktop/contents) ([AppStore](https://apps.apple.com/de/app/whalebird/id1378283354), [GitHub](https://github.com/h3poteto/whalebird-desktop))
|
* [Whalebird](https://whalebird.social/en/desktop/contents) ([App Store](https://apps.apple.com/de/app/whalebird/id1378283354), [GitHub](https://github.com/h3poteto/whalebird-desktop))
|
||||||
|
|
||||||
#### Windows
|
#### Windows
|
||||||
|
|
||||||
* [TheDesk](https://thedesk.top/en/) ([GitHub](https://github.com/cutls/TheDesk))
|
* [TheDesk](https://thedesk.top/en/) ([GitHub](https://github.com/cutls/TheDesk))
|
||||||
* [Whalebird](https://whalebird.social/en/desktop/contents) ([Website Download](https://whalebird.social/en/desktop/contents/downloads#windows), [GitHub](https://github.com/h3poteto/whalebird-desktop))
|
* [Whalebird](https://whalebird.social/en/desktop/contents) ([Microsoft Store](https://apps.microsoft.com/detail/9nbw4csdv5hc), [GitHub](https://github.com/h3poteto/whalebird-desktop))
|
||||||
|
|
||||||
#### Web Frontend
|
#### Web Frontend
|
||||||
|
|
||||||
|
|
|
@ -1,66 +0,0 @@
|
||||||
Forums
|
|
||||||
=====
|
|
||||||
|
|
||||||
* [Home](help)
|
|
||||||
|
|
||||||
|
|
||||||
Friendica also lets you create community forums and other types of accounts that can function as discussion forums, celebrity accounts, announcement channels, news reflectors, or organization pages, depending on how you want to interact with others. Management of these pages can be delegated to other accounts, or a parent account can be designated to easily toggle multiple identities.
|
|
||||||
|
|
||||||
Every page in Friendica has a nickname and these must all be unique. This applies to all forums, whether they are normal profiles or forum profiles.
|
|
||||||
|
|
||||||
Managing Accounts
|
|
||||||
---
|
|
||||||
|
|
||||||
To create a new linked account that can be used as a forum, log in to your normal account and go to Settings > Manage Accounts.
|
|
||||||
Here you can register additional accounts with new nicknames that will be linked to your primary account.
|
|
||||||
|
|
||||||
You may appoint a delegate to manage your new account (e.g. forum page).
|
|
||||||
The Delegates section of Manage Accounts page will provide you with a list of contacts on this instance under "Potential Delegates".
|
|
||||||
Selecting one or more persons will give them access to manage your forum.
|
|
||||||
They will be able to edit contacts, profiles, and all content for this account/page.
|
|
||||||
Please use this facility wisely.
|
|
||||||
Delegated managers will not be able to alter basic account settings, such as passwords or page types, or remove the account.
|
|
||||||
|
|
||||||
Additionally, this page is also where you can choose to designate an account as a parent user.
|
|
||||||
If your primary account is designated as the parent user, you will be able to easily toggle identities and manage your forums or other types of accounts.
|
|
||||||
|
|
||||||
Types of Accounts
|
|
||||||
---
|
|
||||||
|
|
||||||
On the new account, visit the Settings > Account page.
|
|
||||||
Towards the end of the page is a section for "Advanced account types".
|
|
||||||
Typically you would use "Personal Page - Standard" for a normal personal account with manual approval of “friends” and “followers.”
|
|
||||||
This is the default selection.
|
|
||||||
On this page you can change the type of account if desired.
|
|
||||||
|
|
||||||
The other subtypes of a Personal Page are “Soapbox” and “Love-all.”
|
|
||||||
A Soapbox account is an announcement channel that automatically approvals follower requests.
|
|
||||||
Everything posted by the account will go out to the followers, but there will be no opportunity for interaction.
|
|
||||||
This setting would typically be used for announcements or corporate communications.
|
|
||||||
“Love-all” automatically approves contacts as friends.
|
|
||||||
|
|
||||||
In addition to Personal Page, there are options for Organization Page, News Page, and Community Forum.
|
|
||||||
Organization and New Pages automatically approve contact requests as followers.
|
|
||||||
|
|
||||||
Community Forum provide the ability for people to become friends/fans of the forum without requiring approval.
|
|
||||||
This creates a forum page where all members can freely interact.
|
|
||||||
|
|
||||||
Posting to Community forums
|
|
||||||
---
|
|
||||||
|
|
||||||
If you are a member of a community forum, you may post to the forum by including an @-tag in the post mentioning the forum.
|
|
||||||
For example @bicycle would send my post to all members of the group "bicycle" in addition to the normal recipients.
|
|
||||||
If you mention a forum (you are a member of) in a new posting, the posting will be distributed to all members of the forum, regardless of your privacy settings for the posting.
|
|
||||||
Also, if the forum is a public forum, your posting will be public for the all internet users.
|
|
||||||
If your post is private you must also explicitly include the group in the post permissions (to allow the forum "contact" to see the post) **and** mention it in a tag (which redistributes the post to the forum members).
|
|
||||||
Posting privately to a public forum, will result in your posting being displayed on the forum wall, but not on yours.
|
|
||||||
|
|
||||||
Additionally it is possible to address a forum with the exclamation mark.
|
|
||||||
In the example above this means that you can address the bicycle forum via !bicycle.
|
|
||||||
The difference to the @ is that the post will only be sent to the addressed forum.
|
|
||||||
This also means that you shouldn't address multiple forums in a single post in that way since it will only be distributed by one the forums.
|
|
||||||
|
|
||||||
You may also post to a community forum by posting a "wall-to-wall" post using secure cross-site authentication.
|
|
||||||
|
|
||||||
Comments which are relayed to community forums will be relayed back to the original post creator.
|
|
||||||
Mentioning the forum with an @-tag in a comment does not relay the message, as distribution is controlled entirely by the original post creator.
|
|
|
@ -3,7 +3,7 @@ Friendica on GitHub
|
||||||
|
|
||||||
* [Home](help)
|
* [Home](help)
|
||||||
|
|
||||||
Here is how you can work on the code with us. If you have any questions please write to the Friendica developers' forum.
|
Here is how you can work on the code with us. If you have any questions please write to the Friendica developers' group.
|
||||||
|
|
||||||
Introduction to the workflow with our GitHub repository
|
Introduction to the workflow with our GitHub repository
|
||||||
-------------------------------------------------------
|
-------------------------------------------------------
|
||||||
|
|
|
@ -0,0 +1,68 @@
|
||||||
|
Groups
|
||||||
|
=====
|
||||||
|
|
||||||
|
* [Home](help)
|
||||||
|
|
||||||
|
|
||||||
|
Friendica also lets you create accounts that can function as discussion groups, celebrity accounts, announcement channels, news reflectors, or organization pages, depending on how you want to interact with others.
|
||||||
|
Management of these accounts can be delegated to other accounts, or a parent account can be designated to easily toggle multiple identities.
|
||||||
|
|
||||||
|
Every account in Friendica has a nickname and these must all be unique.
|
||||||
|
This applies to all accounts, whether they are individual profiles or group profiles.
|
||||||
|
|
||||||
|
Managing Accounts
|
||||||
|
---
|
||||||
|
|
||||||
|
To create a new linked account that can be used as a group, log in to your normal account and go to Settings > Manage Accounts.
|
||||||
|
Here you can register additional accounts with new nicknames that will be linked to your primary account.
|
||||||
|
|
||||||
|
You may appoint a delegate to manage your new account.
|
||||||
|
The Delegates section of Manage Accounts page will provide you with a list of contacts on this instance under "Potential Delegates".
|
||||||
|
Selecting one or more persons will give them access to manage your newly created account.
|
||||||
|
They will be able to edit contacts, profiles, and all content for this account.
|
||||||
|
Please use this facility wisely.
|
||||||
|
Delegated managers will not be able to alter basic account settings, such as passwords or account types, or remove the account.
|
||||||
|
|
||||||
|
Additionally, this page is also where you can choose to designate an account as a parent user.
|
||||||
|
If your primary account is designated as the parent user, you will be able to easily toggle identities and manage your groups or other types of accounts.
|
||||||
|
|
||||||
|
Types of Accounts
|
||||||
|
---
|
||||||
|
|
||||||
|
On the new account, visit the Settings > Account page.
|
||||||
|
Towards the end of the page is a section for "Advanced account types".
|
||||||
|
Typically, you would use "Personal Page - Standard" for a normal personal account with manual approval of “friends” and “followers.”
|
||||||
|
This is the default selection.
|
||||||
|
On this page you can change the type of account if desired.
|
||||||
|
|
||||||
|
The other subtypes of a Personal Page are “Soapbox” and “Love-all.”
|
||||||
|
A Soapbox account is an announcement channel that automatically approvals follower requests.
|
||||||
|
Everything posted by the account will go out to the followers, but there will be no opportunity for interaction.
|
||||||
|
This setting would typically be used for announcements or corporate communications.
|
||||||
|
“Love-all” automatically approves contacts as friends.
|
||||||
|
|
||||||
|
In addition to Personal Page, there are options for Organization Page, News Page, and Community Group.
|
||||||
|
Organization and New Pages automatically approve contact requests as followers.
|
||||||
|
|
||||||
|
Community Group provide the ability for people to join the group without requiring approval.
|
||||||
|
This creates a group where all members can freely interact.
|
||||||
|
|
||||||
|
Posting to Community groups
|
||||||
|
---
|
||||||
|
|
||||||
|
If you are a member of a community group, you may post to the group by including an @-mention in the post mentioning the group.
|
||||||
|
For example @bicycle would send my post to all members of the group "bicycle" in addition to the normal recipients.
|
||||||
|
If you mention a group (you are a member of) in a new posting, the posting will be distributed to all members of the group, regardless of your privacy settings for the posting.
|
||||||
|
Also, if the group is public, your posting will be public for the all internet users.
|
||||||
|
If your post is private you must also explicitly include the group in the post permissions (to allow the group "contact" to see the post) **and** mention it in a tag (which redistributes the post to the group members).
|
||||||
|
Posting privately to a public group, will result in your posting being displayed on the group wall, but not on yours.
|
||||||
|
|
||||||
|
Additionally, it is possible to address a group with the exclamation mark.
|
||||||
|
In the example above this means that you can address the bicycle group via !bicycle.
|
||||||
|
The difference with the @-mention is that the post will only be sent to the addressed group.
|
||||||
|
This also means that you shouldn't address multiple groups in a single post in that way since it will only be distributed by one the groups.
|
||||||
|
|
||||||
|
You may also post to a community group by posting a "wall-to-wall" post using secure cross-site authentication.
|
||||||
|
|
||||||
|
Comments which are relayed to community groups will be relayed back to the original post creator.
|
||||||
|
Mentioning the group with an @-mention in a comment does not relay the message, as distribution is controlled entirely by the original post creator.
|
|
@ -14,9 +14,10 @@ Friendica Documentation and Resources
|
||||||
* You and other users
|
* You and other users
|
||||||
* [Connectors](help/Connectors)
|
* [Connectors](help/Connectors)
|
||||||
* [Making Friends](help/Making-Friends)
|
* [Making Friends](help/Making-Friends)
|
||||||
* [Groups and Privacy](help/Groups-and-Privacy)
|
* [Circles and Privacy](help/Circles-and-Privacy)
|
||||||
* [Tags and Mentions](help/Tags-and-Mentions)
|
* [Tags and Mentions](help/Tags-and-Mentions)
|
||||||
* [Community Forums](help/Forums)
|
* [Community Groups](help/Groups)
|
||||||
|
* [Channels](help/Channels)
|
||||||
* [Chats](help/Chats)
|
* [Chats](help/Chats)
|
||||||
* Further information
|
* Further information
|
||||||
* [Move your account](help/Move-Account)
|
* [Move your account](help/Move-Account)
|
||||||
|
@ -67,7 +68,7 @@ Friendica Documentation and Resources
|
||||||
|
|
||||||
* [Main Website](https://friendi.ca)
|
* [Main Website](https://friendi.ca)
|
||||||
* Ways to get Support
|
* Ways to get Support
|
||||||
* Friendica Support Forum: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
* Friendica Support Group: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
||||||
* [Mailing List Archive](http://mailman.friendi.ca/mailman/listinfo/support-friendi.ca) you can subscribe to the list by sending an email to ``support-request(at)friendi.ca?subject=subscribe``
|
* [Mailing List Archive](http://mailman.friendi.ca/mailman/listinfo/support-friendi.ca) you can subscribe to the list by sending an email to ``support-request(at)friendi.ca?subject=subscribe``
|
||||||
* Community chat rooms (the IRC, Matrix and XMPP rooms are bridged) these public chats are logged [from IRC](https://gnusociarg.nsupdate.info/2021/%23friendica/) and [Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/)
|
* Community chat rooms (the IRC, Matrix and XMPP rooms are bridged) these public chats are logged [from IRC](https://gnusociarg.nsupdate.info/2021/%23friendica/) and [Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/)
|
||||||
* XMPP/Jabber MUC: support(at)forum.friendi.ca
|
* XMPP/Jabber MUC: support(at)forum.friendi.ca
|
||||||
|
|
|
@ -3,7 +3,7 @@ How to improve the performance of a Friendica site
|
||||||
|
|
||||||
* [Home](help)
|
* [Home](help)
|
||||||
|
|
||||||
Feel free to ask in the [Friendica support forum](https://forum.friendi.ca/profile/helpers) if you need some clarification about the following instructions or if you need help in any other way.
|
Feel free to ask in the [Friendica support group](https://forum.friendi.ca/profile/helpers) if you need some clarification about the following instructions or if you need help in any other way.
|
||||||
|
|
||||||
System configuration
|
System configuration
|
||||||
--------
|
--------
|
||||||
|
|
|
@ -15,7 +15,7 @@ Many will.
|
||||||
But **please** review the [requirements](#Requirements) and confirm these with your hosting provider prior to installation.
|
But **please** review the [requirements](#Requirements) and confirm these with your hosting provider prior to installation.
|
||||||
|
|
||||||
## Support
|
## Support
|
||||||
If you encounter installation issues, please let us know via the [helper](http://forum.friendi.ca/profile/helpers) or the [developer](https://forum.friendi.ca/profile/developers) forum or [file an issue](https://github.com/friendica/friendica/issues).
|
If you encounter installation issues, please let us know via the [helper](http://forum.friendi.ca/profile/helpers) or the [developer](https://forum.friendi.ca/profile/developers) group or [file an issue](https://github.com/friendica/friendica/issues).
|
||||||
|
|
||||||
Please be as clear as you can about your operating environment and provide as much detail as possible about any error messages you may see, so that we can prevent it from happening in the future.
|
Please be as clear as you can about your operating environment and provide as much detail as possible about any error messages you may see, so that we can prevent it from happening in the future.
|
||||||
Due to the large variety of operating systems and PHP platforms in existence we may have only limited ability to debug your PHP installation or acquire any missing modules - but we will do our best to solve any general code issues.
|
Due to the large variety of operating systems and PHP platforms in existence we may have only limited ability to debug your PHP installation or acquire any missing modules - but we will do our best to solve any general code issues.
|
||||||
|
@ -28,9 +28,9 @@ Due to the large variety of operating systems and PHP platforms in existence we
|
||||||
### Requirements
|
### Requirements
|
||||||
|
|
||||||
* Apache with mod-rewrite enabled and "Options All" so you can use a local `.htaccess` file
|
* Apache with mod-rewrite enabled and "Options All" so you can use a local `.htaccess` file
|
||||||
* PHP 7.3+ (PHP8 is not fully supported yet)
|
* PHP 7.4+
|
||||||
* PHP *command line* access with register_argc_argv set to true in the php.ini file
|
* PHP *command line* access with register_argc_argv set to true in the php.ini file
|
||||||
* Curl, GD, GMP, PDO, mbstrings, MySQLi, hash, xml, zip and OpenSSL extensions
|
* Curl, GD, GMP, PDO, mbstrings, MySQLi, hash, xml, zip, IntlChar and OpenSSL extensions
|
||||||
* The POSIX module of PHP needs to be activated (e.g. [RHEL, CentOS](http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7) have disabled it)
|
* The POSIX module of PHP needs to be activated (e.g. [RHEL, CentOS](http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7) have disabled it)
|
||||||
* Some form of email server or email gateway such that PHP mail() works.
|
* Some form of email server or email gateway such that PHP mail() works.
|
||||||
If you cannot set up your own email server, you can use the [phpmailer](https://github.com/friendica/friendica-addons/tree/develop/phpmailer) addon and use a remote SMTP server.
|
If you cannot set up your own email server, you can use the [phpmailer](https://github.com/friendica/friendica-addons/tree/develop/phpmailer) addon and use a remote SMTP server.
|
||||||
|
@ -44,7 +44,7 @@ For alternative server configurations (such as Nginx server and MariaDB database
|
||||||
|
|
||||||
### Optional
|
### Optional
|
||||||
|
|
||||||
* PHP ImageMagick extension (php-imagick) for animated GIF support.
|
* PHP ImageMagick extension (php-imagick) for animated GIF and animated WebP support.
|
||||||
|
|
||||||
## Installation procedure
|
## Installation procedure
|
||||||
|
|
||||||
|
|
|
@ -20,15 +20,15 @@ You'll also see a link to a **Global Directory**.
|
||||||
There are several global directories across the globe that regularly exchange information with each other.
|
There are several global directories across the globe that regularly exchange information with each other.
|
||||||
The specific global directory that you see usually depends on where your server is located.
|
The specific global directory that you see usually depends on where your server is located.
|
||||||
If you click through to the global directory, you will be presented with a list of everybody who choses to be listed across all instances of Friendica.
|
If you click through to the global directory, you will be presented with a list of everybody who choses to be listed across all instances of Friendica.
|
||||||
You will also see a "Show Community Forums" link, which will direct you to Groups, Forums and Fanpages.
|
You will also see a "Show Community Groups" link, which will direct you to Groups.
|
||||||
You connect to people, groups and forums in the same way, except groups and forums will automatically accept your introduction request, whereas a human will approve you manually.
|
You connect to people and groups the same way, public groups will automatically accept your introduction, whereas private groups and some individual users will need to manually approve it.
|
||||||
|
|
||||||
Connect to other Friendica users
|
Connect to other Friendica users
|
||||||
---
|
---
|
||||||
|
|
||||||
Visit their profile.
|
Visit their profile.
|
||||||
Just beneath their profile picture will be the word 'Connect' (we're assuming this is an English language profile).
|
Just beneath their profile picture will be the word 'Connect' (we're assuming this is an English language profile).
|
||||||
Click that 'Connect' button and it will take you to a 'Connect' form.
|
Click that 'Connect' button, and it will take you to a 'Connect' form.
|
||||||
|
|
||||||
The form is going to ask you for your Identity Address.
|
The form is going to ask you for your Identity Address.
|
||||||
This is necessary so that this person's website can find yours.
|
This is necessary so that this person's website can find yours.
|
||||||
|
@ -41,7 +41,7 @@ It's easy for people to remember.
|
||||||
|
|
||||||
You *could* also put in the URL of your "home" page, such as "http://demo.friendica.com/profile/bob" instead of the email-style address.
|
You *could* also put in the URL of your "home" page, such as "http://demo.friendica.com/profile/bob" instead of the email-style address.
|
||||||
|
|
||||||
When you've submitted the connection page, it will take you back to your own site where you must then login (if necessary) and verify the connection request on *your* site.
|
When you've submitted the connection page, it will take you back to your own site where you must then log in (if necessary) and verify the connection request on *your* site.
|
||||||
Once you've done this, the two websites can communicate with each other to complete the process (after your new friend has approved the request).
|
Once you've done this, the two websites can communicate with each other to complete the process (after your new friend has approved the request).
|
||||||
|
|
||||||
If you already know somebody's Identity Address, you can enter it in the "connect" box on your "Contacts" page.
|
If you already know somebody's Identity Address, you can enter it in the "connect" box on your "Contacts" page.
|
||||||
|
@ -55,14 +55,14 @@ You can also use your Identity Address or other people's Identity Addresses to b
|
||||||
Currently, Friendica supports connections with people on diaspora*, Red, Hubzilla, GNU Social, StatusNet, Mastodon, Pleroma, socialhome, and ganggo platforms.
|
Currently, Friendica supports connections with people on diaspora*, Red, Hubzilla, GNU Social, StatusNet, Mastodon, Pleroma, socialhome, and ganggo platforms.
|
||||||
|
|
||||||
If you know (for instance) "alice" on gnusocial.net (a GNU Social site) you could put alice@gnusocial.net into your Contact page and become friends across networks.
|
If you know (for instance) "alice" on gnusocial.net (a GNU Social site) you could put alice@gnusocial.net into your Contact page and become friends across networks.
|
||||||
Likewise you can put in the URL to Alice's gnusocial.net page, if you wish.
|
Likewise, you can put in the URL to Alice's gnusocial.net page, if you wish.
|
||||||
Note: Some versions of GNU Social software may require the full URL to your profile and may not work with the identity address.
|
Note: Some versions of GNU Social software may require the full URL to your profile and may not work with the identity address.
|
||||||
|
|
||||||
People on these networks can also initiate contact with you, if they know your contact details.
|
People on these networks can also initiate contact with you, if they know your contact details.
|
||||||
|
|
||||||
### Other social media
|
### Other social media
|
||||||
If you server provides this functionality, you can also connect with people one
|
If you server provides this functionality, you can also connect with people one
|
||||||
Twitter or important feeds from Tumblr, Wordpress, and many more.
|
Twitter or important feeds from Tumblr, WordPress, and many more.
|
||||||
|
|
||||||
To connect, enter their contact details in the "connect" box on your "Contacts" page.
|
To connect, enter their contact details in the "connect" box on your "Contacts" page.
|
||||||
|
|
||||||
|
|
|
@ -8,7 +8,7 @@ How to move your account between servers
|
||||||
|
|
||||||
* Go to "Settings" -> "[Export personal data](uexport)"
|
* Go to "Settings" -> "[Export personal data](uexport)"
|
||||||
* Click on "Export account" to save your account data.
|
* Click on "Export account" to save your account data.
|
||||||
* **Save the file in a secure place!** It contains your details, your contacts, groups, and personal settings. It also contains your secret keys to authenticate yourself to your contacts.
|
* **Save the file in a secure place!** It contains your details, your contacts, circles, and personal settings. It also contains your secret keys to authenticate yourself to your contacts.
|
||||||
* Go to your new server, and open *http://newserver.com/user/import* (there is not a direct link to this page at the moment). Please consider that this is only possible on servers with open registration. On other systems only the administrator can add accounts with an uploaded file.
|
* Go to your new server, and open *http://newserver.com/user/import* (there is not a direct link to this page at the moment). Please consider that this is only possible on servers with open registration. On other systems only the administrator can add accounts with an uploaded file.
|
||||||
* Do NOT create a new account prior to importing your old settings - user import should be used *instead* of register.
|
* Do NOT create a new account prior to importing your old settings - user import should be used *instead* of register.
|
||||||
* Load your saved account file and click "Import".
|
* Load your saved account file and click "Import".
|
||||||
|
@ -17,7 +17,7 @@ How to move your account between servers
|
||||||
|
|
||||||
Friendica contacts
|
Friendica contacts
|
||||||
---
|
---
|
||||||
Friendica will recreate your account on the new server, with your contacts and groups.
|
Friendica will recreate your account on the new server, with your contacts and circles.
|
||||||
A message is sent to Friendica contacts, to inform them about your move:
|
A message is sent to Friendica contacts, to inform them about your move:
|
||||||
If your contacts are running on an updated server, your details on their side will be automatically updated.
|
If your contacts are running on an updated server, your details on their side will be automatically updated.
|
||||||
|
|
||||||
|
|
|
@ -4,8 +4,7 @@ Here are some more things to help get you started:
|
||||||
|
|
||||||
**Groups**
|
**Groups**
|
||||||
|
|
||||||
|
- <a href="https://forum.friendi.ca/profile/helpers">Friendica Support</a> - problems? This is the place to ask.
|
||||||
- <a href="http://forum.friendi.ca/profile/helpers">Friendica Support</a> - problems? This is the place to ask.
|
|
||||||
|
|
||||||
**Documentation**
|
**Documentation**
|
||||||
|
|
||||||
|
|
|
@ -1,9 +1,9 @@
|
||||||
This is the global directory.
|
This is the global directory.
|
||||||
If you get lost, you can <a href = "help/Quick-Start-groupsandpages">click this link</a> to bring yourself back here.
|
If you get lost, you can <a href = "help/Quick-Start-groupsandpages">click this link</a> to bring yourself back here.
|
||||||
|
|
||||||
On this page, you'll find a collection of groups, forums and celebrity pages.
|
On this page, you'll find a collection of groups.
|
||||||
Groups are not real people.
|
Groups are not real people.
|
||||||
Connecting to them is similar to "liking" something on Facebook, or signing up for a new forum.
|
Connecting to them is similar to "liking" something on Facebook, or signing up for a new group.
|
||||||
You don't have to feel awkward about introducing yourself to a new person, because they're not people!
|
You don't have to feel awkward about introducing yourself to a new person, because they're not people!
|
||||||
|
|
||||||
When you connect to a group, all messages to that group will start appearing in your network tab.
|
When you connect to a group, all messages to that group will start appearing in your network tab.
|
||||||
|
@ -15,6 +15,6 @@ Remember the link at the top of this page will bring you back here.
|
||||||
|
|
||||||
Once you've added some groups, <a href="help/Quick-Start-andfinally">move on to the next section</a>.
|
Once you've added some groups, <a href="help/Quick-Start-andfinally">move on to the next section</a>.
|
||||||
|
|
||||||
<iframe src="https://dir.friendica.social/forum" width="950" height="600"></iframe>
|
<iframe src="https://dir.friendica.social/group" width="950" height="600"></iframe>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -77,11 +77,11 @@ Additionally to the setting in the admin panel, you can decide if registrations
|
||||||
To enable invitation based registration, you have to set the `invitation_only` setting to `true` in the `system` section of the [config/local.config.php](/help/Config) file.
|
To enable invitation based registration, you have to set the `invitation_only` setting to `true` in the `system` section of the [config/local.config.php](/help/Config) file.
|
||||||
If you want to use this method, the registration policy has to be set to either *open* or *requires approval*.
|
If you want to use this method, the registration policy has to be set to either *open* or *requires approval*.
|
||||||
|
|
||||||
#### Check Full Names
|
#### Check Display Names
|
||||||
|
|
||||||
You may find a lot of spammers trying to register on your site.
|
You may find a lot of spammers trying to register on your site.
|
||||||
During testing we discovered that since these registrations were automatic, the "Full Name" field was often set to just an account name with no space between first and last name.
|
During testing we discovered that since these registrations were automatic, the "Display Name" field was often set to just an account name with no space between first and last name.
|
||||||
If you would like to support people with only one name as their full name, you may change this setting to true.
|
If you would like to support people with only one name as their display name, you can leave this setting set to false.
|
||||||
Default is false.
|
Default is false.
|
||||||
|
|
||||||
#### OpenID
|
#### OpenID
|
||||||
|
|
|
@ -0,0 +1,89 @@
|
||||||
|
Friendica strategy Hooks
|
||||||
|
===========================================
|
||||||
|
|
||||||
|
* [Home](help)
|
||||||
|
|
||||||
|
## Strategy hooks
|
||||||
|
|
||||||
|
This type of hook is based on the [Strategy Design Pattern](https://refactoring.guru/design-patterns/strategy).
|
||||||
|
|
||||||
|
A strategy class defines a possible implementation of a given interface based on a unique name.
|
||||||
|
Every name is possible as long as it's unique and not `null`.
|
||||||
|
Using an empty name (`''`) is possible as well and should be used as the "default" implementation.
|
||||||
|
To register a strategy, use the [`ICanRegisterInstance`](../src/Core/Hooks/Capability/ICanRegisterInstances.php) interface.
|
||||||
|
|
||||||
|
After registration, a caller can automatically create this instance with the [`ICanCreateInstances`](../src/Core/Hooks/Capability/ICanCreateInstances.php) interface and the chosen name.
|
||||||
|
|
||||||
|
This is useful in case there are different, possible implementations for the same purpose, like for logging, locking, caching, ...
|
||||||
|
|
||||||
|
Normally, a config entry is used to choose the right implementation at runtime.
|
||||||
|
And if no config entry is set, the "default" implementation should be used.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
```php
|
||||||
|
interface ExampleInterface
|
||||||
|
{
|
||||||
|
public function testMethod();
|
||||||
|
}
|
||||||
|
|
||||||
|
public class ConcreteClassA implements ExampleInterface
|
||||||
|
{
|
||||||
|
public function testMethod()
|
||||||
|
{
|
||||||
|
echo "concrete class A";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public class ConcreteClassB implements ExampleInterface
|
||||||
|
{
|
||||||
|
public function testMethod()
|
||||||
|
{
|
||||||
|
echo "concrete class B";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/** @var \Friendica\Core\Hooks\Capability\ICanRegisterStrategies $instanceRegister */
|
||||||
|
$instanceRegister->registerStrategy(ExampleInterface::class, ConcreteClassA::class, 'A');
|
||||||
|
$instanceRegister->registerStrategy(ExampleInterface::class, ConcreteClassB::class, 'B');
|
||||||
|
|
||||||
|
/** @var \Friendica\Core\Hooks\Capability\ICanCreateInstances $instanceManager */
|
||||||
|
/** @var ConcreteClassA $concreteClass */
|
||||||
|
$concreteClass = $instanceManager->create(ExampleInterface::class, 'A');
|
||||||
|
|
||||||
|
$concreteClass->testMethod();
|
||||||
|
// output:
|
||||||
|
// "concrete class A";
|
||||||
|
```
|
||||||
|
|
||||||
|
## hooks.config.php
|
||||||
|
|
||||||
|
To avoid registering all strategies manually inside the code, Friendica introduced the [`hooks.config.php`](../static/hooks.config.php) file.
|
||||||
|
|
||||||
|
There, you can register all kind of strategies in one file.
|
||||||
|
|
||||||
|
### [`HookType::STRATEGY`](../src/Core/Hooks/Capability/HookType.php)
|
||||||
|
|
||||||
|
For each given interface, a list of key-value pairs can be set, where the key is the concrete implementation class and the value is an array of unique names.
|
||||||
|
|
||||||
|
### Example
|
||||||
|
|
||||||
|
```php
|
||||||
|
use Friendica\Core\Hooks\Capability\BehavioralHookType as H;
|
||||||
|
|
||||||
|
return [
|
||||||
|
H::STRATEGY => [
|
||||||
|
ExampleInterface::class => [
|
||||||
|
ConcreteClassA::class => ['A'],
|
||||||
|
ConcreteClassB::class => ['B'],
|
||||||
|
],
|
||||||
|
],
|
||||||
|
];
|
||||||
|
```
|
||||||
|
|
||||||
|
## Addons
|
||||||
|
|
||||||
|
The hook logic is useful for decoupling the Friendica core logic, but its primary goal is to modularize Friendica in creating addons.
|
||||||
|
|
||||||
|
Therefor you can either use the interfaces directly as shown above, or you can place your own `hooks.config.php` file inside a `static` directory directly under your addon core directory.
|
||||||
|
Friendica will automatically search these config files for each **activated** addon and register the given hooks.
|
|
@ -23,27 +23,27 @@ You can tag a person on a different network or one that is **not in your social
|
||||||
|
|
||||||
Unless their system blocks unsolicited "mentions", the person tagged will likely receive a "Mention" post/activity or become a direct participant in the conversation in the case of public posts.
|
Unless their system blocks unsolicited "mentions", the person tagged will likely receive a "Mention" post/activity or become a direct participant in the conversation in the case of public posts.
|
||||||
Friendica blocks incoming “mentions” from people with no relationship to you.
|
Friendica blocks incoming “mentions” from people with no relationship to you.
|
||||||
The exception is an ongoing conversation started from a contact of both you and the 3rd person or a conversation in a forum where you are a member of.
|
The exception is an ongoing conversation started from a contact of both you and the 3rd person or a conversation in a group where you are a member of.
|
||||||
This is a spam prevention measure.
|
This is a spam prevention measure.
|
||||||
|
|
||||||
Remote mentions are delivered using the OStatus protocol.
|
Remote mentions are delivered using the OStatus protocol.
|
||||||
This protocol is used by Friendica and GNU Social and several other systems like Mastodon, but is not currently implemented in Diaspora.
|
This protocol is used by Friendica and GNU Social and several other systems like Mastodon, but is not currently implemented in Diaspora.
|
||||||
As the OStatus protocol allows this Friendica user can be @-mentioned by users from platforms using this protocol in conversations if the "Enable OStatus support" is activated on the Friendica node.
|
As the OStatus protocol allows this Friendica user can be @-mentioned by users from platforms using this protocol in conversations if the "Enable OStatus support" is activated on the Friendica node.
|
||||||
These @-mentions wont be blocked, even if there is no relationship between the sender and the receiver of the message.
|
These @-mentions won't be blocked, even if there is no relationship between the sender and the receiver of the message.
|
||||||
|
|
||||||
Friendica makes no distinction between people and forums for the purpose of tagging.
|
Friendica makes no distinction between people and groups for the purpose of tagging.
|
||||||
You can use @-mentions for forums like for other accounts to tag the forum.
|
You can use @-mentions for groups like for other accounts to tag the group.
|
||||||
If you want to post something exclusively to a forum (e.g. the support forum) please use the bang-notation instead of the @tag.
|
If you want to post something exclusively to a group (e.g. the support group) please use the !-mention instead of the @-mention.
|
||||||
So !helpers will be an exclusive posting to the support forum if you are connected with the forum.
|
So !helpers will be an exclusive posting to the support group if you are connected with the group.
|
||||||
If you select a forum from the ACL a !-mention will be added automatically to your posting.
|
If you select a group from the ACL a !-mention will be added automatically to your posting.
|
||||||
|
|
||||||
If you sort your contacts into groups, you cannot @-mention these groups.
|
If you sort your contacts into circles, you cannot @-mention these circles.
|
||||||
But you can select the group in the access control when creating a new posting, to allow (or disallow) a certain group of people to see the posting.
|
But you can select the circle in the access control when creating a new posting, to allow (or disallow) a certain circle of people to see the posting.
|
||||||
See [Groups and Privacy](help/Groups-and-Privacy) for more details about grouping your contacts.
|
See [Circles and Privacy](help/Circles-and-Privacy) for more details about grouping your contacts.
|
||||||
|
|
||||||
**Topical Tags**
|
**Topical Tags**
|
||||||
|
|
||||||
Topical tags are indicated by preceding the tag name with the # character.
|
Topical tags are indicated by preceding the tag name with the # character.
|
||||||
This will create a link in the post to a generalised site search for the term provided.
|
This will create a link in the post to a generalised site search for the term provided.
|
||||||
For example, #cars will provide a search link for all posts mentioning 'cars' on your site.
|
For example, #cars will provide a search link for all posts mentioning 'cars' on your site.
|
||||||
Topical tags are generally a minimum of three characters in length.
|
Topical tags are generally a minimum of three characters in length.
|
||||||
|
|
|
@ -88,11 +88,11 @@ Click on "show" under contact name to hide the post to everyone but selected.
|
||||||
|
|
||||||
Click on "Visible to everybody" to make the post public again.
|
Click on "Visible to everybody" to make the post public again.
|
||||||
|
|
||||||
If you have defined some groups, you can check "show" for groups also. All contact in that group will see the post.
|
If you have defined some circles, you can check "show" for circles also. All contact in that circle will see the post.
|
||||||
If you want to hide the post to one contact of a group selected for "show", click "don't show" under contact name.
|
If you want to hide the post to one contact of a circle selected for "show", click "don't show" under contact name.
|
||||||
|
|
||||||
Click again on "show" or "don't show" to switch it off.
|
Click again on "show" or "don't show" to switch it off.
|
||||||
|
|
||||||
You can search for contacts or groups with the search box.
|
You can search for contacts or circles with the search box.
|
||||||
|
|
||||||
See also [Group and Privacy](help/Groups-and-Privacy)
|
See also [Circles and Privacy](help/Circles-and-Privacy)
|
||||||
|
|
|
@ -11,7 +11,9 @@ If you installed Friendica in the ``path/to/friendica`` folder:
|
||||||
2. Copy the following items from ``path/to/friendica`` to ``path/to/friendica_new``:
|
2. Copy the following items from ``path/to/friendica`` to ``path/to/friendica_new``:
|
||||||
* ``config/local.config.php``
|
* ``config/local.config.php``
|
||||||
* ``proxy/``
|
* ``proxy/``
|
||||||
The following items only need to be copied if they are located inside your friendica path:
|
* ``.htaccess`` if using Apache web server
|
||||||
|
|
||||||
|
The following items only need to be copied if they are located inside your friendica path:
|
||||||
* your storage folder as set in **Admin -> Site -> File Upload -> Storage base path**
|
* your storage folder as set in **Admin -> Site -> File Upload -> Storage base path**
|
||||||
* your item cache as set in **Admin -> Site -> Performance -> Path to item cache**
|
* your item cache as set in **Admin -> Site -> Performance -> Path to item cache**
|
||||||
* your temp folder as set in **Admin -> Site -> Advanced -> Temp path**
|
* your temp folder as set in **Admin -> Site -> Advanced -> Temp path**
|
||||||
|
|
|
@ -68,8 +68,8 @@ xml:
|
||||||
The [RSStoFriendika](https://github.com/pafcu/RSStoFriendika) code can be used as an example of how to use the API with python.
|
The [RSStoFriendika](https://github.com/pafcu/RSStoFriendika) code can be used as an example of how to use the API with python.
|
||||||
The lines for posting are located at [line 21](https://github.com/pafcu/RSStoFriendika/blob/master/RSStoFriendika.py#L21) and following.
|
The lines for posting are located at [line 21](https://github.com/pafcu/RSStoFriendika/blob/master/RSStoFriendika.py#L21) and following.
|
||||||
|
|
||||||
def tweet(server, message, group_allow=None):
|
def tweet(server, message, circle_allow=None):
|
||||||
url = server + '/api/statuses/update'
|
url = server + '/api/statuses/update'
|
||||||
urllib2.urlopen(url, urllib.urlencode({'status': message,'group_allow[]':group_allow}, doseq=True))
|
urllib2.urlopen(url, urllib.urlencode({'status': message, 'circle_allow[]': circle_allow}, doseq=True))
|
||||||
|
|
||||||
There is also a [module for python 3](https://bitbucket.org/tobiasd/python-friendica) for using the API.
|
There is also a [module for python 3](https://bitbucket.org/tobiasd/python-friendica) for using the API.
|
||||||
|
|
|
@ -17,6 +17,8 @@ Database Tables
|
||||||
| [arrived-activity](help/database/db_arrived-activity) | Id of arrived activities |
|
| [arrived-activity](help/database/db_arrived-activity) | Id of arrived activities |
|
||||||
| [attach](help/database/db_attach) | file attachments |
|
| [attach](help/database/db_attach) | file attachments |
|
||||||
| [cache](help/database/db_cache) | Stores temporary data |
|
| [cache](help/database/db_cache) | Stores temporary data |
|
||||||
|
| [channel](help/database/db_channel) | User defined Channels |
|
||||||
|
| [check-full-text-search](help/database/db_check-full-text-search) | Check for a full text search match in user defined channels before storing the message in the system |
|
||||||
| [config](help/database/db_config) | main configuration storage |
|
| [config](help/database/db_config) | main configuration storage |
|
||||||
| [contact](help/database/db_contact) | contact table |
|
| [contact](help/database/db_contact) | contact table |
|
||||||
| [contact-relation](help/database/db_contact-relation) | Contact relations |
|
| [contact-relation](help/database/db_contact-relation) | Contact relations |
|
||||||
|
@ -30,8 +32,8 @@ Database Tables
|
||||||
| [fetch-entry](help/database/db_fetch-entry) | |
|
| [fetch-entry](help/database/db_fetch-entry) | |
|
||||||
| [fetched-activity](help/database/db_fetched-activity) | Id of fetched activities |
|
| [fetched-activity](help/database/db_fetched-activity) | Id of fetched activities |
|
||||||
| [fsuggest](help/database/db_fsuggest) | friend suggestion stuff |
|
| [fsuggest](help/database/db_fsuggest) | friend suggestion stuff |
|
||||||
| [group](help/database/db_group) | privacy groups, group info |
|
| [group](help/database/db_group) | privacy circles, circle info |
|
||||||
| [group_member](help/database/db_group_member) | privacy groups, member info |
|
| [group_member](help/database/db_group_member) | privacy circles, member info |
|
||||||
| [gserver](help/database/db_gserver) | Global servers |
|
| [gserver](help/database/db_gserver) | Global servers |
|
||||||
| [gserver-tag](help/database/db_gserver-tag) | Tags that the server has subscribed |
|
| [gserver-tag](help/database/db_gserver-tag) | Tags that the server has subscribed |
|
||||||
| [hook](help/database/db_hook) | addon hook registry |
|
| [hook](help/database/db_hook) | addon hook registry |
|
||||||
|
@ -59,13 +61,16 @@ Database Tables
|
||||||
| [post-category](help/database/db_post-category) | post relation to categories |
|
| [post-category](help/database/db_post-category) | post relation to categories |
|
||||||
| [post-collection](help/database/db_post-collection) | Collection of posts |
|
| [post-collection](help/database/db_post-collection) | Collection of posts |
|
||||||
| [post-content](help/database/db_post-content) | Content for all posts |
|
| [post-content](help/database/db_post-content) | Content for all posts |
|
||||||
|
| [post-counts](help/database/db_post-counts) | Original remote activity |
|
||||||
| [post-delivery](help/database/db_post-delivery) | Delivery data for posts for the batch processing |
|
| [post-delivery](help/database/db_post-delivery) | Delivery data for posts for the batch processing |
|
||||||
| [post-delivery-data](help/database/db_post-delivery-data) | Delivery data for items |
|
| [post-delivery-data](help/database/db_post-delivery-data) | Delivery data for items |
|
||||||
|
| [post-engagement](help/database/db_post-engagement) | Engagement data per post |
|
||||||
| [post-history](help/database/db_post-history) | Post history |
|
| [post-history](help/database/db_post-history) | Post history |
|
||||||
| [post-link](help/database/db_post-link) | Post related external links |
|
| [post-link](help/database/db_post-link) | Post related external links |
|
||||||
| [post-media](help/database/db_post-media) | Attached media |
|
| [post-media](help/database/db_post-media) | Attached media |
|
||||||
| [post-question](help/database/db_post-question) | Question |
|
| [post-question](help/database/db_post-question) | Question |
|
||||||
| [post-question-option](help/database/db_post-question-option) | Question option |
|
| [post-question-option](help/database/db_post-question-option) | Question option |
|
||||||
|
| [post-searchindex](help/database/db_post-searchindex) | Content for all posts |
|
||||||
| [post-tag](help/database/db_post-tag) | post relation to tags |
|
| [post-tag](help/database/db_post-tag) | post relation to tags |
|
||||||
| [post-thread](help/database/db_post-thread) | Thread related data |
|
| [post-thread](help/database/db_post-thread) | Thread related data |
|
||||||
| [post-thread-user](help/database/db_post-thread-user) | Thread related data per user |
|
| [post-thread-user](help/database/db_post-thread-user) | Thread related data per user |
|
||||||
|
@ -77,7 +82,8 @@ Database Tables
|
||||||
| [push_subscriber](help/database/db_push_subscriber) | Used for OStatus: Contains feed subscribers |
|
| [push_subscriber](help/database/db_push_subscriber) | Used for OStatus: Contains feed subscribers |
|
||||||
| [register](help/database/db_register) | registrations requiring admin approval |
|
| [register](help/database/db_register) | registrations requiring admin approval |
|
||||||
| [report](help/database/db_report) | |
|
| [report](help/database/db_report) | |
|
||||||
| [report-post](help/database/db_report-post) | |
|
| [report-post](help/database/db_report-post) | Individual posts attached to a moderation report |
|
||||||
|
| [report-rule](help/database/db_report-rule) | Terms of service rule lines relevant to a moderation report |
|
||||||
| [search](help/database/db_search) | |
|
| [search](help/database/db_search) | |
|
||||||
| [session](help/database/db_session) | web session storage |
|
| [session](help/database/db_session) | web session storage |
|
||||||
| [storage](help/database/db_storage) | Data stored by Database storage backend |
|
| [storage](help/database/db_storage) | Data stored by Database storage backend |
|
||||||
|
@ -85,6 +91,7 @@ Database Tables
|
||||||
| [tag](help/database/db_tag) | tags and mentions |
|
| [tag](help/database/db_tag) | tags and mentions |
|
||||||
| [user](help/database/db_user) | The local users |
|
| [user](help/database/db_user) | The local users |
|
||||||
| [user-contact](help/database/db_user-contact) | User specific public contact data |
|
| [user-contact](help/database/db_user-contact) | User specific public contact data |
|
||||||
|
| [user-gserver](help/database/db_user-gserver) | User settings about remote servers |
|
||||||
| [userd](help/database/db_userd) | Deleted usernames |
|
| [userd](help/database/db_userd) | Deleted usernames |
|
||||||
| [verb](help/database/db_verb) | Activity Verbs |
|
| [verb](help/database/db_verb) | Activity Verbs |
|
||||||
| [worker-ipc](help/database/db_worker-ipc) | Inter process communication between the frontend and the worker |
|
| [worker-ipc](help/database/db_worker-ipc) | Inter process communication between the frontend and the worker |
|
||||||
|
|
|
@ -18,9 +18,9 @@ Fields
|
||||||
| created | creation time | datetime | NO | | 0001-01-01 00:00:00 | |
|
| created | creation time | datetime | NO | | 0001-01-01 00:00:00 | |
|
||||||
| edited | last edit time | datetime | NO | | 0001-01-01 00:00:00 | |
|
| edited | last edit time | datetime | NO | | 0001-01-01 00:00:00 | |
|
||||||
| allow_cid | Access Control - list of allowed contact.id '<19><78> | mediumtext | YES | | NULL | |
|
| allow_cid | Access Control - list of allowed contact.id '<19><78> | mediumtext | YES | | NULL | |
|
||||||
| allow_gid | Access Control - list of allowed groups | mediumtext | YES | | NULL | |
|
| allow_gid | Access Control - list of allowed circles | mediumtext | YES | | NULL | |
|
||||||
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
||||||
| deny_gid | Access Control - list of denied groups | mediumtext | YES | | NULL | |
|
| deny_gid | Access Control - list of denied circles | mediumtext | YES | | NULL | |
|
||||||
| backend-class | Storage backend class | tinytext | YES | | NULL | |
|
| backend-class | Storage backend class | tinytext | YES | | NULL | |
|
||||||
| backend-ref | Storage backend data reference | text | YES | | NULL | |
|
| backend-ref | Storage backend data reference | text | YES | | NULL | |
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,42 @@
|
||||||
|
Table channel
|
||||||
|
===========
|
||||||
|
|
||||||
|
User defined Channels
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ---------------- | ------------------------------------------------------------------------------------------------- | ------------------ | ---- | --- | ------- | -------------- |
|
||||||
|
| id | | int unsigned | NO | PRI | NULL | auto_increment |
|
||||||
|
| uid | User id | mediumint unsigned | NO | | NULL | |
|
||||||
|
| label | Channel label | varchar(64) | NO | | NULL | |
|
||||||
|
| description | Channel description | varchar(64) | YES | | NULL | |
|
||||||
|
| circle | Circle or channel that this channel is based on | int | YES | | NULL | |
|
||||||
|
| access-key | Access key | varchar(1) | YES | | NULL | |
|
||||||
|
| include-tags | Comma separated list of tags that will be included in the channel | varchar(1023) | YES | | NULL | |
|
||||||
|
| exclude-tags | Comma separated list of tags that aren't allowed in the channel | varchar(1023) | YES | | NULL | |
|
||||||
|
| min-size | Minimum post size | int unsigned | YES | | NULL | |
|
||||||
|
| max-size | Maximum post size | int unsigned | YES | | NULL | |
|
||||||
|
| full-text-search | Full text search pattern, see https://mariadb.com/kb/en/full-text-index-overview/#in-boolean-mode | varchar(1023) | YES | | NULL | |
|
||||||
|
| media-type | Filtered media types | smallint unsigned | YES | | NULL | |
|
||||||
|
| languages | Desired languages | mediumtext | YES | | NULL | |
|
||||||
|
| publish | publish channel content | boolean | YES | | NULL | |
|
||||||
|
| valid | Set, when the full-text-search is valid | boolean | YES | | NULL | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ------- | ------ |
|
||||||
|
| PRIMARY | id |
|
||||||
|
| uid | uid |
|
||||||
|
|
||||||
|
Foreign Keys
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Field | Target Table | Target Field |
|
||||||
|
|-------|--------------|--------------|
|
||||||
|
| uid | [user](help/database/db_user) | uid |
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -0,0 +1,23 @@
|
||||||
|
Table check-full-text-search
|
||||||
|
===========
|
||||||
|
|
||||||
|
Check for a full text search match in user defined channels before storing the message in the system
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ---------- | ---------------------------------------- | ------------ | ---- | --- | ------- | ----- |
|
||||||
|
| pid | The ID of the process | int unsigned | NO | PRI | NULL | |
|
||||||
|
| searchtext | Simplified text for the full text search | mediumtext | YES | | NULL | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ---------- | -------------------- |
|
||||||
|
| PRIMARY | pid |
|
||||||
|
| searchtext | FULLTEXT, searchtext |
|
||||||
|
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -6,13 +6,18 @@ Contact relations
|
||||||
Fields
|
Fields
|
||||||
------
|
------
|
||||||
|
|
||||||
| Field | Description | Type | Null | Key | Default | Extra |
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
| ---------------- | --------------------------------------------------- | ------------ | ---- | --- | ------------------- | ----- |
|
| --------------------- | ----------------------------------------------------------------------- | ----------------- | ---- | --- | ------------------- | ----- |
|
||||||
| cid | contact the related contact had interacted with | int unsigned | NO | PRI | 0 | |
|
| cid | contact the related contact had interacted with | int unsigned | NO | PRI | 0 | |
|
||||||
| relation-cid | related contact who had interacted with the contact | int unsigned | NO | PRI | 0 | |
|
| relation-cid | related contact who had interacted with the contact | int unsigned | NO | PRI | 0 | |
|
||||||
| last-interaction | Date of the last interaction | datetime | NO | | 0001-01-01 00:00:00 | |
|
| last-interaction | Date of the last interaction by relation-cid on cid | datetime | NO | | 0001-01-01 00:00:00 | |
|
||||||
| follow-updated | Date of the last update of the contact relationship | datetime | NO | | 0001-01-01 00:00:00 | |
|
| follow-updated | Date of the last update of the contact relationship | datetime | NO | | 0001-01-01 00:00:00 | |
|
||||||
| follows | | boolean | NO | | 0 | |
|
| follows | if true, relation-cid follows cid | boolean | NO | | 0 | |
|
||||||
|
| score | score for interactions of cid on relation-cid | smallint unsigned | YES | | NULL | |
|
||||||
|
| relation-score | score for interactions of relation-cid on cid | smallint unsigned | YES | | NULL | |
|
||||||
|
| thread-score | score for interactions of cid on threads of relation-cid | smallint unsigned | YES | | NULL | |
|
||||||
|
| relation-thread-score | score for interactions of relation-cid on threads of cid | smallint unsigned | YES | | NULL | |
|
||||||
|
| post-score | score for the amount of posts from cid that can be seen by relation-cid | smallint unsigned | YES | | NULL | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -51,8 +51,8 @@ Fields
|
||||||
| archive | | boolean | NO | | 0 | |
|
| archive | | boolean | NO | | 0 | |
|
||||||
| unsearchable | Contact prefers to not be searchable | boolean | NO | | 0 | |
|
| unsearchable | Contact prefers to not be searchable | boolean | NO | | 0 | |
|
||||||
| sensitive | Contact posts sensitive content | boolean | NO | | 0 | |
|
| sensitive | Contact posts sensitive content | boolean | NO | | 0 | |
|
||||||
| baseurl | baseurl of the contact | varbinary(383) | YES | | | |
|
| baseurl | baseurl of the contact from the gserver record, can be missing | varbinary(383) | YES | | | |
|
||||||
| gsid | Global Server ID | int unsigned | YES | | NULL | |
|
| gsid | Global Server ID, can be missing | int unsigned | YES | | NULL | |
|
||||||
| bd | | date | NO | | 0001-01-01 | |
|
| bd | | date | NO | | 0001-01-01 | |
|
||||||
| reason | | text | YES | | NULL | |
|
| reason | | text | YES | | NULL | |
|
||||||
| self | 1 if the contact is the user him/her self | boolean | NO | | 0 | |
|
| self | 1 if the contact is the user him/her self | boolean | NO | | 0 | |
|
||||||
|
@ -81,7 +81,7 @@ Fields
|
||||||
| confirm | | varbinary(383) | YES | | NULL | |
|
| confirm | | varbinary(383) | YES | | NULL | |
|
||||||
| poco | | varbinary(383) | YES | | NULL | |
|
| poco | | varbinary(383) | YES | | NULL | |
|
||||||
| writable | | boolean | NO | | 0 | |
|
| writable | | boolean | NO | | 0 | |
|
||||||
| forum | contact is a forum. Deprecated, use 'contact-type' = 'community' and 'manually-approve' = false instead | boolean | NO | | 0 | |
|
| forum | contact is a group. Deprecated, use 'contact-type' = 'community' and 'manually-approve' = false instead | boolean | NO | | 0 | |
|
||||||
| prv | contact is a private group. Deprecated, use 'contact-type' = 'community' and 'manually-approve' = true instead | boolean | NO | | 0 | |
|
| prv | contact is a private group. Deprecated, use 'contact-type' = 'community' and 'manually-approve' = true instead | boolean | NO | | 0 | |
|
||||||
| bdyear | | varchar(4) | NO | | | |
|
| bdyear | | varchar(4) | NO | | | |
|
||||||
| site-pubkey | Deprecated | text | YES | | NULL | |
|
| site-pubkey | Deprecated | text | YES | | NULL | |
|
||||||
|
|
|
@ -25,9 +25,9 @@ Fields
|
||||||
| nofinish | if event does have no end this is 1 | boolean | NO | | 0 | |
|
| nofinish | if event does have no end this is 1 | boolean | NO | | 0 | |
|
||||||
| ignore | 0 or 1 | boolean | NO | | 0 | |
|
| ignore | 0 or 1 | boolean | NO | | 0 | |
|
||||||
| allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | YES | | NULL | |
|
| allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | YES | | NULL | |
|
||||||
| allow_gid | Access Control - list of allowed groups | mediumtext | YES | | NULL | |
|
| allow_gid | Access Control - list of allowed circles | mediumtext | YES | | NULL | |
|
||||||
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
||||||
| deny_gid | Access Control - list of denied groups | mediumtext | YES | | NULL | |
|
| deny_gid | Access Control - list of denied circles | mediumtext | YES | | NULL | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Table group
|
Table group
|
||||||
===========
|
===========
|
||||||
|
|
||||||
privacy groups, group info
|
privacy circles, circle info
|
||||||
|
|
||||||
Fields
|
Fields
|
||||||
------
|
------
|
||||||
|
@ -11,9 +11,9 @@ Fields
|
||||||
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
||||||
| uid | Owner User id | mediumint unsigned | NO | | 0 | |
|
| uid | Owner User id | mediumint unsigned | NO | | 0 | |
|
||||||
| visible | 1 indicates the member list is not private | boolean | NO | | 0 | |
|
| visible | 1 indicates the member list is not private | boolean | NO | | 0 | |
|
||||||
| deleted | 1 indicates the group has been deleted | boolean | NO | | 0 | |
|
| deleted | 1 indicates the circle has been deleted | boolean | NO | | 0 | |
|
||||||
| cid | Contact id of forum. When this field is filled then the members are synced automatically. | int unsigned | YES | | NULL | |
|
| cid | Contact id of group. When this field is filled then the members are synced automatically. | int unsigned | YES | | NULL | |
|
||||||
| name | human readable name of group | varchar(255) | NO | | | |
|
| name | human readable name of circle | varchar(255) | NO | | | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -1,16 +1,16 @@
|
||||||
Table group_member
|
Table group_member
|
||||||
===========
|
===========
|
||||||
|
|
||||||
privacy groups, member info
|
privacy circles, member info
|
||||||
|
|
||||||
Fields
|
Fields
|
||||||
------
|
------
|
||||||
|
|
||||||
| Field | Description | Type | Null | Key | Default | Extra |
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
| ---------- | --------------------------------------------------------- | ------------ | ---- | --- | ------- | -------------- |
|
| ---------- | ---------------------------------------------------------- | ------------ | ---- | --- | ------- | -------------- |
|
||||||
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
||||||
| gid | groups.id of the associated group | int unsigned | NO | | 0 | |
|
| gid | group.id of the associated circle | int unsigned | NO | | 0 | |
|
||||||
| contact-id | contact.id of the member assigned to the associated group | int unsigned | NO | | 0 | |
|
| contact-id | contact.id of the member assigned to the associated circle | int unsigned | NO | | 0 | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -11,9 +11,9 @@ Fields
|
||||||
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
||||||
| uid | Owner id of this permission set | mediumint unsigned | NO | | 0 | |
|
| uid | Owner id of this permission set | mediumint unsigned | NO | | 0 | |
|
||||||
| allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | YES | | NULL | |
|
| allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | YES | | NULL | |
|
||||||
| allow_gid | Access Control - list of allowed groups | mediumtext | YES | | NULL | |
|
| allow_gid | Access Control - list of allowed circles | mediumtext | YES | | NULL | |
|
||||||
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
||||||
| deny_gid | Access Control - list of denied groups | mediumtext | YES | | NULL | |
|
| deny_gid | Access Control - list of denied circles | mediumtext | YES | | NULL | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -30,9 +30,9 @@ Fields
|
||||||
| scale | | tinyint unsigned | NO | | 0 | |
|
| scale | | tinyint unsigned | NO | | 0 | |
|
||||||
| profile | | boolean | NO | | 0 | |
|
| profile | | boolean | NO | | 0 | |
|
||||||
| allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | YES | | NULL | |
|
| allow_cid | Access Control - list of allowed contact.id '<19><78>' | mediumtext | YES | | NULL | |
|
||||||
| allow_gid | Access Control - list of allowed groups | mediumtext | YES | | NULL | |
|
| allow_gid | Access Control - list of allowed circles | mediumtext | YES | | NULL | |
|
||||||
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
| deny_cid | Access Control - list of denied contact.id | mediumtext | YES | | NULL | |
|
||||||
| deny_gid | Access Control - list of denied groups | mediumtext | YES | | NULL | |
|
| deny_gid | Access Control - list of denied circles | mediumtext | YES | | NULL | |
|
||||||
| accessible | Make photo publicly accessible, ignoring permissions | boolean | NO | | 0 | |
|
| accessible | Make photo publicly accessible, ignoring permissions | boolean | NO | | 0 | |
|
||||||
| backend-class | Storage backend class | tinytext | YES | | NULL | |
|
| backend-class | Storage backend class | tinytext | YES | | NULL | |
|
||||||
| backend-ref | Storage backend data reference | text | YES | | NULL | |
|
| backend-ref | Storage backend data reference | text | YES | | NULL | |
|
||||||
|
|
|
@ -17,6 +17,7 @@ Fields
|
||||||
| location | text location where this item originated | varchar(255) | NO | | | |
|
| location | text location where this item originated | varchar(255) | NO | | | |
|
||||||
| coord | longitude/latitude pair representing location where this item originated | varchar(255) | NO | | | |
|
| coord | longitude/latitude pair representing location where this item originated | varchar(255) | NO | | | |
|
||||||
| language | Language information about this post | text | YES | | NULL | |
|
| language | Language information about this post | text | YES | | NULL | |
|
||||||
|
| sensitive | If true, this post contains sensitive content | boolean | YES | | NULL | |
|
||||||
| app | application which generated this item | varchar(255) | NO | | | |
|
| app | application which generated this item | varchar(255) | NO | | | |
|
||||||
| rendered-hash | | varchar(32) | NO | | | |
|
| rendered-hash | | varchar(32) | NO | | | |
|
||||||
| rendered-html | item.body converted to html | mediumtext | YES | | NULL | |
|
| rendered-html | item.body converted to html | mediumtext | YES | | NULL | |
|
||||||
|
@ -30,13 +31,12 @@ Fields
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
||||||
| Name | Fields |
|
| Name | Fields |
|
||||||
| -------------------------- | -------------------------------------- |
|
| ------------ | ------------ |
|
||||||
| PRIMARY | uri-id |
|
| PRIMARY | uri-id |
|
||||||
| plink | plink(191) |
|
| plink | plink(191) |
|
||||||
| resource-id | resource-id |
|
| resource-id | resource-id |
|
||||||
| title-content-warning-body | FULLTEXT, title, content-warning, body |
|
| quote-uri-id | quote-uri-id |
|
||||||
| quote-uri-id | quote-uri-id |
|
|
||||||
|
|
||||||
Foreign Keys
|
Foreign Keys
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -0,0 +1,35 @@
|
||||||
|
Table post-counts
|
||||||
|
===========
|
||||||
|
|
||||||
|
Original remote activity
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ------------- | ----------------------------------------------------------- | ----------------- | ---- | --- | ------- | ----- |
|
||||||
|
| uri-id | Id of the item-uri table entry that contains the item uri | int unsigned | NO | PRI | NULL | |
|
||||||
|
| vid | Id of the verb table entry that contains the activity verbs | smallint unsigned | NO | PRI | NULL | |
|
||||||
|
| reaction | Emoji Reaction | varchar(4) | NO | PRI | NULL | |
|
||||||
|
| parent-uri-id | Id of the item-uri table that contains the parent uri | int unsigned | YES | | NULL | |
|
||||||
|
| count | Number of activities | int unsigned | YES | | 0 | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ------------- | --------------------- |
|
||||||
|
| PRIMARY | uri-id, vid, reaction |
|
||||||
|
| vid | vid |
|
||||||
|
| parent-uri-id | parent-uri-id |
|
||||||
|
|
||||||
|
Foreign Keys
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Field | Target Table | Target Field |
|
||||||
|
|-------|--------------|--------------|
|
||||||
|
| uri-id | [item-uri](help/database/db_item-uri) | id |
|
||||||
|
| vid | [verb](help/database/db_verb) | id |
|
||||||
|
| parent-uri-id | [item-uri](help/database/db_item-uri) | id |
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -0,0 +1,42 @@
|
||||||
|
Table post-engagement
|
||||||
|
===========
|
||||||
|
|
||||||
|
Engagement data per post
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ------------ | --------------------------------------------------------------------- | ------------------ | ---- | --- | ------- | ----- |
|
||||||
|
| uri-id | Id of the item-uri table entry that contains the item uri | int unsigned | NO | PRI | NULL | |
|
||||||
|
| owner-id | Item owner | int unsigned | NO | | 0 | |
|
||||||
|
| contact-type | Person, organisation, news, community, relay | tinyint | NO | | 0 | |
|
||||||
|
| media-type | Type of media in a bit array (1 = image, 2 = video, 4 = audio | tinyint | NO | | 0 | |
|
||||||
|
| language | Language information about this post in the ISO 639-1 format | char(2) | YES | | NULL | |
|
||||||
|
| searchtext | Simplified text for the full text search | mediumtext | YES | | NULL | |
|
||||||
|
| size | Body size | int unsigned | YES | | NULL | |
|
||||||
|
| created | | datetime | YES | | NULL | |
|
||||||
|
| network | | char(4) | YES | | NULL | |
|
||||||
|
| restricted | If true, this post is either unlisted or not from a federated network | boolean | NO | | 0 | |
|
||||||
|
| comments | Number of comments | mediumint unsigned | YES | | NULL | |
|
||||||
|
| activities | Number of activities (like, dislike, ...) | mediumint unsigned | YES | | NULL | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ---------- | -------------------- |
|
||||||
|
| PRIMARY | uri-id |
|
||||||
|
| owner-id | owner-id |
|
||||||
|
| created | created |
|
||||||
|
| searchtext | FULLTEXT, searchtext |
|
||||||
|
|
||||||
|
Foreign Keys
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Field | Target Table | Target Field |
|
||||||
|
|-------|--------------|--------------|
|
||||||
|
| uri-id | [item-uri](help/database/db_item-uri) | id |
|
||||||
|
| owner-id | [contact](help/database/db_contact) | id |
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -0,0 +1,38 @@
|
||||||
|
Table post-searchindex
|
||||||
|
===========
|
||||||
|
|
||||||
|
Content for all posts
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ---------- | --------------------------------------------------------------------- | ------------ | ---- | --- | ------- | ----- |
|
||||||
|
| uri-id | Id of the item-uri table entry that contains the item uri | int unsigned | NO | PRI | NULL | |
|
||||||
|
| owner-id | Item owner | int unsigned | NO | | 0 | |
|
||||||
|
| media-type | Type of media in a bit array (1 = image, 2 = video, 4 = audio | tinyint | NO | | 0 | |
|
||||||
|
| language | Language information about this post in the ISO 639-1 format | char(2) | YES | | NULL | |
|
||||||
|
| searchtext | Simplified text for the full text search | mediumtext | YES | | NULL | |
|
||||||
|
| size | Body size | int unsigned | YES | | NULL | |
|
||||||
|
| created | | datetime | YES | | NULL | |
|
||||||
|
| restricted | If true, this post is either unlisted or not from a federated network | boolean | NO | | 0 | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ---------- | -------------------- |
|
||||||
|
| PRIMARY | uri-id |
|
||||||
|
| owner-id | owner-id |
|
||||||
|
| created | created |
|
||||||
|
| searchtext | FULLTEXT, searchtext |
|
||||||
|
|
||||||
|
Foreign Keys
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Field | Target Table | Target Field |
|
||||||
|
|-------|--------------|--------------|
|
||||||
|
| uri-id | [item-uri](help/database/db_item-uri) | id |
|
||||||
|
| owner-id | [contact](help/database/db_contact) | id |
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -36,24 +36,31 @@ Fields
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
||||||
| Name | Fields |
|
| Name | Fields |
|
||||||
| ----------------- | ------------------- |
|
| -------------------- | --------------------- |
|
||||||
| PRIMARY | uid, uri-id |
|
| PRIMARY | uid, uri-id |
|
||||||
| uri-id | uri-id |
|
| uri-id | uri-id |
|
||||||
| conversation-id | conversation-id |
|
| conversation-id | conversation-id |
|
||||||
| owner-id | owner-id |
|
| owner-id | owner-id |
|
||||||
| author-id | author-id |
|
| author-id | author-id |
|
||||||
| causer-id | causer-id |
|
| causer-id | causer-id |
|
||||||
| uid | uid |
|
| uid | uid |
|
||||||
| contact-id | contact-id |
|
| contact-id | contact-id |
|
||||||
| psid | psid |
|
| psid | psid |
|
||||||
| post-user-id | post-user-id |
|
| post-user-id | post-user-id |
|
||||||
| commented | commented |
|
| commented | commented |
|
||||||
| uid_received | uid, received |
|
| received | received |
|
||||||
| uid_wall_received | uid, wall, received |
|
| author-id_created | author-id, created |
|
||||||
| uid_commented | uid, commented |
|
| owner-id_created | owner-id, created |
|
||||||
| uid_starred | uid, starred |
|
| uid_received | uid, received |
|
||||||
| uid_mention | uid, mention |
|
| uid_wall_received | uid, wall, received |
|
||||||
|
| uid_commented | uid, commented |
|
||||||
|
| uid_created | uid, created |
|
||||||
|
| uid_starred | uid, starred |
|
||||||
|
| uid_mention | uid, mention |
|
||||||
|
| contact-id_commented | contact-id, commented |
|
||||||
|
| contact-id_received | contact-id, received |
|
||||||
|
| contact-id_created | contact-id, created |
|
||||||
|
|
||||||
Foreign Keys
|
Foreign Keys
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -58,7 +58,8 @@ Indexes
|
||||||
| event-id | event-id |
|
| event-id | event-id |
|
||||||
| psid | psid |
|
| psid | psid |
|
||||||
| author-id_uid | author-id, uid |
|
| author-id_uid | author-id, uid |
|
||||||
| author-id_received | author-id, received |
|
| author-id_created | author-id, created |
|
||||||
|
| owner-id_created | owner-id, created |
|
||||||
| parent-uri-id_uid | parent-uri-id, uid |
|
| parent-uri-id_uid | parent-uri-id, uid |
|
||||||
| uid_wall_received | uid, wall, received |
|
| uid_wall_received | uid, wall, received |
|
||||||
| uid_contactid | uid, contact-id |
|
| uid_contactid | uid, contact-id |
|
||||||
|
|
|
@ -13,7 +13,7 @@ Fields
|
||||||
| profile-name | Deprecated | varchar(255) | YES | | NULL | |
|
| profile-name | Deprecated | varchar(255) | YES | | NULL | |
|
||||||
| is-default | Deprecated | boolean | YES | | NULL | |
|
| is-default | Deprecated | boolean | YES | | NULL | |
|
||||||
| hide-friends | Hide friend list from viewers of this profile | boolean | NO | | 0 | |
|
| hide-friends | Hide friend list from viewers of this profile | boolean | NO | | 0 | |
|
||||||
| name | | varchar(255) | NO | | | |
|
| name | Unused in favor of user.username | varchar(255) | NO | | | |
|
||||||
| pdesc | Deprecated | varchar(255) | YES | | NULL | |
|
| pdesc | Deprecated | varchar(255) | YES | | NULL | |
|
||||||
| dob | Day of birth | varchar(32) | NO | | 0000-00-00 | |
|
| dob | Day of birth | varchar(32) | NO | | 0000-00-00 | |
|
||||||
| address | | varchar(255) | NO | | | |
|
| address | | varchar(255) | NO | | | |
|
||||||
|
@ -56,11 +56,10 @@ Fields
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
||||||
| Name | Fields |
|
| Name | Fields |
|
||||||
| -------------- | ---------------------- |
|
| -------------- | --------------- |
|
||||||
| PRIMARY | id |
|
| PRIMARY | id |
|
||||||
| uid_is-default | uid, is-default |
|
| uid_is-default | uid, is-default |
|
||||||
| pub_keywords | FULLTEXT, pub_keywords |
|
|
||||||
|
|
||||||
Foreign Keys
|
Foreign Keys
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
Table report-post
|
Table report-post
|
||||||
===========
|
===========
|
||||||
|
|
||||||
|
Individual posts attached to a moderation report
|
||||||
|
|
||||||
Fields
|
Fields
|
||||||
------
|
------
|
||||||
|
|
|
@ -0,0 +1,29 @@
|
||||||
|
Table report-rule
|
||||||
|
===========
|
||||||
|
|
||||||
|
Terms of service rule lines relevant to a moderation report
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ------- | ------------------------------------------------------------------------- | ------------ | ---- | --- | ------- | ----- |
|
||||||
|
| rid | Report id | int unsigned | NO | PRI | NULL | |
|
||||||
|
| line-id | Terms of service rule line number, may become invalid after a TOS change. | int unsigned | NO | PRI | NULL | |
|
||||||
|
| text | Terms of service rule text recorded at the time of the report | text | NO | | NULL | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ------- | ------------ |
|
||||||
|
| PRIMARY | rid, line-id |
|
||||||
|
|
||||||
|
Foreign Keys
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Field | Target Table | Target Field |
|
||||||
|
|-------|--------------|--------------|
|
||||||
|
| rid | [report](help/database/db_report) | id |
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -6,28 +6,40 @@ Table report
|
||||||
Fields
|
Fields
|
||||||
------
|
------
|
||||||
|
|
||||||
| Field | Description | Type | Null | Key | Default | Extra |
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
| ----------- | ----------------------------------------------- | ------------------ | ---- | --- | ------------------- | -------------- |
|
| --------------- | ------------------------------------------------------------ | ------------------ | ---- | --- | -------------------------- | -------------- |
|
||||||
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
| id | sequential ID | int unsigned | NO | PRI | NULL | auto_increment |
|
||||||
| uid | Reporting user | mediumint unsigned | YES | | NULL | |
|
| uid | Reporting user | mediumint unsigned | YES | | NULL | |
|
||||||
| reporter-id | Reporting contact | int unsigned | YES | | NULL | |
|
| reporter-id | Reporting contact | int unsigned | YES | | NULL | |
|
||||||
| cid | Reported contact | int unsigned | NO | | NULL | |
|
| cid | Reported contact | int unsigned | NO | | NULL | |
|
||||||
| comment | Report | text | YES | | NULL | |
|
| gsid | Reported contact server | int unsigned | YES | | NULL | |
|
||||||
| category | Category of the report (spam, violation, other) | varchar(20) | YES | | NULL | |
|
| comment | Report | text | YES | | NULL | |
|
||||||
| rules | Violated rules | text | YES | | NULL | |
|
| category-id | Report category, one of Entity Report::CATEGORY_* | int unsigned | NO | | 1 | |
|
||||||
| forward | Forward the report to the remote server | boolean | YES | | NULL | |
|
| forward | Forward the report to the remote server | boolean | YES | | NULL | |
|
||||||
| created | | datetime | NO | | 0001-01-01 00:00:00 | |
|
| public-remarks | Remarks shared with the reporter | text | YES | | NULL | |
|
||||||
| status | Status of the report | tinyint unsigned | YES | | NULL | |
|
| private-remarks | Remarks shared with the moderation team | text | YES | | NULL | |
|
||||||
|
| last-editor-uid | Last editor user | mediumint unsigned | YES | | NULL | |
|
||||||
|
| assigned-uid | Assigned moderator user | mediumint unsigned | YES | | NULL | |
|
||||||
|
| status | Status of the report, one of Entity Report::STATUS_* | tinyint unsigned | NO | | NULL | |
|
||||||
|
| resolution | Resolution of the report, one of Entity Report::RESOLUTION_* | tinyint unsigned | YES | | NULL | |
|
||||||
|
| created | | datetime(6) | NO | | 0001-01-01 00:00:00.000000 | |
|
||||||
|
| edited | Last time the report has been edited | datetime(6) | YES | | NULL | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
||||||
| Name | Fields |
|
| Name | Fields |
|
||||||
| ----------- | ----------- |
|
| ----------------- | ------------------ |
|
||||||
| PRIMARY | id |
|
| PRIMARY | id |
|
||||||
| uid | uid |
|
| uid | uid |
|
||||||
| cid | cid |
|
| cid | cid |
|
||||||
| reporter-id | reporter-id |
|
| reporter-id | reporter-id |
|
||||||
|
| gsid | gsid |
|
||||||
|
| last-editor-uid | last-editor-uid |
|
||||||
|
| assigned-uid | assigned-uid |
|
||||||
|
| status-resolution | status, resolution |
|
||||||
|
| created | created |
|
||||||
|
| edited | edited |
|
||||||
|
|
||||||
Foreign Keys
|
Foreign Keys
|
||||||
------------
|
------------
|
||||||
|
@ -37,5 +49,8 @@ Foreign Keys
|
||||||
| uid | [user](help/database/db_user) | uid |
|
| uid | [user](help/database/db_user) | uid |
|
||||||
| reporter-id | [contact](help/database/db_contact) | id |
|
| reporter-id | [contact](help/database/db_contact) | id |
|
||||||
| cid | [contact](help/database/db_contact) | id |
|
| cid | [contact](help/database/db_contact) | id |
|
||||||
|
| gsid | [gserver](help/database/db_gserver) | id |
|
||||||
|
| last-editor-uid | [user](help/database/db_user) | uid |
|
||||||
|
| assigned-uid | [user](help/database/db_user) | uid |
|
||||||
|
|
||||||
Return to [database documentation](help/database)
|
Return to [database documentation](help/database)
|
||||||
|
|
|
@ -6,28 +6,29 @@ User specific public contact data
|
||||||
Fields
|
Fields
|
||||||
------
|
------
|
||||||
|
|
||||||
| Field | Description | Type | Null | Key | Default | Extra |
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
| ------------------------- | ------------------------------------------------------------ | ------------------ | ---- | --- | ------- | ----- |
|
| ------------------------- | ----------------------------------------------------------------------- | ------------------ | ---- | --- | ------- | ----- |
|
||||||
| cid | Contact id of the linked public contact | int unsigned | NO | PRI | 0 | |
|
| cid | Contact id of the linked public contact | int unsigned | NO | PRI | 0 | |
|
||||||
| uid | User id | mediumint unsigned | NO | PRI | 0 | |
|
| uid | User id | mediumint unsigned | NO | PRI | 0 | |
|
||||||
| uri-id | Id of the item-uri table entry that contains the contact url | int unsigned | YES | | NULL | |
|
| uri-id | Id of the item-uri table entry that contains the contact url | int unsigned | YES | | NULL | |
|
||||||
| blocked | Contact is completely blocked for this user | boolean | YES | | NULL | |
|
| blocked | Contact is completely blocked for this user | boolean | YES | | NULL | |
|
||||||
| ignored | Posts from this contact are ignored | boolean | YES | | NULL | |
|
| ignored | Posts from this contact are ignored | boolean | YES | | NULL | |
|
||||||
| collapsed | Posts from this contact are collapsed | boolean | YES | | NULL | |
|
| collapsed | Posts from this contact are collapsed | boolean | YES | | NULL | |
|
||||||
| hidden | This contact is hidden from the others | boolean | YES | | NULL | |
|
| hidden | This contact is hidden from the others | boolean | YES | | NULL | |
|
||||||
| is-blocked | User is blocked by this contact | boolean | YES | | NULL | |
|
| is-blocked | User is blocked by this contact | boolean | YES | | NULL | |
|
||||||
| pending | | boolean | YES | | NULL | |
|
| channel-frequency | Controls the frequency of the appearance of this contact in channels | tinyint unsigned | YES | | NULL | |
|
||||||
| rel | The kind of the relation between the user and the contact | tinyint unsigned | YES | | NULL | |
|
| pending | | boolean | YES | | NULL | |
|
||||||
| info | | mediumtext | YES | | NULL | |
|
| rel | The kind of the relation between the user and the contact | tinyint unsigned | YES | | NULL | |
|
||||||
| notify_new_posts | | boolean | YES | | NULL | |
|
| info | | mediumtext | YES | | NULL | |
|
||||||
| remote_self | | boolean | YES | | NULL | |
|
| notify_new_posts | | boolean | YES | | NULL | |
|
||||||
| fetch_further_information | | tinyint unsigned | YES | | NULL | |
|
| remote_self | 0 => No mirroring, 1-2 => Mirror as own post, 3 => Mirror as reshare | tinyint unsigned | YES | | NULL | |
|
||||||
| ffi_keyword_denylist | | text | YES | | NULL | |
|
| fetch_further_information | 0 => None, 1 => Fetch information, 3 => Fetch keywords, 2 => Fetch both | tinyint unsigned | YES | | NULL | |
|
||||||
| subhub | | boolean | YES | | NULL | |
|
| ffi_keyword_denylist | | text | YES | | NULL | |
|
||||||
| hub-verify | | varbinary(383) | YES | | NULL | |
|
| subhub | | boolean | YES | | NULL | |
|
||||||
| protocol | Protocol of the contact | char(4) | YES | | NULL | |
|
| hub-verify | | varbinary(383) | YES | | NULL | |
|
||||||
| rating | Automatically detected feed poll frequency | tinyint | YES | | NULL | |
|
| protocol | Protocol of the contact | char(4) | YES | | NULL | |
|
||||||
| priority | Feed poll priority | tinyint unsigned | YES | | NULL | |
|
| rating | Automatically detected feed poll frequency | tinyint | YES | | NULL | |
|
||||||
|
| priority | Feed poll priority | tinyint unsigned | YES | | NULL | |
|
||||||
|
|
||||||
Indexes
|
Indexes
|
||||||
------------
|
------------
|
||||||
|
|
|
@ -0,0 +1,31 @@
|
||||||
|
Table user-gserver
|
||||||
|
===========
|
||||||
|
|
||||||
|
User settings about remote servers
|
||||||
|
|
||||||
|
Fields
|
||||||
|
------
|
||||||
|
|
||||||
|
| Field | Description | Type | Null | Key | Default | Extra |
|
||||||
|
| ------- | ---------------------------------------- | ------------------ | ---- | --- | ------- | ----- |
|
||||||
|
| uid | Owner User id | mediumint unsigned | NO | PRI | 0 | |
|
||||||
|
| gsid | Gserver id | int unsigned | NO | PRI | 0 | |
|
||||||
|
| ignored | server accounts are ignored for the user | boolean | NO | | 0 | |
|
||||||
|
|
||||||
|
Indexes
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Name | Fields |
|
||||||
|
| ------- | --------- |
|
||||||
|
| PRIMARY | uid, gsid |
|
||||||
|
| gsid | gsid |
|
||||||
|
|
||||||
|
Foreign Keys
|
||||||
|
------------
|
||||||
|
|
||||||
|
| Field | Target Table | Target Field |
|
||||||
|
|-------|--------------|--------------|
|
||||||
|
| uid | [user](help/database/db_user) | uid |
|
||||||
|
| gsid | [gserver](help/database/db_gserver) | id |
|
||||||
|
|
||||||
|
Return to [database documentation](help/database)
|
|
@ -34,8 +34,6 @@ Fields
|
||||||
| blockwall | Prohibit contacts to post to the profile page of the user | boolean | NO | | 0 | |
|
| blockwall | Prohibit contacts to post to the profile page of the user | boolean | NO | | 0 | |
|
||||||
| hidewall | Hide profile details from unknown viewers | boolean | NO | | 0 | |
|
| hidewall | Hide profile details from unknown viewers | boolean | NO | | 0 | |
|
||||||
| blocktags | Prohibit contacts to tag the post of this user | boolean | NO | | 0 | |
|
| blocktags | Prohibit contacts to tag the post of this user | boolean | NO | | 0 | |
|
||||||
| unkmail | Permit unknown people to send private mails to this user | boolean | NO | | 0 | |
|
|
||||||
| cntunkmail | | int unsigned | NO | | 10 | |
|
|
||||||
| notify-flags | email notification options | smallint unsigned | NO | | 65535 | |
|
| notify-flags | email notification options | smallint unsigned | NO | | 65535 | |
|
||||||
| page-flags | page/profile type | tinyint unsigned | NO | | 0 | |
|
| page-flags | page/profile type | tinyint unsigned | NO | | 0 | |
|
||||||
| account-type | | tinyint unsigned | NO | | 0 | |
|
| account-type | | tinyint unsigned | NO | | 0 | |
|
||||||
|
|
|
@ -109,7 +109,7 @@ Ein ['Tipp für neue Mitglieder'](newmember)-Link zeigt sich in den ersten beide
|
||||||
|
|
||||||
## Schau Dir ebenfalls folgende Seiten an
|
## Schau Dir ebenfalls folgende Seiten an
|
||||||
|
|
||||||
* [Gruppen und Privatssphäre](help/Groups-and-Privacy)
|
* [Circles und Privatssphäre](help/Circles-and-Privacy)
|
||||||
|
|
||||||
* [Account löschen](help/Remove-Account)
|
* [Account löschen](help/Remove-Account)
|
||||||
|
|
||||||
|
|
|
@ -103,6 +103,15 @@ Derzeitige Hooks
|
||||||
$b ist das Item-Array einer Information, die in der Datenbank und im Item gespeichert ist.
|
$b ist das Item-Array einer Information, die in der Datenbank und im Item gespeichert ist.
|
||||||
{Bitte beachte: der Seiteninhalt ist bbcode - nicht HTML)
|
{Bitte beachte: der Seiteninhalt ist bbcode - nicht HTML)
|
||||||
|
|
||||||
|
**'detect_languages'**
|
||||||
|
Wird nach der Sprachenerkennung aufgerufen.
|
||||||
|
Dieser Hook kann dafür verwendet werden, alternative Erkennungsfunktionen einzubinden.
|
||||||
|
`$data` ist ein Array:
|
||||||
|
'text' => Der analysierte Text.
|
||||||
|
'detected' => (Eingabe/Ausgabe) Das Array mit den erkannten Sprachen. Der Sprachcode ist der Array-Schlüssel, der Array-Wert ist der dezimale Wert für die Wahrscheinlichkeit.
|
||||||
|
'uri-id' => Die Uri-Id des Beitrags
|
||||||
|
'author-id' => Die Contact-id des Autors.
|
||||||
|
|
||||||
**'addon_settings'** - wird aufgerufen, wenn die HTML-Ausgabe der Addon-Einstellungsseite generiert wird.
|
**'addon_settings'** - wird aufgerufen, wenn die HTML-Ausgabe der Addon-Einstellungsseite generiert wird.
|
||||||
$b ist die HTML-Ausgabe (String) der Addon-Einstellungsseite vor dem finalen "</form>"-Tag.
|
$b ist die HTML-Ausgabe (String) der Addon-Einstellungsseite vor dem finalen "</form>"-Tag.
|
||||||
|
|
||||||
|
@ -316,6 +325,7 @@ Eine komplette Liste aller Hook-Callbacks mit den zugehörigen Dateien (am 01-Ap
|
||||||
|
|
||||||
### src/Model/Item.php
|
### src/Model/Item.php
|
||||||
|
|
||||||
|
Hook::callAll('detect_languages', $item);
|
||||||
Hook::callAll('post_local', $item);
|
Hook::callAll('post_local', $item);
|
||||||
Hook::callAll('post_remote', $item);
|
Hook::callAll('post_remote', $item);
|
||||||
Hook::callAll('post_local_end', $posted_item);
|
Hook::callAll('post_local_end', $posted_item);
|
||||||
|
|
|
@ -356,8 +356,8 @@ Zeilen</code></td>
|
||||||
[li] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/ul]<br>
|
[/ul]<br>
|
||||||
[list]<br>
|
[list]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listbullet" style="list-style-type: circle;">
|
<ul class="listbullet" style="list-style-type: circle;">
|
||||||
|
@ -368,12 +368,12 @@ Zeilen</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[ol]<br>
|
<td>[ol]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/ol]<br>
|
[/ol]<br>
|
||||||
[list=1]<br>
|
[list=1]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listdecimal" style="list-style-type: decimal;">
|
<ul class="listdecimal" style="list-style-type: decimal;">
|
||||||
|
@ -384,8 +384,8 @@ Zeilen</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=]<br>
|
<td>[list=]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listnone" style="list-style-type: none;">
|
<ul class="listnone" style="list-style-type: none;">
|
||||||
|
@ -396,8 +396,8 @@ Zeilen</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=i]<br>
|
<td>[list=i]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listlowerroman" style="list-style-type: lower-roman;">
|
<ul class="listlowerroman" style="list-style-type: lower-roman;">
|
||||||
|
@ -408,8 +408,8 @@ Zeilen</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=I]<br>
|
<td>[list=I]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listupperroman" style="list-style-type: upper-roman;">
|
<ul class="listupperroman" style="list-style-type: upper-roman;">
|
||||||
|
@ -420,8 +420,8 @@ Zeilen</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=a]<br>
|
<td>[list=a]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listloweralpha" style="list-style-type: lower-alpha;">
|
<ul class="listloweralpha" style="list-style-type: lower-alpha;">
|
||||||
|
@ -432,8 +432,8 @@ Zeilen</code></td>
|
||||||
</tr>
|
</tr>
|
||||||
<tr>
|
<tr>
|
||||||
<td>[list=A]<br>
|
<td>[list=A]<br>
|
||||||
[*] Erstes Listenelement<br>
|
[li] Erstes Listenelement<br>
|
||||||
[*] Zweites Listenelement<br>
|
[li] Zweites Listenelement<br>
|
||||||
[/list]</td>
|
[/list]</td>
|
||||||
<td>
|
<td>
|
||||||
<ul class="listupperalpha" style="list-style-type: upper-alpha;">
|
<ul class="listupperalpha" style="list-style-type: upper-alpha;">
|
||||||
|
|
|
@ -1,54 +1,54 @@
|
||||||
Gruppen und Privatsphäre
|
Circles und Privatsphäre
|
||||||
==================
|
==================
|
||||||
|
|
||||||
* [Zur Startseite der Hilfe](help)
|
* [Zur Startseite der Hilfe](help)
|
||||||
|
|
||||||
Gruppen sind nur eine Ansammlung von Freunden.
|
Circles sind nur eine Ansammlung von Freunden.
|
||||||
Aber Friendica nutzt diese, um sehr mächtige Features zur Verfügung zu stellen.
|
Aber Friendica nutzt diese, um sehr mächtige Features zur Verfügung zu stellen.
|
||||||
|
|
||||||
**Gruppen erstellen**
|
**Circles erstellen**
|
||||||
|
|
||||||
Um eine Gruppe zu erstellen, besuche deine "Kontakte"-Seite und wähle "Neue Gruppe erstellen" (je nach Design nur als Pluszeichen angezeigt).
|
Um eine Circle zu erstellen, besuche deine "Kontakte"-Seite und wähle "Neue Circle erstellen" (je nach Design nur als Pluszeichen angezeigt).
|
||||||
Gib deiner Gruppe einen Namen.
|
Gib deiner Circle einen Namen.
|
||||||
|
|
||||||
Das führt dich zu einer Seite, auf der du die Gruppenmitglieder auswählen kannst.
|
Das führt dich zu einer Seite, auf der du die Gruppenmitglieder auswählen kannst.
|
||||||
|
|
||||||
Du hast zwei Boxen auf der Seite.
|
Du hast zwei Boxen auf der Seite.
|
||||||
Die obere Box ist die Übersicht der aktuellen Mitglieder.
|
Die obere Box ist die Übersicht der aktuellen Mitglieder.
|
||||||
Die untere beinhaltet alle Freunde, die *nicht* Mitglied dieser Gruppe sind.
|
Die untere beinhaltet alle Freunde, die *nicht* Mitglied dieser Circle sind.
|
||||||
|
|
||||||
Wenn du auf das Foto einer Person klickst, die nicht in der Gruppe ist, wird diese in die Gruppe verschoben.
|
Wenn du auf das Foto einer Person klickst, die nicht in der Circle ist, wird diese in die Circle verschoben.
|
||||||
Wenn du auf das Foto einer Person klickst, die bereits in der Gruppe ist, dann wird diese Person daraus entfernt.
|
Wenn du auf das Foto einer Person klickst, die bereits in der Circle ist, dann wird diese Person daraus entfernt.
|
||||||
|
|
||||||
**Zugriffskontrolle**
|
**Zugriffskontrolle**
|
||||||
|
|
||||||
Sobald du eine Gruppe erstellt hast, kannst du diese auf jeder Zugriffsrechteliste nutzen.
|
Sobald du eine Circle erstellt hast, kannst du diese auf jeder Zugriffsrechteliste nutzen.
|
||||||
Damit ist das kleine Schloss neben deinem Statuseditor auf deiner Startseite gemeint.
|
Damit ist das kleine Schloss neben deinem Statuseditor auf deiner Startseite gemeint.
|
||||||
Wenn du darauf klickst, kannst du auswählen, wer deinen Beitrag sehen kann und wer *nicht*.
|
Wenn du darauf klickst, kannst du auswählen, wer deinen Beitrag sehen kann und wer *nicht*.
|
||||||
Dabei kann es sich um eine einzelne Person oder eine ganze Gruppe handeln.
|
Dabei kann es sich um eine einzelne Person oder eine ganze Circle handeln.
|
||||||
|
|
||||||
Auf deiner "Netzwerk"-Seite ("Unterhaltungen deiner Kontakte") findest du Beiträge und Gespräche aller deiner Kontakte in deinem Netzwerk.
|
Auf deiner "Netzwerk"-Seite ("Unterhaltungen deiner Kontakte") findest du Beiträge und Gespräche aller deiner Kontakte in deinem Netzwerk.
|
||||||
Du kannst aber auch eine einzelne Gruppe auswählen und nur Beiträge dieser Gruppenmitglieder anzeigen lassen.
|
Du kannst aber auch eine einzelne Circle auswählen und nur Beiträge dieser Gruppenmitglieder anzeigen lassen.
|
||||||
|
|
||||||
Aber stopp, es gibt noch mehr...
|
Aber stopp, es gibt noch mehr...
|
||||||
|
|
||||||
Wenn du auf deiner "Netzwerk"-Seite eine bestimmte Gruppe ausgewählt hast, dann findest du im Statuseditor neben dem Schloss ein Ausrufezeichen.
|
Wenn du auf deiner "Netzwerk"-Seite eine bestimmte Circle ausgewählt hast, dann findest du im Statuseditor neben dem Schloss ein Ausrufezeichen.
|
||||||
Dies dient dazu, deine Aufmerksamkeit auf das Schloss zu richten.
|
Dies dient dazu, deine Aufmerksamkeit auf das Schloss zu richten.
|
||||||
Klicke auf das Schloss.
|
Klicke auf das Schloss.
|
||||||
Dort siehst du, dass dein Status-Update in dieser Ansicht standardmäßig nur für diese Gruppe freigegeben ist.
|
Dort siehst du, dass dein Status-Update in dieser Ansicht standardmäßig nur für diese Circle freigegeben ist.
|
||||||
Das hilft dir, deinen zukünftigen Mitarbeitern nicht das Gleiche zu schreiben wie deinen Trinkfreunden.
|
Das hilft dir, deinen zukünftigen Mitarbeitern nicht das Gleiche zu schreiben wie deinen Trinkfreunden.
|
||||||
Du kannst diese Einstellung natürlich auch überschreiben.
|
Du kannst diese Einstellung natürlich auch überschreiben.
|
||||||
|
|
||||||
**Standardmäßige Zugriffsrechte von Beiträgen**
|
**Standardmäßige Zugriffsrechte von Beiträgen**
|
||||||
|
|
||||||
Standardmäßig geht Friendica davon aus, dass alle deine Beiträge privat sein sollen.
|
Standardmäßig geht Friendica davon aus, dass alle deine Beiträge privat sein sollen.
|
||||||
Aus diesem Grund erstellt Friendica nach der Anmeldung eine Gruppe, in die automatisch alle deine Kontakte hinzugefügt werden.
|
Aus diesem Grund erstellt Friendica nach der Anmeldung eine Circle, in die automatisch alle deine Kontakte hinzugefügt werden.
|
||||||
Alle deine Beiträge sind nur auf diese Gruppe beschränkt.
|
Alle deine Beiträge sind nur auf diese Circle beschränkt.
|
||||||
|
|
||||||
Beachte, dass diese Einstellung von deinem Seiten-Administrator überschrieben werden kann, was bedeutet, dass alle deine Beiträge standardmäßig "öffentlich" sind (bspw. für das gesamte Internet).
|
Beachte, dass diese Einstellung von deinem Seiten-Administrator überschrieben werden kann, was bedeutet, dass alle deine Beiträge standardmäßig "öffentlich" sind (bspw. für das gesamte Internet).
|
||||||
|
|
||||||
Wenn du deine Beiträge standardmäßig "öffentlich" haben willst, dann kannst du deine Standardzugriffsrechte auf deiner Einstellungseite ändern.
|
Wenn du deine Beiträge standardmäßig "öffentlich" haben willst, dann kannst du deine Standardzugriffsrechte auf deiner Einstellungseite ändern.
|
||||||
Dort kannst du außerdem festlegen, welchen Gruppen standardmäßig deine Beiträge erhalten oder in welche Gruppe deine neuen Kontakte standardmäßig eingeordnet werden.
|
Dort kannst du außerdem festlegen, welchen Circles standardmäßig deine Beiträge erhalten oder in welche Circle deine neuen Kontakte standardmäßig eingeordnet werden.
|
||||||
|
|
||||||
**Fragen der Privatssphäre, die zu beachten sind**
|
**Fragen der Privatssphäre, die zu beachten sind**
|
||||||
|
|
||||||
|
@ -60,7 +60,7 @@ Keine Software der Welt kann deine Freunde davon abhalten, die privaten Unterhal
|
||||||
Nur eine gute Auswahl deiner Freunde.
|
Nur eine gute Auswahl deiner Freunde.
|
||||||
|
|
||||||
Bei GNu Social und anderen Netzwerk-Anbietern ist es nicht so gesichert.
|
Bei GNu Social und anderen Netzwerk-Anbietern ist es nicht so gesichert.
|
||||||
Du musst **sehr** vorsichtig sein, wenn du Mitglieder anderer Netzwerke in einer deiner Gruppen hast, da es möglich ist, dass deine privaten Nachrichten in einem öffentlichen Stream enden.
|
Du musst **sehr** vorsichtig sein, wenn du Mitglieder anderer Netzwerke in einer deiner Circles hast, da es möglich ist, dass deine privaten Nachrichten in einem öffentlichen Stream enden.
|
||||||
Wenn du auf die "Kontakt bearbeiten"-Seite einer Person gehst, zeigen wir dir, ob sie Mitglied eines unsicheren Netzwerks ist oder nicht.
|
Wenn du auf die "Kontakt bearbeiten"-Seite einer Person gehst, zeigen wir dir, ob sie Mitglied eines unsicheren Netzwerks ist oder nicht.
|
||||||
|
|
||||||
Sobald du einen Post erstellt hast, kannst du die Zugriffsrechte nicht mehr ändern.
|
Sobald du einen Post erstellt hast, kannst du die Zugriffsrechte nicht mehr ändern.
|
|
@ -45,7 +45,7 @@ Die aufgelisteten Adressen werden wie folgt durch Kommas voneinander getrennt:
|
||||||
'admin_email' => 'mail1@example.com,mail2@example.com',
|
'admin_email' => 'mail1@example.com,mail2@example.com',
|
||||||
```
|
```
|
||||||
|
|
||||||
<a name="dbupdate">
|
<a name="dbupdate"></a>
|
||||||
### Die Datenbank Struktur schein nicht aktuell zu sein. Was kann ich tun?
|
### Die Datenbank Struktur schein nicht aktuell zu sein. Was kann ich tun?
|
||||||
|
|
||||||
Rufe bitte im Admin Panel den Punkt [DB Updates](/admin/dbsync/) auf und folge dem Link *Datenbank Struktur überprüfen*.
|
Rufe bitte im Admin Panel den Punkt [DB Updates](/admin/dbsync/) auf und folge dem Link *Datenbank Struktur überprüfen*.
|
||||||
|
@ -56,4 +56,4 @@ Starte dazu bitte vom Grundverzeichnis deiner Friendica Instanz folgendes Komman
|
||||||
|
|
||||||
bin/console dbstructure update
|
bin/console dbstructure update
|
||||||
|
|
||||||
sollten bei der Ausführung Fehler auftreten, kontaktiere bitte das [Support Forum](https://forum.friendi.ca/profile/helpers).
|
sollten bei der Ausführung Fehler auftreten, kontaktiere bitte die [Friendia Support](https://forum.friendi.ca/profile/helpers) Gruppe oder die [Friendica Admins](https://forum.friendi.ca/profile/admins) Gruppe.
|
||||||
|
|
|
@ -23,7 +23,7 @@ Wenn Du Deinen Account nicht nutzen kannst, kannst Du einen Account auf einer ö
|
||||||
|
|
||||||
Wenn du dir keinen weiteren Friendica Account einrichten willst, kannst du auch gerne über einen der folgenden alternativen Kanäle Hilfe suchen:
|
Wenn du dir keinen weiteren Friendica Account einrichten willst, kannst du auch gerne über einen der folgenden alternativen Kanäle Hilfe suchen:
|
||||||
|
|
||||||
* Friendica Support Forum: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
* Friendica Support Gruppe: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
||||||
* Chats der Friendica Community (die IRC, Matrix und XMPP Räume sind mit einer Brücke verbunden) Logs dieser öffentlichen Chaträume können [hier aus dem IRC](https://gnusociarg.nsupdate.info/2021/%23friendica/) und [hier aus der Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/) gefunden werden.
|
* Chats der Friendica Community (die IRC, Matrix und XMPP Räume sind mit einer Brücke verbunden) Logs dieser öffentlichen Chaträume können [hier aus dem IRC](https://gnusociarg.nsupdate.info/2021/%23friendica/) und [hier aus der Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/) gefunden werden.
|
||||||
* XMPP: support(at)forum.friendi.ca
|
* XMPP: support(at)forum.friendi.ca
|
||||||
* IRC: #friendica auf [libera.chat](https://web.libera.chat/?channels=#friendica)
|
* IRC: #friendica auf [libera.chat](https://web.libera.chat/?channels=#friendica)
|
||||||
|
|
|
@ -1,63 +0,0 @@
|
||||||
Foren
|
|
||||||
=====
|
|
||||||
|
|
||||||
* [Zur Startseite der Hilfe](help)
|
|
||||||
|
|
||||||
|
|
||||||
In Friendica kannst Du auch Foren und/oder Prominenten-Seiten erstellen.
|
|
||||||
|
|
||||||
Jede Seite in Friendica hat einen einmaligen Spitznamen.
|
|
||||||
Das gilt für alle Seiten, unabhängig davon, ob es sich um normale Profile oder Forenseiten handelt.
|
|
||||||
|
|
||||||
Das Erste, was Du machen musst, um ein neues Forum zu kreieren, ist einen neuen Account zu erstellen.
|
|
||||||
Bitte beachte, dass der Seitenadministrator die Registrierung neuer Accounts sperren oder an Bedingungen knüpfen kann.
|
|
||||||
|
|
||||||
Wenn Du einen zweiten Account in einem System erstellst und die gleiche Email-Adresse oder den gleichen OpenID-Account nutzt, kannst Du Dich zukünftig nur noch mit Deinem Spitznamen anmelden.
|
|
||||||
|
|
||||||
Gehe im neuen Account auf die "Einstellungs"-Seite und dort am Ende der Seite auf "Erweiterte Konto-/Seitentyp-Einstellungen".
|
|
||||||
Normalerweise nutzt Du "Normales Konto" für einen normalen, persönlichen Account.
|
|
||||||
Das ist die Standardeinstellung.
|
|
||||||
Gruppenseiten bieten die Möglichkeit, Leute als Freund/Fan ohne Kontaktbestätigung zuzulassen.
|
|
||||||
|
|
||||||
Die Auswahl der Einstellung, die Du wählst, hängt davon ab, wie Du mit anderen Leuten auf Deiner Seite interagieren willst.
|
|
||||||
Die "Marktschreier"-Einstellung (Soapbox) lässt den Seitenbesitzer die gesamte Kommunikation kontrollieren.
|
|
||||||
Alles was Du schreibst, geht an alle Seitennutzer, aber es gibt keine Möglichkeit, zu interagieren.
|
|
||||||
Diese Seite wird normalerweise für Ankündigungen oder die Kommunikation von Gemeinschaften genutzt.
|
|
||||||
|
|
||||||
Die normalste Einstellung ist das "Forum-/Promi-Konto".
|
|
||||||
Diese erstellt eine Gruppenseite, in der alle Mitglieder frei miteinander interagieren können.
|
|
||||||
|
|
||||||
Der "Automatische Freunde Seite"-Account ist typischerweise für persönliche Profile, bei denen Du alle Freundschaftsanfragen automatisch bestätigen willst.
|
|
||||||
|
|
||||||
|
|
||||||
**Multiple Foren verwalten**
|
|
||||||
|
|
||||||
Wir schlagen vor, dass Du ein Gruppenforum mit der gleichen Email-Adresse und dem gleichen Passwort wie bei Deinem normalen Account nutzt.
|
|
||||||
Wenn Du das machst, findest Du einen neuen "Verwalten"-Link in der Menüleiste, über den Du einfach zwischen den Identitäten wechseln kannst.
|
|
||||||
Du musst das nicht machen, die Alternative ist allerdings, Dich immer wieder aus- und wieder einzuloggen.
|
|
||||||
Und das kann umständlich sein, wenn Du mehrere verschiedene Foren/Identitäten verwaltest.
|
|
||||||
|
|
||||||
Du kannst ebenso jemanden wählen, der Dein Forum verwaltet.
|
|
||||||
Mach das, indem Du die [Delegations-Setup-Seite](/settings/delegation) besuchst.
|
|
||||||
Dort wird Dir eine Liste an "Potentiellen Bevollmächtigen" angezeigt.
|
|
||||||
Die Auswahl einer oder mehrerer Personen gibt diesen die Möglichkeit, Dein Forum zu verwalten.
|
|
||||||
Sie können Kontakte, Profile und alle Inhalte Deines Accounts/deiner Seite bearbeiten.
|
|
||||||
Bitte nutze diese Einstellung mit Vorsicht.
|
|
||||||
Delegierte haben allerdings keine Möglichkeit, grundlegende Account-Einstellungen wie das Passwort oder den Seitentypen zu ändern bzw. den Account zu löschen.
|
|
||||||
|
|
||||||
|
|
||||||
**Beiträge auf Community-Foren**
|
|
||||||
|
|
||||||
Wenn Du Mitglied eines Community-Forums bist, kannst Du das Forum in einem Beitrag hinzufügen/erwähnen, wenn Du den @-Tag nutzt.
|
|
||||||
Zum Beispiel würde @Fahrrad Deinen Beitrag neben den sonst ausgewählten Nutzern an alle Nutzer schicken, die in der Gruppe "Fahrrad" sind.
|
|
||||||
Wenn Dein Beitrag privat ist, musst Du diese Gruppe explizit in den Zugriffsrechten des Beitrags auswählen **und** sie mit dem @-Tag erwähnen (was den Beitrag auf die Gruppenmitglieder erweitert).
|
|
||||||
|
|
||||||
Zusätzlich ist es möglich, Foren mit dem Ausrufezeichen zu adressieren.
|
|
||||||
Im obigen Beispiel bedeutet dies, dass Du das Fahrrad-Forum per !Fahrrad erreichen würdest.
|
|
||||||
Der Unterschied zum @ besteht darin, dass der Beitrag auschließlich über das Forum verbreitet wird und nicht an weitere Nutzer.
|
|
||||||
Dies bedeutet auch, dass es nicht sinnvoll ist, mehrere Foren per ! in einem Beitrag zu adressieren, da nur eines der Foren den Beitrag verbreiten wird.
|
|
||||||
|
|
||||||
Du kannst außerdem via "Wall zu Wall" einen Beitrag auf der Community-Seite bzw. in dem Community-Forum erstellen.
|
|
||||||
|
|
||||||
Kommentare, die Du an ein Community-Forum schickst, werden dem Originalbeitrag hinzugefügt.
|
|
||||||
Ein weiteres Forum mit dem @-Tag zu erwähnen, leitet den Beitrag nicht an dieses weiter, da die Verteilung der Kommentare komplett vom Originalbeitrag bestimmt wird.
|
|
|
@ -0,0 +1,63 @@
|
||||||
|
Gruppen
|
||||||
|
=====
|
||||||
|
|
||||||
|
* [Zur Startseite der Hilfe](help)
|
||||||
|
|
||||||
|
|
||||||
|
In Friendica kannst Du auch Gruppen und/oder Prominenten-Seiten erstellen.
|
||||||
|
|
||||||
|
Jede Seite in Friendica hat einen einmaligen Spitznamen.
|
||||||
|
Das gilt für alle Seiten, unabhängig davon, ob es sich um normale Profile oder Forenseiten handelt.
|
||||||
|
|
||||||
|
Das Erste, was Du machen musst, um eine neue Gruppe zu kreieren, ist einen neuen Account zu erstellen.
|
||||||
|
Bitte beachte, dass der Seitenadministrator die Registrierung neuer Accounts sperren oder an Bedingungen knüpfen kann.
|
||||||
|
|
||||||
|
Wenn Du einen zweiten Account in einem System erstellst und die gleiche Email-Adresse oder den gleichen OpenID-Account nutzt, kannst Du Dich zukünftig nur noch mit Deinem Spitznamen anmelden.
|
||||||
|
|
||||||
|
Gehe im neuen Account auf die "Einstellungs"-Seite und dort am Ende der Seite auf "Erweiterte Konto-/Seitentyp-Einstellungen".
|
||||||
|
Normalerweise nutzt Du "Normales Konto" für einen normalen, persönlichen Account.
|
||||||
|
Das ist die Standardeinstellung.
|
||||||
|
Gruppenseiten bieten die Möglichkeit, Leute als Freund/Fan ohne Kontaktbestätigung zuzulassen.
|
||||||
|
|
||||||
|
Die Auswahl der Einstellung, die Du wählst, hängt davon ab, wie Du mit anderen Leuten auf Deiner Seite interagieren willst.
|
||||||
|
Die "Marktschreier"-Einstellung (Soapbox) lässt den Seitenbesitzer die gesamte Kommunikation kontrollieren.
|
||||||
|
Alles was Du schreibst, geht an alle Seitennutzer, aber es gibt keine Möglichkeit, zu interagieren.
|
||||||
|
Diese Seite wird normalerweise für Ankündigungen oder die Kommunikation von Gemeinschaften genutzt.
|
||||||
|
|
||||||
|
Die normalste Einstellung ist das "Gruppe-/Promi-Konto".
|
||||||
|
Diese erstellt eine Gruppenseite, in der alle Mitglieder frei miteinander interagieren können.
|
||||||
|
|
||||||
|
Der "Automatische Freunde Seite"-Account ist typischerweise für persönliche Profile, bei denen Du alle Freundschaftsanfragen automatisch bestätigen willst.
|
||||||
|
|
||||||
|
|
||||||
|
**Multiple Gruppen verwalten**
|
||||||
|
|
||||||
|
Wir schlagen vor, dass Du eine Gruppe mit der gleichen Email-Adresse und dem gleichen Passwort wie bei Deinem normalen Account nutzt.
|
||||||
|
Wenn Du das machst, findest Du einen neuen "Verwalten"-Link in der Menüleiste, über den Du einfach zwischen den Identitäten wechseln kannst.
|
||||||
|
Du musst das nicht machen, die Alternative ist allerdings, Dich immer wieder aus- und wieder einzuloggen.
|
||||||
|
Und das kann umständlich sein, wenn Du mehrere verschiedene Gruppen/Identitäten verwaltest.
|
||||||
|
|
||||||
|
Du kannst ebenso jemanden wählen, der Deine Gruppe verwaltet.
|
||||||
|
Mach das, indem Du die [Delegations-Setup-Seite](/settings/delegation) besuchst.
|
||||||
|
Dort wird Dir eine Liste an "Potentiellen Bevollmächtigen" angezeigt.
|
||||||
|
Die Auswahl einer oder mehrerer Personen gibt diesen die Möglichkeit, Deine Gruppe zu verwalten.
|
||||||
|
Sie können Kontakte, Profile und alle Inhalte Deines Accounts/deiner Seite bearbeiten.
|
||||||
|
Bitte nutze diese Einstellung mit Vorsicht.
|
||||||
|
Delegierte haben allerdings keine Möglichkeit, grundlegende Account-Einstellungen wie das Passwort oder den Seitentypen zu ändern bzw. den Account zu löschen.
|
||||||
|
|
||||||
|
|
||||||
|
**Beiträge auf Community-Gruppen**
|
||||||
|
|
||||||
|
Wenn Du Mitglied einer Community-Gruppen bist, kannst Du die Gruppe in einem Beitrag hinzufügen/erwähnen, wenn Du die @-Erwähnung nutzt.
|
||||||
|
Zum Beispiel würde @Fahrrad Deinen Beitrag neben den sonst ausgewählten Nutzern an alle Nutzer schicken, die in der Gruppe "Fahrrad" sind.
|
||||||
|
Wenn Dein Beitrag privat ist, musst Du diese Gruppe explizit in den Zugriffsrechten des Beitrags auswählen **und** sie mit der @-Erwähnung ansprechen (was den Beitrag auf die Gruppenmitglieder erweitert).
|
||||||
|
|
||||||
|
Zusätzlich ist es möglich, Gruppen mit einem Ausrufezeichen zu adressieren.
|
||||||
|
Im obigen Beispiel bedeutet dies, dass Du das Fahrrad-Gruppe per !Fahrrad erreichen würdest.
|
||||||
|
Der Unterschied zum @ besteht darin, dass der Beitrag auschließlich über die Gruppe verbreitet wird und nicht an weitere Nutzer.
|
||||||
|
Dies bedeutet auch, dass es nicht sinnvoll ist, mehrere Gruppen per ! in einem Beitrag zu adressieren, da nur eine der Gruppen den Beitrag verbreiten wird.
|
||||||
|
|
||||||
|
Du kannst außerdem via "Wall zu Wall" einen Beitrag auf der Community-Seite bzw. in der Community-Gruppe erstellen.
|
||||||
|
|
||||||
|
Kommentare, die Du an eine Community-Gruppe schickst, werden dem Originalbeitrag hinzugefügt.
|
||||||
|
Eine weitere Gruppe mit dem @-Erwähnung anzusprechen, leitet den Beitrag nicht an dieses weiter, da die Verteilung der Kommentare komplett vom Originalbeitrag bestimmt wird.
|
|
@ -14,9 +14,10 @@ Friendica - Dokumentation und Ressourcen
|
||||||
* Du und andere Nutzer
|
* Du und andere Nutzer
|
||||||
* [Konnektoren (Connectors)](help/Connectors)
|
* [Konnektoren (Connectors)](help/Connectors)
|
||||||
* [Freunde finden](help/Making-Friends)
|
* [Freunde finden](help/Making-Friends)
|
||||||
* [Gruppen und Privatsphäre](help/Groups-and-Privacy)
|
* [Circles und Privatsphäre](help/Circles-and-Privacy)
|
||||||
* [Tags und Erwähnungen](help/Tags-and-Mentions)
|
* [Tags und Erwähnungen](help/Tags-and-Mentions)
|
||||||
* [Community-Foren](help/Forums)
|
* [Community-Gruppen](help/Groups)
|
||||||
|
* [Channels](help/Channels)
|
||||||
* [Chats](help/Chats)
|
* [Chats](help/Chats)
|
||||||
* Weiterführende Informationen
|
* Weiterführende Informationen
|
||||||
* [Account umziehen](help/Move-Account)
|
* [Account umziehen](help/Move-Account)
|
||||||
|
@ -63,7 +64,7 @@ Friendica - Dokumentation und Ressourcen
|
||||||
|
|
||||||
* [Haupt-Webseite](https://friendi.ca)
|
* [Haupt-Webseite](https://friendi.ca)
|
||||||
* Support Kanäle
|
* Support Kanäle
|
||||||
* Friendica Support Forum: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
* Friendica Support Gruppe: [@helpers@forum.friendi.ca](https://forum.friendi.ca/~helpers)
|
||||||
* [Mailing Listen Archiv](http://mailman.friendi.ca/mailman/listinfo/support-friendi.ca) zum Abonnieren der Liste eine E-Mail an ``support-request(at)friendi.ca?subject=subscribe`` senden
|
* [Mailing Listen Archiv](http://mailman.friendi.ca/mailman/listinfo/support-friendi.ca) zum Abonnieren der Liste eine E-Mail an ``support-request(at)friendi.ca?subject=subscribe`` senden
|
||||||
* Chats der Friendica Community (die IRC, Matrix und XMPP Räume sind mit einer Brücke verbunden) Logs dieser öffentlichen Chaträume können [hier aus dem IRC](https://gnusociarg.nsupdate.info/2021/%23frie) und [hier aus der Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/) gefunden werden.
|
* Chats der Friendica Community (die IRC, Matrix und XMPP Räume sind mit einer Brücke verbunden) Logs dieser öffentlichen Chaträume können [hier aus dem IRC](https://gnusociarg.nsupdate.info/2021/%23frie) und [hier aus der Matrix](https://view.matrix.org/alias/%23friendi.ca:matrix.org/) gefunden werden.
|
||||||
* XMPP/Jabber MUC: support(at)forum.friendi.ca
|
* XMPP/Jabber MUC: support(at)forum.friendi.ca
|
||||||
|
|
|
@ -12,7 +12,7 @@ Diese Funktionalität benötigt ein wenig mehr als die normalen Blogs.
|
||||||
Nicht jeder PHP/MySQL-Hosting-Anbieter kann Friendica unterstützen.
|
Nicht jeder PHP/MySQL-Hosting-Anbieter kann Friendica unterstützen.
|
||||||
Viele hingegen können es. Aber **bitte** prüfe die Voraussetzungen deines Servers vor der Installation.
|
Viele hingegen können es. Aber **bitte** prüfe die Voraussetzungen deines Servers vor der Installation.
|
||||||
|
|
||||||
Wenn dir Fehler während der Installation auffallen, sag uns bitte über [Helper](http://forum.friendi.ca/profile/helpers) oder das [Entwickler Forum](https://forum.friendi.ca/profile/developers) Bescheid oder [erstelle ein Issue](https://github.com/friendica/friendica/issues).
|
Wenn dir Fehler während der Installation auffallen, sag uns bitte über [Helper](http://forum.friendi.ca/profile/helpers) oder die [Entwickler Gruppe](https://forum.friendi.ca/profile/developers) Bescheid oder [erstelle ein Issue](https://github.com/friendica/friendica/issues).
|
||||||
Gib uns bitte so viele Infos zu deinem System, wie du kannst, und beschreibe den Fehler mit allen Details und Fehlermeldungen, so dass wir den Fehler zukünftig verhindern können.
|
Gib uns bitte so viele Infos zu deinem System, wie du kannst, und beschreibe den Fehler mit allen Details und Fehlermeldungen, so dass wir den Fehler zukünftig verhindern können.
|
||||||
Aufgrund der großen Anzahl an verschiedenen Betriebssystemen und PHP-Plattformen haben wir nur geringe Kapazitäten, um deine PHP-Installation zu debuggen oder fehlende Module zu ersetzen, aber wir tun unser Bestes, um allgemeine Code-Fehler zu beheben.
|
Aufgrund der großen Anzahl an verschiedenen Betriebssystemen und PHP-Plattformen haben wir nur geringe Kapazitäten, um deine PHP-Installation zu debuggen oder fehlende Module zu ersetzen, aber wir tun unser Bestes, um allgemeine Code-Fehler zu beheben.
|
||||||
|
|
||||||
|
@ -25,9 +25,9 @@ Requirements
|
||||||
---
|
---
|
||||||
|
|
||||||
* Apache mit einer aktiverten mod-rewrite-Funktion und dem Eintrag "Options All", so dass du die lokale .htaccess-Datei nutzen kannst
|
* Apache mit einer aktiverten mod-rewrite-Funktion und dem Eintrag "Options All", so dass du die lokale .htaccess-Datei nutzen kannst
|
||||||
* PHP 7.3+ (PHP 8 wird noch nicht komplett unterstützt)
|
* PHP 7.4+
|
||||||
* PHP *Kommandozeilen*-Zugang mit register_argc_argv auf "true" gesetzt in der php.ini-Datei
|
* PHP *Kommandozeilen*-Zugang mit register_argc_argv auf "true" gesetzt in der php.ini-Datei
|
||||||
* Curl, GD, GMP, PDO, MySQLi, xml, zip und OpenSSL-Erweiterung
|
* Curl, GD, GMP, PDO, mbstrings, MySQLi, hash, xml, zip, IntlChar and OpenSSL-Erweiterung
|
||||||
* Das POSIX Modul muss aktiviert sein ([CentOS, RHEL](http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7) haben dies z.B. deaktiviert)
|
* Das POSIX Modul muss aktiviert sein ([CentOS, RHEL](http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7http://www.bigsoft.co.uk/blog/index.php/2014/12/08/posix-php-commands-not-working-under-centos-7) haben dies z.B. deaktiviert)
|
||||||
* Einen E-Mail Server, so dass PHP `mail()` funktioniert.
|
* Einen E-Mail Server, so dass PHP `mail()` funktioniert.
|
||||||
Wenn kein eigener E-Mail Server zur Verfügung steht, kann alternativ das [phpmailer](https://github.com/friendica/friendica-addons/tree/develop/phpmailer) Addon mit einem externen SMTP Account verwendet werden.
|
Wenn kein eigener E-Mail Server zur Verfügung steht, kann alternativ das [phpmailer](https://github.com/friendica/friendica-addons/tree/develop/phpmailer) Addon mit einem externen SMTP Account verwendet werden.
|
||||||
|
|
|
@ -12,12 +12,12 @@ Das Verzeichnis ist in zwei Teile aufgeteilt.
|
||||||
Wenn du auf den "Verzeichnis"-Button klickst, wirst du zunächst alle Mitglieder deines Servers sehen, die sich dazu entschlossen haben, angezeigt zu werden.
|
Wenn du auf den "Verzeichnis"-Button klickst, wirst du zunächst alle Mitglieder deines Servers sehen, die sich dazu entschlossen haben, angezeigt zu werden.
|
||||||
Außerdem siehst du dort einen Link zum globalen Verzeichnis.
|
Außerdem siehst du dort einen Link zum globalen Verzeichnis.
|
||||||
Wenn du dich durch das globale Verzeichnis klickst, siehst du alle Nutzer weltweit auf allen Servern, die sich entschlossen haben, im Verzeichnis zu erscheinen.
|
Wenn du dich durch das globale Verzeichnis klickst, siehst du alle Nutzer weltweit auf allen Servern, die sich entschlossen haben, im Verzeichnis zu erscheinen.
|
||||||
Du wirst außerdem den Link "Show Community Forums" sehen, welcher dich zu Gruppen, Foren und Fan-Seiten führt.
|
Du wirst außerdem den Link "Show Community Groups" sehen, welcher dich zu Gruppen und Fan-Seiten führt.
|
||||||
Du verbindest dich mit Personen, Gruppen und Foren auf die gleiche Art, wobei Gruppen und Foren deine Anfrage automatisch annehmen, wohingegen ein Mensch dich erst manuell bestätigen muss.
|
Du verbindest dich mit Personen und Gruppen auf die gleiche Art, wobei Gruppen deine Anfrage automatisch annehmen, wohingegen ein Mensch dich erst manuell bestätigen muss.
|
||||||
|
|
||||||
*Mit anderen Friendica-Nutzern verbinden*
|
*Mit anderen Friendica-Nutzern verbinden*
|
||||||
|
|
||||||
Besuche ihr Profil.
|
Besuche ihr Profil.
|
||||||
Direkt unter dem Profilfoto ist das Wort "Verbinden" (bzw. "Connect" in einem englischsprachigem Profil).
|
Direkt unter dem Profilfoto ist das Wort "Verbinden" (bzw. "Connect" in einem englischsprachigem Profil).
|
||||||
Klicke drauf und du gelangst zur "Verbinden"-Seite.
|
Klicke drauf und du gelangst zur "Verbinden"-Seite.
|
||||||
Dort wirst du nach deiner Identitätsadresse gefragt.
|
Dort wirst du nach deiner Identitätsadresse gefragt.
|
||||||
|
|
|
@ -6,7 +6,7 @@ Gruppen und Seiten
|
||||||
Hier siehst Du das globale Verzeichnis.
|
Hier siehst Du das globale Verzeichnis.
|
||||||
Wenn Du Dich mal verirrt hast, kannst Du diesen Link klicken und wieder hierher kommen.
|
Wenn Du Dich mal verirrt hast, kannst Du diesen Link klicken und wieder hierher kommen.
|
||||||
|
|
||||||
Auf dieser Seite findest Du eine Zusammenstellung von Gruppen, Foren und Promi-Seiten.
|
Auf dieser Seite findest Du eine Zusammenstellung von Gruppen.
|
||||||
Gruppen sind keine realen Personen.
|
Gruppen sind keine realen Personen.
|
||||||
Sich mit diesen zu verbinden ist, als wenn man jemanden auf Facebook "liked" ("gefällt mir") oder wenn man sich in einem Forum anmeldet.
|
Sich mit diesen zu verbinden ist, als wenn man jemanden auf Facebook "liked" ("gefällt mir") oder wenn man sich in einem Forum anmeldet.
|
||||||
Du musst nicht unsicher sein, ob Du jemandem zu nahe trittst, wenn Du Dich so ohne weiteres mit einer Gruppe verbindest; es handelt sich eben nicht um reale Personen.
|
Du musst nicht unsicher sein, ob Du jemandem zu nahe trittst, wenn Du Dich so ohne weiteres mit einer Gruppe verbindest; es handelt sich eben nicht um reale Personen.
|
||||||
|
@ -21,6 +21,6 @@ Solltest Du beim Stöbern durch die vielen Gruppen nicht wieder hierher zurück
|
||||||
|
|
||||||
Wenn Du einige Gruppen hinzugefügt hast, gehe <a href="help/Quick-Start-andfinally">weiter zum nächsten Schritt</a>.
|
Wenn Du einige Gruppen hinzugefügt hast, gehe <a href="help/Quick-Start-andfinally">weiter zum nächsten Schritt</a>.
|
||||||
|
|
||||||
<iframe src="https://dir.friendica.social/forum" width="950" height="600"></iframe>
|
<iframe src="https://dir.friendica.social/group" width="950" height="600"></iframe>
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ Diese Maßnahme dient dazu, Spam zu vermeiden.
|
||||||
"Fernerwähnungen" werden durch das OStatus-Protokoll übermittelt.
|
"Fernerwähnungen" werden durch das OStatus-Protokoll übermittelt.
|
||||||
Dieses Protokoll wird von Friendica, GNU Social und anderen Systemen genutzt, ist allerdings derzeit nicht in Diaspora eingebaut.
|
Dieses Protokoll wird von Friendica, GNU Social und anderen Systemen genutzt, ist allerdings derzeit nicht in Diaspora eingebaut.
|
||||||
|
|
||||||
Friendica unterscheidet bei Tags nicht zwischen Personen und Gruppen (einige andere Netzwerke nutzen "!gruppe", um solche zu markieren).
|
Friendica unterscheidet bei Tags nicht zwischen Personen und Gruppen (einige andere Netzwerke nutzen "!circle", um solche zu markieren).
|
||||||
|
|
||||||
|
|
||||||
**Thematische Tags**
|
**Thematische Tags**
|
||||||
|
|
|
@ -1,26 +0,0 @@
|
||||||
Gruppen und Seiten
|
|
||||||
==========
|
|
||||||
|
|
||||||
* [Zur Startseite der Hilfe](help)
|
|
||||||
|
|
||||||
Hier siehst du das globale Verzeichnis.
|
|
||||||
Wenn du dich mal verirrt hast, kannst du <a href = "help/groupsandpages">diesen Link klicken</a> und wieder hierher kommen.
|
|
||||||
|
|
||||||
Auf dieser Seite findest du eine Zusammenstellung von Gruppen, Foren und bekannten Seiten.
|
|
||||||
Gruppen sind keine realen Personen.
|
|
||||||
Sich mit diesen zu verbinden ist, als wenn man jemanden auf Facebook "liked" ("gefällt mir") oder wenn man sich in einem Forum anmeldet.
|
|
||||||
Habe keine Sorge, falls du dich unbehaglich fühlst, wenn du dich einer neuen Person vorstellen sollst, da es sich nicht um Personen handelt.
|
|
||||||
|
|
||||||
Wenn du dich mit einer Gruppe verbindest, erscheinen alle Nachrichten der Gruppe in deinem "Netzwerk"-Tab.
|
|
||||||
Du kannst diese Beiträge kommentieren oder selbst in der Gruppe schreiben, ohne eine der Gruppenmitglieder persönlich hinzuzufügen.
|
|
||||||
Das ist ein großartiger Weg, dynamisch neue Freunde zu gewinnen.
|
|
||||||
Du findest Personen, die du magst, anstatt Fremde hinzuzufügen.
|
|
||||||
Suche dir einfach eine Gruppe und füge sie so hinzu, wie du auch normale Freunde hinzufügst.
|
|
||||||
Es gibt eine Menge Gruppen und möglicherweise findest du nicht wieder zu dieser Seite zurück.
|
|
||||||
In diesem Fall nutze einfach den Link oben auf dieser Seite.
|
|
||||||
|
|
||||||
Wenn du einige Gruppen hinzugefügt hast, gehe <a href="help/andfinally">weiter zum nächsten Schritt</a>.
|
|
||||||
|
|
||||||
<iframe src="https://dir.friendica.social/home" width="950" height="600"></iframe>
|
|
||||||
|
|
||||||
|
|
151
doc/themes.md
|
@ -2,153 +2,10 @@
|
||||||
|
|
||||||
* [Home](help)
|
* [Home](help)
|
||||||
|
|
||||||
To change the look of friendica you have to touch the themes.
|
The default Theme in Friendica is called [frio](https://github.com/friendica/friendica/tree/stable/view/theme/frio).
|
||||||
The current default theme is [Vier](https://github.com/friendica/friendica/tree/stable/view/theme/vier) but there are numerous others.
|
|
||||||
Have a look at [github.com/bkil/friendica-themes](https://github.com/bkil/friendica-themes) for an overview of the existing themes.
|
|
||||||
In case none of them suits your needs, there are several ways to change a theme.
|
|
||||||
|
|
||||||
So, how to work on the UI of friendica.
|
Open `Settings > Display > Custom Theme Settings` adjust the Theme to your liking. Select your preferred Appearance - light, dark or black - and your favorite Accent color. Click `Submit` to save your changes.
|
||||||
|
|
||||||
You can either directly edit an existing theme.
|
The `Custom` Appearance allows to tweak the themes CSS and set colors for UI elements. So called `schemestrings` can be shared between users.
|
||||||
But you might loose your changes when the theme is updated by the friendica team.
|
|
||||||
|
|
||||||
If you are almost happy with an existing theme, the easiest way to cover your needs is to create a new theme, inheriting most of the properties of the parent theme and change just minor stuff.
|
In the `General Theme Settings` you can also find the [vier](https://github.com/friendica/friendica/tree/stable/view/theme/vier) Theme, which precedes frio and is no longer officially maintained.
|
||||||
The below for a more detailed description of theme heritage.
|
|
||||||
|
|
||||||
Some themes also allow users to select *variants* of the theme.
|
|
||||||
Those theme variants most often contain an additional [CSS](https://en.wikipedia.org/wiki/CSS) file to override some styling of the default theme values.
|
|
||||||
From the themes in the main repository *vier* and *vier* are using this methods for variations.
|
|
||||||
Quattro is using a slightly different approach.
|
|
||||||
|
|
||||||
Third you can start your theme from scratch.
|
|
||||||
Which is the most complex way to change friendicas look.
|
|
||||||
But it leaves you the most freedom.
|
|
||||||
So below for a *detailed* description and the meaning of some special files.
|
|
||||||
|
|
||||||
### Styling
|
|
||||||
|
|
||||||
If you want to change the styling of a theme, have a look at the themes CSS file.
|
|
||||||
In most cases, you can found these in
|
|
||||||
|
|
||||||
/view/theme/**your-theme-name**/style.css
|
|
||||||
|
|
||||||
sometimes, there is also a file called style.php in the theme directory.
|
|
||||||
This is only needed if the theme allows the user to change certain things of the theme dynamically.
|
|
||||||
Say the font size or set a background image.
|
|
||||||
|
|
||||||
### Templates
|
|
||||||
|
|
||||||
If you want to change the structure of the theme, you need to change the templates used by the theme.
|
|
||||||
Friendica themes are using [SMARTY3](http://www.smarty.net/) for templating.
|
|
||||||
The default template can be found in
|
|
||||||
|
|
||||||
/view/templates
|
|
||||||
|
|
||||||
if you want to override any template within your theme create your version of the template in
|
|
||||||
|
|
||||||
/view/theme/**your-theme-name**/templates
|
|
||||||
|
|
||||||
any template that exists there will be used instead of the default one.
|
|
||||||
|
|
||||||
### JavaScript
|
|
||||||
|
|
||||||
The same rule applies to the JavaScript files found in
|
|
||||||
|
|
||||||
/js
|
|
||||||
|
|
||||||
they will be overwritten by files in
|
|
||||||
|
|
||||||
/view/theme/**your-theme-name**/js.
|
|
||||||
|
|
||||||
## Creating a Theme from Scratch
|
|
||||||
|
|
||||||
Keep patient.
|
|
||||||
Basically what you have to do is identify which template you have to change so it looks more like what you want.
|
|
||||||
Adopt the CSS of the theme accordingly.
|
|
||||||
And iterate the process until you have the theme the way you want it.
|
|
||||||
|
|
||||||
*Use the source Luke.* and don't hesitate to ask in @[developers](https://forum.friendi.ca/profile/developers) or @[helpers](https://forum.friendi.ca/profile/helpers).
|
|
||||||
|
|
||||||
## Special Files
|
|
||||||
|
|
||||||
### unsupported
|
|
||||||
|
|
||||||
If a file with this name (which might be empty) exists in the theme directory, the theme is marked as *unsupported*.
|
|
||||||
An unsupported theme may not be selected by a user in the settings.
|
|
||||||
Users who are already using it wont notice anything.
|
|
||||||
|
|
||||||
### README(.md)
|
|
||||||
|
|
||||||
The contents of this file, with or without the .md which indicates [Markdown](https://daringfireball.net/projects/markdown/) syntax, will be displayed at most repository hosting services and in the theme page within the admin panel of friendica.
|
|
||||||
|
|
||||||
This file should contain information you want to let others know about your theme.
|
|
||||||
|
|
||||||
### screenshot.[png|jpg]
|
|
||||||
|
|
||||||
If you want to have a preview image of your theme displayed in the settings you should take a screenshot and save it with this name.
|
|
||||||
Supported formats are PNG and JPEG.
|
|
||||||
|
|
||||||
### theme.php
|
|
||||||
|
|
||||||
This is the main definition file of the theme.
|
|
||||||
In the header of that file, some meta information is stored.
|
|
||||||
For example, have a look at the theme.php of the *vier* theme:
|
|
||||||
|
|
||||||
<?php
|
|
||||||
/**
|
|
||||||
* [Licence]
|
|
||||||
*
|
|
||||||
* Name: Vier
|
|
||||||
* Version: 1.2
|
|
||||||
* Author: Fabio <http://kirgroup.com/profile/fabrixxm>
|
|
||||||
* Author: Ike <http://pirati.ca/profile/heluecht>
|
|
||||||
* Author: Beanow <https://fc.oscp.info/profile/beanow>
|
|
||||||
* Maintainer: Ike <http://pirati.ca/profile/heluecht>
|
|
||||||
* Description: "Vier" is a very compact and modern theme. It uses the font awesome font library: http://fortawesome.github.com/Font-Awesome/
|
|
||||||
*/
|
|
||||||
|
|
||||||
You see the definition of the theme's name, it's version and the initial author of the theme.
|
|
||||||
These three pieces of information should be listed.
|
|
||||||
If the original author is no longer working on the theme, but a maintainer has taken over, the maintainer should be listed as well.
|
|
||||||
The information from the theme header will be displayed in the admin panel.
|
|
||||||
|
|
||||||
The first thing in file is to import the `App` class from `\Friendica\` namespace.
|
|
||||||
|
|
||||||
use Friendica\App;
|
|
||||||
|
|
||||||
This will make our job a little easier, as we don't have to specify the full name every time we need to use the `App` class.
|
|
||||||
|
|
||||||
The next crucial part of the theme.php file is a definition of an init function.
|
|
||||||
The name of the function is <theme-name>_init.
|
|
||||||
So in the case of vier it is
|
|
||||||
|
|
||||||
function vier_init(App $a) {
|
|
||||||
$a->theme_info = array();
|
|
||||||
$a->set_template_engine('smarty3');
|
|
||||||
}
|
|
||||||
|
|
||||||
Here we have set the basic theme information, in this case they are empty.
|
|
||||||
But the array needs to be set.
|
|
||||||
And we have set the template engine that should be used by friendica for this theme.
|
|
||||||
At the moment you should use the *smarty3* engine.
|
|
||||||
There once was a friendica specific templating engine as well but that is not used anymore.
|
|
||||||
If you like to use another templating engine, please implement it.
|
|
||||||
|
|
||||||
If you want to add something to the HTML header of the theme, one way to do so is by adding it to the theme.php file.
|
|
||||||
To do so, add something alike
|
|
||||||
|
|
||||||
DI::page()['htmlhead'] .= <<< EOT
|
|
||||||
/* stuff you want to add to the header */
|
|
||||||
EOT;
|
|
||||||
|
|
||||||
So you can access the properties of this friendica session from the theme.php file as well.
|
|
||||||
|
|
||||||
### default.php
|
|
||||||
|
|
||||||
This file covers the structure of the underlying HTML layout.
|
|
||||||
The default file is in
|
|
||||||
|
|
||||||
/view/default.php
|
|
||||||
|
|
||||||
if you want to change it, say adding a 4th column for banners of your favourite FLOSS projects, place a new default.php file in your theme directory.
|
|
||||||
As with the theme.php file, you can use the properties of the $a variable with holds the friendica application to decide what content is displayed.
|
|
||||||
|
|
Before Width: | Height: | Size: 5.0 KiB After Width: | Height: | Size: 7.8 KiB |
Before Width: | Height: | Size: 598 B |
Before Width: | Height: | Size: 543 B After Width: | Height: | Size: 543 B |
Before Width: | Height: | Size: 852 B After Width: | Height: | Size: 852 B |
Before Width: | Height: | Size: 1.1 KiB After Width: | Height: | Size: 1.1 KiB |
Before Width: | Height: | Size: 2.3 KiB After Width: | Height: | Size: 2.3 KiB |
|
@ -1,6 +1,6 @@
|
||||||
|
|
||||||
IMAGES=add.png edit.png gear.png info.png menu.png \
|
IMAGES=add.png edit.png gear.png info.png menu.png \
|
||||||
notify_off.png star.png delete.png feed.png group.png \
|
notify_off.png star.png delete.png feed.png circle.png \
|
||||||
lock.png notice.png notify_on.png user.png link.png \
|
lock.png notice.png notify_on.png user.png link.png \
|
||||||
play.png plugin.png unlock.png zip.png audio.png video.png \
|
play.png plugin.png unlock.png zip.png audio.png video.png \
|
||||||
image.png text.png
|
image.png text.png
|
||||||
|
|