Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/andrewhamerly/social-network-api
This repository contains the implementation of a social network API built with MongoDB, Express.js, and Mongoose ODM. This API allows users to share their thoughts, react to friends' thoughts, and create a friend list, providing a backend foundation for a social network web application.
https://github.com/andrewhamerly/social-network-api
express-api express-js expressjs insomnia mongodb mongoose node nodejs nosql nosql-database odm odm-database
Last synced: about 2 months ago
JSON representation
This repository contains the implementation of a social network API built with MongoDB, Express.js, and Mongoose ODM. This API allows users to share their thoughts, react to friends' thoughts, and create a friend list, providing a backend foundation for a social network web application.
- Host: GitHub
- URL: https://github.com/andrewhamerly/social-network-api
- Owner: andrewhamerly
- License: mit
- Created: 2024-07-01T19:41:58.000Z (7 months ago)
- Default Branch: main
- Last Pushed: 2024-07-09T18:56:10.000Z (7 months ago)
- Last Synced: 2024-07-09T22:42:02.796Z (7 months ago)
- Topics: express-api, express-js, expressjs, insomnia, mongodb, mongoose, node, nodejs, nosql, nosql-database, odm, odm-database
- Language: JavaScript
- Homepage: https://drive.google.com/file/d/1wtbHc_2JTjLM4eJ-wUGBa--nY75Z_LA8/view?usp=sharing
- Size: 24.4 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Social Network API MongoDB
This repository contains the implementation of a social network API built with MongoDB, Express.js, and Mongoose ODM. This API allows users to share their thoughts, react to friends' thoughts, and create a friend list, providing a backend foundation for a social network web application.## Table of Contents
- [Features](#features)
- [Installation](#installation)
- [Usage](#usage)
- [Walkthrough Video](#walkthrough-video)
- [Technologies Used](#technologies-used)
- [License](#license)
- [Contributing](#contributing)
- [Questions](#questions)## Features
- **User Management**: Create, update, and delete users.
- **Thought Management**: Create, update, and delete thoughts posted by users.
- **Reaction Management**: Add and remove reactions to thoughts.
- **Friend Management**: Add and remove friends from a user's friend list.
- **NoSQL Database**: Uses MongoDB for handling large amounts of unstructured data efficiently.## Installation
1. **Clone the Repository**:
```bash
git clone https://github.com/andrewhamerly/social-network-api.git
```2. **Navigate to the project directory:**
```bash
cd social-network-api
```3. **Install dependencies:**
```bash
npm install
```## Usage
1. **Start the application:**
```bash
npm start
```2. **Testing the API routes:**
Use Insomnia or a similar API client to test the following routes:
### Users
- GET `/api/users` Get all users.
- POST `/api/users` Create a new user.
- PUT `/api/users/:userId` Update a user by ID.
- DELETE `/api/users/:userId` Delete a user by ID.
- POST `/api/users/:userId/friends/:friendId` Add a friend to a user's friend list.
- DELETE `/api/users/:userId/friends/:friendId` Remove a friend from a user's friend list.
### Thoughts
- GET `/api/thoughts` Get all thoughts.
- POST `/api/thoughts` Create a new thought.
- PUT `/api/thoughts/:thoughtId` Update a thought by ID.
- DELETE `/api/thoughts/:thoughtId` Delete a thought by ID.
### Reactions
- POST `/api/thoughts/:thoughtId/reactions` Add a reaction to a thought.
- DELETE `/api/thoughts/:thoughtId/reactions/:reactionId` Remove a reaction from a thought.## Walkthrough Video
[Click here to watch the walkthrough video](https://drive.google.com/file/d/1wtbHc_2JTjLM4eJ-wUGBa--nY75Z_LA8/view?usp=sharing)
## Technologies Used
- **Express.js**: For building the API routes and handling requests.
- **MongoDB**: A NoSQL database chosen for its flexibility and performance with large datasets.
- **Mongoose**: An ODM (Object Data Modeling) library for MongoDB and Node.js, used to define schemas and interact with the database.
- **Insomnia**: Used for testing the API endpoints.## License
This project is licensed under the MIT License. See the [LICENSE](LICENSE) file for details.
## Contributing
Contributions are welcome! Please fork the repository and create a pull request with your changes. For major changes, please open an issue first to discuss what you would like to change.
## Questions
If you have any questions about the project, please feel free to contact me via email at [[email protected]](mailto:[email protected]). You can also find more of my work on [GitHub](https://github.com/andrewhamerly).