Skip to content

Commit

Permalink
Merge pull request #2672 from data-for-change/dev
Browse files Browse the repository at this point in the history
merge dev into master
  • Loading branch information
atalyaalon authored Aug 15, 2024
2 parents e2a4a4c + 04f74be commit bdc56f5
Show file tree
Hide file tree
Showing 20 changed files with 3,328 additions and 294 deletions.
4 changes: 3 additions & 1 deletion .github/workflows/Tests.yml
Original file line number Diff line number Diff line change
Expand Up @@ -58,13 +58,15 @@ jobs:
cd ./anyway-newsflash-infographics/
bash run.bash
cd ../
docker-compose -f docker-compose.yml up -d --build anyway
docker compose -f docker-compose.yml up -d --build anyway
- name: Waiting for DB startup
run: |
bash ./wait_for_postgres.sh
- name: DB Initialization
run: |
docker exec anyway alembic upgrade head
docker exec anyway ./main.py process cities
docker exec anyway ./main.py process streets
docker exec anyway ./main.py process registered-vehicles
docker exec anyway ./main.py process cbs --source local_dir_for_tests_only
docker exec anyway ./main.py process road-segments
Expand Down
30 changes: 30 additions & 0 deletions alembic/versions/53d0b00fb750_add_non_urban_intersection.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
"""add non_urban_intersection
Revision ID: 53d0b00fb750
Revises: 11ddb0cff075
Create Date: 2024-06-16 15:05:30.522542
"""

# revision identifiers, used by Alembic.
revision = '53d0b00fb750'
down_revision = '11ddb0cff075'
branch_labels = None
depends_on = None

from alembic import op
import sqlalchemy as sa
from sqlalchemy.dialects import postgresql

def upgrade():
# ### commands auto generated by Alembic - please adjust! ###
op.add_column('involved_markers_hebrew', sa.Column('urban_intersection', sa.Integer(), nullable=True))
op.add_column('vehicles_markers_hebrew', sa.Column('urban_intersection', sa.Integer(), nullable=True))
# ### end Alembic commands ###


def downgrade():
# ### commands auto generated by Alembic - please adjust! ###
op.drop_column('vehicles_markers_hebrew', 'urban_intersection')
op.drop_column('involved_markers_hebrew', 'urban_intersection')
# ### end Alembic commands ###
2 changes: 2 additions & 0 deletions anyway/db_views.py
Original file line number Diff line number Diff line change
Expand Up @@ -641,6 +641,7 @@ def create_involved_hebrew_markers_hebrew_view(self):
AccidentMarkerView.non_urban_intersection,
AccidentMarkerView.non_urban_intersection_hebrew,
AccidentMarkerView.non_urban_intersection_by_junction_number,
AccidentMarkerView.urban_intersection,
AccidentMarkerView.accident_day,
AccidentMarkerView.accident_hour_raw,
AccidentMarkerView.accident_hour_raw_hebrew,
Expand Down Expand Up @@ -838,6 +839,7 @@ def create_vehicles_markers_hebrew_view(self):
AccidentMarkerView.non_urban_intersection,
AccidentMarkerView.non_urban_intersection_hebrew,
AccidentMarkerView.non_urban_intersection_by_junction_number,
AccidentMarkerView.urban_intersection,
AccidentMarkerView.accident_day,
AccidentMarkerView.accident_hour_raw,
AccidentMarkerView.accident_hour_raw_hebrew,
Expand Down
9 changes: 0 additions & 9 deletions anyway/localization.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@
import pandas as pd

from anyway import field_names
from typing import Optional

import logging

Expand Down Expand Up @@ -214,11 +213,3 @@ def get_field(field, value=None):

def get_supported_tables():
return _tables.keys()


def get_city_name(symbol_id, lang: str = "he") -> Optional[str]:
column_to_fetch = field_names.name if lang == "he" else "ENGLISH_NAME"
try:
return _cities.loc[symbol_id, column_to_fetch]
except Exception:
return None
127 changes: 81 additions & 46 deletions anyway/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,8 +4,7 @@
import json
import logging
from collections import namedtuple
from typing import List, Set, Iterable

from typing import List, Set, Iterable, Optional


try:
Expand Down Expand Up @@ -881,7 +880,9 @@ class NewsFlash(Base):
newsflash_location_qualification = Column(
Integer(),
nullable=False,
server_default=text(f"{NewsflashLocationQualification.NOT_VERIFIED.value}"), # pylint: disable=no-member
server_default=text(
f"{NewsflashLocationQualification.NOT_VERIFIED.value}"
), # pylint: disable=no-member
)
location_qualifying_user = Column(BigInteger(), nullable=True)

Expand All @@ -897,7 +898,9 @@ def set_critical(
)
from anyway.request_params import get_latest_accident_date, LocationInfo

if (self.road1 is None or self.road_segment_id is None) and (self.yishuv_name is None or self.street1_hebrew is None) :
if (self.road1 is None or self.road_segment_id is None) and (
self.yishuv_name is None or self.street1_hebrew is None
):
return None
last_accident_date = get_latest_accident_date(table_obj=AccidentMarkerView, filters=None)
resolution = BE_CONST.ResolutionCategories(self.resolution)
Expand All @@ -911,7 +914,9 @@ def set_critical(
location_info["yishuv_name"] = self.yishuv_name
location_info["street1_hebrew"] = self.street1_hebrew

critical_values = InjuredCountBySeverityWidget.get_injured_count_by_severity(resolution, location_info, start_time, end_time)
critical_values = InjuredCountBySeverityWidget.get_injured_count_by_severity(
resolution, location_info, start_time, end_time
)
if critical_values == {}:
return None
critical = None
Expand All @@ -927,7 +932,6 @@ def set_critical(
) >= 1
self.critical = critical


# generate text describing location or road segment of news flash to be used by
# Use case 1 - FE display of curr location in location qualification
# Use case 2 - Widgets e.g most severe accidents additional info widget
Expand All @@ -949,8 +953,10 @@ def get_news_flash_location_text(self):
elif resolution == "צומת בינעירוני" and road1 and road_segment_name:
res = "כביש " + road1 + " במקטע " + road_segment_name
elif resolution == "רחוב" and yishuv_name and street1_hebrew:

def get_street_location_text(yishuv_name, street1_hebrew):
return "רחוב " + street1_hebrew + " ב" + yishuv_name

res = get_street_location_text(yishuv_name, street1_hebrew)
else:
logging.warning(
Expand Down Expand Up @@ -994,7 +1000,6 @@ def serialize(self):
"curr_cbs_location_text": self.get_news_flash_location_text(),
}


# Flask-Login integration
def is_authenticated(self):
return True
Expand Down Expand Up @@ -1093,11 +1098,19 @@ class City(CityFields, Base):
__tablename__ = "cbs_cities"

@staticmethod
def get_name_from_symbol(symbol: int) -> str:
res = db.session.query(City.heb_name).filter(City.yishuv_symbol == symbol).first()
def get_name_from_symbol(symbol: int, lang: str = 'he') -> str:
int_sym = int(symbol)
res: City = db.session.query(City.heb_name, City.eng_name).filter(City.yishuv_symbol == int_sym).first()
if res is None:
raise ValueError(f"{symbol}: could not find city with that symbol")
return res.heb_name
raise ValueError(f"{int_sym}({symbol}): could not find city with that symbol")
return res.heb_name if lang == 'he' else res.eng_name

@staticmethod
def get_name_from_symbol_or_none(symbol: int, lang: str = 'he') -> Optional[str]:
try:
return City.get_name_from_symbol(symbol, lang)
except ValueError:
return None

@staticmethod
def get_symbol_from_name(name: str) -> int:
Expand All @@ -1117,10 +1130,6 @@ def get_all_cities() -> List[dict]:
return res1


class CityTemp(CityFields, Base):
__tablename__ = "cbs_cities_temp"


class DeprecatedCity(Base):
__tablename__ = "cities"
id = Column(Integer(), primary_key=True)
Expand Down Expand Up @@ -1236,7 +1245,6 @@ def get_streets_by_yishuv(yishuv_symbol: int) -> List[dict]:
raise RuntimeError(f"When retrieving streets of {yishuv_symbol}")
return res1


@staticmethod
def get_streets_by_yishuv_name(yishuv_name: str) -> List[dict]:
yishuv_symbol = City.get_symbol_from_name(yishuv_name)
Expand All @@ -1255,45 +1263,58 @@ class SuburbanJunction(Base):
__tablename__ = "suburban_junction"
MAX_NAME_LEN = 100
non_urban_intersection = Column(Integer(), primary_key=True, nullable=False)
non_urban_intersection_hebrew = Column(String(length=MAX_NAME_LEN),
nullable=True)
non_urban_intersection_hebrew = Column(String(length=MAX_NAME_LEN), nullable=True)
roads = Column(postgresql.ARRAY(Integer(), dimensions=1), nullable=False)

@staticmethod
def get_hebrew_name_from_id(non_urban_intersection: int) -> str:
res = db.session.query(SuburbanJunction.non_urban_intersection_hebrew).filter(
SuburbanJunction.non_urban_intersection == non_urban_intersection).first()
res = (
db.session.query(SuburbanJunction.non_urban_intersection_hebrew)
.filter(SuburbanJunction.non_urban_intersection == non_urban_intersection)
.first()
)
if res is None:
raise ValueError(f"{non_urban_intersection}: could not find "
f"SuburbanJunction with that symbol")
raise ValueError(
f"{non_urban_intersection}: could not find " f"SuburbanJunction with that symbol"
)
return res.non_urban_intersection_hebrew

@staticmethod
def get_id_from_hebrew_name(non_urban_intersection_hebrew: str) -> int:
res = db.session.query(SuburbanJunction.non_urban_intersection).filter(
SuburbanJunction.non_urban_intersection == non_urban_intersection_hebrew).first()
res = (
db.session.query(SuburbanJunction.non_urban_intersection)
.filter(SuburbanJunction.non_urban_intersection == non_urban_intersection_hebrew)
.first()
)
if res is None:
raise ValueError(f"{non_urban_intersection_hebrew}: could not find "
f"SuburbanJunction with that name")
raise ValueError(
f"{non_urban_intersection_hebrew}: could not find "
f"SuburbanJunction with that name"
)
return res.non_urban_intersection

@staticmethod
def get_intersection_from_roads(roads: Set[int]) -> dict:
if not all([isinstance(x, int) for x in roads]):
raise ValueError(f"{roads}: Should be integers")
res = db.session.query(SuburbanJunction).filter(
SuburbanJunction.roads.contains(roads)).first()
res = (
db.session.query(SuburbanJunction)
.filter(SuburbanJunction.roads.contains(roads))
.first()
)
if res is None:
raise ValueError(f"{roads}: could not find "
f"SuburbanJunction with these roads")
raise ValueError(f"{roads}: could not find " f"SuburbanJunction with these roads")
return res.serialize()

@staticmethod
def get_all_from_key_value(key: str, val: Iterable) -> dict:
if not isinstance(val, Iterable):
val = [val]
res = db.session.query(SuburbanJunction).filter(
(getattr(SuburbanJunction, key)).in_(val)).first()
res = (
db.session.query(SuburbanJunction)
.filter((getattr(SuburbanJunction, key)).in_(val))
.first()
)
if res is None:
raise ValueError(f"{key}:{val}: could not find SuburbanJunction")
return res.serialize()
Expand Down Expand Up @@ -2287,20 +2308,30 @@ def get_segment_id(self):

@staticmethod
def get_segments_by_segment(road_segment_id: int):
curr_road = (db.session.query(RoadSegments.road)
.filter(RoadSegments.segment_id == road_segment_id)
.all())
curr_road = (
db.session.query(RoadSegments.road)
.filter(RoadSegments.segment_id == road_segment_id)
.all()
)
curr_road_processed = [{"road": s.road} for s in curr_road]
if curr_road is None or curr_road_processed is None:
raise RuntimeError(f"When retrieving segments of {road_segment_id}")
road = curr_road_processed[0]["road"]
res = (db.session.query(RoadSegments.segment_id, RoadSegments.from_name, RoadSegments.to_name)
.filter(RoadSegments.road == road)
.all())
res1 = [{"road": road, "road_segment_id": s.segment_id, "road_segment_name": " - ".join([s.from_name, s.to_name])} for s in res]
res = (
db.session.query(RoadSegments.segment_id, RoadSegments.from_name, RoadSegments.to_name)
.filter(RoadSegments.road == road)
.all()
)
res1 = [
{
"road": road,
"road_segment_id": s.segment_id,
"road_segment_name": " - ".join([s.from_name, s.to_name]),
}
for s in res
]
return res1


@staticmethod
def get_streets_by_yishuv_name(yishuv_name: str) -> List[dict]:
yishuv_symbol = City.get_symbol_from_name(yishuv_name)
Expand All @@ -2314,14 +2345,15 @@ def get_streets_by_yishuv_name(yishuv_name: str) -> List[dict]:
raise RuntimeError(f"When retrieving streets of {yishuv_symbol}")
return res1


class Comment(Base):
__tablename__ = "comments"
id = Column(BigInteger(), autoincrement=True, primary_key=True, index=True)
author = Column(Integer(), ForeignKey("users.id"), nullable=False)
parent = Column(Integer, ForeignKey("comments.id"), nullable=True)
created_time = Column(DateTime, default=datetime.datetime.now, index=True, nullable=False)
street = Column(Text(), nullable=True, index=True)
city = Column(Text(), nullable=True, index=True)
city = Column(Text(), nullable=True, index=True)
road_segment_id = Column(Integer(), nullable=True, index=True)

def serialize(self):
Expand All @@ -2332,12 +2364,10 @@ def serialize(self):
"street": self.street,
"parent": self.parent,
"city": self.city,
"road_segment_id": self.road_segment_id

"road_segment_id": self.road_segment_id,
}



class ReportProblem(Base):
__tablename__ = "report_problem"
id = Column(BigInteger(), autoincrement=True, primary_key=True, index=True)
Expand Down Expand Up @@ -2367,7 +2397,7 @@ class InvolvedMarkerView(Base):
__table_args__ = (
Index("inv_markers_accident_yishuv_symbol_idx", "accident_yishuv_symbol", unique=False),
Index("inv_markers_injury_severity_idx", "injury_severity", unique=False),
Index("inv_markers_involve_vehicle_type_idx", "involve_vehicle_type", unique=False)
Index("inv_markers_involve_vehicle_type_idx", "involve_vehicle_type", unique=False),
)

accident_id = Column(BigInteger(), primary_key=True)
Expand Down Expand Up @@ -2505,6 +2535,7 @@ class InvolvedMarkerView(Base):
non_urban_intersection = Column(Integer())
non_urban_intersection_hebrew = Column(Text())
non_urban_intersection_by_junction_number = Column(Text())
urban_intersection = Column(Integer())
accident_day = Column(Integer())
accident_hour_raw = Column(Integer())
accident_hour_raw_hebrew = Column(Text())
Expand Down Expand Up @@ -2701,6 +2732,7 @@ class VehicleMarkerView(Base):
non_urban_intersection = Column(Integer())
non_urban_intersection_hebrew = Column(Text())
non_urban_intersection_by_junction_number = Column(Text())
urban_intersection = Column(Integer())
accident_month = Column(Integer())
accident_day = Column(Integer())
accident_hour_raw = Column(Integer())
Expand Down Expand Up @@ -3033,14 +3065,17 @@ class TelegramGroupsBase(Base):
id = Column(Integer(), primary_key=True)
filter = Column(JSON(), nullable=False, server_default="{}")


class TelegramGroups(TelegramGroupsBase):
__tablename__ = "telegram_groups"


class TelegramGroupsTest(TelegramGroupsBase):
__tablename__ = "telegram_groups_test"


class TelegramForwardedMessages(Base):
__tablename__ = 'telegram_forwarded_messages'
__tablename__ = "telegram_forwarded_messages"
message_id = Column(String(), primary_key=True)
newsflash_id = Column(BigInteger(), nullable=False)
group_sent = Column(String(), nullable=False)
Loading

0 comments on commit bdc56f5

Please sign in to comment.