python-freezerclient/exceptions.py
Fabrizio Vanni 58988fc3e3 freezer scheduler
The freezer scheduler is to be executed
as daemon process on the client machines

It has the following responsibilities:

  * when using the api:
    - register -if necessary- as a client in the api
    - download the list of jobs from the api
    - schedule the jobs for execution
    - launch the freezer client at the scheduled time
    - collect metadata and exit codes and upload them to the api
    - periodically poll the api for new/updated jobs
    - if a job is part of a session (a coordinated group of jobs)
      it updates the session status when job starts/stops

  * when not using the api
    - load jobs configurations from files
    - schedule the jobs for execution
    - launch the freezer client at the scheduled time

The freezer scheduler can also be used to manage jobs
and sessions using the following positional parameters:

  job-list
  job-get
  job-create
  job-delete
  job-start
  job-stop
  session-list
  session-get
  session-create
  session-delete
  session-list-job
  session-add-job
  session-remove-job

or to register the client in the api using the positional parameter:

  register

Implements blueprint: freezer-scheduler-start

Change-Id: I06ae202a0f464f7240c137744a5b54d1177cabd9
2015-07-10 18:51:17 +01:00

75 lines
2.3 KiB
Python

"""
Copyright 2014 Hewlett-Packard
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.
This product includes cryptographic software written by Eric Young
(eay@cryptsoft.com). This product includes software written by Tim
Hudson (tjh@cryptsoft.com).
========================================================================
"""
import json
class ApiClientException(Exception):
@staticmethod
def get_message_from_api_response(r):
"""
returns a message based on information from a api-formatted response
if available, otherwise None
api-formatted response should be:
{
title: "error title string",
description: "error description string"
}
:param r: response object
:return: string with error message or None if it fails
"""
try:
body = json.loads(r.text)
message = "[*] Error {0}: {1}".format(
r.status_code,
body['description'])
except:
message = None
return message
@staticmethod
def get_message_from_response(r):
"""
composes the error message using information eventually present
in the response (http error code and the http response body)
:param r: response object
:return: string with error message or None if it fails
"""
try:
message = "[*] Error {0}: {1}".format(
r.status_code,
r.text)
except:
message = None
return message
def __init__(self, r):
message = self.get_message_from_api_response(r) or \
self.get_message_from_response(r) or \
str(r)
try:
self.status_code = r.status_code
except:
self.status_code = None
super(ApiClientException, self).__init__(message)