# Validate deployment POST https://api.astropod.ai/api/v1/deploy/validate Content-Type: application/json Validates a deployment request without applying it to the cluster. Useful for pre-flight checks. Reference: https://docs.astropod.ai/api-reference/endpoints/astro-ai-api/deployments/validate-deployment ## OpenAPI Specification ```yaml openapi: 3.1.1 info: title: Validate deployment version: endpoint_deployments.validateDeployment paths: /deploy/validate: post: operationId: validate-deployment summary: Validate deployment description: >- Validates a deployment request without applying it to the cluster. Useful for pre-flight checks. 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: Validation passed content: application/json: schema: $ref: >- #/components/schemas/deployments_validateDeployment_Response_200 '400': description: Validation failed content: {} '401': description: Authentication required content: {} '403': description: Insufficient permissions for this account content: {} '404': description: Resource not found 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 deployments_validateDeployment_Response_200: type: object properties: valid: type: boolean build_id: type: string name: type: string ``` ## SDK Code Examples ```python import requests url = "https://api.astropod.ai/api/v1/deploy/validate" payload = { "account": "astro-enterprise", "name": "weather-forecast-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/validate'; const options = { method: 'POST', headers: {Authorization: 'Bearer ', 'Content-Type': 'application/json'}, body: '{"account":"astro-enterprise","name":"weather-forecast-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/validate" payload := strings.NewReader("{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-forecast-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/validate") 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-forecast-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/validate") .header("Authorization", "Bearer ") .header("Content-Type", "application/json") .body("{\n \"account\": \"astro-enterprise\",\n \"name\": \"weather-forecast-agent\"\n}") .asString(); ``` ```php request('POST', 'https://api.astropod.ai/api/v1/deploy/validate', [ 'body' => '{ "account": "astro-enterprise", "name": "weather-forecast-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/validate"); 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-forecast-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-forecast-agent" ] as [String : Any] let postData = JSONSerialization.data(withJSONObject: parameters, options: []) let request = NSMutableURLRequest(url: NSURL(string: "https://api.astropod.ai/api/v1/deploy/validate")! 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() ```