Metadata-Version: 2.3
Name: sanhe_confluence_sdk
Version: 0.1.3
Summary: Pythonic Atlassian Confluence Client and CLI
License: MIT
Author: Sanhe Hu
Author-email: husanhe@email.com
Maintainer: Sanhe Hu
Maintainer-email: husanhe@email.com
Requires-Python: >=3.10,<4.0
Classifier: License :: OSI Approved :: MIT License
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
Provides-Extra: auto
Provides-Extra: dev
Provides-Extra: doc
Provides-Extra: test
Requires-Dist: Sphinx (>=7.4.7,<8.0.0) ; extra == "doc"
Requires-Dist: build (>=1.2.1,<2.0.0) ; extra == "dev"
Requires-Dist: docfly (==3.0.0) ; extra == "doc"
Requires-Dist: func_args (>=1.0.1,<2.0.0)
Requires-Dist: furo (==2024.8.6) ; extra == "doc"
Requires-Dist: home_secret_toml (>=0.2.1,<1.0.0) ; extra == "test"
Requires-Dist: ipython (>=8.18.1,<8.19.0) ; extra == "doc"
Requires-Dist: jinja2 (>=3.0.0,<4.0.0) ; extra == "dev"
Requires-Dist: nbsphinx (>=0.8.12,<1.0.0) ; extra == "doc"
Requires-Dist: pygments (>=2.18.0,<3.0.0) ; extra == "doc"
Requires-Dist: pytest (>=8.2.2,<9.0.0) ; extra == "test"
Requires-Dist: pytest-cov (>=6.0.0,<7.0.0) ; extra == "test"
Requires-Dist: rich (>=13.8.1,<15.0.0) ; extra == "test"
Requires-Dist: rstobj (==1.2.1) ; extra == "doc"
Requires-Dist: sanhe-atlassian-sdk (>=0.1.1,<1.0.0)
Requires-Dist: sphinx-copybutton (>=0.5.2,<1.0.0) ; extra == "doc"
Requires-Dist: sphinx-design (>=0.6.1,<1.0.0) ; extra == "doc"
Requires-Dist: sphinx-jinja (>=2.0.2,<3.0.0) ; extra == "doc"
Requires-Dist: twine (>=6.0.0,<7.0.0) ; extra == "dev"
Requires-Dist: varname (>=0.15.0,<0.16.0) ; extra == "test"
Requires-Dist: wheel (>=0.45.0,<1.0.0) ; extra == "dev"
Project-URL: Changelog, https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/blob/main/release-history.rst
Project-URL: Documentation, https://sanhe-confluence-sdk.readthedocs.io/en/latest/
Project-URL: Download, https://pypi.org/pypi/sanhe-confluence-sdk#files
Project-URL: Homepage, https://github.com/MacHu-GWU/sanhe_confluence_sdk-project
Project-URL: Issues, https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/issues
Project-URL: Repository, https://github.com/MacHu-GWU/sanhe_confluence_sdk-project
Description-Content-Type: text/x-rst


.. image:: https://readthedocs.org/projects/sanhe-confluence-sdk/badge/?version=latest
    :target: https://sanhe-confluence-sdk.readthedocs.io/en/latest/
    :alt: Documentation Status

.. image:: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/actions/workflows/main.yml/badge.svg
    :target: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/actions?query=workflow:CI

.. image:: https://codecov.io/gh/MacHu-GWU/sanhe_confluence_sdk-project/branch/main/graph/badge.svg
    :target: https://codecov.io/gh/MacHu-GWU/sanhe_confluence_sdk-project

.. image:: https://img.shields.io/pypi/v/sanhe-confluence-sdk.svg
    :target: https://pypi.python.org/pypi/sanhe-confluence-sdk

.. image:: https://img.shields.io/pypi/l/sanhe-confluence-sdk.svg
    :target: https://pypi.python.org/pypi/sanhe-confluence-sdk

.. image:: https://img.shields.io/pypi/pyversions/sanhe-confluence-sdk.svg
    :target: https://pypi.python.org/pypi/sanhe-confluence-sdk

.. image:: https://img.shields.io/badge/✍️_Release_History!--None.svg?style=social&logo=github
    :target: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/blob/main/release-history.rst

.. image:: https://img.shields.io/badge/⭐_Star_me_on_GitHub!--None.svg?style=social&logo=github
    :target: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project

------

.. image:: https://img.shields.io/badge/Link-API-blue.svg
    :target: https://sanhe-confluence-sdk.readthedocs.io/en/latest/py-modindex.html

.. image:: https://img.shields.io/badge/Link-Install-blue.svg
    :target: `install`_

.. image:: https://img.shields.io/badge/Link-GitHub-blue.svg
    :target: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project

.. image:: https://img.shields.io/badge/Link-Submit_Issue-blue.svg
    :target: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/issues

.. image:: https://img.shields.io/badge/Link-Request_Feature-blue.svg
    :target: https://github.com/MacHu-GWU/sanhe_confluence_sdk-project/issues

.. image:: https://img.shields.io/badge/Link-Download-blue.svg
    :target: https://pypi.org/pypi/sanhe-confluence-sdk#files


Welcome to ``sanhe_confluence_sdk`` Documentation
==============================================================================
.. image:: https://sanhe-confluence-sdk.readthedocs.io/en/latest/_static/sanhe_confluence_sdk-logo.png
    :target: https://sanhe-confluence-sdk.readthedocs.io/en/latest/

``sanhe_confluence_sdk`` is a Pythonic SDK for the Confluence REST API v2.

**Features**:

- **Everything is a Class**: All requests and responses are represented as Python dataclasses with full type hints.
- **IDE Friendly**: With complete type annotations, you get autocomplete and inline documentation in your IDE.
- **Access Raw Data**: Every response object has a ``.raw_data`` attribute that gives you the original JSON dictionary if needed.
- **Consistent Pattern**: All API calls follow the same pattern - create a Request, call ``.sync(client)``, get a Response.


.. _install:

Install
------------------------------------------------------------------------------

``sanhe_confluence_sdk`` is released on PyPI, so all you need is to:

.. code-block:: console

    $ pip install sanhe-confluence-sdk

To upgrade to latest version:

.. code-block:: console

    $ pip install --upgrade sanhe-confluence-sdk


Quick Start
------------------------------------------------------------------------------

**Create a Client**:

.. code-block:: python

    from sanhe_confluence_sdk.api import Confluence

    client = Confluence(
        url="https://your-domain.atlassian.net",
        username="your-email@example.com",
        password="your-api-token",  # https://id.atlassian.com/manage-profile/security/api-tokens
    )

**Basic Usage**:

.. code-block:: python

    from sanhe_confluence_sdk.api import Confluence, m

    client = Confluence(...)

    # Create a request and execute it
    request = m.GetSpacesRequest()
    response = request.sync(client)

    # Access typed results
    for space in response.results:
        print(f"Space: {space.name} (key={space.key})")

    # Access raw JSON data
    print(response.raw_data)

**Pagination**:

.. code-block:: python

    from sanhe_confluence_sdk.api import Confluence, paginate
    from sanhe_confluence_sdk.methods.space.get_spaces import (
        GetSpacesRequest,
        GetSpacesResponse,
    )

    client = Confluence(...)

    for response in paginate(
        client=client,
        request=GetSpacesRequest(),
        response_type=GetSpacesResponse,
        page_size=25,
        max_items=100,
    ):
        for space in response.results:
            print(f"Space: {space.name}")

For more details, see the `Full Documentation <https://sanhe-confluence-sdk.readthedocs.io/en/latest/>`_.

