plain.observer 0.7.0__tar.gz → 0.9.0__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 plain.observer might be problematic. Click here for more details.

Files changed (34) hide show
  1. {plain_observer-0.7.0 → plain_observer-0.9.0}/.gitignore +1 -2
  2. {plain_observer-0.7.0 → plain_observer-0.9.0}/PKG-INFO +1 -1
  3. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/CHANGELOG.md +25 -0
  4. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/config.py +2 -2
  5. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/models.py +2 -2
  6. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/toolbar.py +4 -4
  7. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/views.py +4 -2
  8. {plain_observer-0.7.0 → plain_observer-0.9.0}/pyproject.toml +1 -1
  9. {plain_observer-0.7.0 → plain_observer-0.9.0}/LICENSE +0 -0
  10. {plain_observer-0.7.0 → plain_observer-0.9.0}/README.md +0 -0
  11. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/README.md +0 -0
  12. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/__init__.py +0 -0
  13. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/admin.py +0 -0
  14. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/cli.py +0 -0
  15. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/core.py +0 -0
  16. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/default_settings.py +0 -0
  17. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/logging.py +0 -0
  18. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/0001_initial.py +0 -0
  19. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/0002_trace_share_created_at_trace_share_id_trace_summary_and_more.py +0 -0
  20. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/0003_span_plainobserv_span_id_e7ade3_idx.py +0 -0
  21. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/0004_trace_app_name_trace_app_version.py +0 -0
  22. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/0005_log_log_plainobserv_trace_i_fcfb7d_idx_and_more.py +0 -0
  23. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/0006_remove_log_logger.py +0 -0
  24. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/migrations/__init__.py +0 -0
  25. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/otel.py +0 -0
  26. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/observer/partials/log.html +0 -0
  27. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/observer/partials/span.html +0 -0
  28. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/observer/trace.html +0 -0
  29. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/observer/trace_detail.html +0 -0
  30. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/observer/trace_share.html +0 -0
  31. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/observer/traces.html +0 -0
  32. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/toolbar/observer.html +0 -0
  33. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/templates/toolbar/observer_button.html +0 -0
  34. {plain_observer-0.7.0 → plain_observer-0.9.0}/plain/observer/urls.py +0 -0
@@ -11,9 +11,8 @@ plain*/tests/.plain
11
11
  # Ottobot
12
12
  .aider*
13
13
 
14
- /llms-full.txt
15
-
16
14
  # Plain temp dirs
17
15
  .plain
18
16
 
19
17
  .vscode
18
+ /.claude
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: plain.observer
3
- Version: 0.7.0
3
+ Version: 0.9.0
4
4
  Summary: On-page telemetry and observability tools for Plain.
5
5
  Author-email: Dave Gaeddert <dave.gaeddert@dropseed.dev>
6
6
  License-Expression: BSD-3-Clause
@@ -1,5 +1,30 @@
1
1
  # plain-observer changelog
2
2
 
3
+ ## [0.9.0](https://github.com/dropseed/plain/releases/plain-observer@0.9.0) (2025-09-30)
4
+
5
+ ### What's changed
6
+
7
+ - Settings renamed from `APP_NAME` to `NAME` and `APP_VERSION` to `VERSION` for consistency with Plain conventions ([4c5f216](https://github.com/dropseed/plain/commit/4c5f2166c1))
8
+ - Trace detail and shared views now use `request.get_preferred_type()` for improved content negotiation ([b105ba4](https://github.com/dropseed/plain/commit/b105ba4dd0))
9
+
10
+ ### Upgrade instructions
11
+
12
+ - No changes required
13
+
14
+ ## [0.8.0](https://github.com/dropseed/plain/releases/plain-observer@0.8.0) (2025-09-30)
15
+
16
+ ### What's changed
17
+
18
+ - The toolbar panel class has been renamed from `ToolbarPanel` to `ToolbarItem` for better clarity and consistency ([79654db](https://github.com/dropseed/plain/commit/79654db))
19
+ - The `template_name` attribute has been renamed to `panel_template_name` in toolbar items ([79654db](https://github.com/dropseed/plain/commit/79654db))
20
+ - The registration decorator has been renamed from `register_toolbar_panel` to `register_toolbar_item` ([79654db](https://github.com/dropseed/plain/commit/79654db))
21
+
22
+ ### Upgrade instructions
23
+
24
+ - If you have custom toolbar panels, rename your class from inheriting `ToolbarPanel` to `ToolbarItem`
25
+ - If you use the `template_name` attribute in your toolbar items, rename it to `panel_template_name`
26
+ - If you use the `@register_toolbar_panel` decorator, change it to `@register_toolbar_item`
27
+
3
28
  ## [0.7.0](https://github.com/dropseed/plain/releases/plain-observer@0.7.0) (2025-09-12)
4
29
 
5
30
  ### What's changed
@@ -36,8 +36,8 @@ class Config(PackageConfig):
36
36
  # Start our own provider, new sampler, and span processor
37
37
  resource = Resource.create(
38
38
  {
39
- service_attributes.SERVICE_NAME: settings.APP_NAME,
40
- service_attributes.SERVICE_VERSION: settings.APP_VERSION,
39
+ service_attributes.SERVICE_NAME: settings.NAME,
40
+ service_attributes.SERVICE_VERSION: settings.VERSION,
41
41
  }
42
42
  )
43
43
  provider = TracerProvider(sampler=sampler, resource=resource)
@@ -182,8 +182,8 @@ class Trace(models.Model):
182
182
  request_id=request_id,
183
183
  user_id=user_id,
184
184
  session_id=session_id,
185
- app_name=app_name or getattr(settings, "APP_NAME", ""),
186
- app_version=app_version or getattr(settings, "APP_VERSION", ""),
185
+ app_name=app_name or settings.NAME,
186
+ app_version=app_version or settings.VERSION,
187
187
  root_span_name=root_span.name if root_span else "",
188
188
  )
189
189
 
@@ -1,14 +1,14 @@
1
1
  from functools import cached_property
2
2
 
3
- from plain.toolbar import ToolbarPanel, register_toolbar_panel
3
+ from plain.toolbar import ToolbarItem, register_toolbar_item
4
4
 
5
5
  from .core import Observer
6
6
 
7
7
 
8
- @register_toolbar_panel
9
- class ObserverToolbarPanel(ToolbarPanel):
8
+ @register_toolbar_item
9
+ class ObserverToolbarItem(ToolbarItem):
10
10
  name = "Observer"
11
- template_name = "toolbar/observer.html"
11
+ panel_template_name = "toolbar/observer.html"
12
12
  button_template_name = "toolbar/observer_button.html"
13
13
 
14
14
  @cached_property
@@ -90,8 +90,9 @@ class ObserverTraceDetailView(AuthViewMixin, HTMXViewMixin, DetailView):
90
90
 
91
91
  def get(self):
92
92
  """Return trace data as HTML, JSON, or logs based on content negotiation."""
93
+ preferred = self.request.get_preferred_type("application/json", "text/html")
93
94
  if (
94
- "application/json" in self.request.headers.get("Accept", "")
95
+ preferred == "application/json"
95
96
  or self.request.query_params.get("format") == "json"
96
97
  ):
97
98
  return self.object.as_dict()
@@ -146,8 +147,9 @@ class ObserverTraceSharedView(DetailView):
146
147
 
147
148
  def get(self):
148
149
  """Return trace data as HTML or JSON based on content negotiation."""
150
+ preferred = self.request.get_preferred_type("application/json", "text/html")
149
151
  if (
150
- "application/json" in self.request.headers.get("Accept", "")
152
+ preferred == "application/json"
151
153
  or self.request.query_params.get("format") == "json"
152
154
  ):
153
155
  return JsonResponse(self.object.as_dict())
@@ -1,6 +1,6 @@
1
1
  [project]
2
2
  name = "plain.observer"
3
- version = "0.7.0"
3
+ version = "0.9.0"
4
4
  description = "On-page telemetry and observability tools for Plain."
5
5
  authors = [{name = "Dave Gaeddert", email = "dave.gaeddert@dropseed.dev"}]
6
6
  license = "BSD-3-Clause"
File without changes
File without changes