mastorss/man/mastorss.1.adoc

195 lines
5.5 KiB
Plaintext
Raw Normal View History

2019-12-16 15:23:06 +01:00
= mastorss(1)
:doctype: manpage
:Author: tastytea
:Email: tastytea@tastytea.de
2020-05-10 17:01:20 +02:00
:Date: 2020-05-10
2019-12-16 15:23:06 +01:00
:Revision: 0.0.0
:man source: mastorss
:man manual: General Commands Manual
== NAME
mastorss - Another RSS to Mastodon bot.
== SYNOPSIS
*mastorss* [--help|--version] <profile>
2019-12-16 15:23:06 +01:00
2019-12-24 23:24:24 +01:00
== DESCRIPTION
*mastorss* reads RSS feeds and posts the items via the Mastodon API. Does not
support Atom at the moment.
2019-12-16 15:23:06 +01:00
== OPTIONS
*--help*::
Show help message.
*--version*::
Show version, copyright and license.
2019-12-16 15:23:06 +01:00
== USAGE
Put `watchwords.json` into `${XDG_CONFIG_HOME}/mastorss/`. Launch with profile
name. The first occurence of every watchword in an RSS item will be turned into
a hashtag. For profile-specific watchwords see the example in
`watchwords.json`. In the first run only the newest entry is posted.
The profile is the identifier for a feed and can't be named "global".
.Launch mastorss with the profile “example”.
================================================================================
[source,shellsession]
--------------------------------------------------------------------------------
% mastorss example
--------------------------------------------------------------------------------
================================================================================
=== Configuration
If the profile does not exist yet, a configuration will be created interactively
and then saved to `${XDG_CONFIG_HOME}/mastorss/config-<profile>.json`.
*access_token*::
The API token needed to communicate with the Mastodon API on the _instance_
you're using to post.
*append*::
This string will be appended to every post.
*feedurl*::
The URI of the source feed.
*fixes*::
Array of regular expressions that should be deleted from the text. For
information about the syntax see *perlre*(1).
*instance*::
Hostname of the instance you're using to post.
*keep_looking*::
If true, keep looking for new items after encountering the first that was
already posted. If you set this in the beginning, the whole feed will get
posted, since all items are new.
*interval*::
Time to wait between posts.
*max_size*::
Maximum number of characters a post can have.
*skip*::
Array of strings with titles of posts that should be skipped. Matched against
the beginning of the title; this means: “Good Day” will match “Good Day in
Happytown” but not “A Good Day in Happytown”.
*titles_as_cw*::
If true, the title will be used as the subject (also known as spoiler warning or
content warning) of the post.
*titles_only*::
If true, only post titles, no descriptions.
2020-05-10 17:01:20 +02:00
*replacements*::
Object with a list of regular expressions and replacements. Applies to posts,
subjects and links, but not to the string in _append_. For information about the
syntax see *perlre*(1).
== EXAMPLES
=== Configuration file
[source,json]
--------------------------------------------------------------------------------
{
"example" :
{
"access_token" : "123abc",
"append" : "#bot",
"feedurl" : "https://example.com/feed.rss",
"fixes" :
[
"delete this",
"<p>[Rr]ead more(\.{3}|…)</p>"
],
"instance" : "newsbots.eu",
"interval" : 600,
"keep_looking" : false,
"max_size" : 500,
"skip" :
[
"If the title starts with this, skip it",
"Skip me too!"
],
"titles_as_cw" : true,
2020-05-10 17:01:20 +02:00
"titles_only" : false,
"replacements" :
{
"apple" : "strawberry",
"(chest|wal)nut" : "hazelnut"
}
}
}
--------------------------------------------------------------------------------
2019-12-16 15:23:06 +01:00
== PROTOCOL SUPPORT
Currently only HTTP and HTTPS are supported.
== PROXY SERVERS
2019-12-16 15:23:06 +01:00
2020-01-16 23:58:32 +01:00
Since mastorss is built on libcurl, it respects the same proxy environment
variables. See *curl*(1), section _ENVIRONMENT_.
2019-12-16 15:23:06 +01:00
2020-01-16 23:58:32 +01:00
.Tunnel connections through tor.
================================================================================
[source,shellsession]
--------------------------------------------------------------------------------
2020-01-16 23:58:32 +01:00
% ALL_PROXY="socks4a://[::1]:9050" mastorss example
--------------------------------------------------------------------------------
================================================================================
2019-12-16 15:23:06 +01:00
== FILES
*Configuration file directory*::
`${XDG_CONFIG_HOME}/mastorss/`
2019-12-16 15:23:06 +01:00
`${XDG_CONFIG_HOME}` is usually `~/.config`.
== ERROR CODES
[cols=">,<"]
2019-12-28 09:52:39 +01:00
|===============================================================================
2019-12-16 15:23:06 +01:00
| Code | Explanation
| 1 | No profile specified.
| 2 | Network error.
2019-12-24 18:53:00 +01:00
| 3 | File error.
2019-12-25 02:09:22 +01:00
| 4 | Mastodon API error.
2019-12-28 09:52:39 +01:00
| 5 | JSON error, most likely the file is wrongly formatted.
2019-12-31 13:29:45 +01:00
| 6 | Feed parse error. Usually the type of feed could not be detected.
2019-12-24 18:53:00 +01:00
| 9 | Unknown error.
2019-12-28 09:52:39 +01:00
|===============================================================================
2019-12-16 15:23:06 +01:00
2019-12-24 18:53:45 +01:00
== DEBUGGING
Define the variable `MASTORSS_DEBUG` to enable debug output.
2019-12-24 18:53:45 +01:00
.Debug mastorss while using the profile “example”.
================================================================================
2019-12-31 02:56:43 +01:00
[source,shellsession]
2019-12-24 18:53:45 +01:00
--------------------------------------------------------------------------------
2019-12-31 02:56:43 +01:00
% MASTORSS_DEBUG=1 mastorss example
2019-12-24 18:53:45 +01:00
--------------------------------------------------------------------------------
================================================================================
2019-12-16 15:23:06 +01:00
== REPORTING BUGS
Bugtracker: https://schlomp.space/tastytea/mastorss/issues
E-mail: tastytea@tastytea.de
== SEE ALSO
2020-01-16 23:58:32 +01:00
*perlre*(1), *curl*(1), *crontab*(1), *crontab*(5)