1
0
mirror of https://github.com/etesync/server synced 2024-11-25 18:28:46 +00:00

Make chunks use the same b64 encoding we use elsewhere.

This commit is contained in:
Tom Hacohen 2020-04-15 14:33:38 +03:00
parent a97bb969e7
commit 5dfa2ac8cb

View File

@ -27,13 +27,21 @@ def generate_rev_uid(length=32):
return get_random_string(length) return get_random_string(length)
def b64encode(value):
return base64.urlsafe_b64encode(value).decode('ascii')
def b64decode(data):
data += "=" * ((4 - len(data) % 4) % 4)
return base64.urlsafe_b64decode(data)
class BinaryBase64Field(serializers.Field): class BinaryBase64Field(serializers.Field):
def to_representation(self, value): def to_representation(self, value):
return base64.urlsafe_b64encode(value).decode('ascii') return b64encode(value)
def to_internal_value(self, data): def to_internal_value(self, data):
data += "=" * ((4 - len(data) % 4) % 4) return b64decode(data)
return base64.urlsafe_b64decode(data)
class CollectionEncryptionKeyField(BinaryBase64Field): class CollectionEncryptionKeyField(BinaryBase64Field):
@ -99,7 +107,7 @@ class CollectionItemRevisionInlineSerializer(CollectionItemRevisionBaseSerialize
ret = [] ret = []
for chunk in obj.chunks.all(): for chunk in obj.chunks.all():
with open(chunk.chunkFile.path, 'rb') as f: with open(chunk.chunkFile.path, 'rb') as f:
ret.append(base64.b64encode(f.read()).decode('ascii')) ret.append(b64encode(f.read()))
return ret return ret