Skip to content

Commit

Permalink
fix: store data in index to increase speed
Browse files Browse the repository at this point in the history
  • Loading branch information
vncsna committed Apr 16, 2024
1 parent 5749bc5 commit b7fd9d4
Show file tree
Hide file tree
Showing 3 changed files with 250 additions and 91 deletions.
59 changes: 0 additions & 59 deletions bd_api/apps/api/v1/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -353,13 +353,6 @@ class Meta:
verbose_name_plural = "Tags"
ordering = ["slug"]

@property
def as_search_result(self):
return {
"name": self.name,
"slug": self.slug,
}


class Theme(BaseModel):
"""Theme model"""
Expand All @@ -383,13 +376,6 @@ class Meta:
verbose_name_plural = "Themes"
ordering = ["slug"]

@property
def as_search_result(self):
return {
"name": self.name,
"slug": self.slug,
}


class Organization(BaseModel):
"""Organization model"""
Expand Down Expand Up @@ -440,17 +426,6 @@ def has_picture(self):
return True
return False

@property
def as_search_result(self):
return {
"id": self.pk,
"name": self.name,
"slug": self.slug,
"description": self.description,
"picture": getattr(self.picture, "name", None),
"website": self.website,
}


class Status(BaseModel):
"""Status model"""
Expand Down Expand Up @@ -681,33 +656,6 @@ def raw_data_source_last_updated_at(self):
] # fmt: skip
return max(updates) if updates else None

@property
def as_search_result(self):
return {
"updated_at": self.updated_at,
"id": self.id,
"slug": self.slug,
"name": self.name,
"temporal_coverage": [self.coverage],
"organization": [self.organization.as_search_result],
"tags": [t.as_search_result for t in self.tags.all()],
"themes": [t.as_search_result for t in self.themes.all()],
"entities": self.entities,
"contains_open_data": self.contains_open_data,
"contains_closed_data": self.contains_closed_data,
"contains_tables": self.contains_tables,
"contains_raw_data_sources": self.contains_raw_data_sources,
"contains_information_requests": self.contains_information_requests,
"n_tables": self.n_tables,
"n_raw_data_sources": self.n_raw_data_sources,
"n_information_requests": self.n_information_requests,
"first_table_id": self.first_table_id,
"first_open_table_id": self.first_open_table_id,
"first_closed_table_id": self.first_closed_table_id,
"first_raw_data_source_id": self.first_raw_data_source_id,
"first_information_request_id": self.first_information_request_id,
}


class Update(BaseModel):
id = models.UUIDField(primary_key=True, default=uuid4)
Expand Down Expand Up @@ -1488,13 +1436,6 @@ class Meta:
verbose_name_plural = "Entities"
ordering = ["slug"]

@property
def as_search_result(self):
return {
"name": self.name,
"slug": self.slug,
}


class ObservationLevel(BaseModel):
"""Model definition for ObservationLevel."""
Expand Down
183 changes: 161 additions & 22 deletions bd_api/apps/api/v1/search_indexes.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,40 +7,179 @@
class DatasetIndex(indexes.SearchIndex, indexes.Indexable):
text = indexes.CharField(document=True, use_template=True)

dataset = indexes.CharField(model_attr="slug", null=True, faceted=True)
dataset_name = indexes.CharField(model_attr="name", null=True)
dataset_description = indexes.CharField(model_attr="description", null=True)
updated_at = indexes.DateTimeField(model_attr="updated_at")

table = indexes.MultiValueField(model_attr="tables__slug", null=True, faceted=True)
table_names = indexes.MultiValueField(model_attr="tables__name", null=True)
table_descriptions = indexes.MultiValueField(model_attr="tables__description", null=True)
dataset_slug = indexes.CharField(
model_attr="slug",
indexed=False,
)
dataset_name = indexes.CharField(
model_attr="name",
indexed=False,
)
dataset_description = indexes.CharField(
model_attr="description",
default="",
indexed=False,
)

table_id = indexes.MultiValueField(
model_attr="tables__pk",
indexed=False,
)
table_slug = indexes.MultiValueField(
model_attr="tables__slug",
indexed=False,
)
table_name = indexes.MultiValueField(
model_attr="tables__name",
indexed=False,
)
table_description = indexes.MultiValueField(
model_attr="tables__description",
default="",
indexed=False,
)

organization_id = indexes.MultiValueField(
model_attr="organization__pk",
faceted=True,
indexed=False,
)
organization_slug = indexes.MultiValueField(
model_attr="organization__slug",
faceted=True,
indexed=False,
)
organization_name = indexes.MultiValueField(
model_attr="organization__name",
indexed=False,
)
organization_picture = indexes.MultiValueField(
model_attr="organization__picture",
default="",
indexed=False,
)
organization_website = indexes.MultiValueField(
model_attr="organization__website",
default="",
indexed=False,
)
organization_description = indexes.MultiValueField(
model_attr="organization__description",
default="",
indexed=False,
)

tag_slug = indexes.MultiValueField(
model_attr="tags__slug",
default="",
faceted=True,
indexed=False,
)
tag_name = indexes.MultiValueField(
model_attr="tags__name",
default="",
indexed=False,
)

organization = indexes.CharField(model_attr="organization__slug", null=True, faceted=True)
organization_names = indexes.CharField(model_attr="organization__name", null=True)
organization_descriptions = indexes.CharField(model_attr="organization__description", null=True)
theme_slug = indexes.MultiValueField(
model_attr="themes__slug",
default="",
faceted=True,
indexed=False,
)
theme_name = indexes.MultiValueField(
model_attr="themes__name",
default="",
indexed=False,
)

tag = indexes.MultiValueField(model_attr="tags__slug", null=True, faceted=True)
tag_names = indexes.MultiValueField(model_attr="tags__name", null=True)
entity_slug = indexes.MultiValueField(
model_attr="tables__observation_levels__entity__slug",
default="",
faceted=True,
indexed=False,
)
entity_name = indexes.MultiValueField(
model_attr="tables__observation_levels__entity__name",
default="",
faceted=True,
indexed=False,
)

theme = indexes.MultiValueField(model_attr="themes__slug", null=True, faceted=True)
theme_names = indexes.MultiValueField(model_attr="themes__name", null=True)
temporal_coverage = indexes.MultiValueField(
default="",
model_attr="coverage",
indexed=False,
)

entity = indexes.MultiValueField(
model_attr="tables__observation_levels__entity__slug", null=True, faceted=True
contains_open_data = indexes.BooleanField(
model_attr="contains_open_data",
indexed=False,
)
contains_closed_data = indexes.BooleanField(
model_attr="contains_closed_data",
indexed=False,
)

contains_tables = indexes.BooleanField(
model_attr="contains_tables",
indexed=False,
)
contains_raw_data_sources = indexes.BooleanField(
model_attr="contains_raw_data_sources",
indexed=False,
)
entity_names = indexes.MultiValueField(
model_attr="tables__observation_levels__entity__name", null=True, faceted=True
contains_information_requests = indexes.BooleanField(
model_attr="contains_information_requests",
indexed=False,
)

contains_open_data = indexes.BooleanField(model_attr="contains_open_data")
contains_closed_data = indexes.BooleanField(model_attr="contains_closed_data")
n_tables = indexes.IntegerField(
model_attr="n_tables",
indexed=False,
)
n_raw_data_sources = indexes.IntegerField(
model_attr="n_raw_data_sources",
indexed=False,
)
n_information_requests = indexes.IntegerField(
model_attr="n_information_requests",
indexed=False,
)

contains_tables = indexes.BooleanField(model_attr="contains_tables")
contains_raw_data_sources = indexes.BooleanField(model_attr="contains_raw_data_sources")
contains_information_requests = indexes.BooleanField(model_attr="contains_information_requests")
first_table_id = indexes.CharField(
model_attr="first_table_id",
default="",
indexed=False,
)
first_open_table_id = indexes.CharField(
model_attr="first_open_table_id",
default="",
indexed=False,
)
first_closed_table_id = indexes.CharField(
model_attr="first_closed_table_id",
default="",
indexed=False,
)
first_raw_data_source_id = indexes.CharField(
model_attr="first_raw_data_source_id",
default="",
indexed=False,
)
first_information_request_id = indexes.CharField(
model_attr="first_information_request_id",
default="",
indexed=False,
)

def get_model(self):
return Dataset

def index_queryset(self, using=None):
return self.get_model().objects.exclude(status__slug="under_review").all()

def prepare_organization_picture(self, obj):
return getattr(obj.organization.picture, "name", None)
Loading

0 comments on commit b7fd9d4

Please sign in to comment.