Linux server.nvwebsoft.co.in 3.10.0-1160.114.2.el7.x86_64 #1 SMP Wed Mar 20 15:54:52 UTC 2024 x86_64
Apache
: 162.240.12.249 | : 3.139.70.69
202 Domain
8.1.31
nbspublicschool
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
CREATE WP USER
README
+ Create Folder
+ Create File
/
usr /
lib /
python2.7 /
site-packages /
cloudinit /
config /
[ HOME SHELL ]
Name
Size
Permission
Action
__init__.py
1.4
KB
-rw-r--r--
__init__.pyc
1.31
KB
-rw-r--r--
__init__.pyo
1.31
KB
-rw-r--r--
cc_apt_configure.py
32.8
KB
-rw-r--r--
cc_apt_configure.pyc
30.2
KB
-rw-r--r--
cc_apt_configure.pyo
30.2
KB
-rw-r--r--
cc_apt_pipelining.py
2.44
KB
-rw-r--r--
cc_apt_pipelining.pyc
2.48
KB
-rw-r--r--
cc_apt_pipelining.pyo
2.48
KB
-rw-r--r--
cc_bootcmd.py
3.5
KB
-rw-r--r--
cc_bootcmd.pyc
3.02
KB
-rw-r--r--
cc_bootcmd.pyo
3.02
KB
-rw-r--r--
cc_byobu.py
3.1
KB
-rw-r--r--
cc_byobu.pyc
3.09
KB
-rw-r--r--
cc_byobu.pyo
3.09
KB
-rw-r--r--
cc_ca_certs.py
4.09
KB
-rw-r--r--
cc_ca_certs.pyc
4.1
KB
-rw-r--r--
cc_ca_certs.pyo
4.1
KB
-rw-r--r--
cc_chef.py
13.17
KB
-rw-r--r--
cc_chef.pyc
10.79
KB
-rw-r--r--
cc_chef.pyo
10.79
KB
-rw-r--r--
cc_debug.py
3.08
KB
-rw-r--r--
cc_debug.pyc
3.35
KB
-rw-r--r--
cc_debug.pyo
3.35
KB
-rw-r--r--
cc_disable_ec2_metadata.py
1.56
KB
-rw-r--r--
cc_disable_ec2_metadata.pyc
1.57
KB
-rw-r--r--
cc_disable_ec2_metadata.pyo
1.57
KB
-rw-r--r--
cc_disk_setup.py
32.8
KB
-rw-r--r--
cc_disk_setup.pyc
28.91
KB
-rw-r--r--
cc_disk_setup.pyo
28.91
KB
-rw-r--r--
cc_emit_upstart.py
2
KB
-rw-r--r--
cc_emit_upstart.pyc
2.15
KB
-rw-r--r--
cc_emit_upstart.pyo
2.15
KB
-rw-r--r--
cc_fan.py
2.83
KB
-rw-r--r--
cc_fan.pyc
3.09
KB
-rw-r--r--
cc_fan.pyo
3.09
KB
-rw-r--r--
cc_final_message.py
2.35
KB
-rw-r--r--
cc_final_message.pyc
2.39
KB
-rw-r--r--
cc_final_message.pyo
2.39
KB
-rw-r--r--
cc_foo.py
2.07
KB
-rw-r--r--
cc_foo.pyc
702
B
-rw-r--r--
cc_foo.pyo
702
B
-rw-r--r--
cc_growpart.py
11.51
KB
-rw-r--r--
cc_growpart.pyc
11.12
KB
-rw-r--r--
cc_growpart.pyo
11.12
KB
-rw-r--r--
cc_grub_dpkg.py
2.87
KB
-rw-r--r--
cc_grub_dpkg.pyc
2.63
KB
-rw-r--r--
cc_grub_dpkg.pyo
2.63
KB
-rw-r--r--
cc_keys_to_console.py
2.36
KB
-rw-r--r--
cc_keys_to_console.pyc
2.39
KB
-rw-r--r--
cc_keys_to_console.pyo
2.39
KB
-rw-r--r--
cc_landscape.py
3.93
KB
-rw-r--r--
cc_landscape.pyc
4.02
KB
-rw-r--r--
cc_landscape.pyo
4.02
KB
-rw-r--r--
cc_locale.py
1.16
KB
-rw-r--r--
cc_locale.pyc
1.16
KB
-rw-r--r--
cc_locale.pyo
1.16
KB
-rw-r--r--
cc_lxd.py
10.27
KB
-rw-r--r--
cc_lxd.pyc
8.33
KB
-rw-r--r--
cc_lxd.pyo
8.33
KB
-rw-r--r--
cc_mcollective.py
5.08
KB
-rw-r--r--
cc_mcollective.pyc
3.8
KB
-rw-r--r--
cc_mcollective.pyo
3.8
KB
-rw-r--r--
cc_migrator.py
3.07
KB
-rw-r--r--
cc_migrator.pyc
3.18
KB
-rw-r--r--
cc_migrator.pyo
3.18
KB
-rw-r--r--
cc_mounts.py
17.24
KB
-rw-r--r--
cc_mounts.pyc
14.59
KB
-rw-r--r--
cc_mounts.pyo
14.59
KB
-rw-r--r--
cc_ntp.py
20.19
KB
-rw-r--r--
cc_ntp.pyc
15.74
KB
-rw-r--r--
cc_ntp.pyo
15.74
KB
-rw-r--r--
cc_package_update_upgrade_inst...
4.11
KB
-rw-r--r--
cc_package_update_upgrade_inst...
4.01
KB
-rw-r--r--
cc_package_update_upgrade_inst...
4.01
KB
-rw-r--r--
cc_phone_home.py
3.92
KB
-rw-r--r--
cc_phone_home.pyc
3.28
KB
-rw-r--r--
cc_phone_home.pyo
3.28
KB
-rw-r--r--
cc_power_state_change.py
7.65
KB
-rw-r--r--
cc_power_state_change.pyc
7.8
KB
-rw-r--r--
cc_power_state_change.pyo
7.8
KB
-rw-r--r--
cc_puppet.py
8.86
KB
-rw-r--r--
cc_puppet.pyc
7.06
KB
-rw-r--r--
cc_puppet.pyo
7.06
KB
-rw-r--r--
cc_resizefs.py
10.79
KB
-rw-r--r--
cc_resizefs.pyc
9.15
KB
-rw-r--r--
cc_resizefs.pyo
9.15
KB
-rw-r--r--
cc_resolv_conf.py
3.43
KB
-rw-r--r--
cc_resolv_conf.pyc
3.44
KB
-rw-r--r--
cc_resolv_conf.pyo
3.44
KB
-rw-r--r--
cc_rh_subscription.py
15.65
KB
-rw-r--r--
cc_rh_subscription.pyc
13.5
KB
-rw-r--r--
cc_rh_subscription.pyo
13.5
KB
-rw-r--r--
cc_rightscale_userdata.py
3.76
KB
-rw-r--r--
cc_rightscale_userdata.pyc
2.82
KB
-rw-r--r--
cc_rightscale_userdata.pyo
2.82
KB
-rw-r--r--
cc_rsyslog.py
14.1
KB
-rw-r--r--
cc_rsyslog.pyc
10.56
KB
-rw-r--r--
cc_rsyslog.pyo
10.56
KB
-rw-r--r--
cc_runcmd.py
3.11
KB
-rw-r--r--
cc_runcmd.pyc
2.73
KB
-rw-r--r--
cc_runcmd.pyo
2.73
KB
-rw-r--r--
cc_salt_minion.py
4.66
KB
-rw-r--r--
cc_salt_minion.pyc
3.78
KB
-rw-r--r--
cc_salt_minion.pyo
3.78
KB
-rw-r--r--
cc_scripts_per_boot.py
1.2
KB
-rw-r--r--
cc_scripts_per_boot.pyc
1.2
KB
-rw-r--r--
cc_scripts_per_boot.pyo
1.2
KB
-rw-r--r--
cc_scripts_per_instance.py
1.38
KB
-rw-r--r--
cc_scripts_per_instance.pyc
1.38
KB
-rw-r--r--
cc_scripts_per_instance.pyo
1.38
KB
-rw-r--r--
cc_scripts_per_once.py
1.31
KB
-rw-r--r--
cc_scripts_per_once.pyc
1.31
KB
-rw-r--r--
cc_scripts_per_once.pyo
1.31
KB
-rw-r--r--
cc_scripts_user.py
1.42
KB
-rw-r--r--
cc_scripts_user.pyc
1.38
KB
-rw-r--r--
cc_scripts_user.pyo
1.38
KB
-rw-r--r--
cc_scripts_vendor.py
1.38
KB
-rw-r--r--
cc_scripts_vendor.pyc
1.46
KB
-rw-r--r--
cc_scripts_vendor.pyo
1.46
KB
-rw-r--r--
cc_seed_random.py
4.39
KB
-rw-r--r--
cc_seed_random.pyc
4.53
KB
-rw-r--r--
cc_seed_random.pyo
4.53
KB
-rw-r--r--
cc_set_hostname.py
2.95
KB
-rw-r--r--
cc_set_hostname.pyc
2.72
KB
-rw-r--r--
cc_set_hostname.pyo
2.72
KB
-rw-r--r--
cc_set_passwords.py
8.45
KB
-rw-r--r--
cc_set_passwords.pyc
7.62
KB
-rw-r--r--
cc_set_passwords.pyo
7.62
KB
-rw-r--r--
cc_snap.py
8.11
KB
-rw-r--r--
cc_snap.pyc
7.54
KB
-rw-r--r--
cc_snap.pyo
7.54
KB
-rw-r--r--
cc_snap_config.py
5.37
KB
-rw-r--r--
cc_snap_config.pyc
5.03
KB
-rw-r--r--
cc_snap_config.pyo
5.03
KB
-rw-r--r--
cc_snappy.py
9.69
KB
-rw-r--r--
cc_snappy.pyc
9.27
KB
-rw-r--r--
cc_snappy.pyo
9.27
KB
-rw-r--r--
cc_spacewalk.py
2.89
KB
-rw-r--r--
cc_spacewalk.pyc
2.91
KB
-rw-r--r--
cc_spacewalk.pyo
2.91
KB
-rw-r--r--
cc_ssh.py
10.59
KB
-rw-r--r--
cc_ssh.pyc
9.11
KB
-rw-r--r--
cc_ssh.pyo
9.11
KB
-rw-r--r--
cc_ssh_authkey_fingerprints.py
3.43
KB
-rw-r--r--
cc_ssh_authkey_fingerprints.py...
3.94
KB
-rw-r--r--
cc_ssh_authkey_fingerprints.py...
3.94
KB
-rw-r--r--
cc_ssh_import_id.py
2.88
KB
-rw-r--r--
cc_ssh_import_id.pyc
2.72
KB
-rw-r--r--
cc_ssh_import_id.pyo
2.72
KB
-rw-r--r--
cc_timezone.py
1.15
KB
-rw-r--r--
cc_timezone.pyc
1.15
KB
-rw-r--r--
cc_timezone.pyo
1.15
KB
-rw-r--r--
cc_ubuntu_advantage.py
6.08
KB
-rw-r--r--
cc_ubuntu_advantage.pyc
6.12
KB
-rw-r--r--
cc_ubuntu_advantage.pyo
6.12
KB
-rw-r--r--
cc_ubuntu_drivers.py
5.66
KB
-rw-r--r--
cc_ubuntu_drivers.pyc
4.63
KB
-rw-r--r--
cc_ubuntu_drivers.pyo
4.63
KB
-rw-r--r--
cc_update_etc_hosts.py
3.33
KB
-rw-r--r--
cc_update_etc_hosts.pyc
2.99
KB
-rw-r--r--
cc_update_etc_hosts.pyo
2.99
KB
-rw-r--r--
cc_update_hostname.py
1.58
KB
-rw-r--r--
cc_update_hostname.pyc
1.66
KB
-rw-r--r--
cc_update_hostname.pyo
1.66
KB
-rw-r--r--
cc_users_groups.py
7.06
KB
-rw-r--r--
cc_users_groups.pyc
6.76
KB
-rw-r--r--
cc_users_groups.pyo
6.76
KB
-rw-r--r--
cc_write_files.py
4.95
KB
-rw-r--r--
cc_write_files.pyc
5.13
KB
-rw-r--r--
cc_write_files.pyo
5.13
KB
-rw-r--r--
cc_yum_add_repo.py
4.27
KB
-rw-r--r--
cc_yum_add_repo.pyc
3.88
KB
-rw-r--r--
cc_yum_add_repo.pyo
3.88
KB
-rw-r--r--
cc_zypper_add_repo.py
7.62
KB
-rw-r--r--
cc_zypper_add_repo.pyc
7.12
KB
-rw-r--r--
cc_zypper_add_repo.pyo
7.12
KB
-rw-r--r--
schema.py
14.06
KB
-rw-r--r--
schema.pyc
13.83
KB
-rw-r--r--
schema.pyo
13.83
KB
-rw-r--r--
Delete
Unzip
Zip
${this.title}
Close
Code Editor : cc_ntp.py
# Copyright (C) 2016 Canonical Ltd. # # Author: Ryan Harper <ryan.harper@canonical.com> # # This file is part of cloud-init. See LICENSE file for license information. """NTP: enable and configure ntp""" from cloudinit.config.schema import ( get_schema_doc, validate_cloudconfig_schema) from cloudinit import log as logging from cloudinit.settings import PER_INSTANCE from cloudinit import temp_utils from cloudinit import templater from cloudinit import type_utils from cloudinit import util import copy import os import six from textwrap import dedent LOG = logging.getLogger(__name__) frequency = PER_INSTANCE NTP_CONF = '/etc/ntp.conf' NR_POOL_SERVERS = 4 distros = ['centos', 'debian', 'fedora', 'opensuse', 'rhel', 'sles', 'ubuntu'] NTP_CLIENT_CONFIG = { 'chrony': { 'check_exe': 'chronyd', 'confpath': '/etc/chrony.conf', 'packages': ['chrony'], 'service_name': 'chrony', 'template_name': 'chrony.conf.{distro}', 'template': None, }, 'ntp': { 'check_exe': 'ntpd', 'confpath': NTP_CONF, 'packages': ['ntp'], 'service_name': 'ntp', 'template_name': 'ntp.conf.{distro}', 'template': None, }, 'ntpdate': { 'check_exe': 'ntpdate', 'confpath': NTP_CONF, 'packages': ['ntpdate'], 'service_name': 'ntpdate', 'template_name': 'ntp.conf.{distro}', 'template': None, }, 'systemd-timesyncd': { 'check_exe': '/lib/systemd/systemd-timesyncd', 'confpath': '/etc/systemd/timesyncd.conf.d/cloud-init.conf', 'packages': [], 'service_name': 'systemd-timesyncd', 'template_name': 'timesyncd.conf', 'template': None, }, } # This is Distro-specific configuration overrides of the base config DISTRO_CLIENT_CONFIG = { 'debian': { 'chrony': { 'confpath': '/etc/chrony/chrony.conf', }, }, 'opensuse': { 'chrony': { 'service_name': 'chronyd', }, 'ntp': { 'confpath': '/etc/ntp.conf', 'service_name': 'ntpd', }, 'systemd-timesyncd': { 'check_exe': '/usr/lib/systemd/systemd-timesyncd', }, }, 'sles': { 'chrony': { 'service_name': 'chronyd', }, 'ntp': { 'confpath': '/etc/ntp.conf', 'service_name': 'ntpd', }, 'systemd-timesyncd': { 'check_exe': '/usr/lib/systemd/systemd-timesyncd', }, }, 'ubuntu': { 'chrony': { 'confpath': '/etc/chrony/chrony.conf', }, }, } # The schema definition for each cloud-config module is a strict contract for # describing supported configuration parameters for each cloud-config section. # It allows cloud-config to validate and alert users to invalid or ignored # configuration options before actually attempting to deploy with said # configuration. schema = { 'id': 'cc_ntp', 'name': 'NTP', 'title': 'enable and configure ntp', 'description': dedent("""\ Handle ntp configuration. If ntp is not installed on the system and ntp configuration is specified, ntp will be installed. If there is a default ntp config file in the image or one is present in the distro's ntp package, it will be copied to ``/etc/ntp.conf.dist`` before any changes are made. A list of ntp pools and ntp servers can be provided under the ``ntp`` config key. If no ntp ``servers`` or ``pools`` are provided, 4 pools will be used in the format ``{0-3}.{distro}.pool.ntp.org``."""), 'distros': distros, 'examples': [ dedent("""\ # Override ntp with chrony configuration on Ubuntu ntp: enabled: true ntp_client: chrony # Uses cloud-init default chrony configuration """), dedent("""\ # Provide a custom ntp client configuration ntp: enabled: true ntp_client: myntpclient config: confpath: /etc/myntpclient/myntpclient.conf check_exe: myntpclientd packages: - myntpclient service_name: myntpclient template: | ## template:jinja # My NTP Client config {% if pools -%}# pools{% endif %} {% for pool in pools -%} pool {{pool}} iburst {% endfor %} {%- if servers %}# servers {% endif %} {% for server in servers -%} server {{server}} iburst {% endfor %} pools: [0.int.pool.ntp.org, 1.int.pool.ntp.org, ntp.myorg.org] servers: - ntp.server.local - ntp.ubuntu.com - 192.168.23.2""")], 'frequency': PER_INSTANCE, 'type': 'object', 'properties': { 'ntp': { 'type': ['object', 'null'], 'properties': { 'pools': { 'type': 'array', 'items': { 'type': 'string', 'format': 'hostname' }, 'uniqueItems': True, 'description': dedent("""\ List of ntp pools. If both pools and servers are empty, 4 default pool servers will be provided of the format ``{0-3}.{distro}.pool.ntp.org``.""") }, 'servers': { 'type': 'array', 'items': { 'type': 'string', 'format': 'hostname' }, 'uniqueItems': True, 'description': dedent("""\ List of ntp servers. If both pools and servers are empty, 4 default pool servers will be provided with the format ``{0-3}.{distro}.pool.ntp.org``.""") }, 'ntp_client': { 'type': 'string', 'default': 'auto', 'description': dedent("""\ Name of an NTP client to use to configure system NTP. When unprovided or 'auto' the default client preferred by the distribution will be used. The following built-in client names can be used to override existing configuration defaults: chrony, ntp, ntpdate, systemd-timesyncd."""), }, 'enabled': { 'type': 'boolean', 'default': True, 'description': dedent("""\ Attempt to enable ntp clients if set to True. If set to False, ntp client will not be configured or installed"""), }, 'config': { 'description': dedent("""\ Configuration settings or overrides for the ``ntp_client`` specified."""), 'type': ['object'], 'properties': { 'confpath': { 'type': 'string', 'description': dedent("""\ The path to where the ``ntp_client`` configuration is written."""), }, 'check_exe': { 'type': 'string', 'description': dedent("""\ The executable name for the ``ntp_client``. For example, ntp service ``check_exe`` is 'ntpd' because it runs the ntpd binary."""), }, 'packages': { 'type': 'array', 'items': { 'type': 'string', }, 'uniqueItems': True, 'description': dedent("""\ List of packages needed to be installed for the selected ``ntp_client``."""), }, 'service_name': { 'type': 'string', 'description': dedent("""\ The systemd or sysvinit service name used to start and stop the ``ntp_client`` service."""), }, 'template': { 'type': 'string', 'description': dedent("""\ Inline template allowing users to define their own ``ntp_client`` configuration template. The value must start with '## template:jinja' to enable use of templating support. """), }, }, # Don't use REQUIRED_NTP_CONFIG_KEYS to allow for override # of builtin client values. 'required': [], 'minProperties': 1, # If we have config, define something 'additionalProperties': False }, }, 'required': [], 'additionalProperties': False } } } REQUIRED_NTP_CONFIG_KEYS = frozenset([ 'check_exe', 'confpath', 'packages', 'service_name']) __doc__ = get_schema_doc(schema) # Supplement python help() def distro_ntp_client_configs(distro): """Construct a distro-specific ntp client config dictionary by merging distro specific changes into base config. @param distro: String providing the distro class name. @returns: Dict of distro configurations for ntp clients. """ dcfg = DISTRO_CLIENT_CONFIG cfg = copy.copy(NTP_CLIENT_CONFIG) if distro in dcfg: cfg = util.mergemanydict([cfg, dcfg[distro]], reverse=True) return cfg def select_ntp_client(ntp_client, distro): """Determine which ntp client is to be used, consulting the distro for its preference. @param ntp_client: String name of the ntp client to use. @param distro: Distro class instance. @returns: Dict of the selected ntp client or {} if none selected. """ # construct distro-specific ntp_client_config dict distro_cfg = distro_ntp_client_configs(distro.name) # user specified client, return its config if ntp_client and ntp_client != 'auto': LOG.debug('Selected NTP client "%s" via user-data configuration', ntp_client) return distro_cfg.get(ntp_client, {}) # default to auto if unset in distro distro_ntp_client = distro.get_option('ntp_client', 'auto') clientcfg = {} if distro_ntp_client == "auto": for client in distro.preferred_ntp_clients: cfg = distro_cfg.get(client) if util.which(cfg.get('check_exe')): LOG.debug('Selected NTP client "%s", already installed', client) clientcfg = cfg break if not clientcfg: client = distro.preferred_ntp_clients[0] LOG.debug( 'Selected distro preferred NTP client "%s", not yet installed', client) clientcfg = distro_cfg.get(client) else: LOG.debug('Selected NTP client "%s" via distro system config', distro_ntp_client) clientcfg = distro_cfg.get(distro_ntp_client, {}) return clientcfg def install_ntp_client(install_func, packages=None, check_exe="ntpd"): """Install ntp client package if not already installed. @param install_func: function. This parameter is invoked with the contents of the packages parameter. @param packages: list. This parameter defaults to ['ntp']. @param check_exe: string. The name of a binary that indicates the package the specified package is already installed. """ if util.which(check_exe): return if packages is None: packages = ['ntp'] install_func(packages) def rename_ntp_conf(confpath=None): """Rename any existing ntp client config file @param confpath: string. Specify a path to an existing ntp client configuration file. """ if os.path.exists(confpath): util.rename(confpath, confpath + ".dist") def generate_server_names(distro): """Generate a list of server names to populate an ntp client configuration file. @param distro: string. Specify the distro name @returns: list: A list of strings representing ntp servers for this distro. """ names = [] pool_distro = distro # For legal reasons x.pool.sles.ntp.org does not exist, # use the opensuse pool if distro == 'sles': pool_distro = 'opensuse' for x in range(0, NR_POOL_SERVERS): name = "%d.%s.pool.ntp.org" % (x, pool_distro) names.append(name) return names def write_ntp_config_template(distro_name, servers=None, pools=None, path=None, template_fn=None, template=None): """Render a ntp client configuration for the specified client. @param distro_name: string. The distro class name. @param servers: A list of strings specifying ntp servers. Defaults to empty list. @param pools: A list of strings specifying ntp pools. Defaults to empty list. @param path: A string to specify where to write the rendered template. @param template_fn: A string to specify the template source file. @param template: A string specifying the contents of the template. This content will be written to a temporary file before being used to render the configuration file. @raises: ValueError when path is None. @raises: ValueError when template_fn is None and template is None. """ if not servers: servers = [] if not pools: pools = [] if len(servers) == 0 and len(pools) == 0: pools = generate_server_names(distro_name) LOG.debug( 'Adding distro default ntp pool servers: %s', ','.join(pools)) if not path: raise ValueError('Invalid value for path parameter') if not template_fn and not template: raise ValueError('Not template_fn or template provided') params = {'servers': servers, 'pools': pools} if template: tfile = temp_utils.mkstemp(prefix='template_name-', suffix=".tmpl") template_fn = tfile[1] # filepath is second item in tuple util.write_file(template_fn, content=template) templater.render_to_file(template_fn, path, params) # clean up temporary template if template: util.del_file(template_fn) def reload_ntp(service, systemd=False): """Restart or reload an ntp system service. @param service: A string specifying the name of the service to be affected. @param systemd: A boolean indicating if the distro uses systemd, defaults to False. @returns: A tuple of stdout, stderr results from executing the action. """ if systemd: cmd = ['systemctl', 'reload-or-restart', service] else: cmd = ['service', service, 'restart'] util.subp(cmd, capture=True) def supplemental_schema_validation(ntp_config): """Validate user-provided ntp:config option values. This function supplements flexible jsonschema validation with specific value checks to aid in triage of invalid user-provided configuration. @param ntp_config: Dictionary of configuration value under 'ntp'. @raises: ValueError describing invalid values provided. """ errors = [] missing = REQUIRED_NTP_CONFIG_KEYS.difference(set(ntp_config.keys())) if missing: keys = ', '.join(sorted(missing)) errors.append( 'Missing required ntp:config keys: {keys}'.format(keys=keys)) elif not any([ntp_config.get('template'), ntp_config.get('template_name')]): errors.append( 'Either ntp:config:template or ntp:config:template_name values' ' are required') for key, value in sorted(ntp_config.items()): keypath = 'ntp:config:' + key if key == 'confpath': if not all([value, isinstance(value, six.string_types)]): errors.append( 'Expected a config file path {keypath}.' ' Found ({value})'.format(keypath=keypath, value=value)) elif key == 'packages': if not isinstance(value, list): errors.append( 'Expected a list of required package names for {keypath}.' ' Found ({value})'.format(keypath=keypath, value=value)) elif key in ('template', 'template_name'): if value is None: # Either template or template_name can be none continue if not isinstance(value, six.string_types): errors.append( 'Expected a string type for {keypath}.' ' Found ({value})'.format(keypath=keypath, value=value)) elif not isinstance(value, six.string_types): errors.append( 'Expected a string type for {keypath}.' ' Found ({value})'.format(keypath=keypath, value=value)) if errors: raise ValueError(r'Invalid ntp configuration:\n{errors}'.format( errors='\n'.join(errors))) def handle(name, cfg, cloud, log, _args): """Enable and configure ntp.""" if 'ntp' not in cfg: LOG.debug( "Skipping module named %s, not present or disabled by cfg", name) return ntp_cfg = cfg['ntp'] if ntp_cfg is None: ntp_cfg = {} # Allow empty config which will install the package # TODO drop this when validate_cloudconfig_schema is strict=True if not isinstance(ntp_cfg, (dict)): raise RuntimeError( "'ntp' key existed in config, but not a dictionary type," " is a {_type} instead".format(_type=type_utils.obj_name(ntp_cfg))) validate_cloudconfig_schema(cfg, schema) # Allow users to explicitly enable/disable enabled = ntp_cfg.get('enabled', True) if util.is_false(enabled): LOG.debug("Skipping module named %s, disabled by cfg", name) return # Select which client is going to be used and get the configuration ntp_client_config = select_ntp_client(ntp_cfg.get('ntp_client'), cloud.distro) # Allow user ntp config to override distro configurations ntp_client_config = util.mergemanydict( [ntp_client_config, ntp_cfg.get('config', {})], reverse=True) supplemental_schema_validation(ntp_client_config) rename_ntp_conf(confpath=ntp_client_config.get('confpath')) template_fn = None if not ntp_client_config.get('template'): template_name = ( ntp_client_config.get('template_name').replace('{distro}', cloud.distro.name)) template_fn = cloud.get_template_filename(template_name) if not template_fn: msg = ('No template found, not rendering %s' % ntp_client_config.get('template_name')) raise RuntimeError(msg) write_ntp_config_template(cloud.distro.name, servers=ntp_cfg.get('servers', []), pools=ntp_cfg.get('pools', []), path=ntp_client_config.get('confpath'), template_fn=template_fn, template=ntp_client_config.get('template')) install_ntp_client(cloud.distro.install_packages, packages=ntp_client_config['packages'], check_exe=ntp_client_config['check_exe']) try: reload_ntp(ntp_client_config['service_name'], systemd=cloud.distro.uses_systemd()) except util.ProcessExecutionError as e: LOG.exception("Failed to reload/start ntp service: %s", e) raise # vi: ts=4 expandtab
Close