karrio-server 2025.5rc34__py3-none-any.whl → 2025.5rc35__py3-none-any.whl

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.
karrio/server/VERSION CHANGED
@@ -1 +1 @@
1
- 2025.5rc34
1
+ 2025.5rc35
@@ -49,12 +49,19 @@ if SENTRY_DSN:
49
49
  dsn=SENTRY_DSN,
50
50
  integrations=integrations,
51
51
  # Set traces_sample_rate to 1.0 to capture 100%
52
- # of transactions for performance monitoring.
53
- # We recommend adjusting this value in production,
52
+ # of transactions for tracing.
54
53
  traces_sample_rate=1.0,
54
+ # Set profile_session_sample_rate to 1.0 to profile 100%
55
+ # of profile sessions.
56
+ profile_session_sample_rate=1.0,
57
+ # Set profile_lifecycle to "trace" to automatically
58
+ # run the profiler on when there is an active transaction
59
+ profile_lifecycle="trace",
55
60
  # If you wish to associate users to errors (assuming you are using
56
61
  # django.contrib.auth) you may enable sending PII data.
57
62
  send_default_pii=True,
63
+ # Enable sending logs to Sentry
64
+ enable_logs=True,
58
65
  )
59
66
 
60
67
 
@@ -67,6 +67,7 @@ CORS_ALLOW_HEADERS = list(default_headers) + [
67
67
  # HTTPS configuration
68
68
  if USE_HTTPS is True:
69
69
  global SECURE_SSL_REDIRECT
70
+ global SECURE_REDIRECT_EXEMPT
70
71
  global SECURE_PROXY_SSL_HEADER
71
72
  global SESSION_COOKIE_SECURE
72
73
  global SECURE_HSTS_SECONDS
@@ -75,6 +76,8 @@ if USE_HTTPS is True:
75
76
  global SECURE_HSTS_PRELOAD
76
77
 
77
78
  SECURE_SSL_REDIRECT = True
79
+ # Exempt health check endpoint from HTTPS redirect for Kubernetes probes
80
+ SECURE_REDIRECT_EXEMPT = [r'^status/$']
78
81
  SECURE_PROXY_SSL_HEADER = ("HTTP_X_FORWARDED_PROTO", "https")
79
82
  SESSION_COOKIE_SECURE = True
80
83
  SECURE_HSTS_SECONDS = 1
@@ -385,6 +388,16 @@ AUTH_PASSWORD_VALIDATORS = [
385
388
  AUTH_USER_MODEL = "user.User"
386
389
 
387
390
 
391
+ # Session configuration
392
+ # Use a unique session cookie name to prevent conflicts with other applications
393
+ # (e.g., ORY Kratos sessions in the shipping-app frontend)
394
+ SESSION_COOKIE_NAME = config("SESSION_COOKIE_NAME", default="karrio_sessionid")
395
+ SESSION_COOKIE_PATH = config("SESSION_COOKIE_PATH", default="/")
396
+ SESSION_COOKIE_HTTPONLY = True
397
+ SESSION_COOKIE_SAMESITE = config("SESSION_COOKIE_SAMESITE", default="Lax")
398
+ # SESSION_COOKIE_DOMAIN is intentionally not set to allow per-host cookies
399
+
400
+
388
401
  # Internationalization
389
402
  # https://docs.djangoproject.com/en/3.0/topics/i18n/
390
403
 
@@ -14,9 +14,9 @@ DETACHED_WORKER = config("DETACHED_WORKER", default=False, cast=bool)
14
14
  # Detect if running as a worker process (via run_huey command)
15
15
  IS_WORKER_PROCESS = any("run_huey" in arg for arg in sys.argv)
16
16
 
17
- # Skip default Redis cache configuration if in worker mode
18
- # Workers only need HUEY Redis, not the default Django cache
19
- SKIP_DEFAULT_CACHE = DETACHED_WORKER or IS_WORKER_PROCESS
17
+ # Skip default Redis cache configuration only for worker processes
18
+ # API servers should use Redis cache even when DETACHED_WORKER is True
19
+ SKIP_DEFAULT_CACHE = IS_WORKER_PROCESS
20
20
 
21
21
  # Redis configuration - REDIS_URL takes precedence and supersedes granular env vars
22
22
  REDIS_URL = config("REDIS_URL", default=None)
@@ -60,8 +60,16 @@ else:
60
60
 
61
61
  # Configure Django cache if Redis is available and not in worker mode
62
62
  if REDIS_HOST is not None and not SKIP_DEFAULT_CACHE:
63
- HEALTH_CHECK_APPS += ["health_check.contrib.redis"]
64
- INSTALLED_APPS += ["health_check.contrib.redis"]
63
+ # Configure connection pool with max_connections to prevent exhaustion
64
+ # Default: 50 connections per process (2 Gunicorn workers = 100 total)
65
+ # Azure Redis Basic: 256 max connections total
66
+ REDIS_CACHE_MAX_CONNECTIONS = config(
67
+ "REDIS_CACHE_MAX_CONNECTIONS", default=50, cast=int
68
+ )
69
+
70
+ pool_kwargs = {"max_connections": REDIS_CACHE_MAX_CONNECTIONS}
71
+ if REDIS_SSL:
72
+ pool_kwargs["ssl_cert_reqs"] = None
65
73
 
66
74
  CACHES = {
67
75
  "default": {
@@ -78,6 +86,14 @@ if REDIS_HOST is not None and not SKIP_DEFAULT_CACHE:
78
86
  "KEY_PREFIX": REDIS_PREFIX,
79
87
  }
80
88
  }
89
+
90
+ # Django cache health check uses the cache backend directly
91
+ # Only add Redis health check if REDIS_URL environment variable is set
92
+ # When using granular params, the cache check is sufficient
93
+ if config("REDIS_URL", default=None) is not None:
94
+ HEALTH_CHECK_APPS += ["health_check.contrib.redis"]
95
+ INSTALLED_APPS += ["health_check.contrib.redis"]
96
+
81
97
  print(f"Redis cache connection initialized")
82
98
  elif SKIP_DEFAULT_CACHE:
83
99
  print(
@@ -22,117 +22,118 @@ WORKER_IMMEDIATE_MODE = decouple.config(
22
22
  )
23
23
 
24
24
  # Detect if running as a worker process (via run_huey command)
25
- # Workers always need Huey configured regardless of DETACHED_WORKER setting
26
25
  IS_WORKER_PROCESS = any("run_huey" in arg for arg in sys.argv)
27
26
 
28
- # Skip Huey configuration only if:
29
- # 1. Running in detached worker mode (DETACHED_WORKER=True)
30
- # 2. AND not running as a worker process (IS_WORKER_PROCESS=False)
31
- # This ensures workers always get Huey configured, but API servers don't when detached
32
- if DETACHED_WORKER and not IS_WORKER_PROCESS:
33
- # API server in detached mode - skip Huey configuration
34
- HUEY = None
35
- else:
36
- # Either: worker process, or API server with embedded workers
37
- # Redis configuration - REDIS_URL takes precedence and supersedes granular env vars
38
- REDIS_URL = decouple.config("REDIS_URL", default=None)
39
-
40
- # Parse REDIS_URL or construct from individual parameters
41
- if REDIS_URL is not None:
42
- from urllib.parse import urlparse
43
-
44
- parsed = urlparse(REDIS_URL)
45
-
46
- # Extract values from REDIS_URL (these supersede granular env vars)
47
- REDIS_HOST = parsed.hostname
48
- REDIS_PORT = parsed.port or 6379
49
- REDIS_USERNAME = parsed.username or "default"
50
- REDIS_PASSWORD = parsed.password
51
-
52
- # Determine SSL from URL scheme (rediss:// means SSL is enabled)
53
- REDIS_SCHEME = (
54
- parsed.scheme if parsed.scheme in ("redis", "rediss") else "redis"
55
- )
56
- REDIS_SSL = REDIS_SCHEME == "rediss"
57
-
58
- else:
59
- # Fall back to individual parameters
60
- REDIS_HOST = decouple.config("REDIS_HOST", default=None)
61
- REDIS_PORT = decouple.config("REDIS_PORT", default=None)
62
- REDIS_PASSWORD = decouple.config("REDIS_PASSWORD", default=None)
63
- REDIS_USERNAME = decouple.config("REDIS_USERNAME", default="default")
64
- REDIS_SSL = decouple.config("REDIS_SSL", default=False, cast=bool)
65
-
66
- # Configure HUEY based on available Redis configuration
67
- if REDIS_HOST is not None:
68
- # Calculate max connections based on environment
69
- # Each worker replica needs: (workers_per_replica + 1 scheduler) connections
70
- # Formula: (worker_replicas * (threads_per_worker + 1)) + api_connections + buffer
71
- # Example: 100 connections = (5 replicas * (8 workers + 1 scheduler)) + 40 API + 15 buffer
72
- REDIS_MAX_CONNECTIONS = decouple.config(
73
- "REDIS_MAX_CONNECTIONS", default=100, cast=int
74
- )
75
-
76
- # Connection pool configuration with timeouts
77
- # Use BlockingConnectionPool to wait for available connections instead of failing immediately
78
- pool_kwargs = {
79
- "host": REDIS_HOST,
80
- "port": REDIS_PORT,
81
- "max_connections": REDIS_MAX_CONNECTIONS,
82
- "timeout": 20, # Wait up to 20 seconds for an available connection
83
- # Timeout settings to prevent hung connections
84
- "socket_timeout": 10, # Command execution timeout (seconds)
85
- "socket_connect_timeout": 10, # Connection establishment timeout (seconds)
86
- # Keep connections alive to prevent closure by firewalls/load balancers
87
- "socket_keepalive": True,
88
- # Retry on transient failures
89
- "retry_on_timeout": True,
90
- }
27
+ # Always configure Huey for both API servers and workers
28
+ # API servers need to enqueue tasks even when DETACHED_WORKER=True
29
+ # Only the worker pods will consume tasks
30
+ # Redis configuration - REDIS_URL takes precedence and supersedes granular env vars
31
+ REDIS_URL = decouple.config("REDIS_URL", default=None)
32
+
33
+ # Parse REDIS_URL or construct from individual parameters
34
+ if REDIS_URL is not None:
35
+ from urllib.parse import urlparse
36
+
37
+ parsed = urlparse(REDIS_URL)
91
38
 
92
- # Add TCP keepalive options if available (Linux/Unix only)
93
- try:
94
- pool_kwargs["socket_keepalive_options"] = {
95
- socket.TCP_KEEPIDLE: 60, # Start keepalive after 60s idle
96
- socket.TCP_KEEPINTVL: 10, # Keepalive interval
97
- socket.TCP_KEEPCNT: 3, # Keepalive probes before timeout
98
- }
99
- except AttributeError:
100
- # TCP keepalive constants not available on this platform
101
- pass
102
-
103
- # Add authentication if provided
104
- if REDIS_PASSWORD:
105
- pool_kwargs["password"] = REDIS_PASSWORD
106
- if REDIS_USERNAME:
107
- pool_kwargs["username"] = REDIS_USERNAME
108
-
109
- # Add SSL/TLS configuration if enabled
110
- if REDIS_SSL:
111
- # Use SSLConnection class for SSL/TLS connections
112
- pool_kwargs["connection_class"] = redis.SSLConnection
113
- pool_kwargs["ssl_cert_reqs"] = None # For Azure Redis compatibility
114
-
115
- # Use BlockingConnectionPool to wait for connections instead of raising errors immediately
116
- pool = redis.BlockingConnectionPool(**pool_kwargs)
117
-
118
- HUEY = huey.RedisHuey(
119
- "default",
120
- connection_pool=pool,
121
- **({"immediate": WORKER_IMMEDIATE_MODE} if WORKER_IMMEDIATE_MODE else {}),
122
- )
123
-
124
- else:
125
- # No Redis configured, use SQLite
126
- WORKER_DB_DIR = decouple.config("WORKER_DB_DIR", default=settings.WORK_DIR)
127
- WORKER_DB_FILE_NAME = os.path.join(WORKER_DB_DIR, "tasks.sqlite3")
128
-
129
- settings.DATABASES["workers"] = {
130
- "NAME": WORKER_DB_FILE_NAME,
131
- "ENGINE": "django.db.backends.sqlite3",
39
+ # Extract values from REDIS_URL (these supersede granular env vars)
40
+ REDIS_HOST = parsed.hostname
41
+ REDIS_PORT = parsed.port or 6379
42
+ REDIS_USERNAME = parsed.username or "default"
43
+ REDIS_PASSWORD = parsed.password
44
+
45
+ # Determine SSL from URL scheme (rediss:// means SSL is enabled)
46
+ REDIS_SCHEME = (
47
+ parsed.scheme if parsed.scheme in ("redis", "rediss") else "redis"
48
+ )
49
+ REDIS_SSL = REDIS_SCHEME == "rediss"
50
+
51
+ else:
52
+ # Fall back to individual parameters
53
+ REDIS_HOST = decouple.config("REDIS_HOST", default=None)
54
+ REDIS_PORT = decouple.config("REDIS_PORT", default=None)
55
+ REDIS_PASSWORD = decouple.config("REDIS_PASSWORD", default=None)
56
+ REDIS_USERNAME = decouple.config("REDIS_USERNAME", default="default")
57
+ REDIS_SSL = decouple.config("REDIS_SSL", default=False, cast=bool)
58
+
59
+ # Configure HUEY based on available Redis configuration
60
+ if REDIS_HOST is not None:
61
+ # Calculate max connections based on environment
62
+ # Each worker replica needs: (workers_per_replica + 1 scheduler) connections
63
+ # Formula: (worker_replicas * (threads_per_worker + 1)) + api_connections + buffer
64
+ # Example: 100 connections = (5 replicas * (8 workers + 1 scheduler)) + 40 API + 15 buffer
65
+ REDIS_MAX_CONNECTIONS = decouple.config(
66
+ "REDIS_MAX_CONNECTIONS", default=100, cast=int
67
+ )
68
+
69
+ # Connection pool configuration with timeouts
70
+ # Use BlockingConnectionPool to wait for available connections instead of failing immediately
71
+ pool_kwargs = {
72
+ "host": REDIS_HOST,
73
+ "port": REDIS_PORT,
74
+ "max_connections": REDIS_MAX_CONNECTIONS,
75
+ "timeout": 20, # Wait up to 20 seconds for an available connection
76
+ # Timeout settings to prevent hung connections
77
+ "socket_timeout": 10, # Command execution timeout (seconds)
78
+ "socket_connect_timeout": 10, # Connection establishment timeout (seconds)
79
+ # Keep connections alive to prevent closure by firewalls/load balancers
80
+ "socket_keepalive": True,
81
+ # Retry on transient failures
82
+ "retry_on_timeout": True,
83
+ }
84
+
85
+ # Add TCP keepalive options if available (Linux/Unix only)
86
+ try:
87
+ pool_kwargs["socket_keepalive_options"] = {
88
+ socket.TCP_KEEPIDLE: 60, # Start keepalive after 60s idle
89
+ socket.TCP_KEEPINTVL: 10, # Keepalive interval
90
+ socket.TCP_KEEPCNT: 3, # Keepalive probes before timeout
132
91
  }
92
+ except AttributeError:
93
+ # TCP keepalive constants not available on this platform
94
+ pass
95
+
96
+ # Add authentication if provided
97
+ if REDIS_PASSWORD:
98
+ pool_kwargs["password"] = REDIS_PASSWORD
99
+ if REDIS_USERNAME:
100
+ pool_kwargs["username"] = REDIS_USERNAME
101
+
102
+ # Add SSL/TLS configuration if enabled
103
+ if REDIS_SSL:
104
+ # Use SSLConnection class for SSL/TLS connections
105
+ pool_kwargs["connection_class"] = redis.SSLConnection
106
+ pool_kwargs["ssl_cert_reqs"] = None # For Azure Redis compatibility
107
+
108
+ # Use BlockingConnectionPool to wait for connections instead of raising errors immediately
109
+ pool = redis.BlockingConnectionPool(**pool_kwargs)
110
+
111
+ HUEY = huey.RedisHuey(
112
+ "default",
113
+ connection_pool=pool,
114
+ **({"immediate": WORKER_IMMEDIATE_MODE} if WORKER_IMMEDIATE_MODE else {}),
115
+ )
133
116
 
134
- HUEY = huey.SqliteHuey(
135
- name="default",
136
- filename=WORKER_DB_FILE_NAME,
137
- **({"immediate": WORKER_IMMEDIATE_MODE} if WORKER_IMMEDIATE_MODE else {}),
138
- )
117
+ else:
118
+ # No Redis configured, use SQLite
119
+ WORKER_DB_DIR = decouple.config("WORKER_DB_DIR", default=settings.WORK_DIR)
120
+ WORKER_DB_FILE_NAME = os.path.join(WORKER_DB_DIR, "tasks.sqlite3")
121
+
122
+ settings.DATABASES["workers"] = {
123
+ "NAME": WORKER_DB_FILE_NAME,
124
+ "ENGINE": "django.db.backends.sqlite3",
125
+ }
126
+
127
+ # SQLite-specific Huey configuration
128
+ # WAL mode (Write-Ahead Logging) enables better concurrency for multiple workers
129
+ # Increased timeout helps handle lock contention under concurrent access
130
+ HUEY = huey.SqliteHuey(
131
+ name="default",
132
+ filename=WORKER_DB_FILE_NAME,
133
+ # Storage-specific kwargs for better concurrent access handling
134
+ journal_mode="wal", # Enable Write-Ahead Logging for better concurrency
135
+ timeout=30, # Increase timeout to 30s to handle lock contention with multiple workers
136
+ cache_mb=16, # Increase cache size for better performance (default: 8MB)
137
+ fsync=False, # Disable forced fsync for better performance (default: False)
138
+ **({"immediate": WORKER_IMMEDIATE_MODE} if WORKER_IMMEDIATE_MODE else {}),
139
+ )
@@ -0,0 +1,3 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="1200" height="1200" xml:space="preserve" version="1.1" viewBox="0 0 1200 1200">
2
+ <image width="1200" height="1200" xlink:href=""/>
3
+ </svg>
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: karrio_server
3
- Version: 2025.5rc34
3
+ Version: 2025.5rc35
4
4
  Summary: Multi-carrier shipping API
5
5
  Author-email: karrio <hello@karrio.io>
6
6
  License-Expression: Apache-2.0
@@ -1,4 +1,4 @@
1
- karrio/server/VERSION,sha256=UvdnhEGXMLVD-es3uMQ4wsjc4zpHw83BPAZp3oKp7Rk,10
1
+ karrio/server/VERSION,sha256=VZI-cDaShOMOr-PyQc0yja5-0Yw3xGHcvsqv8Hu3E8Y,10
2
2
  karrio/server/__init__.py,sha256=iOEMwnlORWezdO8-2vxBIPSR37D7JGjluZ8f55vzxls,81
3
3
  karrio/server/__main__.py,sha256=hy2-Zb2wSVe_Pu6zWZ-BhiM4rBaGZ3D16HSuhudygqg,632
4
4
  karrio/server/asgi.py,sha256=LsZYMWo8U9zURVPdHnvUsziOhMjdCdQoD2-gMJbS2U0,462
@@ -6,13 +6,13 @@ karrio/server/workers.py,sha256=wOlWmXC7zRJV86IfbQnfUZsnCIvvWtXzFHH_EIkg1J0,179
6
6
  karrio/server/wsgi.py,sha256=SpWqkEYlMsj89_znZ8p8IjH3EgTVRWRq_9eS8t64dMw,403
7
7
  karrio/server/lib/otel_huey.py,sha256=6MP6vX6b6x6RPF2K1m8B8L8S9GK1Q3vANmLidsxh65k,5428
8
8
  karrio/server/settings/__init__.py,sha256=iw-NBcReOnDYpnvSEBdYDfV7jC0040jYdupnmSdElec,866
9
- karrio/server/settings/apm.py,sha256=fp9_CVzNfQ8MvNp1-WQbCILzLU3RSJeeu1vYAtdrgfs,7415
10
- karrio/server/settings/base.py,sha256=UbZ4pEBEKG0mJSlNED1iU9KEpNmrZjjmwdujwnQ30fI,22285
11
- karrio/server/settings/cache.py,sha256=nAHLgqynNtohxCJSMYP2RzcnBGC0ZC30KH6LlKdxgo4,3218
9
+ karrio/server/settings/apm.py,sha256=229sQB2TeE00fSAZHjzVmkttggOjlxTcIDoLTmSjFYY,7705
10
+ karrio/server/settings/base.py,sha256=ZD0bd949IpHdFkI5WSuQ2W8QIoRZx11DHwdVwUqVlMM,22931
11
+ karrio/server/settings/cache.py,sha256=0o6XLXjtRw3MU2iXQh7Ge9RDXyekIQcXy3Fp54in4Zo,3923
12
12
  karrio/server/settings/constance.py,sha256=wKi7u-NORAPjIJMIbl3k5kPRkUA6jJJWe9kxsV3aoeA,7113
13
13
  karrio/server/settings/debug.py,sha256=fFyK2XX47UGeK0eRNSV-9ZLaComay5QvJW0692vaH98,527
14
14
  karrio/server/settings/email.py,sha256=bHBLKM_v3HTkmjrz_Msdj_Z7_kMzAb7i6pvJCZuzu1E,1403
15
- karrio/server/settings/workers.py,sha256=Ey59-TQ2odW-e15Mf2OZjQSLzX3jNCnWMC7dy-T2A3o,5755
15
+ karrio/server/settings/workers.py,sha256=-pe9u1J5HCF1ZMHIYnHYJfdgJXd0Ix6vCLTr94kmsJs,5672
16
16
  karrio/server/static/extra/branding/android-chrome-192x192.png,sha256=qSwEKKBtk4udSHb0OWGC5-jfkP5cVpULDD1Cdkuk8PU,7005
17
17
  karrio/server/static/extra/branding/android-chrome-512x512.png,sha256=YFwVPnPChO30tTuyrwSc_z548H7C6OFXh4CCu2krvHA,21062
18
18
  karrio/server/static/extra/branding/favicon-16x16.png,sha256=wkELpij29bIvvKr5sDcjfNeYvj7i0yk-__bJbZckEK8,1085
@@ -51,6 +51,7 @@ karrio/server/static/karrio/carriers/sendle_icon.svg,sha256=nB9rYocCcMmhbLOEQRwS
51
51
  karrio/server/static/karrio/carriers/sendle_logo.svg,sha256=aGSpv81J0yOPiHILBvOJwxul3oXZXRi-5htWF9uzFX0,2157
52
52
  karrio/server/static/karrio/carriers/sf_express_icon.svg,sha256=WBdefSXLPQoo173gTpYU9AI17SkG9oQfqW6CYQ-FsVk,932
53
53
  karrio/server/static/karrio/carriers/sf_express_logo.svg,sha256=vWiauCZHEXbK8DOtbb1VBz2imuVMtzyih-k5J-HlhWQ,1449
54
+ karrio/server/static/karrio/carriers/teleship_icon.svg,sha256=9P25dvXAVzXR_Z0PDObzVYwhQcReIjyXC6E5_8vMrEs,32435
54
55
  karrio/server/static/karrio/carriers/tnt_icon.svg,sha256=WGwJmnV2J7U_RM6wdN7QdKrWt_W-ByuqLklinwxVLSI,1326
55
56
  karrio/server/static/karrio/carriers/tnt_logo.svg,sha256=43WZCdCbyA_U-wrs3xAOefwlrkfhagqskSTYzvnfWwE,1494
56
57
  karrio/server/static/karrio/carriers/ups_icon.svg,sha256=ZrLOdsfO-itwiUG9Q6nf6CgiCS35WViNqOBcYl7_Ox8,2058
@@ -73,8 +74,8 @@ karrio/server/templates/admin/base_site.html,sha256=kbcdvehXZ1EHaw07JL7fSZmjrnVM
73
74
  karrio/server/templates/openapi/openapi.html,sha256=3ApCZ5pE6Wjv7CJllVbqD2WiDQuLy-BFS-IIHurXhBY,1133
74
75
  karrio/server/urls/__init__.py,sha256=Ah-XqaqRsfecQgCGRHjxmXe8O7a0avq5ocU90tkVwQI,1998
75
76
  karrio/server/urls/jwt.py,sha256=QN2L-EpUEQCF2UGYPu_VVlA49Fc0BtcY7Ov3-xpp7_U,6772
76
- karrio_server-2025.5rc34.dist-info/METADATA,sha256=wwmvWTOS9_hybwmqLEB-DevkkDSdRNWsH2y1R_4Agso,4305
77
- karrio_server-2025.5rc34.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
78
- karrio_server-2025.5rc34.dist-info/entry_points.txt,sha256=c2eftt6MpJjyp0OFv1OmO9nUYSDemt9fGq_RDdvpGLw,55
79
- karrio_server-2025.5rc34.dist-info/top_level.txt,sha256=D1D7x8R3cTfjF_15mfiO7wCQ5QMtuM4x8GaPr7z5i78,12
80
- karrio_server-2025.5rc34.dist-info/RECORD,,
77
+ karrio_server-2025.5rc35.dist-info/METADATA,sha256=rBpbdffhVVkCl06K4eAM7zOE1ZJCtpmB1swDDQBtoI8,4305
78
+ karrio_server-2025.5rc35.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
79
+ karrio_server-2025.5rc35.dist-info/entry_points.txt,sha256=c2eftt6MpJjyp0OFv1OmO9nUYSDemt9fGq_RDdvpGLw,55
80
+ karrio_server-2025.5rc35.dist-info/top_level.txt,sha256=D1D7x8R3cTfjF_15mfiO7wCQ5QMtuM4x8GaPr7z5i78,12
81
+ karrio_server-2025.5rc35.dist-info/RECORD,,