|
9 | 9 |
|
10 | 10 | import luqum.tree |
11 | 11 | import web |
| 12 | +from pydantic import BaseModel |
12 | 13 |
|
13 | 14 | import infogami |
14 | 15 | from openlibrary.plugins.upstream.utils import convert_iso_to_marc |
|
40 | 41 | re_author_key = re.compile(r'(OL\d+A)') |
41 | 42 |
|
42 | 43 |
|
| 44 | +class WorkSearchFacetFields(BaseModel): |
| 45 | + """Facet fields that can be used when searching""" |
| 46 | + |
| 47 | + # Facets |
| 48 | + has_fulltext: bool | None = None |
| 49 | + author_facet: str | None = None |
| 50 | + language: str | None = None |
| 51 | + first_publish_year: str | None = None |
| 52 | + publisher_facet: str | None = None |
| 53 | + subject_facet: str | None = None |
| 54 | + person_facet: str | None = None |
| 55 | + place_facet: str | None = None |
| 56 | + time_facet: str | None = None |
| 57 | + public_scan_b: bool | None = None |
| 58 | + |
| 59 | + |
| 60 | +class WorkSearchAllFields(BaseModel): |
| 61 | + """All fields that can be used when searching""" |
| 62 | + |
| 63 | + # Unclear why some facets like subject_facet, person_facet, place_facet, time_facet, public_scan_b are not included |
| 64 | + |
| 65 | + key: str | None = None |
| 66 | + redirects: str | None = None |
| 67 | + title: str | None = None |
| 68 | + subtitle: str | None = None |
| 69 | + alternative_title: str | None = None |
| 70 | + alternative_subtitle: str | None = None |
| 71 | + cover_i: str | None = None |
| 72 | + ebook_access: str | None = None |
| 73 | + ebook_provider: str | None = None |
| 74 | + edition_count: str | None = None |
| 75 | + edition_key: str | None = None |
| 76 | + format: str | None = None |
| 77 | + by_statement: str | None = None |
| 78 | + publish_date: str | None = None |
| 79 | + lccn: str | None = None |
| 80 | + lexile: str | None = None |
| 81 | + ia: str | None = None |
| 82 | + oclc: str | None = None |
| 83 | + isbn: str | None = None |
| 84 | + contributor: str | None = None |
| 85 | + publish_place: str | None = None |
| 86 | + publisher: str | None = None |
| 87 | + first_sentence: str | None = None |
| 88 | + author_key: str | None = None |
| 89 | + author_name: str | None = None |
| 90 | + author_alternative_name: str | None = None |
| 91 | + subject: str | None = None |
| 92 | + person: str | None = None |
| 93 | + place: str | None = None |
| 94 | + time: str | None = None |
| 95 | + has_fulltext: bool | None = None |
| 96 | + title_suggest: str | None = None |
| 97 | + publish_year: str | None = None |
| 98 | + language: str | None = None |
| 99 | + number_of_pages_median: int | None = None |
| 100 | + ia_count: int | None = None |
| 101 | + publisher_facet: str | None = None |
| 102 | + author_facet: str | None = None |
| 103 | + first_publish_year: str | None = None |
| 104 | + ratings_count: int | None = None |
| 105 | + readinglog_count: int | None = None |
| 106 | + want_to_read_count: int | None = None |
| 107 | + currently_reading_count: int | None = None |
| 108 | + already_read_count: int | None = None |
| 109 | + # Subjects |
| 110 | + subject_key: str | None = None |
| 111 | + person_key: str | None = None |
| 112 | + place_key: str | None = None |
| 113 | + time_key: str | None = None |
| 114 | + # Classifications |
| 115 | + lcc: str | None = None |
| 116 | + ddc: str | None = None |
| 117 | + lcc_sort: str | None = None |
| 118 | + ddc_sort: str | None = None |
| 119 | + osp_count: int | None = None |
| 120 | + # Trending |
| 121 | + trending_score_hourly_sum: int | None = None |
| 122 | + trending_z_score: int | None = None |
| 123 | + |
| 124 | + |
43 | 125 | class WorkSearchScheme(SearchScheme): |
44 | 126 | universe = frozenset(['type:work']) |
45 | | - all_fields = frozenset( |
46 | | - { |
47 | | - "key", |
48 | | - "redirects", |
49 | | - "title", |
50 | | - "subtitle", |
51 | | - "alternative_title", |
52 | | - "alternative_subtitle", |
53 | | - "cover_i", |
54 | | - "ebook_access", |
55 | | - "ebook_provider", |
56 | | - "edition_count", |
57 | | - "edition_key", |
58 | | - "format", |
59 | | - "by_statement", |
60 | | - "publish_date", |
61 | | - "lccn", |
62 | | - "lexile", |
63 | | - "ia", |
64 | | - "oclc", |
65 | | - "isbn", |
66 | | - "contributor", |
67 | | - "publish_place", |
68 | | - "publisher", |
69 | | - "first_sentence", |
70 | | - "author_key", |
71 | | - "author_name", |
72 | | - "author_alternative_name", |
73 | | - "subject", |
74 | | - "person", |
75 | | - "place", |
76 | | - "time", |
77 | | - "has_fulltext", |
78 | | - "title_suggest", |
79 | | - "publish_year", |
80 | | - "language", |
81 | | - "number_of_pages_median", |
82 | | - "ia_count", |
83 | | - "publisher_facet", |
84 | | - "author_facet", |
85 | | - "first_publish_year", |
86 | | - "ratings_count", |
87 | | - "readinglog_count", |
88 | | - "want_to_read_count", |
89 | | - "currently_reading_count", |
90 | | - "already_read_count", |
91 | | - # Subjects |
92 | | - "subject_key", |
93 | | - "person_key", |
94 | | - "place_key", |
95 | | - "time_key", |
96 | | - # Classifications |
97 | | - "lcc", |
98 | | - "ddc", |
99 | | - "lcc_sort", |
100 | | - "ddc_sort", |
101 | | - "osp_count", |
102 | | - # Trending |
103 | | - "trending_score_hourly_sum", |
104 | | - "trending_z_score", |
105 | | - } |
106 | | - ) |
| 127 | + all_fields = frozenset(WorkSearchAllFields.model_fields.keys()) |
107 | 128 | non_solr_fields = frozenset( |
108 | 129 | { |
109 | 130 | 'description', |
110 | 131 | 'providers', |
111 | 132 | } |
112 | 133 | ) |
113 | | - facet_fields = frozenset( |
114 | | - { |
115 | | - "has_fulltext", |
116 | | - "author_facet", |
117 | | - "language", |
118 | | - "first_publish_year", |
119 | | - "publisher_facet", |
120 | | - "subject_facet", |
121 | | - "person_facet", |
122 | | - "place_facet", |
123 | | - "time_facet", |
124 | | - "public_scan_b", |
125 | | - } |
126 | | - ) |
| 134 | + facet_fields = frozenset(WorkSearchFacetFields.model_fields.keys()) |
127 | 135 | field_name_map = MappingProxyType( |
128 | 136 | { |
129 | 137 | 'author': 'author_name', |
|
0 commit comments