diff options
| author | florian <florian@debian-Florian> | 2015-04-24 09:57:15 +0200 | 
|---|---|---|
| committer | root <florian.doublet@hotmail.fr> | 2015-06-03 11:01:13 +0200 | 
| commit | fae1a8e189c1b2fbc6b7463081c682946a4d3ef3 (patch) | |
| tree | d9b991c9187495cf3967d7fee1b2e02c680c068f /lib/oxidized | |
| parent | eb753e2d8c19bd99ea36d8b0f492aaff5bb996bf (diff) | |
add feature about versions and diffs for oxidized-web
Diffstat (limited to 'lib/oxidized')
| -rw-r--r-- | lib/oxidized/nodes.rb | 29 | ||||
| -rw-r--r-- | lib/oxidized/output/git.rb | 78 | 
2 files changed, 105 insertions, 2 deletions
| diff --git a/lib/oxidized/nodes.rb b/lib/oxidized/nodes.rb index cb2fbc5..d25fbe7 100644 --- a/lib/oxidized/nodes.rb +++ b/lib/oxidized/nodes.rb @@ -148,6 +148,35 @@ module Oxidized          end        end      end +     +    public +     +    def version node, group +      with_lock do +        i = find_node_index node +        output = self[i].output.new +        raise Oxidized::NotSupported unless output.respond_to? :fetch +        output.version node, group +      end +    end +     +    def get_version node, group, oid +      with_lock do +        i = find_node_index node +        output = self[i].output.new +        raise Oxidized::NotSupported unless output.respond_to? :fetch +        output.get_version node, group, oid +      end +    end +     +    def get_diff node, group, oid1, oid2 +      with_lock do +        i = find_node_index node +        output = self[i].output.new +        raise Oxidized::NotSupported unless output.respond_to? :fetch +        output.get_diff node, group, oid1, oid2 +      end +    end    end  end diff --git a/lib/oxidized/output/git.rb b/lib/oxidized/output/git.rb index 64497c9..e9d797a 100644 --- a/lib/oxidized/output/git.rb +++ b/lib/oxidized/output/git.rb @@ -2,7 +2,6 @@ module Oxidized  class Git < Output    class GitError < OxidizedError; end    begin -    gem 'rugged', '~> 0.21.0'      require 'rugged'    rescue LoadError      raise OxidizedError, 'rugged not found: sudo gem install rugged' @@ -62,6 +61,81 @@ class Git < Output        'node not found'      end    end +   +  #give a hash of all oid revision for the givin node, and the date of the commit +    def version node, group +      begin +        repo = @cfg.repo +        if group +          repo = File.join File.dirname(repo), group + '.git' +        end +        repo = Rugged::Repository.new repo   +        walker = Rugged::Walker.new(repo) +        walker.sorting(Rugged::SORT_DATE) +        walker.push(repo.head.target) +        i = -1 +        tab  = [] +        walker.each do |commit| +          if commit.diff(paths: [node]).size > 0 +            hash = {} +            hash[:date] = commit.time.to_s  +            hash[:oid] = commit.oid +            tab[i += 1] = hash +          end +        end +        walker.reset +        tab +      rescue +        'node not found' +      end +    end +     +    #give the blob of a specific revision +    def get_version node, group, oid +      begin +        repo = @cfg.repo +        if group && group != '' +          repo = File.join File.dirname(repo), group + '.git' +        end +        repo = Rugged::Repository.new repo  +        repo.blob_at(oid,node).content +      rescue +        'version not found' +      end +    end +     +    #give a hash with the patch of a diff between 2 revision and the stats (added and deleted lines) +    def get_diff node, group, oid1, oid2 +      begin +        repo = @cfg.repo +        diff_commits = nil +        if group && group != '' +          repo = File.join File.dirname(repo), group + '.git' +        end +        repo = Rugged::Repository.new repo  +        commit = repo.lookup(oid1) +        #if the second revision is precised  +        if oid2  +          commit_old = repo.lookup(oid2) +          diff = repo.diff(commit_old, commit) +          diff.each do |patch| +            if /#{node}\s+/.match(patch.to_s.lines.first) +              diff_commits = {:patch => patch.to_s, :stat => patch.stat} +              break +            end +          end +        #else gives the diffs between the first oid and his first parrent +        else +          stat = commit.parents[0].diff(commit).stat +          stat = [stat[1],stat[2]] +          patch = commit.parents[0].diff(commit).patch +          diff_commits = {:patch => patch, :stat => stat} +        end +        diff_commits +      rescue +        'no diffs' +      end +    end    private @@ -109,4 +183,4 @@ class Git < Output      end    end  end -end +end
\ No newline at end of file | 
