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
		Add a link
		
	
		Reference in a new issue