Changelog

What is new on the ToRun platform, newest first.

v@release.Version

minor
14 giu 2026

June 2026 — 53 changes

  • Added
    Più modelli per immagini e video tra cui scegliere

    Il selettore dei modelli ora include Google Imagen e Gemini per le immagini, e OpenAI Sora e Google Veo per i video, accanto ai modelli che già avevi. Scegli esattamente quello che desideri, oppure lascia che Auto trovi…

  • Added
    Workflow AI senza codice e il Marketplace dei creator sono online

    Concatena più passaggi AI in un workflow da avviare quando vuoi, poi pubblicalo sul Marketplace o esplora quello che altri creator hanno condiviso. Workflow Editor, Runner e Marketplace sono ora disponibili direttamente…

  • Added
    Installa ToRun sul tuo telefono

    Aggiungi ToRun alla schermata Home e avvialo come un'app nativa, a schermo intero e con la sua icona: a un solo tocco di distanza, in attesa dell'app mobile.

  • Added
    Un look rinnovato per ToRun.ai

    Un nuovo logo e un branding più pulito in tutta l'app, ottimizzato sia per il tema chiaro che per quello scuro.

  • Added
    Risposte più intelligenti e personali

    Scegli quanto a fondo deve ragionare l'AI, ora anche in modalità Auto. I prompt per le immagini possono attingere in modo discreto alla tua memoria salvata, così i risultati rispecchiano le persone e i dettagli che ti st…

  • Fixed
    Uno studio per immagini, video e musica più ordinato

    L'avanzamento della generazione appare ora accanto al risultato, anziché sotto il modulo, ogni pagina si apre pulita e la tua ultima creazione resta sempre in primo piano, mentre quelle precedenti trovano posto nella tua…

  • Fixed
    Un wallet più chiaro e una Library più fluida

    La cronologia del tuo wallet è ora suddivisa in pagine e mostra gli importi esatti anche sotto il centesimo, e rimuovere elementi dalla tua Library non genera più errori.

  • Added
    Diventa inserzionista in self-service

    Crea il tuo account inserzionista e invia le campagne per la revisione direttamente dal tuo account, senza dover attendere alcuna configurazione manuale.

  • Fixed
    Affidabilità, precisione di fatturazione e maggiore sicurezza

    Dietro le quinte: una contabilizzazione più equa dei crediti gratuiti, controlli più rigorosi su pagamenti e permessi dei creator, una moderazione dei contenuti multimediali più sicura ed esecuzioni dei workflow più affi…

  • Added
    Un secondo motore di traduzione in tempo reale, con 77 lingue

    La Traduzione in tempo reale ora ti permette di scegliere tra due motori e selezionare quello più adatto alla tua conversazione, inclusa una nuova opzione che parla 77 lingue, tra cui turco e russo. Ogni scelta mostra su…

  • Added
    Un selettore di modelli più chiaro e più modelli nel piano Free

    I modelli non inclusi nel tuo piano ora compaiono con un piccolo lucchetto e un modo per passare a un piano superiore o ricaricare il portafoglio con un solo tocco, invece di darti errore solo dopo l'invio. Abbiamo anche…

  • Added
    Il tuo assistente ricorda le immagini che condividi

    Condividi un'immagine una volta sola e l'assistente conserva ciò che ha visto per tutto il resto della conversazione, così puoi farci domande anche molti messaggi dopo, persino dopo aver cambiato modello, senza mai ricar…

  • Added
    Diagrammi, tabelle e formattazione più ordinata in chat

    Le risposte in chat ora disegnano i diagrammi come veri diagrammi, presentano le tabelle con bordi ben definiti e dimensionano i titoli in base al messaggio invece di riempire lo schermo, così le risposte sono più facili…

  • Fixed
    Sempre chiaro quando qualcosa non è incluso, mai un vicolo cieco

    Quando un modello richiede un piano superiore o il tuo saldo è basso, ora ricevi un avviso amichevole con i pulsanti Cambia piano e Ricarica portafoglio direttamente lì. Le risposte che non possono essere generate spiega…

  • Fixed
    Gli orari ora vengono mostrati nel tuo fuso orario

    I record di fatturazione, la cronologia e le attività vengono ora visualizzati nella tua ora locale anziché in UTC, così le marche temporali corrispondono all'orologio davanti a te.

  • Fixed
    Un elenco delle chat più ordinato

    Avviare una nuova chat ora riutilizza quella vuota già esistente invece di accumulare chat in bianco, le chat rimaste senza risposta non ingombrano più l'elenco e i titoli provvisori vengono sostituiti da un nome vero no…

  • Added
    Fai pubblicità su ToRun

    Le aziende possono ora creare un account inserzionista e gestire le proprie campagne pubblicitarie dall'inizio alla fine: crea le campagne, aggiungi le creatività che le accompagnano e inviale per una rapida revisione pr…

  • Added
    Usa la tua API key per voce e traduzione in tempo reale

    Usare la chiave del tuo provider ora copre anche la voce in tempo reale, la traduzione dal vivo e la trascrizione dal vivo: l'utilizzo dell'AI passa attraverso la tua chiave e noi addebitiamo solo la piccola tariffa al m…

  • Fixed
    Sito pubblico rinnovato, caricamenti più sicuri e registrazione più fluida

    Le nostre pagine pubbliche sono ora basate su contenuti modificabili in tante lingue, le immagini caricate vengono controllate alla ricerca di contenuti non sicuri prima di essere archiviate, la registrazione dell'accoun…

  • Added
    Le chat continuano a generare, anche quando cambi schermata

    Le risposte lunghe ora vengono elaborate sul server e proseguono mentre passi da una chat all'altra, apri un'altra pagina o chiudi la scheda. Torna quando vuoi: la risposta è ancora in arrivo, oppure è già pronta per te.

  • Added
    I progetti ora danno a ogni chat il contesto giusto

    Le chat avviate all'interno di un progetto ne ereditano automaticamente le istruzioni, le conoscenze caricate e la memoria, mostrano un badge del progetto con un collegamento rapido di ritorno e ne riportano il nome tra…

  • Added
    Una memoria che capisce il tempo — e che puoi modificare

    La memoria del tuo assistente ora tiene traccia della rapidità con cui cambia ogni informazione e segnala quelle che potrebbero essere superate, così da basarsi su ciò che è ancora vero. Un nuovo editor ti permette di ri…

  • Added
    I modelli più recenti, con pagine dedicate per Traduci e Trascrivi

    Abbiamo aggiunto gli ultimi modelli per immagini, video, trascrizione e voce in tempo reale e attivato pagine indipendenti Traduci e Trascrivi, così puoi raggiungere questi strumenti direttamente dal menu.

  • Added
    Traduttore vocale in tempo reale

    Parla e lascia che le tue parole vengano tradotte quasi all'istante: scegli due lingue, invertile con un solo tocco e il traduttore acquisisce la tua voce e trasmette la traduzione mentre parli.

  • Added
    Uno studio video più chiaro e più onesto

    La pagina video ora mantiene allineate le sue anteprime quando elimini un elemento dalla libreria, ti consente di impostare la durata della clip per ogni modello, rimuovere singole clip e contrassegna chiaramente i risul…

  • Fixed
    Un assistente in-app più curato

    L'assistente in-app ora mostra risposte ben formattate, mantiene in vista l'ultimo messaggio mentre scrive, salva in modo affidabile la risposta completata e assegna a ogni conversazione un titolo automatico.

  • Fixed
    Le risposte della chat vengono visualizzate in modo affidabile: link, formule e valute

    Le risposte che contengono link, formule matematiche o importi in valuta non appaiono più vuote o visualizzate a metà, nemmeno dopo aver ricaricato la pagina, e le risposte di ricerca approfondita includono sempre il rie…

  • Fixed
    Affidabilità, precisione della fatturazione e rafforzamento della sicurezza

    Un ampio lavoro dietro le quinte: misurazione dell'utilizzo e totali di spesa più precisi, rimborsi automatici più equi, messaggistica in tempo reale più solida, maggiori tutele per privacy e sicurezza e messaggi sullo s…

  • Fixed
    Leggi i contenuti del blog e della community senza accedere

    I post pubblici del blog e le discussioni del forum — comprese le reazioni e le risposte — ora sono visibili anche ai visitatori che non hanno effettuato l'accesso.

  • Fixed
    Prezzi più chiari e una gamma di modelli più ordinata

    L'utilizzo ora viene addebitato con un unico ricarico equo, gli indicatori della spesa mensile e del budget residuo sono accurati e l'elenco dei modelli è stato ripulito — i modelli obsoleti sono stati ritirati e quelli…

  • Added
    Gli annunci e i pacchetti del marketplace ora mostrano le immagini di copertina

    Gli annunci di workflow e i pacchetti possono mostrare un'immagine di copertina vera e propria, rendendo il marketplace più piacevole e facile da esplorare.

  • Added
    Il tuo assistente integrato ora può agire al posto tuo

    Chiedi all'assistente e lui compilerà i moduli, premerà i pulsanti e si muoverà nell'app per te — il tutto grazie a un set di strumenti più ampio, che ora arriva fino ai contatti, alle FAQ, al forum, alla memoria e alla…

  • Added
    L'assistente scrive la sua risposta in tempo reale, in una bolla che puoi spostare

    Le risposte ora compaiono parola dopo parola anziché tutte insieme, e la bolla dell'assistente può essere trascinata dove preferisci, con un'anteprima in tempo reale di ciò su cui sta lavorando.

  • Fixed
    Crea e organizza i Progetti senza intoppi

    Creare un progetto e avviare una nuova chat al suo interno ora funziona senza problemi, così puoi tenere insieme chat, file e contesto correlati.

  • Fixed
    Video, avatar e voce più fluidi

    I video vengono riprodotti in modo affidabile, i contenuti multimediali privati si caricano tramite un proxy sicuro, gli avatar di creator e persona ora sono visibili a tutti e le note vocali vengono trascritte senza err…

  • Fixed
    Avvisi sullo stato del servizio più chiari

    Quando una parte del servizio ha problemi, l'avviso ora è più facile da capire e non rivela più i nomi interni dei fornitori.

  • Added
    Collega le tue app preferite all'assistente

    Connetti app esterne con un solo accesso o una chiave API, così l'assistente può lavorare direttamente con gli strumenti che già usi.

  • Fixed
    Generazione e modifica delle immagini più affidabili

    Gli strumenti per le immagini ora scelgono un modello adatto a ciò che stai facendo, mostrano un'anteprima istantanea del risultato e la modifica funziona di nuovo dopo un cambio di modello del provider.

  • Fixed
    Un file eliminato non blocca più le tue chat o la galleria

    Quando un'immagine o un allegato è stato rimosso, la cronologia delle chat, la galleria multimediale e l'editor di immagini ora mostrano un segnaposto chiaro invece di interrompersi con un errore.

  • Added
    Traduci in circa 100 lingue

    Il traduttore ora offre un selettore con ricerca tra circa 100 lingue, ciascuna indicata con il proprio nome nativo e quello inglese.

  • Added
    Nuovi post del blog e discussioni nella community

    Abbiamo aggiunto una serie di nuovi articoli del blog e discussioni nel forum — comprese domande con risposta — così c'è subito molto altro da leggere ed esplorare.

  • Added
    Nuovi strumenti in chat: file, codice, immagini, audio e altro ancora

    La chat può ora cercare nei tuoi file caricati, eseguire Python in un sandbox, modificare immagini, trascrivere e riprodurre audio, e avviare i tuoi workflow — tutto senza uscire dalla conversazione.

  • Added
    Ricerca web e ricerca approfondita, con citazioni

    Lascia che la chat cerchi sul web in tempo reale, esegua ricerche approfondite multi-fonte e recuperi e legga pagine complete — ogni risposta include le fonti utilizzate.

  • Added
    Chat che ricorda — e dimentica su richiesta

    Il tuo assistente ora mantiene una memoria leggera tra le chat, può elencare ciò che ricorda e rispetta una richiesta di dimenticanza in qualsiasi lingua.

  • Added
    Crea immagini, video e musica in un unico studio

    Genera e modifica immagini, produci cortometraggi e componi canzoni con testi — grazie ai nuovi motori di immagine, video e musica, con un selettore multimediale condiviso e la tua libreria a portata di clic.

  • Added
    Modalità vocale in tempo reale

    Parla con ToRun ad alta voce — una nuova funzionalità vocale in tempo reale porta conversazioni parlate e trascrizione live nella chat.

  • Added
    Workflow: esecuzioni quality-first, approvazioni e ripresa

    Le esecuzioni del workflow ora preferiscono modelli di qualità premium, si mettono in pausa per la tua approvazione dove necessario e possono essere annullate, rigenerate e riprese — con ogni output salvato direttamente…

  • Added
    Progetti: organizza il tuo lavoro

    Raggruppa chat correlate, file e contesto in Progetti così il tuo assistente avrà sempre il giusto contesto per il compito da svolgere.

  • Added
    Canvas: uno spazio di lavoro affiancato

    Redigi e perfeziona contenuti di lunga durata e codice in un pannello canvas dedicato affiancato alla tua chat.

  • Added
    Conversazioni più intelligenti e più lunghe

    Riepiloghi progressivi, finestre di contesto più intelligenti e scorrimento rapido della cronologia mantengono le conversazioni lunghe coerenti e fluide, con controlli chiari quando una conversazione supera la finestra d…

  • Added
    Fatturazione onesta e trasparente

    Una franchigia gratuita equa che si ricarica su una finestra mobile, gauge di spesa più chiari, rimborsi automatici quando la generazione di immagini o video non va a buon fine, e controlli dello sforzo di ragionamento c…

  • Added
    Un catalogo modelli più ampio e aggiornato

    Decine di modelli 2026 aggiunti e quelli obsoleti ritirati, più una sincronizzazione automatica giornaliera che mantiene aggiornati i modelli e i prezzi dei provider — gestiti da un nuovo catalogo admin.

  • Added
    Condividi le tue migliori chat

    Pubblica una conversazione su un link pubblico e fai crescere la community attorno a ciò che crei.

v@release.Version

minor
31 mag 2026

May 2026 — 499 changes

  • Changed
    52-Q-SMOKE-HARNESS: suite smoke end-to-end ripetibile + primo report di regressione

    Harness console .NET standalone (test/ToRun.SmokeTests) che si autentica contro l'Host in esecuzione (grant password OpenIddict) e verifica ogni funzionalità core end-to-end tramite la vera API HTTP: auth/me, CRUD memori…

  • Fixed
    52-Q-AI-MEDIA-ACCESS: lettura Bunny autenticata per tutti i recuperi media nella pipeline

    I media della piattaforma risiedono in una Storage Zone Bunny PRIVATA, quindi una semplice

  • Added
    52-Q-MEMORY-CHAT: strumento memory_list + forget indipendente dalla lingua funzionante

    Completa la funzionalità di gestione della memoria via chat sopra

  • Fixed
    52-Q-MEMORY-FORGET-I18N: corrispondenza fold indipendente dalla lingua + fallback semantico

    memory_forget restituiva no_match per i ricordi che esistono.

  • Fixed
    52-Q-GEMINI-FLASH-400: aumento del valore minimo thinkingBudget flash 128->512 + registrazione del corpo Google 400

    gemini-2.5-flash ha iniziato a restituire HTTP 400 con thinkingBudget=128 (il valore basso 52-N

  • Fixed
    52-Q-MODEL-MENU: nidificazione di model-catalog + onboarding nel gruppo di navigazione ByokVault

    Le due pagine host-admin (/admin/model-catalog, /admin/model-onboarding)

  • Fixed
    52-Q-MODEL-SYNC-DEDUP: esclusione delle varianti modello con snapshot datati nella discovery

    La discovery corrispondeva soltanto per ProviderModelId/ModelKey esatto, quindi i provider datati

  • Changed
    52-Q-CHAT-EFFORT-UX-LOCALE: propagazione del testo effort locked + WalletCta a 28 locale

    Il gate dello sforzo di ragionamento è ora basato sul finanziamento, non sul livello.

  • Added
    52-Q-MODEL-SYNC-AI: fallback di analisi AI della pagina prezzi per la sincronizzazione modelli

    Fusione best-of-both nel sync 52-Q-MODEL-SYNC-JOB già atterrato: quando OpenRouter

  • Fixed
    52-Q-CHAT-EFFORT-UX: gate dello sforzo consapevole del wallet/finanziamento

    Il selettore dello sforzo di ragionamento era rigidamente bloccato al livello di abbonamento più un'esenzione admin/host da un approccio precedente, rifiutato.

  • Changed
    52-Q-MODEL-SYNC-JOB: ricerca di sincronizzazione provider + mappa architetturale

    Deliverable di fase 1: inventario lista/fonte-prezzi di 26-provider, il

  • Added
    52-Q-MODEL-ONBOARDING: gestione del catalogo modelli host-admin (lista/modifica/elimina)

    La procedura guidata di onboarding (fasi A-D) crea SOLTANTO righe nel catalogo; non era disponibile nessun

  • Added
    52-P-SHARE: condivisione pubblica + superficie di crescita community

    Backend (torun.agent): SharedChat aggiunge IsListed/ListedSlug/ListedAt + campi carta denormalizzati; PublicCommunityAppService + PublicCommunityController (feed /community anonimo + visualizzatore by-slug); CommunityLis…

  • Fixed
    52-Q-CHAT-AUDIO-BRIDGE: trascrizione audio caricato + riparazione del player audio

    Gli allegati audio nella chat erano non funzionanti; le cause radice effettive differivano da

  • Fixed
    52-Q-CHAT-CONTEXT-SLASH: persistenza della modalità overflow del contesto + preset slash per UX trasparente

    PARTE 1 — il menu a tendina "Gestione overflow del contesto" nell'intestazione chat era bloccato su

  • Fixed
    52-Q-BUDGET-BUILD: rimozione del riferimento orfano IsCurrentMonth al BudgetBucketCacheItem.DailyKey rimosso

    La rimozione del limite giornaliero (84178afab) ha eliminato DailyKey/MonthlyKey da BudgetBucketCacheItem

  • Changed
    52-Q-SMOKE-INTEG: ripristino del livello Mongo (AiModels dup _id + durata transazione UoW) + test di integrazione dell'isolamento del trasporto ResolveAsync

    Parte 1 — ripristino del livello di test di integrazione MongoDB in rosso.

  • Changed
    52-Q-CHAT-EFFORT-LOCALE: propagazione di 7 chiavi ChatComposer:Effort a 28 locale

    Stringhe del selettore dello sforzo di ragionamento (Effort:Tooltip, Effort:Locked:Tooltip,

  • Added
    52-Q-CHAT-EFFORT: selettore dello sforzo di ragionamento per modello cablato end-to-end

    Controllo dello sforzo di ragionamento canonico e indipendente dal provider sul compositore chat,

  • Changed
    52-Q-BUDGET-DAILYCAP-REMOVE: rimozione del limite giornaliero inerte + minuti attivi

    Passaggio finale di rimozione del codice morto per la riscrittura del budget a finestra di sessione.

  • Changed
    52-Q-MONTHLY-SPEND-FIX: correzione dei commenti della fonte di spesa + doc XML alla telemetria UserDailySummary

    Il gauge Spesa Mensile/Giornaliera legge la telemetria UserDailySummary (ScopeKey=userId,

  • Changed
    52-Q-BUDGET-DEADCFG: rimozione dei parametri di configurazione Allowance inutilizzati

    Follow-up di audit alla riscrittura del budget a finestra di sessione (2a33fd31f).

  • Fixed
    52-Q-BUDGET-BUCKET-GAUGE-ZERO: anteprima della capacità di sessione configurata su cache-miss del bucket

    Il gauge del budget-bucket nella home (/) + me-home mostrava "$0.00 / 0% / $0.00" ogni volta che

  • Added
    52-Q-BUDGET-HUMANE: franchigia gratuita a finestra di sessione mobile (capacità $0.20 / 5h)

    Il budget bucket del livello gratuito era un gocciolamento "$2 / 30d / 24h": ricarica = $2/720/h e

  • Fixed
    52-Q-BUDGET-BUCKET-GAUGE-UX: gauge del bucket leggibile — precisione a 4 decimali + suggerimento periodo di burst gratuito

    Il gauge BUDGET BUCKET nella home (/) e nella me-home (/me) mostrava "$0.00 (2% / $0.01)":

  • Fixed
    52-Q-CHAT-HISTORY-VISION-LEAK: rimozione delle parti immagine dalla cronologia per i modelli solo testo

    Bug di visione multi-turn.

  • Changed
    52-Q-SMOKE: classificazione routing realtime + reasoning (guardie no-DB)

    Primo blocco di regressione nel livello smoke.

  • Added
    52-Q-INVOCATION-PROTOCOL: isolamento del trasporto dei modelli dal routing di completamento

    Correzione della causa radice per i ricorrenti 404 di title-gen / public-chat / vision: la capability

  • Fixed
    52-Q-VISION-BRIDGE: esclusione degli SKU realtime dal routing vision basato sul completamento — VERIFICATO

    Utente confermato: la descrizione delle immagini funziona ora.

  • Fixed
    52-Q-CHAT-IMG-PROXY: verifica dell'appartenenza allegato tramite catena ChatMessageId

    L'ambito del proprietario restituiva 403 anche per il legittimo proprietario della chat: chat create dal manager

  • Fixed
    slice52-Q-CHAT-IMG-PROXY: rendering delle immagini della cronologia chat tramite stream-proxy backend (correzione Bunny 503)

    A3 VERA causa radice (trovata dal test live nel browser): immagine allegato chat

  • Changed
    slice52-Q-AUDIT: registro audit bug critici della pipeline — C1 ciclo DI risolto, M1 Quartz prescritto, TODO per pipeline

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

  • Fixed
    slice52-Q-QUEUE-DI-CYCLE: interruzione del ciclo DI del dispatcher in coda tramite dipendenza lazy del tool workflow-run

    La risoluzione di IQueuedRequestDispatcher causava StackOverflow all'avvio (non intercettabile — una

  • Fixed
    slice52-Q-LOG-ROLLING: rotazione + limite del file sink Serilog (si interrompeva silenziosamente a 1 GB)

    Sia il sink runtime dell'Host (appsettings.json) sia i logger di bootstrap

  • Fixed
    slice52-Q-CHANGELOG-IDEMPOTENT: indicizzazione del seed changelog su Slug, non ExternalId (correzione permanente E11000)

    Causa radice ricorrente: ChangelogBackfillDataSeedContributor verificava l'idempotenza su

  • Changed
    slice52-Q-CHANGELOG: backfill changelog sprint + chiavi 29-locale (93 nuovi sprint)

    Eseguito extract-sprint-changelog.py + propagate-changelog-locales.py da 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 capability voice-realtime + join

    EnBillingSource.RealtimeVoice + seed capability voice-realtime + join

  • 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: distribuzione di 25 chiavi voice-mode a 28 lingue sorella

    Replica delle chiavi UI voice-realtime aggiunte a en.json in

  • 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: aggiunta della voce dello sweep notturno 52-O a PROGRESS.md

    Per CLAUDE.md Regola 10.

  • Changed
    52-O-NIGHT/locale-validation-report: report di parità per-risorsa × per-locale dopo il fan-out del traduttore a 6 agenti

    Output di `python platform-plan/scripts/_validate-29-locales.py` dopo l'atterraggio di tutti e 27 i batch dei traduttori di lingua sorella + il passaggio BOM-strip:

  • Changed
    52-O-NIGHT/translator-batches: 25 batch di traduzione nativa atterrati — totale ~7,800+ chiavi su 52 file

    Batch da 6 agenti Sonnet traduttori in parallelo (tutti già registrati nel repo dai turni precedenti + gruppo finale appena scaricato):

  • 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: revisione del codice chat pipeline + InAppAssistant — 4 Alta + 8 Media + 5 Bassa

    Analisi di sola lettura su ChatPipelineAppService + InAppAssistant + client provider + 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 — attributo route [HttpPut] esplicito

    smoke-backend.py ha rilevato un VERB_MISMATCH: Angular chiama PUT nudo

  • Added
    slice50-F/task#30: PublicChatAppService — turno demo anonimo, rate limit per IP, fatturazione MarketingDemo

    Backend di Sprint 50-F: chat demo landing page anonima con per-IP

  • Changed
    slice50-RRR-fu: BillingDailySummaryConsumer — inferenza tipo decostruzione tuple

    Il dizionario `Dictionary<(DateTime Date, Guid?

  • Fixed
    slice50-UU-fu/task#73: KeywordSettlement — indice sparse univoco su ExternalId + gestione race-loss

    Chiude l'unica finestra di race in KeywordSettlementJob che poteva

  • Changed
    slice50-SS-task67: ja.json lotto 1/4 — prime ~140 chiavi con artefatti cinesi → giapponese nativo

    Continuazione del task #67 (spazzata 50-SS).

  • Added
    slice50-RRR-2: ImageEdit composito — UI chip multi-sorgente + branch provider

    Chiude la fondazione 50-RRR (commit A/B/C) cablando l'effettivo composito

  • Changed
    slice50-NNN-fu: backfill locale InAppAssistant Sessions:* (10 chiavi × 28 locale)

    Backfill di Toggle / Heading / New / Untitled / Empty / Load:Failed / JustNow / MinAgo / HourAgo / DayAgo in tutti i 28 locale non inglesi (en.json aveva già il set completo da Sprint 50-CCC-2).

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

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

  • Added
    slice50-RRR/C: ImageEditPipeline — routing topologia capability-key

    La pipeline ora deriva la chiave capability dalla topologia di input e usa

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

    Contratto adapter per il percorso composito multi-input.

  • Added
    slice50-RRR/A: modello capability-shape — chiavi + InputBoundsJson + delta seed

    Commit fondamentale per il refactoring modifica multi-immagine (Opzione C — capability

  • Added
    slice50-QQQ: persistenza ChatAttachment — osservabilità per il mistero degli zero-insert

    Risultato dell'analisi: il cablaggio in ChatPipelineAppService.cs:1415 già chiama

  • Added
    slice50-SSS: spazzata logging osservabilità — Bunny + OpenAI + ChatPipeline

    5 aggiunte di log strutturati affinché i fallimenti in produzione mostrino il contesto completo

  • Added
    slice50-NNN: sessione InAppAssistant — pulizia automatica vuoti + X di eliminazione per riga

    Correzione su due fronti per la bolla che accumulava sessioni vuote/indesiderate:

  • Added
    slice50-YY-2: Bolla InAppAssistant — registrazione microfono Whisper STT nel compositore

    Chiude il -2 rimandato da 50-YY (dove il mic-attach era stato escluso affinché

  • Added
    slice50-JJJJ: cablaggio registratore UserActivity — pipeline ImageEdit + Translator + Video

    Chiude la lacuna cross-pipeline lasciata da 50-AAA.

  • Added
    slice50-IIII: selettore libreria /me/image — streaming blob + ricerca + ordinamento + paginazione

    Utente ha segnalato sia "Pick a source image" che "Pick a mask image"

  • Fixed
    slice50-HHHH: OpenAI DALL-E 3 — rimozione parametro `style` (deprecato, 400)

    Log di produzione:

  • Fixed
    slice50-GGGG: PUT modifica immagine — header Bearer su XHR + chiave locale maschera mancante

    Utente ha segnalato sia il caricamento sorgente che quello maschera su /me/image Modifica

  • Added
    slice50-FFFF: raggruppamento per data in libreria + cablaggio template vista griglia/elenco

    Ultima slice del modulo libreria.

  • Changed
    slice50-EEEE: caricamento multiplo libreria — banner di successo singolo, nessun sfarfallio per file

    Feedback utente: il banner verde "Upload complete." sfarfalleggiava per

  • Fixed
    slice50-DDDD: rimozione modulo AbpStudioClient — causa radice del crash stream upload

    Sprint 50-CCCC ha tentato di correggere l'ObjectDisposedException della pipeline upload

  • Fixed
    slice50-CCCC: stream upload libreria + segnalazione errori per file

    Causa radice del toast persistente "Upload failed" — anche se i file

  • Added
    slice50-BBBB: UX modalità Cestino libreria + altezza max video + backfill md + rendering markdown + conteggio upload

    Utente ha segnalato cinque problemi distinti:

  • Added
    slice50-AAAA: outbox svuotamento CDN + worker tombstone + UI Cestino

    Utente ha segnalato part_001.wav / part_002.wav eliminati dalla libreria ma

  • Added
    slice50-ZZZ: correzione spinner anteprima libreria + UI eliminazione multipla

    50-YYY ha lasciato una regressione: openAssetDetail attivava solo il precaricamento del testo

  • Added
    slice50-YYY: tipo Document in libreria + anteprima testo inline + pulizia modal

    Utente ha segnalato la scheda Documenti vuota dopo aver caricato file .md / .txt —

  • Added
    slice50-XXX: lettura privata libreria tramite proxy stream backend

    Il pattern URL pubblico CDN era errato per /me/library — il contenuto è per utente

  • Fixed
    slice50-WWW: sincronizzazione override dev Bunny + conteggio reale upload libreria

    Due bug in un unico lotto — entrambi emersi da un test utente in cui 4 file risultavano 'caricati' secondo il banner verde ma la pagina libreria rimaneva a 0 elementi.

  • Added
    slice50-VVV: UI avanzamento ricco per caricamento multiplo in libreria

    Utente: 'upload işlemleri için progress bar koy, uploading vs saniye yazsın hangisi upload oldu kullanıcı bilgilensin, böyle çok yavan duruyor.'

  • Fixed
    slice50-UUU: fallback octet-stream per .md + logging verboso upload Bunny

    Due problemi bloccanti per l'utente dai test /me/library:

  • Fixed
    slice50-TTT: accettazione MIME upload libreria — consapevole dello scopo (solo immagini vs mix libreria)

    Utente ha segnalato upload libreria 400 'Only image/* MIME types are accepted on this endpoint.' dopo aver caricato un file non immagine dalla scheda Tutti.

  • Fixed
    slice50-RRR: timeout Redis 5s → 15s — correzione cascata HMGET localizzazione ABP

    Utente ha segnalato Message Citations admin 500 'Internal error'.

  • Fixed
    slice50-PPP: credenziali storage Bunny Media — sincronizzazione con dashboard

    Utente ha segnalato caricamento libreria 'Bunny storage upload failed with HTTP 401'.

  • Fixed
    slice50-OOO: generazione immagini DALL-E 3 400 — rimozione parametro response_format

    Utente ha segnalato /me/image Genera non funzionante: "Image generation provider

  • Fixed
    slice50-MMM: pannello InAppAssistant overflow:visible + fix clip dropdown + pulizia binding posizione

    Utente ha segnalato che il refactoring posizione pannello di Sprint 50-III NON è ancora

  • Fixed
    slice50-JJJ: corpo messaggio di benvenuto InAppAssistant vuoto — regressione sorgente messaggio 50-CCC-2

    Causa radice (variante Scenario B): `openSession()` chiama `messages.set(mapped)`

  • Added
    slice50-LLL: generazione titolo instrada al modello text-chat più economico (Regola 2 capability-first)

    Utente: "Non è necessario usare lo stesso modello per i titoli, questi sono

  • Fixed
    slice50-III: refactoring posizione quadrante consapevole FAB+Pannello InAppAssistant

    Utente ha segnalato che il pannello continuava ad aprirsi staccato dal FAB nonostante Sprint

  • Fixed
    slice50-KKK: generazione titolo chat — ReasoningEffort=low + limite 1024 token (seguito 50-CCC)

    Sprint 50-CCC ha alzato MaxOutputTokens 24 → 128 aspettandosi "~100

  • Added
    slice50-AAA: registratore cross-modulo IUserActivityRecorder — /me/activity-history popolato per i turni chat

    Utente ha segnalato /me/activity-history vuoto nonostante ore di chat/image/voice/ecc.

  • Fixed
    slice50-CCC: regressione titolo chat + visibilità pulsante scorri-all'ultimo

    Due regressioni rilevate nei test utente e corrette; il terzo problema

  • Fixed
    slice50-BBB: audit menu admin InAppAssistant + Agent — seed permessi modulo ruolo admin (1 correzione, 14/14 menu sbloccati)

    | # | Menu | Gruppo | Percorso Angular | Route backend | Stato | Causa radice |

  • Fixed
    slice50-GGG: caricamento multiplo /me/library — selezione di più file

    Utente: "library dosya eklerken neden tek tek el ile eklemem gerekiyor,

  • Fixed
    slice50-FFF: scheda Modifica /me/image — caricamento da PC della Maschera tramite presign Bunny

    Utente: "source da upload from pc var da mask ta neden yok, bizim

  • Fixed
    slice50-EEE: i provider Bunny espongono le interfacce IMediaStorageProvider + IVideoStreamProvider

    Bug critico segnalato dall'utente: ogni tentativo di caricamento da PC generava

  • Fixed
    slice50-DDD: preferenze notifiche 404 — aggiunto suffisso azione /my-preferences mancante

    Utente ha segnalato ripetutamente da ieri che /me/notifications/

  • Fixed
    slice50-ZZ: z-index dropdown sidebar chat — uscita dall'impilamento del separatore giornaliero

    L'elenco chat recenti in /agent/chat-pipeline aveva Rinomina/Elimina per riga

  • Fixed
    slice50-YY: FAB InAppAssistant in alto a sinistra + ripristino campana in alto a destra + prompt consenso downgrade modello

    I test utente hanno evidenziato 5 problemi; 4 affrontati in questo commit, 1

  • Added
    slice50-WW: MarketplaceRoyaltyPayoutCalculator — suddivisione royalty giornaliera per creator (Piano §2.1 #7)

    AsyncPeriodicBackgroundWorker giornaliero (tick 24h) elabora i Paid

  • Added
    slice50-XX: colonne FK tipizzate Bid/Impression/Click/Conversion di AdAuction + indici (Piano §2.2 / 50-VV-2)

    Sprint 47-O ha creato entità AdAuction flat senza FK di join;

  • Added
    slice50-UU: KeywordSettlementJob — liquidazione giornaliera Spot/Reserve/Futures (Piano §2.1 #6)

    ABP AsyncPeriodicBackgroundWorker giornaliero (tick 24h) elabora in sospeso

  • Added
    slice50-VV: scaffold consumer RTB AdAuction + liquidazione al primo prezzo (Piano §2.1 #5)

    Sprint 50-TT era stato assegnato a questo ma è andato fuori copione (ha

  • Added
    slice50-OO: sistema quota /me/library — tracciamento storage + caricamento da PC + consumo wallet

    Utente ha richiesto: indicatore dimensione in cima alla libreria, caricamento da PC, quota per livello piano,

  • Added
    slice50-TT: lock distribuiti per riga nei worker periodici — sicurezza multi-pod

    Estende il pattern 50-RR (VideoJobPollingWorker IAbpDistributedLock)

  • Added
    slice50-NN: caricamento da PC nella scheda Modifica /me/image tramite pre-upload Bunny

    Sprint 50-P ha rimandato il caricamento da PC perché il backend mancava di un Bunny

  • Changed
    slice50-SS: ja.json lotto 1/N — prime 300 chiavi con artefatti cinesi → giapponese nativo

    50-AA interrotto durante la spazzata completa; questo è il lotto ripreso

  • Added
    slice50-RR: lock distribuito Redis VideoJobPollingWorker — sicurezza multi-pod

    Sprint 50-U + 50-EE ha cablato polling + flusso rimborso ma assumeva single-pod

  • Added
    slice50-QQ: spostamento campana notifiche+attività da flottante in alto a destra a fianco della sidebar

    Direttiva utente (turno Sprint 50-E): bell + activity sağdaki menü ikonlarının

  • Changed
    slice50-PP: rigenera proxy saltata — backend non in esecuzione

    Backend non raggiungibile su https://localhost:44304 durante questo sprint;

  • Added
    slice50-MM: denormalizzazione Creator/Post.CreatorProfileId — correzione ambito 50-LL

    Sprint 47-H ha costruito un indice composto degradato per il feed Creator/Post

  • Added
    slice50-LL: denormalizzazione PersonaPost.PersonaId + CreatorProfileId (Piano §2.2 — query feed)

    Sprint 47-H ha costruito una scansione degradata (TenantId, CreationTime) per PersonaPost

  • Added
    slice50-JJ: IBillingRecorder.RecordPaddleTransactionAsync — auto-ripristino riconciliazione

    Sprint 50-W BillingReconciliationJob ha rilevato lacune (Paddle

  • Fixed
    slice50-KK: deriva del builder workspace Angular del modulo (anomalia Sprint 50-M)

    Ogni modules/torun.*/angular/angular.json faceva riferimento a

  • Fixed
    slice50-II: sostituzione letterali "sample-X" di Suite *DataSeedContributor con segnaposto validi

    I test di isolamento tenant di Sprint 50-CC hanno rilevato un difetto preesistente:

  • Changed
    slice50-HH: script eliminazione indici legacy MongoDB (Piano §2.1 #8)

    La spazzata MT di Sprint 47-A..47-P ha aggiunto indici composti con prefisso TenantId a ogni

  • Fixed
    slice50-FF: migrazione gruppi modulo InAppAssistant + Telemetry + EventBus + Persona

    Completamento serie Sprint 49.

  • Changed
    slice50-GG: script DBA backfill tenant per il giorno di lancio (Piano §2.4)

    Rischio R2 pre-lancio: Sprint 47-A..47-P ha ispezionato oltre 219 entità per

  • Added
    slice50-EE: estensione IBillingRecorder.RefundAsync — record negativo gemello

    Sprint 50-U ha scoperto una lacuna: IBillingRecorder aveva solo RecordAsync.

  • Changed
    slice50-CC: test di isolamento tenant per subscription + agent + persona

    Piano §2.3 / audit R1 — Sprint 47-A...47-P ha ispezionato oltre 219 entità per

  • Changed
    slice50-DD: pipeline ImageEdit + prop di approvazione Bolla InAppAssistant

    Backlog Piano §2.5: propagate 22 chiavi pipeline ImageEdit (Sprint

  • Fixed
    slice50-BB: verifica collisioni MessageKey outbox in 7 punti di emissione

    Sprint 50-K ha rilevato una collisione (config Paddle del piano abbonamento

  • Added
    slice50-W: BillingReconciliationJob — audit giornaliero deriva Paddle↔locale

    Fase 1.5 §2.1 #3 — terzo worker in background.

  • Added
    slice50-X: PaddleSyncWorker — ridondanza periodica dello stato abbonamento

    Fase 1.5 §2.1 #4 — quarto e ultimo worker in background pre-lancio.

  • Fixed
    slice50-Z: lacuna TypePredicate in RunInputUploadAppService (seguito 49-B)

    /api/app/run-input-upload restituiva 404 perché l'AppService era

  • Added
    slice50-Y: seed Capability modifica immagini + AiModelCapability gpt-image-1 + link prezzi

    Sprint 50-P ha realizzato UI scheda Modifica /me/image + cablaggio backend ma

  • Fixed
    slice50-S: timestamp UTC emettono Z — serializer backend + convenzione Mongo

    Il frontend (Angular | date pipe + costruttore Date) gestisce UTC -> locale

  • Added
    slice50-U: VideoJobPollingWorker — hardening IHostedService Sora-2

    Fase 1.5 §2.1 — worker in background a massima priorità.

  • Added
    slice50-V: DunningAttemptScheduler — replica retry Paddle past_due

    Fase 1.5 §2.1 #2 — secondo worker in background.

  • Fixed
    slice50-Q: consumer SSE InAppAssistant + UX di annullamento + protezione retry

    Utente segnalato che il turno di follow-up "form doldurma" restituiva "Message failed.

  • Fixed
    slice50-T: incolla dagli appunti in chat + corpo vuoto per memory_forget

    Bug A: il compositore chat ignorava Ctrl+V sulle immagini dagli appunti.

  • Fixed
    slice50-R: layout /marketplace — rimozione lpx-content-container esterno

    La pagina di esplorazione Marketplace (angular/src/app/marketplace/

  • Fixed
    slice50-P: parità scheda Modifica /me/image + righe pulsanti responsive

    Alla scheda Modifica mancava la selezione Modello (Auto/Manuale), Qualità

  • Fixed
    slice50-N: FAB InAppAssistant predefinito → in basso a sinistra + correzione ancoraggio pannello

    Utente segnalato che il default Sprint 50-I (bottom:96 right:24) sovrappone

  • Fixed
    slice50-O: migrazione route /me/notifications + preferenze (omessa in 49-B)

    Test utente su /me/notifications ha restituito 404 su

  • Fixed
    slice50-M: rimozione WalletTopUpPriceIds — prezzo sempre inline non da catalogo

    PaddleOptions.WalletTopUpPriceIds era un Dictionary<string,string>

  • Fixed
    slice50-L: Paddle checkout — log di stato + body su 4xx/5xx

    Utente segnalato "paddle.js popup açması lazım, hata veriyor" quando

  • Fixed
    slice50-I: trascinamento FAB InAppAssistant (ripristino drag pannello) + allineamento dropdown notifiche

    Sprint 50-I risolve due regressioni UX emerse dopo Sprint 50-B + 50-E:

  • Fixed
    slice50-K: collisione MessageKey outbox al secondo salvataggio del piano Paddle

    L'amministratore ha salvato la config Paddle di un SubscriptionPlan; il primo salvataggio ha funzionato.

  • Fixed
    slice50-J: dettaglio fatturazione — $ solo sui campi monetari

    La tabella di dettaglio costi in /me/billing aggiungeva ingenuamente il prefisso a ogni

  • Fixed
    slice50-H: migrazione route chat-pipeline + Chat nel menu /me

    Sprint 49-B ha lasciato due URL /api/app/* hardcoded in chat-pipeline

  • Changed
    slice50-Fi: propagazione consolidata — drag/dock 50-B + modali workflow 50-D + centro notifiche-attività 50-E in 29 file locale

    - 50-B (InAppAssistant:Bubble:Dock/Undock/DragHint): aggiunto a en.json + tutti gli altri 28 locale con traduzioni native

  • Fixed
    slice50-D: sostituzione globale confirm/alert/prompt js nativi → ABP ConfirmationService + modali LeptonX

    Utente: 'memory sayfasında sil tıkladığımda js confirm çıkıyor biz neden leptonx e

  • Fixed
    slice50-B: ordinamento tool_calls InAppAssistant + bolla trascinabile/ancorable (CRITICO)

    Correzione A (bug server CRITICO):

  • Fixed
    slice50-C: rendering dropdown /me/billing + contenuto scheda vuoto (UX CRITICO)

    Utente segnalato: il dropdown SourceKind mostrava blocchi rosa/blu anomali (rotto

  • Fixed
    slice50-A: le campane notifiche + activity-center non sovrappongono più l'etichetta admin

    Feedback utente: le due campane flottanti (notification-bell + activity-center)

  • Fixed
    slice47-J: subscription parte 2 FINALE — Subscription/Invoice/BYOK/QueuedRequest IMultiTenant (Fase 2 CRITICO)

    Applicazione pattern Sprint 47-I + 45-M.

  • Added
    slice48-B: costo embedding collegato allo snapshot AiModelPricing (seguito Sprint 46-A)

    Sprint 46-A ha introdotto IBillingRecorder cross-modulo + emissione BillingRecords

  • Fixed
    slice48-A: traduzioni native per il modulo translation — lingue ja/ko/pt/sv (~272 voci)

    La normalizzazione strutturale di Sprint 46-F (lowercase→PascalCase) ha lasciato 4 locale con contenuto inglese stub di Suite.

  • Fixed
    slice47-I: correzione audit MT subscription parte 1 — Wallet/BillingRecord/Refund/Dispute IMultiTenant (Fase 2 CRITICO MONEY)

    Applicazione pattern Sprint 45-M + da 47-A a 47-N.

  • Fixed
    slice47-N: correzione audit MT agent parte 2 — Council/DeepResearch/CodeSandbox/Voice/Translator IMultiTenant (Fase 2)

    Applicazione pattern Sprint 47-M.

  • Fixed
    slice47-L: correzione audit MT authoring parte 2 — GenJobs/BlogPost/quote IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M + 47-K.

  • Fixed
    slice47-M: correzione audit MT agent parte 1 — Chat/ChatMessage/Assistant IMultiTenant (Fase 2 RISCHIO ALTO)

    Applicazione pattern Sprint 45-M + da 47-A a 47-K.

  • Fixed
    slice47-K: correzione audit MT authoring parte 1 — ecosistema Workflow IMultiTenant (Fase 2 RISCHIO ALTO)

    Applicazione pattern Sprint 45-M + da 47-A a 47-H.

  • Fixed
    slice47-P: correzione audit MT marketplace — 15 entità IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M + 47-A/B/C/D/E/F/G/O.

  • Fixed
    slice47-H: correzione audit MT creator parte 2 — entità Posts/Teams/Payouts IMultiTenant (Fase 2 RISCHIO ALTO)

    Applicazione pattern Sprint 45-M + 47-G.

  • Fixed
    slice47-O: correzione audit MT advertising — 16 entità IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M + 47-A/B/C/D/E/F.

  • Fixed
    slice47-G: correzione audit MT creator parte 1 — entità Profile/Account/Org IMultiTenant (Fase 2 RISCHIO ALTO)

    Applicazione pattern Sprint 45-M + 47-A/B/C/D/E.

  • Fixed
    slice47-F: correzione audit MT forum — 19 entità IMultiTenant + notifiche fan-out tenant-aware (Fase 2)

    Applicazione pattern Sprint 45-M + 47-A/B/C/E.

  • Fixed
    slice47-D: correzione audit MT telemetry — 18 entità IMultiTenant + writer cross-modulo in ambito tenant (Fase 2 RISCHIO ALTO)

    Applicazione pattern Sprint 45-M + 47-A + 47-B.

  • Fixed
    slice47-E: correzione audit MT persona — 16 entità IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M + 47-A/B/C.

  • Fixed
    slice47-C: correzione audit MT moderation — 11 entità IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M + 47-A/B.

  • Fixed
    slice47-B: correzione audit MT byokvault + knowledge — 7 entità IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M + 47-A.

  • Fixed
    slice47-A: correzione audit MT eventbus + translation — 8 entità IMultiTenant (Fase 2)

    Applicazione pattern Sprint 45-M: Suite NON generava IMultiTenant sulle classi Base nonostante IsMultiTenant: true nel JSON.

  • Added
    slice56-57-58: capability-first routing + Authoring stub fix

    Slice 56 — IModelRoutingService (ByokVault.Application + Contracts):