This project was generated by Flatlogic Platform.
- 
Frontend: Vue.js 
- 
Backend: NodeJS(TypeORM) 
- 
Database: PostgreSQL 
Please change current folder:
cd backend
yarn install
Copy .env file as a new .env.local. Edit database credentials and anything you need in .env.local file. This file is ignored by git, and won't be uploaded anywhere.
MacOS:
brew install postgres
> if you don’t have ‘brew‘ please install it (https://brew.sh) and repeat step `brew install postgres`.
Ubuntu:
sudo apt update
sudo apt install postgresql postgresql-contrib
Before run and test connection, make sure you have created a database as described in the above configuration. You can use the psql command to create a user and database.
psql postgres --u postgres
Next, type this command for creating a new user with password then give access for creating the database.
postgres-# CREATE ROLE admin WITH LOGIN PASSWORD 'admin_pass';
postgres-# ALTER ROLE admin CREATEDB;
Quit psql then log in again using the new user that previously created.
postgres-# \q
psql postgres -U admin
| Command | Description | 
|---|---|
| yarn build | Compile typescript files into distfolder | 
| yarn start | Run compiled code from distfolder | 
| yarn db:create | Create database | 
| yarn db:drop | Drop database schema | 
Start local development with command below:
yarn dev
To run your code on production server, run several commands:
- 
Compile TS code yarn build
- 
Run compiled code in production mode NODE_ENV=production yarn start
Please change current folder:
cd frontend
The project contains the docker folder and the Dockerfile.
The Dockerfile is used to Deploy the project to Google Cloud.
The docker folder contains a couple of helper scripts:
- 
docker-compose.yml(all our services: web, backend, db are described here)
- 
start-backend.sh(starts backend, but only after the database)
- 
wait-for-it.sh(imported from https://github.com/vishnubob/wait-for-it)To avoid breaking the application, we recommend you don't edit the following files: everything that includes the docker folder and Dokerfile.
- 
Install docker compose (https://docs.docker.com/compose/install/) 
- 
Move to dockerfolder. All next steps should be done from this folder.cd docker
- 
Make executables from wait-for-it.shandstart-backend.sh:chmod +x start-backend.sh && chmod +x wait-for-it.sh
- 
Download dependend projects for services. 
- 
Review the docker-compose.yml file. Make sure that all services have Dockerfiles. Only db service doesn't require a Dockerfile. 
- 
Make sure you have needed ports (see them in ports) available on your local machine.
- 
Start services: 7.1. With an empty database rm -rf data && docker-compose up7.2. With a stored (from previus runs) database data docker-compose up
- 
Check http://localhost:3000 
- 
Stop services: 9.1. Just press Ctr+C
- 
connection refusedThere could be many reasons, but the most common are: 
- 
The port is not open on the destination machine. 
- 
The port is open on the destination machine, but its backlog of pending connections is full. 
- 
A firewall between the client and server is blocking access (also check local firewalls). 
After checking for firewalls and that the port is open, use telnet to connect to the IP/port to test connectivity. This removes any potential issues from your application.
MacOS:
If you suspect that your SSH service might be down, you can run this command to find out:
sudo service ssh status
If the command line returns a status of down, then you’ve likely found the reason behind your connectivity error.
Ubuntu:
Sometimes a connection refused error can also indicate that there is an IP address conflict on your network. You can search for possible IP conflicts by running:
arp-scan -I eth0 -l | grep <ipaddress>
arp-scan -I eth0 -l | grep <ipaddress>
and
arping <ipaddress>
- 
yarn db:createcreates database with the assembled tables (on MacOS with Postgres database)The workaround - put the next commands to your Postgres database terminal: DROP SCHEMA public CASCADE;CREATE SCHEMA public;GRANT ALL ON SCHEMA public TO postgres;GRANT ALL ON SCHEMA public TO public;Afterwards, continue to start your project in the backend directory by running: yarn start