2021-11-11 18:31:28 +00:00
|
|
|
#!/usr/bin/env python3
|
2021-11-16 16:14:01 +00:00
|
|
|
"""SelfPrivacy server management API"""
|
|
|
|
import os
|
2021-11-16 10:32:10 +00:00
|
|
|
from flask import Flask, request, jsonify
|
2021-11-11 18:31:28 +00:00
|
|
|
from flask_restful import Api
|
2021-11-16 16:14:01 +00:00
|
|
|
from flask_swagger import swagger
|
|
|
|
from flask_swagger_ui import get_swaggerui_blueprint
|
2021-11-11 18:31:28 +00:00
|
|
|
|
2021-11-16 16:14:01 +00:00
|
|
|
from selfprivacy_api.resources.users import User, Users
|
2021-11-11 18:31:28 +00:00
|
|
|
from selfprivacy_api.resources.common import DecryptDisk
|
2021-11-16 16:14:01 +00:00
|
|
|
from selfprivacy_api.resources.system import api_system
|
|
|
|
from selfprivacy_api.resources.services import services as api_services
|
|
|
|
|
|
|
|
swagger_blueprint = get_swaggerui_blueprint(
|
|
|
|
"/api/docs", "/api/swagger.json", config={"app_name": "SelfPrivacy API"}
|
|
|
|
)
|
2021-11-11 18:31:28 +00:00
|
|
|
|
|
|
|
|
|
|
|
def create_app():
|
2021-11-16 16:14:01 +00:00
|
|
|
"""Initiate Flask app and bind routes"""
|
2021-11-11 18:31:28 +00:00
|
|
|
app = Flask(__name__)
|
|
|
|
api = Api(app)
|
|
|
|
|
2021-11-16 16:14:01 +00:00
|
|
|
app.config["AUTH_TOKEN"] = os.environ.get("AUTH_TOKEN")
|
|
|
|
app.config["ENABLE_SWAGGER"] = os.environ.get("ENABLE_SWAGGER", "0")
|
2021-11-16 10:32:10 +00:00
|
|
|
|
|
|
|
# Check bearer token
|
|
|
|
@app.before_request
|
|
|
|
def check_auth():
|
2021-11-16 16:14:01 +00:00
|
|
|
# Exclude swagger-ui
|
|
|
|
if not request.path.startswith("/api"):
|
|
|
|
auth = request.headers.get("Authorization")
|
|
|
|
if auth is None:
|
|
|
|
return jsonify({"error": "Missing Authorization header"}), 401
|
|
|
|
|
|
|
|
# Check if token is valid
|
|
|
|
if auth != "Bearer " + app.config["AUTH_TOKEN"]:
|
|
|
|
return jsonify({"error": "Invalid token"}), 401
|
|
|
|
|
2021-11-11 18:31:28 +00:00
|
|
|
api.add_resource(Users, "/users")
|
2021-11-16 16:14:01 +00:00
|
|
|
api.add_resource(User, "/users/<string:username>")
|
2021-11-11 18:31:28 +00:00
|
|
|
api.add_resource(DecryptDisk, "/decryptDisk")
|
|
|
|
|
|
|
|
app.register_blueprint(api_system)
|
|
|
|
app.register_blueprint(api_services)
|
|
|
|
|
2021-11-16 16:14:01 +00:00
|
|
|
@app.route("/api/swagger.json")
|
|
|
|
def spec():
|
|
|
|
if app.config["ENABLE_SWAGGER"] == "1":
|
|
|
|
swag = swagger(app)
|
|
|
|
swag["info"]["version"] = "1.0"
|
|
|
|
swag["info"]["title"] = "SelfPrivacy API"
|
|
|
|
swag["info"]["description"] = "SelfPrivacy API"
|
|
|
|
swag["securityDefinitions"] = {
|
|
|
|
"bearerAuth": {
|
|
|
|
"type": "apiKey",
|
|
|
|
"name": "Authorization",
|
|
|
|
"in": "header",
|
|
|
|
}
|
|
|
|
}
|
|
|
|
swag["security"] = [{"bearerAuth": []}]
|
|
|
|
|
|
|
|
return jsonify(swag)
|
|
|
|
return jsonify({}), 404
|
|
|
|
|
|
|
|
if app.config["ENABLE_SWAGGER"] == "1":
|
|
|
|
app.register_blueprint(swagger_blueprint, url_prefix="/api/docs")
|
|
|
|
|
2021-11-11 18:31:28 +00:00
|
|
|
return app
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
2021-11-16 16:14:01 +00:00
|
|
|
created_app = create_app()
|
|
|
|
created_app.run(port=5050, debug=False)
|