Simple Python wrapper for the Spiget API
Project description
Python Spiget API Wrapper
A modern Python wrapper for the Spiget API, providing easy access to Spigot resources, authors, and categories.
Installation
pip install pyspiget
Quick Start
from spiget import Spiget
# Initialize the client
api = Spiget(user_agent="MyApp/1.0.0")
# Get a resource
resource = api.get_resource(1234)
print(f"Resource name: {resource.name}")
# Search for resources
resources = api.search_resources("worldedit")
for resource in resources:
print(f"Found: {resource.name}")
API Reference
Main Classes
Spiget
The main class for interacting with the Spiget API.
api = Spiget(user_agent="MyApp/1.0.0")
WebhookHandler
Handles webhook-related operations for the Spiget API.
webhook_handler = WebhookHandler(api.session)
Data Models
All models inherit from BaseModel
which provides basic dictionary to object conversion.
Resource
Represents a Spigot resource (plugin, mod, etc.)
Properties:
id
: Resource IDname
: Resource nametag
: Resource tagcontributors
: List of contributorslikes
: Number of likesfile
: ResourceFile objecttested_versions
: List of tested Minecraft versionslinks
: Dictionary of related linksrating
: ResourceRating objectrelease_date
: Release datetimeupdate_date
: Last update datetimedownloads
: Number of downloadsexternal
: Whether the resource is externalicon
: Icon objectpremium
: Whether the resource is premiumprice
: Resource price (if premium)currency
: Price currencydescription
: Resource descriptiondocumentation
: Resource documentationsource_code_link
: Link to source codedonation_link
: Link to donation page
ResourceFile
Represents a resource's downloadable file.
Properties:
type
: File typesize
: File sizesize_unit
: Size uniturl
: Download URLexternal_url
: External download URL
ResourceVersion
Represents a specific version of a resource.
Properties:
id
: Version IDuuid
: Version UUIDname
: Version namerelease_date
: Release datetimedownloads
: Number of downloadsrating
: ResourceRating object
ResourceUpdate
Represents an update post for a resource.
Properties:
id
: Update IDresource
: Resource IDtitle
: Update titledescription
: Update descriptiondate
: Update datetimelikes
: Number of likes
ResourceReview
Represents a review for a resource.
Properties:
author
: Author objectrating
: ResourceRating objectmessage
: Review messageresponse_message
: Author's responseversion
: Version revieweddate
: Review datetime
Author
Represents a resource author.
Properties:
id
: Author IDname
: Author nameicon
: Icon object
Category
Represents a resource category.
Properties:
id
: Category IDname
: Category name
Methods
Resource Methods
# Get multiple resources
resources = api.get_resources(size=10, page=1, sort=None, fields=None)
# Get a single resource
resource = api.get_resource(resource_id=1234)
# Get resource versions
versions = api.get_resource_versions(resource_id=1234, size=10, page=1)
# Get specific version
version = api.get_resource_version(resource_id=1234, version_id="1.0.0")
# Get latest version
latest = api.get_resource_latest_version(resource_id=1234)
# Get resource updates
updates = api.get_resource_updates(resource_id=1234, size=10, page=1)
# Get resource reviews
reviews = api.get_resource_reviews(resource_id=1234, size=10, page=1)
# Get resource author
author = api.get_resource_author(resource_id=1234)
Author Methods
# Get multiple authors
authors = api.get_authors(size=10, page=1)
# Get single author
author = api.get_author(author_id=1234)
# Get author's resources
resources = api.get_author_resources(author_id=1234, size=10, page=1)
Category Methods
# Get all categories
categories = api.get_categories(size=10, page=1)
# Get single category
category = api.get_category(category_id=1234)
# Get category resources
resources = api.get_category_resources(category_id=1234, size=10, page=1)
Search Methods
# Search resources
resources = api.search_resources(query="worldedit", field=None, size=10, page=1)
# Search authors
authors = api.search_authors(query="sk89q", field=None, size=10, page=1)
Webhook Methods
# Get available webhook events
events = webhook_handler.get_webhook_events()
# Register a webhook
webhook = webhook_handler.register_webhook(
url="https://example.com/webhook",
events=["resource-update", "new-resource"]
)
# Get webhook status
status = webhook_handler.get_webhook_status(webhook_id="abc123")
# Delete webhook
webhook_handler.delete_webhook(webhook_id="abc123", secret="webhook_secret")
Error Handling
The wrapper includes a custom SpigetError
exception that is raised when API requests fail:
from spiget import Spiget, SpigetError
api = Spiget()
try:
resource = api.get_resource(99999999)
except SpigetError as e:
print(f"API error: {e}")
Credits
This wrapper is built for the Spiget API created by the SpiGetOrg team.
License
MIT License - see LICENSE file for details
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
File details
Details for the file pyspiget-1.0.0.tar.gz
.
File metadata
- Download URL: pyspiget-1.0.0.tar.gz
- Upload date:
- Size: 12.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 333f6543e7060da247305d3ec124dc9205e97bcfde5420e4a08b8eaa33cb44fc |
|
MD5 | bc62a5d859a84bf77330caad1f6ab3c5 |
|
BLAKE2b-256 | fe97c38c67b96176067eefc96776199625999a3ae09142a014b2ee70ac8747c3 |
Provenance
The following attestation bundles were made for pyspiget-1.0.0.tar.gz
:
Publisher:
publish.yml
on Mark7888/pyspiget
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
pyspiget-1.0.0.tar.gz
- Subject digest:
333f6543e7060da247305d3ec124dc9205e97bcfde5420e4a08b8eaa33cb44fc
- Sigstore transparency entry: 151040882
- Sigstore integration time:
- Predicate type:
File details
Details for the file pyspiget-1.0.0-py3-none-any.whl
.
File metadata
- Download URL: pyspiget-1.0.0-py3-none-any.whl
- Upload date:
- Size: 6.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.1.1 CPython/3.12.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 431cd40de212dd038ad0f62f73c1a860ba56f473f9c052697e45a130a6fc9ae5 |
|
MD5 | bf7f30545bcc9ddd6bea5dcdcd9a56ae |
|
BLAKE2b-256 | d0cb65fc48b8e69a13bfef93ca18608321b3adbe6d4ebb05d56b71c47e70dcec |
Provenance
The following attestation bundles were made for pyspiget-1.0.0-py3-none-any.whl
:
Publisher:
publish.yml
on Mark7888/pyspiget
-
Statement type:
https://in-toto.io/Statement/v1
- Predicate type:
https://docs.pypi.org/attestations/publish/v1
- Subject name:
pyspiget-1.0.0-py3-none-any.whl
- Subject digest:
431cd40de212dd038ad0f62f73c1a860ba56f473f9c052697e45a130a6fc9ae5
- Sigstore transparency entry: 151040883
- Sigstore integration time:
- Predicate type: