Skip to content

DeepBlueRobotics/deep-blue-parts

 
 

Repository files navigation

Deep Blue Parts

Deep Blue Parts is a web-based system for tracking parts through the design and manufacture cycle. It assigns part numbers with which CAD files can be saved to version control and stores information about parts' current manufacturing status.

Deep Blue Parts is written in Ruby using the Sinatra framework and uses MySQL as the backing datastore. Development and production are run on UNIX (OS X and Ubuntu), so there are no guarantees it'll work on Windows, sorry.

Deep Blue Parts is built on Cheesy Parts, a wonderful tool written by Pat Fairbank at Team 254.

Team 199 Specific Features

Our fork differs from 254's in a few ways:

  1. Users can edit their own account settings, including passwords, names, and one of several stylesheets.
  2. Workflow, status options, and other attributes are generally optimized for our team's resources.
  3. Secure file upload is added so that members with edit privileges may upload drawings, documentation, and toolpath files. Each part and assembly carries revision letters that are automatically managed by the program. Lite version control is offered, with the ability to restore previous revisions if user is an administrator.
  4. Slack and Trello integeration is offered, since our team uses both tools for communication and task tracking.
  5. Additional dashboards and reports are offered for use.
  6. DBP has been rewritten for compatibility with bootstrap 4.

Planned Additions

  1. Redesigned ordering interface
  2. Mattermost bot integration
  3. Interface for use of COTS parts in assemblies
  4. Integration with GrabCAD or SW PDM

Deploying using Docker

If you want to test-drive DBP, you can use Docker to quickly set up the server.

Prerequisites:

To run Deep Blue Parts in a container:

  1. Make sure Docker is running.
  2. Populate config.json with parameters for the dev and prod environments. config.json.docker contains all the presets you would need to run with the provided docker-compose.yml. Feel free to change the database, username, and password fields, as long as you do it in both the config and compose files.
  3. Run docker-compose up -d web. This will build and run your Deep Blue Parts server in the background.
  4. Run docker-compose run migrations. This will perform the database migration operations that are needed. You may need to run this more than once if an error occurs.
  5. You're now ready to access the DBP server at localhost:9000!
  6. See the text below the Development instructions to login.
  7. When you want to stop the server, you can do so with docker-compose down.

Development

Prerequisites:

  • Ruby 2.3 and development packages
  • Bundler
  • MySQL and development packages
  • g++ for installation of some dev packages (optional)

To run Deep Blue Parts locally:

  1. Create an empty MySQL database and a user account with full permissions on it.
  2. Populate config.json with the parameters for the development and production environments. Set enable_wordpress_auth to false and members_url to blank; they are used for a single sign-on (SSO) mechanism specific to Team 254. Make sure to add your Slack and Trello API tokens if using those features.
  3. Run bundle install. This will download and install the gems that Deep Blue Parts depends on.
  4. Run bundle exec rake db:migrate. This will run the database migrations to create the necessary tables in MySQL.
  5. Run ruby parts_server_control.rb <command> to control the running of the Deep Blue Parts server, where <command> can be one of start|stop|run|restart.

The database migration will create an admin account (username "deleteme@team199.org", password "shark-tank") that you can use to first get into the system and create other accounts. It is highly recommended that you delete this account after having created your own admin account.

Uploads are stored in uploads/ and at this time can only be directly managed by logging into your server.

Contributing

If you encounter a bug, please create a GitHub issue and let us know so that we can look into it.

If you have a suggestion for a new feature in Cheesy Parts, create an issue on GitHub or shoot an e-mail to pat@patfairbank.com. Or if you have some Ruby-fu and are feeling adventurous, fork Team 254 and send a pull request. If you are interested in adding to Deep Blue Parts, please contact Matt (@morops) or Cole (@icecube45).

About

Part tracking system forked from Team 254. Developed for 2018 season.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 48.5%
  • CSS 33.1%
  • HTML 10.3%
  • Ruby 8.0%
  • Other 0.1%