Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/xandao-dev/nlw-valoriza

Next Level Week Node.JS back-end application!
https://github.com/xandao-dev/nlw-valoriza

api express nodejs rocketseat typescript

Last synced: 8 days ago
JSON representation

Next Level Week Node.JS back-end application!

Awesome Lists containing this project

README

        





Logo

NLW Valoriza


NLW Valoriza is a back-end project that serves to compliment your co-workers.
This tool was created at Rocketseat's Next Level Week 6 event.


Explore the docs »




Report Bug
·
Request Feature

Table of Contents



  1. About The Project



  2. Getting Started


  3. Usage

  4. Roadmap

  5. Contributing

  6. License

  7. Contact

  8. Acknowledgements

## About The Project



NLW Together

### Features

* Register coworkers
* Register tags (praise)
* Send compliments to coworkers

### Built With

* [node.js](https://nodejs.org/) - evented I/O for the backend with JS
* [Express](https://expressjs.com/) - fast web framework for node.js
* [TypeORM](https://typeorm.io/#/) - Object Relational Model framework to work easily with databases
* [PostgreSQL](https://www.postgresql.org/) - Advanced Open Source Relational Database. We migrated from `sqlite3` to `PostgreSQL`.

### Business Rules

- User registration

- [x] It's not allowed to register an user with same email
- [x] It's not allowed to register an user without email
- [ ] It's not allowed to register an user with invalid/disposable email
- [x] It's not allowed to create an admin user directly
- User password:
- [x] Should not be empty
- [x] Should be encrypted when it goes to database
- [ ] Should have a minimum of 8 characters
- [ ] Should have letters and numbers

- User update

- [x] It's not allowed to turn a user into admin if you are not an admin
- [ ] It's not allowed to edit a user other than yourself if you are not an admin

- Tag registration

- [x] Is not allowed to register a tag with same name
- [x] Is not allowed to register a tag without name
- [x] Is not allowed registrations from non admin users

- Compliments registration

- [x] Is not allowed an user to register a tag to himself
- [x] Is not allowed to register a tag to invalid users
- [x] The user must be authenticated in order to register a tag

## Getting Started

To get a local copy up and running follow these simple steps.

### Installation

1. Clone the repo
```sh
git clone https://github.com/xandao-dev/nlw-valoriza.git
```
2. [Install Docker Engine](https://docs.docker.com/engine/install/)
3. [Install Docker Compose](https://docs.docker.com/compose/install/)
4. Build the docker image
```sh
cd nlw-valoriza
docker-compose up -d --build
```
5. Set up a local database
```sh
docker-compose exec back-end-dev /bin/sh
> yarn typeorm migration:run
> exit
```

## Usage

* Start the back-end service
```sh
docker-compose up -d
```
* Stop the back-end service
```sh
docker-compose down
```

## Roadmap

See the [open issues](https://github.com/xandao-dev/nlw-valoriza/issues) for a list of proposed features (and known issues).

## Contributing

Contributions are what make the open source community such an amazing place to be learn, inspire, and create. Any contributions you make are **greatly appreciated**.

NLW Valoriza uses [Trunk Based Development(TBD)](https://trunkbaseddevelopment.com/) workflow and [Conventional Commits](www.conventionalcommits.org)!

1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request

Need a database tool? Try these [DBeaver](https://dbeaver.io/) or [BeeKeeper Studio](https://www.beekeeperstudio.io/)

Want to try the API? Try these [Insomnia](https://insomnia.rest/) or [Postman](https://www.postman.com/)

## License

Distributed under the MIT License. See [LICENSE](./LICENSE.md) for more information.

Free software =)

## Contact

Alexandre Calil - [Linkedin](https://www.linkedin.com/in/xandao-dev/) - [[email protected]](mailto:[email protected])

Project Link: [https://github.com/xandao-dev/nlw-valoriza](https://github.com/xandao-dev/nlw-valoriza)

## Acknowledgements

* [TypeScript](https://www.typescriptlang.org/) - strongly typed JavaScript
* [eslint](https://github.com/eslint/eslint) with [AirBnB config](https://github.com/iamturns/eslint-config-airbnb-typescript) - code quality linter with the opinionated AirBnB config
* [prettier](https://github.com/prettier/prettier) with [eslint plugin](https://github.com/prettier/eslint-plugin-prettier) and [eslint config](https://github.com/prettier/eslint-config-prettier) - formatter linter with eslint integration
* [jsonwebtoken](https://github.com/auth0/node-jsonwebtoken) - Industry standard RFC 7519 method for representing claims securely between two parties.
* [class-transformer](https://github.com/typestack/class-transformer) - Transform plain objects into class instances
* [reflect-metadata](https://github.com/rbuckton/reflect-metadata) - Add metadata in classes with decorators
* [bcryptjs](https://github.com/dcodeIO/bcrypt.js) - Encrypt passwords!
* [cors](https://github.com/expressjs/cors) - Enable Cross Origin Resource Sharing, to communicate with a front-end.
* [dotenv](https://github.com/motdotla/dotenv) - Use environment variables across nodejs
* [express-async-errors](https://github.com/davidbanham/express-async-errors) - Try Catch async errors on express
* [uuid](https://github.com/uuidjs/uuid) - Generate uuids to use in db
* [ts-node](https://github.com/TypeStrong/ts-node) - used to run migrations on production
* [ts-node-dev](https://github.com/wclr/ts-node-dev) - transpile TS and hot reload your app