Upload HTML document to telegra.ph
Project description
Python html to telegra.ph poster V2
Forked from html-telegraph-poster by mercuree.
Added async support and fixed some bugs (Because my projects need it). New features will be added soon.
Simple python function to post plain html text to https://telegra.ph/.
Telegra.ph allows <a>, <blockquote>, <br>, <em>, <figure>, <h3>, <h4>, <img>, <p>, <strong>,
elements.
It also supports embedded youtube and vimeo iframe tags.
About telegram telegra.ph service https://telegram.org/blog/instant-view
Installation
pip install html-telegraph-poster-v2
Usage
>> > from html_telegraph_poster_v2 import TelegraphPoster
>> > t = TelegraphPoster(use_api=True)
>> > t.create_api_token('Elon Musk', 'Elon', 'https://www.spacex.com/') # second and third params are optional
{'access_token': '9f3bab568f*************', 'auth_url': 'https://edit.telegra.ph/auth/HFYo***********',
'author_name': 'Elon', 'short_name': 'Elon Musk', 'author_url': 'https://www.spacex.com/'}
>> > t.post(title='Just another funny joke', author='by me', text='<blockquote>Really hard way</blockquote>')
{'path': 'Just-another-funny-joke-06-05-4', 'url': 'http://telegra.ph/Just-another-funny-joke-06-05-4'}
Use graph.org instead of telegra.ph
>>> t = TelegraphPoster(use_api=True, telegraph_api_url='https://api.graph.org')
We can modify this article later:
>>> t.edit(text=t.text + '<p>some text at the end</p>')
{'path': 'Just-another-funny-joke-06-05-4', 'url': 'http://telegra.ph/Just-another-funny-joke-06-05-4'}
Modify page created earlier:
>>> t.edit(text="<p>new text</p>", path='/Another-one-page-06-05')
{'path': 'Another-one-page-06-05', 'url': 'http://telegra.ph/Another-one-page-06-05'}
Generate persistent access token
Actually it's a good idea to generate access token and put it inside environment variables.
This command will generate .env file or append TELEGRAPH_ACCESS_TOKEN at the end of it.
Note: script will not set environment variable. You can use python-dotenv,
set it manually or hardcode it when call TelegraphPoster(access_token='access_token_string')
python -m html_telegraph_poster_v2.create_account "Elon Musk" "Elon" "https://www.spacex.com/"
Uploading images
Since telegra.ph is not support media uploading anymore, you can configure an image/video storage service.
Current supported services:
- AWS S3
- GitHub
## Utils module
Utils module provides ability to make some pre-process steps before document is passed to the converter.
#### Uploading all images to the telegra.ph
```python
from html_telegraph_poster_v2.utils import DocumentPreprocessor
dp = DocumentPreprocessor(html_string)
dp.upload_all_images()
dp.get_processed_html() # this should return html string with uploaded and replaced image urls
Optionally you can pass base_url if the document contains images with relative paths
dp.upload_all_images(base_url='https://example.com')
dp.get_processed_html()
Roadmap
- rewrite the command line interface for simple usage
- add automated test pipeline
- add more services for media uploading
- imgur
- google drive
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 html_telegraph_poster_v2-0.1.4.tar.gz
.
File metadata
- Download URL: html_telegraph_poster_v2-0.1.4.tar.gz
- Upload date:
- Size: 26.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.11.10 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9315f5831b8cf39c15f219199b6708d46a1620596596c8591859019c206f2693 |
|
MD5 | 9e8fe131bf841f6559a0cd0f4a5d5b00 |
|
BLAKE2b-256 | 5be14007730b6af1e578f660534413ca538f9fcc0950e5ad5dd10ed089877797 |
File details
Details for the file html_telegraph_poster_v2-0.1.4-py3-none-any.whl
.
File metadata
- Download URL: html_telegraph_poster_v2-0.1.4-py3-none-any.whl
- Upload date:
- Size: 33.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.8.4 CPython/3.11.10 Linux/6.5.0-1025-azure
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 52daaa162b0a5e8d23ac1e21f8eccb4a6c6ab1054b4e1461abae1a20b79fdfe1 |
|
MD5 | a38ffbf12dd382b152e6a1376303fec9 |
|
BLAKE2b-256 | 9130840db174cffb32ce699beea305f72991a3feb6ad439ee1e80d8b2b9f47c1 |