DEV Community

Eduardo Queiróz
Eduardo Queiróz

Posted on

Gerando engajamento para jogos indies com OpenApi + Twitter API + Azure LogicApps (PT/BR)

Briefing

Em resumo, desenvolver jogos não é minha atividade principal. É um hobby que pratico principalmente durante o meu tempo livre na DZ9 Games, nas madrugadas de insônia ou nos fins de semana. No entanto, percebi que essa jornada tornava-se impossível de trilhar sozinho, então decidi convidar um ilustrador e um roteirista para se juntarem à equipe de #theagent, os quais prontamente aceitaram o desafio.

Se você quiser saber mais detalhes sobre o jogo e sua evolução, pode encontrá-los aqui, aqui ou aqui.

O Problema

À medida que a versão Demo (que está em andamento) se aproxima, estamos começando a trabalhar nas redes sociais e explorar possíveis canais de divulgação. No entanto, enfrentamos um desafio, uma vez que ninguém na equipe se dedica integralmente a essa ocupação. O tempo necessário para esse trabalho de "divulgação", "propaganda" e "engajamento" entra em conflito direto com os ajustes das mecânicas do jogo, o trabalho artístico e aprimoramentos na continuidade.

Mais uma vez, é impossível conciliar e realizar todas essas tarefas com o mínimo de qualidade.

A solução estava próxima

Durante a fase de desenvolvimento, nos deparamos com a necessidade de resolver nossos problemas de divulgação. Consideramos várias opções, como contratar uma agência, um especialista em mídias sociais ou até mesmo um estagiário, mas essas alternativas acarretavam principalmente custos adicionais 😭. A cada nova ideia, parecia que o impossível sempre se apresentava diante de nós.

No entanto, surgiu uma sugestão simples e despretensiosa que se revelou perfeita: "E se automatizarmos isso de alguma maneira?" A maioria das redes sociais fornece API's e meios de integração para a publicação de posts, mas ainda assim o trabalho criativo e o tempo da equipe eram necessários.

IA como facilitadora!

Ao acompanhar a rápida evolução das IA's diariamente, ficou evidente como elas podem facilitar a resolução dos nossos problemas. Neste tutorial, vou mostrar como implementamos a geração automática e eficiente dos tweets em nosso perfil.

É importante ressaltar que, apesar da automatização na geração dos tweets, continuamos a acompanhar e responder todos os comentários. Portanto, se você se deparar com posts em nosso perfil no Twitter, pode ter certeza de que estamos lá! 😄😄😄

Passo 1 - Twitter Developer Platform

O primeiro passo foi ativar a nossa conta no portal do desenvolvedor e criar um projeto na camada gratuita, o que nos permite gerar aproximadamente 1500 tweets por mês. Em seguida, marcamos a opção de escrita e leitura em App permissions e logo após criamos uma aplicação para gerar as chaves de autenticação dos grupos: Consumer Keys/API Key and Secret, e Authentication Tokens/Access Token and Secret.

Image description

Image description

Image description

Passo 2 - Open AI API

O segundo passo consiste em gerar a chave de acesso para a sua conta na OpenAI. Ao criar a conta, você receberá um crédito de $5 para realizar testes nas requisições. Posteriormente, será necessário adquirir um plano para ter acesso às APIs públicas.

Com a chave de acesso em mãos, é hora de preparar a requisição para v1/chat/completions.

Image description

Image description

Passo 3 - Preparando o modelo

Antes de iniciarmos a requisição através das API's podemos preparar nosso modelo diretamente no browser em chat.openai.com.
Utilize esse template, em seguida insira as informações do seu jogo, informe detalhes e ajuste diversas vezes até conseguir um resultado satisfatório.

Image description

Passo 4 - Postman + OpenAPI

Importe a curl template no Postman, e substitua os valores de:

- API KEY: Chave gerada no passo 2.
- TEMPLATE COM ENCODED: Formate o seu texto de prompt que foi refinado no passo 3 em uma ferramenta online de Escape/Unescape.
- EXEMPLO GERADO NO BROWSER: Informe todos os modelos gerados no browser no passo 3 e que atenderam suas necessidades aqui, sem limites, isso vai ajudar que sua resposta seja refinada e cada vez mais aderente a sua solicitação.
- SUA SOLICITAÇÃO: Aqui não têm segredo! (exemplo: preciso de um tweet, preciso de um tweet em francês, preciso de um tweet em inglês).

Image description

Passo 5 - Postman + Twitter

Importe da collection a requisição api.twitter.com/2/tweets

Substitua os valores gerados no passo 1 na aba Authorization:

- Consumer Key: Chave gerada no grupo Consumer Keys/API Key and Secret
- Consumer Secret: Chave gerada no grupo Consumer Keys/API Key and Secret
- Access Token: Chave gerada no grupo Authentication Tokens/Access Token and Secret
- Access Token: Chave gerada no grupo Authentication Tokens/Access Token and Secret

Em seguida, preencha o request body com a string de testes mais famosa do mundo: Hello Word e clique em Send.

Quando a mágica acontecer, o seu perfil estará totalmente integrado as API's.

Image description

Image description

Image description

Image description

Passo 6 - Azure AppLogic

Acesse sua conta por meio do Portal Azure e crie um novo aplicativo lógico.

Após implantar o aplicativo, clique na opção de design. Aqui é onde iniciaremos a configuração da recorrência dos tweets.

Selecione 'Blank App Logic / Scheduler / Recurrence'. Na próxima tela, defina o intervalo de tempo desejado. Para este exemplo, como estamos usando camadas gratuitas/trial, recomenda-se configurar a execução entre 6 e 12 horas.

Agora, crie um novo passo do tipo _HTTP _e copie os valores utilizados no Postman, conforme mostrado no passo 4. Neste momento, é importante lembrar de adicionar a autorização de acesso, conforme demonstrado nas imagens abaixo. (Caso tenha dificuldades nesta tarefa, você pode utilizar o arquivo localizado aqui para configurá-la).

A próxima tarefa é do tipo 'Data Operations/Parse Json'. Aqui, precisamos definir a estrutura da resposta da API. Selecione a opção 'Use sample payload to generate schema' para que a estrutura seja mapeada automaticamente.

Com a estrutura de resposta pronta, vamos manipular os dados. Crie uma tarefa do tipo 'Control/For each', selecionando o nó 'choices' (aqui estão os campos que precisamos). Em seguida, crie uma tarefa do tipo _'Control/Condition' e valide se o campo 'message' está preenchido ou não.

Caso o campo não esteja preenchido, não é necessário fazer nada. No entanto, você pode ajustar essa tarefa: refazer os passos, enviar um e-mail ou enviar um tweet pré-definido. A escolha do que fazer nesse fluxo depende do seu desejo/necessidade. No meu caso, simplesmente encerro a execução.

Se o campo 'message' estiver preenchido corretamente, o último passo é enviar a requisição para a API do Twitter. Crie uma nova tarefa do tipo _HTTP _e preencha os mesmos valores utilizados no passo 5 (configuração da tarefa aqui, caso necessário). Não se esqueça de preencher os valores de autenticação.

Image description

Image description

Image description

Image description

Image description

Image description

Image description

Image description

Image description

Passo 7 - Testes

Para testar sua aplicação, basta selecionar a opção _'Run Trigger' _e acompanhar o log de execuções para verificar o status. Em caso de sucesso na execução, basta acessar seu perfil no Twitter para ver a atualização.

Lembre-se de que, de acordo com o tempo configurado no passo 6, você terá uma nova postagem!

Importante:

  • Talvez seja necessário continuar refinando seu modelo, incluindo novas informações e ajustando os valores de temperatura, top_p, frequency_penalty, presence_penalty e max_tokens. Para entender esses parâmetros, basta acessar a documentação da OpenAPI, testá-los no Postman e, em seguida, atualizar sua tarefa de HTTP no passo 6.

Image description

Image description

Passo 8 - Considerações finais

Neste artigo, procurei detalhar os passos para que pessoas não desenvolvedoras ou sem familiaridade com ambientes em nuvem ou linguagens de programação também possam configurar as tarefas com facilidade!

Se você quiser saber mais detalhes sobre o jogo The Agent - A Role Playing Game e sua evolução, pode encontrá-los aqui, aqui ou aqui.

E para acompanhar nossos tweets, pode seguir nossa página aqui.

Image description

Além disso, caso surjam dúvidas durante o processo, fique à vontade para entrar em contato. Estou disponível para ajudar e esclarecer qualquer questão que possa surgir.

Espero que este guia detalhado seja útil para manter a comunidade de jogos independentes engajada e atualizada com as novidades. 🎮

Juntos, podemos impulsionar o crescimento e o sucesso dessa comunidade apaixonada! 😍 ❤️

Abraços!

Top comments (0)