From e3e9db9509a14032b692597b5134446a5adc137f Mon Sep 17 00:00:00 2001 From: miks Date: Tue, 7 Feb 2012 23:56:53 +0200 Subject: [PATCH 1/2] Allow non-unique deploy keys --- app/models/key.rb | 19 ++++++++++++++++--- 1 file changed, 16 insertions(+), 3 deletions(-) diff --git a/app/models/key.rb b/app/models/key.rb index fb59d759..61c16c14 100644 --- a/app/models/key.rb +++ b/app/models/key.rb @@ -1,3 +1,5 @@ +require 'digest/md5' + class Key < ActiveRecord::Base belongs_to :user belongs_to :project @@ -8,16 +10,24 @@ class Key < ActiveRecord::Base validates :key, :presence => true, - :uniqueness => true, :length => { :within => 0..5000 } before_save :set_identifier after_save :update_repository after_destroy :repository_delete_key + validate :unique_key + + def unique_key + query = 'key = ?' + query << ' AND project_id IS NULL' unless user_id + if (Key.where(query, key.strip).count > 0) + errors.add :key, 'already exist.' + end + end def set_identifier if is_deploy_key - self.identifier = "deploy_#{project.code}_#{Time.now.to_i}" + self.identifier = "deploy_" + Digest::MD5.hexdigest(key) else self.identifier = "#{user.identifier}_#{Time.now.to_i}" end @@ -32,7 +42,10 @@ class Key < ActiveRecord::Base def repository_delete_key Gitlabhq::GitHost.system.new.configure do |c| - c.delete_key(identifier) + #delete key file is there is no identically deploy keys + if !is_deploy_key || Key.where(:identifier => identifier).count() == 0 + c.delete_key(identifier) + end c.update_projects(projects) end end From f5a16663f0b038aeb397bda19ebdefa6ad873955 Mon Sep 17 00:00:00 2001 From: miks Date: Wed, 8 Feb 2012 00:32:20 +0200 Subject: [PATCH 2/2] Improved validation. Strip key. --- app/models/key.rb | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/app/models/key.rb b/app/models/key.rb index 61c16c14..14e191d9 100644 --- a/app/models/key.rb +++ b/app/models/key.rb @@ -13,14 +13,19 @@ class Key < ActiveRecord::Base :length => { :within => 0..5000 } before_save :set_identifier + before_validation :strip_white_space after_save :update_repository after_destroy :repository_delete_key validate :unique_key + def strip_white_space + self.key = self.key.strip + end + def unique_key - query = 'key = ?' - query << ' AND project_id IS NULL' unless user_id - if (Key.where(query, key.strip).count > 0) + query = Key.where('key = ?', key) + query = query.where('(project_id IS NULL OR project_id = ?)', project_id) if project_id + if (query.count > 0) errors.add :key, 'already exist.' end end