1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
|
# frozen_string_literal: true
module Jekyll
module GitHubMetadata
class RepositoryCompat
attr_reader :repo
def initialize(repo)
@repo = repo
end
# In enterprise, the site's scheme will be the same as the instance's
# In dotcom, this will be `https` for GitHub-owned sites that end with
# `.github.com` and will be `http` for all other sites.
# Note: This is not the same as *instance*'s scheme, which may differ
def url_scheme
if Pages.enterprise?
Pages.scheme
elsif repo.owner == "github" && domain.end_with?(".github.com")
"https"
else
"http"
end
end
def user_domain
domain = repo.default_user_domain
repo.user_page_domains.each do |user_repo|
candidate_nwo = "#{repo.owner}/#{user_repo}"
next unless Jekyll::GitHubMetadata.client.repository?(candidate_nwo)
domain = Jekyll::GitHubMetadata::Repository.new(candidate_nwo).repo_compat.domain
end
domain
end
def pages_url
return enterprise_url unless Pages.custom_domains_enabled?
if repo.cname || repo.primary?
"#{url_scheme}://#{domain}"
else
URI.join("#{url_scheme}://#{domain}", repo.name).to_s
end
end
alias_method :html_url, :pages_url
def domain
@domain ||=
if !Pages.custom_domains_enabled?
Pages.github_hostname
elsif repo.cname # explicit CNAME
repo.cname
elsif repo.primary? # user/org repo
repo.default_user_domain
else # project repo
user_domain
end
end
def source
{
"branch" => (repo.user_page? ? "master" : "gh-pages"),
"path" => "/",
}
end
private
def enterprise_url
path = repo.user_page? ? repo.owner : repo.nwo
if Pages.subdomain_isolation?
URI.join("#{Pages.scheme}://#{Pages.pages_hostname}/", path).to_s
else
URI.join("#{Pages.github_url}/pages/", path).to_s
end
end
end
end
end
|