# Register agent POST https://api.astropod.ai/api/v1/agents/{account}/{name}/register Content-Type: application/json Registers a new agent build or updates an existing one. Requires account owner or admin role. Reference: https://docs.astropod.ai/api-reference/endpoints/astro-ai-api/agents/register-agent ## OpenAPI Specification ```yaml openapi: 3.1.1 info: title: Register agent version: endpoint_agents.registerAgent paths: /agents/{account}/{name}/register: post: operationId: register-agent summary: Register agent description: >- Registers a new agent build or updates an existing one. Requires account owner or admin role. tags: - - subpackage_agents parameters: - name: account in: path description: Account name (slug) required: true schema: type: string - name: name in: path description: Agent name required: true schema: type: string - name: Authorization in: header description: OAuth 2.0 device flow or session token from WorkOS required: true schema: type: string responses: '201': description: Agent registered successfully content: application/json: schema: $ref: '#/components/schemas/RegisterAgentResponse' '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/RegisterAgentRequest' components: schemas: RegisterAgentRequest: type: object properties: build_id: type: string registry: type: string description: OCI registry URL spec_content: type: string description: YAML content of astroai.yml readme: type: string required: - build_id - registry - spec_content RegisterAgentResponseValidationWarningsItems: type: object properties: {} RegisterAgentResponse: type: object properties: message: type: string account: type: string name: type: string build_id: type: string validation_warnings: type: array items: $ref: '#/components/schemas/RegisterAgentResponseValidationWarningsItems' ``` ## SDK Code Examples ```python import requests url = "https://api.astropod.ai/api/v1/agents/account/name/register" payload = { "build_id": "build-20240615-xyz123", "registry": "registry.astropod.ai/agents/astro-bot", "spec_content": "name: AstroBot version: 1.2.0 description: AI assistant agent for space mission planning entrypoint: main.py resources: cpu: 500m memory: 256Mi " } 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/agents/account/name/register'; const options = { method: 'POST', headers: {Authorization: 'Bearer ', 'Content-Type': 'application/json'}, body: '{"build_id":"build-20240615-xyz123","registry":"registry.astropod.ai/agents/astro-bot","spec_content":"name: AstroBot\nversion: 1.2.0\ndescription: AI assistant agent for space mission planning\nentrypoint: main.py\nresources:\n cpu: 500m\n memory: 256Mi\n"}' }; 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/agents/account/name/register" payload := strings.NewReader("{\n \"build_id\": \"build-20240615-xyz123\",\n \"registry\": \"registry.astropod.ai/agents/astro-bot\",\n \"spec_content\": \"name: AstroBot\\nversion: 1.2.0\\ndescription: AI assistant agent for space mission planning\\nentrypoint: main.py\\nresources:\\n cpu: 500m\\n memory: 256Mi\\n\"\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/agents/account/name/register") 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 \"build_id\": \"build-20240615-xyz123\",\n \"registry\": \"registry.astropod.ai/agents/astro-bot\",\n \"spec_content\": \"name: AstroBot\\nversion: 1.2.0\\ndescription: AI assistant agent for space mission planning\\nentrypoint: main.py\\nresources:\\n cpu: 500m\\n memory: 256Mi\\n\"\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/agents/account/name/register") .header("Authorization", "Bearer ") .header("Content-Type", "application/json") .body("{\n \"build_id\": \"build-20240615-xyz123\",\n \"registry\": \"registry.astropod.ai/agents/astro-bot\",\n \"spec_content\": \"name: AstroBot\\nversion: 1.2.0\\ndescription: AI assistant agent for space mission planning\\nentrypoint: main.py\\nresources:\\n cpu: 500m\\n memory: 256Mi\\n\"\n}") .asString(); ``` ```php request('POST', 'https://api.astropod.ai/api/v1/agents/account/name/register', [ 'body' => '{ "build_id": "build-20240615-xyz123", "registry": "registry.astropod.ai/agents/astro-bot", "spec_content": "name: AstroBot\\nversion: 1.2.0\\ndescription: AI assistant agent for space mission planning\\nentrypoint: main.py\\nresources:\\n cpu: 500m\\n memory: 256Mi\\n" }', 'headers' => [ 'Authorization' => 'Bearer ', 'Content-Type' => 'application/json', ], ]); echo $response->getBody(); ``` ```csharp using RestSharp; var client = new RestClient("https://api.astropod.ai/api/v1/agents/account/name/register"); var request = new RestRequest(Method.POST); request.AddHeader("Authorization", "Bearer "); request.AddHeader("Content-Type", "application/json"); request.AddParameter("application/json", "{\n \"build_id\": \"build-20240615-xyz123\",\n \"registry\": \"registry.astropod.ai/agents/astro-bot\",\n \"spec_content\": \"name: AstroBot\\nversion: 1.2.0\\ndescription: AI assistant agent for space mission planning\\nentrypoint: main.py\\nresources:\\n cpu: 500m\\n memory: 256Mi\\n\"\n}", ParameterType.RequestBody); IRestResponse response = client.Execute(request); ``` ```swift import Foundation let headers = [ "Authorization": "Bearer ", "Content-Type": "application/json" ] let parameters = [ "build_id": "build-20240615-xyz123", "registry": "registry.astropod.ai/agents/astro-bot", "spec_content": "name: AstroBot version: 1.2.0 description: AI assistant agent for space mission planning entrypoint: main.py resources: cpu: 500m memory: 256Mi " ] as [String : Any] let postData = JSONSerialization.data(withJSONObject: parameters, options: []) let request = NSMutableURLRequest(url: NSURL(string: "https://api.astropod.ai/api/v1/agents/account/name/register")! 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() ```