Skip to content

oysterhr/partner_ruby_sample_app

Repository files navigation

Oyster Embedded Partner API Rails Sample App

This is a Ruby on Rails sample application to demonstrate how to work with Oyster Embedded Partner API. Here's how you can get the project running on your local machine for development and testing purposes.

Prerequisites

Please follow the detailed documentation: Getting Started with Embedded Partners for the required Initial Setup.

Cloning the Repository

First, you'll need to clone the repository to your local machine. Open a terminal and run the following command:

git clone https://github.com/oysterhr/partner-ruby-sample-app.git

cd partner-ruby-sample-app

Setting Up the Environment

Once you have cloned the repository, you'll need to set up the environment variables. You can find an example in the .env.example file. Create a new file named .env in the root directory and copy the contents of .env.example into it.

cp .env.example .env

Then, fill in the values for the following variables:

# .env
OYSTER_CLIENT_ID= # Your Oyster client ID
OYSTER_CLIENT_SECRET= # Your Oyster client secret
OYSTER_AUTHORIZATION_URL= # The authorization URL
OYSTER_REDIRECT_URL= # The redirect URL configured for your Oyster Developer Application.

Installing Dependencies

Next, install the project dependencies by running:

bundle install

Setting Up the Database

The application uses SQLite for the database. To set up the database, run the following command:

bin/rails db:setup

This will create a new SQLite database file in the root directory as specified in the config/database.yml file.

Running the Application

To start the application, run:

bin/rails server

This will start the server on the default port 3000. You can access the application by visiting http://localhost:3000 in your web browser.

Additional Information

  • config/database.yml: This file is used to configure the database settings for different environments (development, test, and production). It uses SQLite as the database adapter and sets up the database file paths for each environment.
  • config/routes.rb: Defines the application's routes. It sets up a health check route, routes for handling OAuth callbacks and token refreshes, a route for partner session management, and the root route.
  • app/controllers/api_auth_controller.rb: Handles OAuth authorization callbacks and token refreshes.
    • #callback action: It receives an authorization code from the OysterHR API, exchanges it for access and refresh tokens, updates the client record with these tokens, and then redirects to the root URL.
    • #refresh_token action: It uses the stored refresh token to request a new access token when the current one expires, updates the client record, and redirects to the root URL.
  • app/controllers/partner_controller.rb: Handles the creation of a session token for a partner.
    • #session action: It finds the client by the client_id, makes a POST request to the OysterHR Embedded API to create a new session using the client's access token, and then redirects to an OysterHR URL with the new session token.
  • app/models/client.rb: Defines the Client model, which has the following fields:
    1. client_id
    2. refresh_token
    3. access_token
  • .env.example: An example file that lists the environment variables required for the application to function. These variables include the client ID, client secret, authorization URL, and the redirect URL for OAuth callbacks.

For further customization and development, refer to the respective files and directories in the project. We have left helpful comments with the files to help explain their respective funcationality.

Notes

  1. Make sure to keep your .env file secure and do not commit it to version control.
  2. Within app/controllers/partner_controller.rb file, after receiving new Session Token, you should redirect to the Oyster Platform via the route: https://app.oysterhr.com/embedded/transfer?token{PLACE THE GENERATE TOKEN HERE}

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published