Skip to main content

A python wrapper for the AllSpice Hub API

Project description

py-allspice

A very simple API client for AllSpice Hub

Note that not the full Swagger-API is accessible. The whole implementation is focused on making access and working with Organizations, Teams, Repositories and Users as pain free as possible.

Forked from https://github.com/Langenfeld/py-gitea.

Usage

Docs

See the documentation site.

Examples

Check the examples directory for full, working example scripts that you can adapt or refer to for your own needs.

Quickstart

First get an allspice_client object wrapping access and authentication (via an api token) for your instance of AllSpice Hub.

from allspice import *

# By default, points to hub.allspice.io.
allspice_client = AllSpice(token_text=TOKEN)

# If you are self-hosting:
allspice_client = AllSpice(allspice_hub_url=URL, token_text=TOKEN)

Operations like requesting the AllSpice version or authentication user can be requested directly from the allspice_client object:

print("AllSpice Version: " + allspice_client.get_version())
print("API-Token belongs to user: " + allspice_client.get_user().username)

Adding entities like Users, Organizations, ... also is done via the allspice_client object.

user = allspice_client.create_user("Test Testson", "test@test.test", "password")

All operations on entities in allspice are then accomplished via the according wrapper objects for those entities. Each of those objects has a .request method that creates an entity according to your allspice_client instance.

other_user = User.request(allspice_client, "OtherUserName")
print(other_user.username)

Note that the fields of the User, Organization,... classes are dynamically created at runtime, and thus not visible during divelopment. Refer to the AllSpice API documentation for the fields names.

Fields that can not be altered via allspice-api, are read only. After altering a field, the .commit method of the according object must be called to synchronize the changed fields with your allspice_client instance.

org = Organization.request(allspice_client, test_org)
org.description = "some new description"
org.location = "some new location"
org.commit()

An entity in allspice can be deleted by calling delete.

org.delete()

All entity objects do have methods to execute some of the requests possible though the AllSpice api:

org = Organization.request(allspice_client, ORGNAME)
teams = org.get_teams()
for team in teams:
	repos = team.get_repos()
	for repo in repos:
		print(repo.name)

Installation

Use pip install py-allspice to install.

A Note on Versioning

This repository does not follow the same versioning policy as py-gitea. After v1.17.x, py-allspice switched to Semantic Versioning with v2.0.0. In general, versions of py-allspice do NOT conform to versions of AllSpice Hub, and the latest version of py-allspice should be compatible with the current version of AllSpice Hub.

Tests

Tests can be run with:

python3 -m pytest test_api.py

Make sure to have an instance of AllSpice Hub running on http://localhost:3000, and an admin-user token at .token. The admin user must be named test, with email secondarytest@test.org.

Cassettes

We use pytest-recording to record cassettes which speed up tests which access the network. By default, tests which have been updated to work with pytest-recording will use cassettes. To disable using cassettes, run:

python -m pytest --disable-recording

The scheduled CI test suite will ignore cassettes using the same command. This is to ensure that our cassettes aren't out of date in a way that leads to tests passing with them but failing with a live Hub environment. If a scheduled test run without the cassettes fails, use:

python -m pytest --record-mode=rewrite

To update the cassettes. Double check the changes in the cassettes and make sure tests are passing again before pushing the changes.

Snapshots

We use syrupy to snapshot test. This makes it easier to assert complex outputs. If you have to update snapshots for a test, run:

python -m pytest -k <specifier for test> --snapshot-update

When updating snapshots, try to run as few tests as possible to ensure you do not update snapshots that are unrelated to your changes, and double check snapshot changes to ensure they are what you expect.

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

py_allspice-3.12.1.tar.gz (65.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

py_allspice-3.12.1-py3-none-any.whl (53.6 kB view details)

Uploaded Python 3

File details

Details for the file py_allspice-3.12.1.tar.gz.

File metadata

  • Download URL: py_allspice-3.12.1.tar.gz
  • Upload date:
  • Size: 65.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for py_allspice-3.12.1.tar.gz
Algorithm Hash digest
SHA256 d74d41b6c5924cb86aea6628336d15e64f8166df7c3bcd155e4e6e41c69156b9
MD5 ff9e602fb556ad226fd2159a3afa7faa
BLAKE2b-256 31e66f2d394647dfaf83e11e78a920dd4150983447a9f4c14c874247ad8fc1c3

See more details on using hashes here.

File details

Details for the file py_allspice-3.12.1-py3-none-any.whl.

File metadata

  • Download URL: py_allspice-3.12.1-py3-none-any.whl
  • Upload date:
  • Size: 53.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for py_allspice-3.12.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e436f664424c8284e9cfa2bbb7da6f13b27f51131048ef6d9d8fb4350a740b28
MD5 39a06781b5dae22d754a5e74b0b96ae8
BLAKE2b-256 efe36ee2b19e03fe8ea5a423850628147cffd942a1fc583f6bd819cc6c7f13dc

See more details on using hashes here.

Supported by

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