jararaca 0.3.26__tar.gz → 0.3.28__tar.gz

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of jararaca might be problematic. Click here for more details.

Files changed (95) hide show
  1. {jararaca-0.3.26 → jararaca-0.3.28}/PKG-INFO +1 -1
  2. {jararaca-0.3.26 → jararaca-0.3.28}/pyproject.toml +1 -1
  3. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/__init__.py +15 -0
  4. jararaca-0.3.28/src/jararaca/observability/constants.py +3 -0
  5. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/observability/decorators.py +8 -2
  6. jararaca-0.3.28/src/jararaca/observability/fastapi_exception_handler.py +33 -0
  7. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/observability/hooks.py +29 -2
  8. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/observability/providers/otel.py +19 -4
  9. {jararaca-0.3.26 → jararaca-0.3.28}/LICENSE +0 -0
  10. {jararaca-0.3.26 → jararaca-0.3.28}/README.md +0 -0
  11. {jararaca-0.3.26 → jararaca-0.3.28}/docs/CNAME +0 -0
  12. {jararaca-0.3.26 → jararaca-0.3.28}/docs/architecture.md +0 -0
  13. {jararaca-0.3.26 → jararaca-0.3.28}/docs/assets/_f04774c9-7e05-4da4-8b17-8be23f6a1475.jpeg +0 -0
  14. {jararaca-0.3.26 → jararaca-0.3.28}/docs/assets/_f04774c9-7e05-4da4-8b17-8be23f6a1475.webp +0 -0
  15. {jararaca-0.3.26 → jararaca-0.3.28}/docs/assets/tracing_example.png +0 -0
  16. {jararaca-0.3.26 → jararaca-0.3.28}/docs/expose-type.md +0 -0
  17. {jararaca-0.3.26 → jararaca-0.3.28}/docs/http-rpc.md +0 -0
  18. {jararaca-0.3.26 → jararaca-0.3.28}/docs/index.md +0 -0
  19. {jararaca-0.3.26 → jararaca-0.3.28}/docs/interceptors.md +0 -0
  20. {jararaca-0.3.26 → jararaca-0.3.28}/docs/messagebus.md +0 -0
  21. {jararaca-0.3.26 → jararaca-0.3.28}/docs/retry.md +0 -0
  22. {jararaca-0.3.26 → jararaca-0.3.28}/docs/scheduler.md +0 -0
  23. {jararaca-0.3.26 → jararaca-0.3.28}/docs/stylesheets/custom.css +0 -0
  24. {jararaca-0.3.26 → jararaca-0.3.28}/docs/websocket.md +0 -0
  25. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/__main__.py +0 -0
  26. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/broker_backend/__init__.py +0 -0
  27. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/broker_backend/mapper.py +0 -0
  28. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/broker_backend/redis_broker_backend.py +0 -0
  29. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/cli.py +0 -0
  30. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/common/__init__.py +0 -0
  31. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/core/__init__.py +0 -0
  32. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/core/providers.py +0 -0
  33. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/core/uow.py +0 -0
  34. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/di.py +0 -0
  35. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/files/entity.py.mako +0 -0
  36. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/lifecycle.py +0 -0
  37. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/__init__.py +0 -0
  38. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/bus_message_controller.py +0 -0
  39. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/consumers/__init__.py +0 -0
  40. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/decorators.py +0 -0
  41. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/implicit_headers.py +0 -0
  42. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/interceptors/__init__.py +0 -0
  43. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/interceptors/aiopika_publisher_interceptor.py +0 -0
  44. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/interceptors/publisher_interceptor.py +0 -0
  45. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/message.py +0 -0
  46. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/publisher.py +0 -0
  47. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/messagebus/worker.py +0 -0
  48. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/microservice.py +0 -0
  49. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/observability/interceptor.py +0 -0
  50. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/observability/providers/__init__.py +0 -0
  51. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/base.py +0 -0
  52. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/exports.py +0 -0
  53. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/interceptors/__init__.py +0 -0
  54. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/interceptors/aiosqa_interceptor.py +0 -0
  55. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/interceptors/constants.py +0 -0
  56. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/interceptors/decorators.py +0 -0
  57. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/session.py +0 -0
  58. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/sort_filter.py +0 -0
  59. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/persistence/utilities.py +0 -0
  60. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/__init__.py +0 -0
  61. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/decorators.py +0 -0
  62. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/hooks.py +0 -0
  63. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/http_microservice.py +0 -0
  64. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/server.py +0 -0
  65. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/__init__.py +0 -0
  66. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/base_types.py +0 -0
  67. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/context.py +0 -0
  68. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/decorators.py +0 -0
  69. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/redis.py +0 -0
  70. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/types.py +0 -0
  71. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/presentation/websocket/websocket_interceptor.py +0 -0
  72. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/py.typed +0 -0
  73. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/reflect/__init__.py +0 -0
  74. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/reflect/controller_inspect.py +0 -0
  75. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/reflect/metadata.py +0 -0
  76. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/__init__.py +0 -0
  77. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/http/__init__.py +0 -0
  78. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/http/backends/__init__.py +0 -0
  79. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/http/backends/httpx.py +0 -0
  80. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/http/backends/otel.py +0 -0
  81. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/http/decorators.py +0 -0
  82. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/rpc/http/httpx.py +0 -0
  83. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/scheduler/__init__.py +0 -0
  84. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/scheduler/beat_worker.py +0 -0
  85. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/scheduler/decorators.py +0 -0
  86. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/scheduler/types.py +0 -0
  87. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/tools/app_config/__init__.py +0 -0
  88. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/tools/app_config/decorators.py +0 -0
  89. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/tools/app_config/interceptor.py +0 -0
  90. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/tools/typescript/__init__.py +0 -0
  91. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/tools/typescript/decorators.py +0 -0
  92. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/tools/typescript/interface_parser.py +0 -0
  93. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/utils/__init__.py +0 -0
  94. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/utils/rabbitmq_utils.py +0 -0
  95. {jararaca-0.3.26 → jararaca-0.3.28}/src/jararaca/utils/retry.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: jararaca
3
- Version: 0.3.26
3
+ Version: 0.3.28
4
4
  Summary: A simple and fast API framework for Python
5
5
  Home-page: https://github.com/LuscasLeo/jararaca
6
6
  Author: Lucas S
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "jararaca"
3
- version = "0.3.26"
3
+ version = "0.3.28"
4
4
  description = "A simple and fast API framework for Python"
5
5
  authors = ["Lucas S <me@luscasleo.dev>"]
6
6
  readme = "README.md"
@@ -18,12 +18,17 @@ if TYPE_CHECKING:
18
18
  use_app_type,
19
19
  )
20
20
  from jararaca.observability.decorators import TracedClass, TracedFunc, traced_class
21
+ from jararaca.observability.fastapi_exception_handler import (
22
+ setup_fastapi_exception_handler,
23
+ )
21
24
  from jararaca.observability.hooks import (
22
25
  add_event,
23
26
  get_tracing_provider,
24
27
  record_exception,
28
+ set_span_attribute,
25
29
  set_span_status,
26
30
  spawn_trace,
31
+ start_span,
27
32
  )
28
33
  from jararaca.observability.interceptor import ObservabilityInterceptor
29
34
  from jararaca.observability.providers.otel import OtelObservabilityProvider
@@ -233,8 +238,11 @@ if TYPE_CHECKING:
233
238
  "TracedFunc",
234
239
  "TracedClass",
235
240
  "traced_class",
241
+ "start_span",
236
242
  "spawn_trace",
243
+ "set_span_attribute",
237
244
  "add_event",
245
+ "setup_fastapi_exception_handler",
238
246
  "set_span_status",
239
247
  "record_exception",
240
248
  "get_tracing_provider",
@@ -412,6 +420,13 @@ _dynamic_imports: "dict[str, tuple[str, str, str | None]]" = {
412
420
  "TracedClass": (__SPEC_PARENT__, "observability.decorators", None),
413
421
  "traced_class": (__SPEC_PARENT__, "observability.decorators", None),
414
422
  "spawn_trace": (__SPEC_PARENT__, "observability.hooks", None),
423
+ "setup_fastapi_exception_handler": (
424
+ __SPEC_PARENT__,
425
+ "observability.fastapi_exception_handler",
426
+ None,
427
+ ),
428
+ "set_span_attribute": (__SPEC_PARENT__, "observability.hooks", None),
429
+ "start_span": (__SPEC_PARENT__, "observability.hooks", None),
415
430
  "add_event": (__SPEC_PARENT__, "observability.hooks", None),
416
431
  "set_span_status": (__SPEC_PARENT__, "observability.hooks", None),
417
432
  "record_exception": (__SPEC_PARENT__, "observability.hooks", None),
@@ -0,0 +1,3 @@
1
+ TRACEPARENT_KEY = "traceparent"
2
+
3
+ __all__ = ["TRACEPARENT_KEY"]
@@ -37,7 +37,7 @@ AttributeMap = Mapping[str, AttributeValue]
37
37
 
38
38
  class TracingContextProvider(Protocol):
39
39
 
40
- def start_trace_context(
40
+ def start_span_context(
41
41
  self, trace_name: str, context_attributes: AttributeMap | None
42
42
  ) -> ContextManager[Any]: ...
43
43
 
@@ -56,7 +56,13 @@ class TracingContextProvider(Protocol):
56
56
  escaped: bool = False,
57
57
  ) -> None: ...
58
58
 
59
+ def set_span_attribute(
60
+ self,
61
+ key: str,
62
+ value: AttributeValue,
63
+ ) -> None: ...
59
64
 
65
+ def update_span_name(self, new_name: str) -> None: ...
60
66
  class TracingContextProviderFactory(Protocol):
61
67
 
62
68
  def root_setup(
@@ -117,7 +123,7 @@ class TracedFunc:
117
123
  ) -> Any:
118
124
 
119
125
  if ctx_provider := get_tracing_ctx_provider():
120
- with ctx_provider.start_trace_context(
126
+ with ctx_provider.start_span_context(
121
127
  self.trace_name,
122
128
  self.trace_mapper(*args, **kwargs),
123
129
  ):
@@ -0,0 +1,33 @@
1
+ from fastapi import FastAPI, Request, Response
2
+ from fastapi.exception_handlers import (
3
+ http_exception_handler,
4
+ request_validation_exception_handler,
5
+ )
6
+ from fastapi.exceptions import RequestValidationError
7
+ from fastapi.responses import JSONResponse
8
+ from starlette.exceptions import HTTPException
9
+
10
+ from jararaca.observability.constants import TRACEPARENT_KEY
11
+
12
+
13
+ def setup_fastapi_exception_handler(
14
+ app: FastAPI, trace_header_name: str = "traceparent"
15
+ ) -> None:
16
+ async def base_http_exception_handler(
17
+ request: Request, exc: HTTPException | RequestValidationError
18
+ ) -> JSONResponse | Response:
19
+
20
+ if isinstance(exc, RequestValidationError):
21
+ response = await request_validation_exception_handler(request, exc)
22
+ response.headers[trace_header_name] = request.scope.get(TRACEPARENT_KEY, "")
23
+ return response
24
+ else:
25
+ err_response = await http_exception_handler(request, exc)
26
+
27
+ err_response.headers[trace_header_name] = request.scope.get(
28
+ TRACEPARENT_KEY, ""
29
+ )
30
+ return err_response
31
+
32
+ app.exception_handlers[HTTPException] = base_http_exception_handler
33
+ app.exception_handlers[RequestValidationError] = base_http_exception_handler
@@ -1,21 +1,23 @@
1
+ import logging
1
2
  from contextlib import contextmanager
2
3
  from typing import Any, Generator, Literal
3
4
 
4
5
  from jararaca.observability.decorators import (
5
6
  AttributeMap,
7
+ AttributeValue,
6
8
  TracingContextProvider,
7
9
  get_tracing_ctx_provider,
8
10
  )
9
11
 
10
12
 
11
13
  @contextmanager
12
- def spawn_trace(
14
+ def start_span(
13
15
  name: str,
14
16
  attributes: AttributeMap | None = None,
15
17
  ) -> Generator[None, Any, None]:
16
18
 
17
19
  if trace_context_provider := get_tracing_ctx_provider():
18
- with trace_context_provider.start_trace_context(
20
+ with trace_context_provider.start_span_context(
19
21
  trace_name=name, context_attributes=attributes
20
22
  ):
21
23
  yield
@@ -23,6 +25,19 @@ def spawn_trace(
23
25
  yield
24
26
 
25
27
 
28
+ def spawn_trace(
29
+ name: str,
30
+ attributes: AttributeMap | None = None,
31
+ ) -> None:
32
+ logging.warning(
33
+ "spawn_trace is deprecated, use start_span as context manager instead."
34
+ )
35
+ if trace_context_provider := get_tracing_ctx_provider():
36
+ trace_context_provider.start_span_context(
37
+ trace_name=name, context_attributes=attributes
38
+ )
39
+
40
+
26
41
  def add_event(
27
42
  name: str,
28
43
  attributes: AttributeMap | None = None,
@@ -55,5 +70,17 @@ def record_exception(
55
70
  )
56
71
 
57
72
 
73
+ def set_span_attribute(
74
+ key: str,
75
+ value: AttributeValue,
76
+ ) -> None:
77
+
78
+ if trace_context_provider := get_tracing_ctx_provider():
79
+ trace_context_provider.set_span_attribute(
80
+ key=key,
81
+ value=value,
82
+ )
83
+
84
+
58
85
  def get_tracing_provider() -> TracingContextProvider | None:
59
86
  return get_tracing_ctx_provider()
@@ -34,8 +34,10 @@ from jararaca.microservice import (
34
34
  Microservice,
35
35
  use_app_transaction_context,
36
36
  )
37
+ from jararaca.observability.constants import TRACEPARENT_KEY
37
38
  from jararaca.observability.decorators import (
38
39
  AttributeMap,
40
+ AttributeValue,
39
41
  TracingContextProvider,
40
42
  TracingContextProviderFactory,
41
43
  )
@@ -50,7 +52,7 @@ class OtelTracingContextProvider(TracingContextProvider):
50
52
  self.app_context = app_context
51
53
 
52
54
  @contextmanager
53
- def start_trace_context(
55
+ def start_span_context(
54
56
  self,
55
57
  trace_name: str,
56
58
  context_attributes: AttributeMap | None,
@@ -82,6 +84,14 @@ class OtelTracingContextProvider(TracingContextProvider):
82
84
  span = trace.get_current_span()
83
85
  span.record_exception(exception, attributes=attributes, escaped=escaped)
84
86
 
87
+ def set_span_attribute(self, key: str, value: AttributeValue) -> None:
88
+ span = trace.get_current_span()
89
+ span.set_attribute(key, value)
90
+
91
+ def update_span_name(self, new_name: str) -> None:
92
+ span = trace.get_current_span()
93
+ span.update_name(new_name)
94
+
85
95
 
86
96
  class OtelTracingContextProviderFactory(TracingContextProviderFactory):
87
97
 
@@ -185,10 +195,15 @@ class OtelTracingContextProviderFactory(TracingContextProviderFactory):
185
195
  },
186
196
  ) as root_span:
187
197
  cx = root_span.get_span_context()
198
+ span_traceparent_id = hex(cx.trace_id)[2:].rjust(32, "0")
188
199
  if app_tx_ctx.transaction_data.context_type == "http":
189
- app_tx_ctx.transaction_data.response.headers["traceparent"] = hex(
190
- cx.trace_id
191
- )[2:].rjust(32, "0")
200
+ app_tx_ctx.transaction_data.request.scope[TRACEPARENT_KEY] = (
201
+ span_traceparent_id
202
+ )
203
+ elif app_tx_ctx.transaction_data.context_type == "websocket":
204
+ app_tx_ctx.transaction_data.websocket.scope[TRACEPARENT_KEY] = (
205
+ span_traceparent_id
206
+ )
192
207
  tracing_headers: ImplicitHeaders = {}
193
208
  TraceContextTextMapPropagator().inject(tracing_headers)
194
209
  W3CBaggagePropagator().inject(tracing_headers)
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes