The tech tracker is a specialized web application used internally by Carnegie Mellon University's Activities Board Technical Committee. Its major features are event planning/organization, incoming email management, financial tracking, and membership management (including payroll and timecard generation). It was originally written in ~2003 in perl-style Rails 1.x, and through the years has been taken over and upgraded by various techies.
The current version of Tracker uses Ruby 2.7.5 and Rails 6.1.7. The OS sendmail is used for sending emails, and Sphinx is used for searching events.
Work on large new features should be done in branches and/or forks; smaller changes can be done in master. The production branch should always be deployable.
A Devise configuration file is required for the membership model. One can be generated with the command rails g devise Member. The generated configuration (and therefore, the membership data in the database) may not be compatible with production Tracker. If using a copy of the production database, this may mean you will either have to edit some records with rails c to allow you to log in, or request a copy of the production Devise configuration file. See setup instructions below.
You must install Sphinx if you wish to use the event search feature. You can then generate an index by running the command rails ts:index on the server.
You must install and configure a sendmail provider if you wish to send emails from Tracker.
- Clone the repo and checkout the intended branch.
- Install MySQL.
- Install rbenv and initialize it.
- rbenv install
- gem install bundler(ensure this runs in your rbenv environment)
- rbenv rehash
- RAILS_ENV=development bundle install
- rbenv rehash
- EDITOR=nano ../rbenv/shims/bundle exec rails credentials:edit. If you want to test out email or Slack integrations, then copy in the example at config/credentials/credentials.example.yml and update the values for your specific instance.
- Install Node and Yarn (included in recent versions via corepack).
- yarn install
- RAILS_ENV=development rails assets:precompile
- Create MySQL databases abtt_development_masterandabtt_test. Use an existing user or create a new user and give it access to these databases. Updateconfig/database.ymlto match your local install for both thedevelopmentandtestenvironments. Be sure not to commit this file with your specific environmental changes.
- RAILS_ENV=development rails db:schema:load
- RAILS_ENV=development rails db:seed
- Run the rails console to create an initial user: RAILS_ENV=development rails cMember.create(namefirst: "Sam", namelast: "Abtek", email: "[email protected]", phone: "5555555555", password: "password", password_confirmation: "password", payrate: 0.0, tracker_dev: true) exit 
- Start the development server: RAILS_ENV=development puma
The intended directory structure is as follows. /srv/abtech-tracker may be moved anywhere if you override the systemd service/socket files, and the production-01 and staging-01 may be any name (these are the instance names).
/srv
├── abtech-tracker
│   ├── production-01
│   │   ├── corepack
│   │   ├── pids
│   │   ├── rbenv
│   │   ├── repo
│   │   ├── run
│   │   └── tracker.env
│   └── staging-01
│       ├── corepack
│       ├── pids
│       ├── rbenv
│       ├── repo
│       ├── run
│       └── tracker.env
- Determine an instance name (like production-01) and create the above directory path. Clone into therepofolder and change to that directory.
- Copy tracker.envto the parent ofrepo. Change any variables inside that need to be changed.
- From the repodirectory as root:set -o allexport; source ../tracker.env; set +o allexport
- rbenv install
- ../rbenv/shims/gem install --no-document bundler
- rbenv rehash
- Create a user deploy-abtech-tracker. This user does not needsudo, a home folder, or a default shell.
- Create a MySQL user deploy-abtech-trackerauthenticated via UNIX socket. Create a databaseabtech_tracker_<instance name>. Grant all permissions on the database to the user.
- Now login as the deploy-abtech-trackeruser:sudo -u deploy-abtech-tracker/bin/bash
- As deploy-abtech-tracker: set -o allexport; source ../tracker.env; set +o allexport
- As deploy-abtech-tracker: ../rbenv/shims/bundle config set --local deployment 'true'
- As deploy-abtech-tracker: ../rbenv/shims/bundle install
- As deploy-abtech-tracker: Copy in the production or staging master key and run EDITOR=nano ../rbenv/shims/bundle exec rails credentials:edit --environment production(or staging) and make sure it looks right. Ensure it is up to date with the example at config/credentials/example.yml.
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails db:environment:set RAILS_ENV=production
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails db:create(may already exist)
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails db:schema:load
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails db:seed
- As deploy-abtech-tracker: yarn install
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails assets:precompile
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails ts:index
- As deploy-abtech-tracker: ../rbenv/shims/bundle exec rails cMember.create(namefirst: "Sam", namelast: "Abtek", email: "[email protected]", phone: "5555555555", password: "password", password_confirmation: "password", payrate: 0.0, tracker_dev: true) exit 
- Now as root:
- As root:systemctl start [email protected] [email protected] [email protected] [email protected]
Tracker includes a rake task called email:idle which will connect to a Gmail account and continuously pull email from it in the background. To do so, you need to get a client ID/secret from Google, and generate a refresh token for the Gmail account you want to authenticate with. Note: if you do not use the email:idle task, the following instructions are unnecessary.
- 
Go to the Google APIs console, select "APIs & auth > Credentials", and click Create new Client ID. 
- 
Choose "Installed Application", and then "Other". If you are requested to set up a Consent screen, enter an email address and a product name, and continue. 
- 
Once you have a Client ID and Client secret, download the oauth2.py tool. 
- 
python oauth2.py --generate_oauth2_token --client_id=CLIENT_ID --client_secret=CLIENT_SECRETMake sure to replace CLIENT_ID and CLIENT_SECRET with the appropriate values. 
- 
Among the output will be a value labeled "refresh token". Use this and the client ID and secret to update your secrets file (see the credentials:edittask in the development and deployment instructions above). An example can be found at config/credentials/example.yml.