1
0
mirror of https://github.com/thingsboard/thingsboard-gateway synced 2025-10-26 22:31:42 +08:00
Files
thingsboard-gateway/thingsboard_gateway/storage/file_event_storage.py

91 lines
3.6 KiB
Python

# Copyright 2020. ThingsBoard
#
# 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 thingsboard_gateway.storage.event_storage import EventStorage, log
from thingsboard_gateway.storage.event_storage_files import EventStorageFiles
from thingsboard_gateway.storage.event_storage_writer import EventStorageWriter
from thingsboard_gateway.storage.event_storage_reader import EventStorageReader
from thingsboard_gateway.storage.file_event_storage_settings import FileEventStorageSettings
from random import choice
from string import ascii_lowercase
import os
import time
import json
class FileEventStorage(EventStorage):
def __init__(self, config):
self.settings = FileEventStorageSettings(config)
self.init_data_folder_if_not_exist()
self.event_storage_files = self.init_data_files()
self.data_files = self.event_storage_files.get_data_files()
self.state_file = self.event_storage_files.get_state_file()
self.__writer = EventStorageWriter(self.event_storage_files, self.settings)
self.__reader = EventStorageReader(self.event_storage_files, self.settings)
def put(self, event):
try:
self.__writer.write(event)
return True
except Exception as e:
log.exception(e)
return False
def get_event_pack(self):
return self.__reader.read()
def event_pack_processing_done(self):
self.__reader.discard_batch()
def init_data_folder_if_not_exist(self):
path = self.settings.get_data_folder_path()
if not os.path.exists(path):
try:
os.makedirs(path)
except OSError as e:
log.error('Failed to create data folder!', e)
def init_data_files(self):
data_files = []
state_file = None
data_files_size = 0
_dir = self.settings.get_data_folder_path()
if os.path.isdir(_dir):
for file in os.listdir(_dir):
if file.startswith('data_'):
data_files.append(file)
data_files_size += os.path.getsize(_dir + file)
elif file.startswith('state_'):
state_file = file
if data_files_size == 0:
data_files.append(self.create_new_datafile())
if not state_file:
state_file = self.create_file('state_', 'file')
with open(self.settings.get_data_folder_path() + state_file, 'w') as f:
json.dump({"position": 0, "file": sorted(data_files)[0]}, f)
return EventStorageFiles(state_file, data_files)
def create_new_datafile(self):
return self.create_file('data_', str(round(time.time() * 1000)))
def create_file(self, prefix, filename):
file_path = self.settings.get_data_folder_path() + prefix + filename + '.txt'
try:
file = open(file_path, 'w')
file.close()
return prefix + filename + '.txt'
except IOError as e:
log.error("Failed to create a new file!", e)
pass