Commit 65c0fd80 authored by Wei Shoulin's avatar Wei Shoulin
Browse files

reconstruct

parent cb2e0a9e
...@@ -54,4 +54,15 @@ def create_dir(root_dir, sub_system, time_str: list): ...@@ -54,4 +54,15 @@ def create_dir(root_dir, sub_system, time_str: list):
the_dir = os.path.join(root_dir, sub_system, time_str) the_dir = os.path.join(root_dir, sub_system, time_str)
if not os.path.exists(the_dir): if not os.path.exists(the_dir):
os.makedirs(os.path.join(root_dir, sub_system, time_str)) os.makedirs(os.path.join(root_dir, sub_system, time_str))
return the_dir return the_dir
\ No newline at end of file
def yield_file_bytes(full_file_path, chunk_size):
if not os.path.exists(full_file_path):
raise Exception("%s file not found" %(full_file_path))
with open(full_file_path, 'rb') as f:
while True:
data = f.read(chunk_size)
if not data:
break
yield data
\ No newline at end of file
...@@ -11,10 +11,9 @@ from glob import glob ...@@ -11,10 +11,9 @@ from glob import glob
from astropy.io import fits from astropy.io import fits
from ..common.db import DBClient from ..common.db import DBClient
from ..common.utils import get_parameter, format_time_ms, create_dir from ..common.utils import *
log = logging.getLogger('csst') log = logging.getLogger('csst')
class FitsApi(object): class FitsApi(object):
def __init__(self, sub_system = "ifs"): def __init__(self, sub_system = "ifs"):
self.sub_system = sub_system self.sub_system = sub_system
...@@ -36,14 +35,14 @@ class FitsApi(object): ...@@ -36,14 +35,14 @@ class FitsApi(object):
def find(self, **kwargs): def find(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
obs_time = [int] obs_time = [int],
file_name = [str] file_name = [str],
exp_time = (start, end) exp_time = (start, end),
ccd_num = [int] ccd_num = [int],
qc0_status = [int] qc0_status = [int],
prc_status = [int] prc_status = [int]
return list of paths return list of raw records
''' '''
paths = [] paths = []
...@@ -90,9 +89,9 @@ class FitsApi(object): ...@@ -90,9 +89,9 @@ class FitsApi(object):
def read(self, **kwargs): def read(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
file_path = [str] file_path = [str],
chunk_size = [int] chunk_size = [int] default 20480
yield bytes of fits file yield bytes of fits file
''' '''
...@@ -106,23 +105,17 @@ class FitsApi(object): ...@@ -106,23 +105,17 @@ class FitsApi(object):
r = self.db.select_one( r = self.db.select_one(
"select * from ifs_rawfits where id=?", (fits_id,)) "select * from ifs_rawfits where id=?", (fits_id,))
if r is not None: if r is not None:
file_path = os.path.join(self.root_dir, r["file_path"]) file_path = r["file_path"]
if file_path is not None: if file_path is not None:
path = os.path.join(self.root_dir, file_path) chunk_size = get_parameter(kwargs, "chunk_size", 20480)
chunk_size = get_parameter(kwargs, "chunk_size", 1024) return yield_file_bytes(os.path.join(self.root_dir, file_path), chunk_size)
with open(path, 'rb') as f:
while True:
data = f.read(chunk_size)
if not data:
break
yield data
def update_proc_status(self, **kwargs): def update_proc_status(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
status = [0 or 1] status = [int]
''' '''
fits_id = get_parameter(kwargs, "fits_id") fits_id = get_parameter(kwargs, "fits_id")
status = get_parameter(kwargs, "status") status = get_parameter(kwargs, "status")
...@@ -143,7 +136,8 @@ class FitsApi(object): ...@@ -143,7 +136,8 @@ class FitsApi(object):
def update_qc0_status(self, **kwargs): def update_qc0_status(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
status = [int]
''' '''
fits_id = get_parameter(kwargs, "fits_id") fits_id = get_parameter(kwargs, "fits_id")
...@@ -164,10 +158,9 @@ class FitsApi(object): ...@@ -164,10 +158,9 @@ class FitsApi(object):
def import2db(self, **kwargs): def import2db(self, **kwargs):
''' '''
reduce the header of fits file of server and insert a record into database
parameter kwargs: parameter kwargs:
file_path = [str] file_path = [str]
upload to database
''' '''
file_path = get_parameter(kwargs, "file_path") file_path = get_parameter(kwargs, "file_path")
...@@ -204,6 +197,11 @@ class FitsApi(object): ...@@ -204,6 +197,11 @@ class FitsApi(object):
log.info("raw fits %s imported.", file_path) log.info("raw fits %s imported.", file_path)
def write(self, **kwargs): def write(self, **kwargs):
'''
copy a local file to file storage, then reduce the header of fits file and insert a record into database
parameter kwargs:
file_path = [str]
'''
file_path = get_parameter(kwargs, "file_path") file_path = get_parameter(kwargs, "file_path")
if not file_path: if not file_path:
......
...@@ -5,11 +5,9 @@ import shutil ...@@ -5,11 +5,9 @@ import shutil
from astropy.io import fits from astropy.io import fits
from ..common.db import DBClient from ..common.db import DBClient
from ..common.utils import get_parameter, format_time_ms,create_dir from ..common.utils import *
from . import FitsApi
log = logging.getLogger('csst') log = logging.getLogger('csst')
class RefFitsApi(object): class RefFitsApi(object):
REF_FITS_BIAS = "bias" REF_FITS_BIAS = "bias"
REF_FITS_FLAT = "flat" REF_FITS_FLAT = "flat"
...@@ -35,13 +33,13 @@ class RefFitsApi(object): ...@@ -35,13 +33,13 @@ class RefFitsApi(object):
def find(self, **kwargs): def find(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
obs_time = [int] obs_time = [int],
file_name = [str] file_name = [str],
exp_time = (start, end) exp_time = (start, end),
status = [int] status = [int],
ref_type = [str] ref_type = [str]
return list of paths return list of reference's files records
''' '''
obs_time = get_parameter(kwargs, "obs_time") obs_time = get_parameter(kwargs, "obs_time")
file_name = get_parameter(kwargs, "file_name") file_name = get_parameter(kwargs, "file_name")
...@@ -73,7 +71,8 @@ class RefFitsApi(object): ...@@ -73,7 +71,8 @@ class RefFitsApi(object):
return r return r
def get(self, **kwargs): def get(self, **kwargs):
''' '''query database, return a record as dict
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int]
...@@ -87,8 +86,8 @@ class RefFitsApi(object): ...@@ -87,8 +86,8 @@ class RefFitsApi(object):
def read(self, **kwargs): def read(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
file_path = [str] file_path = [str],
chunk_size = [int] chunk_size = [int]
yield bytes of fits file yield bytes of fits file
...@@ -103,22 +102,17 @@ class RefFitsApi(object): ...@@ -103,22 +102,17 @@ class RefFitsApi(object):
r = self.db.select_one( r = self.db.select_one(
"select * from ifs_ref_fits where id=?", (fits_id)) "select * from ifs_ref_fits where id=?", (fits_id))
if r is not None: if r is not None:
file_path = os.path.join(self.root_dir, r["file_path"]) file_path = r["file_path"]
if file_path is not None: if file_path is not None:
path = os.path.join(self.root_dir, file_path) chunk_size = get_parameter(kwargs, "chunk_size", 20480)
chunk_size = get_parameter(kwargs, "chunk_size", 1024) return yield_file_bytes(os.path.join(self.root_dir, file_path), chunk_size)
with open(path, 'rb') as f:
while True:
data = f.read(chunk_size)
if not data:
break
yield data
def update_status(self, **kwargs): def update_status(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
status = [int]
''' '''
fits_id = get_parameter(kwargs, "fits_id") fits_id = get_parameter(kwargs, "fits_id")
...@@ -197,6 +191,11 @@ class RefFitsApi(object): ...@@ -197,6 +191,11 @@ class RefFitsApi(object):
log.info("ref fits %s imported.", file_path) log.info("ref fits %s imported.", file_path)
def write(self, **kwargs): def write(self, **kwargs):
''' copy a local file to file storage, then reduce the header of fits file and insert a record into database
parameter kwargs:
file_path = [str]
'''
file_path = get_parameter(kwargs, "file_path") file_path = get_parameter(kwargs, "file_path")
new_file_dir = create_dir(os.path.join(self.root_dir, "refs"), new_file_dir = create_dir(os.path.join(self.root_dir, "refs"),
......
...@@ -4,7 +4,7 @@ import time, datetime ...@@ -4,7 +4,7 @@ import time, datetime
import shutil import shutil
from ..common.db import DBClient from ..common.db import DBClient
from ..common.utils import get_parameter, format_time_ms, create_dir from ..common.utils import *
log = logging.getLogger('csst') log = logging.getLogger('csst')
...@@ -26,11 +26,11 @@ class Result0Api(object): ...@@ -26,11 +26,11 @@ class Result0Api(object):
def find(self, **kwargs): def find(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
raw_id = [int] raw_id = [int],
file_name = [str] file_name = [str],
proc_type = [str] proc_type = [str]
return list of paths return list of level 0 record
''' '''
paths = [] paths = []
...@@ -52,7 +52,8 @@ class Result0Api(object): ...@@ -52,7 +52,8 @@ class Result0Api(object):
return r return r
def get(self, **kwargs): def get(self, **kwargs):
''' ''' query database, return a record as dict
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int]
...@@ -64,11 +65,12 @@ class Result0Api(object): ...@@ -64,11 +65,12 @@ class Result0Api(object):
return r return r
def read(self, **kwargs): def read(self, **kwargs):
''' ''' yield bytes of fits file
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
file_path = [str] file_path = [str],
chunk_size = [int] chunk_size = [int] default 20480
yield bytes of fits file yield bytes of fits file
''' '''
...@@ -82,28 +84,20 @@ class Result0Api(object): ...@@ -82,28 +84,20 @@ class Result0Api(object):
r = self.db.select_one( r = self.db.select_one(
"select * from ifs_result_0 where id=?", (fits_id)) "select * from ifs_result_0 where id=?", (fits_id))
if r is not None: if r is not None:
file_path = os.path.join(self.root_dir, r["file_path"]) file_path = r["file_path"]
if file_path is not None: if file_path is not None:
path = os.path.join(self.root_dir, file_path) chunk_size = get_parameter(kwargs, "chunk_size", 20480)
chunk_size = get_parameter(kwargs, "chunk_size", 1024) return yield_file_bytes(os.path.join(self.root_dir, file_path), chunk_size)
with open(path, 'rb') as f:
while True:
data = f.read(chunk_size)
if not data:
break
yield data
def write(self, **kwargs): def write(self, **kwargs):
''' ''' copy a local level 0 file to file storage, and insert a record into database
parameter kwargs: parameter kwargs:
raw_id = [int] raw_id = [int],
file_path = [str] file_path = [str],
proc_type = [str] proc_type = [str]
insert into database
''' '''
raw_id = get_parameter(kwargs, "raw_id") raw_id = get_parameter(kwargs, "raw_id")
file_path = get_parameter(kwargs, "file_path") file_path = get_parameter(kwargs, "file_path")
proc_type = get_parameter(kwargs, "proc_type", "default") proc_type = get_parameter(kwargs, "proc_type", "default")
......
...@@ -4,10 +4,9 @@ import time, datetime ...@@ -4,10 +4,9 @@ import time, datetime
import shutil import shutil
from ..common.db import DBClient from ..common.db import DBClient
from ..common.utils import get_parameter, format_time_ms, create_dir from ..common.utils import *
log = logging.getLogger('csst') log = logging.getLogger('csst')
class Result1Api(object): class Result1Api(object):
def __init__(self, sub_system = "ifs"): def __init__(self, sub_system = "ifs"):
self.sub_system = sub_system self.sub_system = sub_system
...@@ -26,10 +25,10 @@ class Result1Api(object): ...@@ -26,10 +25,10 @@ class Result1Api(object):
def find(self, **kwargs): def find(self, **kwargs):
''' '''
parameter kwargs: parameter kwargs:
file_name = [str] file_name = [str],
proc_type = [str] proc_type = [str]
return list of paths return list of level 1 record
''' '''
paths = [] paths = []
...@@ -61,11 +60,12 @@ class Result1Api(object): ...@@ -61,11 +60,12 @@ class Result1Api(object):
return r, result0s return r, result0s
def read(self, **kwargs): def read(self, **kwargs):
''' ''' yield bytes of fits file
parameter kwargs: parameter kwargs:
fits_id = [int] fits_id = [int],
file_path = [str] file_path = [str],
chunk_size = [int] chunk_size = [int] default 20480
yield bytes of fits file yield bytes of fits file
''' '''
...@@ -79,23 +79,17 @@ class Result1Api(object): ...@@ -79,23 +79,17 @@ class Result1Api(object):
r = self.db.select_one( r = self.db.select_one(
"select * from ifs_result_1 where id=?", (fits_id)) "select * from ifs_result_1 where id=?", (fits_id))
if r is not None: if r is not None:
file_path = os.path.join(self.root_dir, r["file_path"]) file_path = r["file_path"]
if file_path is not None: if file_path is not None:
path = os.path.join(self.root_dir, file_path) chunk_size = get_parameter(kwargs, "chunk_size", 20480)
chunk_size = get_parameter(kwargs, "chunk_size", 1024) return yield_file_bytes(os.path.join(self.root_dir, file_path), chunk_size)
with open(path, 'rb') as f:
while True:
data = f.read(chunk_size)
if not data:
break
yield data
def write(self, **kwargs): def write(self, **kwargs):
''' ''' copy a local level 1 file to file storage, and insert a record into database
parameter kwargs: parameter kwargs:
file_path = [str] file_path = [str],
proc_type = [str] proc_type = [str],
result0_ids = [list] result0_ids = [list]
insert into database insert into database
......
import os
import unittest import unittest
from astropy.io import fits from astropy.io import fits
......
Supports Markdown
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment