{"id":25583808,"url":"https://github.com/joschonarth/instabytes-server","last_synced_at":"2026-04-17T08:03:59.238Z","repository":{"id":264456551,"uuid":"892847441","full_name":"joschonarth/instabytes-server","owner":"joschonarth","description":"📸 InstaBytes is a Node.js-powered API simulating Instagram, featuring automated image descriptions using Google Gemini, MongoDB Atlas for cloud-based data storage, and hosting on Google Cloud.","archived":false,"fork":false,"pushed_at":"2024-11-27T19:31:59.000Z","size":2979,"stargazers_count":0,"open_issues_count":0,"forks_count":0,"subscribers_count":1,"default_branch":"main","last_synced_at":"2025-06-02T10:21:38.267Z","etag":null,"topics":["google-cloud","google-gemini","javascript","mondodb","mongodb-atlas","nodejs"],"latest_commit_sha":null,"homepage":"","language":"JavaScript","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/joschonarth.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,"zenodo":null}},"created_at":"2024-11-22T22:30:03.000Z","updated_at":"2025-02-19T23:13:22.000Z","dependencies_parsed_at":null,"dependency_job_id":"f786c96a-1f76-4db7-b33c-c28e0450c6ce","html_url":"https://github.com/joschonarth/instabytes-server","commit_stats":null,"previous_names":["joschonarth/instabytes-server"],"tags_count":0,"template":false,"template_full_name":null,"purl":"pkg:github/joschonarth/instabytes-server","repository_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/joschonarth%2Finstabytes-server","tags_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/joschonarth%2Finstabytes-server/tags","releases_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/joschonarth%2Finstabytes-server/releases","manifests_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/joschonarth%2Finstabytes-server/manifests","owner_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/owners/joschonarth","download_url":"https://codeload.github.com/joschonarth/instabytes-server/tar.gz/refs/heads/main","sbom_url":"https://repos.ecosyste.ms/api/v1/hosts/GitHub/repositories/joschonarth%2Finstabytes-server/sbom","host":{"name":"GitHub","url":"https://github.com","kind":"github","repositories_count":263905741,"owners_count":23527972,"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","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":["google-cloud","google-gemini","javascript","mondodb","mongodb-atlas","nodejs"],"created_at":"2025-02-21T06:18:50.916Z","updated_at":"2026-04-17T08:03:59.190Z","avatar_url":"https://github.com/joschonarth.png","language":"JavaScript","funding_links":[],"categories":[],"sub_categories":[],"readme":"# 📸 InstaBytes API\n\nBem-vindo ao **InstaBytes**, uma API desenvolvida em Node.js que simula uma aplicação no estilo Instagram. A API oferece suporte para criar e gerenciar posts, fazer upload de imagens, e atualizar imagens já enviadas. Além disso, utiliza o **Google Gemini** para gerar descrições automáticas das imagens postadas, proporcionando uma experiência inovadora. 🌟\n\n---\n\n## ⚙️ Funcionalidades\n\n- 📃 **Listar posts**: Exibe todos os posts cadastrados na aplicação.\n- ➕ **Criar post**: Permite criar novos posts com título e descrição.\n- 📤 **Upload de imagens**: Permite fazer o upload de imagens associadas aos posts.\n- ✏️ **Atualizar post com IA**: Utiliza o **Google Gemini** para gerar descrições inteligentes e detalhadas das imagens postadas.\n- 🌐 **Conexão em nuvem**: Hospedagem e banco de dados totalmente integrados ao Google Cloud e MongoDB Atlas.\n\n---\n\n## 🛠️ Tecnologias Utilizadas\n\n- 🟡 **JavaScript**: Linguagem de programação utilizada no desenvolvimento da aplicação.\n- 🟢 **Node.js**: Plataforma de execução do JavaScript no servidor.\n- 🗄️ **MongoDB**: Banco de dados não relacional para armazenar informações dos posts.\n- ☁️ **MongoDB Atlas**: Serviço em nuvem para hospedagem do banco de dados MongoDB.\n- 🤖 **Google Gemini**: Ferramenta para geração automática de descrições das imagens postadas.\n- 🌐 **Google Cloud**: Plataforma de hospedagem da aplicação.\n---\n\n## 🔗 Rotas Disponíveis\n\n### 📃 1. Listar Todos os Posts\n- **Descrição**: Retorna uma lista com todos os posts cadastrados.\n- **Método**: `GET`\n- **Endpoint**: `/posts`\n\n### ➕ 2. Criar um Novo Post\n- **Descrição**: Cria um novo post.  \n- **Método**: `POST`\n- **Endpoint**: `/posts`\n- **Exemplo de requisição:**\n\n```json\n{\n    \"descricao\": \"Gato fazendo Post\",\n    \"imgUrl\": \"https://placecats.com/millie/300/150\",\n    \"alt\": \"Gato fazendo Post\"   \n}\n```\n\n### 📤 3. Fazer Upload de uma Imagem\n\n- **Descrição**: Faz o upload de uma imagem.  \n- **Método**: `POST`\n- **Endpoint**: `/posts/upload`\n- **Header**: `Content-Type: multipart/form-data`\n\n### ✏️ 4. Atualizar uma Imagem\n\n- **Descrição**: Atualiza a imagem de um post existente e utiliza o **Google Gemini** para gerar automaticamente uma descrição baseada no conteúdo da nova imagem.  O `id` deve ser substituído pelo identificador do post.  \n- **Método**: `PUT`\n- **Endpoint**: `/posts/upload/:id`\n\n---\n\n## ⚙️ Configuração do Projeto\n\n### 📝 Pré-requisitos\n- 🟡 **JavaScript** habilitado no ambiente de desenvolvimento.\n- 🟢 **Node.js** instalado (v20 ou superior de preferência).\n- 🗄️ Conta no **MongoDB Atlas**.\n- ☁️ Conta no **Google Cloud** e acesso ao **Google Gemini**.\n\n### 🟢 Instalação do Node.js\n1. 🌐 Acesse o site oficial do Node.js: [https://nodejs.org/](https://nodejs.org/).  \n2. 📥 Baixe a versão recomendada para o seu sistema operacional.  \n3. 🖥️ Instale o Node.js seguindo os passos do instalador.  \n4. ✅ Verifique a instalação no terminal:  \n    ```bash\n    node -v\n    npm -v\n    ```\n### 🗄️ Configuração do MongoDB Atlas\n\n1. 🌐 **Acesse o MongoDB Atlas**  \n   - Vá para [MongoDB Atlas](https://www.mongodb.com/cloud/atlas) e crie uma conta, caso ainda não tenha.\n\n2. ➕ **Crie um Cluster**  \n   - Clique em **Create a Cluster** e siga os passos recomendados.  \n   - Escolha a região mais próxima para melhor desempenho.\n\n3. 📂 **Configure uma Database e Collection**  \n   - Acesse o cluster criado e vá para **Database** \u003e **Browse Collections**.  \n   - Clique em **Add My Own Data** e insira:  \n     - **Database Name**: `instabytes`  \n     - **Collection Name**: `posts`\n\n4. 🔑 **Gere a String de Conexão**  \n   - Vá em **Database Access** e crie um usuário com permissões de leitura e escrita.  \n   - Em **Network Access**, adicione o IP global (`0.0.0.0/0`) ou especifique os IPs confiáveis.  \n   - Copie a **string de conexão** fornecida, no formato:  \n     ```\n     mongodb+srv://\u003cusername\u003e:\u003cpassword\u003e@cluster0.mongodb.net/?retryWrites=true\u0026w=majority\n     ```\n   - Substitua `\u003cusername\u003e` e `\u003cpassword\u003e` pelos dados do usuário criado.  \n\n5. 🔗 **Integração com a Aplicação**  \n   - Insira a string de conexão no arquivo `.env` do projeto:  \n     ```env\n     MONGO_URI=mongodb+srv://\u003cusername\u003e:\u003cpassword\u003e@cluster0.mongodb.net/instabytes?retryWrites=true\u0026w=majority\n     ```\n\n### 🚀 Como Executar Localmente\n\n1. 🖥️ Clone este repositório:\n\n```bash\ngit clone https://github.com/joschonarth/instabytes-server.git\ncd instabytes-server\n```\n\n2. 📦 Instale as dependências:\n\n```bash\nnpm install\n```\n\n3. 🔑 Configure as variáveis de ambiente no arquivo `.env`:\n\n```bash\nSTRING_CONEXAO = sua-conexao-do-mongo-atlas\nGEMINI_API_KEY = sua-chave-api-do-google-gemini\n```\n\n4. ▶️ Inicie o servidor:\n\n```bash\nnpm run dev\n```\n\n5. 🌐 Acesse a API em [http://localhost:3000](http://localhost:3000).\n\n---\n\n## 🌐 Frontend do Projeto\n\nO código do frontend para a aplicação **InstaBytes** pode ser encontrado em um repositório separado. Este repositório contém a interface que consome a API desenvolvida no backend, permitindo a interação com os posts e o upload de imagens.\n\n- **Repositório Frontend**: [InstaBytes Frontend - GitHub](https://github.com/joschonarth/instabytes-web)\n\n---\n\n## 📚 Documentações e Links Importantes\n\nAqui estão alguns links úteis para ajudar no desenvolvimento e configuração do projeto:\n\n- 🟢 **Node.js**  \n  [Site Oficial](https://nodejs.org/) | [Documentação](https://nodejs.org/en/docs/)\n\n- 📦 **npm (Node Package Manager)**  \n  [Site Oficial](https://www.npmjs.com/) | [Documentação](https://docs.npmjs.com/)\n\n- 🗄️ **MongoDB**  \n  [Site Oficial](https://www.mongodb.com/) | [Documentação](https://www.mongodb.com/docs/)\n\n- ☁️ **MongoDB Atlas**  \n  [Site Oficial](https://www.mongodb.com/cloud/atlas) | [Guia de Introdução](https://www.mongodb.com/docs/atlas/getting-started/)\n\n- 🖼️ **Google Gemini**  \n  [Página Oficial](https://gemini.google.com/app) | [Gemini API](https://ai.google.dev/gemini-api/docs)\n\n- 🌐 **Google Cloud**  \n  [Site Oficial](https://cloud.google.com/) | [Documentação](https://cloud.google.com/docs)\n\n---\n\n## 🤝 Contribuição\n\n🙌 Sinta-se à vontade para contribuir com melhorias para o projeto. Faça um fork, crie uma nova branch para suas alterações e envie um pull request.\n\n## 📞 Contato\n\n\u003cdiv\u003e\n    \u003ca href=\"https://www.linkedin.com/in/joschonarth/\" target=\"_blank\"\u003e\u003cimg src=\"https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge\u0026logo=linkedin\u0026logoColor=white\" target=\"_blank\"\u003e\u003c/a\u003e\n    \u003ca href=\"mailto:joschonarth@gmail.com\" target=\"_blank\"\u003e\u003cimg src=\"https://img.shields.io/badge/Gmail-D14836?style=for-the-badge\u0026logo=gmail\u0026logoColor=white\" target=\"_blank\"\u003e\u003c/a\u003e\n\u003c/div\u003e","project_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjoschonarth%2Finstabytes-server","html_url":"https://awesome.ecosyste.ms/projects/github.com%2Fjoschonarth%2Finstabytes-server","lists_url":"https://awesome.ecosyste.ms/api/v1/projects/github.com%2Fjoschonarth%2Finstabytes-server/lists"}