diff options
author | Christian Breunig <christian@breunig.cc> | 2023-11-21 21:15:24 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-11-21 21:15:24 +0100 |
commit | 821eaea09d2e58ac5e2e5857ca9249f811062a4b (patch) | |
tree | 66efbf4a9c77c0f90abf4d7104f10054b70dfa90 /src/services | |
parent | 3ab206b04350aec4872ed72ae4bd3440a47204f0 (diff) | |
parent | 36f3c329c2df0e78f2f5da933d9729a872fb2a11 (diff) | |
download | vyos-1x-821eaea09d2e58ac5e2e5857ca9249f811062a4b.tar.gz vyos-1x-821eaea09d2e58ac5e2e5857ca9249f811062a4b.zip |
Merge pull request #2516 from sever-sever/T5767
T5767: HTTPS API add reboot and poweroff endpoints
Diffstat (limited to 'src/services')
-rwxr-xr-x | src/services/vyos-http-api-server | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/src/services/vyos-http-api-server b/src/services/vyos-http-api-server index daee24257..85d7884b6 100755 --- a/src/services/vyos-http-api-server +++ b/src/services/vyos-http-api-server @@ -223,6 +223,19 @@ class ShowModel(ApiModel): } } +class RebootModel(ApiModel): + op: StrictStr + path: List[StrictStr] + + class Config: + schema_extra = { + "example": { + "key": "id_key", + "op": "reboot", + "path": ["op", "mode", "path"], + } + } + class ResetModel(ApiModel): op: StrictStr path: List[StrictStr] @@ -236,6 +249,19 @@ class ResetModel(ApiModel): } } +class PoweroffModel(ApiModel): + op: StrictStr + path: List[StrictStr] + + class Config: + schema_extra = { + "example": { + "key": "id_key", + "op": "poweroff", + "path": ["op", "mode", "path"], + } + } + class Success(BaseModel): success: bool @@ -713,6 +739,26 @@ def show_op(data: ShowModel): return success(res) +@app.post('/reboot') +def reboot_op(data: RebootModel): + session = app.state.vyos_session + + op = data.op + path = data.path + + try: + if op == 'reboot': + res = session.reboot(path) + else: + return error(400, f"'{op}' is not a valid operation") + except ConfigSessionError as e: + return error(400, str(e)) + except Exception as e: + logger.critical(traceback.format_exc()) + return error(500, "An internal error occured. Check the logs for details.") + + return success(res) + @app.post('/reset') def reset_op(data: ResetModel): session = app.state.vyos_session @@ -733,6 +779,26 @@ def reset_op(data: ResetModel): return success(res) +@app.post('/poweroff') +def poweroff_op(data: PoweroffModel): + session = app.state.vyos_session + + op = data.op + path = data.path + + try: + if op == 'poweroff': + res = session.poweroff(path) + else: + return error(400, f"'{op}' is not a valid operation") + except ConfigSessionError as e: + return error(400, str(e)) + except Exception as e: + logger.critical(traceback.format_exc()) + return error(500, "An internal error occured. Check the logs for details.") + + return success(res) + ### # GraphQL integration |