Merge branch '__rsyncer' of https://github.com/phrawzty/cdist
This commit is contained in:
		
						commit
						56d2862e99
					
				
					 4 changed files with 110 additions and 0 deletions
				
			
		
							
								
								
									
										44
									
								
								conf/type/__rsyncer/gencode-local
									
										
									
									
									
										Executable file
									
								
							
							
						
						
									
										44
									
								
								conf/type/__rsyncer/gencode-local
									
										
									
									
									
										Executable file
									
								
							|  | @ -0,0 +1,44 @@ | |||
| #!/bin/sh | ||||
| # | ||||
| # Copyright (C) 2011 Daniel Maher (phrawzty+cdist at gmail.com) | ||||
| # | ||||
| # This file is part of cdist (https://github.com/telmich/cdist/). | ||||
| # | ||||
| # cdist is free software: you can redistribute it and/or modify | ||||
| # it under the terms of the GNU General Public License as published by | ||||
| # the Free Software Foundation, either version 3 of the License, or | ||||
| # (at your option) any later version. | ||||
| # | ||||
| # cdist is distributed in the hope that it will be useful, | ||||
| # but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with cdist. If not, see <http://www.gnu.org/licenses/>. | ||||
| # | ||||
| 
 | ||||
| source="$(cat "$__object/parameter/source")" | ||||
| 
 | ||||
| if [ -f "$__object/parameter/destination" ]; then | ||||
|     destination="$(cat "$__object/parameter/destination")" | ||||
| else | ||||
|     destination="/$__object_id" | ||||
| fi | ||||
| 
 | ||||
| # The system binary is probably ok, but if not... | ||||
| if [ -f "$__object/parameter/rsyncbin" ]; then | ||||
|     rsyncbin="$(cat "$__object/parameter/rsyncbin")" | ||||
| else | ||||
|     rsyncbin=`which rsync` | ||||
| fi | ||||
| 
 | ||||
| args='-a --stats' | ||||
| 
 | ||||
| # If the --delete argument should be passed to rsync. | ||||
| if [ -f "$__object/parameter/delete" ]; then | ||||
|     args="$args --delete" | ||||
| fi | ||||
| 
 | ||||
| # Run rsync (locally). | ||||
| echo "$rsyncbin $args $source root@$__target_host:$destination" | ||||
							
								
								
									
										62
									
								
								conf/type/__rsyncer/man.text
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								conf/type/__rsyncer/man.text
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,62 @@ | |||
| cdist-type__rsyncer(7) | ||||
| ====================== | ||||
| Daniel Maher <phrawzty+cdist at gmail.com> | ||||
| 
 | ||||
| 
 | ||||
| NAME | ||||
| ---- | ||||
| cdist-type__rsyncer - Use rsync to copy files. | ||||
| 
 | ||||
| 
 | ||||
| DESCRIPTION | ||||
| ----------- | ||||
| This type is used to trigger rsync to copy files from the machine running cdist | ||||
| (source) to the target machine in question (destination). The likely usage is | ||||
| the rapid deployment of full directory trees, the cohorency of which can be | ||||
| guarunteed with the optional --delete argument, which will remove any files | ||||
| from the destination which are not present on the source. | ||||
| 
 | ||||
| 
 | ||||
| REQUIRED PARAMETERS | ||||
| ------------------- | ||||
| source:: | ||||
|     The full path of the source from which to copy. This is passed directly | ||||
|     to rsync. | ||||
| 
 | ||||
| 
 | ||||
| OPTIONAL PARAMETERS | ||||
| ------------------- | ||||
| destination:: | ||||
|     The full path of the destination. This is passed directly to rsync. | ||||
|     Default: object_id | ||||
| 
 | ||||
| delete:: | ||||
|     If true, remove files from destination which are not in source. This is | ||||
|     effectively the --delete argument of rsync. | ||||
|     Default: false | ||||
| 
 | ||||
| rsyncbin:: | ||||
|     Specify the full path to the rsync binary. | ||||
|     Default: `which rsync` | ||||
| 
 | ||||
| EXAMPLES | ||||
| -------- | ||||
| 
 | ||||
| -------------------------------------------------------------------------------- | ||||
| # Basic example | ||||
| __rsyncer '/home/foo' --source '/opt/dist/foo' | ||||
| 
 | ||||
| # Fancier example | ||||
| __rsyncer FOO --source '/opt/dist/foo' --destination '/home/foo/' --delete true | ||||
| -------------------------------------------------------------------------------- | ||||
| 
 | ||||
| 
 | ||||
| SEE ALSO | ||||
| -------- | ||||
| - cdist-type(7) | ||||
| 
 | ||||
| 
 | ||||
| COPYING | ||||
| ------- | ||||
| Copyright \(C) 2011 Daniel Maher. Free use of this software is granted under | ||||
| the terms of the GNU General Public License version 3 (GPLv3). | ||||
							
								
								
									
										3
									
								
								conf/type/__rsyncer/parameter/optional
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								conf/type/__rsyncer/parameter/optional
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,3 @@ | |||
| destination | ||||
| delete | ||||
| rsyncbin | ||||
							
								
								
									
										1
									
								
								conf/type/__rsyncer/parameter/required
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								conf/type/__rsyncer/parameter/required
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| source | ||||
		Loading…
	
	Add table
		
		Reference in a new issue