forked from ourresearch/jump-api
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathjournal_price.py
102 lines (81 loc) · 2.91 KB
/
journal_price.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
101
102
# coding: utf-8
from cached_property import cached_property
from collections import OrderedDict
from app import db
from package_input import PackageInput
class JournalPrice(db.Model):
__tablename__ = "jump_journal_prices"
package_id = db.Column(db.Text, db.ForeignKey("jump_account_package.package_id"), primary_key=True)
issn_l = db.Column(db.Text, primary_key=True)
subject = db.Column(db.Text)
price = db.Column(db.Numeric(asdecimal=False))
year = db.Column(db.Numeric(asdecimal=False))
package = None
@cached_property
def journal_metadata(self):
from openalex import MissingJournalMetadata, all_journal_metadata
meta = all_journal_metadata.get(self.issn_l)
if not meta:
meta = MissingJournalMetadata(issn_l=self.issn_l)
return meta
@cached_property
def issns(self):
return self.journal_metadata.issns
@cached_property
def display_issns(self):
return self.journal_metadata.display_issns
@cached_property
def display_issn_l(self):
return self.journal_metadata.display_issn_l
@cached_property
def title(self):
return self.journal_metadata.title
@cached_property
def publisher(self):
return self.journal_metadata.publisher
def to_dict(self):
return OrderedDict([
("issn_l_prefixed", self.display_issn_l),
("issn_l", self.issn_l),
("issns", self.display_issns),
("title", self.title),
("publisher", self.publisher),
("price", self.price)
])
class JournalPriceInput(db.Model, PackageInput):
__tablename__ = "jump_journal_prices_input"
issn = db.Column(db.Text, primary_key=True)
price = db.Column(db.Numeric(asdecimal=False))
year = db.Column(db.Numeric(asdecimal=False))
package_id = db.Column(db.Text, db.ForeignKey("jump_account_package.package_id"), primary_key=True)
def import_view_name(self):
return "jump_journal_prices_view"
def destination_table(self):
return JournalPrice.__tablename__
def issn_columns(self):
return ["issn"]
def csv_columns(self):
return {
"issn": {
"normalize": self.normalize_issn,
"name_snippets": ["issn"],
"required": True,
"warn_if_blank": True,
},
"price": {
"normalize": self.normalize_price,
"name_snippets": ["price", "usd", "cost"],
"warn_if_blank": True,
},
"year": {
"normalize": self.normalize_year,
"name_snippets": ["year"],
"required": False,
}
}
def file_type_label(self):
return "price"
def clear_caches(self, my_package):
super(JournalPriceInput, self).clear_caches(my_package)
def validate_publisher(self):
return True