Skip to main content

A modern Python SDK for generating dynamic JSON interfaces

Project description

Yeria Python SDK

Note: This is the Python port of the Yeria SDK. This repository is a monorepo containing multiple language implementations. See the root README for an overview.

A stateless backend library for building views that are sent to renderers (mobile or web). This is the Python port of the TypeScript Yeria SDK.

🌐 Website: yeria.app

Features

  • Stateless Architecture: No internal state, perfect for serverless and microservices
  • Ed25519 Signing: Secure view signing and verification using Ed25519 cryptography
  • 12 View Types: Form, Reader, ActionList, ActionGrid, QRScan, QRDisplay, Message, Card, Carousel, Timeline, Media, Map
  • Notifications: Send signed notifications to users via City-Mate platform
  • Type Safety: Full type definitions using Python dataclasses and type hints
  • Validation: Built-in field and form validation
  • Security: XSS protection, URL validation, input sanitization

Installation

pip install yeriasdk

Quick Start

from yeriasdk import YeriaApp, YeriaAppConfig
from yeriasdk.views import FormView

# Initialize YeriaApp
config = YeriaAppConfig(
    app_id="my-app",
    view_expiration_minutes=60,
)
app = YeriaApp(config)

# Create a form view
form = app.create_form_view("registration", "User Registration")
form.add_text_field("name", "Full Name", is_required=True)
form.add_email_field("email", "Email", is_required=True)
form.submit_button("Register")

# Serve with signature
response = app.serve(form)
print(response.view)  # The view JSON
print(response.signature)  # Ed25519 signature

View Types

FormView

Create forms with various field types (text, email, password, select, file, GPS, etc.)

ReaderView

Display rich content with paragraphs, images, markdown, tables, code blocks, etc.

ActionListView / ActionGridView

Display lists or grids of actions

QRScanView / QRDisplayView

QR code scanning and display

MessageView

Display messages with actions

CardView

Display card-based content with stats and sections

CarouselView

Display carousel slides

TimelineView

Display chronological events

MediaView

Display audio and video playlists

MapView

Display geographic data on maps

API Parity

The Python SDK maintains API parity with the TypeScript version:

  • Same factory methods: app.create_form_view(), app.create_reader_view(), etc.
  • Same fluent API: view.add_field().set_intro().submit_button() (or set_note() for backward compatibility)
  • Same validation and security features
  • Same Ed25519 signing and verification

Examples

See examples/basic_usage.py for a complete example.

Requirements

  • Python 3.10+
  • cryptography (for Ed25519)
  • markdown (for ReaderView markdown support)
  • bleach (for HTML sanitization)
  • requests (for sending notifications)

Status

✅ Core classes (BaseView, YeriaApp)
✅ All 12 view types
✅ Type definitions
✅ Error handling
✅ Validation utilities
✅ Ed25519 signing/verification
✅ Examples

License

Ce projet est sous licence Apache 2.0. Voir les fichiers LICENSE et NOTICE pour plus de détails. Copyright 2026 Numerum.

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

yeriasdk-1.0.2.tar.gz (55.6 kB view details)

Uploaded Source

Built Distribution

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

yeriasdk-1.0.2-py3-none-any.whl (63.1 kB view details)

Uploaded Python 3

File details

Details for the file yeriasdk-1.0.2.tar.gz.

File metadata

  • Download URL: yeriasdk-1.0.2.tar.gz
  • Upload date:
  • Size: 55.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for yeriasdk-1.0.2.tar.gz
Algorithm Hash digest
SHA256 8e7cfe1a78643ae73699b9fa2efea768a62b7cc04edacccf7823cea0d486b7f5
MD5 6ef8887b1879f5b85b2068cbee3ab5f0
BLAKE2b-256 b0963db3ad305323c73ce69326e54af7eece54f927264311e9ee59f0cce28b0b

See more details on using hashes here.

File details

Details for the file yeriasdk-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: yeriasdk-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 63.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.12

File hashes

Hashes for yeriasdk-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 a6cb3e9711345d6902a0b8f4e646ed62fa2d3bd19f554510340c53249829d874
MD5 efa3c76efcf99b7f63b6b2ab97ca899f
BLAKE2b-256 0c2d1e865660aaa1afa294587dfd50cfae9c4fb8bfb500d573509bc9ad4df069

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