Flask extension to integrate discourse content generated to docs to your website.
Project description
canonicalwebteam.discourse
Flask extension to integrate discourse content generated to docs to your website. This project was previously named discourse_docs
.
Writing documentation
Documentation for how to write documentation pages in Discourse for consumption by this module and how to configure the website to use the module can be found in the Canonical discourse.
Example Flask template for documentation pages can be found in examples
folder. Please refer to the README in that folder for more information.
Install
Install the project with pip: pip install canonicalwebteam.discourse
You can add the extension on your project as follows, replacing, at least, base_url
and index_topic_id
with your own settings:
import talisker.requests
from canonicalwebteam.discourse import DiscourseAPI, Tutorials, TutorialParser
app = Flask("myapp")
session = talisker.requests.get_session()
discourse = Tutorials(
parser=TutorialParser(
api=DiscourseAPI(
base_url="https://forum.example.com/", session=session
),
index_topic_id=321,
url_prefix="/docs",
),
document_template="docs/document.html",
url_prefix="/docs",
)
discourse.init_app(app)
Once this is added you will need to add the file document.html
to your template folder.
Local development
For local development, it's best to test this module with one of our website projects like ubuntu.com. For more information, follow this guide (internal only).
Running tests, linting and formatting
Tests can be run with Tox:
pip3 install tox # Install tox
tox # Run tests
tox -e lint # Check the format of Python code
tox -e format # Reformat the Python code
Instructions for Engage pages extension
Because you are viewing a protected topic, you must provide api_key
and api_username
. You also need an index topic id, which you can get from discourse.ubuntu.com. Your index topic must contain a metadata section. Visit the EngageParser for more information about the structure. You are encouraged to use an blueprint name that does not collide with existent blueprints. The templates must match the ones provided in the parameters indicated.
Here is an example of an implementation:
engage_pages = EngagePages(
api=DiscourseAPI(
base_url="https://discourse.ubuntu.com/",
session=session,
get_topics_query_id=14,
api_key=DISCOURSE_API_KEY, # replace with your API key
api_username=DISCOURSE_API_USERNAME, # replace with correspoding username
),
category_id=51,
page_type="engage-pages", # one of ["engage-pages", "takeovers"]
exclude_topics=[] # this is a list of topic ids that we want to exclude from Markdown error checks
additional_metadata_validation=[] # list of additional keys in the metadata table that you want to validate existence for e.g. language
)
In your project, you need to create your own views:
app.add_url_rule(
"/engage", view_func=build_engage_index(engage_pages)
)
app.add_url_rule(
"/engage/<path>", view_func=single_engage_page(engage_pages)
)
- Where
build_engage_index
would be your view for the list of engage pages, which you can get by using the methodEngagagePages(args).get_index()
- While
single_engage_page
would be your single engage pages view, which you can get usingEngagePages(args).get_engage_page(path)
Similarly for takeovers, you just need to pass page_type="takeovers"
.
- To get a list of takeovers
EngagePages(args).get_index()
also. - To get a list of active takeovers
EngagePages(args).parse_active_takeovers()
.
Pagination
get_index
provides two additional argumentslimit
andoffset
, to provide pagination functionality. They default to 50 and 0 respectively.- If you want to get all engage pages, which in the case of some sites like jp.ubuntu.com there are not that many, you can pass
limit=-1
- Use
MaxLimitError
in theexceptions.py
to handle excessive limit. By default, it will raise an error when it surpasses 500
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
Built Distribution
File details
Details for the file canonicalwebteam_discourse-5.7.3.tar.gz
.
File metadata
- Download URL: canonicalwebteam_discourse-5.7.3.tar.gz
- Upload date:
- Size: 31.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1f90435be0402f46b2d8ef443bee1551935f70f1e93c968d809429b4d7bbb80e |
|
MD5 | eb2f10eefca1ec32f63b4c7859ccb4d7 |
|
BLAKE2b-256 | 372ab36352a00c946a0ea5a681b02ab2c080d641db959bdb177dd55407c1f961 |
File details
Details for the file canonicalwebteam.discourse-5.7.3-py3-none-any.whl
.
File metadata
- Download URL: canonicalwebteam.discourse-5.7.3-py3-none-any.whl
- Upload date:
- Size: 37.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.0.0 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f1e046528ea76550b73e614cd0a8ef79fef0ccc48b5689725bd4d8da8ab13c1f |
|
MD5 | ce50f8855cc170886931f960b10d4c4f |
|
BLAKE2b-256 | b86f5b2b5dce943ae71a244bf1f4355f07a493eda6af860a843eaa3af8bd7b2a |