Mercurial > repos > shellac > sam_consensus_v3
comparison env/bin/sdbadmin @ 0:4f3585e2f14b draft default tip
"planemo upload commit 60cee0fc7c0cda8592644e1aad72851dec82c959"
| author | shellac | 
|---|---|
| date | Mon, 22 Mar 2021 18:12:50 +0000 | 
| parents | |
| children | 
   comparison
  equal
  deleted
  inserted
  replaced
| -1:000000000000 | 0:4f3585e2f14b | 
|---|---|
| 1 #!/Users/cmdms/OneDrive-UOB/Development/Projects/2021/sam-consensus-v3/env/bin/python3 | |
| 2 # Copyright (c) 2009 Chris Moyer http://kopertop.blogspot.com/ | |
| 3 # | |
| 4 # Permission is hereby granted, free of charge, to any person obtaining a | |
| 5 # copy of this software and associated documentation files (the | |
| 6 # "Software"), to deal in the Software without restriction, including | |
| 7 # without limitation the rights to use, copy, modify, merge, publish, dis- | |
| 8 # tribute, sublicense, and/or sell copies of the Software, and to permit | |
| 9 # persons to whom the Software is furnished to do so, subject to the fol- | |
| 10 # lowing conditions: | |
| 11 # | |
| 12 # The above copyright notice and this permission notice shall be included | |
| 13 # in all copies or substantial portions of the Software. | |
| 14 # | |
| 15 # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS | |
| 16 # OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABIL- | |
| 17 # ITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT | |
| 18 # SHALL THE AUTHOR BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | |
| 19 # WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | |
| 20 # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS | |
| 21 | |
| 22 # | |
| 23 # Tools to dump and recover an SDB domain | |
| 24 # | |
| 25 VERSION = "%prog version 1.0" | |
| 26 import boto | |
| 27 import time | |
| 28 from boto import sdb | |
| 29 from boto.compat import json | |
| 30 | |
| 31 def choice_input(options, default=None, title=None): | |
| 32 """ | |
| 33 Choice input | |
| 34 """ | |
| 35 if title == None: | |
| 36 title = "Please choose" | |
| 37 print title | |
| 38 objects = [] | |
| 39 for n, obj in enumerate(options): | |
| 40 print "%s: %s" % (n, obj) | |
| 41 objects.append(obj) | |
| 42 choice = int(raw_input(">>> ")) | |
| 43 try: | |
| 44 choice = objects[choice] | |
| 45 except: | |
| 46 choice = default | |
| 47 return choice | |
| 48 | |
| 49 def confirm(message="Are you sure?"): | |
| 50 choice = raw_input("%s [yN] " % message) | |
| 51 return choice and len(choice) > 0 and choice[0].lower() == "y" | |
| 52 | |
| 53 | |
| 54 def dump_db(domain, file_name, use_json=False, sort_attributes=False): | |
| 55 """ | |
| 56 Dump SDB domain to file | |
| 57 """ | |
| 58 f = open(file_name, "w") | |
| 59 if use_json: | |
| 60 for item in domain: | |
| 61 data = {"name": item.name, "attributes": item} | |
| 62 print >> f, json.dumps(data, sort_keys=sort_attributes) | |
| 63 else: | |
| 64 doc = domain.to_xml(f) | |
| 65 | |
| 66 def empty_db(domain): | |
| 67 """ | |
| 68 Remove all entries from domain | |
| 69 """ | |
| 70 for item in domain: | |
| 71 item.delete() | |
| 72 | |
| 73 def load_db(domain, file, use_json=False): | |
| 74 """ | |
| 75 Load a domain from a file, this doesn't overwrite any existing | |
| 76 data in the file so if you want to do a full recovery and restore | |
| 77 you need to call empty_db before calling this | |
| 78 | |
| 79 :param domain: The SDB Domain object to load to | |
| 80 :param file: The File to load the DB from | |
| 81 """ | |
| 82 if use_json: | |
| 83 for line in file.readlines(): | |
| 84 if line: | |
| 85 data = json.loads(line) | |
| 86 item = domain.new_item(data['name']) | |
| 87 item.update(data['attributes']) | |
| 88 item.save() | |
| 89 | |
| 90 else: | |
| 91 domain.from_xml(file) | |
| 92 | |
| 93 def check_valid_region(conn, region): | |
| 94 if conn is None: | |
| 95 print 'Invalid region (%s)' % region | |
| 96 sys.exit(1) | |
| 97 | |
| 98 def create_db(domain_name, region_name): | |
| 99 """Create a new DB | |
| 100 | |
| 101 :param domain: Name of the domain to create | |
| 102 :type domain: str | |
| 103 """ | |
| 104 sdb = boto.sdb.connect_to_region(region_name) | |
| 105 check_valid_region(sdb, region_name) | |
| 106 return sdb.create_domain(domain_name) | |
| 107 | |
| 108 if __name__ == "__main__": | |
| 109 from optparse import OptionParser | |
| 110 parser = OptionParser(version=VERSION, usage="Usage: %prog [--dump|--load|--empty|--list|-l] [options]") | |
| 111 | |
| 112 # Commands | |
| 113 parser.add_option("--dump", help="Dump domain to file", dest="dump", default=False, action="store_true") | |
| 114 parser.add_option("--load", help="Load domain contents from file", dest="load", default=False, action="store_true") | |
| 115 parser.add_option("--empty", help="Empty all contents of domain", dest="empty", default=False, action="store_true") | |
| 116 parser.add_option("-l", "--list", help="List All domains", dest="list", default=False, action="store_true") | |
| 117 parser.add_option("-c", "--create", help="Create domain", dest="create", default=False, action="store_true") | |
| 118 | |
| 119 parser.add_option("-a", "--all-domains", help="Operate on all domains", action="store_true", default=False, dest="all_domains") | |
| 120 if json: | |
| 121 parser.add_option("-j", "--use-json", help="Load/Store as JSON instead of XML", action="store_true", default=False, dest="json") | |
| 122 parser.add_option("-s", "--sort-attibutes", help="Sort the element attributes", action="store_true", default=False, dest="sort_attributes") | |
| 123 parser.add_option("-d", "--domain", help="Do functions on domain (may be more then one)", action="append", dest="domains") | |
| 124 parser.add_option("-f", "--file", help="Input/Output file we're operating on", dest="file_name") | |
| 125 parser.add_option("-r", "--region", help="Region (e.g. us-east-1[default] or eu-west-1)", default="us-east-1", dest="region_name") | |
| 126 (options, args) = parser.parse_args() | |
| 127 | |
| 128 if options.create: | |
| 129 for domain_name in options.domains: | |
| 130 create_db(domain_name, options.region_name) | |
| 131 exit() | |
| 132 | |
| 133 sdb = boto.sdb.connect_to_region(options.region_name) | |
| 134 check_valid_region(sdb, options.region_name) | |
| 135 if options.list: | |
| 136 for db in sdb.get_all_domains(): | |
| 137 print db | |
| 138 exit() | |
| 139 | |
| 140 if not options.dump and not options.load and not options.empty: | |
| 141 parser.print_help() | |
| 142 exit() | |
| 143 | |
| 144 | |
| 145 | |
| 146 | |
| 147 # | |
| 148 # Setup | |
| 149 # | |
| 150 if options.domains: | |
| 151 domains = [] | |
| 152 for domain_name in options.domains: | |
| 153 domains.append(sdb.get_domain(domain_name)) | |
| 154 elif options.all_domains: | |
| 155 domains = sdb.get_all_domains() | |
| 156 else: | |
| 157 domains = [choice_input(options=sdb.get_all_domains(), title="No domain specified, please choose one")] | |
| 158 | |
| 159 | |
| 160 # | |
| 161 # Execute the commands | |
| 162 # | |
| 163 stime = time.time() | |
| 164 if options.empty: | |
| 165 if confirm("WARNING!!! Are you sure you want to empty the following domains?: %s" % domains): | |
| 166 stime = time.time() | |
| 167 for domain in domains: | |
| 168 print "--------> Emptying %s <--------" % domain.name | |
| 169 empty_db(domain) | |
| 170 else: | |
| 171 print "Canceling operations" | |
| 172 exit() | |
| 173 | |
| 174 if options.dump: | |
| 175 for domain in domains: | |
| 176 print "--------> Dumping %s <---------" % domain.name | |
| 177 if options.file_name: | |
| 178 file_name = options.file_name | |
| 179 else: | |
| 180 file_name = "%s.db" % domain.name | |
| 181 dump_db(domain, file_name, options.json, options.sort_attributes) | |
| 182 | |
| 183 if options.load: | |
| 184 for domain in domains: | |
| 185 print "---------> Loading %s <----------" % domain.name | |
| 186 if options.file_name: | |
| 187 file_name = options.file_name | |
| 188 else: | |
| 189 file_name = "%s.db" % domain.name | |
| 190 load_db(domain, open(file_name, "rb"), options.json) | |
| 191 | |
| 192 | |
| 193 total_time = round(time.time() - stime, 2) | |
| 194 print "--------> Finished in %s <--------" % total_time | 
