diff options
author | Mark Haines <mark.haines@matrix.org> | 2015-02-02 16:02:31 +0000 |
---|---|---|
committer | Mark Haines <mark.haines@matrix.org> | 2015-02-02 16:02:31 +0000 |
commit | 22c1ffb0a0b1a817acade3e8a19948b208a2c9f3 (patch) | |
tree | 74160dd84276e8e618d6c725d54215271dbd3622 /synapse/rest/media/v1/identicon_resource.py | |
parent | Merge master into develop (diff) | |
download | synapse-22c1ffb0a0b1a817acade3e8a19948b208a2c9f3.tar.xz |
Add a media/v1/identicon resource for generating identicons using pydenticon
Diffstat (limited to 'synapse/rest/media/v1/identicon_resource.py')
-rw-r--r-- | synapse/rest/media/v1/identicon_resource.py | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/synapse/rest/media/v1/identicon_resource.py b/synapse/rest/media/v1/identicon_resource.py new file mode 100644 index 0000000000..8878d4c3d4 --- /dev/null +++ b/synapse/rest/media/v1/identicon_resource.py @@ -0,0 +1,48 @@ +from pydenticon import Generator +from twisted.web.resource import Resource + +FOREGROUND = [ + "rgb(45,79,255)", + "rgb(254,180,44)", + "rgb(226,121,234)", + "rgb(30,179,253)", + "rgb(232,77,65)", + "rgb(49,203,115)", + "rgb(141,69,170)" +] + +BACKGROUND = "rgb(224,224,224)" +SIZE = 5 + + +class IdenticonResource(Resource): + isLeaf = True + + def __init__(self): + Resource.__init__(self) + self.generator = Generator( + SIZE, SIZE, foreground=FOREGROUND, background=BACKGROUND, + ) + + def generate_identicon(self, name, width, height): + v_padding = width % SIZE + h_padding = height % SIZE + top_padding = v_padding // 2 + left_padding = h_padding // 2 + bottom_padding = v_padding - top_padding + right_padding = h_padding - left_padding + width -= v_padding + height -= h_padding + padding = (top_padding, bottom_padding, left_padding, right_padding) + identicon = self.generator.generate( + name, width, height, padding=padding + ) + return identicon + + def render_GET(self, request): + name = "/".join(request.postpath) + width = int(request.args.get("width", 96)) + height = int(request.args.get("width", 96)) + identicon_bytes = self.generate_identicon(name, width, height) + request.setHeader(b"Content-Type", b"image/png") + return identicon_bytes |