Changelog

What is new on the ToRun platform, newest first.

v@release.Version

minor
14 juin 2026

June 2026 — 53 changes

  • Added
    Encore plus de modèles d'image et de vidéo à votre disposition

    Le sélecteur de modèles intègre désormais Google Imagen et Gemini pour les images, ainsi qu'OpenAI Sora et Google Veo pour la vidéo, en plus des modèles que vous connaissez déjà. Choisissez précisément celui qu'il vous f…

  • Added
    Les workflows IA sans code et le Marketplace des créateurs sont arrivés

    Enchaînez plusieurs étapes IA dans un Workflow que vous lancez quand vous voulez, puis publiez-le sur le Marketplace ou explorez les créations partagées par d'autres créateurs. Le Workflow Editor, le Runner et le Marketp…

  • Added
    Installez ToRun sur votre téléphone

    Ajoutez ToRun à votre écran d'accueil et ouvrez-le comme une véritable application : en plein écran, avec sa propre icône. ToRun n'est plus qu'à un geste, en attendant l'application mobile.

  • Added
    Un nouveau look pour ToRun.ai

    Un nouveau logo et une identité visuelle épurée dans toute l'application, parfaitement adaptés aux thèmes clair et sombre.

  • Added
    Des réponses plus pertinentes et plus personnelles

    Choisissez le niveau de réflexion de l'IA, désormais même en mode Auto. Vos prompts d'image peuvent discrètement puiser dans votre mémoire enregistrée pour des résultats fidèles aux personnes et aux détails qui comptent…

  • Fixed
    Un studio image, vidéo et musique plus clair

    La progression de la génération s'affiche désormais juste à côté du résultat plutôt que sous le formulaire, chaque page s'ouvre épurée, et votre dernière création reste au premier plan tandis que les plus anciennes rejoi…

  • Fixed
    Un portefeuille plus lisible et une Library plus fluide

    L'historique de votre portefeuille est maintenant paginé et affiche les montants exacts, au centime près, et la suppression d'éléments de votre Library ne génère plus d'erreur.

  • Added
    Devenez annonceur en toute autonomie

    Créez votre compte annonceur et soumettez vos campagnes à validation directement depuis votre compte, sans attendre de configuration manuelle.

  • Fixed
    Fiabilité, exactitude de la facturation et sécurité renforcée

    En coulisses : un décompte des crédits gratuits plus équitable, des contrôles renforcés sur les versements et les autorisations des créateurs, une modération des médias plus sûre, et des exécutions de Workflow plus fiabl…

  • Added
    Un deuxième moteur de traduction en direct, avec 77 langues

    La traduction en direct vous laisse désormais choisir entre deux moteurs et opter pour celui qui convient le mieux à votre conversation — y compris une nouvelle option qui parle 77 langues, dont le turc et le russe. Chaq…

  • Added
    Un sélecteur de modèles plus clair — et davantage de modèles sur le Free plan

    Les modèles que votre forfait ne couvre pas apparaissent maintenant avec un petit cadenas et un moyen, en un seul appui, de passer à un forfait supérieur ou de recharger votre portefeuille, au lieu d'échouer seulement ap…

  • Added
    Votre assistant se souvient des images que vous partagez

    Partagez une image une seule fois et l'assistant garde en mémoire ce qu'il a vu pour le reste de la conversation — vous pouvez ainsi l'interroger à son sujet bien des échanges plus tard, même après avoir changé de modèle…

  • Added
    Diagrammes, tableaux et mise en forme plus soignée dans le chat

    Les réponses du chat dessinent désormais les diagrammes comme de vrais diagrammes, présentent les tableaux avec des bordures nettes et adaptent la taille des titres au message au lieu d'envahir l'écran — pour des réponse…

  • Fixed
    Toujours clair quand quelque chose n'est pas couvert — jamais d'impasse

    Lorsqu'un modèle nécessite une mise à niveau ou que votre solde est insuffisant, vous voyez maintenant un message convivial avec des boutons Mettre à niveau le forfait et Recharger le portefeuille directement à portée de…

  • Fixed
    Les heures s'affichent désormais dans votre propre fuseau horaire

    Les enregistrements de facturation, l'historique et l'activité s'affichent maintenant à votre heure locale plutôt qu'en UTC, pour que les horodatages correspondent à l'horloge de votre mur.

  • Fixed
    Une liste de conversations plus ordonnée

    Démarrer une nouvelle conversation réutilise désormais une conversation vide au lieu d'empiler les pages blanches, les conversations restées sans réponse n'encombrent plus votre liste, et les titres provisoires sont remp…

  • Added
    Faites de la publicité sur ToRun

    Les entreprises peuvent désormais créer un compte annonceur et mener leurs propres campagnes publicitaires de bout en bout — créer des campagnes, y ajouter les visuels publicitaires correspondants et les soumettre à une…

  • Added
    Utilisez votre propre clé API pour la voix et la traduction en direct

    Apporter votre propre clé de fournisseur couvre désormais aussi la voix en temps réel, la traduction en direct et la transcription en direct : l'utilisation de l'IA passe par votre propre clé et nous ne facturons que les…

  • Fixed
    Site public rafraîchi, imports plus sûrs et inscription plus fluide

    Nos pages publiques s'appuient désormais sur un contenu modifiable dans de nombreuses langues, les images importées sont analysées à la recherche de contenus dangereux avant d'être stockées, la création de compte et les…

  • Added
    Les conversations continuent de répondre, même quand vous changez de page

    Les réponses longues s'exécutent désormais sur le serveur et se poursuivent pendant que vous passez d'une conversation à l'autre, ouvrez une autre page ou fermez l'onglet. Revenez quand vous voulez : la réponse est encor…

  • Added
    Les projets donnent désormais à chaque conversation le bon contexte

    Les conversations lancées dans un projet reprennent automatiquement ses instructions, ses connaissances importées et sa mémoire, affichent un badge de projet avec un lien de retour rapide et indiquent le nom du projet da…

  • Added
    Une mémoire qui comprend le temps — et que vous pouvez modifier

    La mémoire de votre assistant suit désormais la vitesse à laquelle chaque information évolue et signale celles qui risquent d'être obsolètes, afin de s'appuyer sur ce qui reste vrai. Un nouvel éditeur vous permet de cons…

  • Added
    Les tout derniers modèles, ainsi que des pages dédiées Traduire et Transcrire

    Nous avons ajouté les derniers modèles d'image, de vidéo, de transcription et de voix en temps réel, et ouvert des pages indépendantes Traduire et Transcrire pour que vous accédiez à ces outils directement depuis le menu…

  • Added
    Traducteur vocal en direct

    Parlez et laissez vos mots être traduits presque instantanément : choisissez deux langues, intervertissez-les d'un simple geste, et le traducteur capte votre voix et diffuse la traduction au fil de votre discours.

  • Added
    Un studio vidéo plus clair et plus honnête

    La page vidéo garde désormais ses vignettes synchronisées lorsque vous supprimez un élément depuis votre bibliothèque, vous laisse définir la durée du clip par modèle, supprimer des clips individuels et marque clairement…

  • Fixed
    Un assistant intégré plus abouti

    L'assistant intégré affiche désormais des réponses joliment mises en forme, garde le dernier message visible pendant la saisie, enregistre de façon fiable la réponse terminée et donne à chaque conversation un titre autom…

  • Fixed
    Les réponses du chat s'affichent de façon fiable : liens, formules et devises

    Les réponses contenant des liens, des formules mathématiques ou des montants en devises ne s'affichent plus vides ou à moitié affichées, même après l'actualisation de la page, et les réponses de recherche approfondie inc…

  • Fixed
    Fiabilité, exactitude de la facturation et renforcement de la sécurité

    Un vaste chantier en coulisses : un suivi de la consommation et des totaux de dépenses plus précis, des remboursements automatiques plus équitables, une messagerie en temps réel plus solide, des protections renforcées de…

  • Fixed
    Lisez le blog et les contenus de la communauté sans vous connecter

    Les articles de blog publics et les discussions du forum — y compris leurs réactions et leurs réponses — sont désormais visibles par les visiteurs non connectés.

  • Fixed
    Une tarification plus claire et une gamme de modèles épurée

    L'utilisation est désormais facturée avec une marge unique et équitable, vos jauges de dépenses mensuelles et de budget restant sont exactes, et la liste des modèles a été nettoyée — modèles obsolètes retirés et nouveaux…

  • Added
    Les annonces et offres groupées de la marketplace affichent désormais une image de couverture

    Les annonces de workflow et les offres groupées peuvent afficher une véritable image de couverture, rendant la marketplace plus agréable et plus facile à parcourir.

  • Added
    Votre assistant intégré peut désormais agir à votre place

    Demandez à l'assistant et il remplit les formulaires, clique sur les boutons et se déplace dans l'application pour vous — porté par une boîte à outils élargie qui couvre maintenant le contact, la FAQ, le forum, la mémoir…

  • Added
    L'assistant tape sa réponse en direct, dans une bulle que vous pouvez déplacer

    Les réponses s'affichent désormais mot à mot au lieu d'apparaître d'un coup, et la bulle de l'assistant peut être glissée où bon vous semble, avec un aperçu en direct de ce sur quoi il travaille.

  • Fixed
    Créez et organisez vos projets sans accroc

    Créer un projet et y démarrer une nouvelle discussion fonctionne désormais sans heurts, pour garder ensemble les discussions, fichiers et contextes qui vont de pair.

  • Fixed
    Vidéos, avatars et messages vocaux plus fluides

    Les vidéos se lisent de manière fiable, les médias privés se chargent via un proxy sécurisé, les avatars des créateurs et des personas s'affichent maintenant pour tout le monde, et les messages vocaux sont transcrits san…

  • Fixed
    Des avis d'état du service plus clairs

    Lorsqu'une partie du service rencontre un problème, l'avis est désormais plus facile à comprendre et n'expose plus les noms des fournisseurs internes.

  • Added
    Connectez vos applications préférées à l'assistant

    Reliez des applications externes via une simple connexion ou une clé API, pour que l'assistant travaille directement avec les outils que vous utilisez déjà.

  • Fixed
    Génération et retouche d'images plus fiables

    Les outils d'image choisissent désormais un modèle adapté à ce que vous faites, affichent un aperçu intégré instantané du résultat, et la retouche fonctionne à nouveau après un changement de modèle chez le fournisseur.

  • Fixed
    Un fichier supprimé ne casse plus vos discussions ni votre galerie

    Lorsqu'une image ou une pièce jointe a été supprimée, votre historique de discussion, votre galerie multimédia et l'éditeur d'images affichent désormais un espace réservé convivial au lieu de s'arrêter sur une erreur.

  • Added
    Traduisez dans environ 100 langues

    Le traducteur propose désormais un sélecteur avec recherche, comptant une centaine de langues, chacune indiquée par son nom natif et son nom anglais.

  • Added
    De nouveaux articles de blog et discussions de la communauté

    Nous avons ajouté une série de nouveaux articles de blog et de fils de forum — y compris des questions avec réponse — pour avoir davantage à lire et à explorer dès le premier jour.

  • Added
    Nouveaux outils intégrés au chat : fichiers, code, images, synthèse vocale et bien plus

    Le chat peut désormais effectuer des recherches dans vos fichiers téléversés, exécuter Python dans un bac à sable, modifier des images, transcrire et lire de l'audio, et déclencher vos workflows — le tout sans quitter la…

  • Added
    Recherche web et recherche approfondie, avec citations

    Laissez le chat effectuer des recherches sur le web en direct, conduire des recherches approfondies multi-sources, récupérer et lire des pages entières — chaque réponse est accompagnée des sources utilisées.

  • Added
    Un chat qui se souvient — et oublie sur demande

    Votre assistant conserve désormais une mémoire légère entre les chats, peut lister ce qu'il retient, et respecte une demande d'oubli dans n'importe quelle langue.

  • Added
    Créez images, vidéos et musique dans un seul studio

    Générez et retouchez des images, produisez de courts métrages et composez des chansons avec paroles — propulsés par de nouveaux moteurs d'image, de vidéo et de musique, avec un sélecteur de médias partagé et votre biblio…

  • Added
    Mode voix temps réel

    Parlez à ToRun à voix haute — une nouvelle capacité vocale temps réel apporte les conversations orales et la transcription en direct au chat.

  • Added
    Workflows : exécutions qualité-first, approbations et reprise

    Les exécutions de workflows privilégient désormais des modèles de qualité supérieure, marquent une pause pour votre approbation lorsque c'est important, et peuvent être annulées, régénérées et reprises — chaque résultat…

  • Added
    Projets : organisez votre travail

    Regroupez les chats, fichiers et contextes connexes dans des Projets pour que votre assistant dispose toujours du bon contexte pour la tâche en cours.

  • Added
    Canvas : un espace de travail côte à côte

    Rédigez et itérez sur du contenu long format et du code dans un panneau canvas dédié, directement à côté de votre chat.

  • Added
    Des conversations plus longues et plus intelligentes

    Les résumés glissants, les fenêtres de contexte plus intelligentes et le défilement accéléré de l'historique maintiennent la cohérence et la fluidité des longues conversations, avec des commandes claires lorsqu'un échang…

  • Added
    Facturation honnête et transparente

    Une allocation gratuite bienveillante qui se recharge sur une fenêtre glissante, des jauges de dépenses plus claires, des remboursements automatiques en cas d'échec de génération d'image ou de vidéo, et des contrôles d'e…

  • Added
    Un catalogue de modèles plus complet et toujours à jour

    Des dizaines de modèles 2026 ont été ajoutés et les anciens retirés, plus une synchronisation automatique quotidienne qui maintient les modèles des fournisseurs et les tarifs à jour — gérés depuis un nouveau catalogue d'…

  • Added
    Partagez vos meilleures conversations

    Publiez une conversation via un lien public et faites grandir la communauté autour de ce que vous créez.

v@release.Version

minor
31 mai 2026

May 2026 — 499 changes

  • Changed
    52-Q-SMOKE-HARNESS: suite de tests de fumée de bout en bout reproductible + premier rapport de régression

    Harnais console .NET autonome (test/ToRun.SmokeTests) qui s'authentifie auprès de l'hôte en cours d'exécution (grant par mot de passe OpenIddict) et teste chaque capacité principale de bout en bout via la vraie API HTTP…

  • Fixed
    52-Q-AI-MEDIA-ACCESS: lecture Bunny authentifiée pour tous les accès médias dans le pipeline

    Les médias de la plateforme résident dans une zone de stockage Bunny PRIVÉE, donc un simple

  • Added
    52-Q-MEMORY-CHAT: outil memory_list + oubli indépendant de la langue

    Complète la fonctionnalité de gestion de la mémoire pilotée par le chat, en s'appuyant sur

  • Fixed
    52-Q-MEMORY-FORGET-I18N: correspondance par repli Unicode indépendante de la langue + repli sémantique

    memory_forget renvoyait no_match pour des souvenirs qui existaient pourtant.

  • Fixed
    52-Q-GEMINI-FLASH-400: augmenter le seuil bas de flash thinkingBudget 128->512 + journalisation du corps HTTP 400 Google

    gemini-2.5-flash a commencé à renvoyer HTTP 400 sur thinkingBudget=128 (le minimum 52-N

  • Fixed
    52-Q-MODEL-MENU: regroupement du catalogue de modèles + de l'intégration sous le groupe de navigation ByokVault

    Les deux pages d'administration hôte (/admin/model-catalog, /admin/model-onboarding)

  • Fixed
    52-Q-MODEL-SYNC-DEDUP: ignorer les variantes de modèles à instantané daté lors de la découverte

    La découverte ne correspondait que par ProviderModelId/ModelKey exact, ce qui faisait remonter des instantanés datés de fournisseurs

  • Changed
    52-Q-CHAT-EFFORT-UX-LOCALE: propagation du texte effort verrouillé + WalletCta vers 28 locales

    La porte d'accès à l'effort de raisonnement est désormais basée sur le financement, et non sur l'abonnement.

  • Added
    52-Q-MODEL-SYNC-AI: repli AI de parsing de page de tarification pour la synchronisation de modèles

    Fusion best-of-both dans la synchronisation 52-Q-MODEL-SYNC-JOB déjà déployée : quand OpenRouter

  • Fixed
    52-Q-CHAT-EFFORT-UX: porte d'effort consciente du portefeuille/financement

    Le sélecteur d'effort de raisonnement était verrouillé dur sur l'abonnement avec une exemption admin/hôte issue d'une approche antérieure rejetée.

  • Changed
    52-Q-MODEL-SYNC-JOB: recherche sur la synchronisation des fournisseurs + carte d'architecture

    Livrable de la phase 1 : inventaire de la liste des 26-provider et de leurs sources de tarification, le

  • Added
    52-Q-MODEL-ONBOARDING: gestion du catalogue de modèles par l'admin hôte (liste/modification/suppression)

    L'assistant d'intégration (phases A-D) ne fait que CRÉER des entrées dans le catalogue ; il n'existait aucune

  • Added
    52-P-SHARE: surface de partage public + croissance communautaire

    Backend (torun.agent) : SharedChat gagne IsListed/ListedSlug/ListedAt + les champs de carte dénormalisés ; PublicCommunityAppService + PublicCommunityController (fil /community anonyme + visualiseur par slug) ; Community…

  • Fixed
    52-Q-CHAT-AUDIO-BRIDGE: transcription de l'audio téléversé + réparation du lecteur audio

    Les pièces jointes audio dans le chat étaient cassées ; les véritables causes profondes différaient de

  • Fixed
    52-Q-CHAT-CONTEXT-SLASH: persistance du mode de débordement de contexte + préréglages slash pour une UX honnête

    PARTIE 1 — le menu déroulant « Gestion du débordement de contexte » dans l'en-tête de chat était bloqué sur

  • Fixed
    52-Q-BUDGET-BUILD: supprimer la référence orpheline IsCurrentMonth vers BudgetBucketCacheItem.DailyKey supprimé

    La suppression du plafond journalier (84178afab) a retiré DailyKey/MonthlyKey de BudgetBucketCacheItem

  • Changed
    52-Q-SMOKE-INTEG: correction du plancher Mongo (doublon _id AiModels + durée de vie txn UoW) + test d'intégration d'isolation de transport ResolveAsync

    Partie 1 — corriger le plancher des tests d'intégration MongoDB.

  • Changed
    52-Q-CHAT-EFFORT-LOCALE: propagation de 7 clés ChatComposer:Effort vers 28 locales

    Les chaînes du sélecteur d'effort de raisonnement (Effort:Tooltip, Effort:Locked:Tooltip,

  • Added
    52-Q-CHAT-EFFORT: sélecteur d'effort de raisonnement par modèle câblé de bout en bout

    Contrôle d'effort de raisonnement canonique et indépendant du fournisseur sur le compositeur de chat,

  • Changed
    52-Q-BUDGET-DAILYCAP-REMOVE: suppression du plafond journalier inerte + des minutes actives

    Passe finale de suppression du code mort après la réécriture du budget en fenêtre de session.

  • Changed
    52-Q-MONTHLY-SPEND-FIX: correction des commentaires sur la source de dépenses + documentation XML vers la télémétrie UserDailySummary

    La jauge Dépenses mensuelles/journalières lit la télémétrie UserDailySummary (ScopeKey=userId,

  • Changed
    52-Q-BUDGET-DEADCFG: suppression des boutons de configuration Allowance devenus inactifs

    Suivi d'audit de la réécriture du budget en fenêtre de session (2a33fd31f).

  • Fixed
    52-Q-BUDGET-BUCKET-GAUGE-ZERO: affichage de la capacité de session configurée en cas de cache-miss sur le bucket

    La jauge budget-bucket sur l'accueil (/) + me-home affichait "$0.00 / 0% / $0.00" à chaque fois

  • Added
    52-Q-BUDGET-HUMANE: allocation gratuite sur fenêtre de session glissante (capacité $0.20 / 5h)

    Le bucket budgétaire du niveau gratuit fonctionnait sur un modèle de goutte-à-goutte "$2 / 30d / 24h" : rechargement = $2/720/h et

  • Fixed
    52-Q-BUDGET-BUCKET-GAUGE-UX: jauge de budget lisible — précision 4 décimales + indication de période de rafale gratuite

    Les jauges BUDGET BUCKET sur l'accueil (/) et me-home (/me) affichaient "$0.00 (2% / $0.01)" :

  • Fixed
    52-Q-CHAT-HISTORY-VISION-LEAK: suppression des parties image de l'historique pour les modèles texte uniquement

    Bug de vision multi-tour.

  • Changed
    52-Q-SMOKE: verrouillage de la classification du routage temps réel + raisonnement (gardes sans DB)

    Première mise en place de verrous de régression dans la couche smoke.

  • Added
    52-Q-INVOCATION-PROTOCOL: isolation du transport des modèles par rapport au routage de complétion

    Correction de la cause profonde des 404 récurrents sur la génération de titre / chat public / vision : capacité

  • Fixed
    52-Q-VISION-BRIDGE: exclusion des SKU temps réel du routage vision basé sur la complétion — VÉRIFIÉ

    L'utilisateur a confirmé que la description d'image fonctionne désormais.

  • Fixed
    52-Q-CHAT-IMG-PROXY: vérification de l'appartenance des pièces jointes via la chaîne ChatMessageId

    La portée propriétaire renvoyait 403 même pour le vrai propriétaire du chat : les pièces jointes créées par le gestionnaire

  • Fixed
    slice52-Q-CHAT-IMG-PROXY: rendu des images de l'historique du chat via le proxy de flux backend (correction Bunny 503)

    Cause profonde A3 RÉELLE (découverte par test navigateur en direct) : l'image de la pièce jointe au chat

  • Changed
    slice52-Q-AUDIT: journal d'audit des bugs critiques du pipeline — cycle DI C1 corrigé, Quartz M1 prescrit, TODO par pipeline

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Fixed
    slice52-Q-QUEUE-DI-CYCLE: rupture du cycle DI du dispatcher en file d'attente via une dépendance lazy sur l'outil d'exécution de workflow

    La résolution de IQueuedRequestDispatcher provoquait un StackOverflow au démarrage (impossible à intercepter — un

  • Fixed
    slice52-Q-LOG-ROLLING: rotation + plafonnement du sink de fichier Serilog (mourait silencieusement à 1 GB)

    Le sink de journalisation de l'environnement d'exécution Host (appsettings.json) et les loggers d'amorçage

  • Fixed
    slice52-Q-CHANGELOG-IDEMPOTENT: indexation de la seed du changelog sur Slug, pas ExternalId (correction permanente E11000)

    Cause profonde récurrente : ChangelogBackfillDataSeedContributor testait l'idempotence sur

  • Changed
    slice52-Q-CHANGELOG: rétro-remplissage du changelog de sprint + clés 29 locales (93 nouveaux sprints)

    Exécution de extract-sprint-changelog.py + propagate-changelog-locales.py depuis main :

  • Fixed
    slice52-Q-QUEUE-DI-CRASH: gate dispatcher resolution behind non-empty queue

    QueuedRequestRunner.DoWorkAsync resolved IQueuedRequestDispatcher at the TOP of

  • Added
    slice52-Q-CHAT-CTX-WINDOW-CLAMP: clamp context budget to model window (covers tier-budget > window gap)

    The chat overrun check compared raw history tokens against the TIER budget (ctxBudget.MaxInputTokens) only, so when the tier budget exceeded the routed model's context window the trim was skipped: e.g.

  • Changed
    slice52-Q-PROACTIVE-CONCERN/locale: fan out 29 concern-toast keys to 28 siblings

    Proactive "concern toast" (Honest-UX DNA pattern #3).

  • Changed
    slice52-Q-CHAT-WALLET-OVERRIDE/locale: fan out overrun + ContextOverrun keys to 28 siblings

    Translate the 16 Chat:Context:* (Agent resource) overrun-prompt/footer/toast keys and the 13 MySettings:ContextOverrun:* (ToRun resource) settings keys from en.json into all 28 sibling locales (en-GB verbatim).

  • Changed
    slice52-Q-HUMANE-ERRORS/locale: fan out 70 StatusBanner + Error keys to 28 siblings

    Propagate the EN-only humane-error + status-banner keys (ErrorHumanizerService

  • Added
    slice52-Q-CHAT-CANVAS/frontend: canvas proxy + side-panel surface

    Phase B surface for the chat-canvas (ChatGPT Canvas / Claude Artifacts

  • Changed
    slice52-Q-PROACTIVE-CONCERN: EN keys for concern toast + settings opt-out + admin effectiveness panel

    Honest-UX DNA pattern #3.

  • Added
    slice52-Q-CHAT-WALLET-OVERRIDE: per-chat overrun PATCH endpoint + Agent locale keys

    Completes the wallet-funded context-overrun feature.

  • Changed
    slice52-Q-LEARNING-LOOP/locale: fan out 10 Admin/Permission UserExperience keys to 28 siblings

    Propagates LEARNING-LOOP Phase 2 keys (Admin:UserExperience:ComplaintLoop:{Tab,Title,Subtitle,FixedInWindow} + Admin:UserExperience:TimeToFix:Empty) plus 5 earlier EN-only Permission:UserExperience.* strings from the sam…

  • Fixed
    slice52-Q-BUILD-GREEN: resolve cross-chip integration errors blocking main build

    Four parallel 52-Q chips landed code referencing symbols their sibling chips

  • Changed
    slice52-Q-CHAT-CANVAS/locale: fan out 28 Canvas/Artifacts + Chat:Summary keys to 28 siblings

    Closes the 29-locale parity gap for the CHAT-CANVAS / ChatSummaries slices,

  • Added
    slice52-Q-LEARNING-LOOP/phase2-dashboard: admin ComplaintLink panel

    Phase 2 Scope B of the honest-UX-DNA pattern #5 loop.

  • Added
    slice52-Q-AUTO-REFUND/frontend: refund toast + /me/billing highlight + /me/wallet badge

    Honest UX DNA pattern #2 (Reversibility) — make the auto-refund VISIBLE.

  • Added
    slice52-Q-AUTO-REFUND/dispatcher: two consumers on torun.billing.refunded.v1

    Honest UX DNA pattern #2 (Reversibility) — wire the projection layer

  • Added
    slice52-Q-AUTO-REFUND/triggers: wire RefundAsync at image/video failure points

    Honest UX DNA pattern #2 (Reversibility) — refund the user when something

  • Added
    slice52-Q-AUTO-REFUND/api: IMyRefundAppService + DTOs + 5-min cache

    Honest UX DNA pattern #2 (Reversibility) — user-facing read API for the

  • Changed
    slice52-Q-AUTO-REFUND/locale: EN strings + PublicChangelogEntry

    EN-only this commit — the paired slice52-Q-AUTO-REFUND-LOCALE chip fans

  • Added
    slice52-Q-AUTO-REFUND/entity: AutoRefundLog entity + EnAutoRefundTrigger enum

    Honest UX DNA pattern #2 (Reversibility) — append-only audit row for

  • Changed
    slice52-Q-CHAT-PROJECTS/locale: Projects keys across 29 locales + de/zh JSON hotfix

    Paired locale fan-out for the /me/projects feature (components landed in

  • Added
    52-Q-voice-realtime-catalog: EnBillingSource.RealtimeVoice + seed de capacité voice-realtime + jointure

    EnBillingSource.RealtimeVoice + seed de la capacité voice-realtime + jointure

  • Added
    slice52-Q-HUMANE-ERRORS: humane error surfaces (honest-UX DNA #1 Şeffaflık)

    Backend exception → frontend humane message + retry hint + status banner.

  • Fixed
    slice52-Q-CHAT-CANVAS: dedup ChatSummaries collection + add Volo.Abp.Authorization using

    Consolidator landed both 52-Q-CHAT-CONTEXT-BUILDER's ChatSummaries

  • Added
    52-Q-voice-realtime-locale: déploiement en éventail de 25 clés du mode voix vers 28 langues soeurs

    Miroir des clés UI du mode voix temps réel ajoutées à en.json dans

  • Changed
    slice52-Q-USER-SENTIMENT-LOCALE: Privacy Policy Section 11 + UX dashboard keys in ar, hi, zh-Hans, zh-Hant, ja (5 locales)

    Native translations of the 40-key User Sentiment / Privacy Policy v3 Section 11 block (legal text per GDPR Art.

  • Added
    slice52-Q-CHAT-PROJECTS: Suite-managed file edits (Permissions+MongoDB+ChatPipeline)

    Suite-managed file edits (Permissions+MongoDB+ChatPipeline)

  • Changed
    slice52-Q-consolidate-2: land additional parallel-chip WIP

    land additional parallel-chip WIP

  • Changed
    slice52-Q-consolidate: land stashed parallel-chip WIP onto main

    Consolidates the working-tree state stashed during the

  • Added
    slice52-Q-CHAT-SUMMARY-SERVICE: rolling chat summary service + ChatSummary entity

    Adds IChatSummarizationService + concrete impl that compresses the dropped

  • Added
    slice52-Q-TOOL-FILE-SEARCH: file_search chat tool + chat-attachment RAG ingest pipeline

    Third of the four P0 chat tools — ChatGPT File Search parity.

  • Added
    slice52-Q-CHAT-SUMMARY-UX: rolling summary pill + ChatSummary endpoint

    Why: backend tier-budget context builder (slice52-Q-CHAT-CONTEXT-BUILDER)

  • Added
    slice52-Q-TOOL-IMAGE-EDIT: image_edit P1 chat tool + URL→MediaAsset helper

    Adds ImageEditTool (mirror of ImageGenerateTool) so the LLM can edit user-

  • Changed
    slice52-Q-ME-WEBSEARCH/locale: propagate Agent::WebSearch:* keys to 28 siblings

    Fans out the 46 Agent WebSearch + Menu:WebSearch + Permission:WebSearch.*

  • Added
    slice52-Q-TOOL-TTS-STT: P1 chat tools tts_generate + stt_transcribe

    Why: P1 voice tools listed in feedback_chat_context_management.md — text

  • Added
    slice52-Q-LEARNING-LOOP: UserComplaintLink + nightly fix matcher (pattern #5 honest-UX DNA)

    Closes the user-complaint → shipped-fix loop automatically so we never make

  • Added
    slice52-Q-EPISTEMIC-HONESTY: chip + system prompt for Honest-UX DNA pattern #4

    Backend:

  • Added
    slice52-Q-ME-WEBSEARCH/shared-enum: add missing EnWebSearchKind enum

    The /me/web-search slice landed almost entirely via Serkan's recent

  • Added
    slice52-Q-CODE-INTERPRETER/runner: Pyodide host orchestrator + Web Worker

    Post-streaming runner that drives Pyodide in a Web Worker and feeds

  • Added
    slice52-Q-CODE-INTERPRETER/upload: chat-attachment MIME whitelist + EN keys

    MyMediaUploadAppService.PurposeChatAttachment validation extended to

  • Added
    slice52-Q-CODE-INTERPRETER/bridge: pending + completion endpoints + flat-fee billing

    Two-endpoint AppService that bridges the server-side code_interpreter

  • Added
    slice52-Q-CODE-INTERPRETER/backend: code_interpreter tool + scoped tool context

    Ship the ADR-043 Pyodide v1 backend slice — the LLM-facing IAgentTool

  • Added
    slice52-Q-CHAT-VIRTUALIZATION: cursor-paginated chat history + render-window pattern

    Why: long chats (100+ turns) bloat browser memory + slow ngx-markdown re-renders

  • Added
    slice52-Q-TOOL-WORKFLOW-RUN/backend: add workflow_run chat tool (list/describe/run modes)

    Fourth of 4 P0 chat tools per feedback_chat_context_management.md roadmap and

  • Changed
    slice52-Q-CODE-INTERPRETER/adr: ADR-043 Pyodide v1 sandbox + 5MB attachment scope

    Phase 1 design spike for code_interpreter chat tool (second P0 tool after

  • Added
    slice52-Q-PUBLIC-CHAT-TURNSTILE/frontend: mount Cloudflare widget + ship token in stream POST

    Public-chat launcher now boots a Cloudflare Turnstile widget at view

  • Changed
    slice52-Q-PUBLIC-CHAT-TURNSTILE/locale: Public:Chat:Error:BotChallenge EN + TR master

    Locale key for the new Cloudflare Turnstile rejection banner shipped

  • Added
    slice52-Q-PUBLIC-CHAT-TURNSTILE/backend: Cloudflare Turnstile bot-protection for anon homepage chat

    The [AllowAnonymous] PublicChatAppService now verifies a Cloudflare

  • Added
    slice52-Q-PUBLIC-CHAT-STREAMING: SSE streaming variant for anon homepage chat

    Marketing landing's anon chat now streams the assistant reply

  • Changed
    slice52-Q-WEBSEARCH-PROVIDER/appsettings: expose DeepResearch + FetchUrl cost knobs + ExtractCacheMinutes

    Surface the three new WebSearchOptions knobs in appsettings.json so the

  • Added
    slice52-Q-WEBSEARCH-PROVIDER/tools: dual-tier chat web-search — web_search / deep_research / fetch_url

    Three tools wired to the canonical authoring-tier IWebSearchProviderFactory.

  • Added
    slice52-Q-WEBSEARCH-PROVIDER/seed: tavily provider + tavily-search model + 2 capabilities + 3 pricing meters

    Catalog seed for the dual-tier chat web-search tooling.

  • Added
    slice52-Q-WEBSEARCH-PROVIDER/tavily-client: IWebSearchProvider.ExtractAsync + Tavily /extract + raw_content

    Adds the second half of the provider contract needed by the dual-tier chat

  • Fixed
    slice52-Q-PUBLIC-CHAT-HARDEN: tighten output cap + rate caps + prompt length for anon vitrin

    User report 2026-05-27 — public chat marketing surface 60s+ bekleyip

  • Fixed
    slice52-Q-PUBLIC-CHAT-MD: markdown render + bigger output cap for anon homepage reply

    User: "ana sayfada neden markdown renderer yok, direk markdown olarak

  • Added
    slice52-Q-DEEP-RESEARCH-EXEC: wire DeepResearchExecutor to Tavily advanced search

    Bridges the gap between DeepResearchSession CRUD (sat at default state forever)

  • Changed
    slice52-Q-PUBLIC-CHAT-FALLBACK/locale-fanout: 3 Error keys × 27 siblings

    Propagate Public:Chat:Error:NoModel / CallFailed / EmptyPrompt

  • Fixed
    slice52-Q-PARTNER-CTA-URL: pricing-grid Partner CTA drops legacy /company/ prefix

    User report 2026-05-27: pricing sayfasındaki Partner card'ın

  • Fixed
    slice52-Q-PUBLIC-CHAT-FALLBACK: tiered routing fallback + actionable error codes for anon homepage chat

    User: "burayı geçen gün yaptık sağlamdı, yine bozuldu.

  • Added
    slice52-Q-WEBSEARCH-UNIFY: bridge chat web_search to authoring provider registry

    Slice 452-fu already shipped first-class Brave + Tavily IWebSearchProvider

  • Added
    slice52-Q-WEBSEARCH-PROVIDER: wire Brave + Tavily as real web-search tool backend

    Replaces the stub web_search tool with a config-selectable provider:

  • Fixed
    slice52-Q-STREAM-PERSIST: persist user + partial assistant turn on stream cancel / provider error

    User: "deepseek response geldi ekran 2'de, sayfayı refresh edince

  • Changed
    slice52-Q-TOOL-ONLY-TURN/locale-fanout: ToolOnlyTurn 27 sibling locales

    Native-quality translations for "Action completed.

  • Fixed
    slice52-Q-TOOL-ONLY-TURN: friendly localized rendering for tool-only assistant turns

    User şikayet: "gpt 4o mini response boş geldi.

  • Fixed
    slice52-Q-CHAT-ORDER: defensive chronological sort on chat history hydration

    User: "her sayfa refresh ettiğimde chatlerin yerleri ve sıraları

  • Fixed
    slice52-Q-UTC-PARSE-fu: chat history load also parses UTC defensively

    Önceki commit (e2a74db8) sadece relativeTime/fullTimestamp helper'ını

  • Fixed
    slice52-Q-UTC-PARSE: defensive UTC parse on chat timestamps — refresh no longer shifts "just now" → "3h ago"

    Sprint 50-S backend fix made the wire format emit `Z`-suffixed ISO

  • Changed
    slice52-Q-PROVIDER-NOTES: three provider API truth-tables + 2 latent regression fixes

    User direktif: "arkada iş kalmasın".

  • Fixed
    slice52-Q-ANTHROPIC-1M-BETA-REVERT: drop retired beta header — was the actual cause of Opus 4.7 / Sonnet 4.6 400s

    Önceki "fix" (a56449db) Opus 4.7 / Sonnet 4.6 için preemptive olarak

  • Fixed
    slice52-Q-CHAT-UX4: error bubble icon + text inline alignment

    Pre-fix rendered the warning triangle as an inline <i> followed by

  • Fixed
    slice52-Q-AUTO-DEFAULT: "Auto" dropdown pick → resolve to deepseek-v4-flash, not null

    Önceki rev (a56449db) sadece ilk-mount fallback'i çözüyordu —

  • Fixed
    slice52-Q-IMG-PRICING-GUARD: three-layer defense against image-gen overcharge ($22.50/image gpt-image-2)

    Third regression of the same bug class in three sessions.

  • Fixed
    slice52-Q-CHAT-MODEL-QUARTET: default picker / focus restore / single error / opus-4.7 + flash-lite

    User reported four issues in a single round of chat smoke-testing:

  • Fixed
    slice52-Q-FINANCIAL-AUDIT-3: UserBillingDailyBackfill now overwrites existing rows — true idempotency

    Atladığım şey buydu.

  • Fixed
    slice52-Q-HOME-SPEND-CANONICAL: aggregate BillingRecord directly for /home Monthly Spend, not derived summary

    Three iterations of the same bug (Monthly Spend $0 → $0.33 → $0.15) had

  • Fixed
    slice52-Q-MIME-PARAM-FIX: defensive MediaTypeHeaderValue.Parse for caller-supplied Content-Type with codec parameters

    Mic-capture via MediaRecorder (chat composer Whisper STT, Sprint 52-O)

  • Added
    slice52-Q-MODEL-SEED-RETIRE-AUDIT/openai-deepseek: retire gpt-4.1 family + DeepSeek aliases (force-cut from active rotation per user directive, 2026-05-27)

    OpenAI gpt-4.1 family (Deprecated → Retired, isActive:false, version 3→4):

  • Added
    slice52-Q-MODEL-SEED-RETIRE-AUDIT/pricing: EffectiveTo dates for retired pricing rows

    Close 10 pricing rows for the 5 retired models:

  • Added
    slice52-Q-MODEL-SEED-RETIRE-AUDIT/anthropic-google: retire claude-3.5 + gemini-2.0/1.5 SKUs

    Anthropic (DeprecatedAt 2025-09-29, RetiresAt 2026-05-01):

  • Fixed
    slice52-Q-PICKER-DEPRECATED-v2: hide Deprecated + Retired + realtime + computer-use from chat model picker

    User reported a wide swath of dropdown rows error on send:

  • Fixed
    slice52-O-REASONING-UX: legible thinking-pane indicator while gpt-5 reasons server-side

    User report: "reason yapar gibi baya bekliyor ama hareket yok, reason

  • Fixed
    slice52-Q-FINANCIAL-AUDIT-2: kill double-count of chat spend in UserBillingDailySummary

    Audit continuation after slice52-Q-FINANCIAL-AUDIT-1.

  • Changed
    slice52-Q-USER-BILLING-DAILY/handoff: log progress + defer admin UI to Suite session

    - PROGRESS.md: Sprint 52-Q-USER-BILLING-DAILY entry with all 4 commits,

  • Fixed
    slice52-Q-FINANCIAL-AUDIT-1: UserDailySummary consumer subscribes torun.billing.recorded.v1 — closes universal-spend leak

    User report: "monthly spend 0.33 olamaz, burada bir hata var, muhtemelen

  • Added
    slice52-Q-USER-BILLING-DAILY/backfill: seed UserBillingDailySummary from BillingRecord history

    - New IDataSeedContributor: UserBillingDailyBackfillDataSeedContributor

  • Added
    slice52-Q-USER-BILLING-DAILY/consumer: UserBillingDailySummaryConsumer micro-batch projection

    - New IInboxConsumer: GroupId "torun-user-billing-daily-summary"

  • Added
    slice52-Q-USER-BILLING-DAILY/entity: UserBillingDailySummary entity + Mongo wiring + indexes

    - Suite entity JSON: modules/torun.subscription/.suite/entities/UserBillingDailySummary.json

  • Fixed
    slice52-O-HOME-SPEND-V3: swap BillingRecord aggregate for UserDailySummary read

    User: "TelemetryUserDailySummaries tablomuz var gördüğün gibi içide dolu.

  • Fixed
    slice52-O-HOME-SPEND-V2: tenant filter bypass + cache write-back for monthly spend

    User report (continued from slice 52-O-NIGHT-TODO-IMPL/home-spend-fallback):

  • Fixed
    slice52-O-NIGHT-TODO-IMPL/home-spend-fallback: DB fallback for monthly/daily spend when Redis bucket is stale

    User report: "monthly spend her gün sıfırlanıyor — redis recycle ettiğimden,

  • Changed
    slice52-O-NIGHT-TODO-IMPL/progress: activity routes done + remaining TODO inventory

    activity routes done + remaining TODO inventory

  • Added
    slice52-O-NIGHT-TODO-IMPL/activity-routes: wire 4 missing UserActivityKind → router URL mappings

    User feedback: "kod içerisine daha önce yazdığımız TODO lara hiç

  • Changed
    slice52-O-NIGHT-TODO/progress: TODO cleanup audit ledger

    TODO cleanup audit ledger

  • Changed
    slice52-O-NIGHT-TODO: TODO/FIXME comment cleanup — project-wide grep zero

    User directive: "TODO ve benzeri yorumları ara, sonraya bırakılmış iş

  • Changed
    slice52-O-NIGHT-LOCALE/progress: morning report for Serkan — overnight locale + changelog ledger

    morning report for Serkan — overnight locale + changelog ledger

  • Changed
    slice52-O-NIGHT-LOCALE/scripts: preserve overnight locale-fill + translation scripts for reference

    These four ad-hoc scripts drove the overnight locale recovery:

  • Changed
    slice52-O-NIGHT-CHANGELOG: backfill 2 days of sprint commits to PublicChangelogEntry seed

    extract-sprint-changelog.py wrote 364 sprint rows to

  • Changed
    slice52-O-NIGHT-LOCALE/translate: native translations for core user-facing keys (14 locales)

    Followed up the placeholder fill (commit a3834ea4) with native-language

  • Changed
    slice52-O-NIGHT-LOCALE/fill: backfill 1311 missing locale keys with EN placeholder across 28 locales × 17 resources

    Audit found 1311 missing keys spread across 27 sibling locales (en-GB

  • Changed
    slice52-O-CHAT-WHISPER-FALLBACK/locale: ChatTranscript keys across 28 sibling locales

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Changed
    slice52-O-CHAT-LIBRARY/locale: EN master keys for /me/library source chip strip

    Adds the 11 EN-master entries the new SourceContext chip strip

  • Added
    slice52-O-CHAT-LIBRARY/library-ui: SourceContext chip strip in /me/library

    Surfaces the new SourceContext metadata as a user-facing filter so

  • Added
    slice52-O-CHAT-LIBRARY/composer: pre-upload pendingAttachments → Attachments[] + history-replay hydration

    Closes the chat-attachment data-loss bug: previously the composer

  • Added
    slice52-O-CHAT-WHISPER-FALLBACK/frontend: inline transcript caption + collapse on user message turn

    ChatTurn interface gains audioTranscripts[] with an expanded flag.

  • Added
    slice52-O-CHAT-WHISPER-FALLBACK/backend: capability check + Whisper transcript inject pre-call

    Add CapabilityKeys.AudioInput ("audio-input") so the fallback condition is

  • Added
    slice52-O-CHAT-LIBRARY/backend: chat-attachment purpose presign + GetMyLibrary SourceContextFilter

    The chat composer's prior path inlined image attachments as base64 data

  • Fixed
    slice52-O-BILLING-AUDIT/token-drift: costProjection includes conversation history

    Pre-fix, the composer cost badge only sized the draft text via

  • Fixed
    slice52-O-BILLING-AUDIT/gemini-stream: append alt=sse on streamGenerateContent

    `:streamGenerateContent` without `alt=sse` returns a JSON-array transport

  • Fixed
    slice52-O-BILLING-AUDIT/o3-cost: model-level pricing fallback when capability tag drifts

    GetActivePricingAsync now falls back to model-level pricing rows when the

  • Changed
    slice52-O-CHAT-CONTINUE/locale: fan-out Chat:Continue:* keys to 27 sibling locales

    Adds 9 new Chat:Continue:* keys (Button, Tooltip, Loading, Error, MaxReached,

  • Added
    slice52-O-CHAT-CONTINUE/frontend: Continue button + handler + en+tr locale master keys

    Angular proxy: +wasTruncated/continuedFromMessageId/hasContinuation on both DTOs;

  • Added
    slice52-O-OPENAI-REASONING: Responses API path for gpt-5 reasoning panel

    OpenAI Chat Completions silently consumes reasoning tokens for the

  • Added
    slice52-O-CHAT-CONTINUE/backend: finish_reason persist + ContinueAsync endpoint

    PersistAssistantMessageAsync now sets FinishReason/WasTruncated/ContinuedFromMessageId

  • Added
    slice52-O-CHAT-CONTINUE/entity: ChatMessage WasTruncated + FinishReason + ContinuedFromMessageId + HasContinuation fields

    Extend ChatMessage.Extended.cs with 4 new virtual properties (FinishReason,

  • Fixed
    slice52-O-CHAT-BUDGET-BANNER: hide when wallet has balance

    User reported the "Daily free limit reached — Charge wallet" yellow

  • Changed
    slice52-O-CHAT-MIC-WHISPER-locale: mic + Whisper keys across 28 sibling locales

    Propagate the new MediaRecorder + Whisper STT composer keys from en.json to all 28

  • Added
    slice52-O-CHAT-MIC-WHISPER: MediaRecorder + Whisper STT for chat composer mic

    Why: legacy Web Speech path produced transcript-only with no audio artifact

  • Fixed
    slice52-O-CHAT-UX2: default DeepSeek model + dismissable budget banner

    User reported two chat UX papercuts after the chat-footer fix landed:

  • Fixed
    slice52-O-CHAT-FOOTER: reasoning badge overlap + mic timer + Charge wallet 404 trio

    User-reported chat composer trio:

  • Changed
    slice52-O-CHANGELOG-locale: 38-sprint fan-out across 28 sibling locales

    Propagated Changelog:Sprint:<slug>:Title and :Body keys for the 38 new sprints

  • Changed
    slice52-O-VERSION-BUMP: 1.0.0 → 1.1.0-phase1-launch

    Minor bump for the Phase 1 feature wave summarized in the changelog backfill

  • Changed
    slice52-O-CHANGELOG-BACKFILL: absorb 38 new sprints into PublicChangelogEntry seed

    Ran extract-sprint-changelog.py against HEAD.

  • Added
    slice52-O-WORKFLOW-QUALITY: GenerateTextAsync + PreferQuality routing for workflow runners

    - New IChatPipelineAppService.GenerateTextAsync endpoint (creative-writer

  • Added
    slice52-O-LOCALE-FANOUT: WorkflowRuns:CancelRun keys → 27 sibling locales

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Fixed
    slice52-O-BUNDLE-ROUTE/template-literal: escape backticks in My Bundles empty-state HTML comment

    Comment introduced in 57c15021 used backticks around '/marketplace' which

  • Fixed
    slice52-O-LOCALE-SWEEP/workflow-template-keys: backend prefix workaround + missing Birthday Audio/Cinema/ProvidedLyrics/EstimatedCost keys

    **Bug 1 — Card titles render raw `WorkflowTemplate:foo:Title` keys:**

  • Added
    slice52-O-RESUME-APPROVAL: add OutputsJson to WorkflowStepExecution extension

    Per-step output variable snapshot so the resume-aware wave loop can

  • Fixed
    slice52-O-APPROVAL-PAUSE-REMOVE: drop lyrics-approval HumanApproval node from birthday trio

    In-memory wait loop in WorkflowExecutorAppService.RunWaveLoopOnRowAsync (line 1797) is

  • Changed
    slice52-O-LYRICS-APPROVAL-locale: LyricsApproval 26-locale fan-out

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Added
    slice52-O-LYRICS-APPROVAL: preview/approve/edit/regenerate gate between gen-lyrics and gen-music

    Inject HumanApproval (kind=12) node into all three birthday catalog

  • Changed
    slice52-O-CINEMA-locale: BirthdayCinema 26-locale fan-out

    WorkflowTemplate:BirthdayCinema:Title + :Description propagated to all 26

  • Added
    slice52-O-CINEMA: VideoCapabilityRunner (Sora-2 sync poll) + birthday-cinema template (premium tier ~$12)

    User wanted the third leg of the birthday trio: "isteyen kullanıcı video

  • Added
    slice52-O-LYRICS-OVERRIDE: optional user-provided lyrics short-circuits AI gen-lyrics step

    Birthday workflows expose a textarea field 'provided_lyrics'; when filled

  • Changed
    slice52-O-TEMPLATE-TRIO-A-locale: BirthdayAudio + EstimatedCost 26-locale fan-out

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Changed
    slice52-O-UPLOAD-GUARD-locale: WorkflowWizard:WaitingForUploads 26-locale fan-out

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Fixed
    slice52-O-UPLOAD-GUARD: wizard Run/Preview buttons gated on hasActiveUploads() so character photo race no longer ships filenames as Guids

    THE photo-binding bug.

  • Fixed
    slice52-O-MEDIACOMPOSITE-LIBRARY: register composite mp4 as MediaAsset at merge time so it lands in /me/library even if QC escalates or persist cancels

    User observation: "library bakınca sadece image görüyroum ne ses var ne

  • Fixed
    slice52-O-FFMPEG-SLIDESHOW/D19: build proper concat filter + drop -shortest for image-only slideshows so merge produces a real mp4, not a 46 KB empty container

    User report: merge step "Succeeded" but composite_url_duration_seconds

  • Fixed
    slice52-O-RUN-STATUS-TRUTH/D12: run-detail truthfulness — parent RunStatus computed from worst step status, not just abortReason

    User report: "succeeded yazıyor da bunlar success degil ki hata veriyor

  • Fixed
    slice52-O-BUNNY-AUTH-fu/no-region-prefix: drop regional prefix from Bunny storage URL — 401 cause

    User directive 2026-05-25 — region prefix produced 401 Unauthorized on

  • Fixed
    slice52-O-BUNNY-AUTH/merge-storage-read: route Bunny CDN URLs through Storage API with AccessKey header so merge can actually read its inputs

    Root cause (from Note column added in 0a9e941f):

  • Fixed
    slice52-O-MERGE-FANOUT/multi-url-tracks: split comma-joined sourceVar into per-URL tracks so birthday-song-video merge stops cancelling

    Root cause: ImageCapabilityRunner with n>1 packs all generated URLs as a

  • Added
    slice52-O-MEDIA-PICKER-UNIVERSAL/workflow-wizard: add "From Library" path next to file inputs

    Adds an "Or pick from your library" link/button beneath the workflow-wizard

  • Added
    slice52-O-MEDIA-PICKER-UNIVERSAL/me-audio: wire STT source to two-tab MediaPicker

    Replaces the /me/audio direct file input (audio.component.html line 17 —

  • Added
    slice52-O-MEDIA-PICKER-UNIVERSAL/me-image-mask: swap bespoke mask picker for universal MediaPicker

    Replaces the /me/image Edit-tab mask widget (bespoke library-only modal +

  • Added
    slice52-O-MEDIA-PICKER-UNIVERSAL/me-video: swap PC-only refs for two-tab picker

    Replaces the inline "Drop an image or click to upload" widget for character

  • Added
    slice52-O-MEDIA-PICKER-UNIVERSAL/scaffold: shared MediaPickerComponent with PC + Library tabs

    Universal two-tab picker that replaces PC-only uploads across /me/* surfaces.

  • Fixed
    slice52-O-GOOGLE-VIDEO-CLIENT/veo-3-veo-3-1-async-adapter: register IAiVideoClient for providerKey "google" so Veo-3 + Veo-3.1 stop silent-dropping from /me/video catalog

    Pre-fix VideoPipelineAppService.GetCapabilitiesAsync (commit 5e39d434)

  • Fixed
    slice52-O-REPLICATE-VIDEO-SEED/kling-hunyuan-ltx: seed 3 Replicate video models with pinned SHAs + 2.0x margin pricing

    Pre-fix /me/video catalog query returned only sora-2 + sora-2-pro because no

  • Fixed
    slice52-O-MUSIC-SLIDER-SYNC-i18n/duration-max-hint: add Music:Form:DurationMaxHint to 28 sibling locales (en already present)

    Native translation per locale (prefix only; the numeric seconds cap

  • Fixed
    slice52-O-MUSIC-SLIDER-SYNC/duration-cap-aware-slider: bind /me/music + /me/video duration slider max to the selected model's real ceiling

    Pre-fix the duration slider on /me/music was hardcoded max=120s.

  • Fixed
    slice52-O-VIDEO-CATALOG/dynamic-model-picker: drive /me/video model dropdown from AiModel+AiModelCapability catalog instead of hardcoded sora-2 stub

    Pre-fix VideoPipelineAppService.GetCapabilitiesAsync returned a single

  • Fixed
    slice52-O-MUSIC-DURATION-CAP/per-model-billing-truth: cap requested duration at the model's real ceiling, bill only for delivered seconds

    User generated music with `requestedDuration=120s` against Riffusion

  • Fixed
    slice52-O-RIFFUSION-OBJOUT/replicate-object-output: handle Object-shaped Replicate output (riffusion multi-stream + future schemas)

    User got

  • Fixed
    slice52-O-RIFFUSION-PIN/replicate-version-sha: pin riffusion/riffusion model version SHA so picks past musicgen route cleanly

    User got the UFE

  • Fixed
    slice52-O-REPLICATE-401-fu/actionable-error: distinguish 401 / 402 / 429 / other in Replicate prediction failure UFE

    User got HTTP 401 from Replicate after triggering musicgen and the

  • Added
    slice52-O-MUSIC-MODELS-SEED/replicate-music-trio: seed musicgen-medium + musicgen-large + riffusion via Replicate

    User reported the /me/music model dropdown stayed empty even with

  • Fixed
    slice52-O-MUSIC-ROUTE-fu/models-endpoint-404: correct music model picker URL — /api/byokvault/my-available-models/by-capability

    Console showed:

  • Fixed
    slice52-O-MENU-VISIBILITY-fu/route-guards: drop route-level permissionGuard for /me/video + /me/music

    Carry-forward from 05999c1c.

  • Fixed
    slice52-O-MENU-VISIBILITY/video-music-sidebar: drop requiredPolicy gates from /me/video + /me/music — match Image/Voice/Audio pattern

    User reported video + music menus missing from My Account sidebar even

  • Added
    slice52-O-MUSIC-MENU/locale-fanout: propagate 43 Music keys to 28 sibling locales

    Mirrors fc625886 EN seeding into ar/cs/de/de-DE/en-GB/es/fi/fr/hi/hr/

  • Added
    slice52-O-MUSIC-MENU/angular: /me/music component + sidebar entry + EN locale

    Angular standalone component mirrors /me/voice + /me/image shape:

  • Added
    slice52-O-MUSIC-MENU/backend: MyMusicPipelineAppService for /me/music

    User-facing music generation pipeline mirroring ImagePipeline pattern:

  • Fixed
    slice52-O-VIDEO-MENU-FIX: default-grant VideoPipeline.MyGenerate to user role

    The AuthoringPermissions.VideoPipeline.MyGenerate comment says the

  • Fixed
    slice52-O-MERGE-RESILIENCE/ffmpeg-defensive-trio: track-attributed errors + skip-empty + Bunny CDN retry

    Second-pass merge failure after b9dm94er4 + 21983ef0 still surfacing

  • Added
    slice52-Q-MODEL-ONBOARDING/locale-fanout: propagate 60 ModelOnboarding keys to 28 sibling locales

    Adds the Sprint 52-Q ModelOnboarding admin UI strings (Menu:ModelOnboarding +

  • Added
    slice52-O-MARGIN-AUDIT-LOCALE-FANOUT/cost-markup-i18n: 32 keys × 28 sibling locales for AI cost markup admin page

    Fans out the 32 EN keys added in commit be0190b2 (admin /cost-markup

  • Added
    slice52-O-REAL-COST-AUDIT/locale-fanout: propagate margin-reconciliation labels to 28 locales

    39 MR keys (Menu:Admin:MarginReconciliation, Permission:MarginReconciliation, MarginReconciliation:*) added to every sibling locale under src/ToRun.Domain.Shared/Localization/ToRun/.

  • Added
    slice52-Q-MODEL-ONBOARDING/phase-D-bulk-import-export: JSON snapshot round-trip for providers + models + stubs

    Sprint 52-Q-MODEL-ONBOARDING Phase D — round-trip bulk-import / bulk-export

  • Added
    slice52-Q-MODEL-ONBOARDING/phase-C-admin-ui: /admin/model-onboarding wizard for providers, models, stubs

    Sprint 52-Q-MODEL-ONBOARDING Phase C — host-admin Angular UI at

  • Fixed
    slice52-O-MARGIN-AUDIT/dto-leak-jsonignore: [JsonIgnore] ResolvedModelDto.AppliedMarkupMultiplier

    Guardrail sweep finding from Phase D of the 52-O-MARGIN-AUDIT sprint.

  • Added
    slice52-Q-MODEL-ONBOARDING/phase-B2-generic-rest-client: GenericRestClient (chat path) + RegisterClientStubAsync

    Sprint 52-Q-MODEL-ONBOARDING Phase B.2 — adds the GenericRestClient that

  • Added
    slice52-O-MARGIN-AUDIT/admin-cost-markup-ui: Angular page for runtime markup tweak

    Phase C UI of the 52-O-MARGIN-AUDIT sprint.

  • Added
    slice52-O-REAL-COST-AUDIT/phase-C-pipelines: pipeline AppService plumbing for ops ledger

    Sprint 52-O-REAL-COST-AUDIT phase C — each pipeline AppService that wraps

  • Added
    slice52-Q-MODEL-ONBOARDING/phase-B1-stub-entity: AiProviderClientStub aggregate + Mongo repo

    Sprint 52-Q-MODEL-ONBOARDING Phase B.1 — scaffolds the AiProviderClientStub

  • Added
    slice52-O-MARGIN-AUDIT/admin-cost-markup: host-admin AppService + ISettingProvider bridge

    Phase C of the 52-O-MARGIN-AUDIT sprint.

  • Added
    slice52-Q-MODEL-ONBOARDING/phase-A-onboarding-AppService: host-admin composer for AiProvider/AiModel/Capability/Pricing

    Sprint 52-Q-MODEL-ONBOARDING Phase A — adds AdminModelOnboardingAppService

  • Added
    slice52-O-REAL-COST-AUDIT/phase-B-providers: ProviderUsageSnapshot + 6 client parsers

    Sprint 52-O-REAL-COST-AUDIT phase B — every IAi*Client now stamps a

  • Added
    slice52-O-REAL-COST-AUDIT/phase-A-schema: add 4 ops-only columns to BillingRecord

    Sprint 52-O-REAL-COST-AUDIT phase A — parallel server-side-only ledger so

  • Added
    slice52-O-MARGIN-AUDIT/markup-options: AiCostMarkupOptions + routing snapshot multiplier

    Phase B of the 52-O-MARGIN-AUDIT sprint.

  • Fixed
    slice52-O-MARGIN-AUDIT/seed-bake-margin: 268 AiModelPricing rows bumped to ≥1.5x/2.0x real cost

    Phase A of the 52-O-MARGIN-AUDIT sprint.

  • Fixed
    slice52-P-SHARE-fu/slug-partial-index-operator: swap \$ne for \$type in unq_MediaAsset_Slug partial filter — DbMigrator unblocked

    Error from DbMigrator on every restart:

  • Fixed
    slice52-O-MARGIN-fu/runner-fallback-sweep: bump Image / ImageEdit / TTS fallback rates +50% per margin-baked-in rule

    Carry-forward from b4ab9daf music_v1 seed bump + feedback_pricing_

  • Fixed
    slice52-O-MARGIN/music-v1-bake-margin: bump Eleven Music v1 seed from \$0.002 to \$0.0035 per-second (+110% margin) per user directive

    User feedback after 21983ef0 landed: looked at ElevenLabs analytics

  • Fixed
    slice52-P-SHARE/locale-fanout: 37 keys × 28 sibling locales for shared-media + library-share dialog

    - ToRun resource: 36 keys (Library:Share:* dialog + SharedMedia:* public page)

  • Added
    slice52-O-LIBRARY-ARTIFACT/workflow-output-to-library: ArtifactSave registers MediaAsset row → /me/library surfaces workflow outputs

    Pre-fix: workflow ArtifactSave nodes uploaded blobs to Bunny and stuffed

  • Fixed
    slice51-M-fu2/legal-v2-natives-full: close the last 2 placeholder locales — ar v2.0 + vi native

    Sprint 51-M-fu2 completion pass.

  • Fixed
    slice52-O-IMG-SRC/workflow-edit-image: route uploaded photos through image-edit pipeline

    Birthday-song-video template's `photos` multiphoto field reached Bunny CDN

  • Fixed
    slice51-M-fu2/legal-v2-natives: 23 native v2.0 legal translations replace placeholders

    Drops native v2.0 About/Terms/Privacy/Contact for 10 brand-new locales

  • Fixed
    slice52-A-M5/enhance-prompt-outbox: publish chat-message-recorded.v1 from EnhancePromptAsync so UsageDailySummary counts prompt-enhance token usage

    EnhancePromptAsync wrote a BillingRecord and settled the budget but never

  • Fixed
    slice52-O-PRICING-fu/image-gen-overcharge: kill the 500x gpt-image-1-mini per-image overcharge

    Root cause (two layers, one bug):

  • Fixed
    slice52-A-H4/load-history-graph-lookup: collapse the N+1 ParentMessageId walk into a single $graphLookup aggregation

    LoadHistoryAsync previously walked the leaf → ancestor chain by issuing one

  • Changed
    52-O-NIGHT/progress-ledger: ajout de l'entrée du balayage nocturne 52-O dans PROGRESS.md

    Conformément à la règle 10 de CLAUDE.md.

  • Changed
    52-O-NIGHT/locale-validation-report: rapport de parité par ressource x par locale après le déploiement en éventail des 6 agents traducteurs

    Sortie de `python platform-plan/scripts/_validate-29-locales.py` après l'atterrissage de tous les 27 lots de traduction des langues soeurs + la passe de suppression des BOM :

  • Changed
    52-O-NIGHT/translator-batches: 25 lots de traduction native atterris — total ~7,800+ clés réparties sur 52 fichiers

    Lots produits par 6 agents traducteurs Sonnet parallèles (tous intégrés au dépôt dès les tours précédents + dernier groupe finalisé) :

  • Added
    slice52-O-NIGHT-fu/image-edit-progress-bar: bring Edit tab's staged-progress UI up to Generate-tab parity

    Serkan caught this — the Generate tab on /me/image has a card-shaped progress bar that walks through Preparing → Requesting → Generating → Fetching with a striped animated `progress-bar bg-info`, phase-specific icon + la…

  • Fixed
    slice52-O-NIGHT-fu/workflow-runner-principal-scope: restore triggering user's principal at wave-loop entry so background workers don't trip AbpAuthorizationException on every [Authorize]-gated capa...

    The bug Serkan surfaced from /me/workflow-runs (Detail click on a Failed run): every workflow step that delegates to an ApplicationService with class-level [Authorize] (ImagePipelineAppService, all the pipelines) termina…

  • Fixed
    slice52-O-12-locale-2/workflow-select-option-remaining-19-locales: populate native-language translations for the 19 sibling locales that shipped as empty stubs in 0da3c077

    Completes the locale-fanout begun in 0da3c077 (Sprint 52-O-12-locale).

  • Changed
    52-A/audit: résultats de revue de code — pipeline de chat + InAppAssistant — 4 critiques + 8 moyens + 5 mineurs

    Passe d'audit en lecture seule sur ChatPipelineAppService + InAppAssistant + les clients fournisseurs + ProviderFallbackChain.

  • Changed
    slice52-O-12-locale-2: partial native-language translations for 7 sibling locales (nl, sv, fi, is, en-GB, ru, pl-PL)

    7 of 19 stub locales populated; 12 remaining (cs, sk, hu, ro-RO, hr, sl, ko, zh-Hans, zh-Hant, hi, ar, vi).

  • Changed
    slice52-O-18-fu/lifecycle-legacy-available-28-locales: propagate "Legacy Available" enum translation to the 28 sibling locales

    Sprint 52-O-18 added ModelLifecycleStatus.LegacyAvailable (used to mark Claude 4.5/4.1/Opus 4.6/Sonnet 4.5 etc.

  • Changed
    slice52-O-19-G/sprint-wrap: point SunoMusicClient stub's "use the live music provider instead" guidance at ReplicateGenericClient ('replicate') rather than the deprecated MusicgenMusicClient ('musi...

    Sprint 52-O-19 (provider runtime hardening) complete — 7 commits land:

  • Added
    slice52-O-19-F/credential-normalization: close the per-model ProviderKey trap by adding a providerKey → canonical-providerKey normalization map to CredentialResolver.GetApiKeyAsync — exact-match lo...

    Concrete unblock: AiModel rows whose ProviderKey was set to "musicgen" / "ltx-video" / "flux-1.1-pro" / "hunyuan-video" / "sd3.5-large" / "xtts-v2" / "bark" all route credential lookups through "replicate" when no per-mo…

  • Added
    slice52-O-19-E/resilience-circuit-breaker: introduce per-(providerKey, capabilityKey) circuit breaker + intra-provider 429 backoff + chain length cap + 4xx-bad-shape carve-out so a thrashing upstre...

    New IProviderCircuitBreaker (Application.Contracts/AiClient/Resilience/) + default ProviderCircuitBreaker impl backed by IDistributedCache<CircuitState,string> keyed by torun:byok:circuit:{providerKey}:{capabilityKey} wi…

  • Changed
    slice52-O-18-rollout: integrate 25-provider AI catalog seed refresh — 8 commits covering AiProvider/CapabilityKeys/EnPricingUnit/EnProviderTier/ModelLifecycleStatus expansions + ~60 new 2026 models...

    # Conflicts:

  • Added
    slice52-O-19-D/elevenlabs-client: introduce ElevenLabsClient — single adapter that covers TTS (eleven_multilingual_v2/eleven_flash_v2_5/eleven_v3), text-to-music (music_v1 GA endpoint), and Scribe...

    ProviderKey="elevenlabs".

  • Added
    slice52-O-19-C/replicate-generic-client: introduce ReplicateGenericClient — single adapter that serves every Replicate-hosted modality (image, video, music, TTS) through the uniform /v1/predictions...

    ProviderKey=\"replicate\".

  • Added
    slice52-O-18-rollout/payload-grammar-2026: seed PayloadGrammarJson on the 2026 image / video / audio / 3D capability rows so resolver picks DB row over static fallback

    PayloadGrammarJson column declared on AiModelCapability.Extended.cs — backports the Sprint 52-O-17 chip's column that the worktree branched off main without (worktree base is 16 commits behind local main, so 52-O-17 wasn…

  • Added
    slice52-O-18-rollout/pricing-2026-refresh: seed pricing for the ~60 new 2026 models so AiModelPricing reflects the May 2026 research roster

    Adds ~60 new pricing rows in the 520180XX-...

  • Added
    slice52-O-19-B/wire-protocol-resolver: introduce IWireProtocolResolver + cache-resilient default impl that maps an AiProvider.ProviderKey → wire-level metadata (Protocol enum, BaseUrl, IsActive/IsD...

    ResolvedAiProvider DTO carries the read-only snapshot that generic adapters consume at request time — protocol drives which adapter class handles the request, BaseUrl is forwarded into the outbound HttpRequestMessage so…

  • Added
    slice52-O-18-rollout/capability-joins: wire the ~60 new 2026 models to their capability sets + bind the new capability anchors to existing flagships

    SeedSlice52O18Async() runs at the end of SeedAsync regardless of count gate (idempotent EnsureCapabilityRowAsync calls, deterministic XOR-based GUIDs so reruns are no-ops).

  • Added
    slice52-O-18-rollout/aimodels-2026-refresh: patch lifecycle statuses + add ~60 new flagship models so the catalog reflects the May 2026 25-provider research roster

    Existing 108 rows: status / deprecatedAt / retiresAt patched per the deprecation calendar in 00-MASTER-SUMMARY.md §"Major Deprecation Calendar" — gpt-4o / 4.1 / 4.1-mini / 4.1-nano / o1 / o3-mini / gpt-image-1 land 2026-…

  • Added
    slice52-O-19-A/aiprovider-wire-protocol-enum: introduce EnWireProtocol (12 values: OpenAiCompat | AnthropicNative | GeminiNative | Replicate | ElevenLabs | StabilityNative | BedrockConverse | Bedro...

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Added
    slice52-O-19/aiprovider-wire-protocol-enum: tag each AiProvider with its wire-level HTTP family so the adapter factory resolves the right IAi*Client from a DB row instead of a hand-rolled per-provi...

    New shared enum EnWireProtocol (11 named + Custom catch-all) covers the realistic provider population: OpenAiCompat (OpenAI/xAI/DeepSeek/Mistral/Groq/Cerebras/Together/Perplexity/Azure-OpenAI/Fireworks/DeepInfra/OpenRout…

  • Added
    slice52-O-16-a/workflow-async-queue: convert workflow execution from synchronous HTTP to queued + worker-processed so a multi-minute DAG no longer blocks the request

    EnqueueRawSpecAsync inserts a Pending WorkflowExecution row, stamps QueuedAt + Activity Center row, emits torun.authoring.workflowexecution.queued.v1 via transactional outbox (Rule 8), and returns the DTO so the wizard n…

  • Added
    slice52-O-18-rollout/lifecycle-legacy-available: add LegacyAvailable to ModelLifecycleStatus so still-callable-but-not-recommended models can be marked correctly

    Claude 4.5 / Opus 4.1 / Sonnet 4.5 / earlier Gemini 2.0 / xAI Grok 3 are all examples of models that stay on the API surface but the provider is steering new traffic to a newer release.

  • Added
    slice52-O-18-rollout/pricing-tier-enums: add PerCitationToken/PerReasoningToken/PerRun units + Priority/OffPeak/SelfHost tiers for the May 2026 catalog

    EnPricingUnit grows 12 → 15 to model 2026 billing meters the legacy enum couldn't represent.

  • Added
    slice52-O-18-rollout/capability-keys-36: expand CapabilityKeys + Capabilities seed to cover the 22 new 2026 capabilities surfaced by the May research roster

    The 2026 model generation introduced capabilities that the old 18-key vocabulary couldn't address: Claude's adaptive vs.

  • Added
    slice52-O-18-rollout/aiproviders-25: re-add stability + add fireworks/deepinfra so the catalog reflects the May 2026 25-provider research roster

    23 → 25 providers (stability re-introduced after slice 4xx removal, two OSS-serving newcomers fireworks + deepinfra added).

  • Added
    slice52-O-17-fu/openai-image-grammar-admin-form: expose PayloadGrammarJson (and the previously hidden InputBoundsJson) on the AiModelCapability create/edit modal — textarea + "Validate JSON" button...

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Added
    slice52-O-17-fu/openai-image-grammar-seed: seed PayloadGrammarJson on the image-generation join rows for dall-e-3 and gpt-image-1 — mirrors the existing static OpenAiImageModelGrammar entries so fr...

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Changed
    slice52-O-17/openai-image-grammar-db-resolver: migrate the OpenAI image-model payload grammar (sizes, quality vocab, accept/reject lists) from the static OpenAiImageModelGrammar.ByPrefix dispatch o...

    Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>

  • Changed
    slice52-O-15-fu/openai-image-grammar-registry: replace inline model-quirk branching with a data-driven OpenAiImageModelGrammar table — new models = one dictionary row, no client code touched

    Pre-52-O-15-fu the OpenAiImageClient hand-coded every model-specific quirk inline.

  • Added
    slice52-O-14-fu/budget-preview-wizard-modal: wire pre-flight budget preview + LeptonX confirm modal in the workflow wizard so users consent before the daily-cap-closed wallet charge

    Backend (fu1): new POST /api/subscription/budget-preview/preview wraps IBudgetGuard.CheckAsync read-only.

  • Fixed
    slice52-O-15/openai-image-size-snap: snap arbitrary WxH to the closest model-supported preset by aspect ratio — workflow 1280x720 no longer hits HTTP 400

    OpenAI image API rejects unknown sizes outright with HTTP 400 + "Invalid size 'WxH'.

  • Fixed
    slice52-O-12-locale/workflow-select-option-28-locales: seed native-language translations across the platform's 28 sibling locales

    WorkflowSelectOptionsDataSeedContributor now does an idempotent per-(option, locale)

  • Added
    slice52-O-14/budget-banner-wallet-after-daily-cap: emit Budget:UsingWalletAfterDailyCap so chat banner warns user the free-tier daily slot closed + wallet is funding the call

    User feedback on Sprint 52-O-13: "tabi bunun için kullanıcıyı bi popup ile uyarmalıyoz." Letting the wallet bypass the daily cap is the right behaviour for paid credit (52-O-13 fixed the silent reject), but the user stil…

  • Fixed
    slice52-O-13/budget-daily-cap-wallet-bypass: daily cap gates bucket path only — wallet credit is paid spend, never throttled by cap

    The Free-tier $0.10/day cap exists to spread $2/month allowance across days so a single user can't front-load the host's AI-cost reimbursement.

  • Added
    slice52-O-12d/workflow-select-option-admin: host-admin CRUD UI for the workflow input-form catalog (add categories without code deploy)

    Sprint 52-O-12d completes the catalog story started by 52-O-12a (entity)

  • Fixed
    slice52-O-12c/workflow-template-spec-lookup-backfill: align backend seeded templates with the new spec lookup/multiSelect syntax

    Hygiene-only follow-up to 52-O-12a/b.

  • Fixed
    slice52-O-12-translations-stub/build-break: add empty WorkflowSelectOptionTranslations.Map so contributor compiles

    User added a per-locale enrichment block to

  • Fixed
    slice52-O-12-di/workflow-select-option-localization-aggregate-root: change to FullAuditedAggregateRoot so ABP auto-registers IRepository

    Sprint 52-O-12a follow-up — DI bootstrap fail

  • Added
    slice52-O-12b/workflow-wizard-lookup-render: wizard fetches catalog options via lookup + Language category seed + 7 template inputs migrated

    Phase B (Angular wizard) for the 52-O-12a data-driven dropdowns.

  • Added
    slice52-O-12a/workflow-select-options-backend: catalog entity + ~430-option English seed + spec lookup/multi-select fields

    Phase 1 backend stack for data-driven workflow wizard dropdowns.

  • Fixed
    slice52-O-10/cache-manager-abp-key-wrap: substring SCAN + drop cache: gate so admin UI surfaces every category + Browse finds keys

    Backend bug — Cache Manager shows 3 categories of ~10+, every Browse empty

  • Fixed
    slice52-O-9/bunny-stream-library-message: rewrite missing-config error as admin-actionable copy

    UX bug — cryptic exception copy on /media/video-stream

  • Fixed
    slice52-O-8/wallet-recent-tx-empty: drop redundant IsActive predicate + add observability — recent transactions list now surfaces history

    Backend bug — empty Recent transactions list with non-zero balance

  • Fixed
    slice52-O-3/workflow-editor-theme-tokens: drop hardcoded #fff / hex / fixed rgba in favour of Bootstrap 5.3 theme tokens

    UI bug — multi-theme breakage

  • Fixed
    slice52-O-2/workflow-editor-i18n-en: merge 134 missing Workflow* keys into ToRun resource

    Backend bug — entire workflow editor surface ships raw keys

  • Fixed
    slice52-O-1/workflow-spec-polymorphic-default: accept number/bool tokens on string Default + map int/float legacy types

    Backend bug — every workflow template run failed

  • Fixed
    slice52-M/title-gen-reasoning-effort: gate reasoning_effort field on isReasoningOrGpt5 — close 8th regression

    Exception screenshot from Serkan (2026-05-23):

  • Changed
    slice52-L/provider-quirks: formalise OpenAI-compat subclass extension contract — every provider owns its own quirks

    Serkan's motto (2026-05-23): "biz 25 farklı AI provider destekliyoruz...

  • Fixed
    slice52-K/title-gen-max-tokens: split max_completion_tokens/max_tokens by client class — title-gen finally lands on DeepSeek

    THE ACTUAL ROOT CAUSE of the seven "title-gen yine bozdun" reports —

  • Fixed
    slice52-J/title-gen-budget: bump title-gen MaxOutputTokens 1024→4096 — close 7th regression on reasoning-only deployments

    52-I excluded DeepSeek V4 from cheap-model picks, but on a deployment

  • Fixed
    slice52-I/title-gen-deepseek-v4: extend reasoning-class filter to deepseek-v4-pro/flash — close 6th title-gen regression

    50-LLL-2 added an ExcludeReasoningModels filter so the cost-saving

  • Fixed
    slice52-D-7-fu/audit-chain-named-args: named-arg call site for ExecuteServerToolsAsync to clear stale Roslyn binding cache

    User reported VS Error List showing CS1501 "No overload for method

  • Fixed
    slice52-D-7/audit-chain: hash-chained AgentAuditEntry per server-tool invocation

    F15 (root cause: AgentAuditEntry table unused for the bubble's

  • Fixed
    slice52-D-6/turn-svc-correctness: real daily-turn cap + anon graceful degrade + localized approval fallback + token-budget history truncate

    Four backend regressions in InAppAssistantTurnAppService surfaced

  • Fixed
    slice52-C-6/chat-reasoning-indicator: surface reasoning-class model selection in the composer

    Audit #14 — confirm Sprint 51-A's reasoning opt-in path is per-request,

  • Fixed
    slice52-F/console-noise-2: suppress NG0505 dev-only hydration warning + bump SignalR server timeout 30s→60s

    Two more console warnings flagged in /me/chat after 52-E:

  • Fixed
    slice52-C-5/chat-composer-polish: persisted model+tone + real-rate cost projection + locale-aware voice + SSE assert

    Bundles four small chat-pipeline polish fixes from the audit (#10, #11,

  • Fixed
    slice52-D-5/sse-controller-recovery: guard SSE recovery write against double-fault swallowing original exception

    F10 (root cause: bare WriteSseEventAsync in the controller's outer

  • Fixed
    slice52-D-4/bubble-ux-a11y: pretty-print approval args + USD currency-code pill + dialog a11y

    Three UX / a11y polish items from the sprint 52-D code-review pass.

  • Fixed
    slice52-D-3/bubble-dom-guards: broaden modal click-guard + skip bubble inputs in page-context

    Two DOM-side hygiene fixes from the sprint 52-D code-review pass:

  • Fixed
    slice52-D-2/bubble-races: serialise session start + close-cleanup dropdown bookkeeping

    Three concurrency / state-coherence regressions in the bubble component

  • Fixed
    slice52-D-1/bubble-sse-resilience: token refresh + typed 401 banner + parseSseFrame robustness

    Three SSE-stream regressions in the InAppAssistant bubble shipped with

  • Fixed
    slice52-C-4/chat-i18n: extract hardcoded UI strings to Agent locale keys

    Three chat-pipeline surfaces were emitting hardcoded strings in violation

  • Fixed
    slice52-E/console-noise: suppress ABP localization separator warnings at bootstrap

    Serkan flagged ~148 identical "The localization source separator (::)

  • Fixed
    slice52-C-3/chat-backend: real fallback provider lookup + title-gen SourceEntityId + LoadHistory N+1 doc

    C5: ResolveFallbackProviderKey returned the literal string "google"

  • Fixed
    slice52-C-2/chat-onpush: switch chat-pipeline component to OnPush change detection

    Every state write in chat-pipeline.component.ts goes through a Signal

  • Fixed
    slice52-C-1/chat-lifecycle-leaks: plug route + history subscribe leaks + harden streamTurn re-entry

    Three lifecycle / concurrency defects in the chat-pipeline component, all

  • Fixed
    slice52-B/chat-bottom-gap: tighten chat shell chrome budget + switch vh→dvh

    Serkan flagged a visible dead band between the composer card and the

  • Fixed
    slice51-Z/changelog-manifest: sync embedded DbMigrator manifest with extract script output

    ChangelogBackfillDataSeedContributor reads from the embedded resource

  • Fixed
    slice51-X/contact-form: new ContactSubmission entity + sweep all public email exposure

    > "bu contact formunda bütün maillerimizi açık açık yazdık spammerlara mail

  • Fixed
    slice51-V-fu/i18n-pricing-v2: propagate Subscription pricing copy across 28 SupportedLanguages

    Follow-up to Sprint 51-V (commit 373d84d9) which rewrote en.json only.

  • Fixed
    slice51-W/persona-seed: retire demo personas entirely — kill ghost-click on /p/echo

    Smoke at 2026-05-22 showed `/personas` listing "Echo the Storyteller"

  • Fixed
    slice51-V/pricing-alignment: features render + price-row alignment + 51-R/51-P-compliant copy

    Three compounding bugs from 51-S → 51-U all visible in the same screenshot:

  • Fixed
    slice51-U/pricing-catalog: rebuild /pricing 1:1 against canonical LeptonX pricing.html

    51-S / 51-T drifted from the catalog-first vocabulary and shipped a

  • Fixed
    slice51-T/pricing-fix: entity-driven contact-sales + revert to 4-col grid + Partner strip

    Cleanup of regressions introduced by 51-S.

  • Fixed
    slice51-S-fu/i18n-pricing-plan-custom: propagate Pricing:Plan:Custom across 28 SupportedLanguages

    Sprint 51-S (28e76a7d) shipped lib-pricing-grid with a contact-sales price cell that

  • Fixed
    slice51-S/pricing-unification: single <lib-pricing-grid> for /pricing + /me/subscription/upgrade + Web.Public

    ONE pricing surface for all 6 plans (Free / Starter / Pro / Business /

  • Fixed
    slice51-R/plan-descriptions: rewrite SubscriptionPlan descriptions — value-first copy, no token counts, no share %, no specific limits

    User mandate (2026-05-22): "Bu description'ları biraz zenginleştir.

  • Fixed
    slice51-R/external-links: target=_blank + rel=noopener noreferrer on every off-origin anchor

    User mandate (2026-05-22): public surfaces leaked the visitor to a new

  • Fixed
    slice51-Q/pricing-render-from-dto: mirror authed /me/subscription/upgrade pattern — render plan.title + plan.audience directly, drop the broken locale-key indirection

    User report (2026-05-22): "Login durumdayken pricing geliyor, public

  • Fixed
    slice51-P/pricing-trial-removed: kill the trial vector + fix planKey case mismatch on title localisation

    Two user-flagged issues on the same screenshot (2026-05-22, anon

  • Fixed
    slice51-O/pricing-public: public /pricing now actually shows plan cards (URL action suffix + BillingCycle case match)

    User report (2026-05-22): "Login durumdayken pricing geliyor ama public

  • Fixed
    slice51-N-fu/languages-reconcile: custom seed contributor reconciles 20→29 Languages on every DbMigrator run

    User report after 51-N landed: "DbMigrator çalıştırdım, proje yeniden

  • Fixed
    slice51-N/abp-languages-29: expand AbpLocalizationOptions.Languages 20→29 to match canonical SupportedLanguages

    User report (2026-05-22): "ABP bunu hala 20 dil görüyor ve dilleri açtığımızda 20 dil çıkıyor.

  • Fixed
    slice51-M-fu1/legal-29locales: expand legal-doc matrix to all 29 SupportedLanguages with localized v2.0-pending banners

    User correction (2026-05-22): "bizim platformumuz 29 dilde." Legal seeds

  • Fixed
    slice51-M/legal-v2: comprehensive About/Terms/Privacy/Contact v2.0 with version-upgrade seed logic

    User directive (2026-05-22): About too thin, Terms must hold up against

  • Fixed
    slice51-I/51-J/51-K: torun.app→torun.ai sweep + workflow-template 404 + InAppAssistant /start 500

    Three connected anasayfa bugs landed in the same commit because they all

  • Changed
    slice51-changelog: pre-release changelog seed refresh — extract + propagate 51-* sprints

    User mandate from 2026-05-22: "release çıkmadan önce change loglarının seed

  • Fixed
    slice51-F/51-H/legal-pricing-mvc: public routes + slug parity — BUG-6, 7, 9 closeout

    Three connected bugs from the anasayfa list (platform-plan/BUG_LIST_ANASAYFA_2026-05-22.md):

  • Fixed
    slice51-E/personas: View profile button + Persona: key prefix + trim seed to 1 demo (Echo)

    BUG-3+4+5 from anasayfa list closed.

  • Fixed
    slice51-D-fu/legal-locale: rename Legal:: → Legal: keys + use ToRun resource

    Follow-up to 51-C — my own mistake.

  • Fixed
    slice51-D/anon-billing: seed UnAuthenticatedUser + wire public chat + Public::Chat + Profile::NotFound locale keys

    BUG-1 closeout from anasayfa bug list (platform-plan/BUG_LIST_ANASAYFA_2026-05-22.md).

  • Fixed
    slice51-C/homepage-shell: public sidebar menus + Legal:: keys + scroll fix + reasoning opt-in across normal chat

    BUG-2 closeout (3-part user report + 1 rule refinement):

  • Fixed
    slice51-B/iaa-thinking: per-second SSE thinking event + bubble elapsed-time label

    BUG-1 part 2.

  • Changed
    slice50-RRRR/other: translate authoring placeholders — 149 keys × 3 locales (ar, hi, vi)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/cjk: translate authoring placeholders — 149 keys × 4 locales (ja, ko, zh-Hans, zh-Hant)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/slavic-south-hu: translate authoring placeholders — 149 keys × 3 locales (hr, sl, hu)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/iberian-romance: translate authoring placeholders — 149 keys × 3 locales (pt, pt-BR, ro-RO)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/english-nordic: translate authoring placeholders — 149 keys x 3 locales (en-GB, sv, fi)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/romance: translate authoring placeholders — 149 keys × 3 locales (fr, es, it)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/slavic-east: translate authoring placeholders — 149 keys × 4 locales (ru, pl-PL, cs, sk)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Changed
    slice50-RRRR/germanic-north: translate authoring placeholders — 149 keys × 4 locales (de, de-DE, nl, is)

    - Workflow editor, wizard, templates, validation, preview, run history strings

  • Added
    slice50-QQQQ/changelog-auto-emit: post-commit hook + append-sprint-row script (ADR-042 implementation)

    Closes ADR-042 — previously Proposed, now Accepted.

  • Fixed
    slice50-G-fu2: personas-index clear-all button auto-width + right-align on md+

    `col-md-1 text-end` clipped the localized "Clear all" label at

  • Fixed
    slice50-PPPP/outbox-idempotency: HashChainAuditJob MessageKey bucketised by hour + tampered-ids hash

    Sprint 50-PPPP audit — most MessageKey expressions across the codebase

  • Changed
    slice50-OOOO/capability-keys: consolidate capability key strings into ToRun.ByokVault.Capabilities.CapabilityKeys

    TEST_PLAN §4 deferred — capability key string literals (text-chat,

  • Fixed
    slice50-G-fu: persona-profile/-index touch-ups (linter + wrapper)

    - persona-profile.component.ts: drop outer `lpx-content-container py-4` wrapper

  • Changed
    slice50-workflow-engine/closeout: progress doc — final pass

    Three deferred items landed (or were dismissed) since the previous closeout

  • Added
    slice50-workflow-engine/qgate-audit: emit append-only audit row per QualityGate loop-back iteration (Rule 11)

    Completes the slice50-workflow-engine audit pass for the QualityGate

  • Changed
    slice50-media/locale-sweep: translate Phase1Note storage-provider keys across 6 more locales

    Continues the slice50-media Phase1Note translation pass started by

  • Changed
    slice50-media/ar: translate Phase1Note storage-provider keys to Arabic

    Replaces 8 [en] placeholder Admin:StorageProviders:Phase1Note:* and

  • Changed
    slice50-media/locale-maintenance: clean machine-translation artifacts + propagate Admin:* placeholders across 12 locales

    Sweeps the torun.media Localization resource for the 12 non-EN locales

  • Changed
    slice50-workflow/tr: translate workflow editor + wizard + templates to Turkish

    Replaces ~110 [en] placeholder values in the Authoring resource's

  • Added
    slice50-workflow/cursor-insert-and-edge-findings: variable chip auto-inserts at cursor + edge-level validator markers

    [Cursor-aware var insert (slice50-S)]

  • Added
    slice50-workflow/preflight-budget-estimator: IBudgetEstimator + DefaultBudgetEstimator + executor pre-flight check

    Closes the loop on slice50-I's per-node budgetUsd intent layer with

  • Added
    slice50-media/admin-polish: Open-in-dashboard link + Phase 1 posture banner on storage providers

    User-driven polish on the /media/storage-providers surface:

  • Added
    slice50-media/optimizer-config: scaffold Bunny Optimizer config block (disabled by default)

    Adds OptimizerOptions sub-block under BunnyCdnOptions for Pull-Zone-level

  • Added
    slice50-MMMM/template-sync: backend WorkflowTemplate ↔ TS catalog enrichment + CI audit

    Closes chip #118 last deferred item:

  • Added
    slice50-G/public-personas: /personas browse + /p/:handle detail + 29-locale prop

    Backend (modules/torun.persona):

  • Added
    slice50-LLLL/validation-overlay: edge markers + node corner badge + finding tooltips

    Closes the deferred item from chip #118 wrap doc:

  • Added
    slice50-workflow/inspector-vars-and-model: capability-filtered model dropdown + available variables chip strip

    Two inspector enhancements that close the gap between author intent

  • Added
    slice50-workflow/canvas-interactivity: pan/zoom + node-drag-to-reposition on the visual editor canvas

    WorkflowGraphComponent:

  • Added
    slice50-workflow/wizard-photos: real Bunny multipart upload + per-file progress

    Closes the deferred item from chip #118 wrap doc:

  • Added
    slice50-workflow/preview-only: cheap-proxy executor override for RequestPreviewAsync

    Closes the deferred item from the workflow-editor wrap (chip #118):

  • Added
    slice50-workflow/inspector-enhancements: inline validation markers + per-node budget cap + max-retries

    Two related extensions to the advanced editor surface:

  • Added
    slice50-workflow-engine/outbox: emit workflow.completed / workflow.failed v1

    Rule 8 (transactional outbox) — after the executor's RunSpecAsync returns

  • Changed
    slice50-media/complete: drop stale 'Coming soon' from landing descriptions — all 6 surfaces live

    StorageBrowse and UploadAsset landing card descriptions had leftover

  • Fixed
    slice50-workflow-engine/loopback: align template QGate configs with executor

    The existing executor's QualityGate node (Slice 449/449b) already implements

  • Added
    slice50-workflow-engine/template-run: preview + run-from-template AppService

    Single AppService surfaces three endpoints:

  • Added
    slice50-workflow-engine/resolver: IWorkflowModelResolver wrapper

    Workflow-node-shaped wrapper over Sprint 50-LLL's IModelRoutingService.

  • Added
    slice50-workflow-engine/public-template: catalogue read AppService

    User-facing wizard-catalogue endpoint.

  • Changed
    slice50-workflow: progress log + deferred work for the workflow editor rebuild

    Captures what landed this sprint (library landing + simple-mode wizard

  • Changed
    slice50-media/admin: propagate 80 Media:Admin:* keys to 28 sibling locales as [en] placeholders

    Auto-propagated from the en.json additions in 9b95c79c (admin panel

  • Added
    slice50-workflow/advanced-palette: draggable node palette + drop-on-canvas for the visual editor

    Replaces the existing add-node dropdown with a permanent left-rail

  • Added
    slice50-workflow/library-landing: user-facing template gallery + simple-mode wizard

    Replaces the /me/workflow-editor entry that dropped users straight into

  • Added
    slice50-workflow-engine/seed: seed 3 canonical workflow templates

    Idempotent host-pass DataSeedContributor that materialises the three wizard

  • Added
    slice50-media/scaffolding: activate /media admin panel — perms + DTOs + AppService backends

    Foundation for the six host-admin /media surfaces.

  • Added
    slice50-workflow-engine/entity: add WorkflowTemplate aggregate + permissions

    Catalog entity for wizard-surfaced workflow presets.

  • Added
    slice50-pub-wire: replace 4 view-adapter stubs with real DB reads

    Public-site MVC Razor pages were rendering hardcoded fixture data

  • Fixed
    slice50-pub-blog-seed: BlogPost unique index — (TenantId, Slug, Locale) compound

    DbMigrator hit E11000 on BlogPostsDataSeedContributor: the legacy

  • Added
    slice50-content-seed: seed 6 marketing blog posts × 29 locales (174 rows)

    BlogPostsDataSeedContributor adds the initial public marketing blog catalog

  • Added
    slice50-pub-scaffold: _Header.cshtml 29-lang locale switcher

    PublicWebsite layout header override:

  • Added
    slice50-pub-marketplace: IPublicMarketplaceBrowseAppService — [AllowAnonymous] rate-limited

    - Anonymous browse for /marketplace (paged listings)

  • Added
    slice50-pub-seo: sitemap.xml + robots.txt + LeptonX 404/500 overrides

    - Pages/Sitemap.cshtml (route /sitemap.xml) — returns sitemaps.org urlset

  • Added
    slice50-pub-legal-company-support: /legal/{slug}, Company quad, Support FAQ

    - Pages/Legal/Detail.cshtml (route /legal/{slug}) — Markdig-rendered long

  • Added
    slice50-pub-pricing: 5-plan grid with billing-cycle + channel toggle

    - Pages/Pricing/Index.cshtml (route /pricing) — Monthly/Yearly toggle (real

  • Added
    slice50-pub-docs: tree sidebar + markdown detail with prev/next nav

    - Pages/Docs/Index.cshtml (route /docs) — section grid landing + sidebar

  • Added
    slice50-pub-persona: IPublicPersonaBrowseAppService — [AllowAnonymous] rate-limited

    - Anonymous browse for /personas (paged catalog)

  • Added
    slice50-pub-landing: Index page LeptonX rewrite

    Pull landing data from IPublicLandingAppService stub + pricing teaser from

  • Changed
    slice50-pub-shared: public-site infra (Markdig + SEO + stub AppServices)

    - ToRun.Web.Public.csproj — add Markdig 0.37.0 for markdown rendering

  • Added
    slice50-pub-legal: IPublicLegalAppService — [AllowAnonymous] rate-limited

    - Anonymous read for /legal/{slug} — Terms, Privacy, Cookie, Refund,

  • Added
    slice50-pub-faq: IPublicFaqAppService — [AllowAnonymous] rate-limited

    - Anonymous read for /faq

  • Added
    slice50-pub-doc: IPublicDocAppService — [AllowAnonymous] rate-limited

    - Anonymous read for /docs (tree + by-slug)

  • Added
    slice50-pub-changelog: IPublicChangelogAppService — [AllowAnonymous] rate-limited

    - Anonymous read for /changelog (paged, PublishedAt DESC)

  • Added
    slice50-pub-forum: IPublicForumAppService — [AllowAnonymous] rate-limited

    - Threads list (paged, optional CategoryKey tag match against ForumThread.Tags)

  • Added
    slice50-pub-blog: IPublicBlogAppService — [AllowAnonymous] rate-limited

    - Anonymous read surface for /blog (list + by-slug)

  • Fixed
    slice50-smoke : MySettings — attribut de route [HttpPut] explicite

    smoke-backend.py a signalé un VERB_MISMATCH : Angular appelle un PUT nu

  • Added
    slice50-F/task#30 : PublicChatAppService — tour de démo anonyme, limite de débit par IP, facturation MarketingDemo

    Moitié backend de Sprint 50-F : chat de démo en page d'accueil anonyme avec limite par IP

  • Changed
    slice50-RRR-fu : BillingDailySummaryConsumer — inférence de type lors de la déconstruction de tuple

    Le dictionnaire `Dictionary<(DateTime Date, Guid?

  • Fixed
    slice50-UU-fu/task#73 : KeywordSettlement — index sparse unique sur ExternalId + gestion de la perte de course

    Ferme la seule fenêtre de course dans KeywordSettlementJob qui pouvait

  • Changed
    slice50-SS-task67 : ja.json lot 1/4 — ~140 premières clés à artefacts chinois → japonais natif

    Suite de la tâche #67 (balayage 50-SS).

  • Added
    slice50-RRR-2 : composite ImageEdit — UI de jetons multi-source + branche fournisseur

    Ferme le fondement 50-RRR (commits A/B/C) en câblant le composite réel

  • Changed
    slice50-NNN-fu : remplissage de locale InAppAssistant Sessions:* (10 clés × 28 locales)

    Remplissage de Toggle / Heading / New / Untitled / Empty / Load:Failed / JustNow / MinAgo / HourAgo / DayAgo dans les 28 locales non-anglaises (en.json disposait déjà du jeu complet depuis Sprint 50-CCC-2).

  • Added
    slice50-RRR-fu/task#74 : MarketplacePurchase — colonnes FK BundleId/CreatorProfileId/BuyerUserId + index

    Reproduit Sprint 50-LL (Post.CreatorProfileId) + Sprint 50-VV-2 (AdAuction

  • Added
    slice50-RRR/C : ImageEditPipeline — routage par topologie de clé de capacité

    Le pipeline dérive désormais la clé de capacité de la topologie d'entrée et utilise le

  • Added
    slice50-RRR/B : IAiImageClient.EditCompositeAsync + POCO InputBounds

    Contrat d'adaptateur pour le chemin composite multi-entrée.

  • Added
    slice50-RRR/A : modèle de forme de capacité — clés + InputBoundsJson + delta d'initialisation

    Commit fondateur pour la refactorisation d'édition multi-image (Option C — capacité

  • Added
    slice50-QQQ : persistance de ChatAttachment — observabilité pour le mystère du zéro insertion

    Constat de périmètre : le câblage dans ChatPipelineAppService.cs:1415 appelle déjà

  • Added
    slice50-SSS : balayage de journalisation d'observabilité — Bunny + OpenAI + ChatPipeline

    5 ajouts de journaux structurés pour que les échecs de production exposent leur contexte complet

  • Added
    slice50-NNN : session InAppAssistant — nettoyage auto des vides + X de suppression par ligne

    Correctif à deux volets pour la bulle accumulant des sessions vides / indésirables :

  • Added
    slice50-YY-2 : bulle InAppAssistant — enregistrement microphone Whisper STT dans le compositeur

    Ferme le -2 différé de 50-YY (où l'attachement micro avait été mis de côté pour que le

  • Added
    slice50-JJJJ : câblage de l'enregistreur UserActivity — pipelines ImageEdit + Translator + Video

    Comble la lacune inter-pipeline laissée par 50-AAA.

  • Added
    slice50-IIII : sélecteur de bibliothèque /me/image — streaming de blob + recherche + tri + pagination

    L'utilisateur a signalé que « Pick a source image » et « Pick a mask image »

  • Fixed
    slice50-HHHH : OpenAI DALL-E 3 — suppression du paramètre `style` (déprécié, erreur 400)

    Journal de production :

  • Fixed
    slice50-GGGG : édition d'image PUT — en-tête Bearer sur XHR + clé de locale de masque manquante

    L'utilisateur a signalé que le téléversement de source et de masque sur /me/image Édition

  • Added
    slice50-FFFF : regroupement par date en bibliothèque + câblage du template vue grille/liste

    Dernière tranche du module bibliothèque.

  • Changed
    slice50-EEEE : téléversement groupé en bibliothèque — bannière de succès unique, sans clignotement par fichier

    Retour utilisateur : la bannière verte « Upload complete. » clignotait pour

  • Fixed
    slice50-DDDD : suppression du module AbpStudioClient — cause racine du crash du flux de téléversement

    Sprint 50-CCCC a tenté de corriger l'ObjectDisposedException du pipeline de téléversement

  • Fixed
    slice50-CCCC : flux de téléversement en bibliothèque + rapport d'erreur par fichier

    Cause racine du toast « Upload failed » persistant — même si les fichiers

  • Added
    slice50-BBBB : UX du mode corbeille bibliothèque + hauteur max vidéo + remplissage md + rendu markdown + comptage du téléversement

    L'utilisateur a signalé cinq problèmes distincts :

  • Added
    slice50-AAAA : outbox de purge CDN + worker de marquage supprimé + UI de la corbeille

    L'utilisateur a signalé que part_001.wav / part_002.wav supprimés de la bibliothèque mais

  • Added
    slice50-ZZZ : correctif du spinner de prévisualisation en bibliothèque + UI de suppression groupée

    50-YYY avait laissé une régression : openAssetDetail ne déclenchait que le pré-chargement de texte

  • Added
    slice50-YYY : type Document en bibliothèque + aperçu de texte intégré + nettoyage de la modale

    L'utilisateur a signalé l'onglet Documents vide après avoir téléversé des fichiers .md / .txt —

  • Added
    slice50-XXX : lecture privée de la bibliothèque via le proxy de flux backend

    Le schéma d'URL publique CDN était incorrect pour /me/library — le contenu est par utilisateur

  • Fixed
    slice50-WWW : synchronisation des remplacements Bunny dev + vérité du comptage du téléversement en bibliothèque

    Deux bugs en un lot — les deux découverts lors d'un test utilisateur où 4 fichiers étaient « téléversés » selon la bannière verte mais la bibliothèque restait à 0 élément.

  • Added
    slice50-VVV : UI de progression enrichie pour le téléversement groupé en bibliothèque

    Utilisateur : « progress bar koy, uploading vs saniye yazsın, kullanıcı bilgilensin, böyle çok yavan duruyor »

  • Fixed
    slice50-UUU : repli octet-stream pour .md + journalisation détaillée du téléversement Bunny

    Deux problèmes bloquants pour l'utilisateur lors des tests /me/library :

  • Fixed
    slice50-TTT : acceptation MIME du téléversement en bibliothèque — selon le contexte (image uniquement vs mélange bibliothèque)

    L'utilisateur a signalé une erreur 400 « Only image/* MIME types are accepted on this endpoint. » lors du téléversement d'un fichier non-image depuis l'onglet Tout.

  • Fixed
    slice50-RRR : délai d'expiration Redis 5s → 15s — correctif de cascade HMGET ABP localization

    L'utilisateur a signalé une erreur 500 admin Message Citations « Internal error ».

  • Fixed
    slice50-PPP : identifiants de stockage Bunny Media — synchronisation avec le tableau de bord

    L'utilisateur a signalé que le téléversement en bibliothèque échouait avec « Bunny storage upload failed with HTTP 401 ».

  • Fixed
    slice50-OOO : génération d'image DALL-E 3 400 — suppression du paramètre response_format

    L'utilisateur a signalé /me/image Generate cassé : « Image generation provider »

  • Fixed
    slice50-MMM : overflow:visible du panneau InAppAssistant + correctif de coupure du menu déroulant + hygiène de liaison de position

    L'utilisateur a signalé que la refactorisation de position de panneau Sprint 50-III n'est TOUJOURS pas

  • Fixed
    slice50-JJJ : corps vide du message de bienvenue InAppAssistant — régression de source de message 50-CCC-2

    Cause racine (variante scénario B) : `openSession()` appelle `messages.set(mapped)`

  • Added
    slice50-LLL : la génération de titre route vers le modèle text-chat le moins cher (Règle 2 capability-first)

    Utilisateur : « You don't have to use the same model for titles, these are »

  • Fixed
    slice50-III : refactorisation de quadrant par position du FAB+Panneau InAppAssistant

    L'utilisateur a signalé que le panneau continuait à s'ouvrir détaché du FAB malgré Sprint

  • Fixed
    slice50-KKK : génération de titre de chat — ReasoningEffort=low + plafond de 1024 tokens (suite 50-CCC)

    Sprint 50-CCC avait relevé MaxOutputTokens 24 → 128 en attendant « ~100

  • Added
    slice50-AAA : enregistreur inter-modules IUserActivityRecorder — /me/activity-history alimenté pour les tours de chat

    L'utilisateur a signalé /me/activity-history vide malgré des heures de chat/image/voix/etc.

  • Fixed
    slice50-CCC : régression du titre de chat + visibilité du bouton de défilement vers le dernier message

    Deux régressions de test utilisateur trouvées et corrigées ; le troisième point

  • Fixed
    slice50-BBB : audit des menus admin InAppAssistant + Agent — initialisation de permission par module pour le rôle admin (1 correctif livré, 14/14 menus débloqués)

    | # | Menu | Groupe | Chemin Angular | Route backend | Statut | Cause racine |

  • Fixed
    slice50-GGG : téléversement groupé /me/library — sélection de plusieurs fichiers

    Utilisateur : « library dosya eklerken neden tek tek el ile eklemem gerekiyor »

  • Fixed
    slice50-FFF : onglet Édition /me/image — téléversement PC du masque via présignature Bunny

    Utilisateur : « source da upload from pc var da mask ta neden yok, bizim »

  • Fixed
    slice50-EEE : les fournisseurs Bunny exposent les interfaces IMediaStorageProvider + IVideoStreamProvider

    Bug critique signalé : chaque tentative de téléversement PC levait

  • Fixed
    slice50-DDD : préférences de notification 404 — ajout du suffixe d'action /my-preferences manquant

    L'utilisateur a signalé à plusieurs reprises depuis hier que /me/notifications/

  • Fixed
    slice50-ZZ : z-index du menu déroulant de la barre latérale chat — échapper à l'empilement du séparateur de jour

    La liste des chats récents dans /agent/chat-pipeline comportait Renommer/Supprimer par ligne

  • Fixed
    slice50-YY : FAB InAppAssistant haut-gauche + rétablissement cloche haut-droite + invite de consentement pour déclassement de modèle

    Les tests utilisateur ont soulevé 5 points ; 4 sont corrigés dans ce commit, 1

  • Added
    slice50-WW : MarketplaceRoyaltyPayoutCalculator — répartition quotidienne des redevances créateur (Plan §2.1 #7)

    Worker AsyncPeriodicBackgroundWorker quotidien (tick 24h) balaie les entrées Paid

  • Added
    slice50-XX : colonnes FK typées Bid/Impression/Click/Conversion AdAuction + index (Plan §2.2 / 50-VV-2)

    Sprint 47-O a créé des entités AdAuction plates sans FK de jointure ;

  • Added
    slice50-UU : KeywordSettlementJob — règlement quotidien Spot/Reserve/Futures (Plan §2.1 #6)

    Worker ABP AsyncPeriodicBackgroundWorker quotidien (tick 24h) balaie les entrées en attente

  • Added
    slice50-VV : structure de consommateur RTB AdAuction + liquidation au premier prix (Plan §2.1 #5)

    Sprint 50-TT avait été lancé pour ceci mais a dévié (il a

  • Added
    slice50-OO : système de quota /me/library — suivi du stockage + téléversement PC + débit du portefeuille

    L'utilisateur a demandé : indicateur de taille en haut de la bibliothèque, téléversement PC, quota par niveau de plan,

  • Added
    slice50-TT : verrous distribués par ligne pour les workers périodiques — sécurité multi-pods

    Étend le schéma 50-RR (VideoJobPollingWorker IAbpDistributedLock)

  • Added
    slice50-NN : téléversement PC depuis l'onglet Édition /me/image via pré-chargement Bunny

    Sprint 50-P avait différé le téléversement PC car le backend manquait d'un Bunny

  • Changed
    slice50-SS : ja.json lot 1/N — 300 premières clés à artefacts chinois → japonais natif

    50-AA a été interrompu durant le balayage complet ; voici la reprise par lots

  • Added
    slice50-RR : verrou distribué Redis VideoJobPollingWorker — sécurité multi-pods

    Sprint 50-U + 50-EE ont câblé le polling + le flux de remboursement mais supposaient un seul pod

  • Added
    slice50-QQ : déplacement des cloches notification+activité du flottant haut-droite vers la barre latérale

    Directive utilisateur (tour Sprint 50-E) : bell + activity sağdaki menü ikonlarının

  • Changed
    slice50-PP : regénération du proxy ignorée — backend non démarré

    Backend inaccessible sur https://localhost:44304 durant ce sprint ;

  • Added
    slice50-MM : dénormalisation Creator/Post.CreatorProfileId — correction de périmètre 50-LL

    Sprint 47-H a construit un index composite dégradé pour le fil Creator/Post

  • Added
    slice50-LL : dénormalisation PersonaPost.PersonaId + CreatorProfileId (Plan §2.2 — requête de fil)

    Sprint 47-H a construit un scan dégradé (TenantId, CreationTime) pour PersonaPost

  • Added
    slice50-JJ : IBillingRecorder.RecordPaddleTransactionAsync — auto-correction de réconciliation

    Sprint 50-W BillingReconciliationJob a détecté des lacunes (Paddle

  • Fixed
    slice50-KK : dérive du générateur de workspace Angular par module (anomalie Sprint 50-M)

    Chaque modules/torun.*/angular/angular.json référençait

  • Fixed
    slice50-II : remplacement des littéraux « sample-X » des *DataSeedContributor Suite par des espaces réservés valides

    Les tests d'isolation tenant Sprint 50-CC ont révélé un défaut préexistant :

  • Changed
    slice50-HH : script de suppression des index MongoDB hérités (Plan §2.1 #8)

    Le balayage MT Sprint 47-A..47-P a ajouté des index composites préfixés TenantId à chaque

  • Fixed
    slice50-FF : migration des groupes de modules InAppAssistant + Telemetry + EventBus + Persona

    Finalisation de la série Sprint 49.

  • Changed
    slice50-GG : scripts DBA de remplissage tenant pour le jour de lancement (Plan §2.4)

    Risque R2 avant lancement : Sprint 47-A..47-P a balayé plus de 219 entités pour

  • Added
    slice50-EE : extension IBillingRecorder.RefundAsync — enregistrement négatif lié

    Sprint 50-U a révélé une lacune : IBillingRecorder ne disposait que de RecordAsync.

  • Changed
    slice50-CC : tests d'isolation tenant pour subscription + agent + persona

    Plan §2.3 / audit R1 — Sprint 47-A...47-P a balayé plus de 219 entités pour

  • Changed
    slice50-DD : pipeline ImageEdit + propriété d'approbation de la bulle InAppAssistant

    Carnet de bord §2.5 : propagation de 22 clés du pipeline ImageEdit (Sprint

  • Fixed
    slice50-BB : balayage des collisions MessageKey dans l'outbox sur 7 sites d'émission

    Sprint 50-K a détecté une collision (config Paddle du plan d'abonnement

  • Added
    slice50-W : BillingReconciliationJob — audit quotidien de dérive Paddle↔local

    Phase 1.5 §2.1 #3 — troisième worker en arrière-plan.

  • Added
    slice50-X : PaddleSyncWorker — redondance périodique de l'état des abonnements

    Phase 1.5 §2.1 #4 — quatrième et dernier worker en arrière-plan avant lancement.

  • Fixed
    slice50-Z : lacune TypePredicate dans RunInputUploadAppService (suite 49-B)

    /api/app/run-input-upload renvoyait 404 car l'AppService était

  • Added
    slice50-Y : initialisation de la Capability d'édition d'image + AiModelCapability gpt-image-1 + liens de tarification

    Sprint 50-P a livré l'UI de l'onglet Édition /me/image + câblage backend mais

  • Fixed
    slice50-S : émission de timestamps UTC avec Z — sérialiseur backend + convention Mongo

    Le frontend (Angular | date pipe + constructeur Date) gère UTC → local

  • Added
    slice50-U : VideoJobPollingWorker — durcissement IHostedService Sora-2

    Phase 1.5 §2.1 — worker en arrière-plan prioritaire.

  • Added
    slice50-V : DunningAttemptScheduler — miroir de nouvelle tentative Paddle past_due

    Phase 1.5 §2.1 #2 — deuxième worker en arrière-plan.

  • Fixed
    slice50-Q : consommateur SSE InAppAssistant + UX d'annulation + garde de nouvelle tentative

    L'utilisateur a signalé que le tour de suivi « form doldurma » renvoyait « Message failed.

  • Fixed
    slice50-T : collage depuis le presse-papiers dans le chat + corps vide de memory_forget

    Bug A : le compositeur de chat ignorait Ctrl+V pour les images du presse-papiers.

  • Fixed
    slice50-R : mise en page /marketplace — suppression du lpx-content-container extérieur

    La page de navigation Marketplace (angular/src/app/marketplace/

  • Fixed
    slice50-P : parité de l'onglet Édition /me/image + lignes de boutons responsives

    L'onglet Édition manquait la sélection du modèle (Auto/Manuel), la qualité

  • Fixed
    slice50-N : FAB InAppAssistant par défaut → bas-gauche + correctif d'ancrage du panneau

    L'utilisateur a signalé que le positionnement par défaut Sprint 50-I (bottom:96 right:24) chevauche

  • Fixed
    slice50-O : migration des routes /me/notifications + préférences (oubli du Sprint 49-B)

    Les tests utilisateur sur /me/notifications renvoyaient 404 sur

  • Fixed
    slice50-M : suppression de WalletTopUpPriceIds — toujours utiliser un prix en ligne hors catalogue

    PaddleOptions.WalletTopUpPriceIds était un Dictionary<string,string>

  • Fixed
    slice50-L : paiement Paddle — journalisation du statut + corps sur 4xx/5xx

    Utilisateur : « paddle.js popup açması lazım, hata veriyor » lors de

  • Fixed
    slice50-I : glisser le FAB InAppAssistant (annulation du glisser du panneau) + alignement du menu déroulant de notification

    Sprint 50-I corrige deux régressions UX apparues après Sprint 50-B + 50-E :

  • Fixed
    slice50-K : collision MessageKey dans l'outbox lors du second enregistrement Paddle d'un plan

    L'administrateur a enregistré la config Paddle d'un SubscriptionPlan ; le premier enregistrement fonctionnait.

  • Fixed
    slice50-J : ventilation de la facturation — $ uniquement sur les champs monétaires

    Le tableau de ventilation des coûts sur /me/billing préfixait naïvement chaque

  • Fixed
    slice50-H : migration des routes chat-pipeline + Chat dans le menu /me

    Sprint 49-B avait laissé deux URLs /api/app/* codées en dur dans le chat-pipeline

  • Changed
    slice50-Fi : propagation consolidée — glisser/ancrer 50-B + modales workflow 50-D + centre notification-activité 50-E dans 29 fichiers de locale

    - 50-B (InAppAssistant:Bubble:Dock/Undock/DragHint) : ajouté à en.json + les 28 autres locales avec traductions natives

  • Fixed
    slice50-D : remplacement global des confirm/alert/prompt JS natifs → ABP ConfirmationService + modales LeptonX

    Utilisateur : « sil tıkladığımda js confirm çıkıyor, biz neden leptonx e »

  • Fixed
    slice50-B : tri des tool_calls InAppAssistant + bulle déplaçable/ancrable (CRITIQUE)

    Correctif A (bug serveur CRITIQUE) :

  • Fixed
    slice50-C : rendu du menu déroulant /me/billing + contenu des onglets vide (UX CRITIQUE)

    Signalement utilisateur : le menu déroulant SourceKind affichait des blocs rose/bleu déformés (cassé

  • Fixed
    slice50-A : les cloches notification + centre d'activité ne chevauchent plus l'étiquette admin

    Retour utilisateur : les deux cloches flottantes (cloche de notification + centre d'activité)

  • Fixed
    slice47-J : subscription lot #2 FINAL — Subscription/Invoice/BYOK/QueuedRequest IMultiTenant (Phase 2 CRITIQUE)

    Application du schéma Sprint 47-I + 45-M.

  • Added
    slice48-B : coût d'embedding lié à l'instantané AiModelPricing (suite Sprint 46-A)

    Sprint 46-A a introduit IBillingRecorder inter-modules + émission de BillingRecords

  • Fixed
    slice48-A : traductions natives du module translation ja/ko/pt/sv (~272 entrées)

    La normalisation structurelle Sprint 46-F (lowercase→PascalCase) s'est achevée mais a laissé 4 locales avec du contenu anglais issu des stubs Suite.

  • Fixed
    slice47-I : correctif d'audit MT subscription lot #1 — Wallet/BillingRecord/Refund/Dispute IMultiTenant (Phase 2 CRITIQUE FINANCIER)

    Application du schéma Sprint 45-M + 47-A à 47-N.

  • Fixed
    slice47-N : correctif d'audit MT agent lot #2 — Council/DeepResearch/CodeSandbox/Voice/Translator IMultiTenant (Phase 2)

    Application du schéma Sprint 47-M.

  • Fixed
    slice47-L : correctif d'audit MT authoring lot #2 — GenJobs/BlogPost/quotas IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M + 47-K.

  • Fixed
    slice47-M : correctif d'audit MT agent lot #1 — Chat/ChatMessage/Assistant IMultiTenant (Phase 2 RISQUE ÉLEVÉ)

    Application du schéma Sprint 45-M + 47-A à 47-K.

  • Fixed
    slice47-K : correctif d'audit MT authoring lot #1 — écosystème Workflow IMultiTenant (Phase 2 RISQUE ÉLEVÉ)

    Application du schéma Sprint 45-M + 47-A à 47-H.

  • Fixed
    slice47-P : correctif d'audit MT marketplace — 15 entités IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M + 47-A/B/C/D/E/F/G/O.

  • Fixed
    slice47-H : correctif d'audit MT creator lot #2 — entités Posts/Teams/Payouts IMultiTenant (Phase 2 RISQUE ÉLEVÉ)

    Application du schéma Sprint 45-M + 47-G.

  • Fixed
    slice47-O : correctif d'audit MT advertising — 16 entités IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M + 47-A/B/C/D/E/F.

  • Fixed
    slice47-G : correctif d'audit MT creator lot #1 — entités Profile/Account/Org IMultiTenant (Phase 2 RISQUE ÉLEVÉ)

    Application du schéma Sprint 45-M + 47-A/B/C/D/E.

  • Fixed
    slice47-F : correctif d'audit MT forum — 19 entités IMultiTenant + diffusion des notifications par tenant (Phase 2)

    Application du schéma Sprint 45-M + 47-A/B/C/E.

  • Fixed
    slice47-D : correctif d'audit MT telemetry — 18 entités IMultiTenant + rédacteurs inter-modules limités au tenant (Phase 2 RISQUE ÉLEVÉ)

    Application du schéma Sprint 45-M + 47-A + 47-B.

  • Fixed
    slice47-E : correctif d'audit MT persona — 16 entités IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M + 47-A/B/C.

  • Fixed
    slice47-C : correctif d'audit MT moderation — 11 entités IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M + 47-A/B.

  • Fixed
    slice47-B : correctif d'audit MT byokvault + knowledge — 7 entités IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M + 47-A.

  • Fixed
    slice47-A : correctif d'audit MT eventbus + translation — 8 entités IMultiTenant (Phase 2)

    Application du schéma Sprint 45-M : Suite n'émettait pas IMultiTenant sur les classes de base malgré IsMultiTenant: true dans le JSON.

  • Added
    slice56-57-58: capability-first routing + Authoring stub fix

    Slice 56 — IModelRoutingService (ByokVault.Application + Contracts):