def is_valid(self): # If you accessing this from unit tests, then before calling # is valid, you can assign your own cursor. if not self.cursor: self.conn = mypool.connect() self.cursor = self.conn.cursor() data = self.data # Version can be blank. data['version'] = data.get('version', '') for field in ['reqVersion', 'id', 'appID', 'appVersion']: if field not in data: return False data['app_id'] = APP_GUIDS.get(data['appID']) if not data['app_id']: return False sql = """SELECT id, status, addontype_id, guid FROM addons WHERE guid = %(guid)s AND inactive = 0 AND status NOT IN (%(STATUS_DELETED)s, %(STATUS_DISABLED)s) LIMIT 1;""" self.cursor.execute( sql, { 'guid': self.data['id'], 'STATUS_DELETED': base.STATUS_DELETED, 'STATUS_DISABLED': base.STATUS_DISABLED, }) result = self.cursor.fetchone() if result is None: return False data['id'], data['addon_status'], data['type'], data['guid'] = result data['version_int'] = version_int(data['appVersion']) if 'appOS' in data: for k, v in PLATFORMS.items(): if k in data['appOS']: data['appOS'] = v break else: data['appOS'] = None return True
def is_valid(self): # If you accessing this from unit tests, then before calling # is valid, you can assign your own cursor. if not self.cursor: self.conn = mypool.connect() self.cursor = self.conn.cursor() data = self.data # Version can be blank. data['version'] = data.get('version', '') for field in ['reqVersion', 'id', 'appID', 'appVersion']: if field not in data: return False data['app_id'] = APP_GUIDS.get(data['appID']) if not data['app_id']: return False sql = """SELECT id, status, addontype_id, guid FROM addons WHERE guid = %(guid)s AND inactive = 0 AND status NOT IN (%(STATUS_DELETED)s, %(STATUS_DISABLED)s) LIMIT 1;""" self.cursor.execute(sql, { 'guid': self.data['id'], 'STATUS_DELETED': base.STATUS_DELETED, 'STATUS_DISABLED': base.STATUS_DISABLED, }) result = self.cursor.fetchone() if result is None: return False data['id'], data['addon_status'], data['type'], data['guid'] = result data['version_int'] = version_int(data['appVersion']) if 'appOS' in data: for k, v in PLATFORMS.items(): if k in data['appOS']: data['appOS'] = v break else: data['appOS'] = None return True
def is_valid(self): # If you accessing this from unit tests, then before calling # is valid, you can assign your own cursor. if not self.cursor: self.conn = mypool.connect() self.cursor = self.conn.cursor() data = self.data # Version can be blank. data["version"] = data.get("version", "") for field in ["reqVersion", "id", "appID", "appVersion"]: if field not in data: return False data["app_id"] = APP_GUIDS.get(data["appID"]) if not data["app_id"]: return False sql = """SELECT id, status, addontype_id, guid FROM addons WHERE guid = %(guid)s AND inactive = 0 AND status != %(STATUS_DELETED)s LIMIT 1;""" self.cursor.execute(sql, {"guid": self.data["id"], "STATUS_DELETED": base.STATUS_DELETED}) result = self.cursor.fetchone() if result is None: return False data["id"], data["addon_status"], data["type"], data["guid"] = result data["version_int"] = version_int(data["appVersion"]) if "appOS" in data: for k, v in PLATFORMS.items(): if k in data["appOS"]: data["appOS"] = v break else: data["appOS"] = None self.is_beta_version = base.VERSION_BETA.search(data["version"]) return True
def is_valid(self): # If you accessing this from unit tests, then before calling # is valid, you can assign your own cursor. if not self.cursor: self.conn = mypool.connect() self.cursor = self.conn.cursor() data = self.data for field in ['reqVersion', 'id', 'version', 'appID', 'appVersion']: if field not in data: return False data['app_id'] = APP_GUIDS.get(data['appID']) if not data['app_id']: return False sql = """SELECT id, status, addontype_id, guid FROM addons WHERE guid = %(guid)s AND inactive = 0 LIMIT 1;""" self.cursor.execute(sql, {'guid': self.data['id']}) result = self.cursor.fetchone() if result is None: return False data['id'], data['addon_status'], data['type'], data['guid'] = result data['version_int'] = version_int(data['appVersion']) if 'appOS' in data: for k, v in PLATFORMS.items(): if k in data['appOS']: data['appOS'] = v break else: data['appOS'] = None self.is_beta_version = base.VERSION_BETA.search(data.get('version', '')) return True