forked from LCOGT/observation-portal-api-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
submit_imaging_requestgroup.py
100 lines (88 loc) · 2.9 KB
/
submit_imaging_requestgroup.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
88
89
90
91
92
93
94
95
96
97
98
99
100
#!/bin/env python
"""
submit_imaging_requestgroup.py
Submit an imaging RequestGroup to be scheduled for observing.
"""
import requests
API_TOKEN = 'PlaceApiTokenHere' # API token obtained from https://observe.lco.global/accounts/profile/
PROPOSAL_ID = 'PlaceProposalHere' # Proposal IDs may be found here: https://observe.lco.global/proposals/
# The target of the observation
target = {
'name': 'm83',
'type': 'ICRS',
'ra': 204.253,
'dec': -29.865,
'epoch': 2000
}
# Constraints used for scheduling the observation
constraints = {
'max_airmass': 1.6,
'min_lunar_distance': 30
}
# The configurations for this request. In this example we are taking 2 exposures with
# different filters and exposure times. The fields acquisition_config and guiding_config
# are required fields in a configuration that are ultimately filled in with defaults
# if the submitted values are empty.
configurations = [
{
'type': 'EXPOSE',
'instrument_type': '1M0-SCICAM-SINISTRO',
'target': target,
'constraints': constraints,
'acquisition_config': {},
'guiding_config': {},
'instrument_configs': [
{
'exposure_time': 30,
'exposure_count': 1,
'optical_elements': {
'filter': 'v'
}
},
{
'exposure_time': 60,
'exposure_count': 1,
'optical_elements': {
'filter': 'b'
}
]
}
]
# The time windows during which this request should be considered for observing. In this example
# we only provide one. These times are in UTC.
windows = [{
'start': '2019-05-02 00:00:00',
'end': '2019-05-30 00:00:00'
}]
# The telescope class that should be used for this observation
location = {
'telescope_class': '1m0'
}
# The full RequestGroup, with additional meta-data
requestgroup = {
'name': 'Example Request 3', # The title
'proposal': PROPOSAL_ID,
'ipp_value': 1.05,
'operator': 'SINGLE',
'observation_type': 'NORMAL',
'requests': [{
'configurations': configurations,
'windows': windows,
'location': location,
}]
}
# Submit the fully formed RequestGroup
response = requests.post(
'https://observe.lco.global/api/requestgroups/',
headers={'Authorization': 'Token {}'.format(API_TOKEN)},
json=requestgroup # Make sure you use json!
)
# Make sure the API call was successful
try:
response.raise_for_status()
except requests.exceptions.HTTPError as exc:
print('API call failed: {}'.format(response.content))
raise exc
requestgroup_dict = response.json() # The API will return the newly submitted requestgroup as json
# Print out the url on the portal where we can view the submitted request
print('View the observing request: https://observe.lco.global/requestgroups/{}/'.format(requestgroup_dict['id']))