diff --git a/Makefile b/Makefile index a0951a8..43b4298 100644 --- a/Makefile +++ b/Makefile @@ -1,5 +1,5 @@ PIP=pip -PYTHON=python +PYTHON=python3 all: help diff --git a/README.md b/README.md index 6c19da4..0643004 100644 --- a/README.md +++ b/README.md @@ -10,10 +10,10 @@ If you want to connect specific frameworks see [Flask integration](./docs/flask. ### Install module -Install `hawk_python_sdk` from PyPI. +Install `hawk-python-sdk` from PyPI. ```shell -$ pip install hawk_python_sdk +$ pip install hawk-python-sdk ``` Import Catcher module to your project. @@ -115,6 +115,6 @@ Repository: Report a bug: -PyPI Package: +PyPI Package: CodeX Team: diff --git a/docs/fastapi.md b/docs/fastapi.md index 0872b3c..bb3bd8e 100644 --- a/docs/fastapi.md +++ b/docs/fastapi.md @@ -5,13 +5,14 @@ This extension adds support for the [FastAPI](https://fastapi.tiangolo.com/) web ## Installation ```bash -pip install hawk_python_sdk[fastapi] +pip install hawk-python-sdk[fastapi] ``` import Catcher module to your project. ```python from hawk_python_sdk.modules.fastapi import HawkFastapi +from hawk_python_sdk.modules.fastapi import HawkFastapi ``` ```python diff --git a/docs/flask.md b/docs/flask.md index a1024dd..9c073ab 100644 --- a/docs/flask.md +++ b/docs/flask.md @@ -5,13 +5,14 @@ This extension adds support for the [Flask](http://flask.pocoo.org/) web framewo ## Installation ```bash -pip install hawk_python_sdk[flask] +pip install hawk-python-sdk[flask] ``` import Catcher module to your project. ```python from hawk_python_sdk.modules.flask import HawkFlask +from hawk_python_sdk.modules.flask import HawkFlask ``` ```python diff --git a/example/example.py b/example/example.py index 15b4eb1..9aebd9d 100644 --- a/example/example.py +++ b/example/example.py @@ -1,5 +1,5 @@ import os -from hawkcatcher import Hawk +from hawk_python_sdk import Hawk from dotenv import load_dotenv load_dotenv() # take environment variables from .env. diff --git a/example/example2.py b/example/example2.py index 171d311..b581d5a 100644 --- a/example/example2.py +++ b/example/example2.py @@ -1,4 +1,4 @@ -import hawkcatcher +import hawk_python_sdk import os from dotenv import load_dotenv @@ -18,13 +18,13 @@ def test_method(self): self.divide_by_zero() def mannual_sending(self): - hawkcatcher.send(ValueError("lol"), {"ping": "pong", "number": 1}) + hawk_python_sdk.send(ValueError("lol"), {"ping": "pong", "number": 1}) def send_custom_error(self): raise InvalidToken() def send_with_user(self): - hawkcatcher.send( + hawk_python_sdk.send( ValueError("USER"), None, {'id': 1, 'name': 'Alice'} @@ -35,9 +35,9 @@ def main(): token = os.getenv('HAWK_TOKEN') if token is None or token == "": - print('hawkcatcher token not provided. Please provide HAWK_TOKEN variable in .env file') + print('hawk-python-sdk token not provided. Please provide HAWK_TOKEN variable in .env file') return - hawkcatcher.init(token) + hawk_python_sdk.init(token) test = Module() test.mannual_sending() test.send_with_user() diff --git a/example/example3.py b/example/example3.py new file mode 100644 index 0000000..c2dd6bd --- /dev/null +++ b/example/example3.py @@ -0,0 +1,15 @@ +import hawk_python_sdk + + +hawk_python_sdk.init({ + 'token':'eyJpbnRlZ3JhdGlvbklkIjoiY2YxYzVhZGEtNzllOC00YWQ1LWFmYTQtNGMzZjI3Y2UzNWRiIiwic2VjcmV0IjoiZjk4NTc5ZTMtNGZmMy00YmVlLThjYzEtOWVlMDY0ZjU4YTRjIn0=', + 'release': '3.12.4' +}) +hawk_python_sdk.send( + event=Exception("Something went wrong"), + context={ + 'ip': '192.168.1.1' + }, + user={'id': 2, 'name': 'Bob'} +) +print('Event sent successfully') \ No newline at end of file diff --git a/example/fill_events.py b/example/fill_events.py index 2915630..33c4147 100644 --- a/example/fill_events.py +++ b/example/fill_events.py @@ -1,6 +1,6 @@ import random import os -import hawkcatcher +import hawk_python_sdk from faker import Faker fake = Faker() @@ -48,7 +48,7 @@ def random_exception(): ] token = os.getenv('HAWK_TOKEN') -hawkcatcher.init(token) +hawk_python_sdk.init(token) for _ in range(10): try: @@ -57,7 +57,7 @@ def random_exception(): except Exception as e: random_username = fake.user_name() random_email = fake.email() - hawkcatcher.send(e, {'username': random_username, 'value': random_email}) + hawk_python_sdk.send(e, {'username': random_username, 'value': random_email}) for _ in range(2): try: @@ -65,4 +65,4 @@ def random_exception(): except Exception as e: random_username = fake.user_name() random_email = fake.email() - hawkcatcher.send(e, {'username': random_username, 'value': random_email}) \ No newline at end of file + hawk_python_sdk.send(e, {'username': random_username, 'value': random_email}) \ No newline at end of file diff --git a/example/requirements.txt b/example/requirements.txt index e345682..142da53 100644 --- a/example/requirements.txt +++ b/example/requirements.txt @@ -1,2 +1,2 @@ -hawkcatcher +hawk-python-sdk faker \ No newline at end of file diff --git a/pyproject.toml b/pyproject.toml index 60ce61a..cf8a9ec 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -4,7 +4,7 @@ build-backend = "hatchling.build" [project] dynamic = ["version"] dependencies = ["requests"] -name = "hawk_python_sdk" +name = "hawk-python-sdk" authors = [{ name = "CodeX Team", email = "team@codex.so" }] description = "Python errors Catcher module for Hawk." readme = "README.md" @@ -21,7 +21,7 @@ classifiers = [ flask = ["flask"] fastapi = ["fastapi"] [tool.hatch.version] -path = "src/hawkcatcher/__init__.py" +path = "src/hawk_python_sdk/__init__.py" [project.urls] Homepage = "https://github.com/codex-team/hawk.python" Issues = "https://github.com/codex-team/hawk.python/issues" diff --git a/src/hawkcatcher/__init__.py b/src/hawk_python_sdk/__init__.py similarity index 90% rename from src/hawkcatcher/__init__.py rename to src/hawk_python_sdk/__init__.py index de78df7..aaf15ba 100644 --- a/src/hawkcatcher/__init__.py +++ b/src/hawk_python_sdk/__init__.py @@ -1,4 +1,4 @@ -__version__ = "3.5.1" +__version__ = "3.5.2" from .core import Hawk from .types import HawkCatcherSettings diff --git a/src/hawkcatcher/core.py b/src/hawk_python_sdk/core.py similarity index 94% rename from src/hawkcatcher/core.py rename to src/hawk_python_sdk/core.py index 095cc4a..28d5f54 100644 --- a/src/hawkcatcher/core.py +++ b/src/hawk_python_sdk/core.py @@ -7,9 +7,9 @@ from base64 import b64decode import json -import hawkcatcher -from hawkcatcher.errors import InvalidHawkToken -from hawkcatcher.types import HawkCatcherSettings, Addons, User +import hawk_python_sdk +from hawk_python_sdk.errors import InvalidHawkToken +from hawk_python_sdk.types import HawkCatcherSettings, Addons, User class Hawk: @@ -89,7 +89,7 @@ def handler(self, exc_cls: type, exc: Exception, tb: traceback, context=None, us 'backtrace': backtrace, 'release': self.params['release'], 'context': context, - 'catcherVersion': hawkcatcher.__version__, + 'catcherVersion': hawk_python_sdk.__version__, 'user': user, 'addons': addons } diff --git a/src/hawkcatcher/errors.py b/src/hawk_python_sdk/errors.py similarity index 100% rename from src/hawkcatcher/errors.py rename to src/hawk_python_sdk/errors.py diff --git a/src/hawkcatcher/modules/fastapi/__init__.py b/src/hawk_python_sdk/modules/fastapi/__init__.py similarity index 100% rename from src/hawkcatcher/modules/fastapi/__init__.py rename to src/hawk_python_sdk/modules/fastapi/__init__.py diff --git a/src/hawkcatcher/modules/fastapi/fastapi.py b/src/hawk_python_sdk/modules/fastapi/fastapi.py similarity index 94% rename from src/hawkcatcher/modules/fastapi/fastapi.py rename to src/hawk_python_sdk/modules/fastapi/fastapi.py index a8e0502..eebaca8 100644 --- a/src/hawkcatcher/modules/fastapi/fastapi.py +++ b/src/hawk_python_sdk/modules/fastapi/fastapi.py @@ -1,11 +1,11 @@ -from hawkcatcher.types import HawkCatcherSettings +from hawk_python_sdk.types import HawkCatcherSettings from ...core import Hawk -from hawkcatcher.modules.fastapi.types import FastapiSettings, FastapiAddons +from hawk_python_sdk.modules.fastapi.types import FastapiSettings, FastapiAddons from starlette.types import ASGIApp, Receive, Scope, Send from starlette.requests import Request from starlette.middleware.base import BaseHTTPMiddleware from typing import Union -from hawkcatcher.errors import ModuleError +from hawk_python_sdk.errors import ModuleError import asyncio from contextvars import ContextVar from fastapi import Request diff --git a/src/hawkcatcher/modules/fastapi/types.py b/src/hawk_python_sdk/modules/fastapi/types.py similarity index 89% rename from src/hawkcatcher/modules/fastapi/types.py rename to src/hawk_python_sdk/modules/fastapi/types.py index b2d8ea1..77fd733 100644 --- a/src/hawkcatcher/modules/fastapi/types.py +++ b/src/hawk_python_sdk/modules/fastapi/types.py @@ -1,4 +1,4 @@ -from hawkcatcher.types import HawkCatcherSettings, User, Addons +from hawk_python_sdk.types import HawkCatcherSettings, User, Addons from typing import Callable, TypedDict from starlette.applications import Starlette from fastapi import Request diff --git a/src/hawkcatcher/modules/flask/__init__.py b/src/hawk_python_sdk/modules/flask/__init__.py similarity index 100% rename from src/hawkcatcher/modules/flask/__init__.py rename to src/hawk_python_sdk/modules/flask/__init__.py diff --git a/src/hawkcatcher/modules/flask/flask.py b/src/hawk_python_sdk/modules/flask/flask.py similarity index 95% rename from src/hawkcatcher/modules/flask/flask.py rename to src/hawk_python_sdk/modules/flask/flask.py index 27dc419..23394a7 100644 --- a/src/hawkcatcher/modules/flask/flask.py +++ b/src/hawk_python_sdk/modules/flask/flask.py @@ -1,7 +1,7 @@ from ...core import Hawk from typing import Union -from hawkcatcher.modules.flask.types import FlaskSettings, Addons -from hawkcatcher.errors import ModuleError +from hawk_python_sdk.modules.flask.types import FlaskSettings, Addons +from hawk_python_sdk.errors import ModuleError try: from flask.signals import got_request_exception diff --git a/src/hawkcatcher/modules/flask/types.py b/src/hawk_python_sdk/modules/flask/types.py similarity index 88% rename from src/hawkcatcher/modules/flask/types.py rename to src/hawk_python_sdk/modules/flask/types.py index 354ee05..c588697 100644 --- a/src/hawkcatcher/modules/flask/types.py +++ b/src/hawk_python_sdk/modules/flask/types.py @@ -1,4 +1,4 @@ -from hawkcatcher.types import HawkCatcherSettings, User, Addons +from hawk_python_sdk.types import HawkCatcherSettings, User, Addons from typing import Callable, TypedDict from flask import Request diff --git a/src/hawkcatcher/types.py b/src/hawk_python_sdk/types.py similarity index 100% rename from src/hawkcatcher/types.py rename to src/hawk_python_sdk/types.py diff --git a/tests/test_cather.py b/tests/test_cather.py index 8daa0ba..d0b6d2b 100644 --- a/tests/test_cather.py +++ b/tests/test_cather.py @@ -2,9 +2,9 @@ import pytest -from hawkcatcher import __version__ -from hawkcatcher import Hawk -from hawkcatcher.errors import InvalidHawkToken +from hawk_python_sdk import __version__ +from hawk_python_sdk import Hawk +from hawk_python_sdk.errors import InvalidHawkToken sample_token = "eyJpbnRlZ3JhdGlvbklkIjoiZGRjZmY4OTItODMzMy00YjVlLWIyYWQtZWM1MDQ5MDVjMjFlIiwic2VjcmV0IjoiZmJjYzIwMTEtMTY5My00NDIyLThiNDItZDRlMzdlYmI4NWIwIn0=" sample_token_collector_endpoint = "https://ddcff892-8333-4b5e-b2ad-ec504905c21e.k1.hawk.so" @@ -40,7 +40,8 @@ def test_settings_parsing(): 'token': sample_token, 'collector_endpoint': sample_token_collector_endpoint, 'release': None, - 'before_send': None + 'before_send': None, + 'context': None } assert settings == right_settings