Create a tweet based on a #100DaysOfCode log message
Project description
LogTweet
Create a tweet based on a #100DaysOfCode log message.
Usage
The log url can be configured. The log has to have a format like my log, which you can find at https://log100days.lpld.io/log.md.
My log is based on the original #100DaysOfCode log repo.
This is a markdown log.
Have created a little Flask app that converts my log to an HTML site using the markdown2
package. But other Markdown converters should work similar.
Once you have an HTML document with h2
day headers and h3
sections for "Today's Progress" and "Link(s)", you can point the tool at that URL and generate a Tweet from it.
To actually enable the tweeting, you need to create a Twitter developer account and get an API key, API secret, Access Token and Access Token Secret.
The tweet will also contain the first link that you define in the "Link(s)" section under today's log. To save some space the link is shortened. By default, I use my own link shortener.
If you want to, you can also use the Bit.ly service. Their links might be a bit shorter and provide some engagement/tracking info. To use the Bitly service, you need to generate an API key through them and add it to the config (see below).
Options
If you want to create a tweet for a different day than today, you can do so with the --offset
command line flag.
The offset is defined in integer days relative to today.
So to generate a tweet for yesterday use -o -1
.
If you want to suppress the actual tweeting and only see the message in the console, use the --testmode
command line flag.
Installation
I recommend pipx
to install python scripts and other tools in isolated virtual environments. This keeps the you platform python clean and you don't have to worry about activating a particular virtual environment to use a tool/script.
pipx install logtweet
This way you will have a clean environment and the tool still available on the command line.
But if you want to, you should be able to install it with pip install logtweet
.
Configuration
You need a configuration file for the script to work.
The config.ini
can either be in the current working directory or in ~/.config/logtweet/
.
Because I can not figure out how to define a "post-install hook" that is run by pip
I can not generate an example config at the defined location.
You can find an example config on GitHub.
In that config file you define the URL where your log can be found and the API keys and access tokens that are needed for Twitter and Bit.ly.
Development
Install with
python -m pip install -e ".[develop]"
This installs the app dependencies as well as tools to develop and distribute the package.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file logtweet-0.1.4.tar.gz
.
File metadata
- Download URL: logtweet-0.1.4.tar.gz
- Upload date:
- Size: 7.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2a57e54270db11b2b1c4ad0734b5e6e0b2007e71df93afcb822ce8f722001710 |
|
MD5 | 491984f5448fc9dcf2d94315924b6fe8 |
|
BLAKE2b-256 | fe9b9f7625e918051d2f5b0d9ca1db5c72c8c71e7649455703b21bd2c70ffbdd |
File details
Details for the file logtweet-0.1.4-py3-none-any.whl
.
File metadata
- Download URL: logtweet-0.1.4-py3-none-any.whl
- Upload date:
- Size: 8.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.1.1 pkginfo/1.5.0.1 requests/2.22.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.41.1 CPython/3.8.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d04e033bb12a165e5ca1310714880b2f687d82f7921fdfd4923c4eea19533eb7 |
|
MD5 | 70192a27faee2034e79e4e24fcab0893 |
|
BLAKE2b-256 | af1c2bd11c58d1890f91b69d026a26bc1113f3bd1ea842d871577f7877f0a0f4 |