Metadata-Version: 2.4
Name: rsjwt
Version: 0.0.4
Classifier: Programming Language :: Rust
Classifier: Programming Language :: Python :: Implementation :: CPython
Classifier: Programming Language :: Python :: Implementation :: PyPy
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3 :: Only
Classifier: Programming Language :: Python :: 3.8
Classifier: Programming Language :: Python :: 3.9
Classifier: Programming Language :: Python :: 3.10
Classifier: Programming Language :: Python :: 3.11
Classifier: Programming Language :: Python :: 3.12
Classifier: Programming Language :: Python :: 3.13
License-File: LICENSE
Summary: Python wrapper for jsonwebtoken from rust
Keywords: jwt,rust
Author-email: Alexander Malev <yttrium@somedev.ru>
Requires-Python: >=3.8
Description-Content-Type: text/x-rst
Project-URL: Source Code, https://github.com/aamalev/rsjwt
Project-URL: Issues, https://github.com/aamalev/rsjwt/issues
Project-URL: Documentation, https://github.com/aamalev/rsjwt#using
Project-URL: Changelog, https://github.com/aamalev/rsjwt/releases

rsjwt
=====

.. image:: https://img.shields.io/badge/License-MIT-blue.svg
   :target: https://lbesson.mit-license.org/

.. image:: https://img.shields.io/pypi/v/rsjwt.svg
  :target: https://pypi.org/project/rsjwt

.. image:: https://img.shields.io/pypi/pyversions/rsjwt.svg
  :target: https://pypi.org/project/rsjwt
  :alt: Python versions

.. image:: https://readthedocs.org/projects/rsjwt/badge/?version=latest
  :target: https://github.com/aamalev/rsjwt#rsjwt
  :alt: Documentation Status

.. image:: https://github.com/aamalev/rsjwt/workflows/Tests/badge.svg
  :target: https://github.com/aamalev/rsjwt/actions?query=workflow%3ATests

.. image:: https://img.shields.io/pypi/dm/rsjwt.svg
  :target: https://pypi.org/project/rsjwt

|

.. image:: https://img.shields.io/badge/Rustc-1.80.0-blue?logo=rust
  :target: https://www.rust-lang.org/

.. image:: https://img.shields.io/badge/cargo-clippy-blue?logo=rust
  :target: https://doc.rust-lang.org/stable/clippy/

.. image:: https://img.shields.io/badge/PyO3-maturin-blue.svg
  :target: https://github.com/PyO3/maturin

.. image:: https://img.shields.io/badge/PyO3-asyncio-blue.svg
  :target: https://github.com/awestlake87/pyo3-asyncio

.. image:: https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/ruff/main/assets/badge/v2.json
  :target: https://github.com/astral-sh/ruff
  :alt: Linter: ruff

.. image:: https://img.shields.io/badge/code%20style-ruff-000000.svg
  :target: https://github.com/astral-sh/ruff
  :alt: Code style: ruff

.. image:: https://img.shields.io/badge/types-Mypy-blue.svg
  :target: https://github.com/python/mypy
  :alt: Code style: Mypy

.. image:: https://img.shields.io/badge/%F0%9F%A5%9A-Hatch-4051b5.svg
  :alt: Hatch project
  :target: https://github.com/pypa/hatch


Python wrapper for:
  | `jsonwebtoken <https://github.com/Keats/jsonwebtoken>`_,


Features
--------

* Encode and decode JWT
* Support HS256, HS384, HS512
* encode datetime.timedelta to float (now + delta)
* encode datetime.datetime with timezone (example datetime.now(timezone.utc))


Install
-------

.. code-block:: shell

    pip install rsjwt


Using
-----

.. code-block:: python

  from datetime import timedelta

  import rsjwt


  v = rsjwt.JWT("my-secret")
  data = {
      "exp": timedelta(hours=8),
      "s": "123",
      "a": ["123", 123],
      "m": {"a": 1},
  }
  token = v.encode(data)
  assert isinstance(token, str)

  td = v.decode(token)
  assert td["a"] == data["a"]
  assert td["s"] == data["s"]
  assert td["m"] == data["m"]
  assert isinstance(td["exp"], float)


Bench
-----

.. code-block:: bash

    % hatch run bench:py           
    ───────────────────────────────────────────────────────────────────────────────── bench.py3.9 ─────────────────────────────────────────────────────────────────────────────────
    Python: 3.9.13 (v3.9.13:6de2ca5339, May 17 2022, 11:37:23) 
    [Clang 13.0.0 (clang-1300.0.29.30)]
    Algorithm: HS256
    Iterations: 1000000

    |      package |   secs  |   n    |
    | ------------ | ------- | ------ |
    |        rsjwt |  2.2350 |  1.000 |
    |        pyjwt |  9.4796 |  4.241 |
    |      authlib | 12.0257 |  5.381 |
    |  python-jose | 14.7699 |  6.608 |
    |     jwcrypto | 61.5658 | 27.546 |
    ──────────────────────────────────────────────────────────────────────────────── bench.py3.13 ─────────────────────────────────────────────────────────────────────────────────
    Python: 3.13.0 (main, Oct  7 2024, 05:02:14) [Clang 16.0.0 (clang-1600.0.26.4)]
    Algorithm: HS256
    Iterations: 1000000

    |      package |   secs  |   n    |
    | ------------ | ------- | ------ |
    |        rsjwt |  2.1902 |  1.000 |
    |        pyjwt |  6.2054 |  2.833 |
    |      authlib |  7.2337 |  3.303 |
    |     jwcrypto | 41.4919 | 18.944 |


Development
-----------

.. code-block:: bash

    cargo fmt
    cargo clippy
    maturin develop


or use hatch envs:

.. code-block:: bash

    hatch run fmt
    hatch run check
    hatch run build
    hatch run test

