hackatime/spec/requests/api/v1/authenticated_spec.rb
Tom (Deployor) 8d0215ff0f
feat: added actual api docs (rswag) + ci enforcement (#846)
* feat: add API documentation and CI checks

- Add Rswag for automated API documentation generation
- Add Swagger specs for all endpoints
- Add CI step to enforce that swagger.yaml stays in sync with code
- Add static test keys in seeds.rb for easier testing
- Update AGENTS.md and README.md to support this

* Merge branch 'main' of https://github.com/deployor/hackatime

* Merge branch 'main' into main

* Deprecations! Yay! :)

* It was wan addicent i swear linter! Dont hurt me

* Apply suggestions from code review

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* Copilot..... we love you! Also this project is open and so are api docs meant to be if another AI reads ts!

* Merge branch 'main' of https://github.com/deployor/hackatime

* Merge branch 'main' into main

* Merge branch 'main' into main

* Update app/controllers/api/admin/v1/admin_controller.rb

If you say so

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* Update spec/requests/api/v1/my_spec.rb

I guessss?

Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>

* Failed my own CI wow.... EMBARRASSINGGGG

* Merge branch 'main' into main

* Merge branch 'main' into main

* clarify wording on internal/revoke

* Merge branch 'main' into main

* update swagger docs
2026-01-27 01:05:49 -05:00

205 lines
6.8 KiB
Ruby

require 'swagger_helper'
RSpec.describe 'Api::V1::Authenticated', type: :request do
path '/api/v1/authenticated/me' do
get('Get current user info') do
tags 'Authenticated'
description 'Returns detailed information about the currently authenticated user.'
security [ Bearer: [], ApiKeyAuth: [] ]
produces 'application/json'
response(200, 'successful') do
let(:Authorization) { "Bearer dev-api-key-12345" }
let(:api_key) { "dev-api-key-12345" }
schema type: :object,
properties: {
id: { type: :integer },
emails: { type: :array, items: { type: :string } },
slack_id: { type: :string, nullable: true },
github_username: { type: :string, nullable: true },
trust_factor: {
type: :object,
properties: {
trust_level: { type: :string },
trust_value: { type: :integer }
}
}
}
run_test!
end
response(401, 'unauthorized') do
let(:Authorization) { 'Bearer invalid' }
let(:api_key) { "invalid" }
# schema '$ref' => '#/components/schemas/Error'
run_test!
end
end
end
path '/api/v1/authenticated/hours' do
get('Get hours') do
tags 'Authenticated'
description 'Returns the total coding hours for the authenticated user.'
security [ Bearer: [], ApiKeyAuth: [] ]
produces 'application/json'
parameter name: :start_date, in: :query, type: :string, format: :date, description: 'Start date (YYYY-MM-DD)'
parameter name: :end_date, in: :query, type: :string, format: :date, description: 'End date (YYYY-MM-DD)'
response(200, 'successful') do
let(:Authorization) { "Bearer dev-api-key-12345" }
let(:api_key) { "dev-api-key-12345" }
let(:start_date) { 7.days.ago.to_date.to_s }
let(:end_date) { Date.today.to_s }
schema type: :object,
properties: {
start_date: { type: :string, format: :date, example: '2024-03-13' },
end_date: { type: :string, format: :date, example: '2024-03-20' },
total_seconds: { type: :number, example: 153000.0 }
}
run_test!
end
response(401, 'unauthorized') do
let(:Authorization) { 'Bearer invalid' }
let(:api_key) { "invalid" }
let(:start_date) { 7.days.ago.to_date.to_s }
let(:end_date) { Date.today.to_s }
# schema '$ref' => '#/components/schemas/Error'
run_test!
end
end
end
path '/api/v1/authenticated/streak' do
get('Get streak') do
tags 'Authenticated'
description 'Returns the current streak information (days coded in a row).'
security [ Bearer: [], ApiKeyAuth: [] ]
produces 'application/json'
response(200, 'successful') do
let(:Authorization) { "Bearer dev-api-key-12345" }
let(:api_key) { "dev-api-key-12345" }
schema type: :object,
properties: {
streak_days: { type: :integer, example: 5 }
}
run_test!
end
response(401, 'unauthorized') do
let(:Authorization) { 'Bearer invalid' }
let(:api_key) { "invalid" }
let(:start_date) { 7.days.ago.to_date.to_s }
let(:end_date) { Date.today.to_s }
# schema '$ref' => '#/components/schemas/Error'
run_test!
end
end
end
path '/api/v1/authenticated/projects' do
get('Get projects') do
tags 'Authenticated'
description 'Returns a list of projects associated with the authenticated user.'
security [ Bearer: [], ApiKeyAuth: [] ]
produces 'application/json'
parameter name: :include_archived, in: :query, type: :boolean, description: 'Include archived projects (true/false)'
response(200, 'successful') do
let(:Authorization) { "Bearer dev-api-key-12345" }
let(:api_key) { "dev-api-key-12345" }
let(:include_archived) { false }
schema type: :object,
properties: {
projects: {
type: :array,
items: {
type: :object,
properties: {
name: { type: :string, example: 'hackatime' },
total_seconds: { type: :number, example: 3600.0 },
most_recent_heartbeat: { type: :string, format: :date_time, nullable: true },
languages: { type: :array, items: { type: :string } },
archived: { type: :boolean }
}
}
}
}
run_test!
end
response(401, 'unauthorized') do
let(:Authorization) { 'Bearer invalid' }
let(:api_key) { "invalid" }
let(:include_archived) { false }
# schema '$ref' => '#/components/schemas/Error'
run_test!
end
end
end
path '/api/v1/authenticated/api_keys' do
get('Get API keys') do
tags 'Authenticated'
description 'Returns the API keys for the authenticated user. Warning: This returns sensitive information.'
security [ Bearer: [], ApiKeyAuth: [] ]
produces 'application/json'
response(200, 'successful') do
let(:Authorization) { "Bearer dev-api-key-12345" }
let(:api_key) { "dev-api-key-12345" }
schema type: :object,
properties: {
token: { type: :string, example: 'waka_...' }
}
run_test!
end
response(401, 'unauthorized') do
let(:Authorization) { 'Bearer invalid' }
let(:api_key) { "invalid" }
# schema '$ref' => '#/components/schemas/Error'
run_test!
end
end
end
path '/api/v1/authenticated/heartbeats/latest' do
get('Get latest heartbeat') do
tags 'Authenticated'
description 'Returns the absolutely latest heartbeat processed for the user.'
security [ Bearer: [], ApiKeyAuth: [] ]
produces 'application/json'
response(200, 'successful') do
let(:Authorization) { "Bearer dev-api-key-12345" }
let(:api_key) { "dev-api-key-12345" }
schema type: :object,
properties: {
id: { type: :integer },
created_at: { type: :string, format: :date_time },
time: { type: :number },
category: { type: :string },
project: { type: :string },
language: { type: :string },
editor: { type: :string },
operating_system: { type: :string },
machine: { type: :string },
entity: { type: :string }
}
run_test!
end
response(401, 'unauthorized') do
let(:Authorization) { 'Bearer invalid' }
let(:api_key) { "invalid" }
# schema '$ref' => '#/components/schemas/Error'
run_test!
end
end
end
end