# Deploy agent POST https://api.astropod.ai/api/v1/deploy Content-Type: application/json Deploys the latest build of an agent to Kubernetes. Creates or updates the K8s namespace, deployment, services, and ingress. Returns `200` on full success or `207` if some resources had errors. Reference: https://docs.astropod.ai/api-reference/endpoints/astro-ai-api/deployments/deploy-agent ## OpenAPI Specification ```yaml openapi: 3.1.1 info: title: Deploy agent version: endpoint_deployments.deployAgent paths: /deploy: post: operationId: deploy-agent summary: Deploy agent description: > Deploys the latest build of an agent to Kubernetes. Creates or updates the K8s namespace, deployment, services, and ingress. Returns `200` on full success or `207` if some resources had errors. tags: - - subpackage_deployments parameters: - name: Authorization in: header description: OAuth 2.0 device flow or session token from WorkOS required: true schema: type: string responses: '200': description: Deployment succeeded content: application/json: schema: $ref: '#/components/schemas/DeployResponse' '400': description: Invalid request body or parameters content: {} '401': description: Authentication required content: {} '403': description: Insufficient permissions for this account content: {} '404': description: Resource not found content: {} '500': description: Server error content: {} requestBody: content: application/json: schema: $ref: '#/components/schemas/DeployRequest' components: schemas: DeployRequest: type: object properties: account: type: string description: Account that owns the deployment name: type: string description: Agent name source_account: type: string description: >- Source account for cross-account deploys (uses latest published version) user_credentials: type: object additionalProperties: type: string description: Credential key-value pairs required by the agent interfaces: type: array items: type: string description: Interface adapter names to enable (e.g. ["slack", "web"]) schedules: type: object additionalProperties: type: string description: Cron schedules keyed by ingestion name required: - account - name DeployResponseStatus: type: string enum: - value: success - value: partial ServiceEndpoint: type: object properties: name: type: string url: type: string type: type: string DeployResponse: type: object properties: status: $ref: '#/components/schemas/DeployResponseStatus' name: type: string build_id: type: string k8s_namespace: type: string deployed_at: type: string format: date-time resources: type: array items: type: object additionalProperties: description: Any type description: Kubernetes resources created or updated service_endpoints: type: array items: $ref: '#/components/schemas/ServiceEndpoint' errors: type: array items: type: string ``` ## SDK Code Examples ```python import requests url = "https://api.astropod.ai/api/v1/deploy" payload = { "account": "astro-enterprise", "name": "weather-agent" } headers = { "Authorization": "Bearer ", "Content-Type": "application/json" } response = requests.post(url, json=payload, headers=headers) print(response.json()) ``` ```javascript const url = 'https://api.astropod.ai/api/v1/deploy'; const options = { method: 'POST', headers: {Authorization: 'Bearer ', 'Content-Type': 'application/json'}, body: '{"account":"astro-enterprise","name":"weather-agent"}' }; try { const response = await fetch(url, options); const data = await response.json(); console.log(data); } catch (error) { console.error(error); } ``` ```go package main import ( "fmt" "strings" "net/http" "io" ) func main() { url := "https://api.astropod.ai/api/v1/deploy" payload := strings.NewReader("{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}") req, _ := http.NewRequest("POST", url, payload) req.Header.Add("Authorization", "Bearer ") req.Header.Add("Content-Type", "application/json") res, _ := http.DefaultClient.Do(req) defer res.Body.Close() body, _ := io.ReadAll(res.Body) fmt.Println(res) fmt.Println(string(body)) } ``` ```ruby require 'uri' require 'net/http' url = URI("https://api.astropod.ai/api/v1/deploy") http = Net::HTTP.new(url.host, url.port) http.use_ssl = true request = Net::HTTP::Post.new(url) request["Authorization"] = 'Bearer ' request["Content-Type"] = 'application/json' request.body = "{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}" response = http.request(request) puts response.read_body ``` ```java import com.mashape.unirest.http.HttpResponse; import com.mashape.unirest.http.Unirest; HttpResponse response = Unirest.post("https://api.astropod.ai/api/v1/deploy") .header("Authorization", "Bearer ") .header("Content-Type", "application/json") .body("{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}") .asString(); ``` ```php request('POST', 'https://api.astropod.ai/api/v1/deploy', [ 'body' => '{ "account": "astro-enterprise", "name": "weather-agent" }', 'headers' => [ 'Authorization' => 'Bearer ', 'Content-Type' => 'application/json', ], ]); echo $response->getBody(); ``` ```csharp using RestSharp; var client = new RestClient("https://api.astropod.ai/api/v1/deploy"); var request = new RestRequest(Method.POST); request.AddHeader("Authorization", "Bearer "); request.AddHeader("Content-Type", "application/json"); request.AddParameter("application/json", "{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}", ParameterType.RequestBody); IRestResponse response = client.Execute(request); ``` ```swift import Foundation let headers = [ "Authorization": "Bearer ", "Content-Type": "application/json" ] let parameters = [ "account": "astro-enterprise", "name": "weather-agent" ] as [String : Any] let postData = JSONSerialization.data(withJSONObject: parameters, options: []) let request = NSMutableURLRequest(url: NSURL(string: "https://api.astropod.ai/api/v1/deploy")! as URL, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0) request.httpMethod = "POST" request.allHTTPHeaderFields = headers request.httpBody = postData as Data let session = URLSession.shared let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in if (error != nil) { print(error as Any) } else { let httpResponse = response as? HTTPURLResponse print(httpResponse) } }) dataTask.resume() ``` ```python import requests url = "https://api.astropod.ai/api/v1/deploy" payload = { "account": "astro-enterprise", "name": "weather-agent" } headers = { "Authorization": "Bearer ", "Content-Type": "application/json" } response = requests.post(url, json=payload, headers=headers) print(response.json()) ``` ```javascript const url = 'https://api.astropod.ai/api/v1/deploy'; const options = { method: 'POST', headers: {Authorization: 'Bearer ', 'Content-Type': 'application/json'}, body: '{"account":"astro-enterprise","name":"weather-agent"}' }; try { const response = await fetch(url, options); const data = await response.json(); console.log(data); } catch (error) { console.error(error); } ``` ```go package main import ( "fmt" "strings" "net/http" "io" ) func main() { url := "https://api.astropod.ai/api/v1/deploy" payload := strings.NewReader("{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}") req, _ := http.NewRequest("POST", url, payload) req.Header.Add("Authorization", "Bearer ") req.Header.Add("Content-Type", "application/json") res, _ := http.DefaultClient.Do(req) defer res.Body.Close() body, _ := io.ReadAll(res.Body) fmt.Println(res) fmt.Println(string(body)) } ``` ```ruby require 'uri' require 'net/http' url = URI("https://api.astropod.ai/api/v1/deploy") http = Net::HTTP.new(url.host, url.port) http.use_ssl = true request = Net::HTTP::Post.new(url) request["Authorization"] = 'Bearer ' request["Content-Type"] = 'application/json' request.body = "{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}" response = http.request(request) puts response.read_body ``` ```java import com.mashape.unirest.http.HttpResponse; import com.mashape.unirest.http.Unirest; HttpResponse response = Unirest.post("https://api.astropod.ai/api/v1/deploy") .header("Authorization", "Bearer ") .header("Content-Type", "application/json") .body("{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}") .asString(); ``` ```php request('POST', 'https://api.astropod.ai/api/v1/deploy', [ 'body' => '{ "account": "astro-enterprise", "name": "weather-agent" }', 'headers' => [ 'Authorization' => 'Bearer ', 'Content-Type' => 'application/json', ], ]); echo $response->getBody(); ``` ```csharp using RestSharp; var client = new RestClient("https://api.astropod.ai/api/v1/deploy"); var request = new RestRequest(Method.POST); request.AddHeader("Authorization", "Bearer "); request.AddHeader("Content-Type", "application/json"); request.AddParameter("application/json", "{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-agent\"\n}", ParameterType.RequestBody); IRestResponse response = client.Execute(request); ``` ```swift import Foundation let headers = [ "Authorization": "Bearer ", "Content-Type": "application/json" ] let parameters = [ "account": "astro-enterprise", "name": "weather-agent" ] as [String : Any] let postData = JSONSerialization.data(withJSONObject: parameters, options: []) let request = NSMutableURLRequest(url: NSURL(string: "https://api.astropod.ai/api/v1/deploy")! as URL, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0) request.httpMethod = "POST" request.allHTTPHeaderFields = headers request.httpBody = postData as Data let session = URLSession.shared let dataTask = session.dataTask(with: request as URLRequest, completionHandler: { (data, response, error) -> Void in if (error != nil) { print(error as Any) } else { let httpResponse = response as? HTTPURLResponse print(httpResponse) } }) dataTask.resume() ```