Changelog

What is new on the ToRun platform, newest first.

v@release.Version

minor
14 jun. 2026

June 2026 — 53 changes

  • Added
    Mais modelos de imagem e vídeo à sua escolha

    O seletor de modelos passa a incluir o Google Imagen e o Gemini para imagens, e o OpenAI Sora e o Google Veo para vídeo, a par dos modelos que já tinha. Escolha exatamente o que pretende ou deixe o Auto encontrar a melho…

  • Added
    Workflows de IA sem código e o Marketplace de criadores já estão disponíveis

    Combine vários passos de IA num workflow que pode executar quando quiser e publique-o no Marketplace ou explore o que outros criadores já partilharam. O Workflow Editor, o Runner e o Marketplace estão agora ao seu alcanc…

  • Added
    Instale o ToRun no seu telemóvel

    Adicione o ToRun ao ecrã principal e abra-o como uma aplicação nativa, em ecrã inteiro e com o seu próprio ícone, ficando a um toque de distância até chegar a aplicação móvel.

  • Added
    Um visual renovado do ToRun.ai

    Um novo logótipo e uma imagem mais clara em toda a aplicação, otimizada tanto para o tema claro como para o escuro.

  • Added
    Respostas mais inteligentes e personalizadas

    Escolha o quanto a IA reflete antes de responder, agora também no modo Auto. Os prompts de imagem podem recorrer discretamente à sua memória guardada para que os resultados correspondam às pessoas e aos detalhes que lhe…

  • Fixed
    Um estúdio de imagem, vídeo e música mais organizado

    O progresso da geração aparece agora mesmo ao lado do resultado, em vez de por baixo do formulário, cada página abre limpa e a sua criação mais recente fica em destaque, enquanto as anteriores ficam guardadas na sua Libr…

  • Fixed
    Uma carteira mais clara e uma Library mais fluida

    O histórico da sua carteira passa a estar paginado e mostra montantes exatos abaixo do cêntimo, e remover itens da sua Library já não causa erros.

  • Added
    Torne-se anunciante, em autosserviço

    Crie a sua conta de anunciante e submeta campanhas para revisão diretamente a partir da sua conta, sem esperar por configurações manuais.

  • Fixed
    Mais fiabilidade, rigor na faturação e reforço de segurança

    Nos bastidores: uma contabilização mais justa dos créditos gratuitos, verificações mais robustas nos pagamentos e nas permissões dos criadores, moderação de conteúdos mais segura e execuções de workflows mais fiáveis.

  • Added
    Um segundo motor de tradução em direto, com 77 idiomas

    A Tradução em Direto permite-lhe agora escolher entre dois motores e optar pelo que melhor se adapta à sua conversa — incluindo uma nova opção que fala 77 idiomas, entre eles o turco e o russo. Cada escolha mostra o preç…

  • Added
    Um seletor de modelos mais claro — e mais modelos no Plano Gratuito

    Os modelos que o seu plano não cobre passam a surgir com um pequeno cadeado e uma forma de, com um toque, fazer upgrade do plano ou carregar a sua carteira, em vez de falharem só depois de enviar. Disponibilizámos também…

  • Added
    O seu assistente lembra-se das imagens que partilha

    Partilhe uma imagem uma vez e o assistente guarda o que viu durante o resto da conversa — assim pode perguntar sobre ela muitas mensagens depois, mesmo após mudar de modelo, sem nunca voltar a carregar a imagem nem cobra…

  • Added
    Diagramas, tabelas e formatação mais cuidada no chat

    As respostas do chat desenham agora os diagramas como verdadeiros diagramas, apresentam as tabelas com limites bem definidos e ajustam o tamanho dos títulos à mensagem, em vez de encherem o ecrã — para que as respostas s…

  • Fixed
    Sempre claro quando algo não está coberto — nunca um beco sem saída

    Quando um modelo precisa de um upgrade ou o seu saldo fica baixo, recebe agora um aviso amigável com os botões Fazer upgrade do plano e Carregar carteira mesmo ali. As respostas que não podem ser geradas explicam porquê,…

  • Fixed
    As horas são agora mostradas no seu fuso horário

    Os registos de faturação, o histórico e a atividade são agora apresentados na sua hora local em vez de UTC, para que as datas e horas correspondam ao relógio à sua frente.

  • Fixed
    Uma lista de chats mais arrumada

    Iniciar um novo chat passa a reaproveitar um que esteja vazio, em vez de acumular chats em branco; os chats que nunca tiveram resposta deixam de sobrecarregar a sua lista; e os títulos provisórios são substituídos por um…

  • Added
    Anuncie na ToRun

    As empresas podem agora criar uma conta de anunciante e gerir as suas próprias campanhas de publicidade de ponta a ponta — criar campanhas, adicionar os criativos publicitários que as acompanham e submetê-las para uma re…

  • Added
    Use a sua própria chave API para voz e tradução em direto

    Usar a chave do seu próprio fornecedor passa a abranger também a voz em tempo real, a tradução em direto e a transcrição em direto: a utilização de IA passa pela sua própria chave e nós cobramos apenas a pequena taxa de…

  • Fixed
    Site público renovado, carregamentos mais seguros e um registo mais fluido

    As nossas páginas públicas passam a ser geridas por conteúdo editável em vários idiomas, as imagens carregadas são analisadas em busca de conteúdo inseguro antes de serem armazenadas, o registo de conta e os e-mails de c…

  • Added
    As conversas continuam a gerar, mesmo quando sais para outro lado

    As respostas longas passam agora a correr no servidor e prosseguem enquanto mudas de conversa, abres outra página ou fechas o separador. Volta quando quiseres: a resposta ainda está a ser gerada ou já está à tua espera.

  • Added
    Os projetos dão agora a cada conversa o contexto certo

    As conversas iniciadas dentro de um projeto assumem automaticamente as suas instruções, o conhecimento carregado e a memória, mostram um distintivo do projeto com uma ligação rápida de regresso e indicam o nome do projet…

  • Added
    Uma memória que compreende o tempo — e que podes editar

    A memória do teu assistente passa agora a acompanhar a rapidez com que cada facto muda e assinala os que podem estar desatualizados, para se apoiar no que ainda é verdadeiro. Um novo editor permite-te rever, adicionar e…

  • Added
    Os modelos mais recentes, além de páginas dedicadas de Traduzir e Transcrever

    Adicionámos os mais recentes modelos de imagem, vídeo, transcrição e voz em tempo real e abrimos páginas autónomas de Traduzir e Transcrever, para que chegues a essas ferramentas diretamente a partir do menu.

  • Added
    Tradutor de voz em direto

    Fala e deixa que as tuas palavras sejam traduzidas quase de imediato: escolhe dois idiomas, troca-os com um único toque, e o tradutor capta a tua voz e transmite a tradução à medida que falas.

  • Added
    Um estúdio de vídeo mais claro e mais honesto

    A página de vídeo mantém agora as miniaturas sincronizadas quando apagas algo da tua biblioteca, permite-te definir a duração do clipe por modelo, remover clipes individuais e marca claramente os resultados de pré-visual…

  • Fixed
    Um assistente integrado mais polido

    O assistente integrado mostra agora respostas bem formatadas, mantém a última mensagem à vista enquanto escreve, guarda de forma fiável a resposta concluída e atribui a cada conversa um título automático.

  • Fixed
    As respostas das conversas são apresentadas de forma fiável: ligações, fórmulas e moeda

    As respostas que contêm ligações, fórmulas matemáticas ou valores monetários deixam de aparecer em branco ou apresentadas a meio, mesmo depois de atualizar a página, e as respostas de investigação aprofundada incluem sem…

  • Fixed
    Fiabilidade, exatidão da faturação e reforço da segurança

    Uma vasta ronda de trabalho nos bastidores: medição de utilização e totais de despesa mais exatos, reembolsos automáticos mais justos, mensagens em tempo real mais robustas, salvaguardas reforçadas de privacidade e segur…

  • Fixed
    Leia o blogue e os conteúdos da comunidade sem iniciar sessão

    As publicações públicas do blogue e os debates do fórum — incluindo as reações e respostas — passam a estar visíveis para os visitantes sem sessão iniciada.

  • Fixed
    Preços mais claros e uma gama de modelos mais arrumada

    A utilização passa a ser cobrada com uma única margem justa, os indicadores de gasto mensal e de orçamento restante apresentam valores rigorosos e a lista de modelos foi depurada — os modelos obsoletos foram retirados e…

  • Added
    Os anúncios e pacotes do marketplace passam a mostrar imagens de capa

    Os anúncios de fluxos de trabalho e os pacotes podem apresentar uma verdadeira imagem de capa, tornando o marketplace mais fácil e agradável de explorar.

  • Added
    O seu assistente integrado já pode agir por si

    Peça ao assistente e ele preenche formulários, carrega em botões e desloca-se pela aplicação por si — apoiado por um conjunto de ferramentas mais alargado que agora chega ao contacto, às perguntas frequentes, ao fórum, à…

  • Added
    O assistente escreve a resposta em direto, numa bolha que pode mover

    As respostas surgem agora palavra a palavra em vez de aparecerem todas de uma vez, e a bolha do assistente pode ser arrastada para onde lhe for mais cómodo, com uma indicação em direto daquilo em que está a trabalhar.

  • Fixed
    Crie e organize Projetos sem percalços

    Criar um projeto e iniciar uma nova conversa no seu interior funciona agora sem problemas, para que possa manter juntos as conversas, os ficheiros e o contexto relacionados.

  • Fixed
    Vídeo, avatares e voz mais fluidos

    Os vídeos são reproduzidos de forma fiável, o conteúdo multimédia privado é carregado através de um proxy seguro, os avatares de criadores e personas passam a ser visíveis para todos e as notas de voz são transcritas sem…

  • Fixed
    Avisos do estado do serviço mais claros

    Quando uma parte do serviço está com problemas, o aviso é agora mais fácil de compreender e deixa de revelar os nomes internos dos fornecedores.

  • Added
    Ligue as suas aplicações favoritas ao assistente

    Associe aplicações externas com um único início de sessão ou uma chave de API, para que o assistente possa trabalhar diretamente com as ferramentas que já utiliza.

  • Fixed
    Geração e edição de imagens mais fiáveis

    As ferramentas de imagem escolhem agora um modelo adequado àquilo que está a fazer, mostram uma pré-visualização instantânea do resultado e a edição volta a funcionar após uma mudança de modelo do fornecedor.

  • Fixed
    Um ficheiro eliminado já não estraga as suas conversas nem a galeria

    Quando uma imagem ou um anexo foi removido, o seu histórico de conversas, a galeria multimédia e o editor de imagens passam a mostrar um marcador de posição claro, em vez de pararem com um erro.

  • Added
    Traduza para cerca de 100 idiomas

    O tradutor oferece agora um seletor com pesquisa entre cerca de 100 idiomas, cada um apresentado pelo seu nome nativo e em inglês.

  • Added
    Novas publicações de blogue e debates na comunidade

    Adicionámos um conjunto de novos artigos de blogue e tópicos de fórum — incluindo perguntas respondidas — para que haja mais para ler e explorar desde o primeiro dia.

  • Added
    Novas ferramentas no chat: ficheiros, código, imagens, voz e muito mais

    O chat consegue agora pesquisar nos seus ficheiros carregados, executar Python numa sandbox, editar imagens, transcrever e reproduzir áudio, e acionar os seus fluxos de trabalho — tudo sem sair da conversa.

  • Added
    Pesquisa web e investigação aprofundada, com citações

    Deixe o chat pesquisar na web em tempo real, realizar investigação aprofundada com múltiplas fontes e obter e ler páginas completas — cada resposta regressa com as fontes que utilizou.

  • Added
    Chat com memória — e esquecimento a pedido

    O seu assistente mantém agora uma memória ligeira entre chats, pode listar o que se recorda e honra um pedido de esquecimento em qualquer idioma.

  • Added
    Crie imagens, vídeo e música num único estúdio

    Gere e edite imagens, produza curtas-metragens e componha músicas com letra — novos motores de imagem, vídeo e música, com um seletor de média partilhado e a sua biblioteca a um clique de distância.

  • Added
    Modo de voz em tempo real

    Fale com o ToRun em voz alta — uma nova capacidade de voz em tempo real traz conversas faladas e transcrição ao vivo para o chat.

  • Added
    Fluxos de trabalho: execuções de qualidade máxima, aprovações e retoma

    As execuções de fluxos de trabalho preferem agora modelos de qualidade superior, fazem pausa para a sua aprovação quando necessário, e podem ser canceladas, regeneradas e retomadas — com cada resultado guardado diretamen…

  • Added
    Projetos: organize o seu trabalho

    Agrupe chats, ficheiros e contexto relacionados em Projetos para que o seu assistente tenha sempre o enquadramento certo para a tarefa em mãos.

  • Added
    Canvas: um espaço de trabalho lado a lado

    Rascunhe e aperfeiçoe conteúdo extenso e código num painel de canvas dedicado, lado a lado com o seu chat.

  • Added
    Conversas mais inteligentes e mais longas

    Resumos deslizantes, janelas de contexto mais inteligentes e rolagem mais rápida do histórico mantêm as conversas longas coerentes e ágeis, com controlos claros quando uma conversa ultrapassa a janela do modelo.

  • Added
    Faturação honesta e transparente

    Um subsídio gratuito humanizado que se recarrega numa janela deslizante, indicadores de despesas mais claros, reembolsos automáticos quando a geração de uma imagem ou vídeo falha, e controlos de esforço de raciocínio que…

  • Added
    Um catálogo de modelos maior e mais atualizado

    Dezenas de modelos de 2026 adicionados e obsoletos retirados, mais uma sincronização automática diária que mantém os modelos e preços dos fornecedores atualizados — gerido a partir de um novo catálogo de administração.

  • Added
    Partilhe os seus melhores chats

    Publique uma conversa com uma ligação pública e faça crescer a comunidade em torno do que cria.

v@release.Version

minor
31 mai. 2026

May 2026 — 499 changes

  • Changed
    52-Q-SMOKE-HARNESS: conjunto de smoke tests de ponta a ponta repetível + primeiro relatório de regressão

    Conjunto de testes de consola .NET autónomo (test/ToRun.SmokeTests) que autentica contra o Host em execução (concessão de senha OpenIddict) e exercita todas as capacidades principais de ponta a ponta via a API HTTP real:…

  • Fixed
    52-Q-AI-MEDIA-ACCESS: leitura autenticada do Bunny para todas as obtenções de média no pipeline

    Os média da plataforma residem numa Zona de Armazenamento PRIVADA do Bunny, pelo que um simples

  • Added
    52-Q-MEMORY-CHAT: ferramenta memory_list + esquecimento funcional independente de idioma

    Conclui a funcionalidade de gestão de memória orientada por chat, construída sobre

  • Fixed
    52-Q-MEMORY-FORGET-I18N: correspondência por dobramento independente de idioma + fallback semântico

    memory_forget devolvia no_match para memórias que existiam.

  • Fixed
    52-Q-GEMINI-FLASH-400: aumentar o mínimo de flash thinkingBudget de 128->512 + registar corpo do erro HTTP 400 do Google

    gemini-2.5-flash começou a devolver HTTP 400 com thinkingBudget=128 (o limite mínimo 52-N

  • Fixed
    52-Q-MODEL-MENU: aninhar model-catalog + onboarding no grupo de navegação ByokVault

    As duas páginas de administrador do anfitrião (/admin/model-catalog, /admin/model-onboarding)

  • Fixed
    52-Q-MODEL-SYNC-DEDUP: ignorar variantes de modelos com snapshot desatualizado na descoberta

    A descoberta correspondia apenas pelo ProviderModelId/ModelKey exato, pelo que versões desatualizadas do fornecedor

  • Changed
    52-Q-CHAT-EFFORT-UX-LOCALE: propagar texto de esforço bloqueado + WalletCta para 28 idiomas

    O bloqueio do esforço de raciocínio passa a basear-se em financiamento, e não em nível de subscrição.

  • Added
    52-Q-MODEL-SYNC-AI: fallback de análise de página de preços por AI para a sincronização de modelos

    Fusão do melhor de ambos no sincronismo 52-Q-MODEL-SYNC-JOB já concluído: quando o OpenRouter

  • Fixed
    52-Q-CHAT-EFFORT-UX: bloqueio de esforço sensível a carteira/financiamento

    O selector de esforço de raciocínio estava rigidamente bloqueado no nível de subscrição, com uma isenção de admin/anfitrião de uma abordagem anterior rejeitada.

  • Changed
    52-Q-MODEL-SYNC-JOB: pesquisa de sincronização de fornecedores + mapa de arquitetura

    Entregável da Fase 1: inventário de lista/fonte de preços de 26-provider, o

  • Added
    52-Q-MODEL-ONBOARDING: gestão do catálogo de modelos pelo admin anfitrião (listar/editar/eliminar)

    O assistente de integração (fases A-D) apenas CRIA entradas no catálogo; não existia

  • Added
    52-P-SHARE: superfície de partilha pública + crescimento da comunidade

    Backend (torun.agent): SharedChat recebe IsListed/ListedSlug/ListedAt + campos de cartão desnormalizados; PublicCommunityAppService + PublicCommunityController (feed /community anónimo + visualizador por slug); Community…

  • Fixed
    52-Q-CHAT-AUDIO-BRIDGE: transcrever áudio carregado + reparar leitor de áudio

    Os anexos de áudio no chat estavam avariados; as causas raiz reais diferiam do

  • Fixed
    52-Q-CHAT-CONTEXT-SLASH: persistir modo de gestão de overflow de contexto + predefinições slash de UX honesta

    PARTE 1 — o menu suspenso de gestão de overflow de contexto no cabeçalho do chat ficava bloqueado em

  • Fixed
    52-Q-BUDGET-BUILD: remover referência órfã a IsCurrentMonth que dependia do BudgetBucketCacheItem.DailyKey removido

    A remoção do limite diário (84178afab) eliminou DailyKey/MonthlyKey do BudgetBucketCacheItem

  • Changed
    52-Q-SMOKE-INTEG: corrigir falhas no Mongo (AiModels dup _id + duração de transação UoW) + teste de integração de isolamento de transporte ResolveAsync

    Parte 1 — restaurar o nível verde dos testes de integração com MongoDB.

  • Changed
    52-Q-CHAT-EFFORT-LOCALE: propagar 7 chaves ChatComposer:Effort para 28 idiomas

    As cadeias do selector de esforço de raciocínio (Effort:Tooltip, Effort:Locked:Tooltip,

  • Added
    52-Q-CHAT-EFFORT: selector de esforço de raciocínio por modelo ligado de ponta a ponta

    Controlo canónico e agnóstico em relação ao fornecedor para o esforço de raciocínio no compositor de chat,

  • Changed
    52-Q-BUDGET-DAILYCAP-REMOVE: remover limite diário inativo + minutos ativos

    Passagem final de remoção de código morto para a reescrita do orçamento por janela de sessão.

  • Changed
    52-Q-MONTHLY-SPEND-FIX: corrigir comentários da fonte de despesas + documentação XML para telemetria UserDailySummary

    O indicador de Despesas Mensais/Diárias lê a telemetria UserDailySummary (ScopeKey=userId,

  • Changed
    52-Q-BUDGET-DEADCFG: remover parâmetros de configuração de Allowance obsoletos

    Seguimento da auditoria à reescrita do orçamento por janela de sessão (2a33fd31f).

  • Fixed
    52-Q-BUDGET-BUCKET-GAUGE-ZERO: pré-visualizar capacidade de sessão configurada em caso de falha de cache do bucket

    O indicador de budget-bucket na página inicial (/) + me-home apresentava "$0.00 / 0% / $0.00" sempre que

  • Added
    52-Q-BUDGET-HUMANE: subsídio gratuito em janela de sessão deslizante (capacidade $0.20 / 5h)

    O bucket de orçamento do nível gratuito funcionava como um débito "$2 / 30d / 24h": recarga = $2/720/h e

  • Fixed
    52-Q-BUDGET-BUCKET-GAUGE-UX: indicador de saldo legível — precisão de 4 decimais + sugestão do período de rajada gratuita

    O indicador BUDGET BUCKET na página inicial (/) e em me-home (/me) mostrava "$0.00 (2% / $0.01)":

  • Fixed
    52-Q-CHAT-HISTORY-VISION-LEAK: remover partes de imagem do histórico em modelos só de texto

    Erro de visão em múltiplas rondas.

  • Changed
    52-Q-SMOKE: bloquear classificação de encaminhamento de voz em tempo real + raciocínio (guardas sem DB)

    Primeiro bloqueio de regressão na camada de smoke.

  • Added
    52-Q-INVOCATION-PROTOCOL: isolar o transporte dos modelos do encaminhamento de completação

    Correção da causa raiz dos 404s recorrentes na geração de títulos / chat público / visão: capacidade

  • Fixed
    52-Q-VISION-BRIDGE: excluir SKUs de tempo real do encaminhamento de visão baseado em completação — VERIFICADO

    O utilizador confirmou que a descrição de imagens funciona agora.

  • Fixed
    52-Q-CHAT-IMG-PROXY: verificar pertença de anexo via cadeia ChatMessageId

    O âmbito de proprietário resultava em 403 mesmo para o legítimo proprietário do chat: criado pelo gestor

  • Fixed
    slice52-Q-CHAT-IMG-PROXY: imagens do histórico do chat renderizadas via proxy de stream no backend (correção do Bunny 503)

    Causa raiz REAL do A3 (detetada por teste ao vivo no browser): imagem de anexo de chat

  • Changed
    slice52-Q-AUDIT: registo de auditoria de erros críticos no pipeline — ciclo DI C1 corrigido, Quartz prescrito para M1, TODO por pipeline

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

  • Fixed
    slice52-Q-QUEUE-DI-CYCLE: quebrar ciclo DI do dispatcher em fila via dependência lazy da ferramenta de execução de fluxo de trabalho

    A resolução de IQueuedRequestDispatcher causava StackOverflow no arranque (não capturável — um

  • Fixed
    slice52-Q-LOG-ROLLING: rodar + limitar o sink de ficheiros Serilog (estava a falhar silenciosamente com 1 GB)

    Tanto o sink de runtime do Host (appsettings.json) como os loggers de arranque

  • Fixed
    slice52-Q-CHANGELOG-IDEMPOTENT: indexar seed do changelog por Slug, não por ExternalId (correção permanente do E11000)

    Causa raiz recorrente: ChangelogBackfillDataSeedContributor verificava idempotência em

  • Changed
    slice52-Q-CHANGELOG: backfill do changelog de sprint + chaves para 29 idiomas (93 novos sprints)

    Executado extract-sprint-changelog.py + propagate-changelog-locales.py a partir do main:

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

    QueuedRequestRunner.DoWorkAsync resolved IQueuedRequestDispatcher at the TOP of

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

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

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

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

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

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

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

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

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

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

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

    Honest-UX DNA pattern #3.

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

    Completes the wallet-funded context-overrun feature.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

  • Added
    52-Q-voice-realtime-catalog: EnBillingSource.RealtimeVoice + seed de capacidade voice-realtime + junção

    EnBillingSource.RealtimeVoice + seed de capacidade voice-realtime + junção

  • 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: distribuir 25 chaves de modo de voz para 28 idiomas-irmãos

    Espelho das chaves de UI do modo de voz em tempo real adicionadas ao en.json em

  • 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: acrescentar entrada da varredura overnight 52-O ao PROGRESS.md

    Por CLAUDE.md Rule 10.

  • Changed
    52-O-NIGHT/locale-validation-report: relatório de paridade por recurso × por idioma após o fan-out de 6 agentes tradutores

    Resultado de `python platform-plan/scripts/_validate-29-locales.py` após todos os 27 lotes de tradução de idiomas-irmãos concluídos + a passagem de remoção de BOM:

  • Changed
    52-O-NIGHT/translator-batches: 25 lotes de tradução nativa concluídos — total ~7,800+ chaves em 52 ficheiros

    Lotes de 6 agentes tradutores Sonnet paralelos (todos confirmados no repositório em iterações anteriores + grupo final agora enviado):

  • 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: revisão de código do pipeline de chat + InAppAssistant — 4 Alta + 8 Média + 5 Baixa

    Auditoria de leitura do ChatPipelineAppService + InAppAssistant + clientes de fornecedor + 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 — atributo de rota explícito [HttpPut]

    O smoke-backend.py sinalizou um VERB_MISMATCH: o Angular chama PUT simples.

  • Added
    slice50-F/task#30: PublicChatAppService — turno demo anónimo, limite de taxa por IP, faturação MarketingDemo

    Metade do backend do Sprint 50-F: chat demo da página de destino anónima com limite de taxa por IP.

  • Changed
    slice50-RRR-fu: BillingDailySummaryConsumer — inferência de tipo na desestruturação de tuplo

    O dicionário `Dictionary<(DateTime Date, Guid?`.

  • Fixed
    slice50-UU-fu/task#73: KeywordSettlement — índice esparso único em ExternalId + tratamento de perda de corrida

    Fecha a única janela de corrida no KeywordSettlementJob que poderia.

  • Changed
    slice50-SS-task67: ja.json lote 1/4 — primeiros ~140 chaves com artefactos chineses → Japonês nativo

    Continuação da task #67 (varrimento 50-SS).

  • Added
    slice50-RRR-2: ImageEdit composto — UI de chips multi-origem + ramo de fornecedor

    Fecha a fundação 50-RRR (commits A/B/C) ao ligar o caminho composto real.

  • Changed
    slice50-NNN-fu: backfill de local Sessions:* InAppAssistant (10 chaves × 28 locais)

    Preenchimento de Toggle / Heading / New / Untitled / Empty / Load:Failed / JustNow / MinAgo / HourAgo / DayAgo em todos os 28 locais não-English (en.json já tinha o conjunto completo desde Sprint 50-CCC-2).

  • Added
    slice50-RRR-fu/task#74: MarketplacePurchase — colunas FK BundleId/CreatorProfileId/BuyerUserId + índices

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

  • Added
    slice50-RRR/C: ImageEditPipeline — encaminhamento por topologia de chave de capability

    O pipeline deriva agora a chave de capability a partir da topologia de entrada e usa.

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

    Contrato do adaptador para o caminho composto de múltiplas entradas.

  • Added
    slice50-RRR/A: modelo de forma de capability — chaves + InputBoundsJson + delta de seed

    Commit de fundação para a refactorização de edição multi-imagem (Opção C — capability).

  • Added
    slice50-QQQ: persistência ChatAttachment — observabilidade para o mistério do zero-insert

    Conclusão da investigação: a ligação em ChatPipelineAppService.cs:1415 já chama.

  • Added
    slice50-SSS: varrimento de registo de observabilidade — Bunny + OpenAI + ChatPipeline

    5 adições de registo estruturado para que falhas em produção mostrem o contexto completo.

  • Added
    slice50-NNN: sessão InAppAssistant — limpeza automática de sessões vazias + botão X de eliminação por linha

    Correcção em duas frentes para o balão a acumular sessões vazias / indesejadas:

  • Added
    slice50-YY-2: Bubble InAppAssistant — gravação STT por microfone Whisper no compositor

    Fecha o -2 adiado do 50-YY (onde o anexo de microfone foi separado para que o.

  • Added
    slice50-JJJJ: ligação do gravador UserActivity — pipelines ImageEdit + Translator + Video

    Fecha a lacuna entre pipelines deixada pelo 50-AAA.

  • Added
    slice50-IIII: seletor de biblioteca /me/image — streaming de blob + pesquisa + ordenação + paginação

    O utilizador reportou que tanto 'Escolher imagem de origem' como 'Escolher imagem de máscara'.

  • Fixed
    slice50-HHHH: OpenAI DALL-E 3 — remover parâmetro `style` (obsoleto, erro 400)

    Registo de produção:

  • Fixed
    slice50-GGGG: imagem edit PUT — cabeçalho Bearer no XHR + chave de local de máscara em falta

    O utilizador reportou que tanto o upload de origem como o upload de máscara em /me/image Edit.

  • Added
    slice50-FFFF: agrupamento por data na biblioteca + ligação de modelos de vista em grelha/lista

    Última parcela do módulo biblioteca.

  • Changed
    slice50-EEEE: upload em massa da biblioteca — banner único de sucesso, sem intermitência por ficheiro

    Feedback do utilizador: o banner verde 'Upload concluído.' aparecia e desaparecia para.

  • Fixed
    slice50-DDDD: remover módulo AbpStudioClient — causa raiz do crash no stream de upload

    O Sprint 50-CCCC tentou corrigir a ObjectDisposedException no pipeline de upload.

  • Fixed
    slice50-CCCC: stream de upload da biblioteca + relatório de erro por ficheiro

    Causa raiz do persistente toast 'Falha no upload' — mesmo que os ficheiros.

  • Added
    slice50-BBBB: UX do modo Reciclagem da biblioteca + altura máxima de vídeo + backfill de .md + renderização markdown + contagem de uploads

    O utilizador reportou cinco problemas distintos:

  • Added
    slice50-AAAA: outbox de purga CDN + worker tombstone + UI da Reciclagem

    O utilizador reportou que part_001.wav / part_002.wav eliminados da biblioteca continuavam a aparecer.

  • Added
    slice50-ZZZ: correcção do spinner de pré-visualização da biblioteca + UI de eliminação em massa

    O 50-YYY deixou uma regressão: openAssetDetail apenas iniciava o pré-carregamento de texto.

  • Added
    slice50-YYY: tipo Documento da biblioteca + pré-visualização de texto inline + limpeza do modal

    O utilizador reportou o separador Documentos vazio após fazer upload de ficheiros .md / .txt —

  • Added
    slice50-XXX: leitura privada da biblioteca via proxy de streaming no backend

    O padrão de URL público do CDN estava errado para /me/library — o conteúdo é por utilizador.

  • Fixed
    slice50-WWW: sincronização da substituição dev Bunny + verdade na contagem de uploads da biblioteca

    Dois bugs num único lote — ambos revelados num teste de utilizador onde 4 ficheiros eram 'carregados' segundo o banner verde, mas a página da biblioteca ficava com 0 itens.

  • Added
    slice50-VVV: UI de progresso detalhado no upload em massa da biblioteca

    Feedback do utilizador: 'adiciona uma barra de progresso para os uploads, mostra o tempo restante, qual foi carregado, informa o utilizador, está muito simples assim.'

  • Fixed
    slice50-UUU: fallback octet-stream para .md + registo detalhado no upload Bunny

    Dois problemas a bloquear o utilizador em /me/library:

  • Fixed
    slice50-TTT: aceite de MIME no upload da biblioteca — por finalidade (apenas imagem vs mistura geral)

    O utilizador reportou erro 400 'Apenas tipos MIME image/* são aceites neste endpoint.' ao fazer upload de um ficheiro não-imagem no separador Todos.

  • Fixed
    slice50-RRR: timeout Redis 5s → 15s — correcção da cascata HMGET de localização ABP

    O utilizador reportou 500 'Erro interno' no administrador de Message Citations.

  • Fixed
    slice50-PPP: credenciais de armazenamento Bunny Media — sincronizar com o dashboard

    O utilizador reportou 'falha no upload Bunny com HTTP 401' na biblioteca.

  • Fixed
    slice50-OOO: geração de imagem DALL-E 3 com erro 400 — remover parâmetro response_format (obsoleto)

    O utilizador reportou /me/image Generate com falha: 'O fornecedor de geração de imagem.'.

  • Fixed
    slice50-MMM: overflow:visible do painel InAppAssistant + correcção de recorte do dropdown + higiene do binding de posição

    O utilizador reportou que a refactorização de posição do painel Sprint 50-III AINDA não.

  • Fixed
    slice50-JJJ: mensagem de boas-vindas InAppAssistant com corpo vazio — regressão na origem da mensagem 50-CCC-2

    Causa raiz (variante Cenário B): `openSession()` chama `messages.set(mapped)`.

  • Added
    slice50-LLL: geração de título encaminha para o modelo de chat textual mais barato (Regra 2 capability-first)

    Utilizador: 'Não tens de usar o mesmo modelo para os títulos, são só alguns tokens.'

  • Fixed
    slice50-III: refactorização do quadrante de posicionamento do FAB+Painel InAppAssistant

    O utilizador reportou que o painel continuava a abrir desancorado do FAB apesar do Sprint.

  • Fixed
    slice50-KKK: geração de título do chat — ReasoningEffort=low + limite de 1024 tokens (continuação 50-CCC)

    O Sprint 50-CCC aumentou MaxOutputTokens de 24 para 128 esperando '~100 tokens'.

  • Added
    slice50-AAA: IUserActivityRecorder gravador entre módulos — /me/activity-history preenchido para turnos de chat

    O utilizador reportou /me/activity-history vazio apesar de horas de chat/imagem/voz/etc.

  • Fixed
    slice50-CCC: regressão no título do chat + visibilidade do botão de scroll para o fim

    Duas regressões encontradas e corrigidas nos testes do utilizador; a terceira preocupação.

  • Fixed
    slice50-BBB: auditoria dos menus de administrador InAppAssistant + Agent — seed de permissão de módulo para função admin (1 correcção, 14/14 menus desbloqueados)

    | # | Menu | Grupo | Caminho Angular | Rota backend | Estado | Causa raiz |

  • Fixed
    slice50-GGG: upload em massa em /me/library — selecção de múltiplos ficheiros

    Utilizador: 'porque tenho de adicionar ficheiros um a um à biblioteca, devia poder seleccionar todos de uma vez.'

  • Fixed
    slice50-FFF: separador Edit em /me/image — upload da máscara de PC via pré-assinatura Bunny

    Utilizador: 'na fonte há upload do PC mas na máscara porque não há, o nosso sistema de upload está disponível.'

  • Fixed
    slice50-EEE: provedores Bunny expõem interfaces IMediaStorageProvider + IVideoStreamProvider

    Bug crítico reportado pelo utilizador: cada tentativa de upload de PC lançava uma excepção.

  • Fixed
    slice50-DDD: preferências de notificação 404 — adicionar sufixo de acção /my-preferences em falta

    O utilizador reportou repetidamente desde ontem que /me/notifications/.

  • Fixed
    slice50-ZZ: z-index do dropdown da barra lateral do chat — escapar ao empilhamento do separador de dias

    A lista de conversas recentes em /agent/chat-pipeline tinha um dropdown Renomear/Apagar por linha.

  • Fixed
    slice50-YY: FAB InAppAssistant canto superior esquerdo + sino canto superior direito revertido + aviso de downgrade de modelo

    Os testes do utilizador revelaram 5 problemas; 4 foram resolvidos neste commit, 1 adiado.

  • Added
    slice50-WW: MarketplaceRoyaltyPayoutCalculator — divisão diária de royalties entre criadores (Plano §2.1 #7)

    AsyncPeriodicBackgroundWorker diário (tick de 24h) varre entidades Paid.

  • Added
    slice50-XX: colunas FK tipadas + índices em AdAuction Bid/Impression/Click/Conversion (Plano §2.2 / 50-VV-2)

    O Sprint 47-O criou entidades AdAuction simples sem FK de junção;

  • Added
    slice50-UU: KeywordSettlementJob — liquidação diária Spot/Reserve/Futures (Plano §2.1 #6)

    AsyncPeriodicBackgroundWorker ABP diário (tick de 24h) varre liquidações pendentes.

  • Added
    slice50-VV: scaffold de consumidor RTB AdAuction + liquidação ao primeiro preço (Plano §2.1 #5)

    O Sprint 50-TT foi distribuído para isto mas saiu do guião (fez outra coisa).

  • Added
    slice50-OO: sistema de quotas /me/library — controlo de armazenamento + upload de PC + débito na carteira

    O utilizador pediu: indicador de tamanho no topo da biblioteca, upload de PC, cota por nível de plano.

  • Added
    slice50-TT: bloqueios distribuídos por linha nos workers periódicos — segurança em múltiplos pods

    Alarga o padrão 50-RR (VideoJobPollingWorker IAbpDistributedLock).

  • Added
    slice50-NN: separador Edit em /me/image — upload de PC via pré-assinatura Bunny

    O Sprint 50-P adiou o upload de PC porque o backend não tinha um endpoint Bunny.

  • Changed
    slice50-SS: ja.json lote 1/N — primeiras ~300 chaves com artefactos chineses → Japonês nativo

    O 50-AA foi interrompido a meio da varredura completa; este é o lote retomado.

  • Added
    slice50-RR: bloqueio distribuído Redis no VideoJobPollingWorker — segurança em múltiplos pods

    O Sprint 50-U + 50-EE ligou polling + fluxo de reembolso assumindo pod único.

  • Added
    slice50-QQ: mover sino de notificação + actividade do canto superior direito flutuante para adjacente à barra lateral

    Directiva do utilizador (turno Sprint 50-E): sino + actividade devem ficar adjacentes aos ícones do menu da direita.

  • Changed
    slice50-PP: regeneração de proxy ignorada — backend não disponível

    Backend inacessível em https://localhost:44304 durante este sprint;

  • Added
    slice50-MM: desnormalização Creator/Post.CreatorProfileId — correcção de âmbito do 50-LL

    O Sprint 47-H construiu um índice composto degradado para o feed Creator/Post.

  • Added
    slice50-LL: desnormalização PersonaPost.PersonaId + CreatorProfileId (Plano §2.2 — consulta de feed)

    O Sprint 47-H construiu uma análise degradada (TenantId, CreationTime) para PersonaPost.

  • Added
    slice50-JJ: IBillingRecorder.RecordPaddleTransactionAsync — recuperação automática de reconciliação

    O BillingReconciliationJob Sprint 50-W detectou lacunas (Paddle).

  • Fixed
    slice50-KK: desvio no builder do workspace Angular dos módulos (anomalia Sprint 50-M)

    Cada modules/torun.*/angular/angular.json referenciava.

  • Fixed
    slice50-II: substituir literais 'sample-X' dos *DataSeedContributor do Suite por marcadores de posição válidos

    Os testes de isolamento de inquilino Sprint 50-CC revelaram um defeito pré-existente:

  • Changed
    slice50-HH: script de remoção de índices MongoDB legados (Plano §2.1 #8)

    A varredura MT Sprint 47-A..47-P adicionou índices compostos prefixados com TenantId a todas as.

  • Fixed
    slice50-FF: migrar grupos de módulos InAppAssistant + Telemetry + EventBus + Persona

    Conclusão da série Sprint 49.

  • Changed
    slice50-GG: scripts DBA de backfill de inquilinos no dia de lançamento (Plano §2.4)

    Risco R2 pré-lançamento: Sprint 47-A..47-P varreu mais de 219 entidades para.

  • Added
    slice50-EE: extensão IBillingRecorder.RefundAsync com registo negativo complementar

    O Sprint 50-U revelou a lacuna: IBillingRecorder tinha apenas RecordAsync.

  • Changed
    slice50-CC: testes de isolamento de inquilino para subscription + agent + persona

    Plano §2.3 / auditoria R1 — Sprint 47-A...47-P varreu mais de 219 entidades para.

  • Changed
    slice50-DD: pipeline ImageEdit + prop de aprovação Bubble InAppAssistant

    Backlog do Plano §2.5: propagadas 22 chaves do pipeline ImageEdit (Sprint).

  • Fixed
    slice50-BB: varrimento de colisões de MessageKey em 7 pontos de emissão

    O Sprint 50-K detectou uma colisão (configuração Paddle do plano de subscrição).

  • Added
    slice50-W: BillingReconciliationJob — auditoria diária de divergências Paddle↔local

    Fase 1.5 §2.1 #3 — terceiro worker em segundo plano.

  • Added
    slice50-X: PaddleSyncWorker — redundância periódica do estado de subscrição

    Fase 1.5 §2.1 #4 — quarto e último worker em segundo plano pré-lançamento.

  • Fixed
    slice50-Z: lacuna TypePredicate em RunInputUploadAppService (continuação 49-B)

    /api/app/run-input-upload retornava 404 porque o AppService estava em falta.

  • Added
    slice50-Y: seed da Capability de edição de imagem + AiModelCapability gpt-image-1 + ligações de preços

    O Sprint 50-P lançou o UI do separador Edit em /me/image + ligação ao backend, mas.

  • Fixed
    slice50-S: timestamps UTC emitem Z — serializador backend + convenção Mongo

    O frontend (Angular | date pipe + construtor Date) trata UTC → local.

  • Added
    slice50-U: VideoJobPollingWorker — reforço do IHostedService Sora-2

    Fase 1.5 §2.1 — worker em segundo plano de prioridade máxima.

  • Added
    slice50-V: DunningAttemptScheduler — espelho de nova tentativa past_due Paddle

    Fase 1.5 §2.1 #2 — segundo worker em segundo plano.

  • Fixed
    slice50-Q: consumidor SSE InAppAssistant + UX de cancelamento + guarda de tentativas

    O utilizador reportou que uma segunda mensagem de acompanhamento retornava 'Message failed.'.

  • Fixed
    slice50-T: colar da área de transferência no chat + corpo vazio em memory_forget

    Bug A: o compositor do chat ignorava Ctrl+V com imagens da área de transferência.

  • Fixed
    slice50-R: layout /marketplace — remover lpx-content-container exterior

    A página de navegação do Marketplace (angular/src/app/marketplace/).

  • Fixed
    slice50-P: paridade do separador Edit em /me/image + linhas de botões responsivas

    O separador Edit não tinha a selecção de Modelo (Auto/Manual), Qualidade.

  • Fixed
    slice50-N: FAB InAppAssistant — posição padrão canto inferior esquerdo + correcção de ancoragem do painel

    O utilizador reportou que o padrão Sprint 50-I (bottom:96 right:24) se sobrepõe.

  • Fixed
    slice50-O: migração de rotas /me/notifications + preferences (omitida no 49-B)

    O teste de /me/notifications resultou em 404.

  • Fixed
    slice50-M: remover WalletTopUpPriceIds — usar sempre preço inline não catalogado

    PaddleOptions.WalletTopUpPriceIds era um Dictionary<string,string>.

  • Fixed
    slice50-L: checkout Paddle — registar estado + corpo em respostas 4xx/5xx

    O utilizador reportou 'paddle.js devia abrir um popup, está a dar erro' ao efectuar o checkout.

  • Fixed
    slice50-I: arrasto FAB InAppAssistant (reverter arrasto do painel) + alinhamento do dropdown de notificação

    O Sprint 50-I resolve duas regressões de UX surgidas após Sprint 50-B + 50-E.

  • Fixed
    slice50-K: colisão de MessageKey na segunda gravação Paddle do plano

    O administrador gravou a configuração Paddle de um SubscriptionPlan; a primeira gravação funcionou.

  • Fixed
    slice50-J: detalhamento da faturação — $ apenas em campos monetários

    A tabela de detalhamento de custos em /me/billing prefixava ingenuamente cada linha com $.

  • Fixed
    slice50-H: migração de rota do pipeline de chat + Chat no menu /me

    O Sprint 49-B deixou dois URL /api/app/* codificados no pipeline de chat.

  • Changed
    slice50-Fi: propagação consolidada — drag/dock 50-B + modais workflow 50-D + centro de notificação-actividade 50-E em 29 ficheiros de local

    - 50-B (InAppAssistant:Bubble:Dock/Undock/DragHint): adicionado a en.json + todos os outros 28 locais com traduções nativas.

  • Fixed
    slice50-D: substituição de confirm/alert/prompt JS nativos por ABP ConfirmationService + modais LeptonX em todo o projecto

    Utilizador: 'na página memory ao clicar em apagar aparece um confirm JS, porque é que não usamos o LeptonX.'

  • Fixed
    slice50-B: ordenação tool_calls InAppAssistant + balão arrastável/ancorado (CRÍTICO)

    Correcção A (bug CRÍTICO no servidor):

  • Fixed
    slice50-C: renderização do dropdown /me/billing + conteúdo de separadores vazio (UX CRÍTICO)

    O utilizador reportou: o dropdown SourceKind mostrava blocos cor-de-rosa/azul estranhos (componente corrompido).

  • Fixed
    slice50-A: sinos de notificação + centro de actividade deixam de sobrepor-se à etiqueta de administrador

    Feedback do utilizador: os dois sinos flutuantes (sino de notificação + centro de actividade) sobrepunham-se à etiqueta de administrador.

  • Fixed
    slice47-J: subscription split #2 FINAL — Subscription/Invoice/BYOK/QueuedRequest IMultiTenant (Phase 2 CRITICAL)

    Aplicação do padrão Sprint 47-I + 45-M.

  • Added
    slice48-B: custo de embedding ligado ao snapshot AiModelPricing (continuação Sprint 46-A)

    O Sprint 46-A introduziu IBillingRecorder entre módulos e emitiu BillingRecords.

  • Fixed
    slice48-A: módulo translation — traduções adequadas ja/ko/pt/sv (~272 entradas)

    A normalização estrutural Sprint 46-F (minúsculas → PascalCase) foi concluída, mas deixou 4 locais com conteúdo English de stub gerado pelo Suite.

  • Fixed
    slice47-I: correção de auditoria MT subscription parte #1 — Wallet/BillingRecord/Refund/Dispute IMultiTenant (Fase 2 CRÍTICO MONETÁRIO)

    Aplicação do padrão Sprint 45-M + 47-A a 47-N.

  • Fixed
    slice47-N: correção de auditoria MT agent parte #2 — Council/DeepResearch/CodeSandbox/Voice/Translator IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 47-M.

  • Fixed
    slice47-L: correção de auditoria MT authoring parte #2 — GenJobs/BlogPost/quotas IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-K.

  • Fixed
    slice47-M: correção de auditoria MT agent parte #1 — Chat/ChatMessage/Assistant IMultiTenant (Fase 2 RISCO ELEVADO)

    Aplicação do padrão Sprint 45-M + 47-A a 47-K.

  • Fixed
    slice47-K: correção de auditoria MT authoring parte #1 — ecossistema Workflow IMultiTenant (Fase 2 RISCO ELEVADO)

    Aplicação do padrão Sprint 45-M + 47-A a 47-H.

  • Fixed
    slice47-P: correção de auditoria MT marketplace — 15 entidades IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-A/B/C/D/E/F/G/O.

  • Fixed
    slice47-H: correção de auditoria MT creator parte #2 — entidades Posts/Teams/Payouts IMultiTenant (Fase 2 RISCO ELEVADO)

    Aplicação do padrão Sprint 45-M + 47-G.

  • Fixed
    slice47-O: correção de auditoria MT advertising — 16 entidades IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-A/B/C/D/E/F.

  • Fixed
    slice47-G: correção de auditoria MT creator parte #1 — entidades Profile/Account/Org IMultiTenant (Fase 2 RISCO ELEVADO)

    Aplicação do padrão Sprint 45-M + 47-A/B/C/D/E.

  • Fixed
    slice47-F: correção de auditoria MT forum — 19 entidades IMultiTenant + difusão de notificações com consciência de inquilino (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-A/B/C/E.

  • Fixed
    slice47-D: correção de auditoria MT telemetry — 18 entidades IMultiTenant + escritores entre módulos com âmbito de inquilino (Fase 2 RISCO ELEVADO)

    Aplicação do padrão Sprint 45-M + 47-A + 47-B.

  • Fixed
    slice47-E: correção de auditoria MT persona — 16 entidades IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-A/B/C.

  • Fixed
    slice47-C: correção de auditoria MT moderation — 11 entidades IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-A/B.

  • Fixed
    slice47-B: correção de auditoria MT byokvault + knowledge — 7 entidades IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M + 47-A.

  • Fixed
    slice47-A: correção de auditoria MT eventbus + translation — 8 entidades IMultiTenant (Fase 2)

    Aplicação do padrão Sprint 45-M: o Suite não emitia IMultiTenant nas classes Base apesar de IsMultiTenant: true no JSON.

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

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