| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  | import googlemaps | 
					
						
							|  |  |  | import reversion | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from django.core.management.base import BaseCommand | 
					
						
							|  |  |  | from django.conf import settings | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | from peeringdb_server import models | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | API_KEY = settings.GOOGLE_GEOLOC_API_KEY | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | class Command(BaseCommand): | 
					
						
							|  |  |  |     help = "Sync latitude and longitude on all geocoding enabled entities" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     def add_arguments(self, parser): | 
					
						
							|  |  |  |         parser.add_argument( | 
					
						
							| 
									
										
										
										
											2019-12-05 16:57:52 +00:00
										 |  |  |             "reftag", | 
					
						
							|  |  |  |             nargs="?", | 
					
						
							|  |  |  |             help="can be reftag only such as 'fac' or reftag with id to only sync that specific entity such as 'fac.1'", | 
					
						
							| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  |         ) | 
					
						
							|  |  |  |         parser.add_argument( | 
					
						
							| 
									
										
										
										
											2019-12-05 16:57:52 +00:00
										 |  |  |             "--limit", | 
					
						
							|  |  |  |             type=int, | 
					
						
							|  |  |  |             default=0, | 
					
						
							|  |  |  |             help="limit how many rows are synced, useful for testing", | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2019-10-08 10:30:52 -05:00
										 |  |  |         parser.add_argument( | 
					
						
							| 
									
										
										
										
											2019-12-05 16:57:52 +00:00
										 |  |  |             "--commit", | 
					
						
							|  |  |  |             action="store_true", | 
					
						
							|  |  |  |             help="commit changes, otherwise run in pretend mode", | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def log(self, msg): | 
					
						
							| 
									
										
										
										
											2019-10-08 10:30:52 -05:00
										 |  |  |         if not self.commit: | 
					
						
							|  |  |  |             self.stdout.write(u"[pretend] {}".format(msg)) | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             self.stdout.write(msg) | 
					
						
							| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |     def handle(self, *args, **options): | 
					
						
							| 
									
										
										
										
											2019-10-08 10:30:52 -05:00
										 |  |  |         self.commit = options.get("commit", False) | 
					
						
							| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  |         reftag = options.get("reftag") | 
					
						
							|  |  |  |         limit = options.get("limit") | 
					
						
							|  |  |  |         if reftag.find(".") > -1: | 
					
						
							|  |  |  |             reftag, _id = reftag.split(".") | 
					
						
							|  |  |  |         else: | 
					
						
							|  |  |  |             _id = 0 | 
					
						
							|  |  |  |         self.gmaps = googlemaps.Client(API_KEY, timeout=5) | 
					
						
							|  |  |  |         self.sync(reftag, _id, limit=limit) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     @reversion.create_revision() | 
					
						
							|  |  |  |     def sync(self, reftag, _id, limit=0): | 
					
						
							|  |  |  |         model = models.REFTAG_MAP.get(reftag) | 
					
						
							|  |  |  |         if not model: | 
					
						
							| 
									
										
										
										
											2019-10-08 10:30:52 -05:00
										 |  |  |             raise ValueError(u"Unknown reftag: {}".format(reftag)) | 
					
						
							| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  |         if not hasattr(model, "geocode_status"): | 
					
						
							| 
									
										
										
										
											2019-12-05 16:57:52 +00:00
										 |  |  |             raise TypeError("Can only geosync models containing GeocodeBaseMixin") | 
					
						
							| 
									
										
										
										
											2018-11-08 19:45:21 +00:00
										 |  |  |         q = model.handleref.undeleted().filter(geocode_status=False) | 
					
						
							|  |  |  |         if _id: | 
					
						
							|  |  |  |             q = q.filter(id=_id) | 
					
						
							|  |  |  |         count = q.count() | 
					
						
							|  |  |  |         if limit > 0: | 
					
						
							|  |  |  |             q = q[:limit] | 
					
						
							|  |  |  |         i = 0 | 
					
						
							|  |  |  |         for entity in q: | 
					
						
							|  |  |  |             if entity.geocode_status: | 
					
						
							|  |  |  |                 continue | 
					
						
							|  |  |  |             i += 1 | 
					
						
							| 
									
										
										
										
											2019-12-05 16:57:52 +00:00
										 |  |  |             self.log( | 
					
						
							|  |  |  |                 u"Syncing {} [{} {}/{} ID:{}]".format( | 
					
						
							|  |  |  |                     entity.name, reftag, i, count, entity.id | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ) | 
					
						
							| 
									
										
										
										
											2019-10-08 10:30:52 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |             if self.commit: | 
					
						
							|  |  |  |                 entity.geocode(self.gmaps) |