Post /surveys/{{survey-id}}/emaillists/{{email-list-id}}/emails

Example Request

https://{{env}}.questionpro.com/a/api/v2/surveys/{{survey-id}}/emaillists/{{email-list-id}}/emails?apiKey={{apiKey}}

The value of environment {{env}} variable depends upon your datacenter. Refer to the Environment page for more details.

Authorization

arrow_rightKey - apiKey
  • Name: apiKey
  • Location: query

Request Parameters

arrow_rightPath Parameters
survey-id integer
required
email-list-id integer
required

Request Body

arrow_rightPayload
application/json

                            [
                                {
                                    "emailAddress": "jane.doe@emaildomain.com",
                                    "firstname": "Jane",
                                    "lastname": "Doe",
                                    "custom1": "WA",
                                    "custom2": "Sales",
                                    "custom3": "EID987",
                                    "custom4": "",
                                    "custom5": "",
                                    "highCustomVariables": {
                                        "custom8": "Product A",
                                        "custom10": "Department X"
                            		 }
                                },
                                {
                                    "emailAddress": "john.doe@emaildomain.com",
                                    "firstname": "John",
                                    "lastname": "Doe",
                                    "custom1": "WA",
                                    "custom2": "Sales",
                                    "custom3": "EID986",
                                    "custom4": "",
                                    "custom5": "",
                                    "highCustomVariables": {
                                        "custom8": "Product A",
                                        "custom10": "Department Z"
                                        	}
                                }
                                ]
                    

Example Code

arrow_rightcURL
application/json

                 curl --request POST \
                      --url 'https://{{env}}.questionpro.com/a/api/v2/surveys/{{survey-id}}/emaillists/{{email-list-id}}/emails?apiKey={{apiKey}}' \
                      --header 'Content-Type: application/json' \
                      --data '[
                       {
                                    "emailAddress": "jane.doe@emaildomain.com",
                                    "firstname": "Jane",
                                    "lastname": "Doe",
                                    "custom1": "WA",
                                    "custom2": "Sales",
                                    "custom3": "EID987",
                                    "custom4": "",
                                    "custom5": "",
                                    "highCustomVariables": {
                                        "custom8": "Product A",
                                        "custom10": "Department X"
                            		 }
                                },
                                {
                                    "emailAddress": "john.doe@emaildomain.com",
                                    "firstname": "John",
                                    "lastname": "Doe",
                                    "custom1": "WA",
                                    "custom2": "Sales",
                                    "custom3": "EID986",
                                    "custom4": "",
                                    "custom5": "",
                                    "highCustomVariables": {
                                        "custom8": "Product A",
                                        "custom10": "Department Z"
                                        	}
                                }
                        ]
                
arrow_rightPython
application/json

                            import requests
                        
                            url = "https://{{env}}.questionpro.com/a/api/v2/surveys/{{survey-id}}/emaillists/{{email-list-id}}/emails"
                        
                            querystring = {"apiKey":"{{apiKey}}"}
                        
                            payload = "[{\"emailAddress\":\"jane.doe@emaildomain.com\",\"firstname\":\"Jane\",\"lastname\":\"Doe\",\"custom1\":\"WA\",\"custom2\":\"Sales\",\"custom3\":\"EID987\",\"custom4\":\"\",\"custom5\":\"\",\"highCustomVariables\":{\"custom8\":\"Product A\",\"custom10\":\"Department X\"}},{\"emailAddress\":\"john.doe@emaildomain.com\",\"firstname\":\"John\",\"lastname\":\"Doe\",\"custom1\":\"WA\",\"custom2\":\"Sales\",\"custom3\":\"EID986\",\"custom4\":\"\",\"custom5\":\"\",\"highCustomVariables\":{\"custom8\":\"Product A\",\"custom10\":\"Department Z\"}}]"
                            headers = {'Content-Type': 'application/json'}
                        
                            response = requests.request("POST", url, data=payload, headers=headers, params=querystring)
                        
                            print(response.text)
                    
arrow_rightPHP
application/json

                       <?php
                                        $curl = curl_init();
        
                                        curl_setopt_array($curl, array(
                                        CURLOPT_URL =>"https://{{env}}.questionpro.com/a/api/v2/surveys/{{survey-id}}/emaillists/{{email-list-id}}/emails?apiKey={{apiKey}}",
                                        CURLOPT_RETURNTRANSFER => true,
                                        CURLOPT_ENCODING => "",
                                        CURLOPT_MAXREDIRS => 10,
                                        CURLOPT_TIMEOUT => 30,
                                        CURLOPT_HTTP_VERSION => CURL_HTTP_VERSION_1_1,
                                        CURLOPT_CUSTOMREQUEST => "POST",
                                        CURLOPT_POSTFIELDS => "[{\"emailAddress\":\"jane.doe@emaildomain.com\",\"firstname\":\"Jane\",\"lastname\":\"Doe\",\"custom1\":\"WA\",\"custom2\":\"Sales\",\"custom3\":\"EID987\",\"custom4\":\"\",\"custom5\":\"\",\"highCustomVariables\":{\"custom8\":\"Product A\",\"custom10\":\"Department X\"}},{\"emailAddress\":\"john.doe@emaildomain.com\",\"firstname\":\"John\",\"lastname\":\"Doe\",\"custom1\":\"WA\",\"custom2\":\"Sales\",\"custom3\":\"EID986\",\"custom4\":\"\",\"custom5\":\"\",\"highCustomVariables\":{\"custom8\":\"Product A\",\"custom10\":\"Department Z\"}}]",
                                        CURLOPT_HTTPHEADER => array(
                                        "Content-Type: application/json"
                                        ),
                                        ));
                                    
                                        $response = curl_exec($curl);
                                        $err = curl_error($curl);
                                    
                                        curl_close($curl);
                                    
                                        if ($err) {
                                        echo "cURL Error # :" . $err;
                                        } else {
                                        echo $response;
                                        }
                                        ?>
                    

Responses

arrow_rightExample
application/json

                        {
                            "response": [
                                {
                                    "addressID": 100000075,
                                    "emailAddress": "jane.doe@emaildomain.com",
                                    "firstname": "Jane",
                                    "lastname": "Doe",
                                    "emailListID": 1000002,
                                    "custom1": "WA",
                                    "custom2": "Sales",
                                    "custom3": "EID987",
                                    "custom4": "",
                                    "custom5": "",
                                    "creationDate": "Mon 23 Nov, 22:11:41 GMT 2020",
                                    "highCustomVariables": {
                                        "custom8": "Product A",
                                        "custom10": "Department X"
                                    }
                                },
                                {
                                    "addressID": 100000076,
                                    "emailAddress": "john.doe@emaildomain.com",
                                    "firstname": "John",
                                    "lastname": "Doe",
                                    "emailListID": 1000002,
                                    "custom1": "WA",
                                    "custom2": "Sales",
                                    "custom3": "EID986",
                                    "custom4": "",
                                    "custom5": "",
                                    "creationDate": "Mon 23 Nov, 22:11:41 GMT 2020",
                                    "highCustomVariables": {
                                        "custom8": "Product A",
                                        "custom10": "Department Z"
                                    }
                                }
                            ],
                            "requestID": "2012fedc-e8ce-48ae-b800-6q5ce287987a7dje"
                        }
                    
arrow_rightSchema
application/json
{
  "$schema": "http://json-schema.org/draft-06/schema# ",
  "type": "object",
  "properties": {
    "response": {
      "type": "array",
      "items": {
        "type": "object",
        "properties": {
          "emailAddress": {
            "type": "string",
            "format": "email"
          },
          "firstname": {
            "type": "string"
          },
          "highCustomVariables": {
            "type": "object",
            "properties": {
              "custom10": {
                "type": "string"
              },
              "custom8": {
                "type": "string"
              }
            },
            "additionalProperties": false,
            "required": [
              "custom10",
              "custom8"
            ]
          },
          "custom3": {
            "type": "string"
          },
          "custom4": {
            "type": "string"
          },
          "custom1": {
            "type": "string"
          },
          "custom2": {
            "type": "string"
          },
          "creationDate": {
            "type": "string"
          },
          "emailListID": {
            "type": "integer"
          },
          "custom5": {
            "type": "string"
          },
          "addressID": {
            "type": "integer"
          },
          "lastname": {
            "type": "string"
          }
        },
        "additionalProperties": false,
        "required": [
          "firstname",
          "highCustomVariables",
          "creationDate",
          "emailListID",
          "addressID",
          "lastname",
          "emailAddress",
          "custom3",
          "custom4",
          "custom1",
          "custom2",
          "custom5"
        ]
      }
    },
    "requestID": {
      "type": "string"
    }
  },
  "additionalProperties": false,
  "required": [
    "response",
    "requestID"
  ]
}
arrow_right400 example
application/json

{
    "response": {
     "error": {
         "docs": www.questionpro.com/api/error-codes.html
         "name": "BAD_REQUEST",
         "httpStatusCode": 400,
         "id" : "1000",
         "message": "Invalid URL parameters",
         "resourceUrl":"resource_url"
        }
    }
}
                                
arrow_rightSchema
application/json

{
  "$schema": "http://json-schema.org/draft-06/schema#                                 ",
  "type": "object",
  "properties": {
    "response": {
      "type": "object",
      "properties": {
        "error": {
          "type": "object",
          "properties": {
            "docs": {
              "type": "string"
            },
            "resourceUrl": {
              "type": "string"
            },
            "name": {
              "type": "string"
            },
            "id": {
              "type": "string"
            },
            "message": {
              "type": "string"
            },
            "httpStatusCode": {
              "type": "integer"
            }
          },
          "additionalProperties": false,
          "required": [
            "docs",
            "resourceUrl",
            "name",
            "id",
            "message",
            "httpStatusCode"
          ]
        }
      },
      "additionalProperties": false,
      "required": [
        "error"
      ]
    }
  },
  "additionalProperties": false,
  "required": [
    "response"
  ]
}
                                
arrow_right401 example
application/json

{
    "response": {
     "error": {
         "docs": www.questionpro.com/api/error-codes.html
         "name": "UNAUTHORIZED",
         "httpStatusCode": 401,
         "id" : "1010",
         "message": "Incorrect API Key",
         "resourceUrl":"resource_url"
        }
    }
}
						
							
arrow_rightSchema
application/json

{
  "$schema": "http://json-schema.org/draft-06/schema#                                 ",
  "type": "object",
  "properties": {
    "response": {
      "type": "object",
      "properties": {
        "error": {
          "type": "object",
          "properties": {
            "docs": {
              "type": "string"
            },
            "resourceUrl": {
              "type": "string"
            },
            "name": {
              "type": "string"
            },
            "id": {
              "type": "string"
            },
            "message": {
              "type": "string"
            },
            "httpStatusCode": {
              "type": "integer"
            }
          },
          "additionalProperties": false,
          "required": [
            "docs",
            "resourceUrl",
            "name",
            "id",
            "message",
            "httpStatusCode"
          ]
        }
      },
      "additionalProperties": false,
      "required": [
        "error"
      ]
    }
  },
  "additionalProperties": false,
  "required": [
    "response"
  ]
}
                                
arrow_right403 example
application/json

{
    "response": {
     "error": {
         "docs": www.questionpro.com/api/error-codes.html
         "name": "FORBIDDEN",
         "httpStatusCode": 403,
         "id" : "1013",
         "message": "The user does not have permission to access the resource",
         "resourceUrl":"resource_url"
        }
    }
}				
							
arrow_rightSchema
application/json

{
  "$schema": "http://json-schema.org/draft-06/schema#                                 ",
  "type": "object",
  "properties": {
    "response": {
      "type": "object",
      "properties": {
        "error": {
          "type": "object",
          "properties": {
            "docs": {
              "type": "string"
            },
            "resourceUrl": {
              "type": "string"
            },
            "name": {
              "type": "string"
            },
            "id": {
              "type": "string"
            },
            "message": {
              "type": "string"
            },
            "httpStatusCode": {
              "type": "integer"
            }
          },
          "additionalProperties": false,
          "required": [
            "docs",
            "resourceUrl",
            "name",
            "id",
            "message",
            "httpStatusCode"
          ]
        }
      },
      "additionalProperties": false,
      "required": [
        "error"
      ]
    }
  },
  "additionalProperties": false,
  "required": [
    "response"
  ]
}
                                
arrow_right404 example
application/json

{
    "response": {
     "error": {
         "docs": www.questionpro.com/api/error-codes.html
         "name": "NOT_FOUND",
         "httpStatusCode": 404,
         "id" : "1040",
         "message": "The resource that you're trying to access doesn't exist",
         "resourceUrl":"resource_url"
        }
    }
}
							
							
arrow_rightSchema
application/json

{
  "$schema": "http://json-schema.org/draft-06/schema#                                 ",
  "type": "object",
  "properties": {
    "response": {
      "type": "object",
      "properties": {
        "error": {
          "type": "object",
          "properties": {
            "docs": {
              "type": "string"
            },
            "resourceUrl": {
              "type": "string"
            },
            "name": {
              "type": "string"
            },
            "id": {
              "type": "string"
            },
            "message": {
              "type": "string"
            },
            "httpStatusCode": {
              "type": "integer"
            }
          },
          "additionalProperties": false,
          "required": [
            "docs",
            "resourceUrl",
            "name",
            "id",
            "message",
            "httpStatusCode"
          ]
        }
      },
      "additionalProperties": false,
      "required": [
        "error"
      ]
    }
  },
  "additionalProperties": false,
  "required": [
    "response"
  ]
}
                                
arrow_right500 example
application/json

{
    "response": {
     "error": {
         "docs": www.questionpro.com/api/error-codes.html
         "name": "INTERNAL_SERVER_ERROR",
         "httpStatusCode": 500,
         "id" : "1026",
         "message": "We are not able to process your request",
         "resourceUrl":"resource_url"
        }
    }
}
							
arrow_rightSchema
application/json

{
  "$schema": "http://json-schema.org/draft-06/schema#                                 ",
  "type": "object",
  "properties": {
    "response": {
      "type": "object",
      "properties": {
        "error": {
          "type": "object",
          "properties": {
            "docs": {
              "type": "string"
            },
            "resourceUrl": {
              "type": "string"
            },
            "name": {
              "type": "string"
            },
            "id": {
              "type": "string"
            },
            "message": {
              "type": "string"
            },
            "httpStatusCode": {
              "type": "integer"
            }
          },
          "additionalProperties": false,
          "required": [
            "docs",
            "resourceUrl",
            "name",
            "id",
            "message",
            "httpStatusCode"
          ]
        }
      },
      "additionalProperties": false,
      "required": [
        "error"
      ]
    }
  },
  "additionalProperties": false,
  "required": [
    "response"
  ]
}