Skip to content

Commit

Permalink
Implement support for conf-{available,enabled} as well
Browse files Browse the repository at this point in the history
  • Loading branch information
jay7x committed Dec 22, 2024
1 parent b21e2f7 commit b54d437
Show file tree
Hide file tree
Showing 9 changed files with 191 additions and 19 deletions.
16 changes: 13 additions & 3 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -93,11 +93,12 @@ caddy::vhost { 'example2':
}
```

Use `conf.d` + `sites-available` + `sites-enabled` layout with `config_files` and `vhosts` parameters set:
Use apache-like configuration files layout:

```puppet
class { 'caddy':
config_dir => '/etc/caddy/conf.d',
config_dir => '/etc/caddy/conf-available',
config_enabled_dir => '/etc/caddy/conf-enabled',
vhost_dir => '/etc/caddy/sites-available',
vhost_enable_dir => '/etc/caddy/sites-enabled',
config_files => {
Expand All @@ -120,7 +121,8 @@ class { 'caddy':
Same as above but configured in Hiera:

```yaml
caddy::config_dir: /etc/caddy/conf.d
caddy::config_dir: /etc/caddy/conf-available
caddy::config_enable_dir: /etc/caddy/conf-enabled
caddy::vhost_dir: /etc/caddy/sites-available
caddy::vhost_enable_dir: /etc/caddy/sites-enabled
caddy::config_files:
Expand All @@ -143,6 +145,14 @@ caddy::vhosts:
}
```
You may consider setting following parameters also. This allows
enabling/disabling config files and virtual hosts manually.
```yaml
caddy::purge_config_enable_dir: false
caddy::purge_vhost_enable_dir: false
```
## Reference
The [reference][1] documentation of this module is generated using [puppetlabs/puppetlabs-strings][2].
Expand Down
40 changes: 35 additions & 5 deletions REFERENCE.md
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,8 @@ The following parameters are available in the `caddy` class:
* [`caddyfile_content`](#-caddy--caddyfile_content)
* [`config_dir`](#-caddy--config_dir)
* [`purge_config_dir`](#-caddy--purge_config_dir)
* [`config_enable_dir`](#-caddy--config_enable_dir)
* [`purge_config_enable_dir`](#-caddy--purge_config_enable_dir)
* [`config_files`](#-caddy--config_files)
* [`vhost_dir`](#-caddy--vhost_dir)
* [`purge_vhost_dir`](#-caddy--purge_vhost_dir)
Expand Down Expand Up @@ -384,7 +386,9 @@ Default value: `undef`

Data type: `Stdlib::Absolutepath`

Where to store Caddy configs
Where to store Caddy configs.
Set this to /etc/caddy/conf-available to simulate nginx/apache behavior
(see config_enable_dir also).

Default value: `'/etc/caddy/config'`

Expand All @@ -396,6 +400,23 @@ Whether to purge Caddy config directory.

Default value: `true`

##### <a name="-caddy--config_enable_dir"></a>`config_enable_dir`

Data type: `Optional[Stdlib::Absolutepath]`

Where to load Caddy configs from. Set this parameter to /etc/caddy/conf-enabled
to simulate nginx/apache behavior.

Default value: `undef`

##### <a name="-caddy--purge_config_enable_dir"></a>`purge_config_enable_dir`

Data type: `Boolean`

Whether to purge Caddy enabled config directory.

Default value: `$purge_config_dir`

##### <a name="-caddy--config_files"></a>`config_files`

Data type: `Hash[String[1], Caddy::Config]`
Expand Down Expand Up @@ -490,14 +511,15 @@ The following parameters are available in the `caddy::configfile` defined type:
* [`source`](#-caddy--configfile--source)
* [`content`](#-caddy--configfile--content)
* [`config_dir`](#-caddy--configfile--config_dir)
* [`enable_dir`](#-caddy--configfile--enable_dir)

##### <a name="-caddy--configfile--ensure"></a>`ensure`

Data type: `Enum['present','absent']`
Data type: `Enum['present','enabled','disabled','absent']`

Make the config file either present or absent.
Make the config file either present (same as disabled), enabled, disabled or absent.

Default value: `'present'`
Default value: `'enabled'`

##### <a name="-caddy--configfile--source"></a>`source`

Expand All @@ -523,6 +545,14 @@ Where to store the config file.

Default value: `$caddy::config_dir`

##### <a name="-caddy--configfile--enable_dir"></a>`enable_dir`

Data type: `Optional[Stdlib::Absolutepath]`

Directory to symlink the config config file into (conf-enabled e.g.) if any.

Default value: `$caddy::config_enable_dir`

### <a name="caddy--vhost"></a>`caddy::vhost`

This defined type handles a Caddy virtual host
Expand Down Expand Up @@ -605,7 +635,7 @@ Alias of

```puppet
Struct[{
ensure => Optional[Enum['absent', 'present']],
ensure => Optional[Enum['present','enabled','disabled','absent']],
source => Optional[Stdlib::Filesource],
content => Optional[String[1]],
}]
Expand Down
15 changes: 14 additions & 1 deletion manifests/config.pp
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,17 @@
}
}

# Manage config_enable_dir if defined
if $caddy::config_enable_dir {
file { $caddy::config_enable_dir:
ensure => directory,
owner => $caddy::caddy_user,
group => $caddy::caddy_group,
mode => '0755',
purge => $caddy::purge_config_enable_dir,
recurse => if $caddy::purge_config_enable_dir { true } else { undef },
}
}
# Manage vhost_enable_dir if defined
if $caddy::vhost_enable_dir {
file { $caddy::vhost_enable_dir:
Expand All @@ -58,8 +69,10 @@
$real_source = $caddy::caddyfile_source
$real_content = if $caddy::caddyfile_source { undef } else {
$caddy::caddyfile_content.lest || {
$config_dir = $caddy::config_enable_dir.lest || { $caddy::config_dir }
$vhost_dir = $caddy::vhost_enable_dir.lest || { $caddy::vhost_dir }
epp('caddy/etc/caddy/caddyfile.epp',
include_dirs => unique([$caddy::config_dir] + [$caddy::vhost_enable_dir.lest || { $caddy::vhost_dir }])
include_dirs => unique([$config_dir, $vhost_dir])
)
}
}
Expand Down
31 changes: 27 additions & 4 deletions manifests/configfile.pp
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
# @summary This defined type handles a Caddy config file
#
# @param ensure
# Make the config file either present or absent.
# Make the config file either present (same as disabled), enabled, disabled or absent.
#
# @param source
# Source (path) for the caddy config file.
Expand All @@ -12,6 +12,9 @@
# @param config_dir
# Where to store the config file.
#
# @param enable_dir
# Directory to symlink the config config file into (conf-enabled e.g.) if any.
#
# @example Configure Caddy logging
# caddy::configfile { 'subdomain-log':
# source => 'puppet:///modules/caddy/etc/caddy/config/logging.conf',
Expand All @@ -32,23 +35,43 @@
# }
#
define caddy::configfile (
Enum['present','absent'] $ensure = 'present',
Enum['present','enabled','disabled','absent'] $ensure = 'enabled',
Optional[Stdlib::Filesource] $source = undef,
Optional[String] $content = undef,
Stdlib::Absolutepath $config_dir = $caddy::config_dir,
Optional[Stdlib::Absolutepath] $enable_dir = $caddy::config_enable_dir,
) {
include caddy

if ($ensure == 'present') and !($source or $content) {
if ($ensure != 'absent') and !($source or $content) {
fail('Either $source or $content must be specified when $ensure is "present"')
}

$file_ensure = $ensure ? {
'absent' => 'absent',
default => 'file',
}

file { "${config_dir}/${title}.conf":
ensure => stdlib::ensure($ensure, 'file'),
ensure => $file_ensure,
content => $content,
source => $source,
mode => '0444',
require => Class['caddy::config'],
notify => Class['caddy::service'],
}

if $enable_dir {
$symlink_ensure = $ensure ? {
'enabled' => 'link',
default => 'absent',
}

file { "${enable_dir}/${title}.conf":
ensure => $symlink_ensure,
target => "${config_dir}/${title}.conf",
require => Class['caddy::config'],
notify => Class['caddy::service'],
}
}
}
13 changes: 12 additions & 1 deletion manifests/init.pp
Original file line number Diff line number Diff line change
Expand Up @@ -121,11 +121,20 @@
# Caddyfile content.
#
# @param config_dir
# Where to store Caddy configs
# Where to store Caddy configs.
# Set this to /etc/caddy/conf-available to simulate nginx/apache behavior
# (see config_enable_dir also).
#
# @param purge_config_dir
# Whether to purge Caddy config directory.
#
# @param config_enable_dir
# Where to load Caddy configs from. Set this parameter to /etc/caddy/conf-enabled
# to simulate nginx/apache behavior.
#
# @param purge_config_enable_dir
# Whether to purge Caddy enabled config directory.
#
# @param config_files
# Hash of config files to create.
#
Expand Down Expand Up @@ -162,6 +171,7 @@
Stdlib::Absolutepath $caddy_home = '/var/lib/caddy',
Stdlib::Absolutepath $caddy_ssl_dir = '/etc/ssl/caddy',
Stdlib::Absolutepath $config_dir = '/etc/caddy/config',
Optional[Stdlib::Absolutepath] $config_enable_dir = undef,
Stdlib::Absolutepath $vhost_dir = '/etc/caddy/config',
Optional[Stdlib::Absolutepath] $vhost_enable_dir = undef,
Enum['personal', 'commercial'] $caddy_license = 'personal',
Expand All @@ -188,6 +198,7 @@
Optional[Stdlib::Filesource] $caddyfile_source = undef,
Optional[String[1]] $caddyfile_content = undef,
Boolean $purge_config_dir = true,
Boolean $purge_config_enable_dir = $purge_config_dir,
Boolean $purge_vhost_dir = $purge_config_dir,
Boolean $purge_vhost_enable_dir = $purge_vhost_dir,
Hash[String[1], Caddy::Config] $config_files = {},
Expand Down
13 changes: 11 additions & 2 deletions spec/acceptance/init_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -109,13 +109,18 @@ class { 'caddy':
let(:manifest) do
<<~PUPPET
class { 'caddy':
config_dir => '/etc/caddy/conf.d',
config_dir => '/etc/caddy/conf-available',
config_enable_dir => '/etc/caddy/conf-enabled',
vhost_dir => '/etc/caddy/sites-available',
vhost_enable_dir => '/etc/caddy/sites-enabled',
config_files => {
admin => {
admin_2020 => {
content => "{\n admin localhost:2020\n}\n",
},
admin_2021 => {
ensure => 'disabled',
content => "{\n admin localhost:2021\n}\n",
},
},
vhosts => {
port_3000 => {
Expand All @@ -136,6 +141,10 @@ class { 'caddy':
its(:stdout) { is_expected.to eq "{\"listen\":\"localhost:2020\"}\n" }
end

describe port(2021) do

Check failure on line 144 in spec/acceptance/init_spec.rb

View workflow job for this annotation

GitHub Actions / Puppet / Static validations

RSpec/RepeatedExampleGroupBody: Repeated describe block body on line(s) [153] (https://www.rubydoc.info/gems/rubocop-rspec/RuboCop/Cop/RSpec/RepeatedExampleGroupBody)
it { is_expected.not_to be_listening }
end

describe command('curl -v http://localhost:3000/') do
its(:exit_status) { is_expected.to eq 0 }
its(:stdout) { is_expected.to eq 'port 3000 ok' }
Expand Down
52 changes: 50 additions & 2 deletions spec/classes/init_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -382,6 +382,53 @@
end
end

context 'with config_enable_dir set' do
let(:params) { { config_enable_dir: '/etc/caddy/conf-enabled' } }

it do
is_expected.to contain_file('/etc/caddy/conf-enabled').
with_ensure('directory').
with_owner('caddy').
with_group('caddy').
with_mode('0755').
with_purge(true).
with_recurse(true)
end

it do
is_expected.to contain_file('/etc/caddy/Caddyfile').
with_content(%r{^import /etc/caddy/conf-enabled/\*\.conf$})
end

context 'with purge_config_enable_dir => false' do
let(:params) { super().merge(purge_config_enable_dir: false) }

it do
is_expected.to contain_file('/etc/caddy/conf-enabled').
with_ensure('directory').
with_purge(false).
with_recurse(nil)
end
end
end

context 'with both config_dir and config_enable_dir set' do
let(:params) do
{
config_dir: '/etc/caddy/conf-available',
config_enable_dir: '/etc/caddy/conf-enabled',
}
end

it { is_expected.to contain_file('/etc/caddy/conf-available') }
it { is_expected.to contain_file('/etc/caddy/conf-enabled') }

it do
is_expected.to contain_file('/etc/caddy/Caddyfile').
with_content(%r{^import /etc/caddy/conf-enabled/\*\.conf$})
end
end

context 'with vhost_dir set' do
let(:params) { { vhost_dir: '/etc/caddy/vhost.d' } }

Expand Down Expand Up @@ -472,6 +519,7 @@
source: 'puppet:///profiles/caddy/example1.conf',
},
example2: {
ensure: 'disabled',
content: "foo\nbar\n",
},
example3: {
Expand All @@ -481,8 +529,8 @@
}
end

it { is_expected.to contain_caddy__configfile('example1').with_ensure('present').with_source('puppet:///profiles/caddy/example1.conf') }
it { is_expected.to contain_caddy__configfile('example2').with_ensure('present').with_content("foo\nbar\n") }
it { is_expected.to contain_caddy__configfile('example1').with_ensure('enabled').with_source('puppet:///profiles/caddy/example1.conf') }
it { is_expected.to contain_caddy__configfile('example2').with_ensure('disabled').with_content("foo\nbar\n") }
it { is_expected.to contain_caddy__configfile('example3').with_ensure('absent') }
end

Expand Down
Loading

0 comments on commit b54d437

Please sign in to comment.