Executando verificação de segurança...
35

Pitch: Meu Curso de Programação Para Quem Quer Se Sentir Competente 🎉

Turma, finalmente o meu curso chegou num estágio em que posso falar abertamente sobre ele e o primeiro lugar que escolhi fazer uma publicação oficial não poderia ser outro, a não ser aqui no TabNews 🤝

Então, a plataforma onde está o curso se chama curso.dev (o nome e o endereço são a mesma coisa) e o primeiro curso disponível é sobre Desenvolvimento Web 🎉 Na verdade, acaba sendo bem mais do que isso, pois é um download do meu cérebro sobre a parte técnica, negócio e carreira na programação, tudo para o aluno atingir de forma genuína a sensação de ser competente no que faz.

E para isso, estou reconstruindo do zero o TabNews lá dentro do curso e explicando como que eu apliquei todas as técnicas que eu uso para organizar e executar um projeto do início ao fim e sem desanimar ou desistir no meio.

Home do curso.dev

Como a plataforma foi construída?

Eu estava louco para fazer essa publicação e dizer que a plataforma do curso.dev é um fork do repositório do TabNews e isso me mostrou como que a arquitetura, modelagem e API aqui do TabNews está super flexível e consegue se adaptar para outras situações e iniciativas.

Ainda tem alguns detalhes que preciso ajustar do backend antes de disponibilizar o core do curso.dev de forma Open Source (eu marretei algumas coisas de forma hard coded e preciso tirar), mas a idéia é sim ter mais uma plataforma Open Source brasileira, agora voltada para cursos 💪

Então em cima do fork original eu programei coisas específicas para uma plataforma de curso que eu vou expandir em tópicos logo abaixo, mas antes eu gostaria de começar com um Diagrama de Sequência revelando o fluxo principal entre o curso.dev e a Hotmart sobre o momento em que acontece uma matrícula:

0) Fluxo de compra

Não é um fluxo complicado, mas queria destacar que a Hotmart está sendo usada apenas para a parte de Pagamentos.

sequenceDiagram
    actor Aluno
    participant curso.dev
    participant Hotmart
    Aluno->>curso.dev: Acessa o site
    curso.dev->>Hotmart: Faz o Pagamento
    Hotmart-->>curso.dev: Webhook (Pagamento Aprovado)
    curso.dev-->>Aluno: Envio do Código de Ativação por email
    Aluno->>curso.dev: Faz o cadastro usando Código de Ativação
    curso.dev-->>Aluno: Acesso às aulas
PS: este gráfico foi feito com o Mermeid e tudo aqui por dentro do TabNews. Obrigado Felipe Barso por consertar o Preview dele 🎉 Coloquei o Editor no modo Full Screen e dividi ele para mostrar o Texto e Resultado ao mesmo tempo para tudo ir atualizando em tempo-real... foi uma experiência sensacional 😍 E segue abaixo o código que foi usado para gerar o gráfico acima:
```mermaid
sequenceDiagram
    actor Aluno
    participant curso.dev
    participant Hotmart
    Aluno->>curso.dev: Acessa o site
    curso.dev->>Hotmart: Faz o Pagamento
    Hotmart-->>curso.dev: Webhook (Pagamento Aprovado)
    curso.dev-->>Aluno: Envio do Código de Ativação por email
    Aluno->>curso.dev: Faz o cadastro usando Código de Ativação
    curso.dev-->>Aluno: Acesso às aulas
```

1) Integração com um Meio de Pagamento

Na parte do pagamento, por hora como falei, optei integrar com a Hotmart e estou usando os Webhooks que eles fornecem e que avisam o backend do curso.dev quando alguém faz uma Nova Matrícula para gerar um Código de Ativação ou, caso o aluno peça Reembolso, para automaticamente desabilitar o acesso à conta.

Webhook da Hotmart

Esta imagem aqui de cima é de dentro do painel da Hotmart e mostra os logs dos Webhooks. Se você clicar no ícone da lupa, é possível inspecionar tanto o que a Hotmart enviou na Request, quanto o que a sua plataforma devolveu como Response (incluindo o Status Code que nos três exemplos acima foram 201).

Esta integração está funcionando surpreendentemente bem e até o momento não gerou nenhum problema. Na verdade tudo indica que, até agora, só um caso a Hotmart não enviou um Webhook de Estorno. E fora isso, teve um evento onde a API do curso.dev não estava respondendo (por um bloqueio rigoroso que fiz na Cloudflare) e a Hotmart fez com sucesso Retentativas do mesmo Webhook. Tudo funcionou de forma transparente 🤝

O legal é que tudo está coberto com Testes de Integração que simulam a Hotmart fazendo um POST contra o backend do curso.dev e isto dá uma baita segurança na hora de alterar o código e avançar com novas features.

2) Nova modelagem: Activation Codes

Uma característica da Matrícula, é que ao fazer ela você recebe por email um Código de Ativação que pode ser utilizado por você ou enviado para outra pessoa como um presente (e algumas pessoas já fizeram isso, muito legal).

A estrutura dela no Banco de Dados é simples:

CREATE TABLE activation_codes (
    id uuid DEFAULT gen_random_uuid() PRIMARY KEY,
    active boolean NOT NULL DEFAULT true,
    type text NOT NULL,
    code text NOT NULL CHECK (length(code) = 23) UNIQUE,
    available_redeems integer NOT NULL DEFAULT 1 CHECK (available_redeems >= 0),
    redeemed_by jsonb DEFAULT '[]'::jsonb,
    metadata jsonb,
    created_at timestamp with time zone NOT NULL DEFAULT (now() AT TIME ZONE 'utc'::text),
    updated_at timestamp with time zone NOT NULL DEFAULT (now() AT TIME ZONE 'utc'::text)
);

Em especial eu destaco a propriedade available_redeems que controla quantas vezes um Código de Ativação pode ser usado (resgatado), que por padrão o valor é 1 e também a propriedade redeemed_by que anota qual usuário (ou usuários) fizeram o resgate dele.

3) Nova modelagem: Lessons

Esta foi uma modelagem interessante de se fazer, pois ela é uma abstração em cima de uma modelagem que já existe no TabNews, que é a de Conteúdos. Todas as publicações no TabNews, sejam elas publicações que vão para a raiz do site (root), sejam elas respostas a outras publicações (child), tudo é um content.

Da mesma forma, o conteúdo de uma aula dentro do curso.dev é também um content e qualquer pessoa da plataforma consegue criar um conteúdo. Mas transformar esse conteúdo em uma aula/lição, fica sob a responsabilidade da lesson, e por isso a tabela abaixo conta com um campo chamado content_id. Este campo diz para a lesson de onde vem o conteúdo dela:

CREATE TABLE lessons (
    id uuid DEFAULT gen_random_uuid() PRIMARY KEY,
    owner_id uuid NOT NULL,
    course_slug character varying NOT NULL,
    slug character varying NOT NULL CHECK (length(slug::text) <= 256),
    content_id uuid NOT NULL,
    xp integer NOT NULL,
    tags character varying[],
    exit_options jsonb[],
    listing_visibility character varying NOT NULL DEFAULT 'public'::character varying CHECK (listing_visibility::text = ANY (ARRAY['unlisted'::character varying, 'public'::character varying]::text[])),
    listing_section character varying,
    listing_order integer,
    created_at timestamp with time zone NOT NULL DEFAULT (now() AT TIME ZONE 'utc'::text),
    updated_at timestamp with time zone NOT NULL DEFAULT (now() AT TIME ZONE 'utc'::text),
    CONSTRAINT lessons_uniqueness_fkey UNIQUE (course_slug, slug)
);

Outro detalhe é que toda lesson possui um xp, que são os Pontos de Experiência que a pessoa pode coletar ao final da aula, e estes pontos são somados ao xp do usuário.

Clicando no botão para resgatar XP

Isso significa que o curso.dev não possui o conceito de tabcoins e tabcash e eles foram alterados para coins e xp, respectivamente:

{
  "id": "78a37e97-14bd-498e-a59d-e527a7cb30e0",
  "username": "filipedeschamps",
  "features": [
    "course:web",
    "create:session",
    "read:session",
    "create:content",
    //...
  ],
  "coins": 1321,
  "xp": 2051,
  "created_at": "2022-12-08T23:31:05.349Z",
  "updated_at": "2022-12-14T20:44:30.223Z"
}

4) Nova modelagem: Lessons Progress

Esta modelagem controla o progresso do aluno pelas aulas e marca 3 estágios:

  1. Aluno não iniciou a aula (nada é registrado na tabela lessons_progress).
  2. Aluno iniciou a aula, porém não marcou como concluída (é criado um novo registro na tabela lessons_progress, porém com completed_at = null).
  3. Aluno concluiu a aula (registro é atualizado com completed_at = NOW()).

Isso significa que, ao entrar numa aula, o frontend já faz um POST contra o backend para sinalizar que você iniciou a aula e o endpoint para isso é idempotente, ou seja, você pode fazer várias vezes um mesmo POST, que sempre será retornado a mesma coisa (não será negado, caso você já tenha iniciado a aula).

E a tabela é bem simples:

CREATE TABLE lessons_progress (
    id uuid DEFAULT gen_random_uuid() PRIMARY KEY,
    user_id uuid NOT NULL,
    lesson_id uuid NOT NULL,
    completed_at timestamp with time zone,
    created_at timestamp with time zone NOT NULL DEFAULT (now() AT TIME ZONE 'utc'::text),
    updated_at timestamp with time zone NOT NULL DEFAULT (now() AT TIME ZONE 'utc'::text),
    CONSTRAINT lessons_progress_uniqueness_fkey UNIQUE (user_id, lesson_id)
);

E a junção da tabela lessons_progress com lessons, faz ser possível construir uma lista com as aulas e representar os 3 tipos de progresso visualmente:

  1. Ícone pontilhado: não iniciou a aula
  2. Ícone amarelo: iniciou a aula
  3. Ícone verde: concluiu a aula

Lista de Aulas

5) Como estão organizadas as aulas?

Pela lista acima você pode ter notado que as aulas são organizadas de uma forma linear e separadas por Dias, onde cada Dia conta com uma aula curta e isto contribui muito com o progresso do Aluno por dentro dos materiais.

Fora isso, note que cada dia possui uma Pista Rápida e algumas Pistas Lentas. Eu explico melhor dentro do curso toda a estratégia por trás disso, mas em resumo é para conseguir comportar usuários iniciantes e avançados na mesma plataforma.

Então se você já tem maestria num determinado assunto, você pode rapidamente navegar pelas Pistas Rápidas, e caso precise ir com mais calma, você pode descer para a Pista Lenta e lá passamos um pente fino em tudo.

O curioso é que vários alunos que já se encontram num nível bem avançado na carreira reportaram estarem gostando muito das Pistas Lentas, pois através delas está sendo possível fechar todos os gaps de conhecimento que talvez ao longo da velocidade e truculência da vida real não foram possíveis de fechar. Eu não esperava que tantos alunos já com esta senioridade reportariam isso, mas foi algo muito muito muito legal de se ver, até porque com eles, a seção dos Comentários virou uma parte fundamental das aulas e todo mundo está se ajudando 🤝 💪

6) Aulas interativas

Este ponto eu não gostaria de revelar muito o que acontece, pois pode acabar sendo um baita spoiler de coisas interessantes que acontecem dentro das aulas... coisas que geram uma certa surpresa no aluno 😂

Bom, essa parte vou deixar apenas para quem se matriculou e vivenciou isso, mas meu objetivo foi criar uma "experiência viva" lá dentro, uma tentativa de realmente me "virtualizar" e estar o mais próximo possível do aluno, ao ponto de que se este mesmo aluno fizer um curso em outra plataforma, vai sentir que "algo está faltando" 🤝

Se você quiser uma pequena demonstração disso, convido a entrar na Home do curso.dev e assistir o vídeo de apresentação, pois possivelmente algo diferente do que você está acostumado vai acontecer 😍

Conclusão

Assim como eu fiz o Canal no YouTube para ter vídeos em português que eu gostaria de ver por lá, a Newsletter para ler por email notícias no formato que eu gostaria de ler, o TabNews para navegar na web e ler conteúdos de valor concreto sem ter medo de ser pego por algum dark pattern na Experiência do Usuário... eu criei o curso.dev para ser uma plataforma onde eu pudesse expressar e atingir o máximo que consigo da minha didática.

Bom, no mais, estou 100% aberto a AMA (Ask Me Anything), então qualquer dúvida que tiver sobre o curso, seja na parte técnica ou sobre as aulas, estou de plantão aqui para responder, independente de quando você ler esta publicação 🤝 💪

4

Eu vou deixar aqui no TabNews o mesmo depoimento que eu deixei lá no curso.dev porque reflete exatamente o que eu penso ao acompanhar o trabalho do filipedeschamps durante todos esses anos:

Pela transparência, eu sou irmão do Filipe. O que me faz ter uma vantagem em relação a todo mundo aqui: acompanhar o desenvolvimento do curso pelos bastidores. O que eu posso dizer é que quando ele afirma que esse é o projeto da vida dele, não é exagero. O curso.dev é culminação da carreira do Filipe – não só como programador, mas como educador. Ele está unindo tudo o que sabe em um ponto focal com uma intensidade de carinho e trabalho que eu nunca vi igual. A interação do Filipe com todos aqui dentro da plataforma deixa o curso vivo e me também tira o receio de eu não conseguir acompanhar os módulos do curso. É um orgulho participar dessa master class em programação aqui com todos vocês.

4
2

Parabéns pelo lançamento.

Virará certamente uma das minhas recomendações para quem quer entrar no nosso mundo de desenvolvimento.

Abraços e boa sorte.

1

Virará certamente uma das minhas recomendações para quem quer entrar no nosso mundo de desenvolvimento.

É uma honra isto vindo de você meu caro! Como falo no vídeo de introdução, é o projeto da minha vida 💪

2

Fiquei sabendo desse curso a um tempo atras e estou muito feliz por 2 motivos
o primeiro é que voce conseguiu lançar o curso e o segundo é que os videos no canal voltaram !!!

parabens !!!

2

É surpreendente como que tudo que você bota a mão vira ouro. Parabéns!

Só fiquei com uma dúvida... A plataforma e o curso foram disponibilizados de antemão para os membros do canal?

1

É surpreendente como que tudo que você bota a mão vira ouro. Parabéns!

Muito obrigado pelo comentário megbr 🤝

Só fiquei com uma dúvida... A plataforma e o curso foram disponibilizados de antemão para os membros do canal?

Sim! Da mesma forma como os outros produtos, como a Newsletter e o próprio TabNews 💪 A turma lá é muito fera e gosto sempre de envolver eles logo no início de tudo que faço 😍

2

Parabéns pelo lançamento, Filipe!
Sua contribuição com a comunidade é gigante, sempre descomplicando temas complexos e agora de forma estruturada em um curso/plataforma.
Além da boa didática, é um baita diferencial essa abordagem de um sistema da vida real, algo que poucos cursos oferecem.
Sucesso!

1

é um baita diferencial essa abordagem de um sistema da vida real, algo que poucos cursos oferecem

Justo heigler, eu diria que este é o grande diferencial do curso, ou pelo menos faz ser possível ensinar coisas que apenas acontece com um projeto que encosta no calor da vida real 💪

2
2

Sou muito suspeito para falar sobre o curso, mas vou ser sincero em relatar minha "insatisfação", pois eu não consigo assistir apenas as aulas da pista rápida, mesmo que domine o assunto 😅

Não resisto e assisto todas, pois além da didática incrível, as aulas são muito legais 🤩

2

haahahhahah showww!! Excelente insatisfação 😂

E para quem estiver lendo este comentário, o FelipeBarso é o principal core commiter aqui do TabNews e pelo fato de compartilharmos o core entre os dois sistemas, já foi possível levar melhorias de um lado para o outro 💪

2

Olá!
Onde encontro a grade detalhada do curso?

Em comparação a outros cursos nesse mesmo range de valor
no que o seu se destaca na questão grade?

Abraços

1
2

Só de ler este post, e a forma como ele esta explicado, é possível ter uma ideia do potencial absurdo que este curso tem, eu já aprendi algumas coisas só lendo o post. Muito massa mesmo

2

Com certeza esse será um curso que vou recomendar para muitas pessoas, mesmo sem ter experimentado. Só pela qualidade dos vídeos no Youtube do Filipe da para ter uma noção de quão bom será o curso.

é um download do meu cérebro sobre a parte técnica, negócio e carreira na programação

Para mim, esse é o diferencial do Filipe: consegue sintetizar experiências, aprendizados, erros, etc., e repassar de maneira muito rica e simples de entender. Poucas pessoas, não só da área de tecnologia, conseguem fazer isso.

2

Deschamps, mano. Sei nem oq falar, então nem vô (mto). Mas num para não fi. Maluco bom demaisi, a paz na fala e nas ações. O futuro de uma galera, que ainda esta por vir, que ainda receberá uma ou outra semente, vai se beneficiar muito do seu legado. Parabéns pelo esforço e por toda sua entrega. 💛

2

Cara MUITO bom esse curso. Gosto muitos dos vídeos no canal do youtube pela didática e pelo conteúdo muito massa. Um curso sobre desenvolvimento web moderno nessa pegada é simplesmente sensacional!

Pergunta: filipedeschamps você predende criar outros cursos fora esse de Desenvolvimento Web? Se sim quais?

3

Showww LikedAndrew obrigado pelo comentário e ótima pergunta! Eu gostaria sim, e três cursos que vejo o pessoal pedindo muito são:

  1. Algoritmos (principalmente para entrevista de emprego)
  2. Inglês (para poder trabalhar com oportunidades internacionais)
  3. Programação para iniciantes
1
1

Gostaria de saber até quando este desconto de pre-lançamento irá permanecer?

OBS: Quero muito comprar esse curso mas preciso esperar meu cartão fechar kkkkkkkkkkkkkkkkkkkkkk

1

Vi a postagem aqui no TabNews, mas com a página do curso já aberta por ter ido na descrição do vídeo no youtube hahaha! Bom demais, e fiquei interessadíssimo! Teu conteúdo é muito massa, Filipe! Parabéns pelo seu trabalho aqui na Internet, que tanto nos ajuda!

1