summaryrefslogtreecommitdiffstats
path: root/laas-fog/pharoslaas/actions/fog_startImaging.py
blob: f775efef8b22aafbb47037f7f98ebf1f2d959381 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
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)