Compare commits
4 commits
master
...
ws_endpoin
Author | SHA1 | Date | |
---|---|---|---|
e2128c8402 | |||
309c0b50b1 | |||
95961d4b7b | |||
4cb417a448 |
3 changed files with 51 additions and 5 deletions
|
@ -8,7 +8,7 @@ COPY . /git/
|
||||||
RUN find . -type d -name .git -exec git describe --always --dirty > /git-version.txt \;
|
RUN find . -type d -name .git -exec git describe --always --dirty > /git-version.txt \;
|
||||||
|
|
||||||
|
|
||||||
FROM python:3.13
|
FROM python:3.12
|
||||||
|
|
||||||
EXPOSE 8080
|
EXPOSE 8080
|
||||||
|
|
||||||
|
|
46
app.py
46
app.py
|
@ -18,6 +18,26 @@ from gitmgr import GitManagerConfiguration, GitManager
|
||||||
startup_timestamp = datetime.now()
|
startup_timestamp = datetime.now()
|
||||||
|
|
||||||
|
|
||||||
|
class AuthenticatedHandler(tornado.web.RequestHandler, metaclass=ABCMeta):
|
||||||
|
# noinspection PyAttributeOutsideInit
|
||||||
|
def initialize(self, auth_provider=None):
|
||||||
|
self.auth_provider = auth_provider
|
||||||
|
|
||||||
|
def prepare(self):
|
||||||
|
if self.auth_provider is None:
|
||||||
|
return
|
||||||
|
|
||||||
|
# check authentication
|
||||||
|
auth_hdr = "Authentication"
|
||||||
|
if auth_hdr not in self.request.headers:
|
||||||
|
raise tornado.web.HTTPError(401, reason="authentication not provided")
|
||||||
|
|
||||||
|
tk = self.request.headers[auth_hdr]
|
||||||
|
|
||||||
|
if not self.auth_provider.validate_token(tk):
|
||||||
|
raise tornado.web.HTTPError(403, reason="invalid authentication token provided")
|
||||||
|
|
||||||
|
|
||||||
class HealthHandler(tornado.web.RequestHandler, metaclass=ABCMeta):
|
class HealthHandler(tornado.web.RequestHandler, metaclass=ABCMeta):
|
||||||
# noinspection PyAttributeOutsideInit
|
# noinspection PyAttributeOutsideInit
|
||||||
def initialize(self, sources=None):
|
def initialize(self, sources=None):
|
||||||
|
@ -77,12 +97,38 @@ class Oas3Handler(tornado.web.RequestHandler, metaclass=ABCMeta):
|
||||||
self.finish()
|
self.finish()
|
||||||
|
|
||||||
|
|
||||||
|
class AllEntitiesHandler(AuthenticatedHandler, metaclass=ABCMeta):
|
||||||
|
# noinspection PyAttributeOutsideInit
|
||||||
|
def initialize(self, auth_provider=None):
|
||||||
|
super().initialize(auth_provider)
|
||||||
|
|
||||||
|
def post(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def get(self):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
|
class SingleEntityHandler(AuthenticatedHandler, metaclass=ABCMeta):
|
||||||
|
# noinspection PyAttributeOutsideInit
|
||||||
|
def initialize(self, auth_provider=None):
|
||||||
|
super().initialize(auth_provider)
|
||||||
|
|
||||||
|
def post(self, identifier):
|
||||||
|
pass
|
||||||
|
|
||||||
|
def get(self, identifier):
|
||||||
|
pass
|
||||||
|
|
||||||
|
|
||||||
def make_app(_auth_provider=None, gitmgr=None):
|
def make_app(_auth_provider=None, gitmgr=None):
|
||||||
version_path = r"/v[0-9]"
|
version_path = r"/v[0-9]"
|
||||||
return tornado.web.Application([
|
return tornado.web.Application([
|
||||||
(version_path + r"/health", HealthHandler,
|
(version_path + r"/health", HealthHandler,
|
||||||
{"sources": [lambda: {"git-head": gitmgr.head_sha}] if gitmgr else None}),
|
{"sources": [lambda: {"git-head": gitmgr.head_sha}] if gitmgr else None}),
|
||||||
(version_path + r"/oas3", Oas3Handler),
|
(version_path + r"/oas3", Oas3Handler),
|
||||||
|
(version_path + r"/entities", AllEntitiesHandler, {"auth_provider": _auth_provider}),
|
||||||
|
(version_path + r"/entity/{.*}", SingleEntityHandler, {"auth_provider": _auth_provider}),
|
||||||
])
|
])
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
tornado==6.4.1
|
tornado==6.3.3
|
||||||
isodate==0.7.2
|
isodate==0.6.1
|
||||||
pytest==8.3.3
|
pytest==7.4.3
|
||||||
GitPython==3.1.43
|
GitPython==3.1.40
|
Loading…
Reference in a new issue