agent-starter-pack 0.2.2__py3-none-any.whl → 0.2.3__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of agent-starter-pack might be problematic. Click here for more details.

Files changed (26) hide show
  1. {agent_starter_pack-0.2.2.dist-info → agent_starter_pack-0.2.3.dist-info}/METADATA +7 -13
  2. {agent_starter_pack-0.2.2.dist-info → agent_starter_pack-0.2.3.dist-info}/RECORD +26 -26
  3. src/base_template/Makefile +6 -4
  4. src/base_template/README.md +7 -1
  5. src/base_template/deployment/README.md +4 -1
  6. src/base_template/deployment/cd/deploy-to-prod.yaml +3 -3
  7. src/base_template/deployment/cd/staging.yaml +4 -4
  8. src/base_template/deployment/ci/pr_checks.yaml +1 -1
  9. src/base_template/deployment/terraform/build_triggers.tf +3 -0
  10. src/base_template/pyproject.toml +2 -2
  11. src/cli/commands/create.py +35 -9
  12. src/cli/commands/setup_cicd.py +22 -6
  13. src/data_ingestion/README.md +37 -50
  14. src/deployment_targets/agent_engine/app/agent_engine_app.py +7 -12
  15. src/deployment_targets/cloud_run/Dockerfile +1 -1
  16. src/frontends/streamlit/frontend/utils/stream_handler.py +3 -3
  17. src/resources/locks/uv-agentic_rag-agent_engine.lock +128 -127
  18. src/resources/locks/uv-agentic_rag-cloud_run.lock +174 -173
  19. src/resources/locks/uv-crewai_coding_crew-agent_engine.lock +149 -148
  20. src/resources/locks/uv-crewai_coding_crew-cloud_run.lock +195 -194
  21. src/resources/locks/uv-langgraph_base_react-agent_engine.lock +125 -124
  22. src/resources/locks/uv-langgraph_base_react-cloud_run.lock +171 -170
  23. src/resources/locks/uv-live_api-cloud_run.lock +162 -161
  24. {agent_starter_pack-0.2.2.dist-info → agent_starter_pack-0.2.3.dist-info}/WHEEL +0 -0
  25. {agent_starter_pack-0.2.2.dist-info → agent_starter_pack-0.2.3.dist-info}/entry_points.txt +0 -0
  26. {agent_starter_pack-0.2.2.dist-info → agent_starter_pack-0.2.3.dist-info}/licenses/LICENSE +0 -0
@@ -26,16 +26,12 @@ import vertexai
26
26
  from google.cloud import logging as google_cloud_logging
27
27
  from langchain_core.runnables import RunnableConfig
28
28
  from traceloop.sdk import Instruments, Traceloop
29
- from vertexai.preview import reasoning_engines
29
+ from vertexai import agent_engines
30
30
 
31
31
  from app.utils.gcs import create_bucket_if_not_exists
32
32
  from app.utils.tracing import CloudTraceLoggingSpanExporter
33
33
  from app.utils.typing import Feedback, InputChat, dumpd, ensure_valid_config
34
34
 
35
- logging.basicConfig(
36
- level=logging.INFO,
37
- )
38
-
39
35
 
40
36
  class AgentEngineApp:
41
37
  """Class for managing agent engine functionality."""
@@ -124,6 +120,8 @@ class AgentEngineApp:
124
120
  **kwargs: Any,
125
121
  ) -> Any:
126
122
  """Process a single input and return the agent's response."""
123
+ config = ensure_valid_config(config)
124
+ self.set_tracing_properties(config=config)
127
125
  return dumpd(self.runnable.invoke(input=input, config=config, **kwargs))
128
126
 
129
127
  def register_operations(self) -> Mapping[str, Sequence]:
@@ -151,7 +149,7 @@ def deploy_agent_engine_app(
151
149
  requirements_file: str = ".requirements.txt",
152
150
  extra_packages: list[str] = ["./app"],
153
151
  env_vars: dict[str, str] | None = None,
154
- ) -> reasoning_engines.ReasoningEngine:
152
+ ) -> agent_engines.AgentEngine:
155
153
  """Deploy the agent engine app to Vertex AI."""
156
154
 
157
155
  staging_bucket = f"gs://{project}-agent-engine"
@@ -169,7 +167,7 @@ def deploy_agent_engine_app(
169
167
 
170
168
  # Common configuration for both create and update operations
171
169
  agent_config = {
172
- "reasoning_engine": agent,
170
+ "agent_engine": agent,
173
171
  "display_name": agent_name,
174
172
  "description": "This is a sample custom application in Agent Engine that uses LangGraph",
175
173
  "extra_packages": extra_packages,
@@ -178,10 +176,7 @@ def deploy_agent_engine_app(
178
176
  agent_config["requirements"] = requirements
179
177
 
180
178
  # Check if an agent with this name already exists
181
- existing_agents = reasoning_engines.ReasoningEngine.list(
182
- filter=f"display_name={agent_name}"
183
- )
184
-
179
+ existing_agents = list(agent_engines.list(filter=f"display_name={agent_name}"))
185
180
  if existing_agents:
186
181
  # Update the existing agent with new configuration
187
182
  logging.info(f"Updating existing agent: {agent_name}")
@@ -189,7 +184,7 @@ def deploy_agent_engine_app(
189
184
  else:
190
185
  # Create a new agent if none exists
191
186
  logging.info(f"Creating new agent: {agent_name}")
192
- remote_agent = reasoning_engines.ReasoningEngine.create(**agent_config)
187
+ remote_agent = agent_engines.create(**agent_config)
193
188
 
194
189
  config = {
195
190
  "remote_agent_engine_id": remote_agent.resource_name,
@@ -14,7 +14,7 @@
14
14
 
15
15
  FROM python:3.11-slim
16
16
 
17
- RUN pip install --no-cache-dir uv
17
+ RUN pip install --no-cache-dir uv==0.6.12
18
18
 
19
19
  WORKDIR /code
20
20
 
@@ -28,7 +28,7 @@ import streamlit as st
28
28
  import vertexai
29
29
  from google.auth.exceptions import DefaultCredentialsError
30
30
  from langchain_core.messages import AIMessage, ToolMessage
31
- from vertexai.preview import reasoning_engines
31
+ from vertexai import agent_engines
32
32
 
33
33
  from frontend.utils.multimodal_utils import format_content
34
34
 
@@ -43,7 +43,7 @@ def get_remote_agent(remote_agent_engine_id: str) -> Any:
43
43
  project_id = parts[1]
44
44
  location = parts[3]
45
45
  vertexai.init(project=project_id, location=location)
46
- return reasoning_engines.ReasoningEngine(remote_agent_engine_id)
46
+ return agent_engines.AgentEngine(remote_agent_engine_id)
47
47
 
48
48
 
49
49
  @st.cache_resource
@@ -159,7 +159,7 @@ class Client:
159
159
  if self.authenticate_request:
160
160
  headers["Authorization"] = f"Bearer {self.id_token}"
161
161
  with requests.post(
162
- self.url, json=data, headers=headers, stream=True, timeout=10
162
+ self.url, json=data, headers=headers, stream=True, timeout=60
163
163
  ) as response:
164
164
  for line in response.iter_lines():
165
165
  if line: