diff options
Diffstat (limited to 'puppet/modules/ntp')
34 files changed, 1380 insertions, 9 deletions
| diff --git a/puppet/modules/ntp b/puppet/modules/ntp deleted file mode 160000 -Subproject 27f2bc72110b1001233eb0907aa07e06cdf3319 diff --git a/puppet/modules/ntp/.fixtures.yml b/puppet/modules/ntp/.fixtures.yml new file mode 100644 index 00000000..a4b98014 --- /dev/null +++ b/puppet/modules/ntp/.fixtures.yml @@ -0,0 +1,5 @@ +fixtures: +  repositories: +    "stdlib": "git://github.com/puppetlabs/puppetlabs-stdlib.git" +  symlinks: +    "ntp": "#{source_dir}" diff --git a/puppet/modules/ntp/.gitignore b/puppet/modules/ntp/.gitignore new file mode 100644 index 00000000..49cf4650 --- /dev/null +++ b/puppet/modules/ntp/.gitignore @@ -0,0 +1,3 @@ +pkg/ +metadata.json +Gemfile.lock diff --git a/puppet/modules/ntp/.gitrepo b/puppet/modules/ntp/.gitrepo new file mode 100644 index 00000000..dd7d7267 --- /dev/null +++ b/puppet/modules/ntp/.gitrepo @@ -0,0 +1,11 @@ +; DO NOT EDIT (unless you know what you are doing) +; +; This subdirectory is a git "subrepo", and this file is maintained by the +; git-subrepo command. See https://github.com/git-commands/git-subrepo#readme +; +[subrepo] +	remote = https://leap.se/git/puppet_ntp +	branch = master +	commit = 8a554ab4b00e25f52a337c4c974fd89f44042957 +	parent = 5552d592f9332e55bcf2a5d2c6b0258b8130c26b +	cmdver = 0.3.0 diff --git a/puppet/modules/ntp/.nodeset.yml b/puppet/modules/ntp/.nodeset.yml new file mode 100644 index 00000000..cbd0d57b --- /dev/null +++ b/puppet/modules/ntp/.nodeset.yml @@ -0,0 +1,35 @@ +--- +default_set: 'centos-64-x64' +sets: +  'centos-59-x64': +    nodes: +      "main.foo.vm": +        prefab: 'centos-59-x64' +  'centos-64-x64': +    nodes: +      "main.foo.vm": +        prefab: 'centos-64-x64' +  'fedora-18-x64': +    nodes: +      "main.foo.vm": +        prefab: 'fedora-18-x64' +  'debian-607-x64': +    nodes: +      "main.foo.vm": +        prefab: 'debian-607-x64' +  'debian-70rc1-x64': +    nodes: +      "main.foo.vm": +        prefab: 'debian-70rc1-x64' +  'ubuntu-server-10044-x64': +    nodes: +      "main.foo.vm": +        prefab: 'ubuntu-server-10044-x64' +  'ubuntu-server-12042-x64': +    nodes: +      "main.foo.vm": +        prefab: 'ubuntu-server-12042-x64' +  'sles-11sp1-x64': +    nodes: +      "main.foo.vm": +        prefab: 'sles-11sp1-x64' diff --git a/puppet/modules/ntp/.travis.yml b/puppet/modules/ntp/.travis.yml new file mode 100644 index 00000000..e9f0e84b --- /dev/null +++ b/puppet/modules/ntp/.travis.yml @@ -0,0 +1,40 @@ +--- +branches: +  only: +  - master +language: ruby +bundler_args: --without development +script: "bundle exec rake spec SPEC_OPTS='--format documentation'" +after_success: +  - git clone -q git://github.com/puppetlabs/ghpublisher.git .forge-releng +  - .forge-releng/publish +rvm: +- 1.8.7 +- 1.9.3 +- 2.0.0 +env: +  matrix: +    - PUPPET_GEM_VERSION="~> 2.7.0" +    - PUPPET_GEM_VERSION="~> 3.0.0" +    - PUPPET_GEM_VERSION="~> 3.1.0" +    - PUPPET_GEM_VERSION="~> 3.2.0" +  global: +    - PUBLISHER_LOGIN=puppetlabs +    - secure: |- +        ZiIkYd9+CdPzpwSjFPnVkCx1FIlipxpbdyD33q94h2Tj5zXjNb1GXizVy0NR +        kVxGhU5Ld8y9z8DTqKRgCI1Yymg3H//OU++PKLOQj/X5juWVR4URBNPeBOzu +        IJBDl1MADKA4i1+jAZPpz4mTvTtKS4pWKErgCSmhSfsY1hs7n6c= +matrix: +  exclude: +    - rvm: 1.9.3 +      env: PUPPET_GEM_VERSION="~> 2.7.0" +    - rvm: 2.0.0 +      env: PUPPET_GEM_VERSION="~> 2.7.0" +    - rvm: 2.0.0 +      env: PUPPET_GEM_VERSION="~> 3.0.0" +    - rvm: 2.0.0 +      env: PUPPET_GEM_VERSION="~> 3.1.0" +    - rvm: 1.8.7 +      env: PUPPET_GEM_VERSION="~> 3.2.0" +notifications: +  email: false diff --git a/puppet/modules/ntp/CHANGELOG b/puppet/modules/ntp/CHANGELOG new file mode 100644 index 00000000..8be6c4e0 --- /dev/null +++ b/puppet/modules/ntp/CHANGELOG @@ -0,0 +1,61 @@ +2013-07-31 - Version 2.0.0 + +Summary: + +The 2.0 release focuses on merging all the distro specific +templates into a single reusable template across all platforms. + +To aid in that goal we now allow you to change the driftfile, +ntp keys, and perferred_servers. + +Backwards-incompatible changes: + +As all the distro specific templates have been removed and a +unified one created you may be missing functionality you +previously relied on.  Please test carefully before rolling +out globally. + +Configuration directives that might possibly be affected: +- `filegen` +- `fudge` (for virtual machines) +- `keys` +- `logfile` +- `restrict` +- `restrictkey` +- `statistics` +- `trustedkey` + +Features: +- All templates merged into a single template. +- NTP Keys support added. +- Add preferred servers support. +- Parameters in `ntp` class: + - `driftfile`: path for the ntp driftfile. + - `keys_enable`: Enable NTP keys feature. + - `keys_file`: Path for the NTP keys file. + - `keys_trusted`: Which keys to trust. + - `keys_controlkey`: Which key to use for the control key. + - `keys_requestkey`: Which key to use for the request key. + - `preferred_servers`: Array of servers to prefer. + - `restrict`: Array of restriction options to apply. + +2013-07-15 - Version 1.0.1 +Bugfixes: +- Fix deprecated warning in `autoupdate` parameter. +- Correctly quote is_virtual fact. + +2013-07-08 - Version 1.0.0 +Features: +- Completely refactored to split across several classes. +- rspec-puppet tests rewritten to cover more options. +- rspec-system tests added. +- ArchLinux handled via osfamily instead of special casing. +- parameters in `ntp` class: + - `autoupdate`: deprecated in favor of directly setting package_ensure. + - `panic`: set to false if you wish to allow large clock skews.  + +2011-11-10 Dan Bode <dan@puppetlabs.com> - 0.0.4 +Add Amazon Linux as a supported platform +Add unit tests +2011-06-16 Jeff McCune <jeff@puppetlabs.com> - 0.0.3 +Initial release under puppetlabs diff --git a/puppet/modules/ntp/CONTRIBUTING.md b/puppet/modules/ntp/CONTRIBUTING.md new file mode 100644 index 00000000..a2b1d77b --- /dev/null +++ b/puppet/modules/ntp/CONTRIBUTING.md @@ -0,0 +1,9 @@ +Puppet Labs modules on the Puppet Forge are open projects, and community contributions +are essential for keeping them great. We can’t access the huge number of platforms and +myriad of hardware, software, and deployment configurations that Puppet is intended to serve. + +We want to keep it as easy as possible to contribute changes so that our modules work +in your environment. There are a few guidelines that we need contributors to follow so +that we can have a chance of keeping on top of things. + +You can read the complete module contribution guide [on the Puppet Labs wiki.](http://projects.puppetlabs.com/projects/module-site/wiki/Module_contributing) diff --git a/puppet/modules/ntp/Gemfile b/puppet/modules/ntp/Gemfile new file mode 100644 index 00000000..4e733308 --- /dev/null +++ b/puppet/modules/ntp/Gemfile @@ -0,0 +1,19 @@ +source 'https://rubygems.org' + +group :development, :test do +  gem 'rake',                    :require => false +  gem 'puppetlabs_spec_helper',  :require => false +  gem 'rspec-system-puppet',     :require => false +  gem 'puppet-lint',             :require => false +  gem 'serverspec',              :require => false +  gem 'rspec-system-serverspec', :require => false +  gem 'vagrant-wrapper',         :require => false +end + +if puppetversion = ENV['PUPPET_GEM_VERSION'] +  gem 'puppet', puppetversion, :require => false +else +  gem 'puppet', :require => false +end + +# vim:ft=ruby diff --git a/puppet/modules/ntp/LICENSE b/puppet/modules/ntp/LICENSE new file mode 100644 index 00000000..57bc88a1 --- /dev/null +++ b/puppet/modules/ntp/LICENSE @@ -0,0 +1,202 @@ +                                 Apache License +                           Version 2.0, January 2004 +                        http://www.apache.org/licenses/ + +   TERMS AND CONDITIONS FOR USE, REPRODUCTION, AND DISTRIBUTION + +   1. Definitions. + +      "License" shall mean the terms and conditions for use, reproduction, +      and distribution as defined by Sections 1 through 9 of this document. + +      "Licensor" shall mean the copyright owner or entity authorized by +      the copyright owner that is granting the License. + +      "Legal Entity" shall mean the union of the acting entity and all +      other entities that control, are controlled by, or are under common +      control with that entity. For the purposes of this definition, +      "control" means (i) the power, direct or indirect, to cause the +      direction or management of such entity, whether by contract or +      otherwise, or (ii) ownership of fifty percent (50%) or more of the +      outstanding shares, or (iii) beneficial ownership of such entity. + +      "You" (or "Your") shall mean an individual or Legal Entity +      exercising permissions granted by this License. + +      "Source" form shall mean the preferred form for making modifications, +      including but not limited to software source code, documentation +      source, and configuration files. + +      "Object" form shall mean any form resulting from mechanical +      transformation or translation of a Source form, including but +      not limited to compiled object code, generated documentation, +      and conversions to other media types. + +      "Work" shall mean the work of authorship, whether in Source or +      Object form, made available under the License, as indicated by a +      copyright notice that is included in or attached to the work +      (an example is provided in the Appendix below). + +      "Derivative Works" shall mean any work, whether in Source or Object +      form, that is based on (or derived from) the Work and for which the +      editorial revisions, annotations, elaborations, or other modifications +      represent, as a whole, an original work of authorship. For the purposes +      of this License, Derivative Works shall not include works that remain +      separable from, or merely link (or bind by name) to the interfaces of, +      the Work and Derivative Works thereof. + +      "Contribution" shall mean any work of authorship, including +      the original version of the Work and any modifications or additions +      to that Work or Derivative Works thereof, that is intentionally +      submitted to Licensor for inclusion in the Work by the copyright owner +      or by an individual or Legal Entity authorized to submit on behalf of +      the copyright owner. For the purposes of this definition, "submitted" +      means any form of electronic, verbal, or written communication sent +      to the Licensor or its representatives, including but not limited to +      communication on electronic mailing lists, source code control systems, +      and issue tracking systems that are managed by, or on behalf of, the +      Licensor for the purpose of discussing and improving the Work, but +      excluding communication that is conspicuously marked or otherwise +      designated in writing by the copyright owner as "Not a Contribution." + +      "Contributor" shall mean Licensor and any individual or Legal Entity +      on behalf of whom a Contribution has been received by Licensor and +      subsequently incorporated within the Work. + +   2. Grant of Copyright License. Subject to the terms and conditions of +      this License, each Contributor hereby grants to You a perpetual, +      worldwide, non-exclusive, no-charge, royalty-free, irrevocable +      copyright license to reproduce, prepare Derivative Works of, +      publicly display, publicly perform, sublicense, and distribute the +      Work and such Derivative Works in Source or Object form. + +   3. Grant of Patent License. Subject to the terms and conditions of +      this License, each Contributor hereby grants to You a perpetual, +      worldwide, non-exclusive, no-charge, royalty-free, irrevocable +      (except as stated in this section) patent license to make, have made, +      use, offer to sell, sell, import, and otherwise transfer the Work, +      where such license applies only to those patent claims licensable +      by such Contributor that are necessarily infringed by their +      Contribution(s) alone or by combination of their Contribution(s) +      with the Work to which such Contribution(s) was submitted. If You +      institute patent litigation against any entity (including a +      cross-claim or counterclaim in a lawsuit) alleging that the Work +      or a Contribution incorporated within the Work constitutes direct +      or contributory patent infringement, then any patent licenses +      granted to You under this License for that Work shall terminate +      as of the date such litigation is filed. + +   4. Redistribution. You may reproduce and distribute copies of the +      Work or Derivative Works thereof in any medium, with or without +      modifications, and in Source or Object form, provided that You +      meet the following conditions: + +      (a) You must give any other recipients of the Work or +          Derivative Works a copy of this License; and + +      (b) You must cause any modified files to carry prominent notices +          stating that You changed the files; and + +      (c) You must retain, in the Source form of any Derivative Works +          that You distribute, all copyright, patent, trademark, and +          attribution notices from the Source form of the Work, +          excluding those notices that do not pertain to any part of +          the Derivative Works; and + +      (d) If the Work includes a "NOTICE" text file as part of its +          distribution, then any Derivative Works that You distribute must +          include a readable copy of the attribution notices contained +          within such NOTICE file, excluding those notices that do not +          pertain to any part of the Derivative Works, in at least one +          of the following places: within a NOTICE text file distributed +          as part of the Derivative Works; within the Source form or +          documentation, if provided along with the Derivative Works; or, +          within a display generated by the Derivative Works, if and +          wherever such third-party notices normally appear. The contents +          of the NOTICE file are for informational purposes only and +          do not modify the License. You may add Your own attribution +          notices within Derivative Works that You distribute, alongside +          or as an addendum to the NOTICE text from the Work, provided +          that such additional attribution notices cannot be construed +          as modifying the License. + +      You may add Your own copyright statement to Your modifications and +      may provide additional or different license terms and conditions +      for use, reproduction, or distribution of Your modifications, or +      for any such Derivative Works as a whole, provided Your use, +      reproduction, and distribution of the Work otherwise complies with +      the conditions stated in this License. + +   5. Submission of Contributions. Unless You explicitly state otherwise, +      any Contribution intentionally submitted for inclusion in the Work +      by You to the Licensor shall be under the terms and conditions of +      this License, without any additional terms or conditions. +      Notwithstanding the above, nothing herein shall supersede or modify +      the terms of any separate license agreement you may have executed +      with Licensor regarding such Contributions. + +   6. Trademarks. This License does not grant permission to use the trade +      names, trademarks, service marks, or product names of the Licensor, +      except as required for reasonable and customary use in describing the +      origin of the Work and reproducing the content of the NOTICE file. + +   7. Disclaimer of Warranty. Unless required by applicable law or +      agreed to in writing, Licensor provides the Work (and each +      Contributor provides its Contributions) on an "AS IS" BASIS, +      WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or +      implied, including, without limitation, any warranties or conditions +      of TITLE, NON-INFRINGEMENT, MERCHANTABILITY, or FITNESS FOR A +      PARTICULAR PURPOSE. You are solely responsible for determining the +      appropriateness of using or redistributing the Work and assume any +      risks associated with Your exercise of permissions under this License. + +   8. Limitation of Liability. In no event and under no legal theory, +      whether in tort (including negligence), contract, or otherwise, +      unless required by applicable law (such as deliberate and grossly +      negligent acts) or agreed to in writing, shall any Contributor be +      liable to You for damages, including any direct, indirect, special, +      incidental, or consequential damages of any character arising as a +      result of this License or out of the use or inability to use the +      Work (including but not limited to damages for loss of goodwill, +      work stoppage, computer failure or malfunction, or any and all +      other commercial damages or losses), even if such Contributor +      has been advised of the possibility of such damages. + +   9. Accepting Warranty or Additional Liability. While redistributing +      the Work or Derivative Works thereof, You may choose to offer, +      and charge a fee for, acceptance of support, warranty, indemnity, +      or other liability obligations and/or rights consistent with this +      License. However, in accepting such obligations, You may act only +      on Your own behalf and on Your sole responsibility, not on behalf +      of any other Contributor, and only if You agree to indemnify, +      defend, and hold each Contributor harmless for any liability +      incurred by, or claims asserted against, such Contributor by reason +      of your accepting any such warranty or additional liability. + +   END OF TERMS AND CONDITIONS + +   APPENDIX: How to apply the Apache License to your work. + +      To apply the Apache License to your work, attach the following +      boilerplate notice, with the fields enclosed by brackets "[]" +      replaced with your own identifying information. (Don't include +      the brackets!)  The text should be enclosed in the appropriate +      comment syntax for the file format. We also recommend that a +      file or class name and description of purpose be included on the +      same "printed page" as the copyright notice for easier +      identification within third-party archives. + +   Copyright [yyyy] [name of copyright owner] + +   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. + diff --git a/puppet/modules/ntp/Modulefile b/puppet/modules/ntp/Modulefile new file mode 100644 index 00000000..9610ef67 --- /dev/null +++ b/puppet/modules/ntp/Modulefile @@ -0,0 +1,11 @@ +name    'puppetlabs-ntp' +version '2.0.0-rc1' +source 'git://github.com/puppetlabs/puppetlabs-ntp' +author 'Puppet Labs' +license 'Apache Version 2.0' +summary 'NTP Module' +description 'NTP Module for Debian, Ubuntu, CentOS, RHEL, OEL, Fedora, FreeBSD, ArchLinux and Gentoo.' +project_page 'http://github.com/puppetlabs/puppetlabs-ntp' + +## Add dependencies, if any: +dependency 'puppetlabs/stdlib', '>= 0.1.6' diff --git a/puppet/modules/ntp/README.markdown b/puppet/modules/ntp/README.markdown new file mode 100644 index 00000000..3aedd47a --- /dev/null +++ b/puppet/modules/ntp/README.markdown @@ -0,0 +1,215 @@ +#ntp + +####Table of Contents + +1. [Overview](#overview) +2. [Module Description - What the module does and why it is useful](#module-description) +3. [Setup - The basics of getting started with ntp](#setup) +    * [What ntp affects](#what-ntp-affects) +    * [Setup requirements](#setup-requirements) +    * [Beginning with ntp](#beginning-with-ntp) +4. [Usage - Configuration options and additional functionality](#usage) +5. [Reference - An under-the-hood peek at what the module is doing and how](#reference) +5. [Limitations - OS compatibility, etc.](#limitations) +6. [Development - Guide for contributing to the module](#development) + +##Overview + +The NTP module installs, configures, and manages the ntp service. + +##Module Description + +The NTP module handles running NTP across a range of operating systems and +distributions.  Where possible we use the upstream ntp templates so that the +results closely match what you'd get if you modified the package default conf +files. + +##Setup + +###What ntp affects + +* ntp package. +* ntp configuration file. +* ntp service. + +###Beginning with ntp + +include '::ntp' is enough to get you up and running.  If you wish to pass in +parameters like which servers to use then you can use: + +```puppet +class { '::ntp': +  servers => [ 'ntp1.corp.com', 'ntp2.corp.com' ], +} +``` + +##Usage + +All interaction with the ntp module can do be done through the main ntp class. +This means you can simply toggle the options in the ntp class to get at the +full functionality. + +###I just want NTP, what's the minimum I need? + +```puppet +include '::ntp' +``` + +###I just want to tweak the servers, nothing else. + +```puppet +class { '::ntp': +  servers => [ 'ntp1.corp.com', 'ntp2.corp.com' ], +} +``` + +###I'd like to make sure I restrict who can connect as well. + +```puppet +class { '::ntp': +  servers  => [ 'ntp1.corp.com', 'ntp2.corp.com' ], +  restrict => 'restrict 127.0.0.1', +} +``` + +###I'd like to opt out of having the service controlled, we use another tool for that. + +```puppet +class { '::ntp': +  servers        => [ 'ntp1.corp.com', 'ntp2.corp.com' ], +  restrict       => 'restrict 127.0.0.1', +  manage_service => false, +} +``` + +###Looks great!  But I'd like a different template, we need to do something unique here. + +```puppet +class { '::ntp': +  servers         => [ 'ntp1.corp.com', 'ntp2.corp.com' ], +  restrict        => 'restrict 127.0.0.1', +  manage_service  => false, +  config_template => 'different/module/custom.template.erb', +} +``` + +##Reference + +###Classes + +* ntp: Main class, includes all the rest. +* ntp::install: Handles the packages. +* ntp::config: Handles the configuration file. +* ntp::service: Handles the service. + +###Parameters + +The following parameters are available in the ntp module + +####`autoupdate` + +Deprecated: This parameter previously determined if the ntp module should be +automatically updated to the latest version available.  Replaced by package\_ +ensure. + +####`config` + +This sets the file to write ntp configuration into. + +####`config_template` + +This determines which template puppet should use for the ntp configuration. + +####`driftfile` + +This sets the location of the driftfile for ntp. + +####`keys_controlkey` + +Which of the keys is used as the control key. + +####`keys_enable` + +Should the ntp keys functionality be enabled. + +####`keys_file` + +Location of the keys file. + +####`keys_requestkey` + +Which of the keys is used as the request key. + +####`package_ensure` + +This can be set to 'present' or 'latest' or a specific version to choose the +ntp package to be installed. + +####`package_name` + +This determines the name of the package to install. + +####`panic` + +This determines if ntp should 'panic' in the event of a very large clock skew. +We set this to false if you're on a virtual machine by default as they don't +do a great job with keeping time. + +####`preferred_servers` + +List of ntp servers to prefer.  Will append prefer for any server in this list +that also appears in the servers list. + +####`restrict` + +This sets the restrict options in the ntp configuration. + +####`servers` + +This selects the servers to use for ntp peers. + +####`service_enable` + +This determines if the service should be enabled at boot. + +####`service_ensure` + +This determines if the service should be running or not. + +####`service_manage` + +This selects if puppet should manage the service in the first place. + +####`service_name` + +This selects the name of the ntp service for puppet to manage. + + +##Limitations + +This module has been built on and tested against Puppet 2.7 and higher. + +The module has been tested on: + +* RedHat Enterprise Linux 5/6 +* Debian 6/7 +* CentOS 5/6 +* Ubuntu 12.04 +* Gentoo +* Arch Linux +* FreeBSD + +Testing on other platforms has been light and cannot be guaranteed.  + +##Development + +Puppet Labs modules on the Puppet Forge are open projects, and community +contributions are essential for keeping them great. We can’t access the +huge number of platforms and myriad of hardware, software, and deployment +configurations that Puppet is intended to serve. + +We want to keep it as easy as possible to contribute changes so that our +modules work in your environment. There are a few guidelines that we need +contributors to follow so that we can have a chance of keeping on top of things. + +You can read the complete module contribution guide [on the Puppet Labs wiki.](http://projects.puppetlabs.com/projects/module-site/wiki/Module_contributing) diff --git a/puppet/modules/ntp/Rakefile b/puppet/modules/ntp/Rakefile new file mode 100644 index 00000000..bb60173e --- /dev/null +++ b/puppet/modules/ntp/Rakefile @@ -0,0 +1,2 @@ +require 'puppetlabs_spec_helper/rake_tasks' +require 'rspec-system/rake_task' diff --git a/puppet/modules/ntp/manifests/config.pp b/puppet/modules/ntp/manifests/config.pp new file mode 100644 index 00000000..1c8963dc --- /dev/null +++ b/puppet/modules/ntp/manifests/config.pp @@ -0,0 +1,23 @@ +# +class ntp::config inherits ntp { + +  if $keys_enable { +    $directory = dirname($keys_file) +    file { $directory: +      ensure  => directory, +      owner   => 0, +      group   => 0, +      mode    => '0755', +      recurse => true, +    } +  } + +  file { $config: +    ensure  => file, +    owner   => 0, +    group   => 0, +    mode    => '0644', +    content => template($config_template), +  } + +} diff --git a/puppet/modules/ntp/manifests/init.pp b/puppet/modules/ntp/manifests/init.pp new file mode 100644 index 00000000..be951187 --- /dev/null +++ b/puppet/modules/ntp/manifests/init.pp @@ -0,0 +1,58 @@ +class ntp ( +  $autoupdate        = $ntp::params::autoupdate, +  $config            = $ntp::params::config, +  $config_template   = $ntp::params::config_template, +  $driftfile         = $ntp::params::driftfile, +  $keys_enable       = $ntp::params::keys_enable, +  $keys_file         = $ntp::params::keys_file, +  $keys_controlkey   = $ntp::params::keys_controlkey, +  $keys_requestkey   = $ntp::params::keys_requestkey, +  $keys_trusted      = $ntp::params::keys_trusted, +  $package_ensure    = $ntp::params::package_ensure, +  $package_name      = $ntp::params::package_name, +  $panic             = $ntp::params::panic, +  $preferred_servers = $ntp::params::preferred_servers, +  $restrict          = $ntp::params::restrict, +  $servers           = $ntp::params::servers, +  $service_enable    = $ntp::params::service_enable, +  $service_ensure    = $ntp::params::service_ensure, +  $service_manage    = $ntp::params::service_manage, +  $service_name      = $ntp::params::service_name, +) inherits ntp::params { + +  validate_absolute_path($config) +  validate_string($config_template) +  validate_absolute_path($driftfile) +  validate_bool($keys_enable) +  validate_re($keys_controlkey, ['^\d+$', '']) +  validate_re($keys_requestkey, ['^\d+$', '']) +  validate_array($keys_trusted) +  validate_string($package_ensure) +  validate_array($package_name) +  validate_bool($panic) +  validate_array($preferred_servers) +  validate_array($restrict) +  validate_array($servers) +  validate_bool($service_enable) +  validate_string($service_ensure) +  validate_bool($service_manage) +  validate_string($service_name) + +  if $autoupdate { +    notice('autoupdate parameter has been deprecated and replaced with package_ensure.  Set this to latest for the same behavior as autoupdate => true.') +  } + +  include '::ntp::install' +  include '::ntp::config' +  include '::ntp::service' + +  # Anchor this as per #8040 - this ensures that classes won't float off and +  # mess everything up.  You can read about this at: +  # http://docs.puppetlabs.com/puppet/2.7/reference/lang_containment.html#known-issues +  anchor { 'ntp::begin': } +  anchor { 'ntp::end': } + +  Anchor['ntp::begin'] -> Class['::ntp::install'] -> Class['::ntp::config'] +    ~> Class['::ntp::service'] -> Anchor['ntp::end'] + +} diff --git a/puppet/modules/ntp/manifests/install.pp b/puppet/modules/ntp/manifests/install.pp new file mode 100644 index 00000000..098949c3 --- /dev/null +++ b/puppet/modules/ntp/manifests/install.pp @@ -0,0 +1,9 @@ +# +class ntp::install inherits ntp { + +  package { 'ntp': +    ensure => $package_ensure, +    name   => $package_name, +  } + +} diff --git a/puppet/modules/ntp/manifests/params.pp b/puppet/modules/ntp/manifests/params.pp new file mode 100644 index 00000000..10a4fb2b --- /dev/null +++ b/puppet/modules/ntp/manifests/params.pp @@ -0,0 +1,116 @@ +class ntp::params { + +  $autoupdate        = false +  $config_template   = 'ntp/ntp.conf.erb' +  $keys_enable       = false +  $keys_controlkey   = '' +  $keys_requestkey   = '' +  $keys_trusted      = [] +  $package_ensure    = 'present' +  $preferred_servers = [] +  $restrict          = [ +    'restrict default kod nomodify notrap nopeer noquery', +    'restrict -6 default kod nomodify notrap nopeer noquery', +    'restrict 127.0.0.1', +    'restrict -6 ::1', +  ] +  $service_enable    = true +  $service_ensure    = 'running' +  $service_manage    = true + +  # On virtual machines allow large clock skews. +  $panic = str2bool($::is_virtual) ? { +    true    => false, +    default => true, +  } + +  case $::osfamily { +    'Debian': { +      $config          = '/etc/ntp.conf' +      $keys_file       = '/etc/ntp/keys' +      $driftfile       = '/var/lib/ntp/drift' +      $package_name    = [ 'ntp' ] +      $service_name    = 'ntp' +      $servers         = [ +        '0.debian.pool.ntp.org iburst', +        '1.debian.pool.ntp.org iburst', +        '2.debian.pool.ntp.org iburst', +        '3.debian.pool.ntp.org iburst', +      ] +    } +    'RedHat': { +      $config          = '/etc/ntp.conf' +      $driftfile       = '/var/lib/ntp/drift' +      $keys_file       = '/etc/ntp/keys' +      $package_name    = [ 'ntp' ] +      $service_name    = 'ntpd' +      $servers         = [ +        '0.centos.pool.ntp.org', +        '1.centos.pool.ntp.org', +        '2.centos.pool.ntp.org', +      ] +    } +    'SuSE': { +      $config          = '/etc/ntp.conf' +      $driftfile       = '/var/lib/ntp/drift/ntp.drift' +      $keys_file       = '/etc/ntp/keys' +      $package_name    = [ 'ntp' ] +      $service_name    = 'ntp' +      $servers         = [ +        '0.opensuse.pool.ntp.org', +        '1.opensuse.pool.ntp.org', +        '2.opensuse.pool.ntp.org', +        '3.opensuse.pool.ntp.org', +      ] +    } +    'FreeBSD': { +      $config          = '/etc/ntp.conf' +      $driftfile       = '/var/db/ntpd.drift' +      $keys_file       = '/etc/ntp/keys' +      $package_name    = ['net/ntp'] +      $service_name    = 'ntpd' +      $servers         = [ +        '0.freebsd.pool.ntp.org iburst maxpoll 9', +        '1.freebsd.pool.ntp.org iburst maxpoll 9', +        '2.freebsd.pool.ntp.org iburst maxpoll 9', +        '3.freebsd.pool.ntp.org iburst maxpoll 9', +      ] +    } +    'Archlinux': { +      $config          = '/etc/ntp.conf' +      $driftfile       = '/var/lib/ntp/drift' +      $keys_file       = '/etc/ntp/keys' +      $package_name    = [ 'ntp' ] +      $service_name    = 'ntpd' +      $servers         = [ +        '0.pool.ntp.org', +        '1.pool.ntp.org', +        '2.pool.ntp.org', +      ] +    } +    'Linux': { +      # Account for distributions that don't have $::osfamily specific settings. +      case $::operatingsystem { +        'Gentoo': { +          $config          = '/etc/ntp.conf' +          $driftfile       = '/var/lib/ntp/drift' +          $keys_file       = '/etc/ntp/keys' +          $package_name    = ['net-misc/ntp'] +          $service_name    = 'ntpd' +          $servers         = [ +            '0.gentoo.pool.ntp.org', +            '1.gentoo.pool.ntp.org', +            '2.gentoo.pool.ntp.org', +            '3.gentoo.pool.ntp.org', +          ] +        } +        default: { +          fail("The ${module_name} module is not supported on an ${::operatingsystem} distribution.") +        } +      } +    } +    default: { +      fail("The ${module_name} module is not supported on an ${::osfamily} based system.") +    } +  } +} diff --git a/puppet/modules/ntp/manifests/service.pp b/puppet/modules/ntp/manifests/service.pp new file mode 100644 index 00000000..3f1ada0b --- /dev/null +++ b/puppet/modules/ntp/manifests/service.pp @@ -0,0 +1,18 @@ +# +class ntp::service inherits ntp { + +  if ! ($service_ensure in [ 'running', 'stopped' ]) { +    fail('service_ensure parameter must be running or stopped') +  } + +  if $service_manage == true { +    service { 'ntp': +      ensure     => $service_ensure, +      enable     => $service_enable, +      name       => $service_name, +      hasstatus  => true, +      hasrestart => true, +    } +  } + +} diff --git a/puppet/modules/ntp/spec/classes/ntp_spec.rb b/puppet/modules/ntp/spec/classes/ntp_spec.rb new file mode 100644 index 00000000..6c636f40 --- /dev/null +++ b/puppet/modules/ntp/spec/classes/ntp_spec.rb @@ -0,0 +1,261 @@ +require 'spec_helper' + +describe 'ntp' do + +  ['Debian', 'RedHat','SuSE', 'FreeBSD', 'Archlinux', 'Gentoo'].each do |system| +    if system == 'Gentoo' +      let(:facts) {{ :osfamily => 'Linux', :operatingsystem => system }} +    else +      let(:facts) {{ :osfamily => system }} +    end + +    it { should include_class('ntp::install') } +    it { should include_class('ntp::config') } +    it { should include_class('ntp::service') } + +    describe 'ntp::config on #{system}' do +      it { should contain_file('/etc/ntp.conf').with_owner('0') } +      it { should contain_file('/etc/ntp.conf').with_group('0') } +      it { should contain_file('/etc/ntp.conf').with_mode('0644') } + +      describe 'allows template to be overridden' do +        let(:params) {{ :config_template => 'my_ntp/ntp.conf.erb' }} +        it { should contain_file('/etc/ntp.conf').with({ +          'content' => /server foobar/}) +        } +      end + +      describe "keys for osfamily #{system}" do +        context "when enabled" do +          let(:params) {{ +            :keys_enable     => true, +            :keys_file       => '/etc/ntp/ntp.keys', +            :keys_trusted    => ['1', '2', '3'], +            :keys_controlkey => '2', +            :keys_requestkey => '3', +          }} + +          it { should contain_file('/etc/ntp').with({ +            'ensure'  => 'directory'}) +          } +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /trustedkey 1 2 3/}) +          } +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /controlkey 2/}) +          } +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /requestkey 3/}) +          } +        end +      end + +      context "when disabled" do +        let(:params) {{ +          :keys_enable     => false, +          :keys_file       => '/etc/ntp/ntp.keys', +          :keys_trusted    => ['1', '2', '3'], +          :keys_controlkey => '2', +          :keys_requestkey => '3', +        }} + +        it { should_not contain_file('/etc/ntp').with({ +          'ensure'  => 'directory'}) +        } +        it { should_not contain_file('/etc/ntp.conf').with({ +          'content' => /trustedkey 1 2 3/}) +        } +        it { should_not contain_file('/etc/ntp.conf').with({ +          'content' => /controlkey 2/}) +        } +        it { should_not contain_file('/etc/ntp.conf').with({ +          'content' => /requestkey 3/}) +        } +      end + +      describe 'preferred servers' do +        context "when set" do +          let(:params) {{ +            :servers           => ['a', 'b', 'c', 'd'], +            :preferred_servers => ['a', 'b'] +          }} + +          it { should contain_file('/etc/ntp.conf').with({ +            'content' => /server a prefer\nserver b prefer\nserver c\nserver d/}) +          } +        end +        context "when not set" do +          let(:params) {{ +            :servers           => ['a', 'b', 'c', 'd'], +            :preferred_servers => [] +          }} + +          it { should_not contain_file('/etc/ntp.conf').with({ +            'content' => /server a prefer/}) +          } +        end +      end + +      describe 'ntp::install on #{system}' do +        let(:params) {{ :package_ensure => 'present', :package_name => ['ntp'], }} + +        it { should contain_package('ntp').with( +          :ensure => 'present', +          :name   => 'ntp' +        )} + +        describe 'should allow package ensure to be overridden' do +          let(:params) {{ :package_ensure => 'latest', :package_name => ['ntp'] }} +          it { should contain_package('ntp').with_ensure('latest') } +        end + +        describe 'should allow the package name to be overridden' do +          let(:params) {{ :package_ensure => 'present', :package_name => ['hambaby'] }} +          it { should contain_package('ntp').with_name('hambaby') } +        end +      end + +      describe 'ntp::service' do +        let(:params) {{ +          :service_manage => true, +          :service_enable => true, +          :service_ensure => 'running', +          :service_name   => 'ntp' +        }} + +        describe 'with defaults' do +          it { should contain_service('ntp').with( +            :enable => true, +            :ensure => 'running', +            :name   => 'ntp' +          )} +        end + +        describe 'service_ensure' do +          describe 'when overridden' do +            let(:params) {{ :service_name => 'ntp', :service_ensure => 'stopped' }} +            it { should contain_service('ntp').with_ensure('stopped') } +          end +        end + +        describe 'service_manage' do +          let(:params) {{ +            :service_manage => false, +            :service_enable => true, +            :service_ensure => 'running', +            :service_name   => 'ntpd', +          }} + +          it 'when set to false' do +            should_not contain_service('ntp').with({ +              'enable' => true, +              'ensure' => 'running', +              'name'   => 'ntpd' +            }) +          end +        end +      end +    end + +    context 'ntp::config' do +      describe "for operating system Gentoo" do +        let(:facts) {{ :operatingsystem => 'Gentoo', +                       :osfamily        => 'Linux' }} + +        it 'uses the NTP pool servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.gentoo.pool.ntp.org/, +          }) +        end +      end +      describe "on osfamily Debian" do +        let(:facts) {{ :osfamily => 'debian' }} + +        it 'uses the debian ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.debian.pool.ntp.org iburst/, +          }) +        end +      end + +      describe "on osfamily RedHat" do +        let(:facts) {{ :osfamily => 'RedHat' }} + +        it 'uses the redhat ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.centos.pool.ntp.org/, +          }) +        end +      end + +      describe "on osfamily SuSE" do +        let(:facts) {{ :osfamily => 'SuSE' }} + +        it 'uses the opensuse ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.opensuse.pool.ntp.org/, +          }) +        end +      end + +      describe "on osfamily FreeBSD" do +        let(:facts) {{ :osfamily => 'FreeBSD' }} + +        it 'uses the freebsd ntp servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.freebsd.pool.ntp.org iburst maxpoll 9/, +          }) +        end +      end + +      describe "on osfamily ArchLinux" do +        let(:facts) {{ :osfamily => 'ArchLinux' }} + +        it 'uses the NTP pool servers by default' do +          should contain_file('/etc/ntp.conf').with({ +            'content' => /server \d.pool.ntp.org/, +          }) +        end +      end + +      describe "for operating system family unsupported" do +        let(:facts) {{ +          :osfamily  => 'unsupported', +        }} + +        it { expect{ subject }.to raise_error( +          /^The ntp module is not supported on an unsupported based system./ +        )} +      end +    end + +    describe 'for virtual machines' do +      let(:facts) {{ :osfamily        => 'Archlinux', +                     :is_virtual      => 'true' }} + +      it 'should not use local clock as a time source' do +        should_not contain_file('/etc/ntp.conf').with({ +          'content' => /server.*127.127.1.0.*fudge.*127.127.1.0 stratum 10/, +        }) +      end + +      it 'allows large clock skews' do +        should contain_file('/etc/ntp.conf').with({ +          'content' => /tinker panic 0/, +        }) +      end +    end + +    describe 'for physical machines' do +      let(:facts) {{ :osfamily        => 'Archlinux', +                     :is_virtual      => 'false' }} + +      it 'disallows large clock skews' do +        should_not contain_file('/etc/ntp.conf').with({ +          'content' => /tinker panic 0/, +        }) +      end +    end +  end + +end diff --git a/puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb b/puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb new file mode 100644 index 00000000..40cf67c6 --- /dev/null +++ b/puppet/modules/ntp/spec/fixtures/modules/my_ntp/templates/ntp.conf.erb @@ -0,0 +1,4 @@ +#my uber ntp config +# + +server foobar diff --git a/puppet/modules/ntp/spec/spec.opts b/puppet/modules/ntp/spec/spec.opts new file mode 100644 index 00000000..91cd6427 --- /dev/null +++ b/puppet/modules/ntp/spec/spec.opts @@ -0,0 +1,6 @@ +--format +s +--colour +--loadby +mtime +--backtrace diff --git a/puppet/modules/ntp/spec/spec_helper.rb b/puppet/modules/ntp/spec/spec_helper.rb new file mode 100644 index 00000000..2c6f5664 --- /dev/null +++ b/puppet/modules/ntp/spec/spec_helper.rb @@ -0,0 +1 @@ +require 'puppetlabs_spec_helper/module_spec_helper' diff --git a/puppet/modules/ntp/spec/spec_helper_system.rb b/puppet/modules/ntp/spec/spec_helper_system.rb new file mode 100644 index 00000000..d5208463 --- /dev/null +++ b/puppet/modules/ntp/spec/spec_helper_system.rb @@ -0,0 +1,26 @@ +require 'rspec-system/spec_helper' +require 'rspec-system-puppet/helpers' +require 'rspec-system-serverspec/helpers' +include Serverspec::Helper::RSpecSystem +include Serverspec::Helper::DetectOS +include RSpecSystemPuppet::Helpers + +RSpec.configure do |c| +  # Project root +  proj_root = File.expand_path(File.join(File.dirname(__FILE__), '..')) + +  # Enable colour +  c.tty = true + +  c.include RSpecSystemPuppet::Helpers + +  # This is where we 'setup' the nodes before running our tests +  c.before :suite do +    # Install puppet +    puppet_install + +    # Install modules and dependencies +    puppet_module_install(:source => proj_root, :module_name => 'ntp') +    shell('puppet module install puppetlabs-stdlib') +  end +end diff --git a/puppet/modules/ntp/spec/system/basic_spec.rb b/puppet/modules/ntp/spec/system/basic_spec.rb new file mode 100644 index 00000000..7b717a04 --- /dev/null +++ b/puppet/modules/ntp/spec/system/basic_spec.rb @@ -0,0 +1,13 @@ +require 'spec_helper_system' + +# Here we put the more basic fundamental tests, ultra obvious stuff. +describe "basic tests:" do +  context 'make sure we have copied the module across' do +    # No point diagnosing any more if the module wasn't copied properly +    context shell 'ls /etc/puppet/modules/ntp' do +      its(:stdout) { should =~ /Modulefile/ } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end +end diff --git a/puppet/modules/ntp/spec/system/class_spec.rb b/puppet/modules/ntp/spec/system/class_spec.rb new file mode 100644 index 00000000..49dfc641 --- /dev/null +++ b/puppet/modules/ntp/spec/system/class_spec.rb @@ -0,0 +1,39 @@ +require 'spec_helper_system' + +describe "ntp class:" do +  context 'should run successfully' do +    pp = "class { 'ntp': }" + +    context puppet_apply(pp) do +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end + +  context 'service_ensure => stopped:' do +    pp = "class { 'ntp': service_ensure => stopped }" + +    context puppet_apply(pp) do +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end + +  context 'service_ensure => running:' do +    pp = "class { 'ntp': service_ensure => running }" + +    context puppet_apply(pp) do |r| +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end +end diff --git a/puppet/modules/ntp/spec/system/ntp_config_spec.rb b/puppet/modules/ntp/spec/system/ntp_config_spec.rb new file mode 100644 index 00000000..194cdf10 --- /dev/null +++ b/puppet/modules/ntp/spec/system/ntp_config_spec.rb @@ -0,0 +1,35 @@ +require 'spec_helper_system' + +describe 'ntp::config class' do +  let(:os) { +    node.facts['osfamily'] +  } + +  puppet_apply(%{ +    class { 'ntp': } +  }) + +  case node.facts['osfamily'] +  when 'FreeBSD' +    line = '0.freebsd.pool.ntp.org iburst maxpoll 9' +  when 'Debian' +    line = '0.debian.pool.ntp.org iburst' +  when 'RedHat' +    line = '0.centos.pool.ntp.org' +  when 'SuSE' +    line = '0.opensuse.pool.ntp.org' +  when 'Linux' +    case node.facts['operatingsystem'] +    when 'ArchLinux' +      line = '0.pool.ntp.org' +    when 'Gentoo' +      line = '0.gentoo.pool.ntp.org' +    end +  end + +  describe file('/etc/ntp.conf') do +    it { should be_file } +    it { should contain line } +  end + +end diff --git a/puppet/modules/ntp/spec/system/ntp_install_spec.rb b/puppet/modules/ntp/spec/system/ntp_install_spec.rb new file mode 100644 index 00000000..39759c5e --- /dev/null +++ b/puppet/modules/ntp/spec/system/ntp_install_spec.rb @@ -0,0 +1,31 @@ +require 'spec_helper_system' + + +describe 'ntp::install class' do +  let(:os) { +    node.facts['osfamily'] +  } + +  case node.facts['osfamily'] +  when 'FreeBSD' +    packagename = 'net/ntp' +  when 'Linux' +    case node.facts['operatingsystem'] +    when 'ArchLinux' +      packagename = 'ntp' +    when 'Gentoo' +      packagename = 'net-misc/ntp' +    end +  else +    packagename = 'ntp' +  end + +  puppet_apply(%{ +    class { 'ntp': } +  }) + +  describe package(packagename) do +    it { should be_installed } +  end + +end diff --git a/puppet/modules/ntp/spec/system/ntp_service_spec.rb b/puppet/modules/ntp/spec/system/ntp_service_spec.rb new file mode 100644 index 00000000..b97e2a4e --- /dev/null +++ b/puppet/modules/ntp/spec/system/ntp_service_spec.rb @@ -0,0 +1,25 @@ +require 'spec_helper_system' + + +describe 'ntp::service class' do +  let(:os) { +    node.facts['osfamily'] +  } + +  case node.facts['osfamily'] +  when 'RedHat', 'FreeBSD', 'Linux' +    servicename = 'ntpd' +  else +    servicename = 'ntp' +  end + +  puppet_apply(%{ +    class { 'ntp': } +  }) + +  describe service(servicename) do +    it { should be_enabled } +    it { should be_running } +  end + +end diff --git a/puppet/modules/ntp/spec/system/preferred_servers_spec.rb b/puppet/modules/ntp/spec/system/preferred_servers_spec.rb new file mode 100644 index 00000000..686861bc --- /dev/null +++ b/puppet/modules/ntp/spec/system/preferred_servers_spec.rb @@ -0,0 +1,20 @@ +require 'spec_helper_system' + +describe 'preferred servers' do +  it 'applies cleanly' do +    puppet_apply(%{ +      class { '::ntp': +        servers           => ['a', 'b', 'c', 'd'], +        preferred_servers => ['c', 'd'], +      } +    }) +  end + +  describe file('/etc/ntp.conf') do +    it { should be_file } +    it { should contain 'server a' } +    it { should contain 'server b' } +    it { should contain 'server c prefer' } +    it { should contain 'server d prefer' } +  end +end diff --git a/puppet/modules/ntp/spec/system/restrict_spec.rb b/puppet/modules/ntp/spec/system/restrict_spec.rb new file mode 100644 index 00000000..ae23bc01 --- /dev/null +++ b/puppet/modules/ntp/spec/system/restrict_spec.rb @@ -0,0 +1,20 @@ +require 'spec_helper_system' + +describe "ntp class with restrict:" do +  context 'should run successfully' do +    pp = "class { 'ntp': restrict => ['test restrict']}" + +    context puppet_apply(pp) do +      its(:stderr) { should be_empty } +      its(:exit_code) { should_not == 1 } +      its(:refresh) { should be_nil } +      its(:stderr) { should be_empty } +      its(:exit_code) { should be_zero } +    end +  end + +  describe file('/etc/ntp.conf') do +    it { should contain('test restrict') } +  end + +end diff --git a/puppet/modules/ntp/spec/unit/puppet/provider/README.markdown b/puppet/modules/ntp/spec/unit/puppet/provider/README.markdown new file mode 100644 index 00000000..70258502 --- /dev/null +++ b/puppet/modules/ntp/spec/unit/puppet/provider/README.markdown @@ -0,0 +1,4 @@ +Provider Specs +============== + +Define specs for your providers under this directory. diff --git a/puppet/modules/ntp/spec/unit/puppet/type/README.markdown b/puppet/modules/ntp/spec/unit/puppet/type/README.markdown new file mode 100644 index 00000000..1ee19ac8 --- /dev/null +++ b/puppet/modules/ntp/spec/unit/puppet/type/README.markdown @@ -0,0 +1,4 @@ +Resource Type Specs +=================== + +Define specs for your resource types in this directory. diff --git a/puppet/modules/ntp/templates/ntp.conf.erb b/puppet/modules/ntp/templates/ntp.conf.erb new file mode 100644 index 00000000..94b36755 --- /dev/null +++ b/puppet/modules/ntp/templates/ntp.conf.erb @@ -0,0 +1,43 @@ +# ntp.conf: Managed by puppet. +# +<% if @panic == false -%> +# Keep ntpd from panicking in the event of a large clock skew +# when a VM guest is suspended and resumed. +tinker panic 0 +<% end -%> + +<% if @restrict != [] -%> +# Permit time synchronization with our time source, but do not' +# permit the source to query or modify the service on this system.' +<% @restrict.flatten.each do |restrict| -%> +<%= restrict %> +<% end %> +<% end -%> + +# Servers +<% [@servers].flatten.each do |server| -%> +server <%= server %><% if @preferred_servers.include?(server) -%> prefer<% end %> +<% end -%> + +<% if scope.lookupvar('::is_virtual') == "false" -%> +# Undisciplined Local Clock. This is a fake driver intended for backup +# and when no outside source of synchronized time is available.  +server	127.127.1.0	# local clock +fudge	127.127.1.0 stratum 10	 +<% end -%> + +# Driftfile. +driftfile <%= @driftfile %> + +<% if @keys_enable -%> +keys <%= @keys_file %> +<% unless @keys_trusted.empty? -%> +trustedkey <%= @keys_trusted.join(' ') %> +<% end -%> +<% if @keys_requestkey != '' -%> +requestkey <%= @keys_requestkey %> +<% end -%> +<% if @keys_controlkey != '' -%> +controlkey <%= @keys_controlkey %> +<% end -%> +<% end -%> diff --git a/puppet/modules/ntp/tests/init.pp b/puppet/modules/ntp/tests/init.pp new file mode 100644 index 00000000..e6d9b537 --- /dev/null +++ b/puppet/modules/ntp/tests/init.pp @@ -0,0 +1,11 @@ +node default { + +  notify { 'enduser-before': } +  notify { 'enduser-after': } + +  class { 'ntp': +    require => Notify['enduser-before'], +    before  => Notify['enduser-after'], +  } + +} | 
