Twitter to Mastodon timeline forwarding tool
Project description
# t2m - Twitter 2 Mastodon
A script to manage the forwarding of tweets from Twitter accounts to a Mastodon one.
[![Build Status](https://travis-ci.org/yoloswagteam/t2m.svg?branch=refactoring-tests-pip-installation)](https://travis-ci.org/fcayre/t2m)
# Installation
On debian/ubuntu:
sudo apt-get install python-virtualenv
virtualenv ve
source ve/bin/activate
# if you run with an old version of python 2.7 (Ubuntu 14.04 for example)
# you'll need to run those, otherwise requests will break because it won't
# be able to correctly verify the host of the https issuer
# if you use python 3 you can ignore that
pip install pyopenssl ndg-httpsclient pyasn1
python setup.py develop
Then you need twitter API credentials. Following this tutorial https://python-twitter.readthedocs.io/en/latest/getting_started.html then create a `conf.yaml` file of this format:
consumer_key: "..."
consumer_secret: "..."
access_token_key: "..."
access_token_secret: "..."
The credentials for Mastodon are automatically generated at the first startup.
# Python 2/3 and one known bug
Compatible with both.
There is a known bug if you run python2 coming for the STL lib `mimetypes`:
JPEG images will be uploaded with the `.jpe` extension, this will break "going
on the exact url of the image" (will cause a download instead of a display).
This bug is fixed in python 3 so I would recommend running t2m with it.
# Usage
## One account
Forward for one account:
t2m one twitter_account -m mastodon_account
This will forward all not already forwarded tweet (this can be up to 200) while
waiting 30 seconds between each toot. This will also remember the mastodon account (so you don't need to specify it again).
Tweets that starts with a "@" won't be forwarded. Retweets won't be forwarded unless the `-r` option is specified.
You might want a finer control on your action, so you can do:
t2m one twitter_account -m mastodon_account -n 10
To forward only 10 tweet (be careful: if you relaunch the command this will forward 10 other tweets that weren't already forwarded).
You can also mark the whole available tweet as "already seen" without forwarding them so they'll never be forwarded in the future by using this command:
t2m one twitter_account -m mastodon_account -o
If you want to test your commands without forwarding you can simply uses the `-d` (or `--debug`) option:
t2m one twitter_account -m mastodon_account -d
t2m one twitter_account -m mastodon_account -n 10 -d
## Recommendation
In general, when I had a new account I look at its timeline, read how many tweets make sens then do:
t2m one twitter_account -m mastodon_account -n <number of tweets>
t2m one twitter_account -m mastodon_account -o
## Several accounts
To forward tweets for all accounts, simply run:
t2m all
This is a good command to put inside a crontab.
To check all accounts that will be forwarded, do a:
t2m list
You can also add an account directly without using the `one` command using:
t2m add twitter_account mastodon_account
## Retweets
When enabled, retweets are forwarded using the `retweet.tmpl` file as a template, feel free to edit it to suit your needs. The following tokens will be replaced in the template:
* `%(text)s`: the retweeted text
* `%(user)s`: the original tweet author username
* `%(id)s`: the original tweet id
To create a link to the original tweet, use `https://twitter.com/%(user)s/status/%(id)s`. To link to the original author profile, use `https://twitter.com/%(user)s`.
## Content Warnings
Content warnings can be added automatically to toots based on regular
expressions. These are configured by creating a file named cw.json.
For example, simple patterns can be used to match any tweet mentioning specific
keywords:
```json
{
"coding": [
"code", "coding", "pull request", "github", "git", "json", "regex"
],
"coffee": [
"#coffee", "coffee", "caffeine"
]
}
```
If a regex pattern contains a group then that group will be used as the content
warning text. This allows rules such as using the first hashtag of a tweet as
the CW warning:
```json
{
"hashtag-prefix": [
"^(#[^\\s]*)\\s"
]
}
```
This also allows using a prefix such as CW to specify that the first line of a
tweet should be used as the content warning:
```json
{
"cw-prefix": [
"^CW (.*)\\n"
]
}
```
Note that the regex is matched after the `retweet.tmpl` file is applied as a
template, so this can be used to automatically apply a content warning to all
RTs, or RTs from specific people, etc.
# Licence
Copyright (C) 2017-2018 Laurent Peuch and [Contributors](https://github.com/Psycojoker/t2m/graphs/contributors)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
A script to manage the forwarding of tweets from Twitter accounts to a Mastodon one.
[![Build Status](https://travis-ci.org/yoloswagteam/t2m.svg?branch=refactoring-tests-pip-installation)](https://travis-ci.org/fcayre/t2m)
# Installation
On debian/ubuntu:
sudo apt-get install python-virtualenv
virtualenv ve
source ve/bin/activate
# if you run with an old version of python 2.7 (Ubuntu 14.04 for example)
# you'll need to run those, otherwise requests will break because it won't
# be able to correctly verify the host of the https issuer
# if you use python 3 you can ignore that
pip install pyopenssl ndg-httpsclient pyasn1
python setup.py develop
Then you need twitter API credentials. Following this tutorial https://python-twitter.readthedocs.io/en/latest/getting_started.html then create a `conf.yaml` file of this format:
consumer_key: "..."
consumer_secret: "..."
access_token_key: "..."
access_token_secret: "..."
The credentials for Mastodon are automatically generated at the first startup.
# Python 2/3 and one known bug
Compatible with both.
There is a known bug if you run python2 coming for the STL lib `mimetypes`:
JPEG images will be uploaded with the `.jpe` extension, this will break "going
on the exact url of the image" (will cause a download instead of a display).
This bug is fixed in python 3 so I would recommend running t2m with it.
# Usage
## One account
Forward for one account:
t2m one twitter_account -m mastodon_account
This will forward all not already forwarded tweet (this can be up to 200) while
waiting 30 seconds between each toot. This will also remember the mastodon account (so you don't need to specify it again).
Tweets that starts with a "@" won't be forwarded. Retweets won't be forwarded unless the `-r` option is specified.
You might want a finer control on your action, so you can do:
t2m one twitter_account -m mastodon_account -n 10
To forward only 10 tweet (be careful: if you relaunch the command this will forward 10 other tweets that weren't already forwarded).
You can also mark the whole available tweet as "already seen" without forwarding them so they'll never be forwarded in the future by using this command:
t2m one twitter_account -m mastodon_account -o
If you want to test your commands without forwarding you can simply uses the `-d` (or `--debug`) option:
t2m one twitter_account -m mastodon_account -d
t2m one twitter_account -m mastodon_account -n 10 -d
## Recommendation
In general, when I had a new account I look at its timeline, read how many tweets make sens then do:
t2m one twitter_account -m mastodon_account -n <number of tweets>
t2m one twitter_account -m mastodon_account -o
## Several accounts
To forward tweets for all accounts, simply run:
t2m all
This is a good command to put inside a crontab.
To check all accounts that will be forwarded, do a:
t2m list
You can also add an account directly without using the `one` command using:
t2m add twitter_account mastodon_account
## Retweets
When enabled, retweets are forwarded using the `retweet.tmpl` file as a template, feel free to edit it to suit your needs. The following tokens will be replaced in the template:
* `%(text)s`: the retweeted text
* `%(user)s`: the original tweet author username
* `%(id)s`: the original tweet id
To create a link to the original tweet, use `https://twitter.com/%(user)s/status/%(id)s`. To link to the original author profile, use `https://twitter.com/%(user)s`.
## Content Warnings
Content warnings can be added automatically to toots based on regular
expressions. These are configured by creating a file named cw.json.
For example, simple patterns can be used to match any tweet mentioning specific
keywords:
```json
{
"coding": [
"code", "coding", "pull request", "github", "git", "json", "regex"
],
"coffee": [
"#coffee", "coffee", "caffeine"
]
}
```
If a regex pattern contains a group then that group will be used as the content
warning text. This allows rules such as using the first hashtag of a tweet as
the CW warning:
```json
{
"hashtag-prefix": [
"^(#[^\\s]*)\\s"
]
}
```
This also allows using a prefix such as CW to specify that the first line of a
tweet should be used as the content warning:
```json
{
"cw-prefix": [
"^CW (.*)\\n"
]
}
```
Note that the regex is matched after the `retweet.tmpl` file is applied as a
template, so this can be used to automatically apply a content warning to all
RTs, or RTs from specific people, etc.
# Licence
Copyright (C) 2017-2018 Laurent Peuch and [Contributors](https://github.com/Psycojoker/t2m/graphs/contributors)
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU 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 General Public License for more details.
You should have received a copy of the GNU General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
t2m-0.1.0.tar.gz
(24.2 kB
view details)
Built Distribution
t2m-0.1.0-py2.py3-none-any.whl
(27.5 kB
view details)
File details
Details for the file t2m-0.1.0.tar.gz
.
File metadata
- Download URL: t2m-0.1.0.tar.gz
- Upload date:
- Size: 24.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6f1479454328af0a338d71d714ae0cc6d6aa9d4f5644eb4fa7a0c01c781fe20b |
|
MD5 | fc3150e99822bfe0af4fa041f8c52cce |
|
BLAKE2b-256 | 21fe3790458db01abcf408b446954e554a1fd4180b7763f5b92424afbdaec92c |
File details
Details for the file t2m-0.1.0-py2.py3-none-any.whl
.
File metadata
- Download URL: t2m-0.1.0-py2.py3-none-any.whl
- Upload date:
- Size: 27.5 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | a3cf9dae2c076b0c2d3045f266c1584b9eaf7b9e107f59b2b90177902eed03bf |
|
MD5 | 029ada5b1eabdaa66479f55c6d25caf2 |
|
BLAKE2b-256 | 51f47856e474371c62bae74ab923b72bdcde4a594c1a1349146d2c7c0e88c0bb |