You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@ponymail.apache.org by hu...@apache.org on 2020/09/06 17:34:53 UTC
[incubator-ponymail-foal] 08/15: Add single email endpoint
This is an automated email from the ASF dual-hosted git repository.
humbedooh pushed a commit to branch master
in repository https://gitbox.apache.org/repos/asf/incubator-ponymail-foal.git
commit d1dcb5d04679e7c8063cf1061021534c55e53c7d
Author: Daniel Gruno <hu...@apache.org>
AuthorDate: Sun Sep 6 19:20:42 2020 +0200
Add single email endpoint
---
server/endpoints/email.py | 79 +++++++++++++++++++++++++++++++++++++++++++++++
1 file changed, 79 insertions(+)
diff --git a/server/endpoints/email.py b/server/endpoints/email.py
new file mode 100644
index 0000000..c22bca1
--- /dev/null
+++ b/server/endpoints/email.py
@@ -0,0 +1,79 @@
+#!/usr/bin/env python3
+# -*- coding: utf-8 -*-
+# Licensed to the Apache Software Foundation (ASF) under one or more
+# contributor license agreements. See the NOTICE file distributed with
+# this work for additional information regarding copyright ownership.
+# The ASF licenses this file to You under the Apache License, Version 2.0
+# (the "License"); you may not use this file except in compliance with
+# the License. You may obtain a copy of the License at
+#
+# http://www.apache.org/licenses/LICENSE-2.0
+#
+# Unless required by applicable law or agreed to in writing, software
+# distributed under the License is distributed on an "AS IS" BASIS,
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+# See the License for the specific language governing permissions and
+# limitations under the License.
+
+"""Simple endpoint that returns an email or an attachment from one"""
+""" THIS ONLY DEALS WITH PUBLIC EMAILS FOR NOW - AAA IS BEING WORKED ON"""
+
+import plugins.server
+import plugins.session
+import plugins.mbox
+import aiohttp.web
+import plugins.aaa
+import base64
+
+
+async def process(
+ server: plugins.server.BaseServer,
+ session: plugins.session.SessionObject,
+ indata: dict,
+) -> dict:
+
+ email = await plugins.mbox.get_email(session, id=indata.get("id"))
+ if email and isinstance(email, dict):
+ if plugins.aaa.can_access_email(session, email):
+ # Are we fetching an attachment?
+ if not indata.get("attachment"):
+ email["gravatar"] = plugins.mbox.gravatar(email)
+ return email
+ else:
+ fid = indata.get("file")
+ for entry in email.get("attachments", []):
+ if entry.get("hash") == fid:
+ ct = entry.get("content_type") or "application/binary"
+ headers = {
+ "Content-Type": ct,
+ "Content-Length": str(entry.get("size")),
+ }
+ if "image/" not in ct and "text/" not in ct:
+ headers[
+ "Content-Disposition"
+ ] = f"attachment; filename=\"{entry.get('filename')}\""
+ try:
+ attachment = await session.database.get(
+ itype="attachment", id=indata.get("file")
+ )
+ if attachment:
+ blob = base64.decodebytes(
+ attachment["_source"].get("source").encode("utf-8")
+ )
+ return aiohttp.web.Response(
+ headers=headers, status=200, body=blob
+ )
+ except Exception as e:
+ print(e)
+ return aiohttp.web.Response(
+ headers={}, status=404, text="Attachment not found"
+ )
+
+ else:
+ return aiohttp.web.Response(headers={}, status=404, text="Email not found")
+ else:
+ return aiohttp.web.Response(headers={}, status=404, text="Email not found")
+
+
+def register(server: plugins.server.BaseServer):
+ return plugins.server.Endpoint(process)