Admin: offene Partner-Profil-Freigaben in 'Zu erledigen'-Leiste + ADMIN_EMAIL-Befund
Rene reichte ein Partner-Profil ein und sah als Admin nirgends einen Hinweis: 1. Action-Items kannten Partner-Profile nicht — partner_profiles_pending (submitted_at gesetzt, approved=0) jetzt im Endpoint + Chip im Admin-Kopf (Klick -> Partner-Tab). Test ergänzt (7 passed). 2. ADMIN_EMAIL fehlte in BEIDEN .env auf der DS (Prod+Staging) — damit wurden auch Upgrade-Anfragen-Mails still verschluckt (bekanntes Silent-Skip-Muster). Auf der DS nachgetragen; greift je beim nächsten Deploy.
This commit is contained in:
parent
73ca66bbf5
commit
a40aa183ec
8 changed files with 36 additions and 16 deletions
2
VERSION
2
VERSION
|
|
@ -1 +1 @@
|
|||
1254
|
||||
1255
|
||||
|
|
@ -152,6 +152,12 @@ async def action_items(user=Depends(require_mod)):
|
|||
).fetchone()[0]
|
||||
except Exception:
|
||||
invoices_unpaid = 0
|
||||
try:
|
||||
partner_profiles_pending = conn.execute(
|
||||
"SELECT COUNT(*) FROM partner_profiles WHERE submitted_at IS NOT NULL AND approved=0"
|
||||
).fetchone()[0]
|
||||
except Exception:
|
||||
partner_profiles_pending = 0
|
||||
return {
|
||||
"jobs_pending": jobs,
|
||||
"breeder_pending": breeders,
|
||||
|
|
@ -161,6 +167,7 @@ async def action_items(user=Depends(require_mod)):
|
|||
"users_today": users_today,
|
||||
"upgrades_pending": upgrades_pending,
|
||||
"invoices_unpaid": invoices_unpaid,
|
||||
"partner_profiles_pending": partner_profiles_pending,
|
||||
}
|
||||
|
||||
|
||||
|
|
|
|||
|
|
@ -86,14 +86,14 @@
|
|||
<title>Ban Yaro</title>
|
||||
|
||||
<!-- Theme + theme-color Statusleiste vor CSS setzen -->
|
||||
<script src="/js/boot-early.js?v=1254"></script>
|
||||
<script src="/js/boot-early.js?v=1255"></script>
|
||||
|
||||
<!-- CSS: Reihenfolge ist wichtig — ?v= zwingt Browser zur Neuladung -->
|
||||
<link rel="stylesheet" href="/css/design-system.css?v=1254">
|
||||
<link rel="stylesheet" href="/css/layout.css?v=1254">
|
||||
<link rel="stylesheet" href="/css/components.css?v=1254">
|
||||
<link rel="stylesheet" href="/css/utilities.css?v=1254">
|
||||
<link rel="stylesheet" href="/css/lists.css?v=1254">
|
||||
<link rel="stylesheet" href="/css/design-system.css?v=1255">
|
||||
<link rel="stylesheet" href="/css/layout.css?v=1255">
|
||||
<link rel="stylesheet" href="/css/components.css?v=1255">
|
||||
<link rel="stylesheet" href="/css/utilities.css?v=1255">
|
||||
<link rel="stylesheet" href="/css/lists.css?v=1255">
|
||||
</head>
|
||||
<body>
|
||||
|
||||
|
|
@ -612,11 +612,11 @@
|
|||
<div id="modal-container"></div>
|
||||
|
||||
<!-- JS: Reihenfolge ist wichtig — erst Basis, dann Features -->
|
||||
<script src="/js/api.js?v=1254"></script>
|
||||
<script src="/js/ui.js?v=1254"></script>
|
||||
<script src="/js/app.js?v=1254"></script>
|
||||
<script src="/js/worlds.js?v=1254"></script>
|
||||
<script src="/js/offline-indicator.js?v=1254"></script>
|
||||
<script src="/js/api.js?v=1255"></script>
|
||||
<script src="/js/ui.js?v=1255"></script>
|
||||
<script src="/js/app.js?v=1255"></script>
|
||||
<script src="/js/worlds.js?v=1255"></script>
|
||||
<script src="/js/offline-indicator.js?v=1255"></script>
|
||||
|
||||
<!-- Feature-Seiten werden lazy geladen -->
|
||||
|
||||
|
|
@ -626,7 +626,7 @@
|
|||
|
||||
|
||||
<!-- Boot: Offline-Banner + SW-Registration (extrahiert für CSP) -->
|
||||
<script src="/js/boot.js?v=1254"></script>
|
||||
<script src="/js/boot.js?v=1255"></script>
|
||||
|
||||
|
||||
</body>
|
||||
|
|
|
|||
|
|
@ -3,7 +3,7 @@
|
|||
Router, State-Management, Navigation, Initialisierung.
|
||||
============================================================ */
|
||||
|
||||
const APP_VER = '1254'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
|
||||
const APP_VER = '1255'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
|
||||
const APP_VERSION = '1.6.0'; // ← semantische Version, wird bei make release gesetzt
|
||||
window.APP_VER = APP_VER; // global verfügbar für andere Module (z.B. offline-indicator)
|
||||
window.APP_VERSION = APP_VERSION;
|
||||
|
|
|
|||
|
|
@ -123,6 +123,7 @@ window.Page_admin = (() => {
|
|||
{ key: 'fotos_pending', label: 'Foto-Einreichungen',tab: 'moderation', icon: 'image' },
|
||||
{ key: 'poi_edits_pending', label: 'POI-Korrekturen', tab: 'moderation', icon: 'map-pin' },
|
||||
{ key: 'invoices_unpaid', label: 'Offene Rechnungen', tab: 'rechnungen', icon: 'receipt' },
|
||||
{ key: 'partner_profiles_pending', label: 'Partner-Profile', tab: 'partner', icon: 'handshake' },
|
||||
];
|
||||
|
||||
const open = items.filter(i => d[i.key] > 0);
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@
|
|||
<meta charset="UTF-8">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0">
|
||||
<meta name="color-scheme" content="light dark">
|
||||
<script src="/js/landing-init.js?v=1254"></script>
|
||||
<script src="/js/landing-init.js?v=1255"></script>
|
||||
<title>Ban Yaro — Die Hunde-App für Deutschland, Österreich & Schweiz</title>
|
||||
<meta name="description" content="Ban Yaro: Die kostenlose All-in-One Hunde-App für DACH. Tagebuch, Giftköder-Alarm, Training mit KI, Forum, Wurfbörse, Stammbaum, Inzucht-Check — DSGVO-konform, offline-fähig, direkt im Browser.">
|
||||
<meta name="keywords" content="Hunde App, Hunde Community, Wurfbörse, Züchter, Welpen kaufen, Stammbaum Hund, Inzuchtkoeffizient, Hundezucht, Impfpass Hund, Giftköder Alarm, Gassi Community, Hundetraining App, Hunde Forum, Hunde KI, Hundefilm Datenbank, Welpen Marktplatz">
|
||||
|
|
|
|||
|
|
@ -4,7 +4,7 @@
|
|||
============================================================ */
|
||||
|
||||
// ← EINZIGE Stelle für die Version — STATIC_ASSETS und CACHE_VERSION leiten sich ab
|
||||
const VER = '1254';
|
||||
const VER = '1255';
|
||||
const CACHE_VERSION = `by-v${VER}`;
|
||||
const CACHE_STATIC = `${CACHE_VERSION}-static`;
|
||||
const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten
|
||||
|
|
|
|||
|
|
@ -136,6 +136,18 @@ def test_heic_uploads_convert(client, user):
|
|||
assert r.json()["photos"][0].endswith(".webp")
|
||||
|
||||
|
||||
def test_submit_appears_in_admin_action_items(client, user, admin):
|
||||
"""Eingereichtes Profil taucht im Admin-'Zu erledigen'-Zaehler auf."""
|
||||
_make_partner(user["email"])
|
||||
client.put("/api/partner/my-profile", headers=user["headers"],
|
||||
json={"display_name": "Action-Item-Test"})
|
||||
before = client.get("/api/admin/action-items", headers=admin["headers"]).json()
|
||||
r = client.post("/api/partner/my-profile/submit", headers=user["headers"], json={})
|
||||
assert r.status_code == 200
|
||||
after = client.get("/api/admin/action-items", headers=admin["headers"]).json()
|
||||
assert after["partner_profiles_pending"] == before.get("partner_profiles_pending", 0) + 1
|
||||
|
||||
|
||||
def test_partner_has_pro_access(client, user):
|
||||
"""is_partner=1 -> has_pro_access True (Pro gratis fuer Partner)."""
|
||||
from auth import has_pro_access
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue