snac.8 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885
  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 keeps hard
  27. links, like
  28. .Xr tar 1
  29. or
  30. .Xr rsync 1
  31. with the -H switch. Remember:
  32. .Nm
  33. is a very UNIXy program that loves hard links.
  34. .Ss Building and Installation
  35. A C compiler must be installed in the system, as well as the development
  36. headers and libraries for OpenSSL (or compatible) and curl. To build
  37. .Nm ,
  38. run
  39. .Bd -literal -offset indent
  40. make
  41. .Ed
  42. .Pp
  43. And, after that, run as root
  44. .Bd -literal -offset indent
  45. make install
  46. .Ed
  47. .Ss Data storage Initialization
  48. Once
  49. .Nm
  50. is properly installed on the system, designate a directory where
  51. the server and user data are to be stored. This directory
  52. must not exist yet.
  53. .Nm
  54. must always be run as a regular user; you can create one for
  55. it or use your own. To initialize the data storage, execute
  56. .Bd -literal -offset indent
  57. snac init $HOME/snac-data
  58. .Ed
  59. .Pp
  60. A small set of questions will be asked regarding the installation,
  61. specially the host name it will run under, the local network address
  62. and port
  63. .Nm
  64. will listen to, the optional path prefix and possibly other things.
  65. .Pp
  66. Since version 2.57, if the 'network address' starts with /, it's
  67. assumed to be a UNIX-like socket (please take note that the http proxy
  68. must have full read and write access to this socket; this is a common
  69. pitfall. Permissions will break your heart).
  70. .Pp
  71. You can launch the
  72. .Nm
  73. process by running
  74. .Bd -literal -offset indent
  75. snac httpd $HOME/snac-data
  76. .Ed
  77. .Pp
  78. Log messages are sent to the standard error stream. By default, only
  79. relevant information is written there. You can increase the debugging
  80. level by editing the 'dbglevel' field in the
  81. .Pa server.json
  82. file or by setting a numeric value between 0 and 3 to the DEBUG
  83. environment variable, see below.
  84. .Pp
  85. If you operate a Linux systemd-enabled system, OpenBSD, FreeBSD or NetBSD, there are
  86. startup scripts and configuration data in the
  87. .Pa examples
  88. directory.
  89. For other operating systems, please read the appropriate documentation
  90. on how to install a daemon as a non-root service.
  91. .Ss Upgrading to a new version
  92. Sometimes, the data storage disk layout changes between versions. If there
  93. is such a change,
  94. .Nm
  95. will refuse to run and require an upgrade. Do this by running
  96. .Bd -literal -offset indent
  97. snac upgrade $HOME/snac-data
  98. .Ed
  99. .Pp
  100. Take special care to execute this upgrade operation without any
  101. .Nm
  102. processes serving on the same folder. You can break everything. I know
  103. this because Tyler knows this.
  104. .Pp
  105. .Ss Server Setup
  106. .Pp
  107. An http server with TLS and proxying support must already be
  108. installed and configured.
  109. .Nm
  110. runs as a daemon and listens on a TCP/IP socket, preferably
  111. on a local interface. It can serve the full domain or only
  112. a directory. The http server must be configured to route to the
  113. .Nm
  114. socket all related traffic and also the webfinger standard
  115. address. The Host header must be propagated.
  116. See the examples below.
  117. .Ss Adding Users
  118. .Pp
  119. Users must be created from the command line.
  120. You can do it by running
  121. .Bd -literal -offset indent
  122. snac adduser $HOME/snac-data
  123. .Ed
  124. .Pp
  125. All needed data will be prompted for. There is no artificial limit
  126. on the number of users that can be created.
  127. .Ss Customization
  128. The
  129. .Pa server.json
  130. configuration file allows some behaviour tuning:
  131. .Bl -tag -width tenletters
  132. .It Ic host
  133. The host name.
  134. .It Ic prefix
  135. The URL path prefix.
  136. .It Ic address
  137. The listen network address. If it starts with /, it's assumed to be
  138. a UNIX-like socket instead.
  139. .It Ic port
  140. The listen network port (unused if address is a UNIX socket).
  141. .It Ic dbglevel
  142. The debug level. An integer value, being 0 the less verbose (the default).
  143. .It Ic layout
  144. The disk storage layout version. Never touch this.
  145. .It Ic queue_retry_max
  146. Messages sent out are stored in a queue. If the posting of a messages fails,
  147. it's re-enqueued for later. This integer configures the maximum count of
  148. times the sending will be retried.
  149. .It Ic queue_retry_minutes
  150. The number of minutes to wait before the failed posting of a message is
  151. retried. This is not linear, but multiplied by the number of retries
  152. already done.
  153. .It Ic queue_timeout
  154. The maximum number of seconds to wait when sending a message from the queue.
  155. .It Ic queue_timeout_2
  156. The maximum number of seconds to wait when sending a message from the queue
  157. to those servers that went timeout in the previous retry. If you want to
  158. give slow servers a chance to receive your messages, you can increase this
  159. value (but also take into account that processing the queue will take longer
  160. while waiting for these molasses to respond).
  161. .It Ic def_timeline_entries
  162. This is the default timeline entries shown in the web interface.
  163. .It Ic max_timeline_entries
  164. This is the maximum timeline entries shown in the web interface.
  165. .It Ic timeline_purge_days
  166. Entries in the timeline older that this number of days are purged.
  167. If you don't want any timeline purging and enjoy your data drives
  168. fill up with old crap and finally burst in flames, you can disable
  169. purging by setting this to 0.
  170. .It Ic local_purge_days
  171. Same as before, but for the user-generated entries in the local timeline.
  172. .It Ic cssurls
  173. This is a list of URLs to CSS files that will be inserted, in this order,
  174. in the HTML before the user CSS. Use these files to configure the global
  175. site layout.
  176. .It Ic disable_cache
  177. If set to true, timeline caching is not done. This is only useful for
  178. debugging purposes; don't enable it unless you know what do you want, as
  179. it makes everything slower.
  180. .It Ic disable_openbsd_security
  181. If running under OpenBSD,
  182. .Nm
  183. makes use of the enhanced security functions
  184. .Xr unveil 2
  185. and
  186. .Xr pledge 2 .
  187. Setting this to true disables their usage. These functions limit severely
  188. what an intruder can do in case of a security vulnerability, so only enable
  189. this option if something is very broken.
  190. .It Ic num_threads
  191. By setting this value, you can specify the exact number of threads
  192. .Nm
  193. will use when processing connections. Values lesser than 4 will be ignored.
  194. .It Ic disable_email_notifications
  195. By setting this to true, no email notification will be sent for any user.
  196. .It Ic disable_inbox_collection
  197. By setting this to true, no inbox collection is done. Inbox collection helps
  198. being discovered from remote instances, but also increases network traffic.
  199. .It Ic http_headers
  200. If you need to add more HTTP response headers for whatever reason, you can
  201. fill this object with the required header/value pairs.
  202. .It Ic show_instance_timeline
  203. If this is set to true, the instance base URL will show a timeline with the latest
  204. user posts instead of the default greeting static page. If other information
  205. fields are set (see below), they are also shown.
  206. .It Ic admin_email
  207. The email address of the instance administrator (optional).
  208. .It Ic admin_account
  209. The user name of the instance administrator (optional).
  210. .It Ic short_description
  211. A textual short description about the instance (optional).
  212. .It Ic short_description_raw
  213. Whether to interpret short_descript as raw string or convert to HTML (optional).
  214. .It Ic fastcgi
  215. If set to true,
  216. .Nm
  217. will use the FastCGI interface to communicate with the upper level
  218. http server, that must be configured accordingly.
  219. .It Ic disable_history
  220. If set to true, history monthly snapshots are not served nor their links shown.
  221. .It Ic shared_inboxes
  222. This boolean value selects if shared inboxes are announced or not. Enabling
  223. shared inboxes helps (somewhat) in optimizing incoming traffic for instances
  224. with a large number of users.
  225. .It Ic min_account_age
  226. If this numeric value (in seconds) is set, any activity coming from an account
  227. that was created more recently than that will be rejected. This may be used
  228. to mitigate spam from automatically created accounts.
  229. .It Ic protocol
  230. This string value contains the protocol (schema) to be used in URLs. If not
  231. set, it defaults to "https". If you run
  232. .Nm
  233. as part of a hidden network like Tor or I2P that doesn't have a TLS /
  234. Certificate infrastructure, you need to set it to "http". Don't change it
  235. unless you know what you are doing.
  236. .It Ic hide_delete_post_button
  237. If set to true, the button to delete a post is not shown. It's not very
  238. useful and somewhat clutters the already crowded button space.
  239. .It Ic disable_block_notifications
  240. If set to true, notifications about 'Block' activities are never sent.
  241. .It Ic strict_public_timelines
  242. If set to true, public timelines only show posts and boosts originating
  243. from an account (no conversation trees).
  244. .It Ic proxy_media
  245. If set to true, links to all image, audio or video media from other accounts'
  246. posts will not be direct ones, but proxied by
  247. .Nm .
  248. This way, remote media servers will not see the user's IP, but the server one,
  249. improving privacy. Please take note that this will increase the server's incoming
  250. and outgoing traffic.
  251. .It Ic badlogin_retries
  252. If incorrect logins from a given IP address reach this count, subsequent attempts
  253. from it are rejected until the lock expires (default: 5 retries).
  254. .It Ic badlogin_expire
  255. The number of seconds a blocked IP address is ignored in login attempts
  256. (default: 300 seconds).
  257. .It Ic disable_sandbox
  258. This boolean toggle allows disabling Linux Landlock sandboxing. Confining a
  259. program in a sandbox limits the directories and resources it can use, so it's
  260. recommended for security. Support for Linux sandboxing must be compiled in, and you
  261. need at least a Linux kernel version 5.13.0.
  262. .It Ic max_public_entries
  263. The maximum number of entries (posts) to be returned in user RSS feeds and outboxes
  264. (default: 20).
  265. .It Ic max_attachments
  266. The maximum number of attachments per post (default: 4).
  267. .It Ic enable_svg
  268. Since version 2.73, SVG image attachments are hidden by default; you can enable
  269. them by setting this value to true.
  270. .El
  271. .Pp
  272. You must restart the server to make effective these changes.
  273. .Pp
  274. If a file named
  275. .Pa greeting.html
  276. is present in the server base directory, it will be returned whenever
  277. the base URL of the server is requested. Fill it with whatever
  278. information about the instance you want to supply to people
  279. visiting the server, like sign up requirements, site policies
  280. and such. The special %userlist% mark in the file will cause
  281. the list of users in this instance to be inserted.
  282. .Pp
  283. Users can change a bit of information about themselves from the
  284. web interface. See
  285. .Xr snac 1
  286. for details. Further, every user can have a private CSS file in their
  287. .Pa static/style.css
  288. that will be served instead of the server-wide one.
  289. It's not modifiable from the web interface to avoid users
  290. shooting themselves in the foot by destroying everything.
  291. .Ss Custom Emojis
  292. From version 2.51, support for customized Emojis in posts is available
  293. (previously, they were hardcoded). Emojis are read from the
  294. .Pa emojis.json
  295. file in the instance base directory, as a JSON object of key / value
  296. pairs (if this file does not exist, it will be created with
  297. the predefined set). Each key in the object contains the text to be found (e.g.,
  298. the :-) for a smiling face), and its associated value, the text string that
  299. will replace it (in this example case, the HTML entity for the Unicode codepoint
  300. for the smiley or the Emoji itself as text).
  301. .Pp
  302. Emoji values can also be URLs to image files; in this case, they will not be
  303. substituted in the post content, but added to the 'tag' array as an ActivityPub
  304. standard 'Emoji' object (it's recommendable that the Emoji key be enclosed in
  305. colons for maximum compatilibity with other ActivityPub implementations, like
  306. e.g. :happydoggo:). These images can be served from an external source or from the
  307. .Pa static
  308. directory of the instance admin.
  309. .Pp
  310. If you want to disable any Emoji substitution, change the file to contain
  311. just an empty JSON object ({}).
  312. .Ss SPAM Mitigation
  313. There have been some SPAM attacks on the Fediverse and, as too many
  314. instances and server implementations out there still allow automatic
  315. account creation, it will only get worse.
  316. .Nm
  317. includes some (not very strong) tools for trying to survive the SPAM
  318. flood that will eventually happen.
  319. .Pp
  320. The
  321. .Ic min_account_age
  322. field in the main configuration file allows setting a minimum age (in
  323. seconds) to consider too recently created accounts suspicious of being
  324. a potential source of SPAM. This is a naïve assumption, because spammers
  325. can create accounts, let them dormant for a while and then start to use
  326. them. Also, some ActivityPub implementations don't even bother to return
  327. a creation date for their accounts, so this is not very useful.
  328. .Pp
  329. From version 2.50, post content can be filtered out by regular expressions.
  330. These weapons of mass destruction can be written into the
  331. .Ic filter_reject.txt
  332. file in the server base directory, one per line; if this file exists,
  333. all posts' content will be matched (after being stripped of HTML tags)
  334. against these regexes, one by one, and any match will make the post to
  335. be rejected. Use lower case, the regex will be case insensitive by default.
  336. If you don't know about regular expressions, don't use this
  337. option (or learn about them inw some tutorial, there are gazillions of
  338. them out there), as you and your users may start missing posts. Also,
  339. given that every regular expression implementation supports a different
  340. set of features, consider reading the documentation about the one
  341. implemented in your system.
  342. .Ss ActivityPub Support
  343. These are the following activities and objects that
  344. .Nm
  345. supports:
  346. .Bl -tag -width tenletters
  347. .It Vt Follow
  348. Complete support, on input and output.
  349. .It Vt Undo
  350. For
  351. .Vt Follow ,
  352. .Vt Like
  353. and
  354. .Vt Announce
  355. objects, on input and output.
  356. .It Vt Create
  357. For
  358. .Vt Note ,
  359. .Vt Question ,
  360. .Vt Page ,
  361. .Vt Article ,
  362. .Vt Event
  363. and
  364. .Vt Video
  365. objects on input, and for
  366. .Vt Note
  367. and
  368. .Vt Question
  369. on output.
  370. .It Vt Accept
  371. For
  372. .Vt Follow
  373. objects, on input and output.
  374. .It Vt Like
  375. For
  376. .Vt Note
  377. objects, on input and output.
  378. .It Vt EmojiReact
  379. For
  380. .Vt Note
  381. objects, on input.
  382. .It Vt Announce
  383. For
  384. .Vt Note
  385. objects, on input and output.
  386. .It Vt Update
  387. For
  388. .Vt Note ,
  389. .Vt Question ,
  390. .Vt Page ,
  391. .Vt Article ,
  392. .Vt Event
  393. and
  394. .Vt Video
  395. objects on input, and for
  396. .Vt Note
  397. on output.
  398. .It Vt Delete
  399. Supported for
  400. .Vt Note
  401. and
  402. .Vt Tomsbtone
  403. objects on input, and for
  404. .Vt Note
  405. objects on output.
  406. .It Vt Move
  407. For actor-like objects, for input and output.
  408. .El
  409. .Pp
  410. The rest of activities and objects are dropped on input.
  411. .Pp
  412. There is partial support for
  413. .Vt OrderedCollection
  414. objects in the
  415. .Pa /outbox
  416. (with the last 20 entries of the local timeline shown). No pagination
  417. is supported. Intentionally, the
  418. .Pa /followers
  419. and
  420. .Pa /following
  421. paths return empty lists.
  422. .Ss Migrating from snac to Mastodon
  423. Since version 2.60, you can migrate your
  424. .Nm
  425. account to other ActivityPub instances. What is described here is the process to do it from
  426. .Nm
  427. to Mastodon; on other software implementations, it will surely be somewhat different. All
  428. the steps regarding your
  429. .Nm
  430. account must be done from the command line. For the sake of the example, let's
  431. say that you want to migrate from an account named @origin@snac.example.org to
  432. another one named @destination@mastodon.example.com and that both of them
  433. already exist. I've used this very informative page as a guideline:
  434. .Pp
  435. .Lk https://fedi.tips/transferring-your-mastodon-account-to-another-server/
  436. .Pp
  437. 1. On your
  438. .Nm
  439. server, first export your data to CSV by running:
  440. .Bd -literal -offset indent
  441. snac export_csv $SNAC_BASEDIR origin
  442. .Ed
  443. .Pp
  444. You'll find the following CSV files in the
  445. .Pa export/
  446. subdirectory inside the user directory:
  447. .Pa bookmarks.csv ,
  448. .Pa blocked_accounts.csv ,
  449. .Pa lists.csv , and
  450. .Pa following_accounts.csv .
  451. .Pp
  452. 2. In the web interface of your new Mastodon account, click on
  453. .Vt Preferences
  454. >
  455. .Vt Import and Export
  456. >
  457. .Vt Import
  458. and upload the CSV files one at a time. You must specify the type of
  459. file you are uploading.
  460. .Pp
  461. 3. Still in the web interface of your new Mastodon account, click on
  462. .Vt Preferences
  463. >
  464. .Vt Account
  465. >
  466. .Vt Moving From a Different Account ,
  467. then click on
  468. .Vt Create an account alias
  469. and follow the instructions. (When it asks you to
  470. write your old account’s handle, it needs to include the @ at the start
  471. as well as the @ in the middle; as of our example, @origin@snac.example.org).
  472. It seems this step is not performed immediately, you must wait an unspecified
  473. number of minutes for this to be effective.
  474. .Pp
  475. 4. Meanwhile, you must tell
  476. .Nm
  477. about your new account by creating an alias from your current one.
  478. So, on your
  479. .Nm
  480. server, run
  481. .Bd -literal -offset indent
  482. snac alias $SNAC_BASEDIR origin "@destination@mastodon.example.com"
  483. .Ed
  484. .Pp
  485. 5. Finally, you must order
  486. .Nm
  487. to start the migration process, that will consist in iterating all the
  488. people that follows your account and sending them a
  489. .Vt Move
  490. message, that acts as a suggestion to unfollow your old account
  491. and follow the new one. The command is
  492. .Bd -literal -offset indent
  493. snac migrate $SNAC_BASEDIR origin
  494. .Ed
  495. .Pp
  496. This process can be very long and unreliable; any destination server may be down,
  497. too busy, disconnected or gone. I recommend you to read the document I linked
  498. above to know about all the sorrows awaiting.
  499. .Pp
  500. Also, please take note that the
  501. .Nm
  502. account you migrated from is not disabled nor changed in any way, so can still
  503. use it as it no migration was done. This behaviour may or may not match what other
  504. ActivityPub implementations do.
  505. .Pp
  506. .Ss Migrating from Mastodon to snac
  507. Since version 2.61, you can migrate accounts on other ActivityPub instances to your
  508. .Nm
  509. one. What is described here is the process to do it from
  510. Mastodon; on other software implementations, it will surely be somewhat different. All
  511. the steps regarding your
  512. .Nm
  513. account must be done from the command line. For the sake of the example, let's
  514. say that you want to migrate from an account named @origin@mastodon.example.com to
  515. another one named @destination@snac.example.org and that both of them
  516. already exist. I've used this very informative page as a guideline:
  517. .Pp
  518. .Lk https://fedi.tips/transferring-your-mastodon-account-to-another-server/
  519. .Pp
  520. 1. On the web interface of your origin Mastodon account, click on
  521. .Vt Preferences
  522. >
  523. .Vt Import and Export
  524. >
  525. .Vt Export
  526. and download the CSV files under the "Follows", "Lists", "You Block" and "Bookmarks"
  527. labels. After being downloaded, you should find the following files on your download
  528. directory:
  529. .Pa bookmarks.csv ,
  530. .Pa blocked_accounts.csv ,
  531. .Pa lists.csv , and
  532. .Pa following_accounts.csv .
  533. .Pp
  534. 2. Copy all those files to the
  535. .Pa import/
  536. subdirectory of the user's directory inside the server base directory, and run
  537. .Bd -literal -offset indent
  538. snac import_csv $SNAC_BASEDIR destination
  539. .Ed
  540. .Pp
  541. This process may take some time because it depends on the availability / responsiveness
  542. of all the ActivityPub servers involved (webfinger, accounts, posts, etc.). Some errors
  543. may be transient and retried later. Also, if
  544. .Nm
  545. complains that it can't find any of these files, please check that they are really
  546. stored in the
  547. .Pa import/
  548. subdirectory and that their names match exactly. Some of them may be
  549. empty (for example, if you didn't create any list) and that's fine.
  550. .Pp
  551. 3. Again on your
  552. .Nm
  553. server, run
  554. .Bd -literal -offset indent
  555. snac alias $SNAC_BASEDIR destination "@origin@mastodon.example.com"
  556. .Ed
  557. .Pp
  558. Check that no errors were shown. If they do, the origin Mastodon server may be
  559. busy or down; try again later.
  560. .Pp
  561. 4. Move back to the web interface of the origin Mastodon account, go to
  562. .Vt Preferences
  563. >
  564. .Vt Account
  565. >
  566. .Vt Move To A Different Account ,
  567. and follow the instructions there. Set the handle of the new account to your
  568. .Nm
  569. one; as of our example, @destination@snac.example.org. This will start the migration
  570. process: it's the duty of your old Mastodon instance to send an automatic
  571. .Vt Move
  572. message to every one of your followers. Eventually, you will start receiving follow notifications to your
  573. .Nm
  574. account from all accounts that followed the Mastodon one. According to the great document
  575. I linked above, this process may or may not start immediately, and its success may depend
  576. heavily on how all the servers involved behave. Just cross your fingers and hope for the best.
  577. .Pp
  578. .Ss Instance blocking
  579. Full instances can be blocked. This operation must be done from
  580. the command-line tool. See
  581. .Xr snac 1 .
  582. .Pp
  583. .Ss Bad login throttling
  584. Since version 2.67, a simple logic to avoid brute force attacks against user passwords
  585. has been implemented: if, from a given IP address, the number of failed logins reaches
  586. a given threshold, further tries from that IP address are never successful until a timer
  587. expires. The maximum number of retries can be configured in the
  588. .Pa server.json
  589. file by setting the
  590. .Ic badlogin_retries
  591. variable, and the number of seconds the IP address unlock timer expires, in
  592. .Ic badlogin_expire .
  593. Please take note that, for this system to work, you must setup your web server proxy
  594. to pass the remote connection address in the
  595. .Ic X-Forwarded-For
  596. HTTP header (unless you use the FastCGI interface; if that's the case, you don't have
  597. to do anything).
  598. .Pp
  599. .Ss Subscribing to Fediverse Relays
  600. Since version 2.69, a
  601. .Nm
  602. instance can subscribe to LitePub (Pleroma-style) Fediverse Relays. Doing this improves
  603. visibility and allows following hashtags. To do this, you must create a special user named
  604. relay and, from it, follow the relay actor(s) like you do with regular actor URLs. This
  605. special user will start receiving boosts from the relay server of posts from other instances
  606. also following it. If any other user of the same
  607. .Nm
  608. instance follows any of the hashtags included in these boosted posts coming from the relay,
  609. they will be received as if they were for them.
  610. .Pp
  611. Example:
  612. .Bd -literal -offset indent
  613. snac adduser $SNAC_BASEDIR relay # only needed once
  614. snac follow $SNAC_BASEDIR relay https://relay.example.com/actor
  615. .Ed
  616. .Pp
  617. Users on your instance do NOT need to follow the local relay user to benefit from following
  618. hashtags.
  619. .Pp
  620. Please take note that subscribing to relays can increase the traffic towards your instance
  621. significantly. In any case, lowering the "Maximum days to keep posts" value for the relay
  622. special user is recommended (e.g. setting to just 1 day).
  623. .Ss Web interface language
  624. Since version 2.73, the web UI can be localized via simple .po files (they are directly
  625. parsed, no support for gettext is needed).
  626. .Pp
  627. No language file is installed by default; the administrator must copy any desired .po files
  628. to the
  629. .Pa lang/
  630. subdirectory in the base directory. Once the server is restarted, users can select the
  631. new language from the user settings. The
  632. .Nm
  633. source distribution may include .po files in the
  634. .Pa po/
  635. subdirectory. You don't need to copy the English language one, as it's the default.
  636. .Pp
  637. To create new language files, create a copy of
  638. .Pa po/en.po ,
  639. rename it to a reasonable value like
  640. .Pa pl.po
  641. or
  642. .Pa pt_BR.po ,
  643. change the translator in the header to yourself and fill the msgstr strings with your
  644. translation. If you have any doubt on how to modify .po files, there are many tutorials
  645. out there. If you want your language file to be included in the standard
  646. .Nm
  647. distribution, please send me a link to it via the Fediverse to @grunfink@comam.es
  648. or make a PR via the Git repository.
  649. .Sh ENVIRONMENT
  650. .Bl -tag -width Ds
  651. .It Ev DEBUG
  652. Overrides the debugging level from the server 'dbglevel' configuration
  653. variable. Set it to an integer value. The higher, the deeper in meaningless
  654. verbiage you'll find yourself into.
  655. .El
  656. .Sh EXAMPLES
  657. You want to install the
  658. .Nm
  659. Fediverse daemon in the host example.com, that is correctly configured
  660. with a valid TLS certificate and running the nginx httpd server.
  661. The service will be installed under the
  662. .Pa fedi
  663. location. Two users, walter and jessie, will be hosted in the system.
  664. Their Fediverse presence addresses will be
  665. .Lk https://example.com/fedi/walter
  666. and
  667. .Lk https://example.com/fedi/jesse ,
  668. respectively. They will be known
  669. in the Fediverse as @walter@example.com and @jesse@example.com. The
  670. .Nm
  671. daemon will run as the user snacusr in the system and listen to the
  672. localhost:8001 network socket. All data will be stored in the
  673. .Pa /home/snacusr/fedidata
  674. directory.
  675. .Pp
  676. Log into the system as snacusr and execute:
  677. .Bd -literal -offset indent
  678. snac init /home/snacusr/fedidata
  679. .Ed
  680. .Pp
  681. Answer "example.com" to the host name question, "/fedi" to the path
  682. prefix question, "localhost" to the address and "8001" to the port.
  683. .Pp
  684. Create the users
  685. .Bd -literal -offset indent
  686. snac adduser /home/snacusr/fedidata walter
  687. snac adduser /home/snacusr/fedidata jesse
  688. .Ed
  689. .Pp
  690. Answer the questions with reasonable values.
  691. .Pp
  692. Execute the server:
  693. .Bd -literal -offset indent
  694. snac httpd /home/snacusr/fedidata
  695. .Ed
  696. .Pp
  697. Edit the nginx configuration and add the following snippet to the
  698. example.com server section:
  699. .Bd -literal -offset indent
  700. # nginx configuration example
  701. # main web access point
  702. location /fedi {
  703. proxy_pass http://localhost:8001;
  704. proxy_set_header Host $http_host;
  705. proxy_set_header X-Forwarded-For $remote_addr;
  706. }
  707. # webfinger
  708. location /.well-known/webfinger {
  709. proxy_pass http://localhost:8001;
  710. proxy_set_header Host $http_host;
  711. proxy_set_header X-Forwarded-For $remote_addr;
  712. }
  713. # Mastodon API (entry points)
  714. location /api/v1/ {
  715. proxy_pass http://localhost:8001;
  716. proxy_set_header Host $http_host;
  717. proxy_set_header X-Forwarded-For $remote_addr;
  718. }
  719. location /api/v2/ {
  720. proxy_pass http://localhost:8001;
  721. proxy_set_header Host $http_host;
  722. proxy_set_header X-Forwarded-For $remote_addr;
  723. }
  724. # Mastodon API (OAuth support)
  725. location /oauth {
  726. proxy_pass http://localhost:8001;
  727. proxy_set_header Host $http_host;
  728. proxy_set_header X-Forwarded-For $remote_addr;
  729. }
  730. # optional
  731. location /.well-known/nodeinfo {
  732. proxy_pass http://localhost:8001;
  733. proxy_set_header Host $http_host;
  734. proxy_set_header X-Forwarded-For $remote_addr;
  735. }
  736. # optional (needed by some Mastodon API clients)
  737. location /.well-known/host-meta {
  738. proxy_pass http://localhost:8001;
  739. proxy_set_header Host $http_host;
  740. proxy_set_header X-Forwarded-For $remote_addr;
  741. }
  742. # optional (Mastodon-like link share entrypoint)
  743. location /share {
  744. proxy_pass http://localhost:8001;
  745. proxy_set_header Host $http_host;
  746. proxy_set_header X-Forwarded-For $remote_addr;
  747. }
  748. # optional (Mastodon-like "authorize interaction" entrypoint)
  749. location /authorize_interaction {
  750. proxy_pass http://localhost:8001;
  751. proxy_set_header Host $http_host;
  752. proxy_set_header X-Forwarded-For $remote_addr;
  753. }
  754. .Ed
  755. .Pp
  756. Restart the nginx daemon and connect to
  757. .Lk https://example.com/fedi/walter .
  758. The empty, default screen will be shown. Enter the admin section with the
  759. credentials defined for this user. Search people, start following
  760. them, engage in arid discussions and generally enjoy the frustrating
  761. experience of Social Media.
  762. .Pp
  763. This is an example of a similar configuration for the Apache2 web server:
  764. .Bd -literal -offset indent
  765. # apache2 configuration example
  766. ProxyPreserveHost On
  767. # Main web access point
  768. <Location /fedi>
  769. ProxyPass http://127.0.0.1:8001/social
  770. </Location>
  771. # WebFinger
  772. <Location /.well-known/webfinger>
  773. ProxyPass http://127.0.0.1:8001/.well-known/webfinger
  774. </Location>
  775. # Mastodon API (entry points)
  776. <Location /api/v1/>
  777. ProxyPass http://127.0.0.1:8001/api/v1/
  778. </Location>
  779. <Location /api/v2/>
  780. ProxyPass http://127.0.0.1:8001/api/v2/
  781. </Location>
  782. # Mastodon API (OAuth support)
  783. <Location /oauth>
  784. ProxyPass http://127.0.0.1:8001/oauth
  785. </Location>
  786. # NodeInfo (optional)
  787. <Location /.well-known/nodeinfo>
  788. ProxyPass http://127.0.0.1:8001/.well-known/nodeinfo
  789. </Location>
  790. # host-meta (optional, needed for some Mastodon API clients)
  791. <Location /.well-known/host-meta>
  792. ProxyPass http://127.0.0.1:8001/.well-known/host-meta
  793. </Location>
  794. # optional (Mastodon-like link share entrypoint)
  795. <Location /share>
  796. ProxyPass http://127.0.0.1:8001/share
  797. </Location>
  798. # optional (Mastodon-like "authorize interaction" entrypoint)
  799. <Location /authorize_interaction>
  800. ProxyPass http://127.0.0.1:8001/share
  801. </Location>
  802. .Ed
  803. .Pp
  804. Since version 2.43,
  805. .Nm
  806. supports communicating from / to the front end http server using the FastCGI
  807. protocol. There is no special advantage in using this, only that some servers
  808. allow for simpler configuration. For example, in the case of nginx, you can
  809. replace the two 'proxy_pass' and 'proxy_set_header' lines in the example
  810. above with just
  811. .Bd -literal -offset indent
  812. fastcgi_pass localhost:8001;
  813. .Ed
  814. .Pp
  815. The only thing to change on
  816. .Nm
  817. is to the set 'fastcgi' value to true in
  818. .Pa server.json .
  819. .Pp
  820. Further, using the FastCGI interface allows a much simpler configuration
  821. under OpenBSD's native httpd, given that it's natively implemented there
  822. and you no longer need to configure the complicated relayd server. This is
  823. an example:
  824. .Bd -literal -offset indent
  825. # OpenBSD httpd configuration example
  826. # other server configuration
  827. [...]
  828. location "/fedi/*" {
  829. fastcgi socket tcp "127.0.0.1" 8001
  830. }
  831. location "/.well-known/webfinger" {
  832. fastcgi socket tcp "127.0.0.1" 8001
  833. }
  834. location "/oauth/*" {
  835. fastcgi socket tcp "127.0.0.1" 8001
  836. }
  837. location "/api/v1/*" {
  838. fastcgi socket tcp "127.0.0.1" 8001
  839. }
  840. location "/api/v2/*" {
  841. fastcgi socket tcp "127.0.0.1" 8001
  842. }
  843. location "/.well-known/nodeinfo" {
  844. fastcgi socket tcp "127.0.0.1" 8001
  845. }
  846. location "/.well-known/host-meta" {
  847. fastcgi socket tcp "127.0.0.1" 8001
  848. }
  849. location "/share" {
  850. fastcgi socket tcp "127.0.0.1" 8001
  851. }
  852. location "/authorize_interaction" {
  853. fastcgi socket tcp "127.0.0.1" 8001
  854. }
  855. .Ed
  856. .Sh SEE ALSO
  857. .Xr snac 1 ,
  858. .Xr snac 5
  859. .Sh AUTHORS
  860. .An grunfink Lk https://comam.es/snac/grunfink @grunfink@comam.es
  861. .Sh LICENSE
  862. See the LICENSE file for details.
  863. .Sh CAVEATS
  864. JSON files are fragile when modified by hand. Take care.