-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathapp.py
executable file
·48 lines (39 loc) · 1.32 KB
/
app.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
#!/usr/bin/env python
from base64 import b64encode
from datetime import datetime, timedelta
from json import dumps
from os import environ
from uuid import uuid4
import hmac
import sha
from flask import Flask, render_template, jsonify
app = Flask(__name__)
for key in ('AWS_ACCESS_KEY_ID', 'AWS_SECRET_ACCESS_KEY', 'AWS_S3_BUCKET_URL'):
app.config[key] = environ[key]
@app.route('/')
def index():
return render_template('index.html')
@app.route('/params')
def params():
def make_policy():
policy_object = {
"expiration": (datetime.now() + timedelta(hours=24)).strftime('%Y-%m-%dT%H:%M:%S.000Z'),
"conditions": [
{ "bucket": "ajax-cors-s3-upload" },
{ "acl": "public-read" },
["starts-with", "$key", "uploads/"],
{ "success_action_status": "201" }
]
}
return b64encode(dumps(policy_object).replace('\n', '').replace('\r', ''))
def sign_policy(policy):
return b64encode(hmac.new(app.config['AWS_SECRET_ACCESS_KEY'], policy, sha).digest())
policy = make_policy()
return jsonify({
"policy": policy,
"signature": sign_policy(policy),
"key": "uploads/" + uuid4().hex + ".bin",
"success_action_redirect": "/"
})
if __name__ == '__main__':
app.run(debug=True)