Skip to content

Latest commit

 

History

History
96 lines (65 loc) · 2.7 KB

README.md

File metadata and controls

96 lines (65 loc) · 2.7 KB

Build Status

Puppet module: ddclient

This is a Puppet module for ddclient originall based on the version by Javier Bertoli / Netmanagers

USAGE - Basic management

  • All parameters can be set using Hiera. See the manifests to see what can be set.

  • Install ddclient with default distro's settings

      class { 'ddclient': }
    
  • You can install and configure a single dDNS host/provider using a template (ie., the included one):

      class { 'ddclient': 
        host_config => 'file',
        template    => 'ddclient/ddclient.conf.erb',
        server      => 'ddns_provider',
        login       => 'myuser',
        password    => 'secret',
        protocol    => 'ddns_prot',
        hostname    => 'my.host.name',
      }
    
  • Or you can configure multiple hosts using host_config => 'concat' and ddclient::host define:

      class { 'ddclient': 
        host_config   => 'concat',
      }
    
      ddclient::host { 'my_ddns.hostname.com':
        server    => 'one.ddns.provider.com',
        login     => 'my_account',
        password  => 'secret',
        protocol  => 'dyndns2',
      }
    
  • Install a specific version of ddclient package

      class { 'ddclient':
        version => '1.0.1',
      }
    
  • Disable ddclient service.

      class { 'ddclient':
        disable => true
      }
    
  • Remove ddclient package

      class { 'ddclient':
        absent => true
      }
    
  • Enable auditing without without making changes on existing ddclient configuration files

      class { 'ddclient':
        audit_only => true
      }
    
  • Module dry-run: Do not make any change on all the resources provided by the module

      class { 'ddclient':
        noops => true
      }
    

USAGE - Overrides and Customizations

  • Use custom sources for main config file

      class { 'ddclient':
        source => [ "puppet:///modules/example42/ddclient/ddclient.conf-${hostname}" , "puppet:///modules/example42/ddclient/ddclient.conf" ], 
      }
    
  • Use custom source directory for the whole configuration dir

      class { 'ddclient':
        source_dir       => 'puppet:///modules/example42/ddclient/conf/',
        source_dir_purge => false, # Set to true to purge any existing file not present in $source_dir
      }
    
  • Use custom template for main config file. Note that template and source arguments are alternative.

      class { 'ddclient':
        template => 'example42/ddclient/ddclient.conf.erb',
      }
    
  • Automatically include a custom subclass

      class { 'ddclient':
        my_class => 'example42::my_ddclient',
      }