Skip to content

Platform for managing incoming ERASMUS students at ETSIT UPM

License

Notifications You must be signed in to change notification settings

ging/ETSIT-erasmus

Repository files navigation

ETSIT-erasmus

Codacy Badge

Application for managing the registration process of incoming students at ETSIT-UPM. Currently working towards supporting the eIDAS specification.

Installation

This is a step-by-step guide on how to install the ETSIT-erasmus application from scratch. If you already have rails installed, you can skip the first part. There is a comprehensive guide for each one of the three main operating systems.

Ubuntu

sudo apt-get install git

Install rbenv from https://github.com/rbenv/rbenv and ruby-build as plugin

git clone https://github.com/rbenv/rbenv.git ~/.rbenv
echo 'export PATH="$HOME/.rbenv/bin:$PATH"' >> ~/.bashrc
~/.rbenv/bin/rbenv init
echo 'eval "$(rbenv init -)"' >> ~/.bashrc

Reboot terminal

mkdir -p "$(rbenv root)"/plugins
git clone https://github.com/rbenv/ruby-build.git "$(rbenv root)"/plugins/ruby-build

Reboot terminal

sudo apt-get install -y libssl-dev libreadline-dev zlib1g-dev
rbenv install 2.5.1
rbenv use 
gem install bundler
sudo apt-get install postgresql postgresql-contrib libpq-dev
bundle install

Create user and give ownership as in config/database.yml

sudo -u postgres psql (to enter in the postgreSQL console)  
CREATE ROLE loguser WITH CREATEDB LOGIN PASSWORD 'password';

Now, execute the following command in the postgreSQL console to make your user superuser. This way, the 'loguser' user will have access rights to the databases.

ALTER USER loguser WITH superuser;

Afterwards, we create the databases needed.

CREATE DATABASE logapp_dev OWNER loguser;
CREATE DATABASE logapp_prod OWNER loguser;
CREATE DATABASE logapp_test OWNER loguser;
\q (exit from postgreSQL console)

Windows

Download ruby version 2.5.1 for your system in https://rubyinstaller.org/downloads/

Download postgres version 9.6 in https://www.postgresql.org/download/windows/ Configure new role as in database.yml

Install rails:

gem install rails -v 5.2.0

In the instalation folder do:

bundle install
bundle exec rake db:migrate
rails s

MacIntosh

brew install git

Install rbenv from https://github.com/rbenv/rbenv and ruby-build as plugin

brew install rbenv
~/.rbenv/bin/rbenv init
echo 'eval "$(rbenv init -)"' >> ~/.bashrc
rbenv install 2.5.1
rbenv global 2.5.1

Reboot Terminal

brew install postgres
gem install bundler
bundle install

Create user and give ownership as in config/database.yml

sudo -u postgres psql (to enter in the postgreSQL console)  
CREATE ROLE loguser WITH CREATEDB LOGIN PASSWORD 'password';

Now, execute the following command in the postgreSQL console to make your user superuser. This way, the 'loguser' user will have access rights to the databases.

ALTER USER loguser WITH superuser;

Afterwards, we create the databases needed.

CREATE DATABASE logapp_dev OWNER loguser;
CREATE DATABASE logapp_prod OWNER loguser;
CREATE DATABASE logapp_test OWNER loguser;

\q (exit from postgreSQL console)

Running the application

To purge database and recreate:

rake db:drop db:create db:migrate db:populate

Create an admin user:

Use this rake task in order to create an admin user to manage the incoming students

rake db:create_admin [email protected] password=1234

The following files are needed in order to run the project:

  • config/config.yml
  • config/secrets.yml
  • vendor/certs/key.pem
  • vendor/certs/cert.pem
  • vendor/saml2-node/eidas.json

To start rails:

rails s

Open browser on http://localhost:3000/erasmus

About

Platform for managing incoming ERASMUS students at ETSIT UPM

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published