mirror of
https://github.com/inspec/inspec
synced 2025-01-04 01:09:07 +00:00
100 lines
1.8 KiB
Ruby
100 lines
1.8 KiB
Ruby
# encoding: utf-8
|
|
# copyright: 2015, Vulcano Security GmbH
|
|
# author: Christoph Hartmann
|
|
# author: Dominik Richter
|
|
# license: All rights reserved
|
|
|
|
# The file format consists of
|
|
# - username
|
|
# - password
|
|
# - userid
|
|
# - groupid
|
|
# - user id info
|
|
# - home directory
|
|
# - command
|
|
|
|
# usage:
|
|
#
|
|
# describe passwd do
|
|
# its(:usernames) { should eq ['root'] }
|
|
# its(:uids) { should eq [0] }
|
|
# end
|
|
#
|
|
# describe passwd.uid(0) do
|
|
# its(:username) { should eq 'root' }
|
|
# its(:count) { should eq 1 }
|
|
# end
|
|
|
|
require 'utils/parser'
|
|
|
|
class Passwd < Inspec.resource(1)
|
|
name 'passwd'
|
|
desc 'Use the passwd InSpec audit resource to test the contents of /etc/passwd, which contains the following information for users that may log into the system and/or as users that own running processes.'
|
|
example "
|
|
describe passwd.uid(0) do
|
|
its('username') { should eq 'root' }
|
|
its('count') { should eq 1 }
|
|
end
|
|
"
|
|
|
|
include PasswdParser
|
|
|
|
attr_reader :uid
|
|
attr_reader :parsed
|
|
|
|
def initialize(path = nil)
|
|
@path = path || '/etc/passwd'
|
|
@content = inspec.file(@path).content
|
|
@parsed = parse_passwd(@content)
|
|
end
|
|
|
|
# call passwd().uid(0)
|
|
# returns a seperate object with reference to this object
|
|
def uid(uid)
|
|
PasswdUid.new(self, uid)
|
|
end
|
|
|
|
def usernames
|
|
map_data('name')
|
|
end
|
|
|
|
def passwords
|
|
map_data('password')
|
|
end
|
|
|
|
def uids
|
|
map_data('uid')
|
|
end
|
|
|
|
def gids
|
|
map_data('gid')
|
|
end
|
|
|
|
def to_s
|
|
'/etc/passwd'
|
|
end
|
|
|
|
private
|
|
|
|
def map_data(id)
|
|
@parsed.map {|x|
|
|
x[id]
|
|
}
|
|
end
|
|
end
|
|
|
|
# object that hold a specifc uid view on passwd
|
|
class PasswdUid
|
|
def initialize(passwd, uid)
|
|
@passwd = passwd
|
|
@users = @passwd.parsed.select { |x| x['uid'] == uid.to_s }
|
|
end
|
|
|
|
def username
|
|
@users.at(0)['name']
|
|
end
|
|
|
|
def count
|
|
@users.size
|
|
end
|
|
end
|