Schul-Cloud Content API
Project description
The ressources API package allows easy access to the Schul-Cloud ressources servers. To get an overview about how the api is defined, please refer to the repository.
Installation
You can install the package with pip from PyPI
pip install schul_cloud_ressources_api_v1
Accessing the API
Suppose, a server runs under http://localhost:8080/v1. You can use the api to connect to it. If you do not have a server, you can get a test server from the package schul_cloud_ressources_server_tests.
# import the api classes for access
from schul_cloud_ressources_api_v1 import ApiClient, RessourceApi
# create the client objects
url = "http://localhost:8080/v1"
client = ApiClient(url)
api = RessourceApi(client)
The api object gives access to the server. Here, you can see how to access the api:
# import the ressource examples
from schul_cloud_ressources_api_v1.schema import get_valid_examples
# get a valid ressource
ressource = get_valid_examples()[0]
print(ressource)
# add the ressource to the server
response = api.add_ressource(ressource)
# verify the ressource is on the server
all_my_resssources_on_the_server = api.get_ressource_ids()
assert response.id in all_my_resssources_on_the_server
# get the ressource from the server
ressource_copy = api.get_ressource(response.id)
assert ressource_copy == ressource
# delete the ressource
api.delete_ressource(response.id)
Authentication
There are these options for authentication:
no authentication: this is the default and nothing needs to be done.
basic authentication: authentication with user name and password
api_key authentication: a key is supplied to authorize the requests.
The authentication is a global state. All ApiClients use this global state. Thus, you can only authenticate at one API at a time.
import schul_cloud_ressources_api_v1.auth as auth
You can remove all authentication. This is the default case.
auth.none()
You can authenticate with username and password. This is Basic Authentication <https://en.wikipedia.org/wiki/Basic_access_authentication>.
auth.basic("username", "password")
You can authenticate with an api key.
auth.api_key("your-api-key")
Verifying Ressources
When you use ressources, you may want to verify if they have the correct format. The format is specified in the ressource-schema. This schema is included in the api.
from schul_cloud_ressources_api_v1.schema import (
get_valid_examples, get_invalid_examples, validate_ressource, is_valid_ressource
)
You can test if a ressource is valid or not using is_valid_ressource
valid_ressource = get_valid_examples()[0]
assert is_valid_ressource(valid_ressource)
invalid_ressource = get_invalid_examples()[0]
assert not is_valid_ressource(invalid_ressource)
If you would like to find out more about why the ressource is not valid, you can use validate_ressource.
validate_ressource({'title': 'hello'})
Which results in an error that the url property is not present but is required.
jsonschema.exceptions.ValidationError: 'url' is a required property
Failed validating 'required' in schema:
{'properties': {'contentCategory': {'$ref': '#/definitions/ContentCategory'},
'contextUrl': {'$ref': '#/definitions/URL'},
'curricula': {'items': {'$ref': '../curriculum/curriculum.json'},
'type': 'array'},
'dimensions': {'$ref': '#/definitions/Dimensions'},
'duration': {'type': 'number'},
'languages': {'description': 'As described in IEEE '
'LOM, Section 1.3 '
'http://129.115.100.158/txlor/docs/IEEE_LOM_1484_12_1_v1_Final_Draft.pdf',
'items': {'$ref': '#/definitions/Language'},
'type': 'array'},
'licenses': {'items': {'$ref': '../license/license.json'},
'type': 'array'},
'mimeType': {'description': 'https://tools.ietf.org/html/rfc2046',
'example': 'text/html',
'type': 'string'},
'size': {'format': 'int64', 'type': 'integer'},
'thumbnail': {'$ref': '#/definitions/URL'},
'title': {'description': 'The title of the ressource.',
'example': 'Schul-Cloud',
'type': 'string'},
'url': {'$ref': '#/definitions/URL'}},
'required': ['title',
'url',
'licenses',
'mimeType',
'contentCategory',
'languages'],
'type': 'object'}
On instance:
{'title': 'hello'}
Further Reading
To edit this description, you can edit the file on Github. You can use this editor.
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
Hashes for schul_cloud_ressources_api_v1-1.0.0.58.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 07b1c05781b9180160a4237a868f774f1e77f9213966962b34683be639266ee5 |
|
MD5 | 8d5d50c0ea0fb297d3707f9da1874a97 |
|
BLAKE2b-256 | 109437388e1319981b0b95461357132e5bcd2d36d61224183bf65f1f479aa2e6 |
Hashes for schul_cloud_ressources_api_v1-1.0.0.58-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | e40de3d08e3f809e3c5bbe39610936ff6b3be0fc0358b3c7a624d6b52b06b500 |
|
MD5 | 15b4f344edd4e6b7a3e283e0fa59d294 |
|
BLAKE2b-256 | 94db17808791764267f6aa7a815d250543ffb62223ab0ae085988afcc0f36d4a |