Ansible - Check if string exists in file

Frostie_the_snowman picture Frostie_the_snowman · Jul 19, 2016 · Viewed 63.2k times · Source

I'm very new to Ansible

Is it possible to check if a string exists in a file using Ansible.

I want to check is a user has access to a server. this can be done on the server using cat /etc/passwd | grep username

but I want Ansible to stop if the user is not there.

I have tried to use the lineinfile but can't seem to get it to return.

code

 - name: find
   lineinfile: dest=/etc/passwd
               regexp=[user]
               state=present
               line="user"

The code above adds user to the file if he is not there. All i want to do is check. I don't want to modify the file in any way, is this possible

Thanks.

Answer

Jon Staples picture Jon Staples · Sep 27, 2017

It's a tricky one. the lineinfile module is specifically intended for modifying the content of a file, but you can use it for a validation check as well.

- name: find
  lineinfile: 
    dest: /etc/passwd
    line: "user"
  check_mode: yes
  register: presence
  failed_when: presence.changed

check_mode ensures it never updates the file. register saves the variable as noted. failed_when allows you to set the failure condition i.e. by adding the user because it was not found in the file.

There are multiple iterations of this that you can use based on what you want the behavior to be. lineinfile docs particular related to state and regexp should allow you to determine whether or not presence or absence is failure etc, or you can do the not presence.changed etc.