This seems to work, but is it fragile? I want the owner and group in the files command to be set to someguy
. I'd expect to be able to use {{ remote_user }}
but that doesn't work.
This is an example playbook showing what I mean.
---
- hosts: foobar
remote_user: someguy
tasks:
- name: configure /usr/src/foo
file:
dest: /usr/src/foo
state: directory
owner: {{ ansible_ssh_user }}
group: {{ ansible_ssh_user }}
recurse: yes
sudo: yes
This doesn't work:
---
- hosts: foobar
remote_user: someguy
tasks:
- name: configure /usr/src/foo
file:
dest: /usr/src/foo
state: directory
owner: {{ remote_user }}
group: {{ remote_user }}
recurse: yes
sudo: yes
One or more undefined variables: 'remote_user' is undefined
There's also
{{ ansible_ssh_user }}
, which contains remote user name and seems to be accessible without issues. See also this answer.When specifying variables in commands, you have to enclose them in quotes - for example:
should really be:
I'm surprised your first example works at all given the lack of quotes.
Additionally, your 'remote_user' doesn't actually have to be 'someguy' in that example as usually using
sudo: yes
is sufficient to have the file module set the specified owner and group correctly.You can try to write playbook like:
You can fix this by adding a vars: option