# Create filters (one per seat) POST https://hublinks.io/rest/accounts/{account_id}/campaigns/{campaign_id}/filters Content-Type: application/json Create multiple filters; generates `filter_group_id`. **Request body fields (wrapped in `campaign` object):** - `name` (string, required) - Human-readable campaign name. - `account_id` (string, required) - Target account ID. - `status` (string, optional) - `DRAFT` | `RUN` | `PAUSE` | `DONE`. Defaults to `DRAFT`. - `seats` (array of strings, required) - Seat IDs to run this campaign. - `schedule` (object, required) - Day-of-week schedule. Each day key maps to `[enabled (bool), start_hour (int), end_hour (int)]`. - `timezone` (integer, optional) - UTC offset in minutes (e.g. `-300` = UTC-5). - `campaign_id` (string, optional) - Supply to create with a specific ID; omit to auto-generate. Reference: https://api.hublinks.io/api-reference/filters/create-filters-one-per-seat ## OpenAPI Specification ```yaml openapi: 3.1.0 info: title: collection version: 1.0.0 paths: /rest/accounts/{account_id}/campaigns/{campaign_id}/filters: post: operationId: create-filters-one-per-seat summary: Create filters (one per seat) description: >- Create multiple filters; generates `filter_group_id`. **Request body fields (wrapped in `campaign` object):** - `name` (string, required) - Human-readable campaign name. - `account_id` (string, required) - Target account ID. - `status` (string, optional) - `DRAFT` | `RUN` | `PAUSE` | `DONE`. Defaults to `DRAFT`. - `seats` (array of strings, required) - Seat IDs to run this campaign. - `schedule` (object, required) - Day-of-week schedule. Each day key maps to `[enabled (bool), start_hour (int), end_hour (int)]`. - `timezone` (integer, optional) - UTC offset in minutes (e.g. `-300` = UTC-5). - `campaign_id` (string, optional) - Supply to create with a specific ID; omit to auto-generate. tags: - subpackage_filters parameters: - name: account_id in: path required: true schema: type: string - name: campaign_id in: path required: true schema: type: string - name: X-API-KEY in: header required: true schema: type: string responses: '200': description: Response with status 200 content: application/json: schema: $ref: >- #/components/schemas/Filters_Create filters (one per seat)_Response_200 '400': description: Bad Request content: application/json: schema: $ref: >- #/components/schemas/PostRestAccountsAccount_cd855c2bb1cc72097238CampaignsCampaign_test_123FiltersRequestBadRequestError '401': description: Unauthorized content: application/json: schema: $ref: >- #/components/schemas/PostRestAccountsAccount_cd855c2bb1cc72097238CampaignsCampaign_test_123FiltersRequestUnauthorizedError requestBody: content: application/json: schema: type: object properties: seats: type: array items: type: string filter: $ref: >- #/components/schemas/RestAccountsAccountIdCampaignsCampaignIdFiltersPostRequestBodyContentApplicationJsonSchemaFilter required: - seats - filter servers: - url: https://hublinks.io components: schemas: RestAccountsAccountIdCampaignsCampaignIdFiltersPostRequestBodyContentApplicationJsonSchemaFilterFilters: type: object properties: data_cleansing: type: boolean include_degree_1: type: boolean required: - data_cleansing - include_degree_1 title: >- RestAccountsAccountIdCampaignsCampaignIdFiltersPostRequestBodyContentApplicationJsonSchemaFilterFilters RestAccountsAccountIdCampaignsCampaignIdFiltersPostRequestBodyContentApplicationJsonSchemaFilter: type: object properties: type: type: string filters: $ref: >- #/components/schemas/RestAccountsAccountIdCampaignsCampaignIdFiltersPostRequestBodyContentApplicationJsonSchemaFilterFilters url_page: type: string format: uri max_profiles: type: integer profile_fetch_type: type: string required: - type - filters - url_page - max_profiles - profile_fetch_type title: >- RestAccountsAccountIdCampaignsCampaignIdFiltersPostRequestBodyContentApplicationJsonSchemaFilter RestAccountsAccountIdCampaignsCampaignIdFiltersPostResponsesContentApplicationJsonSchemaFiltersItemsFilters: type: object properties: data_cleansing: type: boolean include_degree_1: type: boolean required: - data_cleansing - include_degree_1 title: >- RestAccountsAccountIdCampaignsCampaignIdFiltersPostResponsesContentApplicationJsonSchemaFiltersItemsFilters RestAccountsAccountIdCampaignsCampaignIdFiltersPostResponsesContentApplicationJsonSchemaFiltersItems: type: object properties: type: type: string status: type: string filters: $ref: >- #/components/schemas/RestAccountsAccountIdCampaignsCampaignIdFiltersPostResponsesContentApplicationJsonSchemaFiltersItemsFilters seat_id: type: string url_page: type: string format: uri filter_id: type: string account_id: type: string created_at: type: integer campaign_id: type: string max_profiles: type: integer filter_group_id: type: string profile_fetch_type: type: string required: - type - status - filters - seat_id - url_page - filter_id - account_id - created_at - campaign_id - max_profiles - filter_group_id - profile_fetch_type title: >- RestAccountsAccountIdCampaignsCampaignIdFiltersPostResponsesContentApplicationJsonSchemaFiltersItems Filters_Create filters (one per seat)_Response_200: type: object properties: success: type: boolean filters: type: array items: $ref: >- #/components/schemas/RestAccountsAccountIdCampaignsCampaignIdFiltersPostResponsesContentApplicationJsonSchemaFiltersItems required: - success - filters title: Filters_Create filters (one per seat)_Response_200 PostRestAccountsAccount_cd855c2bb1cc72097238CampaignsCampaign_test_123FiltersRequestBadRequestError: type: object properties: error: type: string message: type: string required: - error - message title: >- PostRestAccountsAccount_cd855c2bb1cc72097238CampaignsCampaign_test_123FiltersRequestBadRequestError PostRestAccountsAccount_cd855c2bb1cc72097238CampaignsCampaign_test_123FiltersRequestUnauthorizedError: type: object properties: error: type: string message: type: string required: - error - message title: >- PostRestAccountsAccount_cd855c2bb1cc72097238CampaignsCampaign_test_123FiltersRequestUnauthorizedError securitySchemes: apiKeyAuth: type: apiKey in: header name: X-API-KEY ``` ## SDK Code Examples ```python Filters_Create filters (one per seat)_example import requests url = "https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters" payload = { "seats": ["seat_6a13e661ecc6a86e3fb7"], "filter": { "type": "filter_LP", "filters": { "data_cleansing": True, "include_degree_1": True }, "url_page": "https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e", "max_profiles": 500, "profile_fetch_type": "LAZY" } } headers = { "X-API-KEY": "", "Content-Type": "application/json" } response = requests.post(url, json=payload, headers=headers) print(response.json()) ``` ```javascript Filters_Create filters (one per seat)_example const url = 'https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters'; const options = { method: 'POST', headers: {'X-API-KEY': '', 'Content-Type': 'application/json'}, body: '{"seats":["seat_6a13e661ecc6a86e3fb7"],"filter":{"type":"filter_LP","filters":{"data_cleansing":true,"include_degree_1":true},"url_page":"https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e","max_profiles":500,"profile_fetch_type":"LAZY"}}' }; try { const response = await fetch(url, options); const data = await response.json(); console.log(data); } catch (error) { console.error(error); } ``` ```go Filters_Create filters (one per seat)_example package main import ( "fmt" "strings" "net/http" "io" ) func main() { url := "https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters" payload := strings.NewReader("{\n \"seats\": [\n \"seat_6a13e661ecc6a86e3fb7\"\n ],\n \"filter\": {\n \"type\": \"filter_LP\",\n \"filters\": {\n \"data_cleansing\": true,\n \"include_degree_1\": true\n },\n \"url_page\": \"https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e\",\n \"max_profiles\": 500,\n \"profile_fetch_type\": \"LAZY\"\n }\n}") req, _ := http.NewRequest("POST", url, payload) req.Header.Add("X-API-KEY", "") 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 Filters_Create filters (one per seat)_example require 'uri' require 'net/http' url = URI("https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters") http = Net::HTTP.new(url.host, url.port) http.use_ssl = true request = Net::HTTP::Post.new(url) request["X-API-KEY"] = '' request["Content-Type"] = 'application/json' request.body = "{\n \"seats\": [\n \"seat_6a13e661ecc6a86e3fb7\"\n ],\n \"filter\": {\n \"type\": \"filter_LP\",\n \"filters\": {\n \"data_cleansing\": true,\n \"include_degree_1\": true\n },\n \"url_page\": \"https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e\",\n \"max_profiles\": 500,\n \"profile_fetch_type\": \"LAZY\"\n }\n}" response = http.request(request) puts response.read_body ``` ```java Filters_Create filters (one per seat)_example import com.mashape.unirest.http.HttpResponse; import com.mashape.unirest.http.Unirest; HttpResponse response = Unirest.post("https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters") .header("X-API-KEY", "") .header("Content-Type", "application/json") .body("{\n \"seats\": [\n \"seat_6a13e661ecc6a86e3fb7\"\n ],\n \"filter\": {\n \"type\": \"filter_LP\",\n \"filters\": {\n \"data_cleansing\": true,\n \"include_degree_1\": true\n },\n \"url_page\": \"https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e\",\n \"max_profiles\": 500,\n \"profile_fetch_type\": \"LAZY\"\n }\n}") .asString(); ``` ```php Filters_Create filters (one per seat)_example request('POST', 'https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters', [ 'body' => '{ "seats": [ "seat_6a13e661ecc6a86e3fb7" ], "filter": { "type": "filter_LP", "filters": { "data_cleansing": true, "include_degree_1": true }, "url_page": "https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e", "max_profiles": 500, "profile_fetch_type": "LAZY" } }', 'headers' => [ 'Content-Type' => 'application/json', 'X-API-KEY' => '', ], ]); echo $response->getBody(); ``` ```csharp Filters_Create filters (one per seat)_example using RestSharp; var client = new RestClient("https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters"); var request = new RestRequest(Method.POST); request.AddHeader("X-API-KEY", ""); request.AddHeader("Content-Type", "application/json"); request.AddParameter("application/json", "{\n \"seats\": [\n \"seat_6a13e661ecc6a86e3fb7\"\n ],\n \"filter\": {\n \"type\": \"filter_LP\",\n \"filters\": {\n \"data_cleansing\": true,\n \"include_degree_1\": true\n },\n \"url_page\": \"https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e\",\n \"max_profiles\": 500,\n \"profile_fetch_type\": \"LAZY\"\n }\n}", ParameterType.RequestBody); IRestResponse response = client.Execute(request); ``` ```swift Filters_Create filters (one per seat)_example import Foundation let headers = [ "X-API-KEY": "", "Content-Type": "application/json" ] let parameters = [ "seats": ["seat_6a13e661ecc6a86e3fb7"], "filter": [ "type": "filter_LP", "filters": [ "data_cleansing": true, "include_degree_1": true ], "url_page": "https://www.linkedin.com/search/results/people/?keywords=ceos%20michigan&network=%5B%22S%22%5D&sid=p-e", "max_profiles": 500, "profile_fetch_type": "LAZY" ] ] as [String : Any] let postData = JSONSerialization.data(withJSONObject: parameters, options: []) let request = NSMutableURLRequest(url: NSURL(string: "https://hublinks.io/rest/accounts/account_id/campaigns/campaign_id/filters")! 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() ```