level1.py 4.07 KB
Newer Older
Wei Shoulin's avatar
c3  
Wei Shoulin committed
1
2
3
4
5
6
7
8

from ..common.delegate import Delegate

class Level1DataApi(object):
    """
    Level1 Data Operation Class
    """
    def __init__(self):
Wei Shoulin's avatar
Wei Shoulin committed
9
        self.pymodule = Delegate().load(sub_module = "facility")
Wei Shoulin's avatar
c3  
Wei Shoulin committed
10
11
12
13
14
        self.stub = getattr(self.pymodule, "Level1DataApi")()
        
    def find(self, **kwargs):
        ''' retrieve level1 records from database

Wei Shoulin's avatar
docs    
Wei Shoulin committed
15
        :param kwargs: Parameter dictionary, key items support:
Wei Shoulin's avatar
Wei Shoulin committed
16
            obs_id: [str]
Wei Shoulin's avatar
Wei Shoulin committed
17
            level0_id: [str]
Wei Shoulin's avatar
Wei Shoulin committed
18
            module_id: [str]
Wei Shoulin's avatar
c3  
Wei Shoulin committed
19
            data_type: [str]
Wei Shoulin's avatar
Wei Shoulin committed
20
21
22
            create_time : (start, end)
            qc1_status : [int]
            prc_status : [int]
Wei Shoulin's avatar
c3  
Wei Shoulin committed
23
            filename: [str]
Wei Shoulin's avatar
Wei Shoulin committed
24
            ra_cen: float = None
Wei Shoulin's avatar
Wei Shoulin committed
25
            dec_cen: float = None,
Wei Shoulin's avatar
Wei Shoulin committed
26
            radius: float = None
Wei Shoulin's avatar
Wei Shoulin committed
27
            pipeline_id: [str]
Wei Shoulin's avatar
Wei Shoulin committed
28
            build: [int]
Wei Shoulin's avatar
Wei Shoulin committed
29
30
31
            detector_no: [str]
            filter: [str]
            object_name: [str]
Wei Shoulin's avatar
c3  
Wei Shoulin committed
32
            limit: limits returns the number of records,default 0:no-limit
Wei Shoulin's avatar
docs    
Wei Shoulin committed
33
34
        
        :returns: csst_dfs_common.models.Result
Wei Shoulin's avatar
c3  
Wei Shoulin committed
35
36
37
        '''
        return self.stub.find(**kwargs)

Wei Shoulin's avatar
hstdm    
Wei Shoulin committed
38
39
40
41
42
43
44
45
46
    def find_by_brick_ids(self, **kwargs):
        ''' retrieve level1 records by brick_ids like [1,2,3,4]

        :param kwargs: Parameter dictionary, key items support:
            brick_ids: [list]
        :returns: csst_dfs_common.models.Result
        '''
        return self.stub.find_by_brick_ids(**kwargs)

Wei Shoulin's avatar
Wei Shoulin committed
47
48
49
50
51
52
53
54
55
    def find_refs_by_ids(self, **kwargs):
        ''' retrieve level1 reference records by internal level1 ids like [1,2,3,4]

        :param kwargs: Parameter dictionary, key items support:
            ids: [list]
        :returns: csst_dfs_common.models.Result
        '''
        return self.stub.find_refs_by_ids(**kwargs)
    
Wei Shoulin's avatar
Wei Shoulin committed
56
57
58
59
    def find_by_ids(self, **kwargs):
        ''' retrieve level1 records by internal level1 ids like [1,2,3,4]

        :param kwargs: Parameter dictionary, key items support:
Wei Shoulin's avatar
Wei Shoulin committed
60
61
            ids: [list],
            module_id: [str] like 'MSC'
Wei Shoulin's avatar
Wei Shoulin committed
62
63
64
65
        :returns: csst_dfs_common.models.Result
        '''
        return self.stub.find_by_ids(**kwargs)
    
Wei Shoulin's avatar
Wei Shoulin committed
66
67
68
69
70
71
72
73
74
75
76
    def sls_find_by_qc1_status(self, **kwargs):
        ''' retrieve level1 records from database

        :param kwargs: Parameter dictionary, key items support:
            qc1_status : [int],
            limit: limits returns the number of records,default 1
        
        :returns: csst_dfs_common.models.Result
        '''
        return self.stub.sls_find_by_qc1_status(**kwargs)

Wei Shoulin's avatar
c3  
Wei Shoulin committed
77
78
79
    def get(self, **kwargs):
        '''  fetch a record from database

Wei Shoulin's avatar
docs    
Wei Shoulin committed
80
        :param kwargs: Parameter dictionary, key items support:
Wei Shoulin's avatar
c3  
Wei Shoulin committed
81
            id : [int] 
Wei Shoulin's avatar
docs    
Wei Shoulin committed
82
83
        
        :returns: csst_dfs_common.models.Result
Wei Shoulin's avatar
c3  
Wei Shoulin committed
84
85
86
87
88
89
90
        '''
        return self.stub.get(**kwargs)


    def update_proc_status(self, **kwargs):
        ''' update the status of reduction

Wei Shoulin's avatar
docs    
Wei Shoulin committed
91
        :param kwargs: Parameter dictionary, key items support:
Wei Shoulin's avatar
c3  
Wei Shoulin committed
92
93
            id = [int],
            status = [int]
Wei Shoulin's avatar
docs    
Wei Shoulin committed
94
95
        
        :returns: csst_dfs_common.models.Result
Wei Shoulin's avatar
c3  
Wei Shoulin committed
96
97
98
99
        '''
        return self.stub.update_proc_status(**kwargs)

    def update_qc1_status(self, **kwargs):
Wei Shoulin's avatar
Wei Shoulin committed
100
        ''' update the status of QC1
Wei Shoulin's avatar
c3  
Wei Shoulin committed
101
        
Wei Shoulin's avatar
docs    
Wei Shoulin committed
102
        :param kwargs: Parameter dictionary, key items support:
Wei Shoulin's avatar
c3  
Wei Shoulin committed
103
104
            id = [int],
            status = [int]
Wei Shoulin's avatar
docs    
Wei Shoulin committed
105
106
        
        :returns: csst_dfs_common.models.Result
Wei Shoulin's avatar
c3  
Wei Shoulin committed
107
108
109
110
111
        '''        
        return self.stub.update_qc1_status(**kwargs)    

    def write(self, **kwargs):
        ''' insert a level1 record into database
Wei Shoulin's avatar
Wei Shoulin committed
112

Wei Shoulin's avatar
docs    
Wei Shoulin committed
113
        :param kwargs: Parameter dictionary, key items support:
Wei Shoulin's avatar
Wei Shoulin committed
114
            level0_id: [str]
Wei Shoulin's avatar
doc    
Wei Shoulin committed
115
            module_id: [str]
Wei Shoulin's avatar
Wei Shoulin committed
116
            detector_no: [str]
Wei Shoulin's avatar
doc    
Wei Shoulin committed
117
            file_type : [str]
Wei Shoulin's avatar
c3  
Wei Shoulin committed
118
119
120
121
122
            filename : [str]
            file_path : [str]            
            prc_status : [int]
            prc_time : [str]
            pipeline_id : [str]
Wei Shoulin's avatar
Wei Shoulin committed
123
            pmapname : [str]
Wei Shoulin's avatar
Wei Shoulin committed
124
            build : [str],
Wei Shoulin's avatar
doc    
Wei Shoulin committed
125
            refs : dict  for example: {'dark': 'csst_msc_dark_001.rmap', 'bias': 'csst_msc_bias_001.rmap', 'flat': 'csst_msc_flat_001.rmap'}
Wei Shoulin's avatar
docs    
Wei Shoulin committed
126
127
        
        :returns: csst_dfs_common.models.Result
Wei Shoulin's avatar
c3  
Wei Shoulin committed
128
129
130
        '''          
        return self.stub.write(**kwargs)