mastorss/man/mastorss.1.adoc

192 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
:Date: 2019-12-29
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.
*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.
== 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,
"max_size" : 500,
"skip" :
[
"If the title starts with this, skip it",
"Skip me too!"
],
"titles_as_cw" : true,
"titles_only" : false
}
}
--------------------------------------------------------------------------------
2019-12-16 15:23:06 +01:00
== PROTOCOL SUPPORT
Currently only HTTP and HTTPS are supported.
// == PROXY SERVERS
// Since mastorss is built on libcurl, it respects the same proxy environment
// variables. See *curl*(1), section _ENVIRONMENT_.
// .Tunnel connections through tor.
// ================================================================================
// [source,shell]
// --------------------------------------------------------------------------------
// ALL_PROXY="socks4a://[::1]:9050" mastorss example
// --------------------------------------------------------------------------------
// ================================================================================
== PROXY SERVERS
2019-12-16 15:23:06 +01:00
mastorss supports HTTP proxies set via the environment variable
_http_proxy_. Accepted format: _\http://[user[:password]@]host[:port]/_ No SOCKS
proxy support yet, sorry.
2019-12-16 15:23:06 +01:00
.Use mastorss with a proxy server
================================================================================
[source,shellsession]
--------------------------------------------------------------------------------
% http_proxy="http://localhost:3128/" 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-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”.
================================================================================
[source,shell]
--------------------------------------------------------------------------------
MASTORSS_DEBUG=1 mastorss example
--------------------------------------------------------------------------------
================================================================================
2019-12-16 15:23:06 +01:00
== REPORTING BUGS
Bugtracker: https://schlomp.space/tastytea/mastorss/issues
E-mail: tastytea@tastytea.de
== SEE ALSO
*perlre*(1), *crontab*(1), *crontab*(5)