Compare commits

..

10 Commits

Author SHA1 Message Date
Geekix
20144b511d
Update config.yml 2021-11-08 12:13:43 +01:00
Geekix
e9b327cc0c
Update config.yml 2021-11-08 11:55:14 +01:00
Geekix
a72f539c23
Update config.yml 2021-11-08 11:21:00 +01:00
Geekix
c8fa6599ff
Update config.yml 2021-11-08 09:36:52 +01:00
Geekix
eba85e08df
Update init.pp 2021-11-08 09:35:14 +01:00
Geekix
6d478b124c
Update config.yml 2021-11-08 09:34:00 +01:00
Geekix
c06708dc91
Update config.yml 2021-11-08 09:33:40 +01:00
Geekix
e24a9aa89a
Update config.yml 2021-11-08 09:29:24 +01:00
Geekix
bd5fbd4cc6
Update config.yml 2021-11-07 11:52:46 +01:00
Geekix
418a817b70 Add .circleci/config.yml 2021-11-06 17:11:44 +01:00
20 changed files with 100 additions and 163 deletions

30
.circleci/config.yml Normal file
View File

@ -0,0 +1,30 @@
version: 2.1
orbs:
ruby: circleci/ruby@1.1.0
node: circleci/node@2
jobs:
verif:
docker:
- image: cimg/ruby:2.7-node
steps:
- checkout
- run :
name: prerequisites
command: bundle install
- run:
name: verif_lint
command: bundle exec rake validate lint
- run:
name: verif_parser
command: puppet parser validate manifests/init.pp
- run:
name: woot
command: bundle exec rake spec
workflows:
version: 2
verif:
jobs:
- verif

View File

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

View File

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

View File

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

View File

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

View File

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

View File

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

34
Gemfile
View File

@ -13,31 +13,21 @@ def location_for(place_or_version, fake_version = nil)
end
end
ruby_version_segments = Gem::Version.new(RUBY_VERSION.dup).segments
minor_version = ruby_version_segments[0..1].join('.')
group :development do
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.5.1', require: false if Gem::Requirement.create(['>= 3.0.0', '< 3.0.5']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
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 "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 "voxpupuli-puppet-lint-plugins", '~> 4.0', require: false
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]
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.3.0', require: false if Gem::Requirement.create(['>= 2.7.0', '< 2.8.0']).satisfied_by?(Gem::Version.new(RUBY_VERSION.dup))
gem "puppet-module-posix-default-r#{minor_version}", '~> 1.0', require: false, platforms: [:ruby]
gem "puppet-module-posix-dev-r#{minor_version}", '~> 1.0', require: false, platforms: [:ruby]
gem "puppet-module-win-default-r#{minor_version}", '~> 1.0', require: false, platforms: [:mswin, :mingw, :x64_mingw]
gem "puppet-module-win-dev-r#{minor_version}", '~> 1.0', require: false, platforms: [:mswin, :mingw, :x64_mingw]
end
group :system_tests do
gem "puppet_litmus", '< 1.0.0', require: false, platforms: [:ruby, :x64_mingw]
gem "serverspec", '~> 2.41', require: false
gem "puppet-module-posix-system-r#{minor_version}", '~> 1.0', require: false, platforms: [:ruby]
gem "puppet-module-win-system-r#{minor_version}", '~> 1.0', require: false, platforms: [:mswin, :mingw, :x64_mingw]
end
puppet_version = ENV['PUPPET_GEM_VERSION']

View File

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

View File

@ -98,7 +98,8 @@
# 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.
#
class nslcd (
class nslcd
(
Variant[Boolean,String[1]] $package_ensure = 'present',
String[1] $package_name = $nslcd::params::package_name,
Boolean $package_manage = true,
@ -108,7 +109,7 @@ class nslcd (
Boolean $service_manage = true,
String[1] $uid = 'nslcd',
String[1] $gid = $nslcd::params::gid,
Stdlib::Unixpath $config = $nslcd::params::config,
Stdlib::Unixpath $config = '/etc/nslcd.conf',
String[1] $config_user = 'root',
String[1] $config_group = $nslcd::params::config_group,
Stdlib::Filemode $config_mode = $nslcd::params::config_mode,
@ -130,7 +131,9 @@ class nslcd (
Optional[Integer] $idle_timelimit = undef,
Integer $reconnect_sleeptime = 1,
Integer $reconnect_retrytime = 10,
) inherits nslcd::params {
)
inherits nslcd::params
{
contain nslcd::install
contain nslcd::config
contain nslcd::service

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@ -1,13 +0,0 @@
# 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

@ -1,13 +0,0 @@
# 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

@ -1,13 +0,0 @@
# 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

@ -1,13 +0,0 @@
# 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

@ -1,13 +0,0 @@
# 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