From c61819d00b2d86479b21422910770c1322aa941c Mon Sep 17 00:00:00 2001 From: Domenico Iezzi Date: Mon, 13 Nov 2017 11:44:15 +0100 Subject: [PATCH] Fix #22 Now gpapi checks if the locale retrieved from system or provided by the user is valid. In case it's invalid, default to en_US. --- gpapi/config.py | 12 +++++++++++- gpapi/googleplay.py | 3 +-- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/gpapi/config.py b/gpapi/config.py index d6d9f79..0c443c2 100644 --- a/gpapi/config.py +++ b/gpapi/config.py @@ -3,6 +3,7 @@ from os import path from sys import version_info from locale import getdefaultlocale +from re import match VERSION = version_info[0] if VERSION == 2: @@ -48,11 +49,20 @@ class DeviceBuilder(object): def __init__(self, device): self.device = {} - self.locale = getdefaultlocale()[0] self.timezone = "Europe/Berlin" for (key, value) in config.items(device): self.device[key] = value + def setLocale(self, locale): + if locale is None: + locale = getdefaultlocale()[0] + + # check if locale matches the structure of a common + # value like "en_US" + if match(r'[a-z]{2}\_[A-Z]{2}', locale) is None: + locale = 'en_US' + self.locale = locale + def getUserAgent(self): return ("Android-Finsky/8.1.72.S-all [6] [PR] 165478484 (" "api=3" diff --git a/gpapi/googleplay.py b/gpapi/googleplay.py index 2b86fd3..cef3d6a 100644 --- a/gpapi/googleplay.py +++ b/gpapi/googleplay.py @@ -52,8 +52,7 @@ def __init__(self, debug=False, device_codename='bacon', self.gsfId = None self.debug = debug self.deviceBuilder = config.DeviceBuilder(device_codename) - if locale is not None: - self.deviceBuilder.locale = locale + self.deviceBuilder.setLocale(locale) if timezone is not None: self.deviceBuilder.timezone = timezone if sim_operator is not None: