Metadata-Version: 2.3
Name: belgie-organization
Version: 0.10.0
Summary: Organization plugin for Belgie
Author: Matt LeMay
Author-email: Matt LeMay <mplemay@users.noreply.github.com>
Requires-Dist: belgie-core
Requires-Dist: belgie-proto
Requires-Dist: fastapi>=0.100
Requires-Dist: pydantic>=2.0
Requires-Dist: pydantic-settings>=2.0
Requires-Python: >=3.12, <3.15
Description-Content-Type: text/markdown

# belgie-organization

Organization plugin and client for Belgie.

## Breaking change in 0.1.0

`OrganizationPlugin` no longer exposes built-in HTTP endpoints.
The plugin now exists to inject a request-scoped `OrganizationClient` into your own FastAPI routes.

## Usage

```python
from typing import Annotated

from fastapi import Depends, FastAPI

from belgie import Belgie
from belgie.organization import OrganizationClient

app = FastAPI()
app.include_router(auth.router)

organization_plugin = auth.add_plugin(...)


@app.post("/org/create")
async def create_org(
    org_client: Annotated[OrganizationClient, Depends(organization_plugin)],
) -> dict[str, str]:
    organization, _member = await org_client.create(
        name="Acme",
        slug="acme",
        role="owner",
    )
    return {"organization_id": str(organization.id)}


@app.post("/org/invite")
async def invite_member(
    org_client: Annotated[OrganizationClient, Depends(organization_plugin)],
) -> dict[str, str]:
    invitation = await org_client.invite(
        email="member@example.com",
        role="member",
    )
    return {"invitation_id": str(invitation.id)}
```

## Core client methods

- `create`, `check_slug`, `list_for_user`, `set_active`, `get_active`, `get_full`, `update`, `delete`
- `list_members`, `add_member`, `remove_member`, `update_member_role`, `get_active_member`, `leave`
- `invite`, `accept_invitation`, `cancel_invitation`, `reject_invitation`, `get_invitation`, `list_invitations`,
  `list_user_invitations`

## Roles

Role values are required for create/invite/member-role flows. Inputs support `str`, `StrEnum`, and role sequences.
Roles are persisted as a normalized comma-separated string.
