Skip to main content

NTI ContentFragments

Project description

nti.contentfragments

Latest release Supported Python versions https://travis-ci.org/NextThought/nti.contentfragments.svg?branch=master https://coveralls.io/repos/github/NextThought/nti.contentfragments/badge.svg Documentation Status

Support for working with string-based content in a Zope3/ZTK environment.

Overview

In a client/server environment dealing with various types of content from users, it’s important to know what not just the Python type of a particular string is, but also what the semantic type of the string is: HTML, plain text, LaTeX, etc.

This package defines interfaces and classes to be able to record this information. It also features a framework for transforming between the various supported semantic types (e.g., HTML to plain text).

Other features:

  • Support for making arbitrary incoming HTML safe (sanitizing it).

  • Support for very configurable (optionally) event-based profanity censoring that integrates with nti.schema/zope.schema.

See the documentation for more details.

Changes

1.6.1 (2020-09-14)

  • Ensure disallowed tags nested within anchors do not raise. See issue 34 <https://github.com/NextThought/nti.contentfragments/issues/34>.

1.6.0 (2020-09-02)

  • Add support for reStructuredText content fragments and corresponding fields.

1.5.0 (2020-07-23)

  • When sanitizing html, disable link creation when already under an anchor.

1.4.0 (2020-06-17)

  • Allow IAllowedAttributeProvider to be registered to provide additional attributes that would be allowed in sanitized content fragments.

1.3.0 (2020-04-06)

1.2.1 (2019-11-07)

1.2.0 (2018-10-15)

  • Add support for Python 3.7. Note that datrie is not yet available for Python 3.7.

  • Add support for PyPy3.

  • Add interfaces for all schema fields defined in nti.contentfragments.schema and make the respective classes implement them.

1.1.1 (2018-06-29)

1.1.0 (2017-06-14)

  • Remove dependency of dolmen.builtins. The interfaces IUnicode, IBytes and IString are now always defined by this package.

  • Add support for Python 3.6.

1.0.0 (2016-08-19)

  • Add support for Python 3.

  • Stop configuring plone.i18n. It’s a big dependency and doesn’t work on Python 3.

  • Introduce our own interfaces for IUnicode and IString, subclassing dolmen.builtins.IUnicode and IString, respectively, if possible.

  • The word lists used in censoring are cached in memory.

  • nti.contentfragments.html._Serializer has been renamed and is no longer public.

  • Depend on zope.mimetype >= 2.1.0 for better support of Python 3.

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

nti.contentfragments-1.6.1.tar.gz (51.2 kB view details)

Uploaded Source

Built Distribution

nti.contentfragments-1.6.1-py2.py3-none-any.whl (50.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file nti.contentfragments-1.6.1.tar.gz.

File metadata

  • Download URL: nti.contentfragments-1.6.1.tar.gz
  • Upload date:
  • Size: 51.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/46.1.3 requests-toolbelt/0.8.0 tqdm/4.27.0 CPython/3.7.9

File hashes

Hashes for nti.contentfragments-1.6.1.tar.gz
Algorithm Hash digest
SHA256 00c8f91a4f46575711e06132b1d680ab7f99f7440ac7e9a46f8b7de4aeeeaba7
MD5 0782a3b5e21bc519b5e45f24f26051cd
BLAKE2b-256 72ceaab307710b9c2ff2ddd397efca4198bdb904e995db6eb45b9138b177b0fb

See more details on using hashes here.

File details

Details for the file nti.contentfragments-1.6.1-py2.py3-none-any.whl.

File metadata

  • Download URL: nti.contentfragments-1.6.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 50.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.12.1 pkginfo/1.4.2 requests/2.19.1 setuptools/46.1.3 requests-toolbelt/0.8.0 tqdm/4.27.0 CPython/3.7.9

File hashes

Hashes for nti.contentfragments-1.6.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1d873135fb2b49496e79b9aa43bd9a8f13571cc7d8fe34a6e9d9ff814750ec87
MD5 8c8d4ec2204956b56ef63d51d6b9f55d
BLAKE2b-256 fe5abce9cff2a61c2c06fc60b2e2ced7f60dfbdec10a17af3ec87bd823454698

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