Skip to content

Commit

Permalink
Native firewalld_custom_service
Browse files Browse the repository at this point in the history
* Create firewalld_custom_service type and provider
* Add spec tests
* Update Beaker tests
* Mark firewalld::custom_service for deprecation
* Resolve dependency loops

Fixes voxpupuli#275
  • Loading branch information
trevor-vaughan committed Apr 16, 2020
1 parent a9d2921 commit a1993ba
Show file tree
Hide file tree
Showing 17 changed files with 1,503 additions and 248 deletions.
1 change: 1 addition & 0 deletions .rspec
Original file line number Diff line number Diff line change
@@ -1,2 +1,3 @@
--format documentation
--color
--fail-fast
11 changes: 11 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,17 @@ The following paramters are the element of the rich rule, only _one_ may be used

The `firewalld::custom_service` defined type creates and manages custom services. It makes the service usable by firewalld, but does not add it to any zones. To do that, use the firewalld::service type.

---

> The `firewalld::custom_service` is **DEPRECATED** and will be removed in a
> future release. Please use the `firewalld_custom_service` native type.
>
> Please note that there are slight differences in the parameters that will
> require modifications to the `firewalld::custom_services` Hash if utilized from
> Hiera.

---

_Example in Class_:

```puppet
Expand Down
149 changes: 121 additions & 28 deletions REFERENCE.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,10 +11,11 @@

**Defined types**

* [`firewalld::custom_service`](#firewalldcustom_service): == Type: firewalld::custom_service Creates a new service definition for use in firewalld See the README.md for usage instructions for this
* [`firewalld::custom_service`](#firewalldcustom_service): Creates a new service definition for use in firewalld

**Resource types**

* [`firewalld_custom_service`](#firewalld_custom_service): Creates a custom firewalld service.
* [`firewalld_direct_chain`](#firewalld_direct_chain): Allow to create a custom chain in iptables/ip6tables/ebtables using firewalld direct interface. Example: firewalld_direct_chain {'Add c
* [`firewalld_direct_passthrough`](#firewalld_direct_passthrough): Allow to create a custom passthroughhrough traffic in iptables/ip6tables/ebtables using firewalld direct interface. Example: firewalld_
* [`firewalld_direct_purge`](#firewalld_direct_purge): Allow to purge direct rules in iptables/ip6tables/ebtables using firewalld direct interface. Example: firewalld_direct_purge {'chain':
Expand Down Expand Up @@ -306,37 +307,39 @@ A common point for triggering an intermediary firewalld full reload using firewa

### firewalld::custom_service

== Type: firewalld::custom_service
**DEPRECATED**: Please use the `firewalld_custom_service` native type moving forward

Creates a new service definition for use in firewalld
This defined type will be removed in a future release

See the README.md for usage instructions for this defined type
Andrew Patik <andrewpatik@gmail.com>
Trevor Vaughan <tvaughan@onyxpoint.com>

=== Examples
#### Examples

firewalld::custom_service{'My Custom Service':
short => 'MyService',
description => 'My Custom Service is a daemon that does whatever',
port => [
{
'port' => '1234'
'protocol' => 'tcp'
},
{
'port' => '1234'
'protocol' => 'udp'
},
],
module => ['nf_conntrack_netbios_ns'],
destination => {
'ipv4' => '127.0.0.1',
'ipv6' => '::1'
}
}
#####

=== Authors
```puppet
Andrew Patik <andrewpatik@gmail.com>
firewalld::custom_service{'My Custom Service':
short => 'MyService',
description => 'My Custom Service is a daemon that does whatever',
port => [
{
'port' => '1234'
'protocol' => 'tcp'
},
{
'port' => '1234'
'protocol' => 'udp'
},
],
module => ['nf_conntrack_netbios_ns'],
destination => {
'ipv4' => '127.0.0.1',
'ipv6' => '::1'
}
}
```

#### Parameters

Expand Down Expand Up @@ -411,6 +414,96 @@ Default value: 'present'

## Resource types

### firewalld_custom_service

You will still need to create a `firewalld_service` resource to bind your new
service to a zone.

#### Examples

##### Creating a custom 'test' service

```puppet
firewalld_custom_service {'test':
ensure => present,
ports => [{'port' => '1234', 'protocol' => 'tcp'}]
}
```

#### Properties

The following properties are available in the `firewalld_custom_service` type.

##### `ensure`

Valid values: present, absent

The basic property that the resource should be in.

Default value: present

##### `short`

Valid values: %r{.+}

The short description of the service

##### `description`

Valid values: %r{.+}

The long description of the service

##### `ports`

An Array of allowed port/protocol Hashes or Strings of the form `port/protocol`

Default value: unset

##### `protocols`

Valid values: %r{^[^\s#]+$}

Protocols allowed by the service as defined in /etc/protocols

Default value: unset

##### `modules`

Valid values: %r{^[\w-]+$}

The list of netfilter modules to add to the service

Default value: unset

##### `ipv4_destination`

Valid values: %r{^[^/]+(/\d+)?$}

The IPv4 destination network of the service

Default value: unset

##### `ipv6_destination`

Valid values: %r{^[^/]+(/\d+)?$}

The IPv6 destination network of the service

Default value: unset

#### Parameters

The following parameters are available in the `firewalld_custom_service` type.

##### `name`

Valid values: %r{.+}

namevar

The target filename of the resource (without the .xml suffix)

### firewalld_direct_chain

Allow to create a custom chain in iptables/ip6tables/ebtables using firewalld direct interface.
Expand Down Expand Up @@ -1026,7 +1119,7 @@ Result => 'B--d--Characters--.txt'

#### `firewalld::safe_filename(String[1] $filename, Struct[
{
'replacement_string' => Pattern[/[\w-]/],
'replacement_string' => Pattern[/^[\w-]+$/],
'file_extension' => Optional[String[1]]
}
] $options = { 'replacement_string' => '_'})`
Expand Down Expand Up @@ -1071,7 +1164,7 @@ The String to process

Data type: `Struct[
{
'replacement_string' => Pattern[/[\w-]/],
'replacement_string' => Pattern[/^[\w-]+$/],
'file_extension' => Optional[String[1]]
}
]`
Expand Down
2 changes: 1 addition & 1 deletion functions/safe_filename.pp
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ function firewalld::safe_filename(
String[1] $filename,
Struct[
{
'replacement_string' => Pattern[/[\w-]/],
'replacement_string' => Pattern[/^[\w-]+$/],
'file_extension' => Optional[String[1]]
}
] $options = { 'replacement_string' => '_'}
Expand Down
Loading

0 comments on commit a1993ba

Please sign in to comment.