cpe 0.1.0

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,5 @@
1
+ lib/**/*.rb
2
+ bin/*
3
+ -
4
+ features/**/*.feature
5
+ LICENSE.txt
data/Gemfile ADDED
@@ -0,0 +1,13 @@
1
+ source "http://rubygems.org"
2
+ # Add dependencies required to use your gem here.
3
+ # Example:
4
+ # gem "activesupport", ">= 2.3.5"
5
+
6
+ # Add dependencies to develop your gem here.
7
+ # Include everything needed to run rake, tests, features, etc.
8
+ group :development do
9
+ gem "shoulda", ">= 0"
10
+ gem "rdoc", "~> 3.12"
11
+ gem "bundler", "~> 1.0.0"
12
+ gem "jeweler", "~> 1.8.3"
13
+ end
@@ -0,0 +1,20 @@
1
+ Copyright (c) 2012 Chris Wuest
2
+
3
+ Permission is hereby granted, free of charge, to any person obtaining
4
+ a copy of this software and associated documentation files (the
5
+ "Software"), to deal in the Software without restriction, including
6
+ without limitation the rights to use, copy, modify, merge, publish,
7
+ distribute, sublicense, and/or sell copies of the Software, and to
8
+ permit persons to whom the Software is furnished to do so, subject to
9
+ the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be
12
+ included in all copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
15
+ EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
17
+ NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
18
+ LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
19
+ OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
20
+ WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -0,0 +1,19 @@
1
+ = cpe
2
+
3
+ Description goes here.
4
+
5
+ == Contributing to cpe
6
+
7
+ * Check out the latest master to make sure the feature hasn't been implemented or the bug hasn't been fixed yet.
8
+ * Check out the issue tracker to make sure someone already hasn't requested it and/or contributed it.
9
+ * Fork the project.
10
+ * Start a feature/bugfix branch.
11
+ * Commit and push until you are happy with your contribution.
12
+ * Make sure to add tests for it. This is important so I don't break it in a future version unintentionally.
13
+ * Please try not to mess with the Rakefile, version, or history. If you want to have your own version, or is otherwise necessary, that is fine, but please isolate to its own commit so I can cherry-pick around it.
14
+
15
+ == Copyright
16
+
17
+ Copyright (c) 2012 Chris Wuest. See LICENSE.txt for
18
+ further details.
19
+
@@ -0,0 +1,45 @@
1
+ # encoding: utf-8
2
+
3
+ require 'rubygems'
4
+ require 'bundler'
5
+ begin
6
+ Bundler.setup(:default, :development)
7
+ rescue Bundler::BundlerError => e
8
+ $stderr.puts e.message
9
+ $stderr.puts "Run `bundle install` to install missing gems"
10
+ exit e.status_code
11
+ end
12
+ require 'rake'
13
+
14
+ require 'jeweler'
15
+ Jeweler::Tasks.new do |gem|
16
+ # gem is a Gem::Specification... see http://docs.rubygems.org/read/chapter/20 for more options
17
+ gem.name = "cpe"
18
+ gem.homepage = "http://github.com/cwuest/ruby-cpe"
19
+ gem.license = "MIT"
20
+ gem.summary = %Q{Library for parsing and generating CPEs}
21
+ gem.description = %Q{Library for parsing and generating Common Platform Enumeration strings (see http://cpe.mitre.org/)}
22
+ gem.email = "chris@chriswuest.com"
23
+ gem.authors = ["Chris Wuest"]
24
+ # dependencies defined in Gemfile
25
+ end
26
+ Jeweler::RubygemsDotOrgTasks.new
27
+
28
+ require 'rake/testtask'
29
+ Rake::TestTask.new(:test) do |test|
30
+ test.libs << 'lib' << 'test'
31
+ test.pattern = 'test/**/test_*.rb'
32
+ test.verbose = true
33
+ end
34
+
35
+ task :default => :test
36
+
37
+ require 'rdoc/task'
38
+ Rake::RDocTask.new do |rdoc|
39
+ version = File.exist?('VERSION') ? File.read('VERSION') : ""
40
+
41
+ rdoc.rdoc_dir = 'rdoc'
42
+ rdoc.title = "cpe #{version}"
43
+ rdoc.rdoc_files.include('README*')
44
+ rdoc.rdoc_files.include('lib/**/*.rb')
45
+ end
data/VERSION ADDED
@@ -0,0 +1 @@
1
+ 0.1.0
@@ -0,0 +1,58 @@
1
+ # Generated by jeweler
2
+ # DO NOT EDIT THIS FILE DIRECTLY
3
+ # Instead, edit Jeweler::Tasks in Rakefile, and run 'rake gemspec'
4
+ # -*- encoding: utf-8 -*-
5
+
6
+ Gem::Specification.new do |s|
7
+ s.name = "cpe"
8
+ s.version = "0.1.0"
9
+
10
+ s.required_rubygems_version = Gem::Requirement.new(">= 0") if s.respond_to? :required_rubygems_version=
11
+ s.authors = ["Chris Wuest"]
12
+ s.date = "2012-02-24"
13
+ s.description = "Library for parsing and generating Common Platform Enumeration strings (see http://cpe.mitre.org/)"
14
+ s.email = "chris@chriswuest.com"
15
+ s.extra_rdoc_files = [
16
+ "LICENSE.txt",
17
+ "README.rdoc"
18
+ ]
19
+ s.files = [
20
+ ".document",
21
+ "Gemfile",
22
+ "LICENSE.txt",
23
+ "README.rdoc",
24
+ "Rakefile",
25
+ "VERSION",
26
+ "cpe.gemspec",
27
+ "lib/cpe.rb",
28
+ "test/helper.rb",
29
+ "test/test_cpe.rb"
30
+ ]
31
+ s.homepage = "http://github.com/cwuest/ruby-cpe"
32
+ s.licenses = ["MIT"]
33
+ s.require_paths = ["lib"]
34
+ s.rubygems_version = "1.8.10"
35
+ s.summary = "Library for parsing and generating CPEs"
36
+
37
+ if s.respond_to? :specification_version then
38
+ s.specification_version = 3
39
+
40
+ if Gem::Version.new(Gem::VERSION) >= Gem::Version.new('1.2.0') then
41
+ s.add_development_dependency(%q<shoulda>, [">= 0"])
42
+ s.add_development_dependency(%q<rdoc>, ["~> 3.12"])
43
+ s.add_development_dependency(%q<bundler>, ["~> 1.0.0"])
44
+ s.add_development_dependency(%q<jeweler>, ["~> 1.8.3"])
45
+ else
46
+ s.add_dependency(%q<shoulda>, [">= 0"])
47
+ s.add_dependency(%q<rdoc>, ["~> 3.12"])
48
+ s.add_dependency(%q<bundler>, ["~> 1.0.0"])
49
+ s.add_dependency(%q<jeweler>, ["~> 1.8.3"])
50
+ end
51
+ else
52
+ s.add_dependency(%q<shoulda>, [">= 0"])
53
+ s.add_dependency(%q<rdoc>, ["~> 3.12"])
54
+ s.add_dependency(%q<bundler>, ["~> 1.0.0"])
55
+ s.add_dependency(%q<jeweler>, ["~> 1.8.3"])
56
+ end
57
+ end
58
+
@@ -0,0 +1,94 @@
1
+ # = cpe.rb
2
+ #
3
+ # Copyright (c) Chris Wuest <chris@chriswuest.com>
4
+ # Expectr is freely distributable under the terms of an MIT-style license.
5
+ # See LICENSE.txt or http://www.opensource.org/licenses/mit-license.php.
6
+
7
+ # == Description
8
+ # Cpe is a small library built to simplify working with the Common Platform
9
+ # Enumeration spec managed by Mitre. See http://cpe.mitre.org/ for further
10
+ # details.
11
+ #
12
+ # == Examples
13
+ # === Parsing CPE
14
+ #
15
+ # cpe = Cpe.parse "cpe:/o:microsoft:windows_xp:::pro"
16
+ # cpe.vendor # => "microsoft"
17
+ # cpe.to_s # => "cpe:/o:microsoft:windows_xp:::pro:"
18
+ #
19
+ # === Generating CPE string
20
+ # cpe = Cpe.new :part => Cpe::OS
21
+ # cpe.vendor = "microsoft"
22
+ # cpe.product = "windows_xp"
23
+ # cpe.to_s # => "cpe:/o:microsoft:windows_xp::::"
24
+ class Cpe
25
+ # Part type. Can be /o (Cpe::OS), /a (Cpe::Application), /h (Cpe::Hardware)
26
+ attr_accessor :part
27
+ # Vendor
28
+ attr_accessor :vendor
29
+ # Product
30
+ attr_accessor :product
31
+ # Version
32
+ attr_accessor :version
33
+ # Update/patch level
34
+ attr_accessor :update
35
+ # Edition
36
+ attr_accessor :edition
37
+ # Language
38
+ attr_accessor :language
39
+
40
+ #
41
+ # Create a new Cpe object, initializing all relevent variables to known
42
+ # values, or else an empty string. Part must be one of /o, /a, /h or else
43
+ # be nil.
44
+ #
45
+ def initialize args={}
46
+ raise ArgumentError unless args.kind_of? Hash
47
+ raise ArgumentError unless /\/[oah]/.match args[:part].to_s or args[:part].nil?
48
+ @part = args[:part] || ""
49
+ @vendor = args[:vendor] || ""
50
+ @product = args[:product] || ""
51
+ @version = args[:version] || ""
52
+ @update = args[:update] || ""
53
+ @edition = args[:edition] || ""
54
+ @language = args[:language] || ""
55
+ end
56
+
57
+ #
58
+ # Check that at least Part and one other piece of information have been
59
+ # collected, and generate CPE string.
60
+ #
61
+ def to_s
62
+ raise KeyError unless /\/[oah]/.match @part
63
+ raise KeyError if @vendor.to_s.empty? and @product.to_s.empty? and @version.to_s.empty? and @update.to_s.empty? and @edition.to_s.empty? and @language.to_s.empty?
64
+ return ["cpe", @part, @vendor, @product, @version, @update, @edition, @language].join(":").downcase
65
+ end
66
+
67
+ #
68
+ # Parse pre-existing CPE string and return new Cpe object
69
+ #
70
+ # String parsing is permissive regarding the number of trailing colons
71
+ # provided, filling in empty strings if needed.
72
+ #
73
+ # === Bugs
74
+ #
75
+ # * Presently unable to pass File object as input
76
+ #
77
+ def Cpe.parse cpe
78
+ raise ArgumentError unless cpe.kind_of? String
79
+ raise ArgumentError, "CPE malformed" unless /^cpe:\/[hoa]:/.match cpe and !/ /.match cpe
80
+
81
+ data = Hash.new
82
+ discard, data[:part], data[:vendor], data[:product], data[:version],
83
+ data[:update], data[:edition], data[:language] = cpe.split(/:/, 8)
84
+
85
+ return self.new data
86
+ end
87
+ end
88
+
89
+ # Variable for readability for "/o"
90
+ Cpe::OS = "/o"
91
+ # Variable for readability for "/a"
92
+ Cpe::Application = "/a"
93
+ # Variable for readability for "/h"
94
+ Cpe::Hardware = "/h"
@@ -0,0 +1,18 @@
1
+ require 'rubygems'
2
+ require 'bundler'
3
+ begin
4
+ Bundler.setup(:default, :development)
5
+ rescue Bundler::BundlerError => e
6
+ $stderr.puts e.message
7
+ $stderr.puts "Run `bundle install` to install missing gems"
8
+ exit e.status_code
9
+ end
10
+ require 'test/unit'
11
+ require 'shoulda'
12
+
13
+ $LOAD_PATH.unshift(File.join(File.dirname(__FILE__), '..', 'lib'))
14
+ $LOAD_PATH.unshift(File.dirname(__FILE__))
15
+ require 'cpe'
16
+
17
+ class Test::Unit::TestCase
18
+ end
@@ -0,0 +1,45 @@
1
+ require 'helper'
2
+
3
+ # CPE examples borrowed from CPE Spec document ver. 2.2
4
+ class TestCpe < Test::Unit::TestCase
5
+ def setup
6
+ @valid = "cpe:/o:microsoft:windows_xp:::pro"
7
+ @invalid = ["cpe::", "cpe://redhat:enterprise_linux:3::as", "cpe:/o:redhat:Enterprise Linux:3::", ":/o:redhat:enterprise_linux:3", 4]
8
+ end
9
+
10
+ def test_parse_valid
11
+ cpe = Cpe.parse(@valid)
12
+ assert_equal "/o", cpe.part
13
+ assert_equal "microsoft", cpe.vendor
14
+ assert_equal "windows_xp", cpe.product
15
+ assert_equal "", cpe.version
16
+ assert_equal "", cpe.update
17
+ assert_equal "pro", cpe.edition
18
+ assert_equal "", cpe.language
19
+ end
20
+
21
+ def test_parse_invalid
22
+ @invalid.each do |cpe|
23
+ assert_raises(ArgumentError) { Cpe.parse(cpe) }
24
+ end
25
+ end
26
+
27
+ def test_generation
28
+ cpe = Cpe.new :part => Cpe::OS, :vendor => "microsoft", :product => "windows_xp", :edition => "pro"
29
+ assert_equal cpe.to_s, "cpe:/o:microsoft:windows_xp:::pro:"
30
+
31
+ cpe = Cpe.new :part => Cpe::Application, :vendor => "ACME", :product => "Product", :version => "1.0", :update => "update2", :edition => "-", :language => "en-us"
32
+ assert_equal cpe.to_s, "cpe:/a:acme:product:1.0:update2:-:en-us"
33
+
34
+ cpe = Cpe.new :part => Cpe::Hardware, :vendor => "cisco", :product => "router", :version => 3825
35
+ assert_equal cpe.to_s, "cpe:/h:cisco:router:3825:::"
36
+
37
+ assert_raises(ArgumentError) { Cpe.new :part => 2 }
38
+ assert_nothing_raised { Cpe.new }
39
+
40
+ assert_raises(KeyError) { Cpe.new.to_s }
41
+ assert_raises(KeyError) { Cpe.new(:part => Cpe::OS).to_s }
42
+ assert_raises(KeyError) { Cpe.new(:vendor => "redhat").to_s }
43
+ assert_nothing_raised { Cpe.new(:vendor => "redhat", :part => Cpe::OS).to_s }
44
+ end
45
+ end
metadata ADDED
@@ -0,0 +1,105 @@
1
+ --- !ruby/object:Gem::Specification
2
+ name: cpe
3
+ version: !ruby/object:Gem::Version
4
+ version: 0.1.0
5
+ prerelease:
6
+ platform: ruby
7
+ authors:
8
+ - Chris Wuest
9
+ autorequire:
10
+ bindir: bin
11
+ cert_chain: []
12
+ date: 2012-02-24 00:00:00.000000000 Z
13
+ dependencies:
14
+ - !ruby/object:Gem::Dependency
15
+ name: shoulda
16
+ requirement: &11396320 !ruby/object:Gem::Requirement
17
+ none: false
18
+ requirements:
19
+ - - ! '>='
20
+ - !ruby/object:Gem::Version
21
+ version: '0'
22
+ type: :development
23
+ prerelease: false
24
+ version_requirements: *11396320
25
+ - !ruby/object:Gem::Dependency
26
+ name: rdoc
27
+ requirement: &11413360 !ruby/object:Gem::Requirement
28
+ none: false
29
+ requirements:
30
+ - - ~>
31
+ - !ruby/object:Gem::Version
32
+ version: '3.12'
33
+ type: :development
34
+ prerelease: false
35
+ version_requirements: *11413360
36
+ - !ruby/object:Gem::Dependency
37
+ name: bundler
38
+ requirement: &11412000 !ruby/object:Gem::Requirement
39
+ none: false
40
+ requirements:
41
+ - - ~>
42
+ - !ruby/object:Gem::Version
43
+ version: 1.0.0
44
+ type: :development
45
+ prerelease: false
46
+ version_requirements: *11412000
47
+ - !ruby/object:Gem::Dependency
48
+ name: jeweler
49
+ requirement: &11409060 !ruby/object:Gem::Requirement
50
+ none: false
51
+ requirements:
52
+ - - ~>
53
+ - !ruby/object:Gem::Version
54
+ version: 1.8.3
55
+ type: :development
56
+ prerelease: false
57
+ version_requirements: *11409060
58
+ description: Library for parsing and generating Common Platform Enumeration strings
59
+ (see http://cpe.mitre.org/)
60
+ email: chris@chriswuest.com
61
+ executables: []
62
+ extensions: []
63
+ extra_rdoc_files:
64
+ - LICENSE.txt
65
+ - README.rdoc
66
+ files:
67
+ - .document
68
+ - Gemfile
69
+ - LICENSE.txt
70
+ - README.rdoc
71
+ - Rakefile
72
+ - VERSION
73
+ - cpe.gemspec
74
+ - lib/cpe.rb
75
+ - test/helper.rb
76
+ - test/test_cpe.rb
77
+ homepage: http://github.com/cwuest/ruby-cpe
78
+ licenses:
79
+ - MIT
80
+ post_install_message:
81
+ rdoc_options: []
82
+ require_paths:
83
+ - lib
84
+ required_ruby_version: !ruby/object:Gem::Requirement
85
+ none: false
86
+ requirements:
87
+ - - ! '>='
88
+ - !ruby/object:Gem::Version
89
+ version: '0'
90
+ segments:
91
+ - 0
92
+ hash: 3747455494260107595
93
+ required_rubygems_version: !ruby/object:Gem::Requirement
94
+ none: false
95
+ requirements:
96
+ - - ! '>='
97
+ - !ruby/object:Gem::Version
98
+ version: '0'
99
+ requirements: []
100
+ rubyforge_project:
101
+ rubygems_version: 1.8.10
102
+ signing_key:
103
+ specification_version: 3
104
+ summary: Library for parsing and generating CPEs
105
+ test_files: []