Skip to main content

Enhanced Python API for the Plone Content Management System

Project description

kitconcept, GmbH

kitconcept.api

A facade enhancing the already amazing plone.api.

Installation

Add kitconcept.api as a requirement of your package (in setup.py or setup.cfg).

Usage

Replace, in your codebase, occurrences of from plone import api with from kitconcept import api.

Inclusion of api.addon

api.addon.get_addons

Return a list of addons (kitconcept.api._typing.AddonInformation) in the installation.

Example:

from kitconcept import api
from kitconcept.api._typing import AddonInformation


addons = api.addon.get_addons()

# List of AddonInformation
assert isinstance(addons, list)
assert isinstance(addons[0], AddonInformation)

It is possible to filter the addons using the parameter limit:

from kitconcept import api


# Return all valid addons
all_addons = api.addon.get_addons()

# Only installed addons
installed_addons = api.addon.get_addons(limit="installed")

# Only upgradable (already installed) addons
upgradable_addons = api.addon.get_addons(limit="upgradable")

# Available addons -- not installed
available_addons = api.addon.get_addons(limit="available")

# It is also possible to get addons not available in the UI
# Only broken addons (with installation problems)
broken_addons = api.addon.get_addons(limit="broken")

# Only non-installable addons
broken_addons = api.addon.get_addons(limit="non_installable")

api.addon.get_addons_ids

Similar to api.addon.get_addons, but return only the addon ids.

Example:

from kitconcept import api


addons_ids = api.addon.get_addons_ids()

# List of str
assert isinstance(addons_ids, list)
assert isinstance(addons_ids[0], str)

api.addon.get

Get information about one addon.

Example:

from kitconcept import api


# Get information about plone.restapi
addon = api.addon.get("plone.restapi")
assert addon.id, "plone.restapi"
assert addon.valid is True
assert addon.description == "RESTful hypermedia API for Plone."
assert addon.profile_type == "default"
assert addon.version == "8.21.0"

api.addon.install

Install an addon

Example:

from kitconcept import api


status = api.addon.install("plone.restapi")
assert status is True
assert "plone.restapi" in api.addon.get_addons_ids(limit="installed")

api.addon.uninstall

Uninstall an addon

Example:

from kitconcept import api


status = api.addon.uninstall("plone.restapi")
assert status is True
assert "plone.restapi" in api.addon.get_addons_ids(limit="available")

Additions to api.content

api.content.get_constrains

Get constrains -- limits -- of a folderish content.

Example:

from kitconcept import api


constrains = api.content.get_constrains(obj)

# Constrains are not enabled by default
assert constrains.mode == "disabled"

# Document is allowed to be added to obj
assert "Document" in constrains.allowed_types

# Document is a prefered type to be added to obj
assert "Document" in constrains.immediately_addable_types

api.content.set_constrains

Set constrains -- limits -- of a folderish content.

Example:

from kitconcept import api


constrains = api.content.set_constrains(
    obj,
    mode="enabled",
    allowed_types=["Folder", "Image"],
    immediately_addable_types=[
        "Image",
    ],
)

# Constrains now enabled
assert constrains.mode == "enabled"

# Folder and Image are allowed to be added to obj
assert "Folder" in constrains.allowed_types
assert "Image" in constrains.allowed_types

# Image is a prefered type to be added to obj
assert "Image" in constrains.immediately_addable_types

api.content.serialize

Serialize an object, using the serializers defined in plone.restapi.

Example:

from kitconcept import api


portal = api.portal.get()
data = api.content.serialize(portal)

# data is a dictionary
assert isinstance(data, dict)

# We have the serialized info
assert data["@type"] == "Plone Site"
assert data["id"] == "plone"
assert data["title"] == "Site"

Inclusion of api.fti

api.fti.get_types

Return a dictionary with all FTI's registered for the Portal.

Example:

from kitconcept import api
from plone.dexterity.fti import DexterityFTI


ftis = api.fti.get_types()

# Dictionary with FTI
assert isinstance(ftis, dict)
# Document FTI should be present
assert "Document" in ftis
assert isinstance(ftis["Document"], DexterityFTI)

api.fti.get

Return a FTI for a type.

Example:

from kitconcept import api
from plone.dexterity.fti import DexterityFTI


fti = api.fti.get(type="Document")

# FTI for Document content type
assert isinstance(fti, DexterityFTI)
assert fti.id == "Document

api.fti.behaviors_for_type

Return a list of behaviors for a type.

Example:

from kitconcept import api
from plone.dexterity.fti import DexterityFTI


behaviors = api.fti.behaviors_for_type(type="Document")

# List of behaviors for Document
assert isinstance(behaviors, list)
assert "plone.dublincore" in behaviors

api.fti.get_behavior_registration

Return a list of behaviors for a type.

Example:

from kitconcept import api
from plone.behavior.registration import BehaviorRegistration


behavior = api.fti.get_behavior_registration(name="plone.dublincore")

# Behavior registration info
assert isinstance(behavior, BehaviorRegistration)
assert behavior.title == "Dublin Core metadata"

api.fti.add_behavior_for_type

Adds the given behavior to the given portal type.

Example:

from kitconcept import api

api.fti.add_behavior_for_type("Document", "plone.leadimage")
behaviors = api.fti.behaviors_for_type(type="Document")

# List of behaviors for Document
assert isinstance(behaviors, list)
assert "plone.leadimage" in behaviors

api.fti.remove_behavior_for_type

Removes the given behavior from the given portal type.

Example:

from kitconcept import api

api.fti.remove_behavior_for_type("Document", "plone.allowdiscussion")
behaviors = api.fti.behaviors_for_type(type="Document")

# List of behaviors for Document
assert isinstance(behaviors, list)
assert "plone.allowdiscussion" not in behaviors

Inclusion of api.vocabulary

api.vocabulary.get_vocabulary_names

Return a list of names for all vocabularies

Example:

from kitconcept import api


vocabularies = api.addon.get_vocabulary_names()

# List of str
assert isinstance(vocabularies, list)
assert isinstance(vocabularies[0], str)
assert "plone.app.vocabularies.Month" in vocabularies

api.vocabulary.get

Get one vocabulary.

Example:

from kitconcept import api
from zope.schema.vocabulary import SimpleVocabulary


# Return one vocabulary
vocabulary = api.vocabulary.get("plone.app.vocabularies.Month")
assert isinstance(vocabulary, SimpleVocabulary)
assert vocabulary.getTerm(0).title == "month_jan"

Wish List

  • api.concent.deserialize
  • plone.app.multilingual: Translations management

Status

Build Status

Black

Flake8

iSort

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

kitconcept.api-1.0.0a3.tar.gz (22.9 kB view details)

Uploaded Source

Built Distribution

kitconcept.api-1.0.0a3-py3-none-any.whl (24.9 kB view details)

Uploaded Python 3

File details

Details for the file kitconcept.api-1.0.0a3.tar.gz.

File metadata

  • Download URL: kitconcept.api-1.0.0a3.tar.gz
  • Upload date:
  • Size: 22.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.26.0 requests-toolbelt/0.9.1 urllib3/1.26.7 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.12

File hashes

Hashes for kitconcept.api-1.0.0a3.tar.gz
Algorithm Hash digest
SHA256 03d7da5b380fc866fd6382bc83d5c380078e2613b34b7fc1939c853553a48de6
MD5 62e517c489b97108dfa000158282d9c8
BLAKE2b-256 d104ac9a64cf547c1336e238aa2d473e6c1e011496d30dc8209e4d6fedb36b3c

See more details on using hashes here.

File details

Details for the file kitconcept.api-1.0.0a3-py3-none-any.whl.

File metadata

  • Download URL: kitconcept.api-1.0.0a3-py3-none-any.whl
  • Upload date:
  • Size: 24.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/34.0 requests/2.26.0 requests-toolbelt/0.9.1 urllib3/1.26.7 tqdm/4.63.0 importlib-metadata/4.11.3 keyring/23.5.0 rfc3986/2.0.0 colorama/0.4.4 CPython/3.8.12

File hashes

Hashes for kitconcept.api-1.0.0a3-py3-none-any.whl
Algorithm Hash digest
SHA256 1ce5dfbbbc750c321b906a3e6f50eb6875fe2f9eef39c890ba00643a9ee069d1
MD5 29656a0bc2e34bb76b5be062a10af79b
BLAKE2b-256 82e4500be9909f4fc4629e21ff14f5a95e5e7105ce1a95e6a80aa1b8f15c099f

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