Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/kwoodson/ansible-role-yedit
Ansible Role for Yaml editing
https://github.com/kwoodson/ansible-role-yedit
Last synced: about 2 months ago
JSON representation
Ansible Role for Yaml editing
- Host: GitHub
- URL: https://github.com/kwoodson/ansible-role-yedit
- Owner: kwoodson
- Created: 2016-05-25T20:44:04.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-04-01T14:40:42.000Z (10 months ago)
- Last Synced: 2024-08-08T18:24:51.772Z (5 months ago)
- Language: Python
- Homepage:
- Size: 103 KB
- Stars: 161
- Watchers: 9
- Forks: 63
- Open Issues: 47
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-starred - kwoodson/ansible-role-yedit - Ansible Role for Yaml editing (others)
README
// vim: ft=asciidoc
= yedit repository
:toc: macro
:toc-title:toc::[]
== Ansible Role: Yedit
This repository contains an ansible module for modifying yaml files.
I didn't see a good method of editing yaml files and config managing them through ansible. This is my attempt.
== Install
You can install via Ansible Galaxy:
$ ansible-galaxy install kwoodson.yedit
If you do this, you should also add a `requirements.yml` so other users of your playbook know what dependencies to install:```yaml
---
- src: kwoodson.yedit
```You can then reference it in a play by importing it before use:
```yaml
roles:
- kwoodson.yedit
- role-that-uses-yedit
```
== ExamplesSometimes it is necessary to config manage .yml files.
[source,yaml]
----
- hosts: localhost
gather_facts: no
roles:
- kwoodson.yedit
tasks:
- name: manage yaml files
yedit:
src: /tmp/test.yaml
key: a.b.c
value:
d:
e:
f:
this is a test- name: get a specific value
yedit:
src: /tmp/test.yaml
state: list
key: a.b.c.d.e.f
register: yeditout
- debug: var=yeditout
----== Development
As this is a role, just copy it into any roles directory recognized by Ansible. For details, see http://docs.ansible.com/ansible/latest/index.html[Ansible documentation]:
* http://docs.ansible.com/ansible/devel/playbooks_reuse_roles.html#embedding-modules-and-plugins-in-roles[Embedding Modules and Plugins In Roles]
* http://docs.ansible.com/ansible/latest/intro_configuration.html#module-utils[module_utils]== Documentation
Full documentation is available inline https://github.com/kwoodson/ansible-role-yedit/blob/master/library/yedit.py#L15[here].