Skip to main content

Convenience wrapper for exonware-xwentity - provides 'import xwentity' alias

Project description

xwentity

Unified entity layer. Ties schema (xwschema), actions (xwaction), and data (xwdata) together with metadata, caching, state, and XWNode. Used by xwmodels, xwbase, and the rest of the eXonware stack. Details live in docs/.

Company: eXonware.com · Author: eXonware Backend Team · Email: connect@exonware.com

Status Python License


📦 Install

pip install exonware-xwentity
pip install exonware-xwentity[lazy]
# Full stack used by xwentity flows
pip install exonware-xwentity[full]

[full] pulls the full variants of: xwsystem, xwaction, xwdata, xwquery, xwschema, and xwnode.


🚀 Quick start

from exonware.xwentity import XWEntity
from exonware.xwschema import XWSchema

schema = XWSchema({"type": "object", "properties": {"name": {"type": "string"}, "age": {"type": "integer"}}})
entity = XWEntity(schema=schema, data={"name": "Alice", "age": 30})
print(entity.data["name"])

See docs/ for metadata, state, and REF_* files.


✨ What you get

Area What's in it
Entity One class for schema, actions, data, metadata, caching.
Integration xwschema, xwaction, xwdata, XWNode.
Lifecycle State and property discovery.

🧱 Core model (explicit roles)

  • XWEntity (entity.py) composes XWSchema + XWAction + XWData: validation contract, entity-scoped behavior, and multi-format data payloads.
  • XWCollection (collection.py) is a logical, storage-agnostic collection of entities of the same type, with collection-level actions (search/bulk operations).
  • XWGroup (group.py) manages multiple collections and supports nested parent/child groups, forming a tree structure for organization.
  • Shared foundation: XWCollection and XWGroup directly extend XWObject (xwsystem), and XWEntity extends AEntity which extends XWObject, so all core entity types inherit the same lightweight identity/object base.

🌐 Ecosystem functional contributions

xwentity is the domain model backbone; other XW libs provide validation, behavior, data, and persistence layers around it. You can use xwentity standalone as a domain modeling layer with only the components you need. The broader XW stack is optional and is most relevant for enterprise and mission-critical systems that need fully integrated, self-hosted model infrastructure.

Supporting XW lib What it provides to xwentity Functional requirement it satisfies
XWSchema Schema definitions and validation contracts attached to entities. Strong model integrity and versionable validation rules.
XWAction Entity-scoped actions and workflow behavior. Behavioral domain methods with consistent execution hooks.
XWData Multi-format data payload support and transformation paths. Portable model serialization/input across formats.
XWNode Node/graph structural representation and traversal capabilities. Rich relationships and graph-aware entity operations.
XWSystem Base object model and shared runtime primitives. Uniform identity/runtime behavior across entities, collections, and groups.
XWStorage Persistence providers used by higher-level entity collections/groups. Durable entity lifecycle management across storage backends.

This combination is the differentiator: xwentity is not just a dataclass layer, it is a contract-validated domain core connected to action, data, and storage infrastructure.


📖 Docs and tests

  • Start: docs/INDEX.md or docs/.
  • Tests: From repo root, follow the layout in this package (pytest or project runner).

📜 License and links

Apache-2.0 - see LICENSE. Homepage: https://exonware.com · Repository: https://github.com/exonware/xwentity

⏱️ Async Support

  • xwentity includes asynchronous execution paths in production code.
  • Source validation: 4 async def definitions and 1 await usages under src/.
  • Use async APIs for I/O-heavy or concurrent workloads to improve throughput and responsiveness.

Version: 0.6.0.11 | Updated: 13-Apr-2026

Built with ❤️ by eXonware.com - Revolutionizing Python Development Since 2025

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

xwentity-0.6.0.11.tar.gz (86.4 kB view details)

Uploaded Source

Built Distribution

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

xwentity-0.6.0.11-py3-none-any.whl (9.7 kB view details)

Uploaded Python 3

File details

Details for the file xwentity-0.6.0.11.tar.gz.

File metadata

  • Download URL: xwentity-0.6.0.11.tar.gz
  • Upload date:
  • Size: 86.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for xwentity-0.6.0.11.tar.gz
Algorithm Hash digest
SHA256 3aeb76eadb35fca12638fa8d707e2a8bb9396996515e9fd9f2da32669de7897b
MD5 33918f8bdbe031ff3909f8b44b43861f
BLAKE2b-256 ea8b9e83e0a4872bc2a821f093e4a1acb4fbe9690e1c445dff9be0b6024f28c9

See more details on using hashes here.

File details

Details for the file xwentity-0.6.0.11-py3-none-any.whl.

File metadata

  • Download URL: xwentity-0.6.0.11-py3-none-any.whl
  • Upload date:
  • Size: 9.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.13

File hashes

Hashes for xwentity-0.6.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 3716cc8b5ad3c4d738b9cc3ea3a6a5f7f6f0205250b29533c80b8fc8dda20c70
MD5 da182eb419af9f9b63546dd6aea76c02
BLAKE2b-256 da29f563e598d0bdffc9e231b4579f853b120b822f47f2fb28e62ed27d341afa

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