
By parameterizing the selinux mode we can set the mode and pass the mode to other classes so they can make decisions on whether or not to run selinux commands as part of their configuration. Depends-On: I21add092d9d09077f2b23760a384f5a5cb91d86a Change-Id: I86a5bb006b6ab9d64f7fbd894c967428cfaed8f8
85 lines
2.7 KiB
Puppet
85 lines
2.7 KiB
Puppet
# Copyright 2013 Red Hat, Inc.
|
|
#
|
|
# Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
# not use this file except in compliance with the License. You may obtain
|
|
# a copy of the License at
|
|
#
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
#
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
# License for the specific language governing permissions and limitations
|
|
# under the License.
|
|
#
|
|
# Class to configure asterisk on a CentOS node.
|
|
#
|
|
# == Class: openstack_project::pbx
|
|
class openstack_project::pbx (
|
|
$sysadmins = [],
|
|
$sip_providers = [],
|
|
$selinux_mode = 'enforcing'
|
|
) {
|
|
class { 'openstack_project::server':
|
|
sysadmins => $sysadmins,
|
|
# SIP signaling is either TCP or UDP port 5060.
|
|
# RTP media (audio/video) uses a range of UDP ports.
|
|
iptables_public_tcp_ports => [5060],
|
|
iptables_public_udp_ports => [5060],
|
|
iptables_rules4 => ['-m udp -p udp --dport 10000:20000 -j ACCEPT'],
|
|
iptables_rules6 => ['-m udp -p udp --dport 10000:20000 -j ACCEPT'],
|
|
}
|
|
|
|
if ($::osfamily == 'RedHat') {
|
|
class { 'selinux':
|
|
mode => $selinux_mode
|
|
}
|
|
}
|
|
|
|
realize (
|
|
User::Virtual::Localuser['rbryant'],
|
|
User::Virtual::Localuser['pabelanger'],
|
|
)
|
|
|
|
class { 'asterisk':
|
|
asterisk_conf_source => 'puppet:///modules/openstack_project/pbx/asterisk/asterisk.conf',
|
|
modules_conf_source => 'puppet:///modules/openstack_project/pbx/asterisk/modules.conf',
|
|
}
|
|
|
|
file {'/etc/asterisk/sip.conf.d/sip.conf':
|
|
ensure => present,
|
|
owner => 'asterisk',
|
|
group => 'asterisk',
|
|
mode => '0660',
|
|
content => template('openstack_project/pbx/asterisk/sip.conf.erb'),
|
|
require => File['/etc/asterisk/'],
|
|
}
|
|
|
|
file {'/etc/asterisk/extensions.conf.d/extensions.conf':
|
|
ensure => present,
|
|
owner => 'asterisk',
|
|
group => 'asterisk',
|
|
mode => '0660',
|
|
source => 'puppet:///modules/openstack_project/pbx/asterisk/extensions.conf',
|
|
require => File['/etc/asterisk/'],
|
|
}
|
|
|
|
file {'/etc/asterisk/cdr.conf.d/cdr.conf':
|
|
ensure => present,
|
|
owner => 'asterisk',
|
|
group => 'asterisk',
|
|
mode => '0660',
|
|
source => 'puppet:///modules/openstack_project/pbx/asterisk/cdr.conf',
|
|
require => File['/etc/asterisk/'],
|
|
}
|
|
|
|
file {'/etc/asterisk/cdr_custom.conf.d/cdr_custom.conf':
|
|
ensure => present,
|
|
owner => 'asterisk',
|
|
group => 'asterisk',
|
|
mode => '0660',
|
|
source => 'puppet:///modules/openstack_project/pbx/asterisk/cdr_custom.conf',
|
|
require => File['/etc/asterisk/'],
|
|
}
|
|
}
|