Skip to content

Commit

Permalink
Unlock pydantic and fastapi versions
Browse files Browse the repository at this point in the history
  • Loading branch information
Christdej committed Oct 5, 2023
1 parent 9479deb commit 1c6bab6
Show file tree
Hide file tree
Showing 4 changed files with 51 additions and 54 deletions.
4 changes: 2 additions & 2 deletions setup.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,15 +33,15 @@
"backoff",
"click",
"dacite",
"fastapi-azure-auth==4.0.0",
"fastapi-azure-auth",
"fastapi",
"injector",
"opencensus-ext-logging",
"opencensus-ext-requests",
"opencensus-ext-azure",
"numpy",
"paho-mqtt",
"pydantic==1.10.11",
"pydantic",
"PyJWT",
"python-dotenv",
"PyYAML",
Expand Down
2 changes: 1 addition & 1 deletion src/isar/apis/models/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ class StepResponse(BaseModel):

class TaskResponse(BaseModel):
id: str
tag_id: Optional[str]
tag_id: Optional[str] = None
steps: List[StepResponse]


Expand Down
14 changes: 7 additions & 7 deletions src/isar/apis/models/start_mission_definition.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,22 +32,22 @@ class InspectionTypes(str, Enum):
class StartMissionInspectionDefinition(BaseModel):
type: InspectionTypes = Field(default=InspectionTypes.image)
inspection_target: InputPosition
duration: Optional[float]
metadata: Optional[dict]
id: Optional[str]
duration: Optional[float] = None
metadata: Optional[dict] = None
id: Optional[str] = None


class StartMissionTaskDefinition(BaseModel):
pose: InputPose
inspections: List[StartMissionInspectionDefinition]
tag: Optional[str]
id: Optional[str]
tag: Optional[str] = None
id: Optional[str] = None


class StartMissionDefinition(BaseModel):
tasks: List[StartMissionTaskDefinition]
id: Optional[str]
name: Optional[str]
id: Optional[str] = None
name: Optional[str] = None


def to_isar_mission(mission_definition: StartMissionDefinition) -> Mission:
Expand Down
85 changes: 41 additions & 44 deletions src/isar/config/settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,14 +3,23 @@
from typing import List, Optional

from dotenv import load_dotenv
from pydantic import BaseSettings, Field, validator
from pydantic import Field
from pydantic_settings import BaseSettings, SettingsConfigDict

from isar.config import predefined_missions
from robot_interface.models.robots.robot_model import RobotModel
from robot_interface.telemetry.payloads import VideoStream


class Settings(BaseSettings):
def __init__(self) -> None:
try:
with pkg_resources.path(f"isar.config", "settings.env") as path:
env_file_path = path
except ModuleNotFoundError:
env_file_path = None
super().__init__(_env_file=env_file_path)

# Determines which robot package ISAR will attempt to import
# Name must match with an installed python package in the local environment
ROBOT_PACKAGE: str = Field(default="isar_robot")
Expand All @@ -32,7 +41,7 @@ class Settings(BaseSettings):
FSM_SLEEP_TIME: float = Field(default=0.1)

# Location of JSON files containing predefined missions for the Local Planner to use
path = os.path.dirname(predefined_missions.__file__)
path: str = os.path.dirname(predefined_missions.__file__)
PREDEFINED_MISSIONS_FOLDER: str = Field(default=path + "/")

# Name of default map transformation
Expand Down Expand Up @@ -217,14 +226,18 @@ class Settings(BaseSettings):
DATA_CLASSIFICATION: str = Field(default="internal")

# List of MQTT Topics
TOPIC_ISAR_STATE: str = Field(default="state")
TOPIC_ISAR_MISSION: str = Field(default="mission")
TOPIC_ISAR_TASK: str = Field(default="task")
TOPIC_ISAR_STEP: str = Field(default="step")
TOPIC_ISAR_INSPECTION_RESULT = Field(default="inspection_result")
TOPIC_ISAR_ROBOT_STATUS: str = Field(default="robot_status")
TOPIC_ISAR_ROBOT_INFO: str = Field(default="robot_info")
TOPIC_ISAR_ROBOT_HEARTBEAT: str = Field(default="robot_heartbeat")
TOPIC_ISAR_STATE: str = Field(default="state", validate_default=True)
TOPIC_ISAR_MISSION: str = Field(default="mission", validate_default=True)
TOPIC_ISAR_TASK: str = Field(default="task", validate_default=True)
TOPIC_ISAR_STEP: str = Field(default="step", validate_default=True)
TOPIC_ISAR_INSPECTION_RESULT: str = Field(
default="inspection_result", validate_default=True
)
TOPIC_ISAR_ROBOT_STATUS: str = Field(default="robot_status", validate_default=True)
TOPIC_ISAR_ROBOT_INFO: str = Field(default="robot_info", validate_default=True)
TOPIC_ISAR_ROBOT_HEARTBEAT: str = Field(
default="robot_heartbeat", validate_default=True
)

# Logging

Expand All @@ -238,21 +251,20 @@ class Settings(BaseSettings):
LOG_HANDLER_APPLICATION_INSIGHTS_ENABLED: bool = Field(default=False)

# Log levels
API_LOG_LEVEL: str = Field(default="INFO")
MAIN_LOG_LEVEL: str = Field(default="INFO")
MQTT_LOG_LEVEL: str = Field(default="INFO")
STATE_MACHINE_LOG_LEVEL: str = Field(default="INFO")
UPLOADER_LOG_LEVEL: str = Field(default="INFO")
CONSOLE_LOG_LEVEL: str = Field(default="INFO")
URLLIB3_LOG_LEVEL: str = Field(default="WARNING")
UVICORN_LOG_LEVEL: str = Field(default="WARNING")
AZURE_LOG_LEVEL: str = Field(default="WARNING")
API_LOG_LEVEL: str = Field(default="INFO", validate_default=True)
MAIN_LOG_LEVEL: str = Field(default="INFO", validate_default=True)
MQTT_LOG_LEVEL: str = Field(default="INFO", validate_default=True)
STATE_MACHINE_LOG_LEVEL: str = Field(default="INFO", validate_default=True)
UPLOADER_LOG_LEVEL: str = Field(default="INFO", validate_default=True)
CONSOLE_LOG_LEVEL: str = Field(default="INFO", validate_default=True)
URLLIB3_LOG_LEVEL: str = Field(default="WARNING", validate_default=True)
UVICORN_LOG_LEVEL: str = Field(default="WARNING", validate_default=True)
AZURE_LOG_LEVEL: str = Field(default="WARNING", validate_default=True)

LOG_LEVELS: dict = Field(default={})

REQUIRED_ROLE: str = Field(default="Mission.Control")

@validator("LOG_LEVELS", pre=True, always=True)
def set_log_levels(cls, v, values) -> dict:
return {
"api": values["API_LOG_LEVEL"],
Expand All @@ -266,29 +278,14 @@ def set_log_levels(cls, v, values) -> dict:
"azure": values["AZURE_LOG_LEVEL"],
}

@validator(
"TOPIC_ISAR_STATE",
"TOPIC_ISAR_MISSION",
"TOPIC_ISAR_TASK",
"TOPIC_ISAR_STEP",
"TOPIC_ISAR_ROBOT_STATUS",
"TOPIC_ISAR_ROBOT_INFO",
"TOPIC_ISAR_ROBOT_HEARTBEAT",
"TOPIC_ISAR_INSPECTION_RESULT",
pre=True,
always=True,
)
def prefix_isar_topics(cls, v, values):
return f"isar/{values['ISAR_ID']}/{v}"

class Config:
with pkg_resources.path("isar.config", "settings.env") as path:
package_path = path

env_prefix = "ISAR_"
env_file = package_path
env_file_encoding = "utf-8"
case_sensitive = True
model_config = SettingsConfigDict(
env_prefix="ISAR_",
env_file_encoding="utf-8",
case_sensitive=True,
)


load_dotenv()
Expand Down Expand Up @@ -319,10 +316,10 @@ def __init__(self) -> None:
# Note that if the robot does not support moving an arm this will be None and
# the functionality will be unavailable
VALID_ARM_POSES: Optional[List[str]] = Field(default=None)

class Config:
env_file_encoding = "utf-8"
case_sensitive = True
model_config = SettingsConfigDict(
env_file_encoding="utf-8",
case_sensitive=True,
)


robot_settings = RobotSettings()

0 comments on commit 1c6bab6

Please sign in to comment.