• Muitas vezes usuários do Catarse precisam transferir seus saldos para outros usuários (por diversos motivos). Implementamos uma novidade interna, para o time que administra a plataforma do Catarse, focada em permitir que o Saldo de usuários no Catarse sejam transferidos entre si (como se fosse um PIX interno nosso), sem que para isso o time de suporte do Catarse precise acionar um dos desenvolvedores.
• Fizemos também um ajuste numa ferramenta interna nossa de execução de scripts, para facilitar a vida do time de desenvolvedores na hora de investigar bugs na plataforma.
Fizemos alguns ajustes referentes a alguns erros encontrados no deploy do Rails 6, realizado ontem. São eles:
• Atualizar gridhook - é uma ferramenta que utilizamos para comunicar o Catarse com o Sendgrid (plataforma usada para enviar emails transacionais do Catarse). Por conta do deploy do Rails, tivemos que alterar a versão dessa ferramenta. O problema que ela gerava era no envio de algumas notificações.
• Acesso à página de documentos fiscais - alguns realizadores de projetos relataram erro ao acessar a página de documentos fiscais em seus projetos. Enviamos uma correção e está funcionando normalmente esse acesso.
• Correção da visualização de dataclips em CSV [Melhoria interna]- temos uma ferramenta interna para visualizar dados chamada Dataclips que, após o deploy do Rails, deixou de exibir arquivos em formato em CSV. Enviamos uma correção para isso, assim nosso time de operações pode seguir usando planilhas que são alimentadas por esses arquivos.
O Ruby on Rails (tecnologia utilizada no desenvolvimento do site do Catarse) que estávamos usando ainda estava na versão 4.2. Era uma versão lançada em 2016, que já não recebia nenhuma atualização (a não ser quando eram encontradas falhas de segurança).
As gems (bibliotecas) que utilizávamos, muitas já haviam sido abandonadas há alguns anos, algumas outras só poderiam ser atualizadas se tivéssemos uma versão do Rails mais atual, e algumas gems novas só poderiam ser adicionadas ao projeto se estivéssemos com uma versão recente do Rails.
Ou seja, estávamos rodando o Catarse num motor antigo, quando deveríamos estar rodando em um motor atual, novinho em folha. A nova versão do Rails que estamos agora utilizando trouxe algumas melhorias e facilidades no uso do framework.
Com isso, estamos prontos para seguir em uma série de melhorias e refatorações em 2021, com a garantia que estamos evoluindo o código do Catarse em uma máquina atualizada, sem códigos obsoletos.
Entregamos duas funcionalidades que buscam melhorar a experiência e a segurança do Catarse:
* ✨ Bloquear cadastro de email com referencia a catarse
* Corrigir regex de validação do e-mail
Essa é uma entrega bem técnica, de bastidores, mas que tem como objetivo dar mais agilidade para o nosso time de produto na hora de entregar soluções, melhorias e novas funcionalidades para a comunidade de usuárias e usuários do Catarse. A explicação técnica é que estamos movendo o catarse.js para dentro do catarse, simplificado o processo de deploy, pois não será mais necessário fazer commits do build para o repositório do catarse.js. Ao realizar um npm install no Catarse, o build do catarse.js será realizado.
Uma imagem vale mais que mil palavras. Pensando nisso que hoje anunciamos uma funcionalidade leve, mas que já é uma das mais pedidas pela nossa comunidade há um tempão: a possibilidade de atribuir uma imagem à uma recompensa no Catarse.
Você pode ver pela imagem acima que é super simples adicionar imagens às suas recompensas a partir do painel de controle do projeto. É possível pode adicionar, deletar e trocar as imagens a qualquer momento de sua campanha.
✨ Deixa de exibir email do destinatário em mensagens enviadas pela plataforma. Para preservar a privacidade de nossos usuários, a partir de agora as mensagens enviadas pela plataforma não exibem mais o email do destinatário. Com isso, a pessoa que enviar uma mensagem pela plataforma receberá somente um recibo do envio, onde constará o conteúdo da mensagem enviada e o nome público do destinatário, porém não terá mais o email do destinatário (considerado informação confidencial). Exemplo de um recibo de mensagem abaixo:
✨ Remove o nome do realizador na aba pública de Novidades, quando não existe novidade ainda enviada.
✨ Exibe uma saudação genérica (Olá!) no email enviado à pessoas que não possuem um nome público registrado no Catarse
✨ [Trabalho em progresso - não foi publicado no changelog] Altera os dados da nova estrutura de dados fiscais, Cria integração com o Enotas para geração de notas fiscais, Cria rotina para gerar os dados fiscais de pagamentos feitos após a geração dos dados fiscais. São tarefas implementadas no back-end do Catarse, mas que ainda não estão funcionando (ou seja, nossas Notas Fiscais ainda estão sendo emitidas da forma que sempre foram emitidas). Próximo passo será validar o funcionamento real dessas tarefas e partir para a última fase do projeto, que será "virar a chave" para que a gente possa começar a usar o Enotas para emissão de Notas Fiscais.
🐞 Remove validação de prazo para projetos Flex. Os projetos Flex no Catarse já não precisam se limitar a estarem no ar por um período máximo de 365 dias. Porém, caso um realizador com projeto FLEX há mais de 365 dias no ar tentasse definir um prazo para sua campanha, nós ainda estávamos exibindo uma mensagem de erro no momento da definição do prazo (considerando ainda a regra antiga). O que essa correção fez foi remover essa validação no momento da definição do prazo e também ajustar o texto que informa sobre o limite de prazo do Flex nesse, nesse e nesse artigo da base de conhecimento. Além também de corrigir essa informação sobre prazo ilimitado em Flex na aba Financiamento no painel de controle de projetos:
🔧 Coloca idempotencia no repasse realizado através do Pagarme para evitar erros de transferências duplicadas
💎 Atualiza as dependências do back-end e o Ruby para a versão 3.0.1
Temos alguns casos em que um boleto é pago após o vencimento, e temos casos em que as pessoas pagam um boleto parcialmente (não pagam todo o valor dele). Essas coisas, apesar de não serem frequentes, quando acontecem necessitam de um esforço do time do Catarse pra resolver. Ainda não está claro se essa configuração que adicionamos (oferecida pelo meio de pagamento que utilizamos para processar os boletos) impede os apps e atendentes de efetuarem o pagamento desses boletos nas situações indesejadas ou apenas adiciona instruções na folha do boleto. Entretanto, como o esforço para adicionar essa configuração era mínimo, estamos entregando essa atividade hoje e iremos monitorar se esse problema irá persistir.
O Ruby on Rails (tecnologia utilizada no desenvolvimento do site do Catarse) que estávamos usando ainda estava na versão 4.2. Era uma versão lançada em 2016, que já não recebia nenhuma atualização (a não ser quando eram encontradas falhas de segurança).
As gems (bibliotecas) que utilizávamos, muitas já haviam sido abandonadas há alguns anos, algumas outras só poderiam ser atualizadas se tivéssemos uma versão do Rails mais atual, e algumas gems novas só poderiam ser adicionadas ao projeto se estivéssemos com uma versão recente do Rails.
Ou seja, estávamos rodando o Catarse num motor antigo, quando deveríamos estar rodando em um motor atual, novinho em folha. A nova versão do Rails que estamos agora utilizando trouxe algumas melhorias e facilidades no uso do framework.
Com isso, estamos prontos para seguir em uma série de melhorias e refatorações em 2021, com a garantia que estamos evoluindo o código do Catarse em uma máquina atualizada, sem códigos obsoletos.
Entregamos duas funcionalidades que buscam melhorar a experiência e a segurança do Catarse:
* ✨ Bloquear cadastro de email com referencia a catarse
* Corrigir regex de validação do e-mail
Essa é uma entrega bem técnica, de bastidores, mas que tem como objetivo dar mais agilidade para o nosso time de produto na hora de entregar soluções, melhorias e novas funcionalidades para a comunidade de usuárias e usuários do Catarse. A explicação técnica é que estamos movendo o catarse.js para dentro do catarse, simplificado o processo de deploy, pois não será mais necessário fazer commits do build para o repositório do catarse.js. Ao realizar um npm install no Catarse, o build do catarse.js será realizado.
Segundo a legislação, quando o tomador do serviço (no caso, o Realizador de Projeto no Catarse) for Pessoa Jurídica e o valor devido de Imposto de Renda for superior a R$10,00, o Realizador é responsável por recolher o Imposto de Renda. Para que isso ocorra, o Catarse precisa transferir para o saldo do Realizador, além do montante arrecadado no projeto, o valor referente ao Imposto de Renda.
Com a melhoria que implementamos, esse processo agora é feito automaticamente para projetos pontuais (a solução para projetos de Assinatura virá em breve), e sempre que um realizador que tenha um perfil de Pessoa Jurídica no Catarse receber recursos em seu saldo, será também transferido um valor do Imposto de Renda. Para isso, criamos um evento no Saldo deixando claro do que se trata o valor e também incluímos uma mensagem na aba Saldo explicando a questão. Além disso, essa informação também constará nos Documentos Fiscais, disponíveis aos realizadores em seu painel de controle de projetos.
Existia uma falha na edição de projetos do Catarse que permitia que usuários alterassem atributos na página de projeto que deveriam ser restritos à edição de administradores da plataforma. Kudos (mais uma vez!) para o Paulo, estudante de TI e usuário do Catarse que identificou esse problema e nos avisou de prontidão 💜
🐞 Pagamentos reembolsados em projetos de assinatura agora são tratados como pagamento pago: antes, se o último pagamento de uma assinatura estivesse com o status reembolsado (ou seja, caso o time de atendimento do Catarsetivesse respondido à uma solicitação de um assinantes paa reembolsar o último pagamento de uma assinatura), essa assinatura ficaria em um modo "congelado", pois nosso sistema não sabia como computar um pagamento com status reembolsado (ou seja, se a assinatura estivesse com status ATIVA e último pagamento REFUNDED, ela não seria cobrada no próximo aniversário e nem seria inativada, permanecendo ativa pra sempre). Agora estamos considerando, para fins da máquina de cobranças, que um pagamento refunded é um pagamento pago. Ou seja, se uma pessoa tiver o último pagamento de sua assinatura com status refunded, nossa máquina irá tratar esse pagamento como sendo pago, portanto a assinatura seguirá seu curso normal (e será cobrada em seu próximo aniversário de cobrança).
🐞 Deixa de enviar emails de "Campanhas apoiadas por amigos" com conteúdo vazio: alguns usuários recebiam esse email vazio, sem nenhum conteúdo. Corrigimos isso e agora o email só é disparado se existir conteúdo para ser exibido.
💎 Atualiza as dependências do back-end e o Ruby para a versão 3.0.2. Não houve nenhuma modificação relevante no código devido à essas atualizações.
🐞 Configura prazo do Pix de 2 dias corridos: corrigimos um problema que estava gerando o QR Code do PIX com prazo de 2 dias úteis, quando o correto é 2 dias corridos.
🐞 Exibe QR Code do Pix no email: voltamos a exibir o QR Code nas notificações por email de apoios em PIX (quando fizemos o lançamento do PIX, tivemos que fazer um ajuste temporário onde existia um botão no email para visualizar o QR Code em uma aba do Browse, pois o QR Code não estava sendo exibido no email).
🐞 Exibe código do PIX em formato de texto no email: reduzimos um problema que fazia com que o código do PIX (para copiar e colar) fosse exibido como se fosse um link no email (ainda depende do cliente de email da pessoa para que o problema seja 100% corrigido, porém não iremos fazer maiores investigacões sobre isso por enquanto).
🐞 Remove texto em branco nas notificações de reembolso no Catarse: ajuste de redação do email de reembolso, que estava gerando um mal entendimento sobre o conteúdo da notificação.
🐞 Ajusta contador de recompensas selecionadas no Relatório de Apoios online: corrigimos um erro que fazia com que, ao selecionar uma faixa de recompensa para marcar como 'Entregue / Erro no envio' e avançar, o sistema informava erroneamente que a alteração seria feita em outras recompensas também.
🐞 Corrigimos uma problema que estava deixando de exibir na Base de Assinantes online o bairro dos assinantes.
🐞 Corrigimos um problema que estava causando o envio da mensagem "Seus amigos apoiaram projetos no Catarse" para usuários que não estavam seguindo ninguém
🐞 Corrige um bug que não estava exibindo as datas de transferência na área de Saldo do usuário
🐞 Corrige um bug que estava impedindo usuários de editar ou deletar os links de 'Presença na Internet' em seu perfil público
🐞 Centraliza o botão de deletar projeto no painel de controle de projetos (que estava por vezes ficando escondido atrás do widget de 'Fale conosco' no canto inferior direito da tela)
🐞 Corrige um bug que estava impedindo usuários de conectar suas contas do Facebook e atrapalhando a visualização de projetos apoiados por amigos
🐞 Corrige um bug que estava exibindo um texto quebrado na data de resposta de um questionário, no Relatório de apoios online em projetos pontuais, quando o questionário ainda não havia sido respondido pelo apoiador
🐞 Corrige um bug que estava exibindo uma mensagem de erro ao salvar dados na aba 'Dados cadastrais' no painel de controle de projetos, mesmo quando todos os dados informados estavam corretos
🐞 Corrige um problema que estava impedindo a publicação de projetos da Catarse Solidária:Não estava sendo possível publicar projetos na Catarse Solidária sem o usuário informar links de redes sociais em seu perfil.
🐞 Oculta cidade e estado da aba de apoiadores e assinantesNós estávamos informando a cidade e o estado dos apoiadores na aba pública de apoiadores/assinantes nos projetos. Removemos essa informação por ser considerada informação sensível. Em breve vamos avançar nesse projeto e remover as fotos e nome também dessa aba pública.
🐞 Altera nome de usuário para nome público em emails automáticos
Fizemos mais alterações em alguns emails automáticos para que eles usem o nome público da pessoa.
✨ Melhora no texto de aviso de cancelamento de projeto
Quando um usuário tem um projeto em cancelamento, ele fica impedido de solicitar saque até que o projeto seja definitivamente cancelado e os reembolsos sejam concluídos para seus apoiadores. Fizemos uma alteração simples no texto que informa isso à pessoa em sua aba de Saldo, deixando mais claro essa regra.
💚 Substitui biblioteca de captura de erros do back-end e 💚 Adiciona tratamento de erro na tarefa de repasses
Atividades técnicas para melhorar a forma como nosso time de desenvolvimento monitora os erros que acontecem em nossa plataforma
🐞 Ajusta ação de banir projetos em reembolso de boleto
🐞 Ajusta busca da informação do usuário e envio de contexto ao Sentry
🐞 Corrige problema de baixar dados do Pagarme
🐞 Deixa de exibir projetos deletados da plataforma
🐞 Deixa de exibir usuários banidos da plataforma
🐞 Altera nome de usuário para nome público nas notificações do sistema
🐞Valida imagem base64 nas novidades: corrigimos um problema que estava permitindo enviar novidades com imagens base64. Agora, só podem imagens que tenha sido carregadas via upload no texto da novidade.
🐞Ajustamento ordenamento de recompensas em projetos de Assinatura (na página de seleção de recompensa) : corrigimos um problema que estava exibindo recompensas fora de ordem em alguns casos, quando a pessoa visitava a tela de selecionar recompensa em projetos de assinatura.
Ao criar uma nova recompensa em um projeto que já possui uma ou mais recompensas várias, nosso sistema estava posicionando essa nova recompensa na ordem errada. Isso estava gerando dois problemas - no painel de controle de projeto, ao clicar em Adicionar recompensa, o realizador não tinha um feedback visual de que a recompensa tinha sido criada, dando a entender que algo deu errado. Além disso, no fluxo de apoio, na tela de seleção de recompensa, as recompensas estavam desordenadas. Enviamos uma correção para resolver esse problema.
Nós tínhamos uma tela especial que era exibida sempre que usuários tentavam acessar uma página de apoio a um projeto utilizando um browser antigo, porém essa tela não era exibida em outras áreas da plataforma (como a página inicial, o Explore, etc). Com isso, pessoas que tentassem acessar essas outras páginas se deparavam com uma tela em branco. Fizemos uma correção que agora passa a exibir essa tela em todas as áreas do site para usuários com browsers antigos, orientado-os a fazer o download de um browser mais moderno.