./lib/dolt/sinatra/multi_repo_browser.rb in dolt-0.29.0 vs ./lib/dolt/sinatra/multi_repo_browser.rb in dolt-0.30.0
- old
+ new
@@ -1,8 +1,8 @@
# encoding: utf-8
#--
-# Copyright (C) 2012 Gitorious AS
+# Copyright (C) 2012-2013 Gitorious AS
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
@@ -13,95 +13,81 @@
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#++
-require "sinatra/base"
-require "dolt/sinatra/actions"
+require "dolt/sinatra/repo_browser"
require "libdolt/view/multi_repository"
-require "libdolt/view/blob"
-require "libdolt/view/tree"
module Dolt
module Sinatra
- class MultiRepoBrowser < ::Sinatra::Base
+ class MultiRepoBrowser < RepoBrowser
include Dolt::View::MultiRepository
- include Dolt::View::Blob
- include Dolt::View::Tree
- def initialize(lookup, renderer)
- @lookup = lookup
- @renderer = renderer
- super()
+ def self.repo_ref_path_pattern(action)
+ %r{/([^/]+)/#{action}/([^:]+)(?::|%3(?:a|A))(.*)}
end
- not_found { renderer.render("404") }
-
get "/" do
response["Content-Type"] = "text/html"
body(renderer.render(:index, { :repositories => lookup.repositories }))
end
get "/:repo" do
redirect "/#{params[:repo]}/tree/HEAD:"
end
- get "/*/tree/*:*" do
+ get repo_ref_path_pattern('tree') do |repo, ref, path| # "/*/tree/*:*
begin
- repo, ref, path = params[:splat]
dolt.tree(repo, ref, path)
rescue Exception => err
dolt.render_error(err, repo, ref)
end
end
get "/*/tree/*" do
dolt.force_ref(params[:splat], "tree", "HEAD")
end
- get "/*/blob/*:*" do
+ get repo_ref_path_pattern('blob') do |repo, ref, path| # "/*/blob/*:*
begin
- repo, ref, path = params[:splat]
dolt.blob(repo, ref, path)
rescue Exception => err
dolt.render_error(err, repo, ref)
end
end
get "/*/blob/*" do
dolt.force_ref(params[:splat], "blob", "HEAD")
end
- get "/*/raw/*:*" do
+ get repo_ref_path_pattern('raw') do |repo, ref, path| # "/*/raw/*:*
begin
- repo, ref, path = params[:splat]
dolt.raw(repo, ref, path)
rescue Exception => err
dolt.render_error(err, repo, ref)
end
end
get "/*/raw/*" do
dolt.force_ref(params[:splat], "raw", "HEAD")
end
- get "/*/blame/*:*" do
+ get repo_ref_path_pattern('blame') do |repo, ref, path| # "/*/blame/*:*
begin
- repo, ref, path = params[:splat]
dolt.blame(repo, ref, path)
rescue Exception => err
dolt.render_error(err, repo, ref)
end
end
get "/*/blame/*" do
dolt.force_ref(params[:splat], "blame", "HEAD")
end
- get "/*/history/*:*" do
+ get repo_ref_path_pattern('history') do |repo, ref, path| # "/*/history/*:*
begin
- repo, ref, path = params[:splat]
dolt.history(repo, ref, path, (params[:commit_count] || 20).to_i)
rescue Exception => err
dolt.render_error(err, repo, ref)
end
end
@@ -116,24 +102,18 @@
rescue Exception => err
dolt.render_error(err, repo, nil)
end
end
- get "/*/tree_history/*:*" do
+ get repo_ref_path_pattern('tree_history') do |repo, ref, path| # "/*/tree_history/*:*
begin
- repo, ref, path = params[:splat]
dolt.tree_history(repo, ref, path)
rescue Exception => err
dolt.render_error(err, repo, ref)
end
end
private
- attr_reader :repo, :lookup, :renderer
-
- def dolt
- @dolt ||= Dolt::Sinatra::Actions.new(self, lookup, renderer)
- end
def force_ref(args, action, ref)
redirect(args.shift + "/#{action}/#{ref}:" + args.join)
end
end