win_copy – Copies files to remote locations on windows hosts¶
Synopsis¶
- The - win_copymodule copies a file on the local box to remote windows locations.
- For non-Windows targets, use the copy module instead. 
Parameters¶
Notes¶
Note
- Currently win_copy does not support copying symbolic links from both local to remote and remote to remote. 
- It is recommended that backslashes - \are used instead of- /when dealing with remote paths.
- Because win_copy runs over WinRM, it is not a very efficient transfer mechanism. If sending large files consider hosting them on a web service and using win_get_url instead. 
See Also¶
See also
- assemble – Assemble configuration files from fragments
- The official documentation on the assemble module. 
- copy – Copy files to remote locations
- The official documentation on the copy module. 
- win_get_url – Downloads file from HTTP, HTTPS, or FTP to node
- The official documentation on the win_get_url module. 
- win_robocopy – Synchronizes the contents of two directories using Robocopy
- The official documentation on the win_robocopy module. 
Examples¶
- name: Copy a single file
  win_copy:
    src: /srv/myfiles/foo.conf
    dest: C:\Temp\renamed-foo.conf
- name: Copy a single file, but keep a backup
  win_copy:
    src: /srv/myfiles/foo.conf
    dest: C:\Temp\renamed-foo.conf
    backup: yes
- name: Copy a single file keeping the filename
  win_copy:
    src: /src/myfiles/foo.conf
    dest: C:\Temp\
- name: Copy folder to C:\Temp (results in C:\Temp\temp_files)
  win_copy:
    src: files/temp_files
    dest: C:\Temp
- name: Copy folder contents recursively
  win_copy:
    src: files/temp_files/
    dest: C:\Temp
- name: Copy a single file where the source is on the remote host
  win_copy:
    src: C:\Temp\foo.txt
    dest: C:\ansible\foo.txt
    remote_src: yes
- name: Copy a folder recursively where the source is on the remote host
  win_copy:
    src: C:\Temp
    dest: C:\ansible
    remote_src: yes
- name: Set the contents of a file
  win_copy:
    content: abc123
    dest: C:\Temp\foo.txt
- name: Copy a single file as another user
  win_copy:
    src: NuGet.config
    dest: '%AppData%\NuGet\NuGet.config'
  vars:
    ansible_become_user: user
    ansible_become_password: pass
    # The tmp dir must be set when using win_copy as another user
    # This ensures the become user will have permissions for the operation
    # Make sure to specify a folder both the ansible_user and the become_user have access to (i.e not %TEMP% which is user specific and requires Admin)
    ansible_remote_tmp: 'c:\tmp'
Return Values¶
Common return values are documented here, the following are the fields unique to this module:
Status¶
- This module is guaranteed to have backward compatible interface changes going forward. [stableinterface] 
- This module is maintained by the Ansible Core Team. [core] 
Red Hat Support¶
More information about Red Hat’s support of this module is available from this Red Hat Knowledge Base article.
Authors¶
- Jon Hawkesworth (@jhawkesworth) 
- Jordan Borean (@jborean93) 
Hint
If you notice any issues in this documentation, you can edit this document to improve it.
