mCaptcha/DEVELOPMENT.md
2021-04-11 14:08:14 +05:30

2.6 KiB

Development Setup

Setting up development environment

Toolchain

You'll have to install before you can start writing code.

  1. Install Rust: Install Cargo(Rust toolchain) using rustup with:
$ curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
  1. Install Node: Please refer to official instructions

  2. Install yarn: npm install -g yarn For more details, refer to official instructions

  3. GNU Make: If you are on Linux, it's probably already installed on your machine.

You can check it's existence by running:

$ make --version

If it's not available, you download it with your package manager or refer to official instructions

External Dependencies:

Postgres databse:

The backend requires a Postgres database. We have compiletime SQL checks so without a database available, you won't be able to build the project.

I use Postgres in Docker.

  1. To install Docker, please refer to [official instructions](https://docs.docker.com/engine/install/].

  2. Create create database user:

$ docker create --name mcaptcha-postgres \
	-e POSTGRES_PASSWORD=password \
	-p 5432:5432    postgres
  1. Start database container:
$ docker start mcaptcha-postgres
  1. Set configurations:
$ cd guard # your copy of https://github.com/mCaptcha/guard
$ echo 'export DATABASE_URL="postgres://postgres:password@localhost:5432/postgres"' > .env

NOTE: Don't use this database for other projects

  1. Run migrations: This step is only required when migrations are updated. The server binary has inbuilt migrations manager but that can only be used after the server is compiled. Since we are trying to compile the server here, we can't use that.

However, this project ships with a utility to run migrations!

$ cd guard # your copy of https://github.com/mCaptcha/guard
$ cargo run --bin tests-migrate

That's it, you are all set!

Build commands:

Compile:

$ cd guard # your copy of https://github.com/mCaptcha/guard
$ make

Additional commands:

➜  guard git:(master) ✗ make help
  docs      	- build documentation
  run       	- run developer instance
  test 		- run unit and integration tests
  migrate   	- run database migrations
  dev-env 	- download dependencies
  clean     	- drop builds and environments
  coverage 	- build test coverage in HTML format
  xml-coverage 	- build test coverage in XML for upload to codecov