forked from thelastpickle/cassandra-medusa
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutils.py
87 lines (72 loc) · 2.49 KB
/
utils.py
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
# -*- coding: utf-8 -*-
# Copyright 2020- Datastax, Inc. All rights reserved.
#
# 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.
import logging
import sys
import pathlib
import traceback
import tempfile
class MedusaTempFile(object):
_tempfile = None
_tempfile_path = f'{tempfile.gettempdir()}/medusa_backup_in_progress'
def __init__(self):
pass
def create(self):
try:
self._tempfile = open(self._tempfile_path, 'wb')
except Exception:
logging.warning(f'Could not create running backup marker at {self._tempfile_path}')
def delete(self):
try:
if self._tempfile is not None:
self._tempfile.close()
pathlib.Path(self._tempfile_path).unlink()
except Exception:
pass
def exists(self):
if self._tempfile is not None:
try:
return pathlib.Path(self._tempfile_path).exists()
except Exception:
logging.warning(
f'Could not check for running backup marker {self._tempfile_path}. Assuming a backup is not running'
)
return False
else:
return False
def get_path(self):
return self._tempfile_path
def evaluate_boolean(value):
# same behaviour as python's configparser
if str(value).lower() in ('0', 'false', 'no', 'off'):
return False
elif str(value).lower() in ('1', 'true', 'yes', 'on'):
return True
else:
raise TypeError('{} not a boolean'.format(value))
def handle_exception(exception, msg, config):
if evaluate_boolean(config.grpc.enabled):
# Propagate the exception when running gRPC server so that exception/error
# details can be sent back to client.
raise exception
else:
logging.error(msg)
traceback.print_exc()
sys.exit(1)
def null_if_empty(value):
if (value is None):
return None
if (str(value) == ''):
return None
return value