Files
gpt-pilot/core/db/models/exec_log.py
Senko Rasic 5b474ccc1f merge gpt-pilot 0.2 codebase
This is a complete rewrite of the GPT Pilot core, from the ground
up, making the agentic architecture front and center, and also
fixing some long-standing problems with the database architecture
that weren't feasible to solve without breaking compatibility.

As the database structure and config file syntax have changed,
we have automatic imports for projects and current configs,
see the README.md file for details.

This also relicenses the project to FSL-1.1-MIT license.
2024-05-22 21:42:25 +02:00

72 lines
2.5 KiB
Python

from datetime import datetime
from typing import TYPE_CHECKING, Optional
from uuid import UUID
from sqlalchemy import ForeignKey, inspect
from sqlalchemy.orm import Mapped, mapped_column, relationship
from core.db.models import Base
from core.proc.exec_log import ExecLog as ExecLogData
if TYPE_CHECKING:
from core.db.models import Branch, ProjectState
class ExecLog(Base):
__tablename__ = "exec_logs"
# ID and parent FKs
id: Mapped[int] = mapped_column(primary_key=True, autoincrement=True)
branch_id: Mapped[UUID] = mapped_column(ForeignKey("branches.id", ondelete="CASCADE"))
project_state_id: Mapped[Optional[UUID]] = mapped_column(ForeignKey("project_states.id", ondelete="SET NULL"))
# Attributes
started_at: Mapped[datetime] = mapped_column()
duration: Mapped[float] = mapped_column()
cmd: Mapped[str] = mapped_column()
cwd: Mapped[str] = mapped_column()
env: Mapped[dict] = mapped_column()
timeout: Mapped[Optional[float]] = mapped_column()
status_code: Mapped[Optional[int]] = mapped_column()
stdout: Mapped[str] = mapped_column()
stderr: Mapped[str] = mapped_column()
analysis: Mapped[str] = mapped_column()
success: Mapped[bool] = mapped_column()
# Relationships
branch: Mapped["Branch"] = relationship(back_populates="exec_logs")
project_state: Mapped["ProjectState"] = relationship(back_populates="exec_logs")
@classmethod
def from_exec_log(cls, project_state: "ProjectState", exec_log: ExecLogData) -> "ExecLog":
"""
Store the user input in the database.
Note this just creates the UserInput object. It is committed to the
database only when the DB session itself is comitted.
:param project_state: Project state to associate the request log with.
:param question: Question the user was asked.
:param user_input: User input.
:return: Newly created User input in the database.
"""
session = inspect(project_state).async_session
obj = cls(
project_state=project_state,
branch=project_state.branch,
started_at=exec_log.started_at,
duration=exec_log.duration,
cmd=exec_log.cmd,
cwd=exec_log.cwd,
env=exec_log.env,
timeout=exec_log.timeout,
status_code=exec_log.status_code,
stdout=exec_log.stdout,
stderr=exec_log.stderr,
analysis=exec_log.analysis,
success=exec_log.success,
)
session.add(obj)
return obj