-
Notifications
You must be signed in to change notification settings - Fork 37
/
Copy pathjournal.py
46 lines (39 loc) · 1.29 KB
/
journal.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
from sqlalchemy.dialects.postgresql import JSONB
from app import db
from urllib.parse import quote
class Journal(db.Model):
issn_l = db.Column(db.Text, primary_key=True)
issns = db.Column(JSONB)
title = db.Column(db.Text)
publisher = db.Column(db.Text)
delayed_oa = db.Column(db.Boolean)
embargo = db.Column(db.Interval)
api_raw_crossref = db.Column(JSONB)
api_raw_issn = db.Column(JSONB)
url = db.Column(db.Text)
@property
def home_page(self):
if self.url:
return self.url
else:
query = quote('{} {}'.format(self.title, self.issn_l).encode('utf-8'))
url = 'https://www.google.com/search?q={}'.format(query)
return url
def to_csv_row(self):
row = []
for attr in ["home_page", "publisher", "title"]:
value = getattr(self, attr) or ''
value = value.replace(',', '; ')
row.append(value)
csv_row = ','.join(row)
return csv_row
def to_dict(self):
return {
"home_page": self.home_page,
"institution_name": self.publisher,
"repository_name": self.title
}
def __repr__(self):
return '<Journal ({issn_l}, {title})>'.format(
issn_l=self.issn_l, title=self.title
)