# Update Proxy PATCH https://api.bctrl.ai/v1/proxies/{id} Content-Type: application/json Reference: https://platform.bctrl.ai/api/api-reference/proxies/update ## OpenAPI Specification ```yaml openapi: 3.1.0 info: title: bctrl API version: 1.0.0 paths: /v1/proxies/{id}: patch: operationId: update summary: Update a saved proxy tags: - subpackage_proxies parameters: - name: id in: path required: true schema: type: string - name: Authorization in: header description: Use Bearer . required: true schema: type: string responses: '200': description: Default Response content: application/json: schema: $ref: '#/components/schemas/proxies_update_Response_200' requestBody: content: application/json: schema: $ref: '#/components/schemas/proxies_update_Request' servers: - url: https://api.bctrl.ai - url: http://localhost:8787 components: schemas: V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0ConnectionProtocol: type: string enum: - http - socks5 title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0ConnectionProtocol V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0Connection: type: object properties: host: type: string password: type: - string - 'null' port: type: integer protocol: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0ConnectionProtocol username: type: - string - 'null' title: V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0Connection V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0Kind: type: string enum: - custom title: V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0Kind ProxiesUpdateRequest0: type: object properties: connection: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0Connection kind: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf0Kind name: type: string required: - kind title: ProxiesUpdateRequest0 V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsGeo: type: object properties: city: type: string country: type: string isp: type: string region: type: string title: V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsGeo V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsIpFamily: type: string enum: - dual-stack - ipv4-only title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsIpFamily V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsPoolPreference: type: string enum: - quality - quality-speed - speed - max-pool title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsPoolPreference V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsProtocol: type: string enum: - http - socks5 title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsProtocol V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf0Strategy: type: string enum: - rotate title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf0Strategy V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession0: type: object properties: strategy: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf0Strategy required: - strategy title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession0 V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf1Strategy: type: string enum: - sticky title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf1Strategy V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession1: type: object properties: key: type: string strategy: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf1Strategy required: - strategy title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession1 V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession: oneOf: - $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession0 - $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession1 title: >- V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1Defaults: type: object properties: geo: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsGeo ipFamily: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsIpFamily poolPreference: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsPoolPreference protocol: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsProtocol session: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1DefaultsSession title: V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1Defaults V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1Kind: type: string enum: - managed-rotating title: V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1Kind ProxiesUpdateRequest1: type: object properties: defaults: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1Defaults kind: $ref: >- #/components/schemas/V1ProxiesIdPatchRequestBodyContentApplicationJsonSchemaOneOf1Kind name: type: string required: - kind title: ProxiesUpdateRequest1 proxies_update_Request: oneOf: - $ref: '#/components/schemas/ProxiesUpdateRequest0' - $ref: '#/components/schemas/ProxiesUpdateRequest1' title: proxies_update_Request V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0ConnectionProtocol: type: string enum: - http - socks5 title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0ConnectionProtocol V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0Connection: type: object properties: hasPassword: type: boolean host: type: string port: type: integer protocol: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0ConnectionProtocol username: type: - string - 'null' required: - hasPassword - host - port - protocol title: V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0Connection V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0Kind: type: string enum: - custom title: V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0Kind ProxiesUpdateResponse2000: type: object properties: connection: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0Connection createdAt: type: string id: type: string format: uuid kind: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf0Kind name: type: string updatedAt: type: string required: - connection - createdAt - id - kind - name - updatedAt title: ProxiesUpdateResponse2000 V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsGeo: type: object properties: city: type: string country: type: string isp: type: string region: type: string title: V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsGeo V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsIpFamily: type: string enum: - dual-stack - ipv4-only title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsIpFamily V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsPoolPreference: type: string enum: - quality - quality-speed - speed - max-pool title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsPoolPreference V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsProtocol: type: string enum: - http - socks5 title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsProtocol V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf0Strategy: type: string enum: - rotate title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf0Strategy V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession0: type: object properties: strategy: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf0Strategy required: - strategy title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession0 V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf1Strategy: type: string enum: - sticky title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf1Strategy V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession1: type: object properties: key: type: string strategy: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSessionOneOf1Strategy required: - strategy title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession1 V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession: oneOf: - $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession0 - $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession1 title: >- V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1Defaults: type: object properties: geo: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsGeo ipFamily: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsIpFamily poolPreference: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsPoolPreference protocol: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsProtocol session: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1DefaultsSession title: V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1Defaults V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1Kind: type: string enum: - managed-rotating title: V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1Kind ProxiesUpdateResponse2001: type: object properties: createdAt: type: string defaults: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1Defaults id: type: string format: uuid kind: $ref: >- #/components/schemas/V1ProxiesIdPatchResponsesContentApplicationJsonSchemaOneOf1Kind name: type: string updatedAt: type: string required: - createdAt - defaults - id - kind - name - updatedAt title: ProxiesUpdateResponse2001 proxies_update_Response_200: oneOf: - $ref: '#/components/schemas/ProxiesUpdateResponse2000' - $ref: '#/components/schemas/ProxiesUpdateResponse2001' title: proxies_update_Response_200 securitySchemes: bearerAuth: type: http scheme: bearer description: Use Bearer . ``` ## SDK Code Examples ```python import requests url = "https://api.bctrl.ai/v1/proxies/id" payload = { "kind": "custom" } headers = { "Authorization": "Bearer ", "Content-Type": "application/json" } response = requests.patch(url, json=payload, headers=headers) print(response.json()) ``` ```javascript const url = 'https://api.bctrl.ai/v1/proxies/id'; const options = { method: 'PATCH', headers: {Authorization: 'Bearer ', 'Content-Type': 'application/json'}, body: '{"kind":"custom"}' }; 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.bctrl.ai/v1/proxies/id" payload := strings.NewReader("{\n \"kind\": \"custom\"\n}") req, _ := http.NewRequest("PATCH", 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.bctrl.ai/v1/proxies/id") http = Net::HTTP.new(url.host, url.port) http.use_ssl = true request = Net::HTTP::Patch.new(url) request["Authorization"] = 'Bearer ' request["Content-Type"] = 'application/json' request.body = "{\n \"kind\": \"custom\"\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.patch("https://api.bctrl.ai/v1/proxies/id") .header("Authorization", "Bearer ") .header("Content-Type", "application/json") .body("{\n \"kind\": \"custom\"\n}") .asString(); ``` ```php request('PATCH', 'https://api.bctrl.ai/v1/proxies/id', [ 'body' => '{ "kind": "custom" }', 'headers' => [ 'Authorization' => 'Bearer ', 'Content-Type' => 'application/json', ], ]); echo $response->getBody(); ``` ```csharp using RestSharp; var client = new RestClient("https://api.bctrl.ai/v1/proxies/id"); var request = new RestRequest(Method.PATCH); request.AddHeader("Authorization", "Bearer "); request.AddHeader("Content-Type", "application/json"); request.AddParameter("application/json", "{\n \"kind\": \"custom\"\n}", ParameterType.RequestBody); IRestResponse response = client.Execute(request); ``` ```swift import Foundation let headers = [ "Authorization": "Bearer ", "Content-Type": "application/json" ] let parameters = ["kind": "custom"] as [String : Any] let postData = JSONSerialization.data(withJSONObject: parameters, options: []) let request = NSMutableURLRequest(url: NSURL(string: "https://api.bctrl.ai/v1/proxies/id")! as URL, cachePolicy: .useProtocolCachePolicy, timeoutInterval: 10.0) request.httpMethod = "PATCH" 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() ```