blob: a03fb324aaf8bbbe8e32103beee693c5ef80e8a4 [file] [log] [blame]
tierno87858ca2018-10-08 16:30:15 +02001# -*- coding: utf-8 -*-
2
3# Copyright 2018 Telefonica S.A.
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or
14# implied.
15# See the License for the specific language governing permissions and
16# limitations under the License.
17
tierno5c012612018-04-19 16:01:59 +020018
19from http import HTTPStatus
aticig3dd0db62022-03-04 19:35:45 +030020import logging
tierno1e9a3292018-11-05 18:18:45 +010021from threading import Lock
tierno5c012612018-04-19 16:01:59 +020022
aticig3dd0db62022-03-04 19:35:45 +030023from osm_common.common_utils import FakeLock
24
25
tierno5c012612018-04-19 16:01:59 +020026__author__ = "Alfonso Tierno <alfonso.tiernosepulveda@telefonica.com>"
27
28
29class FsException(Exception):
30 def __init__(self, message, http_code=HTTPStatus.INTERNAL_SERVER_ERROR):
31 self.http_code = http_code
32 Exception.__init__(self, "storage exception " + message)
33
34
35class FsBase(object):
garciadeblas2644b762021-03-24 09:21:01 +010036 def __init__(self, logger_name="fs", lock=False):
tierno1e9a3292018-11-05 18:18:45 +010037 """
38 Constructor of FsBase
39 :param logger_name: logging name
40 :param lock: Used to protect simultaneous access to the same instance class by several threads:
41 False, None: Do not protect, this object will only be accessed by one thread
42 True: This object needs to be protected by several threads accessing.
43 Lock object. Use thi Lock for the threads access protection
44 """
45 self.logger = logging.getLogger(logger_name)
46 if not lock:
47 self.lock = FakeLock()
48 elif lock is True:
49 self.lock = Lock()
50 elif isinstance(lock, Lock):
51 self.lock = lock
52 else:
53 raise ValueError("lock parameter must be a Lock class or boolean")
tierno5c012612018-04-19 16:01:59 +020054
55 def get_params(self):
56 return {}
57
58 def fs_connect(self, config):
59 pass
60
61 def fs_disconnect(self):
62 pass
63
64 def mkdir(self, folder):
tiernoebbf3532018-05-03 17:49:37 +020065 raise FsException("Method 'mkdir' not implemented")
tierno5c012612018-04-19 16:01:59 +020066
tiernod4378aa2018-12-04 15:37:23 +000067 def dir_rename(self, src, dst):
68 raise FsException("Method 'dir_rename' not implemented")
69
delacruzramo13a71fb2019-11-19 15:10:49 +010070 def dir_ls(self, storage):
71 raise FsException("Method 'dir_ls' not implemented")
72
tierno5c012612018-04-19 16:01:59 +020073 def file_exists(self, storage):
tiernoebbf3532018-05-03 17:49:37 +020074 raise FsException("Method 'file_exists' not implemented")
tierno5c012612018-04-19 16:01:59 +020075
76 def file_size(self, storage):
tiernoebbf3532018-05-03 17:49:37 +020077 raise FsException("Method 'file_size' not implemented")
tierno5c012612018-04-19 16:01:59 +020078
79 def file_extract(self, tar_object, path):
tiernoebbf3532018-05-03 17:49:37 +020080 raise FsException("Method 'file_extract' not implemented")
tierno5c012612018-04-19 16:01:59 +020081
82 def file_open(self, storage, mode):
tiernoebbf3532018-05-03 17:49:37 +020083 raise FsException("Method 'file_open' not implemented")
tierno5c012612018-04-19 16:01:59 +020084
85 def file_delete(self, storage, ignore_non_exist=False):
tiernoebbf3532018-05-03 17:49:37 +020086 raise FsException("Method 'file_delete' not implemented")
David Garcia788b9d62020-01-20 13:21:06 +010087
tiernob07e4ef2020-05-06 14:22:48 +000088 def sync(self, from_path=None):
David Garcia788b9d62020-01-20 13:21:06 +010089 raise FsException("Method 'sync' not implemented")
lloretgallegf296d2a2020-09-02 09:36:24 +000090
91 def reverse_sync(self, from_path):
92 raise FsException("Method 'reverse_sync' not implemented")