updating to rename to user_tag from auto_tag and use bash builtin for region evaluation. Also updated README.txt for ec2-automate-backup.
This commit is contained in:
		
							parent
							
								
									d18b3c3f7d
								
							
						
					
					
						commit
						ff06380942
					
				@ -51,6 +51,6 @@ ec2-automate-backup requires one of the following two parameters be provided:
 | 
				
			|||||||
the file "ec2ab - IAM User Required Permissions.json" contains the IAM permissions required to run ec2-automate-backup.sh in with the least permissions required as of 2012-11-21.
 | 
					the file "ec2ab - IAM User Required Permissions.json" contains the IAM permissions required to run ec2-automate-backup.sh in with the least permissions required as of 2012-11-21.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- Author: Colin Johnson / colin@cloudavail.com
 | 
					- Author: Colin Johnson / colin@cloudavail.com
 | 
				
			||||||
- Date: 2013-02-13
 | 
					- Date: 2013-02-17
 | 
				
			||||||
- Version 0.9
 | 
					- Version 0.9 Beta
 | 
				
			||||||
- License Type: GNU GENERAL PUBLIC LICENSE, Version 3
 | 
					- License Type: GNU GENERAL PUBLIC LICENSE, Version 3
 | 
				
			||||||
 | 
				
			|||||||
@ -143,7 +143,7 @@ date_binary=""
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#sets the "Name" tag set for a snapshot to false - using "Name" requires that ec2-create-tags be called in addition to ec2-create-snapshot
 | 
					#sets the "Name" tag set for a snapshot to false - using "Name" requires that ec2-create-tags be called in addition to ec2-create-snapshot
 | 
				
			||||||
name_tag_create=false
 | 
					name_tag_create=false
 | 
				
			||||||
#sets the auto_tagging feature to false - auto_tag creates tags on snapshots - by default each snapshot is tagged with volume_id and current_data timestamp
 | 
					#sets the user_tags feature to false - user_tag creates tags on snapshots - by default each snapshot is tagged with volume_id and current_data timestamp
 | 
				
			||||||
user_tags=false
 | 
					user_tags=false
 | 
				
			||||||
#sets the Purge Snapshot feature to false - this feature will eventually allow the removal of snapshots that have a "PurgeAfterFE" tag that is earlier than current date
 | 
					#sets the Purge Snapshot feature to false - this feature will eventually allow the removal of snapshots that have a "PurgeAfterFE" tag that is earlier than current date
 | 
				
			||||||
purge_snapshots=false
 | 
					purge_snapshots=false
 | 
				
			||||||
 | 
				
			|||||||
@ -37,12 +37,12 @@ ec2-automate-backup requires one of the following two parameters be provided:
 | 
				
			|||||||
* To perform daily backup using cron and to load environment configuration with a "cron-primer" file:
 | 
					* To perform daily backup using cron and to load environment configuration with a "cron-primer" file:
 | 
				
			||||||
 - `0 0 * * 0 ec2-user /home/ec2-user/ec2-automate-backup.sh -c /home/ec2-user/cron-primer.sh -s tag -t "Backup=True"`
 | 
					 - `0 0 * * 0 ec2-user /home/ec2-user/ec2-automate-backup.sh -c /home/ec2-user/cron-primer.sh -s tag -t "Backup=True"`
 | 
				
			||||||
 | 
					
 | 
				
			||||||
`-a` - the -a flag will tag snapshots with additional data so that snapshots can be more easily located. Currently the two auto tags created are Volume="ebs_volume" and Created="date"
 | 
					`-u` - the -u flag will tag snapshots with additional data so that snapshots can be more easily located. Currently the two user tags created are Volume="ebs_volume" and Created="date." These can be easily modified in code.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Additional Information:
 | 
					# Additional Information:
 | 
				
			||||||
the file "ec2ab - IAM User Required Permissions.json" contains the IAM permissions required to run ec2-automate-backup.sh in with the least permissions required as of 2012-11-21.
 | 
					the file "ec2ab - IAM User Required Permissions.json" contains the IAM permissions required to run ec2-automate-backup.sh in with the least permissions required as of 2012-11-21.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
- Author: Colin Johnson / colin@cloudavail.com
 | 
					- Author: Colin Johnson / colin@cloudavail.com
 | 
				
			||||||
- Date: 2013-01-27
 | 
					- Date: 2013-02-17
 | 
				
			||||||
- Version 0.1
 | 
					- Version 0.9
 | 
				
			||||||
- License Type: GNU GENERAL PUBLIC LICENSE, Version 3
 | 
					- License Type: GNU GENERAL PUBLIC LICENSE, Version 3
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
#!/bin/bash -
 | 
					#!/bin/bash -
 | 
				
			||||||
# Author: Colin Johnson / colin@cloudavail.com
 | 
					# Author: Colin Johnson / colin@cloudavail.com
 | 
				
			||||||
# Date: 2013-01-27
 | 
					# Date: 2013-02-13
 | 
				
			||||||
# Version 0.1
 | 
					# Version 0.9
 | 
				
			||||||
# License Type: GNU GENERAL PUBLIC LICENSE, Version 3
 | 
					# License Type: GNU GENERAL PUBLIC LICENSE, Version 3
 | 
				
			||||||
#
 | 
					#
 | 
				
			||||||
#confirms that executables required for succesful script execution are available
 | 
					#confirms that executables required for succesful script execution are available
 | 
				
			||||||
@ -62,10 +62,10 @@ create_EBS_Snapshot_Tags()
 | 
				
			|||||||
		snapshot_tags="$snapshot_tags --tag PurgeAfter=$purge_after_date --tag PurgeAllow=true"
 | 
							snapshot_tags="$snapshot_tags --tag PurgeAfter=$purge_after_date --tag PurgeAllow=true"
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	#if $auto_tag is true, then append Volume=$ebs_selected and Created=$date_current to the variable $snapshot_tags
 | 
						#if $user_tags is true, then append Volume=$ebs_selected and Created=$current_date to the variable $snapshot_tags
 | 
				
			||||||
	if $auto_tag
 | 
						if $user_tags
 | 
				
			||||||
		then
 | 
							then
 | 
				
			||||||
		snapshot_tags="$snapshot_tags --tag Volume=${ebs_selected} --tag Created=$date_current"
 | 
							snapshot_tags="$snapshot_tags --tag Volume=${ebs_selected} --tag Created=$current_date"
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	#if $snapshot_tags is not zero length then set the tag on the snapshot using ec2-create-tags
 | 
						#if $snapshot_tags is not zero length then set the tag on the snapshot using ec2-create-tags
 | 
				
			||||||
@ -156,12 +156,13 @@ date_binary=""
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#sets the "Name" tag set for a snapshot to false - using "Name" requires that ec2-create-tags be called in addition to ec2-create-snapshot
 | 
					#sets the "Name" tag set for a snapshot to false - using "Name" requires that ec2-create-tags be called in addition to ec2-create-snapshot
 | 
				
			||||||
name_tag_create=false
 | 
					name_tag_create=false
 | 
				
			||||||
#sets the auto_tagging feature to false - auto_tag creates tags on snapshots - by default each snapshot is tagged with volume_id and current_data timestamp
 | 
					#sets the user_tags feature to false - user_tag creates tags on snapshots - by default each snapshot is tagged with volume_id and current_data timestamp
 | 
				
			||||||
auto_tag=false
 | 
					user_tags=false
 | 
				
			||||||
#sets the Purge Snapshot feature to false - this feature will eventually allow the removal of snapshots that have a "PurgeAfter" tag that is earlier than current date
 | 
					#sets the Purge Snapshot feature to false - this feature will eventually allow the removal of snapshots that have a "PurgeAfter" tag that is earlier than current date
 | 
				
			||||||
purge_snapshots=false
 | 
					purge_snapshots=false
 | 
				
			||||||
#handles options processing
 | 
					#handles options processing
 | 
				
			||||||
while getopts :s:c:r:v:t:k:pna opt; do
 | 
					while getopts :s:c:r:v:t:k:pnu opt
 | 
				
			||||||
 | 
						do
 | 
				
			||||||
		case $opt in
 | 
							case $opt in
 | 
				
			||||||
			s) selection_method="$OPTARG";;
 | 
								s) selection_method="$OPTARG";;
 | 
				
			||||||
			c) cron_primer="$OPTARG";;
 | 
								c) cron_primer="$OPTARG";;
 | 
				
			||||||
@ -171,10 +172,10 @@ while getopts :s:c:r:v:t:k:pna opt; do
 | 
				
			|||||||
			k) purge_after_days="$OPTARG";;
 | 
								k) purge_after_days="$OPTARG";;
 | 
				
			||||||
			n) name_tag_create=true;;
 | 
								n) name_tag_create=true;;
 | 
				
			||||||
			p) purge_snapshots=true;;
 | 
								p) purge_snapshots=true;;
 | 
				
			||||||
		a) auto_tag=true;;
 | 
								u) user_tags=true;;
 | 
				
			||||||
			*) echo "Error with Options Input. Cause of failure is most likely that an unsupported parameter was passed or a parameter was passed without a corresponding option." 1>&2 ; exit 64;;
 | 
								*) echo "Error with Options Input. Cause of failure is most likely that an unsupported parameter was passed or a parameter was passed without a corresponding option." 1>&2 ; exit 64;;
 | 
				
			||||||
		esac
 | 
							esac
 | 
				
			||||||
done
 | 
						done
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#sources "cron_primer" file for running under cron or other restricted environments - this file should contain the variables and environment configuration required for ec2-automate-backup to run correctly
 | 
					#sources "cron_primer" file for running under cron or other restricted environments - this file should contain the variables and environment configuration required for ec2-automate-backup to run correctly
 | 
				
			||||||
if [[ -n $cron_primer ]]
 | 
					if [[ -n $cron_primer ]]
 | 
				
			||||||
@ -185,11 +186,14 @@ if [[ -n $cron_primer ]]
 | 
				
			|||||||
	fi
 | 
						fi
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
if [ -z $region ]; then
 | 
					#if region is not set then:
 | 
				
			||||||
	if [ -z $EC2_REGION ]; then
 | 
					if [[ -z $region ]]
 | 
				
			||||||
		region="us-east-1"
 | 
						#if the environment variable $EC2_REGION is not set set to us-east-1
 | 
				
			||||||
 | 
						then if [[ -z $EC2_REGION ]]
 | 
				
			||||||
 | 
							#if both 
 | 
				
			||||||
 | 
							then region="us-east-1"
 | 
				
			||||||
	else
 | 
						else
 | 
				
			||||||
		region="$EC2_REGION"
 | 
							region=$EC2_REGION
 | 
				
			||||||
	fi
 | 
						fi
 | 
				
			||||||
fi
 | 
					fi
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user