Skip to main content

Simple and limited Python client for Jive collaboration software ReST API v3.

Project description

travis-ci for master branch sphinx documentation for latest release Project Status: Unsupported – The project has reached a stable, usable state but the author(s) have ceased all work on it. A new maintainer may be desired.

Simple and limited Python client for Jive collaboration software ReST API v3, along with utilities for massaging HTML to display better on Jive. Also comes pre-installed in a Docker image and a Sphinx theme and builder for Jive-optimized HTML output.

Note: Full documentation is hosted at: jiveapi.readthedocs.io. This README is just a short introduction.

Scope and Status

This project is effectively abandoned/unsupported and needs a new maintainer! My employer to longer uses Jive, so I’m no longer using this project and also have no way of testing it. If you are interested in taking over as maintainer, please open an issue!

I’m writing this to be a working Python wrapper around a small portion of the Jive ReST API - specifically, uploading/publishing updating Documents, uploading embedded Images, and manipulating the input HTML to display better in Jive. I’m doing this in my personal time, but we’ll be using the project at work for a very limited requirement: “syndicating” documentation that we publish on internal web servers (mostly Sphinx and Hugo static sites) to our corporate Jive instance. The main purpose for doing this is to reach a wider audience and for searchability, not to faithfully reproduce the layout and styling of the original HTML. I don’t plan on adding support beyond what’s required for that, but contributions are welcome.

This has been in use daily at my current employer for almost a year. It’s stable for the particular way we use it, but some code paths may not have been fully exercised before.

Also be aware that Jive heavily modifies HTML, including stripping out and sometimes replacing id attributes, breaking any internal anchor links containing dashes, etc. The high-level methods in this package make a best effort to modify HTML to work in Jive, but nothing is guaranteed. Once again, this is focused on content not presentation.

Supported Actions

  • Low-level API (direct interface to Jive API calls)

  • High-level wrapper API (provides assistance with generating parameters and massaging content):

    • Create and Update HTML Documents given HTML content and some parameters, including most of the common parameters such as the place to post in, visibility, published/draft status, and keywords.

    • Not Yet Implemented: Create and Update HTML Posts given HTML content and some parameters, including most of the common parameters such as the place to post in, visibility, published/draft status, and keywords.

    • Modify HTML formatting to use Jive UI conventions (“jive-ize” HTML).

    • Given a HTML string that contains image tags referring to local images and the filesystem path containing the images, upload each of them to Jive and modify the HTML to point to the images’ Jive URLs. Return metadata about the content and images to the user for future updates. Use this metadata on future updates to prevent re-uploading the same image.

    • Option to modify HTML to insert Jive-style information/notice boxes as header and footer, such as information reminding users not to edit the document directly on Jive and giving links to the canonical source, commit, and build that last generated the content.

    • Option to add a Jive Table of Contents macro to the beginning of the content.

  • jiveapi also includes a basic Sphinx theme (called jiveapi) and Builder (also called jiveapi) optimized for building single-page HTML for uploading to Jive.

Requirements

jiveapi is also available in a self-contained Docker image with all dependencies. See https://hub.docker.com/r/jantman/jiveapi/.

  • Python 3.5+. Yes, this package is only developed and tested against Python3, specifically 3.5 or later. It should work under 2.7 as well, but that is neither tested nor supported.

  • requests

  • premailer (optional, only required for high-level JiveContent interface)

  • lxml (optional, only required for high-level JiveContent interface)

Usage

See the full documentation at: http://jiveapi.readthedocs.io/

License

This software is licensed under the Affero General Public License, version 3 or later. If you’re not redistributing or modifying this software, compliance with the license is simple: make sure anyone interacting with it (even remotely over a network) is informed of where the source code can be downloaded (the project URL in the Python package, or the jiveapi.version.PROJECT_URL string constant). If you intend on modifying it, the user must have a way of retrieving the exact running source code. If you’re intending on distributing it outside your company, please read the full license and consult your legal counsel or Open Source Compliance policy.

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

jiveapi-1.0.0.tar.gz (50.6 kB view details)

Uploaded Source

Built Distribution

jiveapi-1.0.0-py2.py3-none-any.whl (57.0 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file jiveapi-1.0.0.tar.gz.

File metadata

  • Download URL: jiveapi-1.0.0.tar.gz
  • Upload date:
  • Size: 50.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/38.2.4 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.3

File hashes

Hashes for jiveapi-1.0.0.tar.gz
Algorithm Hash digest
SHA256 608c88fc47391d7570966c5950c4b10cb5a2abda93a838b259804f5cd93e4113
MD5 2b93aa4cf75218cd89cd2243ce5c7ee1
BLAKE2b-256 97cca30dfb0a189c4f62718546d77da4a41765649dae12f542edd7352c4a166e

See more details on using hashes here.

File details

Details for the file jiveapi-1.0.0-py2.py3-none-any.whl.

File metadata

  • Download URL: jiveapi-1.0.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 57.0 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/2.0.0 pkginfo/1.5.0.1 requests/2.22.0 setuptools/38.2.4 requests-toolbelt/0.9.1 tqdm/4.36.1 CPython/3.6.3

File hashes

Hashes for jiveapi-1.0.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 69753f958d16aae4d32e415c2eb17c8ac45e62e0f2a1d3708dba16ea69a9408f
MD5 b995a92129b0745e44a0270517ff92d3
BLAKE2b-256 e0b58de02f7985d81df983e281919623d824730864b85a7937f1ab2f283c7fa0

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