snac.8 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582
  1. .Dd $Mdocdate$
  2. .Dt SNAC 8
  3. .Os
  4. .Sh NAME
  5. .Nm snac
  6. .Nd snac administration
  7. .Sh DESCRIPTION
  8. The
  9. .Nm
  10. daemon processes messages from other servers in the Fediverse
  11. using the ActivityPub protocol.
  12. .Pp
  13. This is the admin manual. For user operation, see
  14. .Xr snac 1 .
  15. For file and data formats, see
  16. .Xr snac 5 .
  17. .Ss Special cares about your snac you must know beforehand
  18. .Nm
  19. makes heavy use of hard links and link reference counts for its work, so
  20. don't even think of using it on a filesystem that doesn't support this
  21. feature. Most UNIX-like operating systems (Linux, the BSDs, the old DEC
  22. Ultrix machine in your grandfather basement, probably MacOS) support hard
  23. links on their native filesystems. Don't do fancy things like moving the
  24. subdirectories to different filesystems. Also, if you move your
  25. .Nm
  26. installation to another server, do it with a tool that respect hard
  27. link counts. Remember:
  28. .Nm
  29. is a very UNIXy program that loves hard links.
  30. .Ss Building and Installation
  31. A C compiler must be installed in the system, as well as the development
  32. headers and libraries for OpenSSL (or compatible) and curl. To build
  33. .Nm ,
  34. run
  35. .Bd -literal -offset indent
  36. make
  37. .Ed
  38. .Pp
  39. And, after that, run as root
  40. .Bd -literal -offset indent
  41. make install
  42. .Ed
  43. .Ss Data storage Initialization
  44. Once
  45. .Nm
  46. is properly installed on the system, designate a directory where
  47. the server and user data are to be stored. This directory
  48. must not exist yet.
  49. .Nm
  50. must always be run as a regular user; you can create one for
  51. it or use your own. To initialize the data storage, execute
  52. .Bd -literal -offset indent
  53. snac init $HOME/snac-data
  54. .Ed
  55. .Pp
  56. A small set of questions will be asked regarding the installation,
  57. specially the host name it will run under, the local network address
  58. and port
  59. .Nm
  60. will listen to, the optional path prefix and possibly other things.
  61. .Pp
  62. You can launch the
  63. .Nm
  64. process by running
  65. .Bd -literal -offset indent
  66. snac httpd $HOME/snac-data
  67. .Ed
  68. .Pp
  69. Use a web browser to connect to the specified address and port. You
  70. should see a greeting page.
  71. .Pp
  72. Log messages are sent to the standard error stream. By default, only
  73. relevant information is written there. You can increase the debugging
  74. level by editing the 'dbglevel' field in the
  75. .Pa server.json
  76. file or by setting a numeric value between 0 and 3 to the DEBUG
  77. environment variable, see below.
  78. .Pp
  79. If you operate a Linux systemd-enabled system, OpenBSD or FreeBSD, there are
  80. startup scripts and configuration data in the
  81. .Pa examples
  82. directory.
  83. For other operating systems, please read the appropriate documentation
  84. on how to install a daemon as a non-root service.
  85. .Ss Upgrading to a new version
  86. Sometimes, the data storage disk layout changes between versions. If there
  87. is such a change,
  88. .Nm
  89. will refuse to run and require an upgrade. Do this by running
  90. .Bd -literal -offset indent
  91. snac upgrade $HOME/snac-data
  92. .Ed
  93. .Pp
  94. Take special care to execute this upgrade operation without any
  95. .Nm
  96. processes serving on the same folder. You can break everything. I know
  97. this because Tyler knows this.
  98. .Pp
  99. .Ss Server Setup
  100. .Pp
  101. An http server with TLS and proxying support must already be
  102. installed and configured.
  103. .Nm
  104. runs as a daemon and listens on a TCP/IP socket, preferrably
  105. on a local interface. It can serve the full domain or only
  106. a directory. The http server must be configured to route to the
  107. .Nm
  108. socket all related traffic and also the webfinger standard
  109. address. The Host header must be propagated.
  110. See the examples below.
  111. .Ss Adding Users
  112. .Pp
  113. Users must be created from the command line.
  114. You can do it by running
  115. .Bd -literal -offset indent
  116. snac adduser $HOME/snac-data
  117. .Ed
  118. .Pp
  119. All needed data will be prompted for. There is no artificial limit
  120. on the number of users that can be created.
  121. .Ss Customization
  122. The
  123. .Pa server.json
  124. configuration file allows some behaviour tuning:
  125. .Bl -tag -width tenletters
  126. .It Ic host
  127. The host name.
  128. .It Ic prefix
  129. The URL path prefix.
  130. .It Ic address
  131. The listen network address.
  132. .It Ic port
  133. The listen network port.
  134. .It Ic dbglevel
  135. The debug level. An integer value, being 0 the less verbose (the default).
  136. .It Ic layout
  137. The disk storage layout version. Never touch this.
  138. .It Ic queue_retry_max
  139. Messages sent out are stored in a queue. If the posting of a messages fails,
  140. it's re-enqueued for later. This integer configures the maximum count of
  141. times the sending will be retried.
  142. .It Ic queue_retry_minutes
  143. The number of minutes to wait before the failed posting of a message is
  144. retried. This is not linear, but multipled by the number of retries
  145. already done.
  146. .It Ic queue_timeout
  147. The maximum number of seconds to wait when sending a message from the queue.
  148. .It Ic queue_timeout_2
  149. The maximum number of seconds to wait when sending a message from the queue
  150. to those servers that went timeout in the previous retry. If you want to
  151. give slow servers a chance to receive your messages, you can increase this
  152. value (but also take into account that processing the queue will take longer
  153. while waiting for these molasses to respond).
  154. .It Ic max_timeline_entries
  155. This is the maximum timeline entries shown in the web interface.
  156. .It Ic timeline_purge_days
  157. Entries in the timeline older that this number of days are purged.
  158. If you don't want any timeline purging and enjoy your data drives
  159. fill up with old crap and finally burst in flames, you can disable
  160. purging by setting this to 0.
  161. .It Ic local_purge_days
  162. Same as before, but for the user-generated entries in the local timeline.
  163. .It Ic cssurls
  164. This is a list of URLs to CSS files that will be inserted, in this order,
  165. in the HTML before the user CSS. Use these files to configure the global
  166. site layout.
  167. .It Ic disable_cache
  168. If set to true, timeline caching is not done. This is only useful for
  169. debugging purposes; don't enable it unless you know what do you want, as
  170. it makes everything slower.
  171. .It Ic disable_openbsd_security
  172. If running under OpenBSD,
  173. .Nm
  174. makes use of the enhanced security functions
  175. .Xr unveil 2
  176. and
  177. .Xr pledge 2 .
  178. Setting this to true disables their usage. These functions limit severely
  179. what an intruder can do in case of a security vulnerability, so only enable
  180. this option if something is very broken.
  181. .It Ic num_threads
  182. By setting this value, you can specify the exact number of threads
  183. .Nm
  184. will use when processing connections. Values lesser than 4 will be ignored.
  185. .It Ic disable_email_notifications
  186. By setting this to true, no email notification will be sent for any user.
  187. .It Ic disable_inbox_collection
  188. By setting this to true, no inbox collection is done. Inbox collection helps
  189. being discovered from remote instances, but also increases network traffic.
  190. .It Ic http_headers
  191. If you need to add more HTTP response headers for whatever reason, you can
  192. fill this object with the required header/value pairs. For example, for enhanced
  193. XSS security, you can set the "Content-Security-Policy" header to "script-src ;"
  194. to be totally sure that no JavaScript is executed.
  195. .It Ic show_instance_timeline
  196. If this is set to true, the instance base URL will show a timeline with the latest
  197. user posts instead of the default greeting static page. If other information
  198. fields are set (see below), they are also shown.
  199. .It Ic admin_email
  200. The email address of the instance administrator (optional).
  201. .It Ic admin_account
  202. The user name of the instance administrator (optional).
  203. .It Ic short_description
  204. A textual short description about the instance (optional).
  205. .It Ic fastcgi
  206. If set to true,
  207. .Nm
  208. will use the FastCGI interface to communicate with the upper level
  209. http server, that must be configured accordingly.
  210. .It Ic disable_history
  211. If set to true, history monthly snapshots are not served nor their links shown.
  212. .It Ic shared_inboxes
  213. This boolean value selects if shared inboxes are announced or not. Enabling
  214. shared inboxes helps (somewhat) in optimizing incoming traffic for instances
  215. with a large number of users.
  216. .It Ic min_account_age
  217. If this numeric value (in seconds) is set, any activity coming from an account
  218. that was created more recently than that will be rejected. This may be used
  219. to mitigate spam from automatically created accounts.
  220. .It Ic protocol
  221. This string value contains the protocol (schema) to be used in URLs. If not
  222. set, it defaults to "https". If you run
  223. .Nm
  224. as part of a hidden network like Tor or I2P that doesn't have a TLS /
  225. Certificate infrastructure, you need to set it to "http". Don't change it
  226. unless you know what you are doing.
  227. .El
  228. .Pp
  229. You must restart the server to make effective these changes.
  230. .Pp
  231. If a file named
  232. .Pa greeting.html
  233. is present in the server base directory, it will be returned whenever
  234. the base URL of the server is requested. Fill it with whatever
  235. information about the instance you want to supply to people
  236. visiting the server, like sign up requirements, site policies
  237. and such. The special %userlist% mark in the file will cause
  238. the list of users in this instance to be inserted.
  239. .Pp
  240. Users can change a bit of information about themselves from the
  241. web interface. See
  242. .Xr snac 1
  243. for details. Further, every user can have a private CSS file in their
  244. .Pa static/style.css
  245. that will be served instead of the server-wide one.
  246. It's not modifiable from the web interface to avoid users
  247. shooting themselves in the foot by destroying everything.
  248. .Ss Custom Emojis
  249. From version 2.51, support for customized Emojis in posts is available
  250. (previously, they were hardcoded). Emojis are read from the
  251. .Pa emojis.json
  252. file in the instance base directory, as a JSON object of key / value
  253. pairs (if this file does not exist, it will be created with
  254. the predefined set). Each key in the object contains the text to be found (e.g.,
  255. the :-) for a smiling face), and its associated value, the text string that
  256. will replace it (in this example case, the HTML entity for the Unicode codepoint
  257. for the smiley or the Emoji itself as text).
  258. .Pp
  259. Emoji values can also be URLs to image files; in this case, they will not be
  260. substituted in the post content, but added to the 'tag' array as an ActivityPub
  261. standard 'Emoji' object (it's recommendable that the Emoji key be enclosed in
  262. colons for maximum compatilibity with other ActivityPub implementations, like
  263. e.g. :happydoggo:). These images can be served from an external source or from the
  264. .Pa static
  265. directory of the instance admin.
  266. .Pp
  267. If you want to disable any Emoji substitution, change the file to contain
  268. just an empty JSON object ({}).
  269. .Ss SPAM Mitigation
  270. There have been some SPAM attacks on the Fediverse and, as too many
  271. instances and server implementations out there still allow automatic
  272. account creation, it will only get worse.
  273. .Nm
  274. includes some (not very strong) tools for trying to survive the SPAM
  275. flood that will eventually happen.
  276. .Pp
  277. The
  278. .Ic min_account_age
  279. field in the main configuration file allows setting a minimum age (in
  280. seconds) to consider too recently created accounts suspicious of being
  281. a potential source of SPAM. This is a naïve assumption, because spammers
  282. can create accounts, let them dormant for a while and then start to use
  283. them. Also, some ActivityPub implementations don't even bother to return
  284. a creation date for their accounts, so this is not very useful.
  285. .Pp
  286. From version 2.50, post content can be filtered out by regular expressions.
  287. These weapons of mass destruction can be written into the
  288. .Ic filter_reject.txt
  289. file in the server base directory, one per line; if this file exists,
  290. all posts' content will be matched (after being stripped of HTML tags)
  291. against these regexes, one by one, and any match will make the post to
  292. be rejected. If you don't know about regular expressions, don't use this
  293. option (or learn about them in some tutorial, there are gazillions of
  294. them out there), as you and your users may start missing posts. Also,
  295. given that every regular expression implementation supports a different
  296. set of features, consider reading the documentation about the one
  297. implemented in your system.
  298. .Ss ActivityPub Support
  299. These are the following activities and objects that
  300. .Nm
  301. supports:
  302. .Bl -tag -width tenletters
  303. .It Vt Follow
  304. Complete support, on input and output.
  305. .It Vt Undo
  306. For
  307. .Vt Follow
  308. objects, on input and output.
  309. .It Vt Create
  310. For
  311. .Vt Note ,
  312. .Vt Question
  313. and
  314. .Vt Page
  315. objects, on input and output.
  316. .It Vt Accept
  317. For
  318. .Vt Follow
  319. objects, on input and output.
  320. .It Vt Like
  321. For
  322. .Vt Note
  323. objects, on input and output.
  324. .It Vt Announce
  325. For
  326. .Vt Note
  327. objects, on input and output.
  328. .It Vt Update
  329. For
  330. .Vt Person ,
  331. .Vt Note
  332. and
  333. .Vt Question
  334. objects, on input and output.
  335. .It Vt Delete
  336. Supported for
  337. .Vt Note
  338. and
  339. .Vt Tomsbtone
  340. objects on input, and for
  341. .Vt Note
  342. objects on output.
  343. .El
  344. .Pp
  345. The rest of activities and objects are dropped on input.
  346. .Pp
  347. There is partial support for
  348. .Vt OrderedCollection
  349. objects in the
  350. .Pa /outbox
  351. (with the last 20 entries of the local timeline shown). No pagination
  352. is supported. Intentionally, the
  353. .Pa /followers
  354. and
  355. .Pa /following
  356. paths return empty lists.
  357. .Ss Migrating from Mastodon
  358. User migration from different Fediverse instances is a pain in the ass
  359. that has been implemented everywhere as a kludgy afterthought. There is
  360. not much that can be done, other than importing the list of people you
  361. follow to your new
  362. .Nm
  363. account.
  364. .Pp
  365. To do this, download the user's list of accounts being followed (in CSV
  366. format) from the Mastodon web interface and execute this:
  367. .Bd -literal -offset indent
  368. awk -F, 'NR > 1 { print $1 }' /path/to/following_accounts.csv | \\
  369. xargs -n 1 snac follow $SNAC_BASEDIR $SNAC_USER
  370. .Ed
  371. .Ss Instance blocking
  372. Full instances can be blocked. This operation must be done from
  373. the command-line tool. See
  374. .Xr snac 1 .
  375. .Ss Other Considerations
  376. .Nm
  377. stores all the messages it receives as JSON files, which are usually
  378. bloated and filled with redundant information. Using a filesystem with
  379. file compression enabled (like btrfs or zfs) will probably be a good
  380. choice to store the
  381. .Nm
  382. data storage into.
  383. .Sh ENVIRONMENT
  384. .Bl -tag -width Ds
  385. .It Ev DEBUG
  386. Overrides the debugging level from the server 'dbglevel' configuration
  387. variable. Set it to an integer value. The higher, the deeper in meaningless
  388. verbiage you'll find yourself into.
  389. .El
  390. .Sh EXAMPLES
  391. You want to install the
  392. .Nm
  393. Fediverse daemon in the host example.com, that is correctly configured
  394. with a valid TLS certificate and running the nginx httpd server.
  395. The service will be installed under the
  396. .Pa fedi
  397. location. Two users, walter and jessie, will be hosted in the system.
  398. Their Fediverse presence addresses will be
  399. .Lk https://example.com/fedi/walter
  400. and
  401. .Lk https://example.com/fedi/jesse ,
  402. respectively. They will be known
  403. in the Fediverse as @walter@example.com and @jesse@example.com. The
  404. .Nm
  405. daemon will run as the user snacusr in the system and listen to the
  406. localhost:8001 network socket. All data will be stored in the
  407. .Pa /home/snacusr/fedidata
  408. directory.
  409. .Pp
  410. Log into the system as snacusr and execute:
  411. .Bd -literal -offset indent
  412. snac init /home/snacusr/fedidata
  413. .Ed
  414. .Pp
  415. Answer "example.com" to the host name question, "/fedi" to the path
  416. prefix question, "localhost" to the address and "8001" to the port.
  417. .Pp
  418. Create the users
  419. .Bd -literal -offset indent
  420. snac adduser /home/snacusr/fedidata walter
  421. snac adduser /home/snacusr/fedidata jesse
  422. .Ed
  423. .Pp
  424. Answer the questions with reasonable values.
  425. .Pp
  426. Execute the server:
  427. .Bd -literal -offset indent
  428. snac httpd /home/snacusr/fedidata
  429. .Ed
  430. .Pp
  431. Edit the nginx configuration and add the following snippet to the
  432. example.com server section:
  433. .Bd -literal -offset indent
  434. # nginx configuration example
  435. # main web access point
  436. location /fedi {
  437. proxy_pass http://localhost:8001;
  438. proxy_set_header Host $http_host;
  439. }
  440. # webfinger
  441. location /.well-known/webfinger {
  442. proxy_pass http://localhost:8001;
  443. proxy_set_header Host $http_host;
  444. }
  445. # Mastodon API (entry points)
  446. location /api/v1/ {
  447. proxy_pass http://localhost:8001;
  448. proxy_set_header Host $http_host;
  449. }
  450. location /api/v2/ {
  451. proxy_pass http://localhost:8001;
  452. proxy_set_header Host $http_host;
  453. }
  454. # Mastodon API (OAuth support)
  455. location /oauth {
  456. proxy_pass http://localhost:8001;
  457. proxy_set_header Host $http_host;
  458. }
  459. # optional
  460. location /.well-known/nodeinfo {
  461. proxy_pass http://localhost:8001;
  462. proxy_set_header Host $http_host;
  463. }
  464. # optional (needed by some Mastodon API clients)
  465. location /.well-known/host-meta {
  466. proxy_pass http://localhost:8001;
  467. proxy_set_header Host $http_host;
  468. }
  469. .Ed
  470. .Pp
  471. Restart the nginx daemon and connect to
  472. .Lk https://example.com/fedi/walter .
  473. The empty, default screen will be shown. Enter the admin section with the
  474. credentials defined for this user. Search people, start following
  475. them, engage in arid discussions and generally enjoy the frustrating
  476. experience of Social Media.
  477. .Pp
  478. This is an example of a similar configuration for the Apache2 web server:
  479. .Bd -literal -offset indent
  480. # apache2 configuration example
  481. ProxyPreserveHost On
  482. # Main web access point
  483. <Location /fedi>
  484. ProxyPass http://127.0.0.1:8001/social
  485. </Location>
  486. # WebFinger
  487. <Location /.well-known/webfinger>
  488. ProxyPass http://127.0.0.1:8001/.well-known/webfinger
  489. </Location>
  490. # Mastodon API (entry points)
  491. <Location /api/v1/>
  492. ProxyPass http://127.0.0.1:8001/api/v1/
  493. </Location>
  494. <Location /api/v2/>
  495. ProxyPass http://127.0.0.1:8001/api/v2/
  496. </Location>
  497. # Mastodon API (OAuth support)
  498. <Location /oauth>
  499. ProxyPass http://127.0.0.1:8001/oauth
  500. </Location>
  501. # NodeInfo (optional)
  502. <Location /.well-known/nodeinfo>
  503. ProxyPass http://127.0.0.1:8001/.well-known/nodeinfo
  504. </Location>
  505. # host-meta (optional, needed for some Mastodon API clients)
  506. <Location /.well-known/host-meta>
  507. ProxyPass http://127.0.0.1:8001/.well-known/host-meta
  508. </Location>
  509. .Ed
  510. .Pp
  511. Since version 2.43,
  512. .Nm
  513. supports communicating from / to the front end http server using the FastCGI
  514. protocol. There is no special advantage in using this, only that some servers
  515. allow for simpler configuration. For example, in the case of nginx, you can
  516. replace the two 'proxy_pass' and 'proxy_set_header' lines in the example
  517. above with just
  518. .Bd -literal -offset indent
  519. fastcgi_pass localhost:8001;
  520. .Ed
  521. .Pp
  522. The only thing to change on
  523. .Nm
  524. size is to the set 'fastcgi' value to true in
  525. .Pa server.json .
  526. .Pp
  527. Further, using the FastCGI interface allows a much simpler configuration
  528. under OpenBSD's native httpd, given that it's natively implemented there
  529. and you no longer need to configure the complicated relayd server. This is
  530. an example:
  531. .Bd -literal -offset indent
  532. # OpenBSD httpd configuration example
  533. # other server configuration
  534. [...]
  535. location "/fedi/*" {
  536. fastcgi socket tcp "127.0.0.1" 8001
  537. }
  538. location "/.well-known/webfinger" {
  539. fastcgi socket tcp "127.0.0.1" 8001
  540. }
  541. location "/oauth/*" {
  542. fastcgi socket tcp "127.0.0.1" 8001
  543. }
  544. location "/api/v1/*" {
  545. fastcgi socket tcp "127.0.0.1" 8001
  546. }
  547. location "/api/v2/*" {
  548. fastcgi socket tcp "127.0.0.1" 8001
  549. }
  550. location "/.well-known/nodeinfo" {
  551. fastcgi socket tcp "127.0.0.1" 8001
  552. }
  553. location "/.well-known/host-meta" {
  554. fastcgi socket tcp "127.0.0.1" 8001
  555. }
  556. .Ed
  557. .Sh SEE ALSO
  558. .Xr snac 1 ,
  559. .Xr snac 5
  560. .Sh AUTHORS
  561. .An grunfink Lk https://comam.es/snac/grunfink @grunfink@comam.es
  562. .Sh LICENSE
  563. See the LICENSE file for details.
  564. .Sh CAVEATS
  565. JSON files are fragile when modified by hand. Take care.