GithubHelp home page GithubHelp logo

infopen-forks / ansible-role-skel Goto Github PK

View Code? Open in Web Editor NEW

This project forked from temelio/ansible-role-skel

0.0 2.0 0.0 61 KB

Manage the skeleton structures used with account creation

License: MIT License

Python 100.00%

ansible-role-skel's Introduction

skel

Build Status Build Status Updates Python 3 Ansible Role

Manage the skeleton structures used with account creation

Requirements

This role requires Ansible 2.2 or higher, and platform requirements are listed in the metadata file.

Testing

This role use Molecule to run tests.

Local and Travis tests run tests on Docker by default. See molecule documentation to use other backend.

Currently, tests are done on:

  • Debian Jessie
  • Ubuntu Trusty
  • Ubuntu Xenial

and use:

  • Ansible 2.2.x
  • Ansible 2.3.x
  • Ansible 2.4.x

Running tests

Using Docker driver

$ tox

Role Variables

Default role variables

skel_default_owner: 'root'
skel_default_group: 'root'
skel_default_directory_mode: '0750'
skel_default_file_mode: '0640'

skel_default_link_force: False
skel_default_link_mode: '0640'
skel_default_link_state: 'link'

skel_entries: []

How manage skels

Skels are defined in skel_entries var, and follow this syntax:

skel_entries:
  - directories:
      - path: '/etc/skel/.ssh'
        mode: '0700'
    to_remove:
      - path: '/etc/skel/.bashrc'
  - directories:
      - path: '/etc/skel/foo'
      - path: '/etc/skel/bar'
        mode: '0755'
    links:
      - src: '/etc/skel/foo'
        dest: '/etc/skel/bar/foolink'
    to_copy:
      - src: './files/foo.txt'
        dest: '/etc/skel/bar/'
    to_template:
      - src: './files/bar.j2'
        dest: '/etc/skel/bar/bar.txt'

All lv1 keys are optional, you can mix them as you want.

to_remove key

Use it to remove files from structure. It's the first task. Only one arg:

  • path (mandatory): full element path

directories key

It manage directories creation. You can use these sub keys:

  • path (mandatory): full directory path
  • state (optional): default is 'directory'
  • owner (optional): default is managed by skel_default_owner var
  • group (optional): default is managed by skel_default_group var
  • mode (optional): default is managed by skel_default_directory_mode var

links key

It manage links creation. You can use these sub keys:

  • src (mandatory): full source path
  • dest (mandatory): full destination path
  • state (optional): default is managed by skel_default_link_state var
  • owner (optional): default is managed by skel_default_owner var
  • group (optional): default is managed by skel_default_group var
  • mode (optional): default is managed by skel_default_link_mode var
  • force (optional): default is managed by skel_default_link_force var

to_copy key

It manage element to be copied. You can use these sub keys:

  • src (mandatory): full source path
  • dest (mandatory): full destination path
  • owner (optional): default is managed by skel_default_owner var
  • group (optional): default is managed by skel_default_group var
  • mode (optional): default is managed by skel_default_file_mode var

to_template key

It manage templating. You can use these sub keys:

  • src (mandatory): full source path
  • dest (mandatory): full destination path
  • owner (optional): default is managed by skel_default_owner var
  • group (optional): default is managed by skel_default_group var
  • mode (optional): default is managed by skel_default_file_mode var

Dependencies

None

Example Playbook

- hosts: servers
  roles:
    - { role: Temelio.skel }

License

MIT

Author Information

Alexandre Chaussier (for Temelio company)

ansible-role-skel's People

Contributors

achaussier avatar pyup-bot avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.