DOKK / manpages / debian 11 / caspar / csp_helper.1.en
csp_helper(1) USER COMMANDS csp_helper(1)


csp_helper - A collection of caspar helper scripts


csp_install dir (directory) file (file)

csp_mkdircp dir (directory) file (file)

csp_scp_keep_mode h ([user@]host) dir (directory) file (file)

csp_sucp h ([user@]host) dir (directory) file (file)


The scripts csp_install, csp_mkdircp, csp_scp_keep_mode and csp_sucp are helpers for caspar(7). These scripts typically are not invoked directly, but via a Makefile which uses caspar. See the notes on csp_PUSH in caspar(7) for information on how to link csp_install, csp_scp_keep_mode and csp_sucp to caspar.


csp_install creates the required directory (if needed) and installs the file, preserving timestamps. It uses install(1).




csp_INSTALL_OPTIONS='--owner=www-data --group=www-data' \
csp_INSTALL_MODE=ugo=r \
csp_install /srv/www index.html




csp_INSTALL_MODE=u=rwx,go= csp_install /usr/local/sbin mkpasswd



csp_install honors csp_INSTALL_OPTIONS and csp_INSTALL_MODE (default is u=rw,go=r).


csp_mkdircp calls mkdir(1) and cp(1). csp_mkdircp is used like csp_CP. use csp_mkdircp if you frequently have to bootstrap installation on a fresh system, on which needed directories don't exist yet. csp_mkdircp makes sure the target directory exists before calling cp(1), by calling mkdir -p first.


csp_scp_keep_mode uses ssh to copy a file to a remote host, keeping its file permission mode. The trick used is a combination of mktemp(1) and mv(1). Useful if you'd like to be sure a file gets installed e.g. group writable, without fiddling with permission bits on the remote host.




chmod g+w rc
csp_scp_keep_mode root@gandalf /etc/uruk rc



csp_scp_keep_mode honors csp_SSH ("ssh" by default).


csp_sucp calls tar(1) from within sudo(1) from within ssh(1). This allows one to copy files to accounts on hosts one can only reach by calling sudo on the ssh-reachable remote host.

Typically, one wants to install a root-owned file, but one does not want to allow access to the root-account directly from ssh. Typically sudo is used as an extra line of defense.

NB: if your sudo prompts for a password, be sure to have line



Defaults !tty_tickets


in your sudoers file: we first call sudo -v, than we call sudo to write the data. Since we use ssh to get to the host, we'll use a different tty for both sudo calls.


Some examples:



csp_sucp rms@bilbo /etc fstab




csp_sucp monty-python commit/ trailer.txt



Joost van Baal-Ilić


caspar(7) The caspar homepage is at http://mdcc.cx/caspar/ .

9 јун 2020 csp_helper 20200609