discourse/db/migrate/20240712050324_default_github_onebox_token.rb
Martin Brennan 97e2b353f6
FEATURE: Allow for multiple GitHub onebox tokens (#27887)
Followup 560e8aff75

GitHub auth tokens cannot be made with permissions to
access multiple organisations. This is quite limiting.
This commit changes the site setting to be a "secret list"
type, which allows for a key/value mapping where the value
is treated like a password in the UI.

Now when a GitHub URL is requested for oneboxing, the
org name from the URL is used to determine which token
to use for the request.

Just in case anyone used the old site setting already,
there is a migration to create a `default` entry
with that token in the new list setting, and for
a period of time we will consider that token valid to
use for all GitHub oneboxes as well.
2024-07-15 13:07:36 +10:00

26 lines
737 B
Ruby

# frozen_string_literal: true
class DefaultGithubOneboxToken < ActiveRecord::Migration[7.1]
def up
existing_token =
DB.query_single(
"SELECT value FROM site_settings WHERE name = 'github_onebox_access_token'",
).first
# 8 is the data type for a list
execute <<~SQL if existing_token.present?
INSERT INTO site_settings (name, data_type, value, created_at, updated_at)
VALUES ('github_onebox_access_tokens', 8, 'default|#{existing_token}', CURRENT_TIMESTAMP, CURRENT_TIMESTAMP)
ON CONFLICT DO NOTHING
SQL
execute <<~SQL
DELETE FROM site_settings WHERE name = 'github_onebox_access_token'
SQL
end
def down
raise ActiveRecord::IrreversibleMigration
end
end