Fix versioning functionality more, explicit version check
This commit is contained in:
pare
a93f051b5e
commit
fad615b8d6
S'han modificat 1 arxius amb 30 adicions i 10 eliminacions
|
@ -116,7 +116,7 @@ class Mastodon:
|
||||||
def __init__(self, client_id, client_secret=None, access_token=None,
|
def __init__(self, client_id, client_secret=None, access_token=None,
|
||||||
api_base_url=__DEFAULT_BASE_URL, debug_requests=False,
|
api_base_url=__DEFAULT_BASE_URL, debug_requests=False,
|
||||||
ratelimit_method="wait", ratelimit_pacefactor=1.1,
|
ratelimit_method="wait", ratelimit_pacefactor=1.1,
|
||||||
request_timeout=__DEFAULT_TIMEOUT, mastodon_version="2.0.0"):
|
request_timeout=__DEFAULT_TIMEOUT, mastodon_version=None):
|
||||||
"""
|
"""
|
||||||
Create a new API wrapper instance based on the given client_secret and client_id. If you
|
Create a new API wrapper instance based on the given client_secret and client_id. If you
|
||||||
give a client_id and it is not a file, you must also give a secret.
|
give a client_id and it is not a file, you must also give a secret.
|
||||||
|
@ -140,8 +140,8 @@ class Mastodon:
|
||||||
|
|
||||||
The mastodon_version parameter can be used to specify the version of Mastodon that Mastodon.py will
|
The mastodon_version parameter can be used to specify the version of Mastodon that Mastodon.py will
|
||||||
expect to be installed on the server. The function will throw an error if an unparseable
|
expect to be installed on the server. The function will throw an error if an unparseable
|
||||||
Version is specified or if the server mastodon version is too old. If no version is specified,
|
Version is specified. If no version is specified, Mastodon.py will set mastodon_version to the
|
||||||
Mastodon.py will set mastodon_version to the detected version.
|
detected version.
|
||||||
"""
|
"""
|
||||||
self.api_base_url = Mastodon.__protocolize(api_base_url)
|
self.api_base_url = Mastodon.__protocolize(api_base_url)
|
||||||
self.client_id = client_id
|
self.client_id = client_id
|
||||||
|
@ -160,14 +160,20 @@ class Mastodon:
|
||||||
|
|
||||||
self.request_timeout = request_timeout
|
self.request_timeout = request_timeout
|
||||||
|
|
||||||
try:
|
# Versioning
|
||||||
self.mastodon_major, self.mastodon_minor, self.mastodon_patch = parse_version_string(mastodon_version)
|
if mastodon_version == None:
|
||||||
except:
|
self.retrieve_mastodon_version()
|
||||||
raise MastodonVersionError("Bad version specified")
|
else:
|
||||||
|
try:
|
||||||
|
self.mastodon_major, self.mastodon_minor, self.mastodon_patch = parse_version_string(mastodon_version)
|
||||||
|
except:
|
||||||
|
raise MastodonVersionError("Bad version specified")
|
||||||
|
|
||||||
|
# Ratelimiting parameter check
|
||||||
if ratelimit_method not in ["throw", "wait", "pace"]:
|
if ratelimit_method not in ["throw", "wait", "pace"]:
|
||||||
raise MastodonIllegalArgumentError("Invalid ratelimit method.")
|
raise MastodonIllegalArgumentError("Invalid ratelimit method.")
|
||||||
|
|
||||||
|
# Token loading
|
||||||
if os.path.isfile(self.client_id):
|
if os.path.isfile(self.client_id):
|
||||||
with open(self.client_id, 'r') as secret_file:
|
with open(self.client_id, 'r') as secret_file:
|
||||||
self.client_id = secret_file.readline().rstrip()
|
self.client_id = secret_file.readline().rstrip()
|
||||||
|
@ -184,7 +190,6 @@ class Mastodon:
|
||||||
"""
|
"""
|
||||||
Determine installed mastodon version and set major, minor and patch (not including RC info) accordingly.
|
Determine installed mastodon version and set major, minor and patch (not including RC info) accordingly.
|
||||||
|
|
||||||
|
|
||||||
Returns the version string, possibly including rc info.
|
Returns the version string, possibly including rc info.
|
||||||
"""
|
"""
|
||||||
try:
|
try:
|
||||||
|
@ -193,10 +198,25 @@ class Mastodon:
|
||||||
# instance() was added in 1.1.0, so our best guess is 1.0.0.
|
# instance() was added in 1.1.0, so our best guess is 1.0.0.
|
||||||
version_str = "1.0.0"
|
version_str = "1.0.0"
|
||||||
|
|
||||||
self.mastodon_major, self.mastodon_minor, self.mastodon_patch = parse_version_string(version)
|
self.mastodon_major, self.mastodon_minor, self.mastodon_patch = parse_version_string(version_str)
|
||||||
return version_str
|
return version_str
|
||||||
|
|
||||||
|
def verify_minimum_version(self, version_str):
|
||||||
|
"""
|
||||||
|
Update version info from server and verify that at least the specified version is present.
|
||||||
|
|
||||||
|
Returns True if version requirement is satisfied, False if not.
|
||||||
|
"""
|
||||||
|
self.retrieve_mastodon_version()
|
||||||
|
major, minor, patch = parse_version_string(version_str)
|
||||||
|
if major > self.mastodon_major:
|
||||||
|
return False
|
||||||
|
elif major == self.mastodon_major and minor > self.mastodon_minor:
|
||||||
|
return False
|
||||||
|
elif major == self.mastodon_major and minor == self.mastodon_minor and patch > self.mastodon_patch:
|
||||||
|
return False
|
||||||
|
return True
|
||||||
|
|
||||||
def auth_request_url(self, client_id=None, redirect_uris="urn:ietf:wg:oauth:2.0:oob",
|
def auth_request_url(self, client_id=None, redirect_uris="urn:ietf:wg:oauth:2.0:oob",
|
||||||
scopes=['read', 'write', 'follow']):
|
scopes=['read', 'write', 'follow']):
|
||||||
"""Returns the url that a client needs to request the grant from the server.
|
"""Returns the url that a client needs to request the grant from the server.
|
||||||
|
|
Loading…
Referencia en una nova incidència