forked from oppia/oppia
-
Notifications
You must be signed in to change notification settings - Fork 0
/
constants.py
79 lines (59 loc) · 2.56 KB
/
constants.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
# coding: utf-8
#
# Copyright 2017 The Oppia Authors. All Rights Reserved.
#
# 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.
"""Loads constants for backend use."""
from __future__ import absolute_import # pylint: disable=import-only-modules
from __future__ import unicode_literals # pylint: disable=import-only-modules
import json
import os
import re
import python_utils
from typing import Any, Dict, Text, TextIO # isort:skip # pylint: disable=unused-import
def parse_json_from_js(js_file):
# type: (TextIO) -> Dict[Text, Any]
"""Extracts JSON object from JS file.
Args:
js_file: file. The js file containing JSON that needs to be parsed.
Returns:
dict. The dict representation of JSON object in the js file.
"""
text = js_file.read()
text_without_comments = remove_comments(text)
json_start = text_without_comments.find('{\n')
# Add 1 to index returned because the '}' is part of the JSON object.
json_end = text_without_comments.rfind('}') + 1
json_dict = json.loads(text_without_comments[json_start:json_end]) # type: Dict[Text, Any]
return json_dict
def remove_comments(text):
# type: (Text) -> Text
"""Removes comments from given text.
Args:
text: str. The text from which comments should be removed.
Returns:
str. Text with all its comments removed.
"""
return re.sub(r' //.*\n', r'', text)
class Constants(dict): # type: ignore[type-arg]
"""Transforms dict to object, attributes can be accessed by dot notation."""
def __setattr__(self, name, value):
# type: (Text, Any) -> None
self[name] = value
def __getattr__(self, name):
# type: (Text) -> Any
return self[name]
with python_utils.open_file(os.path.join('assets', 'constants.ts'), 'r') as f: # type: ignore[no-untyped-call]
constants = Constants(parse_json_from_js(f)) # pylint:disable=invalid-name
with python_utils.open_file('release_constants.json', 'r') as f: # type: ignore[no-untyped-call]
release_constants = Constants(json.loads(f.read())) # pylint:disable=invalid-name