Skip to content

Commit de6da99

Browse files
committed
Add open ai temporal template
1 parent 826536d commit de6da99

File tree

16 files changed

+1318
-3
lines changed

16 files changed

+1318
-3
lines changed

src/agentex/lib/cli/commands/init.py

Lines changed: 16 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,7 @@
2323

2424
class TemplateType(str, Enum):
2525
TEMPORAL = "temporal"
26+
TEMPORAL_OPENAI_AGENTS = "temporal-openai-agents"
2627
DEFAULT = "default"
2728
SYNC = "sync"
2829

@@ -54,6 +55,7 @@ def create_project_structure(
5455
# Define project files based on template type
5556
project_files = {
5657
TemplateType.TEMPORAL: ["acp.py", "workflow.py", "run_worker.py"],
58+
TemplateType.TEMPORAL_OPENAI_AGENTS: ["acp.py", "workflow.py", "run_worker.py", "activities.py"],
5759
TemplateType.DEFAULT: ["acp.py"],
5860
TemplateType.SYNC: ["acp.py"],
5961
}[template_type]
@@ -152,13 +154,26 @@ def validate_agent_name(text: str) -> bool | str:
152154
"What type of template would you like to create?",
153155
choices=[
154156
{"name": "Async - ACP Only", "value": TemplateType.DEFAULT},
155-
{"name": "Async - Temporal", "value": TemplateType.TEMPORAL},
157+
{"name": "Async - Temporal", "value": "temporal_submenu"},
156158
{"name": "Sync ACP", "value": TemplateType.SYNC},
157159
],
158160
).ask()
159161
if not template_type:
160162
return
161163

164+
# If Temporal was selected, show sub-menu for Temporal variants
165+
if template_type == "temporal_submenu":
166+
console.print()
167+
template_type = questionary.select(
168+
"Which Temporal template would you like to use?",
169+
choices=[
170+
{"name": "Basic Temporal", "value": TemplateType.TEMPORAL},
171+
{"name": "Temporal + OpenAI Agents SDK (Recommended)", "value": TemplateType.TEMPORAL_OPENAI_AGENTS},
172+
],
173+
).ask()
174+
if not template_type:
175+
return
176+
162177
project_path = questionary.path(
163178
"Where would you like to create your project?", default="."
164179
).ask()
Lines changed: 43 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,43 @@
1+
# Python
2+
__pycache__/
3+
*.py[cod]
4+
*$py.class
5+
*.so
6+
.Python
7+
build/
8+
develop-eggs/
9+
dist/
10+
downloads/
11+
eggs/
12+
.eggs/
13+
lib/
14+
lib64/
15+
parts/
16+
sdist/
17+
var/
18+
wheels/
19+
*.egg-info/
20+
.installed.cfg
21+
*.egg
22+
23+
# Environments
24+
.env**
25+
.venv
26+
env/
27+
venv/
28+
ENV/
29+
env.bak/
30+
venv.bak/
31+
32+
# IDE
33+
.idea/
34+
.vscode/
35+
*.swp
36+
*.swo
37+
38+
# Git
39+
.git
40+
.gitignore
41+
42+
# Misc
43+
.DS_Store
Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
# syntax=docker/dockerfile:1.3
2+
FROM python:3.12-slim
3+
COPY --from=ghcr.io/astral-sh/uv:0.6.4 /uv /uvx /bin/
4+
5+
# Install system dependencies
6+
RUN apt-get update && apt-get install -y \
7+
htop \
8+
vim \
9+
curl \
10+
tar \
11+
python3-dev \
12+
postgresql-client \
13+
build-essential \
14+
libpq-dev \
15+
gcc \
16+
cmake \
17+
netcat-openbsd \
18+
nodejs \
19+
npm \
20+
&& apt-get clean \
21+
&& rm -rf /var/lib/apt/lists/**
22+
23+
# Install tctl (Temporal CLI)
24+
RUN curl -L https://github.com/temporalio/tctl/releases/download/v1.18.1/tctl_1.18.1_linux_arm64.tar.gz -o /tmp/tctl.tar.gz && \
25+
tar -xzf /tmp/tctl.tar.gz -C /usr/local/bin && \
26+
chmod +x /usr/local/bin/tctl && \
27+
rm /tmp/tctl.tar.gz
28+
29+
RUN uv pip install --system --upgrade pip setuptools wheel
30+
31+
ENV UV_HTTP_TIMEOUT=1000
32+
33+
# Copy just the pyproject.toml file to optimize caching
34+
COPY {{ project_path_from_build_root }}/pyproject.toml /app/{{ project_path_from_build_root }}/pyproject.toml
35+
36+
WORKDIR /app/{{ project_path_from_build_root }}
37+
38+
# Install the required Python packages using uv
39+
RUN uv pip install --system .
40+
41+
# Copy the project code
42+
COPY {{ project_path_from_build_root }}/project /app/{{ project_path_from_build_root }}/project
43+
44+
# Run the ACP server using uvicorn
45+
CMD ["uvicorn", "project.acp:acp", "--host", "0.0.0.0", "--port", "8000"]
46+
47+
# When we deploy the worker, we will replace the CMD with the following
48+
# CMD ["python", "-m", "run_worker"]
Lines changed: 48 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,48 @@
1+
# syntax=docker/dockerfile:1.3
2+
FROM python:3.12-slim
3+
COPY --from=ghcr.io/astral-sh/uv:0.6.4 /uv /uvx /bin/
4+
5+
# Install system dependencies
6+
RUN apt-get update && apt-get install -y \
7+
htop \
8+
vim \
9+
curl \
10+
tar \
11+
python3-dev \
12+
postgresql-client \
13+
build-essential \
14+
libpq-dev \
15+
gcc \
16+
cmake \
17+
netcat-openbsd \
18+
node \
19+
npm \
20+
&& apt-get clean \
21+
&& rm -rf /var/lib/apt/lists/*
22+
23+
# Install tctl (Temporal CLI)
24+
RUN curl -L https://github.com/temporalio/tctl/releases/download/v1.18.1/tctl_1.18.1_linux_arm64.tar.gz -o /tmp/tctl.tar.gz && \
25+
tar -xzf /tmp/tctl.tar.gz -C /usr/local/bin && \
26+
chmod +x /usr/local/bin/tctl && \
27+
rm /tmp/tctl.tar.gz
28+
29+
RUN uv pip install --system --upgrade pip setuptools wheel
30+
31+
ENV UV_HTTP_TIMEOUT=1000
32+
33+
# Copy just the requirements file to optimize caching
34+
COPY {{ project_path_from_build_root }}/requirements.txt /app/{{ project_path_from_build_root }}/requirements.txt
35+
36+
WORKDIR /app/{{ project_path_from_build_root }}
37+
38+
# Install the required Python packages
39+
RUN uv pip install --system -r requirements.txt
40+
41+
# Copy the project code
42+
COPY {{ project_path_from_build_root }}/project /app/{{ project_path_from_build_root }}/project
43+
44+
# Run the ACP server using uvicorn
45+
CMD ["uvicorn", "project.acp:acp", "--host", "0.0.0.0", "--port", "8000"]
46+
47+
# When we deploy the worker, we will replace the CMD with the following
48+
# CMD ["python", "-m", "run_worker"]

0 commit comments

Comments
 (0)