mirror of
https://github.com/glitch-soc/mastodon.git
synced 2025-01-19 14:12:54 -05:00
b28ce2424c
Conflicts: - `app/helpers/application_helper.rb`: Upstream added a helper where glitch-soc had its own, not really a conflict. Added upstream's helper. - `lib/sanitize_ext/sanitize_config.rb`: Upstream renamed a constant that was used slightly differently in glitch-soc. Renamed it as upstream did.
78 lines
1.5 KiB
Ruby
78 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Mastodon
|
|
module Version
|
|
module_function
|
|
|
|
def major
|
|
4
|
|
end
|
|
|
|
def minor
|
|
4
|
|
end
|
|
|
|
def patch
|
|
0
|
|
end
|
|
|
|
def default_prerelease
|
|
'alpha.1'
|
|
end
|
|
|
|
def prerelease
|
|
ENV['MASTODON_VERSION_PRERELEASE'].presence || default_prerelease
|
|
end
|
|
|
|
def build_metadata
|
|
['glitch', ENV.fetch('MASTODON_VERSION_METADATA', nil)].compact_blank.join('.')
|
|
end
|
|
|
|
def to_a
|
|
[major, minor, patch].compact
|
|
end
|
|
|
|
def to_s
|
|
components = [to_a.join('.')]
|
|
components << "-#{prerelease}" if prerelease.present?
|
|
components << "+#{build_metadata}" if build_metadata.present?
|
|
components.join
|
|
end
|
|
|
|
def gem_version
|
|
@gem_version ||= Gem::Version.new(to_s.split('+')[0])
|
|
end
|
|
|
|
def api_versions
|
|
{
|
|
mastodon: 2,
|
|
}
|
|
end
|
|
|
|
def repository
|
|
ENV.fetch('GITHUB_REPOSITORY', 'glitch-soc/mastodon')
|
|
end
|
|
|
|
def source_base_url
|
|
ENV.fetch('SOURCE_BASE_URL', "https://github.com/#{repository}")
|
|
end
|
|
|
|
# specify git tag or commit hash here
|
|
def source_tag
|
|
ENV.fetch('SOURCE_TAG', nil)
|
|
end
|
|
|
|
def source_url
|
|
if source_tag
|
|
"#{source_base_url}/tree/#{source_tag}"
|
|
else
|
|
source_base_url
|
|
end
|
|
end
|
|
|
|
def user_agent
|
|
@user_agent ||= "Mastodon/#{Version} (#{HTTP::Request::USER_AGENT}; +http#{Rails.configuration.x.use_https ? 's' : ''}://#{Rails.configuration.x.web_domain}/)"
|
|
end
|
|
end
|
|
end
|