summaryrefslogtreecommitdiff
path: root/lib/trocla
diff options
context:
space:
mode:
authormh <mh@immerda.ch>2014-06-27 18:59:02 +0200
committermh <mh@immerda.ch>2014-06-27 18:59:02 +0200
commit91b2a47d44069e23192e326890c87c9c9f92dae0 (patch)
treef1d0205dbd02675c95f148263e4f7f54c4d2bd38 /lib/trocla
parent20de208ee827cb451e60705180909ce81eae0127 (diff)
parenteabd41b10fa6da986e7e5ee2e3d93d3f19100c49 (diff)
Merge branch 'charset_option' of https://github.com/tilya/trocla into tilya-charset_option
& simplify charset selection Conflicts: lib/trocla.rb lib/trocla/util.rb
Diffstat (limited to 'lib/trocla')
-rw-r--r--lib/trocla/default_config.yaml1
-rw-r--r--lib/trocla/util.rb32
2 files changed, 20 insertions, 13 deletions
diff --git a/lib/trocla/default_config.yaml b/lib/trocla/default_config.yaml
index f46568f..d4037fd 100644
--- a/lib/trocla/default_config.yaml
+++ b/lib/trocla/default_config.yaml
@@ -2,6 +2,7 @@
options:
random: true
length: 12
+ charset: default
adapter: :YAML
adapter_options:
:file: '/tmp/trocla.yaml'
diff --git a/lib/trocla/util.rb b/lib/trocla/util.rb
index ff7e3ce..78462f5 100644
--- a/lib/trocla/util.rb
+++ b/lib/trocla/util.rb
@@ -2,30 +2,36 @@ require 'securerandom'
class Trocla
class Util
class << self
- def random_str(length=12,shellsafe=:undef)
- if shellsafe
- (1..length).collect{|a| safechars[SecureRandom.random_number(safechars.size)] }.join.to_s
- else
- (1..length).collect{|a| chars[SecureRandom.random_number(chars.size)] }.join.to_s
- end
+ def random_str(length=12, charset='default')
+ _charsets = charsets[charset]
+ (1..length).collect{|a| _charsets[SecureRandom.random_number(_charsets.size)] }.join.to_s
end
def salt(length=8)
- (1..length).collect{|a| normal_chars[SecureRandom.random_number(normal_chars.size)] }.join.to_s
+ (1..length).collect{|a| alphanumeric[SecureRandom.random_number(alphanumeric.size)] }.join.to_s
end
private
+
+ def charsets
+ @charsets ||= {
+ 'default' => chars,
+ 'alphanumeric' => alphanumeric,
+ 'shellsafe' => shellsafe,
+ }
+ end
+
def chars
- @chars ||= normal_chars + special_chars
+ @chars ||= shellsafe + special_chars
end
- def safechars
- @chars ||= normal_chars + shellsafe_chars
+ def shellsafe
+ @chars ||= alphanumeric + shellsafe_chars
end
- def normal_chars
- @normal_chars ||= ('a'..'z').to_a + ('A'..'Z').to_a + ('0'..'9').to_a
+ def alphanumeric
+ @alphanumeric ||= ('a'..'z').to_a + ('A'..'Z').to_a + ('0'..'9').to_a
end
def special_chars
- @special_chars ||= "+*%/()@&=?![]{}-_.,;:".split(//)
+ @special_chars ||= "*()&![]{}-".split(//)
end
def shellsafe_chars
@shellsafe_chars ||= "+%/@=?_.,:".split(//)