{"id":17473686,"url":"https://github.com/valms/zipcode-temperature-tracing","last_synced_at":"2026-02-16T23:34:16.257Z","repository":{"id":258082543,"uuid":"872109041","full_name":"valms/zipcode-temperature-tracing","owner":"valms","description":"Part of the Go Postgraduation Labs at FullCycle. Microservices for CEP-based weather info using OpenTelemetry","archived":false,"fork":false,"pushed_at":"2024-10-16T02:35:39.000Z","size":22,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-04-10T05:03:02.019Z","etag":null,"topics":["docker","docker-compose","go","golang","otel-collector","viacep-api","weather-api","zepkin"],"latest_commit_sha":null,"homepage":"","language":"Go","has_issues":true,"has_wiki":null,"has_pages":null,"mirror_url":null,"source_name":null,"license":null,"status":null,"scm":"git","pull_requests_enabled":true,"icon_url":"https://github.com/valms.png","metadata":{"files":{"readme":"README.md","changelog":null,"contributing":null,"funding":null,"license":null,"code_of_conduct":null,"threat_model":null,"audit":null,"citation":null,"codeowners":null,"security":null,"support":null,"governance":null,"roadmap":null,"authors":null,"dei":null,"publiccode":null,"codemeta":null}},"created_at":"2024-10-13T19:54:17.000Z","updated_at":"2024-10-16T02:35:42.000Z","dependencies_parsed_at":"2024-10-17T15:44:01.364Z","dependency_job_id":"39109bad-850e-47b2-8f90-75e0b664c7b3","html_url":"https://github.com/valms/zipcode-temperature-tracing","commit_stats":null,"previous_names":["valms/zipcode-temperature-tracing"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/valms/zipcode-temperature-tracing","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/valms%2Fzipcode-temperature-tracing","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/valms%2Fzipcode-temperature-tracing/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/valms%2Fzipcode-temperature-tracing/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/valms%2Fzipcode-temperature-tracing/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/valms","download_url":"https://codeload.github.com/valms/zipcode-temperature-tracing/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/valms%2Fzipcode-temperature-tracing/sbom","scorecard":null,"host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":279011543,"owners_count":26084963,"icon_url":"https://github.com/github.png","version":null,"created_at":"2022-05-30T11:31:42.601Z","updated_at":"2022-07-04T15:15:14.044Z","status":"online","status_checked_at":"2025-10-12T02:00:06.719Z","response_time":53,"last_error":null,"robots_txt_status":"success","robots_txt_updated_at":"2025-07-24T06:49:26.215Z","robots_txt_url":"https://github.com/robots.txt","online":true,"can_crawl_api":true,"host_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub","repositories_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories","repository_names_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repository_names","owners_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners"}},"keywords":["docker","docker-compose","go","golang","otel-collector","viacep-api","weather-api","zepkin"],"created_at":"2024-10-18T18:06:27.338Z","updated_at":"2025-10-12T14:08:02.795Z","avatar_url":"https://github.com/valms.png","language":"Go","funding_links":[],"categories":[],"sub_categories":[],"readme":"# Rastreamento de Temperatura por CEP\n\nEste projeto faz parte dos Laboratórios de Pós-Graduação em Go da FullCycle. Consiste em microsserviços para obtenção de\ninformações meteorológicas baseadas em CEP, utilizando OpenTelemetry para rastreamento.\n\n## Desafio\n\n### Objetivo\n\nDesenvolver um sistema em Go que receba um CEP, identifica a cidade e retorna o clima atual (temperatura em graus\ncelsius, fahrenheit e kelvin) juntamente com a cidade. Esse sistema deverá implementar OTEL(Open Telemetry) e Zipkin.\n\n### Requisitos - Serviço A (responsável pelo input):\n\n- Receber um input de 8 dígitos via POST, através do schema: `{ \"cep\": \"29902555\" }`\n- Validar se o input é válido (contém 8 dígitos) e é uma STRING\n- Se válido, encaminhar para o Serviço B via HTTP\n- Se inválido, retornar:\n\t- Código HTTP: 422\n\t- Mensagem: \"invalid zipcode\"\n\n### Requisitos - Serviço B (responsável pela orquestração):\n\n- Receber um CEP válido de 8 dígitos\n- Realizar a pesquisa do CEP e encontrar o nome da localização\n- Retornar as temperaturas formatadas em: Celsius, Fahrenheit, Kelvin juntamente com o nome da localização\n\t- Cenários de resposta:\n\t\t- Sucesso:\n\t\t\t- Código HTTP: 200\n\t\t\t- Response Body:\n\t\t  ``` json\n\t\t\t\t  {\n\t\t\t\t\t\"city\": \"São Paulo\",\n\t\t\t\t\t\"temp_C\": 28.5,\n\t\t\t\t\t\"temp_F\": 28.5,\n\t\t\t\t\t\"temp_K\": 28.5\n\t\t\t\t  }\n\t\t  ```\n\t\t- CEP inválido (com formato correto):\n\t\t\t- Código HTTP: 422\n\t\t\t- Mensagem: \"invalid zipcode\"\n\t\t- CEP não encontrado:\n\t\t\t- Código HTTP: 404\n\t\t\t- Mensagem: \"can not find zipcode\"\n\n### Implementação OTEL + Zipkin:\n\n- Implementar tracing distribuído entre Serviço A - Serviço B\n- Utilizar span para medir o tempo de resposta do serviço de busca de CEP e busca de temperatura\n\n## Estrutura do Projeto\n\n```\n.\n├── config\n│   └── otel\n├── serviceA\n├── serviceB\n├── .editorconfig\n├── .gitignore\n├── README.md\n└── docker-compose.yml\n```\n## Pré-requisitos\n\n- Docker\n- Docker Compose\n\n## Como Executar o Projeto em Ambiente de Desenvolvimento\n\n1. Clone o repositório:\n   ```\n   git clone https://github.com/valms/zipcode-temperature-tracing.git\n   cd zipcode-temperature-tracing\n   ```\n\n2. Configure as variáveis de ambiente:\n   Crie um arquivo `.env` no diretório raiz e adicione as seguintes variáveis:\n   ```\n   API_KEY=sua_weather_api_key\n   ```\n   Substitua `sua_weather_api_key` por uma chave API válida do API WeatherAPI.\n\n3. Inicie os serviços usando Docker Compose:\n   ```\n   docker-compose up --build\n   ```\n\n4. Os serviços estarão disponíveis nos seguintes endereços:\n\t- ServiceA: http://localhost:8080\n\t- ServiceB: http://localhost:8081\n\t- Coletor OpenTelemetry: http://localhost:4318 (Exportador OTLP HTTP)\n\n## Uso\n\nPara utilizar o serviço, envie uma requisição POST para o ServiceA com um CEP no corpo da requisição:\n\n```\ncurl -X POST http://localhost:8080 -H \"Content-Type: application/json\" -d '{\"cep\": \"01001000\"}'\n```\n\nO serviço retornará as informações de temperatura para o CEP fornecido.\n\n## Rastreamento\n\nEste projeto utiliza OpenTelemetry para rastreamento distribuído. Você pode visualizar os rastros usando Zipkin.\n\n## Serviços\n\n### ServiceA\n\nPonto de entrada da aplicação. Recebe requisições de CEP, valida-as e as encaminha para o ServiceB.\n\n### ServiceB\n\nRecebe requisições de CEP do ServiceA, busca as informações da cidade e obtém as informações de temperatura.\n\n## Configuração\n\nO diretório `config/otel` contém arquivos de configuração para o Coletor OpenTelemetry.\n\n# Fontes\n\n1. https://opentelemetry.io/docs/languages/go/instrumentation/\n2. https://github.com/open-telemetry/opentelemetry-go/issues/23\n3. https://opentelemetry.io/docs/languages/go/getting-started/\n4. https://stackoverflow.com/questions/72867313/opentelemetry-open-span-in-one-process-and-close-it-in-another\n5. https://opentelemetry.io/docs/concepts/signals/traces/\n","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvalms%2Fzipcode-temperature-tracing","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fvalms%2Fzipcode-temperature-tracing","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fvalms%2Fzipcode-temperature-tracing/lists"}