-
Notifications
You must be signed in to change notification settings - Fork 55
Passenger Ruby Report App Tutorial
**Note: this is a DRAFT of a tutorial that will be moved to **
TODO
Login to Open OnDemand, click "Develop" and "My Sandbox Apps (Development)". Click "New Product" and "Clone Existing App". We will be starting with an example status app that displays the output of the ps command.
screenshot
- Directory name: quota
- Git remote: https://github.com/OSC/ood-example-ps
- Check "Create new Git Project from this?"
- Click Submit
screenshot
Launch the app by clicking the large blue Launch button and in a new browser window/tab you will see the output of a ps command filtered using grep.
screeenshot
The features of this app include:
- The app uses the custom branded Bootstrap 3 that My Jobs ande ActiveJobs apps use.
- The navbar contains a link back to the dashboard.
- On a request, the app runs a shell command, parses the output, and displays the result in a table.
This serves as a good starting point for any status app to build for OnDemand, because
- the app has the branding matching other OnDemand apps
- all status apps will do something similar on a request to the app:
- get raw data from a shell command or http request
- parse the raw data into an intermediate object representation
- use that intermediate object representation to display the data formatted as a table or graph
Go back to the Dashboard browser window/tab where the quota details page is displayed. Click the Files button to open this app in the File Explorer. Notice the structure of the app. It is a Ruby Passenger app that uses the Sinatra web framework:
-
config.ru
is the entry point for the app (as is for all Ruby Passenger apps) - the
Gemfile
andGemfile.lock
specify the Ruby gem dependencies, and those dependencies are installed in vendor/bundle -
public/
contains static css and js files. everything underpublic/
is automatically served up by NGINX -
views/
contains index.html which is the template for the body of the index page, and thelayout.html
which contains the erb tag<%== yield %>
that is replaced with the rendered contents ofindex.html
Here is part of the config.ru
file that defines a single route for '/':
get '/' do
# Define your variables that will be sent to the view.
@title = "Currently Running OnDemand Passenger Apps"
@command = "ps aux | grep App | grep -v grep"
# Run the command and capture the stdout, stderr, and exit code as separate variables.
stdout_str, stderr_str, status = Open3.capture3(@command)
# Parse the stdout of the command and set the resulting object array to a variable.
@app_processes = parse_ps(stdout_str)
# If there was an error performing the command, set it to an error variable.
@error = stderr_str unless status.success?
# Variables will be available in views/index.erb
erb :index
end
This does 3 things:
- Sets several instance variables for things like the title and the command to run
- Executes a shell command, calls a helper method to parse the output, and sets the resulting array of structs to an instance variable
- Renders the
views/index.erb
which makes uses of the instance variables to render the webpage
TODO