Project

timedoctor

0.0
No release in over 3 years
Low commit activity in last 3 years
Client for TimeDoctor API
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

~> 1.16
~> 0.1.10
~> 12.3
~> 3.7
~> 0.55.0
~> 0.16.1
~> 3.3

Runtime

~> 0.15.0
 Project Readme

TimeDoctor

Build Status codecov Maintainability

Installation

Add this line to your application's Gemfile:

gem 'timedoctor'

And then execute:

$ bundle

Or install it yourself as:

$ gem install timedoctor

Usage

To get started first you need to register your application and acquire Client ID. Next, you need to build URI for your application to request permission to access user account.

https://webapi.timedoctor.com/oauth/v2/auth?client_id=<YOUR_CLIENT_ID>&response_type=code&state=<STATE>&redirect_uri=<CALLBACK_URI>

Here's breakdown of url parameters: YOUR_CLIENT_ID - Client ID for your application. STATE - random string to validate authentication integrity in callback. CALLBACK_URI - URI to your application endpoint which will be used upon successful authentication.

Make sure that CALLBACK_URI matches URI that you used during registration of Timedoctor application.

When url is visited and permission to access user account is successfuly granted, user will be redirected to CALLBACK_URI that you provided earlier with code and state as parameters.

Optionally, you can validate state value to make sure that it's same as generated previously for this user.

Configuration

To configure Timedoctor application for Rails, create config/initializers/timedoctor.rb with following setup:

TimeDoctor::Config.configure do |config|
  # Required
  config.client_id = '<YOUR_CLIENT_ID>'
  config.client_secret = '<YOUR_CLIENT_SECRET>'
end

Optionally, you can also define callbacks that will be invoked during token acquisition

TimeDoctor::Config.configure do |config|
  ...

  # Invoked when token acquired successfuly
  config.on_token_authorize = lambda do |data, config|
  end

  # Invoked when token acquisition failed
  config.on_token_authorize_error = lambda do |error, config|
  end

  # Invoked when token refresh completed successfuly
  config.on_token_refresh = lambda do |data, config|
    # You may want to use this callback to store updated tokens
    access_token = data[:access_token]
    refresh_token = data[:refresh_token]
  end

  # Invoked when token refresh failed, you may want to notify user here that integration is broken
  config.on_token_refresh_error = lambda do |error, config|
  end
end

Generating access token

To generate access token to work with API you will need to use code that you received as parameter to your callback endpoint:

token = TimeDoctor::Auth.new(
  code: params[:code],
  redirect_uri: 'https://your_app_host/callback'
).fetch_token

After that, you can create client to work directly with Timedoctor API:

client = TimeDoctor::Client.new(
  access_token: token[:access_token],
  refresh_token: token[:refresh_token]
)

Make sure to store access_token and refresh_token somewhere safe for that user, so you can use it later.

Requesting account information

To get account information such as name and company details you can use following command:

account = client.companies.list
puts "Account owner name: #{account[:user][:full_name]}"
puts "Account email: #{account[:user][:email]}"
puts "User ID: #{account[:user][:user_id]}"
puts "Company ID: #{account[:user][:company_id]}"

Requesting worklogs

To request worklogs you will need to provide company_id, start_date and end_date. user_ids can also be used to narrow down returned data. Here's how to get worklogs for user associated with access token for today:

account = client.companies.list
client.worklogs.list(
  company_id: account[:user][:company_id],
  user_ids: account[:user][:user_id],
  start_date: Date.today,
  end_date: Date.today
)

Contributing

Bug reports and pull requests are welcome on GitHub at https://github.com/roonyx/timedoctor. This project is intended to be a safe, welcoming space for collaboration, and contributors are expected to adhere to the Contributor Covenant code of conduct.

License

The gem is available as open source under the terms of the MIT License.

Code of Conduct

Everyone interacting in the TimeDoctor project’s codebases, issue trackers, chat rooms and mailing lists.