DeleteVM endpoint added

This commit is contained in:
ahmadbilalkhalid 2019-06-26 12:33:29 +05:00
parent 272bbcd5c6
commit a65a9b243c
1 changed files with 35 additions and 5 deletions

40
main.py
View File

@ -18,6 +18,12 @@ createvm_argparser.add_argument("realm", type=str, required=True)
createvm_argparser.add_argument("seed", type=str, required=True)
createvm_argparser.add_argument("specs", type=dict, required=True)
deletevm_argparser = reqparse.RequestParser()
deletevm_argparser.add_argument("name", type=str, required=True)
deletevm_argparser.add_argument("realm", type=str, required=True)
deletevm_argparser.add_argument("seed", type=str, required=True)
deletevm_argparser.add_argument("vmid", type=str, required=True)
vmstatus_argparser = reqparse.RequestParser()
vmstatus_argparser.add_argument("id", type=str, required=True)
@ -38,9 +44,32 @@ class CreateVM(Resource):
etcd_client.put(f"/v1/vm/{uuid4().hex}", json.dumps(vm_entry))
return {'message': "VM Creation Queued"}, 200
return {"message": "VM Creation Queued"}, 200
else:
return {'message': 'Invalid Credentials'}, 400
return {"message": "Invalid Credentials"}, 400
class DeleteVM(Resource):
def post(self):
deletevm_args = deletevm_argparser.parse_args()
name, realm, seed, vmid = deletevm_args.name, deletevm_args.realm,\
deletevm_args.seed, deletevm_args.vmid
if check_otp(name, realm, seed) == 200:
# User is good
vmentry_etcd = etcd_client.get(f"/v1/vm/{vmid}")[0]
if vmentry_etcd:
vmentry_etcd = json.loads(vmentry_etcd)
vmentry_etcd["status"] = "REQUEST_DELETE"
etcd_client.put(f"/v1/vm/{vmid}", json.dumps(vmentry_etcd))
return {"message": "VM Deletion Queued"}, 200
else:
return {"message": "Invalid VM ID"}
else:
return {"message": "Invalid Credentials"}, 400
class VmStatus(Resource):
@ -53,8 +82,9 @@ class VmStatus(Resource):
return {"Message": "Not Found"}
api.add_resource(CreateVM, '/vm/create')
api.add_resource(VmStatus, '/vm/status')
api.add_resource(CreateVM, "/vm/create")
api.add_resource(DeleteVM, "/vm/delete")
api.add_resource(VmStatus, "/vm/status")
if __name__ == '__main__':
if __name__ == "__main__":
app.run(debug=True)