mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
40 lines
910 B
Ruby
40 lines
910 B
Ruby
|
# frozen_string_literal: true
|
||
|
|
||
|
require File.expand_path("../endpoint", __FILE__)
|
||
|
|
||
|
Artifice.deactivate
|
||
|
|
||
|
class EndpointCredsDiffHost < Endpoint
|
||
|
helpers do
|
||
|
def auth
|
||
|
@auth ||= Rack::Auth::Basic::Request.new(request.env)
|
||
|
end
|
||
|
|
||
|
def authorized?
|
||
|
auth.provided? && auth.basic? && auth.credentials && auth.credentials == %w[user pass]
|
||
|
end
|
||
|
|
||
|
def protected!
|
||
|
return if authorized?
|
||
|
response["WWW-Authenticate"] = %(Basic realm="Testing HTTP Auth")
|
||
|
throw(:halt, [401, "Not authorized\n"])
|
||
|
end
|
||
|
end
|
||
|
|
||
|
before do
|
||
|
protected! unless request.path_info.include?("/no/creds/")
|
||
|
end
|
||
|
|
||
|
get "/gems/:id" do
|
||
|
redirect "http://diffhost.com/no/creds/#{params[:id]}"
|
||
|
end
|
||
|
|
||
|
get "/no/creds/:id" do
|
||
|
if request.host.include?("diffhost") && !auth.provided?
|
||
|
File.read("#{gem_repo1}/gems/#{params[:id]}")
|
||
|
end
|
||
|
end
|
||
|
end
|
||
|
|
||
|
Artifice.activate_with(EndpointCredsDiffHost)
|