mirror of
https://git.sr.ht/~tsileo/microblog.pub
synced 2025-01-08 22:24:27 +00:00
Allow to attach files from the admin UI when posting a note
This commit is contained in:
parent
9c664ad29d
commit
c6ae9793d5
2 changed files with 26 additions and 47 deletions
70
app.py
70
app.py
|
@ -1223,51 +1223,6 @@ def api_debug():
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
@app.route("/api/upload", methods=["POST"])
|
|
||||||
@api_required
|
|
||||||
def api_upload():
|
|
||||||
file = request.files["file"]
|
|
||||||
rfilename = secure_filename(file.filename)
|
|
||||||
prefix = hashlib.sha256(os.urandom(32)).hexdigest()[:6]
|
|
||||||
mtype = mimetypes.guess_type(rfilename)[0]
|
|
||||||
filename = f"{prefix}_{rfilename}"
|
|
||||||
file.save(os.path.join("static", "media", filename))
|
|
||||||
|
|
||||||
# Remove EXIF metadata
|
|
||||||
if filename.lower().endswith(".jpg") or filename.lower().endswith(".jpeg"):
|
|
||||||
piexif.remove(os.path.join("static", "media", filename))
|
|
||||||
|
|
||||||
print("upload OK")
|
|
||||||
print(filename)
|
|
||||||
attachment = [
|
|
||||||
{
|
|
||||||
"mediaType": mtype,
|
|
||||||
"name": rfilename,
|
|
||||||
"type": "Document",
|
|
||||||
"url": BASE_URL + f"/static/media/{filename}",
|
|
||||||
}
|
|
||||||
]
|
|
||||||
print(attachment)
|
|
||||||
content = request.args.get("content")
|
|
||||||
to = request.args.get("to")
|
|
||||||
note = ap.Note(
|
|
||||||
attributedTo=MY_PERSON.id,
|
|
||||||
cc=[ID + "/followers"],
|
|
||||||
to=[to if to else ap.AS_PUBLIC],
|
|
||||||
content=content, # TODO(tsileo): handle markdown
|
|
||||||
attachment=attachment,
|
|
||||||
)
|
|
||||||
print("post_note_init")
|
|
||||||
print(note)
|
|
||||||
create = note.build_create()
|
|
||||||
print(create)
|
|
||||||
print(create.to_dict())
|
|
||||||
OUTBOX.post(create)
|
|
||||||
print("posted")
|
|
||||||
|
|
||||||
return Response(status=201, response="OK")
|
|
||||||
|
|
||||||
|
|
||||||
@app.route("/api/new_note", methods=["POST"])
|
@app.route("/api/new_note", methods=["POST"])
|
||||||
@api_required
|
@api_required
|
||||||
def api_new_note():
|
def api_new_note():
|
||||||
|
@ -1293,7 +1248,7 @@ def api_new_note():
|
||||||
if tag["type"] == "Mention":
|
if tag["type"] == "Mention":
|
||||||
cc.append(tag["href"])
|
cc.append(tag["href"])
|
||||||
|
|
||||||
note = ap.Note(
|
raw_note = dict(
|
||||||
attributedTo=MY_PERSON.id,
|
attributedTo=MY_PERSON.id,
|
||||||
cc=list(set(cc)),
|
cc=list(set(cc)),
|
||||||
to=[to if to else ap.AS_PUBLIC],
|
to=[to if to else ap.AS_PUBLIC],
|
||||||
|
@ -1302,6 +1257,29 @@ def api_new_note():
|
||||||
source={"mediaType": "text/markdown", "content": source},
|
source={"mediaType": "text/markdown", "content": source},
|
||||||
inReplyTo=reply.id if reply else None,
|
inReplyTo=reply.id if reply else None,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if 'file' in request.files:
|
||||||
|
file = request.files["file"]
|
||||||
|
rfilename = secure_filename(file.filename)
|
||||||
|
prefix = hashlib.sha256(os.urandom(32)).hexdigest()[:6]
|
||||||
|
mtype = mimetypes.guess_type(rfilename)[0]
|
||||||
|
filename = f"{prefix}_{rfilename}"
|
||||||
|
file.save(os.path.join("static", "media", filename))
|
||||||
|
|
||||||
|
# Remove EXIF metadata
|
||||||
|
if filename.lower().endswith(".jpg") or filename.lower().endswith(".jpeg"):
|
||||||
|
piexif.remove(os.path.join("static", "media", filename))
|
||||||
|
|
||||||
|
raw_note['attachment'] = [
|
||||||
|
{
|
||||||
|
"mediaType": mtype,
|
||||||
|
"name": rfilename,
|
||||||
|
"type": "Document",
|
||||||
|
"url": BASE_URL + f"/static/media/{filename}",
|
||||||
|
}
|
||||||
|
]
|
||||||
|
|
||||||
|
note = ap.Note(**raw_note)
|
||||||
create = note.build_create()
|
create = note.build_create()
|
||||||
OUTBOX.post(create)
|
OUTBOX.post(create)
|
||||||
|
|
||||||
|
|
|
@ -11,11 +11,12 @@
|
||||||
{% else %}
|
{% else %}
|
||||||
<h3 style="padding-bottom:20px;">New note</h3>
|
<h3 style="padding-bottom:20px;">New note</h3>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
<form action="/api/new_note" method="POST">
|
<form action="/api/new_note" method="POST" enctype="multipart/form-data">
|
||||||
<input type="hidden" name="redirect" value="/">
|
<input type="hidden" name="redirect" value="/">
|
||||||
<input type="hidden" name="csrf_token" value="{{ csrf_token() }}">
|
<input type="hidden" name="csrf_token" value="{{ csrf_token() }}">
|
||||||
{% if reply %}<input type="hidden" name="reply" value="{{reply}}">{% endif %}
|
{% if reply %}<input type="hidden" name="reply" value="{{reply}}">{% endif %}
|
||||||
<textarea name="content" rows="10" cols="50" autofocus="autofocus">{{ content }}</textarea>
|
<textarea name="content" rows="10" cols="50" autofocus="autofocus">{{ content }}</textarea>
|
||||||
|
<input type="file" name="file">
|
||||||
<div style="margin-top:20px;">
|
<div style="margin-top:20px;">
|
||||||
<input type="submit" value="post">
|
<input type="submit" value="post">
|
||||||
</div>
|
</div>
|
||||||
|
|
Loading…
Reference in a new issue