From d5fe7a5881f68b274e6e310e57dc2a5834248e30 Mon Sep 17 00:00:00 2001 From: myronkaifung <97630035+myronkaifung@users.noreply.github.com> Date: Wed, 15 Jan 2025 14:45:57 -0800 Subject: [PATCH] Add IP query param to group and engage endpoints (#1719) * add ip value as a query param for engage and group endpoints * grammar * set default value in playground to 0, but clarify that default behavior is 1 --------- Co-authored-by: Myron Fung --- openapi/src/common/ingestion-api.yaml | 12 +++++++++++- openapi/src/ingestion.openapi.yaml | 20 ++++++++++++++++++++ 2 files changed, 31 insertions(+), 1 deletion(-) diff --git a/openapi/src/common/ingestion-api.yaml b/openapi/src/common/ingestion-api.yaml index c169c139d5..2be62041d7 100644 --- a/openapi/src/common/ingestion-api.yaml +++ b/openapi/src/common/ingestion-api.yaml @@ -61,4 +61,14 @@ OptionalRequestParameter: schema: $ref: ./schemas.yaml#/IntegerPropertyAsBooleanFlag description: >- - If present and equal to 1, Mixpanel will validate the provided records and return a JSON object with per-record error messages for records that fail validation. \ No newline at end of file + If present and equal to 1, Mixpanel will validate the provided records and return a JSON object with per-record error messages for records that fail validation. + IP: + in: query + name: ip + required: false + schema: + $ref: ./schemas.yaml#/IntegerPropertyAsBooleanFlag + default: 0 + description: >- + If present and equal to 0, Mixpanel will not perform geolocation parsing using the IP address of the request. We recommend setting the ip to "0" when making requests from the server-side to prevent the unintentional effect of overwriting your profile's geolocation with your server location. + Defaults to 1 which would use the IP address of the request to update profile geolocation. \ No newline at end of file diff --git a/openapi/src/ingestion.openapi.yaml b/openapi/src/ingestion.openapi.yaml index 736a094719..0f95974621 100644 --- a/openapi/src/ingestion.openapi.yaml +++ b/openapi/src/ingestion.openapi.yaml @@ -193,6 +193,7 @@ paths: it does exist, it sets the properties to these values, overwriting existing values. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -236,6 +237,7 @@ paths: Works just like "$set", except it will not overwrite existing property values. This is useful for properties like "First login date". parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -284,6 +286,7 @@ paths: negative values. This is useful for maintaining the values of properties like "Number of Logins" or "Files Uploaded". parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -329,6 +332,7 @@ paths: Adds the specified values to a list property on a user profile and ensures that those values only appear once. The profile is created if it does not exist. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -385,6 +389,7 @@ paths: property that doesn't exist will result in assigning a list with one element to that property. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -429,6 +434,7 @@ paths: is removed from the existing list on the user profile. If it does not exist, no updates are made. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -472,6 +478,7 @@ paths: Takes a JSON list of string property names, and permanently removes the properties and their values from a profile. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -524,6 +531,7 @@ paths: Refer to the respective user profile update commands ($set, $set_once, $add, $union, $append, $remove, $unset, and $delete) on syntax for their parameters. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/JavascriptWithCallback @@ -625,6 +633,8 @@ paths: summary: Update Property description: Updates or adds properties to a group profile. The profile is created if it does not exist. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose requestBody: required: true @@ -668,6 +678,8 @@ paths: summary: Set Property Once description: Adds properties to a group only if the property is not already set. The profile is created if it does not exist. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose requestBody: required: true @@ -711,6 +723,8 @@ paths: summary: Delete Property description: Unsets specific properties on the group profile. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose requestBody: required: true @@ -758,6 +772,8 @@ paths: summary: Remove from List Property description: Removes a specific value in a list property. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose requestBody: required: true @@ -803,6 +819,8 @@ paths: Adds the specified values to a list property on a group profile and ensures that those values only appear once. The profile is created if it does not exist. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose requestBody: required: true @@ -864,6 +882,8 @@ paths: Refer to the respective group profile update commands ($set, $set_once, $add, $union, $remove, $unset, and $delete) on syntax for their parameters. parameters: + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/IP + - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Strict - $ref: ./common/ingestion-api.yaml#/OptionalRequestParameter/ResponseType/Verbose requestBody: required: true