summaryrefslogtreecommitdiffstats
path: root/laas-fog/pharoslaas/actions/fog_startImaging.py
diff options
context:
space:
mode:
Diffstat (limited to 'laas-fog/pharoslaas/actions/fog_startImaging.py')
-rw-r--r--laas-fog/pharoslaas/actions/fog_startImaging.py55
1 files changed, 55 insertions, 0 deletions
diff --git a/laas-fog/pharoslaas/actions/fog_startImaging.py b/laas-fog/pharoslaas/actions/fog_startImaging.py
new file mode 100644
index 0000000..f775efe
--- /dev/null
+++ b/laas-fog/pharoslaas/actions/fog_startImaging.py
@@ -0,0 +1,55 @@
+##############################################################################
+# Copyright 2017 Parker Berberian and Others #
+# #
+# Licensed under the Apache License, Version 2.0 (the "License"); #
+# you may not use this file except in compliance with the License. #
+# You may obtain a copy of the License at #
+# #
+# http://www.apache.org/licenses/LICENSE-2.0 #
+# #
+# Unless required by applicable law or agreed to in writing, software #
+# distributed under the License is distributed on an "AS IS" BASIS, #
+# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. #
+# See the License for the specific language governing permissions and #
+# limitations under the License. #
+##############################################################################
+
+from fogAction import FogAction
+import requests
+import sys
+
+
+class StartImagingAction(FogAction):
+ def __init__(self, config=None):
+ super(StartImagingAction, self).__init__(config=config)
+
+ def run(self, host=None):
+ """
+ Schedules an imaging task for the given host.
+ This automatically uses the "associated" disk image.
+ """
+ host = self.getFogHost(host)
+ num = str(self.getHostNumber(host))
+ url = self.baseURL+'host/'+num+'/task'
+ try:
+ req = requests.post(
+ url,
+ headers=self.header,
+ json={"taskTypeID": 1}
+ )
+ if req.status_code == 200:
+ # self.logger.info("%s", "Scheduled image task for host")
+ pass
+ except Exception:
+ # self.logger.warning("%s", "Failed to schedule host imaging")
+ # self.logger.warning("%s", "Trying to delete existing image task")
+ self.delTask(num)
+ req = requests.post(
+ url,
+ headers=self.header,
+ json={"taskTypeID": 1}
+ )
+ if req.status_code == 200:
+ # self.logger.info("%s", "Scheduled image task for host")
+ pass
+ sys.exit(0)