Skip to main content

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.

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.

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_path = "/engage"
engage_docs = EngagePages(
    parser=EngageParser(
        api=DiscourseAPI(
            base_url="https://discourse.ubuntu.com/",
            session=session,
            api_key="secretkey", # API KEY used in the tests
            api_username="canonical",
        ),
        index_topic_id=17229,
        url_prefix=engage_path,
    ),
    document_template="/engage/base.html",
    url_prefix=engage_path,
    blueprint_name="engage-pages",
)

Additionally, if you need a list of all engage pages, you would construct a view this way:

app.add_url_rule(
    engage_path, view_func=build_engage_index(engage_docs)
)

Where build_engage_index would be your view.

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

canonicalwebteam.discourse-4.0.5.tar.gz (23.4 kB view details)

Uploaded Source

Built Distribution

canonicalwebteam.discourse-4.0.5-py3-none-any.whl (29.8 kB view details)

Uploaded Python 3

File details

Details for the file canonicalwebteam.discourse-4.0.5.tar.gz.

File metadata

  • Download URL: canonicalwebteam.discourse-4.0.5.tar.gz
  • Upload date:
  • Size: 23.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.0 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for canonicalwebteam.discourse-4.0.5.tar.gz
Algorithm Hash digest
SHA256 d2b1cfc0873bf9f74c20167e4d49f93720662b294b3be0d61c204b8d72046ec0
MD5 e9fd302f6b50920bc9cef0caff8cfd93
BLAKE2b-256 f5573712dd337dc70bcbb115d4b2ccdc52d2c4632ce3f3e9365777ad0bde7b05

See more details on using hashes here.

File details

Details for the file canonicalwebteam.discourse-4.0.5-py3-none-any.whl.

File metadata

  • Download URL: canonicalwebteam.discourse-4.0.5-py3-none-any.whl
  • Upload date:
  • Size: 29.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.6.0 importlib_metadata/4.8.2 pkginfo/1.8.0 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.9.9

File hashes

Hashes for canonicalwebteam.discourse-4.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 bf4d2df0a20d1c97f5e28bb75e9ca957c11f55576744e0805c96a100418e98aa
MD5 4fb3b74237b8bf021faa865c9512e6bb
BLAKE2b-256 c9315cb2a92e09f4a97c6807d969e08adf56af9172f1a501a11b8e01f2a9bd64

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page