Compare commits

...

8 Commits

Author SHA1 Message Date
853f5d60b1 Version bump to v0.5.1 2023-04-02 15:31:02 -04:00
0286f81bbd Fixed some style errors found with puppet-lint 2023-04-02 15:30:41 -04:00
2632cfbe59 Added unit tests to module 2023-04-02 15:25:54 -04:00
40310daf29 Version bump to v0.5.0 2023-03-30 11:45:16 -04:00
658c6520a0 Added FreeBSD support 2023-03-30 11:34:41 -04:00
Geekix
7f59387532
Update CHANGELOG.md 2021-11-07 12:12:08 +01:00
Geekix
92abd87230
Update metadata.json 2021-11-07 12:10:29 +01:00
Geekix
f099b991b4
Update metadata.json
Add missing RHEL support
2021-11-07 12:04:22 +01:00
19 changed files with 165 additions and 72 deletions

View File

@ -13,14 +13,18 @@ https://github.com/microsoft/vscode-dev-containers/tree/v0.140.1/containers/pupp
// Set *default* container specific settings.json values on container create. // Set *default* container specific settings.json values on container create.
"settings": { "settings": {
"terminal.integrated.shell.linux": "/bin/bash" "terminal.integrated.profiles.linux": {
"bash": {
"path": "bash",
}
}
}, },
// Add the IDs of extensions you want installed when the container is created. // Add the IDs of extensions you want installed when the container is created.
"extensions": [ "extensions": [
"puppet.puppet-vscode", "puppet.puppet-vscode",
"rebornix.Ruby" "rebornix.Ruby"
] ],
// Use 'forwardPorts' to make a list of ports inside the container available locally. // Use 'forwardPorts' to make a list of ports inside the container available locally.
"forwardPorts": [], "forwardPorts": [],

View File

@ -5,7 +5,7 @@
"settings": { "settings": {
"terminal.integrated.profiles.linux": { "terminal.integrated.profiles.linux": {
"bash": { "bash": {
"path": "bash", "path": "bash"
} }
} }
}, },

View File

@ -3,4 +3,6 @@
--- ---
fixtures: fixtures:
forge_modules: forge_modules:
# stdlib: "puppetlabs/stdlib" stdlib:
repo: "puppetlabs/stdlib"
ref: "6.0.0"

View File

@ -4,7 +4,7 @@ require:
- rubocop-rspec - rubocop-rspec
AllCops: AllCops:
DisplayCopNames: true DisplayCopNames: true
TargetRubyVersion: '2.4' TargetRubyVersion: '2.5'
Include: Include:
- "**/*.rb" - "**/*.rb"
Exclude: Exclude:

3
.vscode/settings.json vendored Normal file
View File

@ -0,0 +1,3 @@
{
"puppet.editorService.puppet.version": "7.23.0"
}

View File

@ -2,7 +2,13 @@
All notable changes to this project will be documented in this file. All notable changes to this project will be documented in this file.
## 0.4.2 (2021-05-11) ## 0.4.3 (2021-11-07)
### Changed
- Add support for RedHat RHEL in the metadata
## 0.4.2 (2021-11-05)
### Addition ### Addition

34
Gemfile
View File

@ -13,21 +13,31 @@ def location_for(place_or_version, fake_version = nil)
end end
end end
ruby_version_segments = Gem::Version.new(RUBY_VERSION.dup).segments
minor_version = ruby_version_segments[0..1].join('.')
group :development do group :development do
gem "json", '= 2.0.4', require: false if Gem::Requirement.create('~> 2.4.2').satisfied_by?(Gem::Version.new(RUBY_VERSION.dup)) gem "json", '= 2.1.0', require: false if Gem::Requirement.create(['>= 2.5.0', '< 2.7.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
gem "json", '= 2.1.0', require: false if Gem::Requirement.create(['>= 2.5.0', '< 2.7.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup)) gem "json", '= 2.3.0', require: false if Gem::Requirement.create(['>= 2.7.0', '< 3.0.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
gem "json", '= 2.3.0', require: false if Gem::Requirement.create(['>= 2.7.0', '< 2.8.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup)) gem "json", '= 2.5.1', require: false if Gem::Requirement.create(['>= 3.0.0', '< 3.0.5']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
gem "puppet-module-posix-default-r#{minor_version}", '~> 1.0', require: false, platforms: [:ruby] gem "json", '= 2.6.1', require: false if Gem::Requirement.create(['>= 3.1.0', '< 3.1.3']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
gem "puppet-module-posix-dev-r#{minor_version}", '~> 1.0', require: false, platforms: [:ruby] gem "json", '= 2.6.3', require: false if Gem::Requirement.create(['>= 3.2.0', '< 4.0.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
gem "puppet-module-win-default-r#{minor_version}", '~> 1.0', require: false, platforms: [:mswin, :mingw, :x64_mingw] gem "voxpupuli-puppet-lint-plugins", '~> 4.0', require: false
gem "puppet-module-win-dev-r#{minor_version}", '~> 1.0', require: false, platforms: [:mswin, :mingw, :x64_mingw] gem "facterdb", '~> 1.18', require: false
gem "metadata-json-lint", '>= 2.0.2', '< 4.0.0', require: false
gem "puppetlabs_spec_helper", '~> 5.0', require: false
gem "rspec-puppet-facts", '~> 2.0', require: false
gem "codecov", '~> 0.2', require: false
gem "dependency_checker", '~> 0.2', require: false
gem "parallel_tests", '= 3.12.1', require: false
gem "pry", '~> 0.10', require: false
gem "simplecov-console", '~> 0.5', require: false
gem "puppet-debugger", '~> 1.0', require: false
gem "rubocop", '= 1.6.1', require: false
gem "rubocop-performance", '= 1.9.1', require: false
gem "rubocop-rspec", '= 2.0.1', require: false
gem "rb-readline", '= 0.5.5', require: false, platforms: [:mswin, :mingw, :x64_mingw]
end end
group :system_tests do group :system_tests do
gem "puppet-module-posix-system-r#{minor_version}", '~> 1.0', require: false, platforms: [:ruby] gem "puppet_litmus", '< 1.0.0', require: false, platforms: [:ruby, :x64_mingw]
gem "puppet-module-win-system-r#{minor_version}", '~> 1.0', require: false, platforms: [:mswin, :mingw, :x64_mingw] gem "serverspec", '~> 2.41', require: false
end end
puppet_version = ENV['PUPPET_GEM_VERSION'] puppet_version = ENV['PUPPET_GEM_VERSION']

View File

@ -2,10 +2,8 @@
# #
# Manages the nslcd server configuration file # Manages the nslcd server configuration file
# #
class nslcd::config inherits nslcd class nslcd::config inherits nslcd {
{ file {
file
{
$nslcd::config: $nslcd::config:
ensure => file, ensure => file,
owner => $nslcd::config_user, owner => $nslcd::config_user,
@ -13,4 +11,4 @@ class nslcd::config inherits nslcd
mode => $nslcd::config_mode, mode => $nslcd::config_mode,
content => template('nslcd/nslcd.erb'), content => template('nslcd/nslcd.erb'),
} }
} }

View File

@ -98,8 +98,7 @@
# Sets the time after which the LDAP server is considered to be permanently unavailable. # Sets the time after which the LDAP server is considered to be permanently unavailable.
# Once this time is reached retries will be done only once per this time period. # Once this time is reached retries will be done only once per this time period.
# #
class nslcd class nslcd (
(
Variant[Boolean,String[1]] $package_ensure = 'present', Variant[Boolean,String[1]] $package_ensure = 'present',
String[1] $package_name = $nslcd::params::package_name, String[1] $package_name = $nslcd::params::package_name,
Boolean $package_manage = true, Boolean $package_manage = true,
@ -109,7 +108,7 @@ class nslcd
Boolean $service_manage = true, Boolean $service_manage = true,
String[1] $uid = 'nslcd', String[1] $uid = 'nslcd',
String[1] $gid = $nslcd::params::gid, String[1] $gid = $nslcd::params::gid,
Stdlib::Unixpath $config = '/etc/nslcd.conf', Stdlib::Unixpath $config = $nslcd::params::config,
String[1] $config_user = 'root', String[1] $config_user = 'root',
String[1] $config_group = $nslcd::params::config_group, String[1] $config_group = $nslcd::params::config_group,
Stdlib::Filemode $config_mode = $nslcd::params::config_mode, Stdlib::Filemode $config_mode = $nslcd::params::config_mode,
@ -131,14 +130,12 @@ class nslcd
Optional[Integer] $idle_timelimit = undef, Optional[Integer] $idle_timelimit = undef,
Integer $reconnect_sleeptime = 1, Integer $reconnect_sleeptime = 1,
Integer $reconnect_retrytime = 10, Integer $reconnect_retrytime = 10,
) ) inherits nslcd::params {
inherits nslcd::params
{
contain nslcd::install contain nslcd::install
contain nslcd::config contain nslcd::config
contain nslcd::service contain nslcd::service
Class['nslcd::install'] Class['nslcd::install']
-> Class['nslcd::config'] -> Class['nslcd::config']
~> Class['nslcd::service'] ~> Class['nslcd::service']
} }

View File

@ -2,14 +2,10 @@
# #
# Installs the nslcd package. # Installs the nslcd package.
# #
class nslcd::install inherits nslcd class nslcd::install inherits nslcd {
{ if $nslcd::package_manage {
if $nslcd::package_manage package { $nslcd::package_name:
{ ensure => $nslcd::package_ensure,
package
{
$nslcd::package_name:
ensure => $nslcd::package_ensure,
} }
} }
} }

View File

@ -2,27 +2,31 @@
# #
# Sets the default parameters for the nslcd class. # Sets the default parameters for the nslcd class.
# #
class nslcd::params class nslcd::params {
{ case $facts['os']['family'] {
case $::osfamily 'Debian': {
{
'Debian':
{
$package_name = 'nslcd' $package_name = 'nslcd'
$gid = 'nslcd' $gid = 'nslcd'
$config = '/etc/nslcd.conf'
$config_group = 'nslcd' $config_group = 'nslcd'
$config_mode = '0640' $config_mode = '0640'
} }
'RedHat': 'RedHat': {
{
$package_name = 'nss-pam-ldapd' $package_name = 'nss-pam-ldapd'
$gid = 'ldap' $gid = 'ldap'
$config = '/etc/nslcd.conf'
$config_group = 'root' $config_group = 'root'
$config_mode = '0600' $config_mode = '0600'
} }
default: 'FreeBSD': {
{ $package_name = 'nss-pam-ldapd'
fail("The ${module_name} module is not supported on an ${::osfamily} based system.") $gid = 'nslcd'
$config = '/usr/local/etc/nslcd.conf'
$config_group = 'wheel'
$config_mode = '0600'
}
default: {
fail("The ${module_name} module is not supported on an ${facts['os']['family']} based system.")
} }
} }
} }

View File

@ -2,16 +2,12 @@
# #
# Manages the nslcd service. # Manages the nslcd service.
# #
class nslcd::service inherits nslcd class nslcd::service inherits nslcd {
{ if $nslcd::service_manage {
if $nslcd::service_manage service { 'nslcd':
{ ensure => $nslcd::service_ensure,
service enable => $nslcd::service_enable,
{ name => $nslcd::service_name,
'nslcd':
ensure => $nslcd::service_ensure,
enable => $nslcd::service_enable,
name => $nslcd::service_name,
} }
} }
} }

View File

@ -1,16 +1,16 @@
{ {
"name": "geekix-nslcd", "name": "ascendings-nslcd",
"version": "0.4.2", "version": "0.5.1",
"author": "geekix", "author": "ascendings",
"summary": "Installs and configures nslcd.", "summary": "Installs and configures nslcd.",
"license": "Apache-2.0", "license": "Apache-2.0",
"source": "https://github.com/geekix/puppet-nslcd", "source": "https://git.metaunix.net/Metaunix/puppet-nslcd",
"project_page": "https://github.com/geekix/puppet-nslcd", "project_page": "https://git.metaunix.net/Metaunix/puppet-nslcd",
"issues_url": "https://github.com/geekix/puppet-nslcd/issues", "issues_url": "https://git.metaunix.net/Metaunix/puppet-nslcd/issues",
"dependencies": [ "dependencies": [
{ {
"name": "puppetlabs-stdlib", "name": "puppetlabs-stdlib",
"version_requirement": ">= 4.0.0 < 8.1.0" "version_requirement": ">= 6.0.0 < 8.5.0"
} }
], ],
"operatingsystem_support": [ "operatingsystem_support": [
@ -31,6 +31,16 @@
"18.04", "18.04",
"20.04" "20.04"
] ]
},
{
"operatingsystem": "RedHat",
"operatingsystemrelease": [
"7",
"8"
]
},
{
"operatingsystem": "FreeBSD"
} }
], ],
"requirements": [ "requirements": [
@ -46,7 +56,7 @@
"ldap", "ldap",
"authentication" "authentication"
], ],
"pdk-version": "2.2.0", "pdk-version": "2.7.1",
"template-url": "https://github.com/puppetlabs/pdk-templates#main", "template-url": "https://github.com/puppetlabs/pdk-templates#main",
"template-ref": "tags/2.3.0-0-g8aaceff" "template-ref": "heads/main-0-gc6d4446"
} }

2
pdk.yaml Normal file
View File

@ -0,0 +1,2 @@
---
ignore: []

View File

@ -0,0 +1,13 @@
# frozen_string_literal: true
require 'spec_helper'
describe 'nslcd::config' do
on_supported_os.each do |os, os_facts|
context "on #{os}" do
let(:facts) { os_facts }
it { is_expected.to compile.with_all_deps }
end
end
end

View File

@ -0,0 +1,13 @@
# frozen_string_literal: true
require 'spec_helper'
describe 'nslcd::install' do
on_supported_os.each do |os, os_facts|
context "on #{os}" do
let(:facts) { os_facts }
it { is_expected.to compile.with_all_deps }
end
end
end

View File

@ -0,0 +1,13 @@
# frozen_string_literal: true
require 'spec_helper'
describe 'nslcd' do
on_supported_os.each do |os, os_facts|
context "on #{os}" do
let(:facts) { os_facts }
it { is_expected.to compile.with_all_deps }
end
end
end

View File

@ -0,0 +1,13 @@
# frozen_string_literal: true
require 'spec_helper'
describe 'nslcd::params' do
on_supported_os.each do |os, os_facts|
context "on #{os}" do
let(:facts) { os_facts }
it { is_expected.to compile.with_all_deps }
end
end
end

View File

@ -0,0 +1,13 @@
# frozen_string_literal: true
require 'spec_helper'
describe 'nslcd::service' do
on_supported_os.each do |os, os_facts|
context "on #{os}" do
let(:facts) { os_facts }
it { is_expected.to compile.with_all_deps }
end
end
end