diff options
author | azul <azul@riseup.net> | 2013-01-04 02:16:05 -0800 |
---|---|---|
committer | azul <azul@riseup.net> | 2013-01-04 02:16:05 -0800 |
commit | d2acd205b3c3f0931ce4c453e67b1ba572ec77e9 (patch) | |
tree | 4a5e21685acb1a96334ece4b33c0322702a76b80 /certs/app/models | |
parent | e6496b0f45cc0b487da7cb35a34b8e79037034c0 (diff) | |
parent | 1f249ecb60ef270278db4c39b78b1cc23425dce6 (diff) |
Merge pull request #12 from leapcode/feature/use-leap_ca-lib
require leap_ca from leap_web_certs to ensure consistency
Diffstat (limited to 'certs/app/models')
-rw-r--r-- | certs/app/models/.gitkeep | 0 | ||||
-rw-r--r-- | certs/app/models/leap_ca/cert.rb | 56 |
2 files changed, 0 insertions, 56 deletions
diff --git a/certs/app/models/.gitkeep b/certs/app/models/.gitkeep deleted file mode 100644 index e69de29..0000000 --- a/certs/app/models/.gitkeep +++ /dev/null diff --git a/certs/app/models/leap_ca/cert.rb b/certs/app/models/leap_ca/cert.rb deleted file mode 100644 index 9d4f15e..0000000 --- a/certs/app/models/leap_ca/cert.rb +++ /dev/null @@ -1,56 +0,0 @@ -# -# Model for certificates stored in CouchDB. -# -# This file must be loaded after Config has been loaded. -# - -module LeapCA - class Cert < CouchRest::Model::Base - -# No config yet. use_database LeapCA::Config.db_name - use_database 'client_certificates' - - timestamps! - - property :key, String # the client private RSA key - property :cert, String # the client x509 certificate, signed by the CA - property :valid_until, Time # expiration time of the client certificate - property :random, Float, :accessible => false # used to help pick a random cert by the webapp - - before_validation :set_random, :on => :create - - validates :key, :presence => true - validates :cert, :presence => true - validates :random, :presence => true - validates :random, :numericality => {:greater_than => 0, :less_than => 1} - - design do - view :by_random - end - - def set_random - self.random = rand - end - - class << self - def sample - self.by_random.startkey(rand).first || self.by_random.first - end - - def pick_from_pool - cert = self.sample - raise RECORD_NOT_FOUND unless cert - cert.destroy - return cert - rescue RESOURCE_NOT_FOUND - retry if self.by_random.count > 0 - raise RECORD_NOT_FOUND - end - - def valid_attributes_hash - {:key => "ABCD", :cert => "A123"} - end - end - - end -end |