From aca023a193feeac0c49d36bece8a285c48a6481e Mon Sep 17 00:00:00 2001 From: Derric Gilling Date: Thu, 2 May 2024 17:25:33 -0400 Subject: [PATCH 1/2] #187540291 Add: subscription_id, and cleanup extra fields --- source/includes/_overview.md | 8 + source/includes/collector-api/_actions-api.md | 19 +- .../includes/collector-api/_companies-api.md | 199 ++---------------- source/includes/collector-api/_events-api.md | 39 ++-- source/includes/collector-api/_overview.md | 1 - source/includes/collector-api/_users-api.md | 153 +------------- 6 files changed, 53 insertions(+), 366 deletions(-) diff --git a/source/includes/_overview.md b/source/includes/_overview.md index 998ea6c..24547cc 100644 --- a/source/includes/_overview.md +++ b/source/includes/_overview.md @@ -1,5 +1,13 @@ # Overview +### Data Model + +The Moesif data model includes two types of events (API Calls and Custom Actions) and three type of entities (Users, Companies, and Subscriptions). A full diagram is below. + +![Moesif Data Model](https://docs.moesif.com/images/illustration/product-data-model.svg) + +For more info, [view docs on Moesif data structure](https://www.moesif.com/docs/getting-started/overview/). + ## Filtering ### Query Params diff --git a/source/includes/collector-api/_actions-api.md b/source/includes/collector-api/_actions-api.md index c76348e..d90f70c 100644 --- a/source/includes/collector-api/_actions-api.md +++ b/source/includes/collector-api/_actions-api.md @@ -45,7 +45,6 @@ Replace YOUR_COLLECTOR_APPLICATION_ID with your real Application Id "user_id": "12345", "company_id": "67890", "transaction_id": "a3765025-46ec-45dd-bc83-b136c8d1d257", - "session_token": "XXXXX", "request": { "uri": "https://acmeinc.com/pricing", "user_agent_string": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36" @@ -62,7 +61,7 @@ Replace YOUR_COLLECTOR_APPLICATION_ID with your real Application Id curl -X POST https://api.moesif.net/v1/actions \ -H 'Content-Type: application/json' \ -H 'X-Moesif-Application-Id: YOUR_COLLECTOR_APPLICATION_ID' \ - -d '{"action_name":"Clicked Sign Up","user_id":"12345","company_id":"67890","session_token":"XXXXX","transaction_id": "a3765025-46ec-45dd-bc83-b136c8d1d257","request":{"uri":"https://acmeinc.com/pricing","user_agent_string":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"},"metadata":{"button_label":"Get Started","sign_up_method":"Google SSO"}}' + -d '{"action_name":"Clicked Sign Up","user_id":"12345","company_id":"67890","transaction_id": "a3765025-46ec-45dd-bc83-b136c8d1d257","request":{"uri":"https://acmeinc.com/pricing","user_agent_string":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"},"metadata":{"button_label":"Get Started","sign_up_method":"Google SSO"}}' ``` ```javascript--browser @@ -85,8 +84,9 @@ moesif.track('Clicked Sign Up', { transaction_id | string | false | A random 36 char UUID for this event. If set, Moesif will deduplicate events using this id and ensure idempotency. action_name | string | __true__ | A recognizable name such as Clicked Sign Up or Purchased Subscription session_token | string | false | The customer's current session token as a string. -user_id | string | false | The [user](#users) identifier to associate this action with. -company_id | string | false | The [company](#companies) identifier to associate this action with (Helpful for B2B companies). +user_id | string | false | Associate this API call to a [user](#users). Typically, a real person. +company_id | string | false | Associate this API call to a [company](#companies) (Required for metered billing). +subscription_id | string | false | Associate this API call to a specific [subscription](#subscriptions) of a company. Not needed unless same company can have multiple subscriptions to the same plan. metadata | object | false | An object containing any custom event metadata you want to store with this event. request |object | __true__ | The object containing the action's request context.

time

|string(date-time) | false | Timestamp for the action in ISO 8601 format. Set by server automatically if not set. @@ -143,7 +143,6 @@ Replace YOUR_COLLECTOR_APPLICATION_ID with your real Application Id "action_name": "Clicked Sign Up", "user_id": "12345", "company_id": "67890", - "session_token": "XXXXX", "transaction_id": "a3765025-46ec-45dd-bc83-b136c8d1d257", "request": { "uri": "https://acmeinc.com/pricing", @@ -158,7 +157,6 @@ Replace YOUR_COLLECTOR_APPLICATION_ID with your real Application Id "action_name": "Purchased Subscription", "user_id": "12345", "company_id": "67890", - "session_token": "XXXXX", "transaction_id": "a90cbabb-2dfc-4290-a368-48ce1a1af7ba", "request": { "uri": "https://acmeinc.com/pricing", @@ -177,7 +175,7 @@ Replace YOUR_COLLECTOR_APPLICATION_ID with your real Application Id curl -X POST https://api.moesif.net/v1/actions/batch \ -H 'Content-Type: application/json' \ -H 'X-Moesif-Application-Id: YOUR_COLLECTOR_APPLICATION_ID' \ - -d '[{"action_name":"Clicked Sign Up","user_id":"12345","company_id":"67890","session_token":"XXXXX","transaction_id": "a3765025-46ec-45dd-bc83-b136c8d1d257","request":{"uri":"https://acmeinc.com/pricing","user_agent_string":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"},"metadata":{"button_label":"Get Started","sign_up_method":"Google SSO"}},{"action_name":"Purchased Subscription","user_id":"12345","company_id":"67890","session_token":"XXXXX","transaction_id": "a90cbabb-2dfc-4290-a368-48ce1a1af7ba","request":{"uri":"https://acmeinc.com/pricing","user_agent_string":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"},"metadata":{"plan_name":"Pay As You Go","plan_revenue":5000}}]' + -d '[{"action_name":"Clicked Sign Up","user_id":"12345","company_id":"67890","transaction_id": "a3765025-46ec-45dd-bc83-b136c8d1d257","request":{"uri":"https://acmeinc.com/pricing","user_agent_string":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"},"metadata":{"button_label":"Get Started","sign_up_method":"Google SSO"}},{"action_name":"Purchased Subscription","user_id":"12345","company_id":"67890","transaction_id": "a90cbabb-2dfc-4290-a368-48ce1a1af7ba","request":{"uri":"https://acmeinc.com/pricing","user_agent_string":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.77 Safari/537.36"},"metadata":{"plan_name":"Pay As You Go","plan_revenue":5000}}]' ``` ```javascript--browser @@ -197,11 +195,12 @@ moesif.track('Clicked Sign Up', { |Name|Type|Required|Description| |-----------|-----------|-----------|-----------| -transaction_id | string | false | A random 36 char UUID for this event. If set, Moesif will deduplicate events using this id and ensure idempotency. Moesif will still deduplicate even accross different size batches. +transaction_id | string | false | A random 36 char UUID for this event. If set, Moesif will deduplicate events using this id and ensure idempotency. Moesif will still deduplicate even across different size batches. action_name | string | __true__ | A recognizable name such as Clicked Sign Up or Purchased Subscription session_token | string | false | The customer's current session token as a string. -user_id | string | false | The [user](#users) identifier to associate this action with. -company_id | string | false | The [company](#companies) identifier to associate this action with (Helpful for B2B companies). +user_id | string | false | Associate this API call to a [user](#users). Typically, a real person. +company_id | string | false | Associate this API call to a [company](#companies) (Required for metered billing). +subscription_id | string | false | Associate this API call to a specific [subscription](#subscriptions) of a company. Not needed unless same company can have multiple subscriptions to the same plan. metadata | object | false | An object containing any custom event metadata you want to store with this event. request |object | __true__ | The object containing the action's request context.

time

|string(date-time) | false | Timestamp for the action in ISO 8601 format. Set by server automatically if not set. diff --git a/source/includes/collector-api/_companies-api.md b/source/includes/collector-api/_companies-api.md index 1180523..fc92967 100644 --- a/source/includes/collector-api/_companies-api.md +++ b/source/includes/collector-api/_companies-api.md @@ -4,13 +4,14 @@ **`POST https://api.moesif.net/v1/companies`** -Updates a company profile in Moesif. A company can be an enterprise account or a group of [users](#update-a-user) accessing the API. -Adding company metadata enables you to understand API usage across different cohorts, -company demographics, acquisition channels, etc. +Updates a company profile in Moesif. A company is your direct customer paying for your service. A company can have one or more [users](#update-a-user) and one or more [subscriptions](#update-a-subscription). [More info on the Moesif data model](https://www.moesif.com/docs/getting-started/overview/). -Any custom company properties can be stored via the `metadata` object. -You can also set the company's website domain which enables Moesif to automatically your company profiles -with publicly available information. +You can save custom properties to a company via the `metadata` object. While optional, it's also recommended to set the `company_domain`. When set, Moesif will enrich the company with publicly available information. + +If company does not exist, a new one will be created. +If a company exists, it will be merged on top of existing fields. +Any new field set will override the existing fields. +This is done via recursive merge which merges inner objects. #### Create vs update If the company does not exist, Moesif will create a new one. @@ -38,13 +39,6 @@ will automatically associate the user with the company. { "company_id": "12345", "company_domain": "acmeinc.com", - "campaign": { - "utm_source": "google", - "utm_medium": "cpc", - "utm_campaign": "adwords", - "utm_term": "api+tooling", - "utm_content": "landing" - }, "metadata": { "org_name": "Acme, Inc", "plan_name": "Free", @@ -56,13 +50,12 @@ will automatically associate the user with the company. } } } - ``` ```shell # You can also use wget curl -X POST https://api.moesif.net/v1/companies \ - -d '{"company_id":"12345","company_domain":"acmeinc.com","campaign":{"utm_source":"google","utm_medium":"cpc","utm_campaign":"adwords","utm_term":"api+tooling","utm_content":"landing"},"metadata":{"org_name":"Acme, Inc","plan_name":"Free","deal_stage":"Lead","mrr":24000,"demographics":{"alexa_ranking":500000,"employee_count":47}}}' \ + -d '{"company_id":"12345","company_domain":"acmeinc.com","metadata":{"org_name":"Acme, Inc","plan_name":"Free","deal_stage":"Lead","mrr":24000,"demographics":{"alexa_ranking":500000,"employee_count":47}}}' \ -H 'Accept: application/json' \ -H 'X-Moesif-Application-Id: YOUR_COLLECTOR_APPLICATION_ID' ``` @@ -75,19 +68,10 @@ moesifapi.configuration.ApplicationId = "YOUR_COLLECTOR_APPLICATION_ID"; // Only companyId is required. -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema // metadata can be any custom object var company = { companyId: '67890', companyDomain: 'acmeinc.com', // If domain is set, Moesif will enrich your profiles with publicly available info - campaign: { - utmSource: 'google', - utmMedium: 'cpc', - utmCampaign: 'adwords', - utmTerm: 'api+tooling', - utmContent: 'landing' - }, metadata: { orgName: 'Acme, Inc', planName: 'Free Plan', @@ -112,19 +96,10 @@ from moesifapi.models import * api_client = MoesifAPIClient("YOUR_COLLECTOR_APPLICATION_ID").api # Only company_id is required. -# Campaign object is optional, but useful if you want to track ROI of acquisition channels -# See https://www.moesif.com/docs/api#update-a-company for campaign schema # metadata can be any custom object company = { 'company_id': '12345', 'company_domain': 'acmeinc.com', # If domain is set, Moesif will enrich your profiles with publicly available info - 'campaign': { - 'utm_source': 'google', - 'utm_medium': 'cpc', - 'utm_campaign': 'adwords', - 'utm_term': 'api+tooling', - 'utm_content': 'landing' - }, 'metadata': { 'org_name': 'Acme, Inc', 'plan_name': 'Free', @@ -154,21 +129,11 @@ metadata => { } } -# Campaign object is optional, but useful if you want to track ROI of acquisition channels -# See https://www.moesif.com/docs/api#update-a-company for campaign schema -campaign = CampaignModel.new() -campaign.utm_source = "google" -campaign.utm_medium = "cpc" -campaign.utm_campaign = "adwords" -campaign.utm_term = "api+tooling" -campaign.utm_content = "landing" - # Only company_id is required. # metadata can be any custom object company = CompanyModel.new() company.company_id = "67890" company.company_domain = "acmeinc.com" # If domain is set, Moesif will enrich your profiles with publicly available info -company.campaign = campaign company.metadata = metadata update_company = api_client.update_company(company) @@ -184,20 +149,10 @@ require_once "vendor/autoload.php"; use MoesifApi\MoesifApiClient; $apiClient = new MoesifApiClient("YOUR_COLLECTOR_APPLICATION_ID")->getApi(); -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema -$campaign = new Models\CampaignModel(); -$campaign->utmSource = "google"; -$campaign->utmCampaign = "cpc"; -$campaign->utmMedium = "adwords"; -$campaign->utmContent = "api+tooling"; -$campaign->utmTerm = "landing"; - $company = new Models\CompanyModel(); $company->companyId = "67890"; $company->companyDomain = "acmeinc.com"; -$company->campaign = $campaign; // metadata can be any custom object $company->metadata = array( @@ -220,16 +175,6 @@ import "github.com/moesif/moesifapi-go/models" apiClient := moesifapi.NewAPI("YOUR_COLLECTOR_APPLICATION_ID") -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema -campaign := models.CampaignModel { - UtmSource: "google", - UtmMedium: "cpc", - UtmCampaign: "adwords", - UtmTerm: "api+tooling", - UtmContent: "landing", -} - // metadata can be any custom dictionary metadata := map[string]interface{}{ "org_name", "Acme, Inc", @@ -246,7 +191,6 @@ metadata := map[string]interface{}{ company := models.CompanyModel{ CompanyId: "67890", // The only required field is your company id CompanyDomain: "acmeinc.com", // If domain is set, Moesif will enrich your profiles with publicly available info - Campaign: &campaign, Metadata: &metadata, } @@ -260,17 +204,6 @@ err := apiClient.UpdateCompany(&company) ```csharp var apiClient = new MoesifApiClient("YOUR_COLLECTOR_APPLICATION_ID").Api;; -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#companies for campaign schema -var campaign = new CampaignModel() -{ - UtmSource = "google", - UtmMedium = "cpc" - UtmCampaign = "adwords" - UtmTerm = "api+tooling" - UtmContent = "landing" -}; - // metadata can be any custom dictionary var metadata = new Dictionary { @@ -289,7 +222,6 @@ var company = new CompanyModel() { CompanyId = "67890", CompanyDomain = "acmeinc.com", // If domain is set, Moesif will enrich your profiles with publicly available info - Campaign = campaign, Metadata = metadata }; @@ -303,22 +235,11 @@ apiClient.UpdateCompany(company); ```java MoesifAPIClient apiClient = new MoesifAPIClient("YOUR_COLLECTOR_APPLICATION_ID").Api; -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema -CampaignModel campaign = new CampaignBuilder() - .utmSource("google") - .utmCampaign("cpc") - .utmMedium("adwords") - .utmTerm("api+tooling") - .utmContent("landing") - .build(); - // Only companyId is required // metadata can be any custom object CompanyModel company = new CompanyBuilder() .companyId("67890") .companyDomain("acmeinc.com") // If set, Moesif will enrich your profiles with publicly available info - .campaign(campaign) .metadata(APIHelper.deserialize("{" + "\"org_name\": \"Acme, Inc\"," + "\"plan_name\": \"Free\"," + @@ -403,8 +324,9 @@ Updates a list of companies profile in Moesif. A custom JSON object can be placed in the `metadata` object of each company which will be stored as part of the company profile. -While optional, you can set the `company_domain` field which enables Moesif -to enrich your company profiles with stuff like company logo. +A company is your direct customer paying for your service. A company can have one or more [users](#update-a-user) and one or more [subscriptions](#update-a-subscription). [More info on the Moesif data model](https://www.moesif.com/docs/getting-started/overview/). + +You can save custom properties to a company via the `metadata` object. While optional, it's also recommended to set the `company_domain`. When set, Moesif will enrich the company with publicly available information. If company does not exist, a new one will be created. If a company exists, it will be merged on top of existing fields. @@ -424,13 +346,6 @@ Replace my_application_id with your real Application Id { "company_id": "12345", "company_domain": "acmeinc.com", - "campaign": { - "utm_source": "google", - "utm_medium": "cpc", - "utm_campaign": "adwords", - "utm_term": "api+tooling", - "utm_content": "landing" - }, "metadata": { "org_name": "Acme, Inc", "plan_name": "Free", @@ -445,11 +360,6 @@ Replace my_application_id with your real Application Id { "company_id": "54321", "company_domain": "contoso.com", - "campaign": { - "utm_source": "facebook", - "utm_medium": "dislay", - "utm_campaign": "retargeting" - }, "metadata": { "org_name": "Contoso, Inc", "plan_name": "Paid", @@ -467,7 +377,7 @@ Replace my_application_id with your real Application Id ```shell # You can also use wget curl -X POST https://api.moesif.net/v1/companies/batch \ - -d '[{"company_id":"12345","company_domain":"acmeinc.com","campaign":{"utm_source":"google","utm_medium":"cpc","utm_campaign":"adwords","utm_term":"api+tooling","utm_content":"landing"},"metadata":{"org_name":"Acme, Inc","plan_name":"Free","deal_stage":"Lead","mrr":24000,"demographics":{"alexa_ranking":500000,"employee_count":47}}},{"company_id":"54321","company_domain":"contoso.com","campaign":{"utm_source":"facebook","utm_medium":"dislay","utm_campaign":"retargeting"},"metadata":{"org_name":"Contoso, Inc","plan_name":"Paid","deal_stage":"Lead","mrr":48000,"demographics":{"alexa_ranking":500000,"employee_count":47}}}]' \ + -d '[{"company_id":"12345","company_domain":"acmeinc.com","metadata":{"org_name":"Acme, Inc","plan_name":"Free","deal_stage":"Lead","mrr":24000,"demographics":{"alexa_ranking":500000,"employee_count":47}}},{"company_id":"54321","company_domain":"contoso.com","metadata":{"org_name":"Contoso, Inc","plan_name":"Paid","deal_stage":"Lead","mrr":48000,"demographics":{"alexa_ranking":500000,"employee_count":47}}}]' \ -H 'Accept: application/json' \ -H 'X-Moesif-Application-Id: YOUR_COLLECTOR_APPLICATION_ID' ``` @@ -480,19 +390,10 @@ moesifapi.configuration.ApplicationId = "YOUR_COLLECTOR_APPLICATION_ID"; // Only companyId is required. -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema // metadata can be any custom object var companies = [{ companyId: '67890', companyDomain: 'acmeinc.com', // If domain is set, Moesif will enrich your profiles with publicly available info - campaign: { - utmSource: 'google', - utmMedium: 'cpc', - utmCampaign: 'adwords', - utmTerm: 'api+tooling', - utmContent: 'landing' - }, metadata: { orgName: 'Acme, Inc', planName: 'Free Plan', @@ -507,11 +408,6 @@ var companies = [{ { companyId: '09876', companyDomain: 'contoso.com', // If domain is set, Moesif will enrich your profiles with publicly available info - campaign: { - utmSource: 'facebook', - utmMedium: 'cpc', - utmCampaign: 'retargeting' - }, metadata: { orgName: 'Contoso, Inc', planName: 'Paid Plan', @@ -537,19 +433,10 @@ from moesifapi.models import * api_client = MoesifAPIClient("YOUR_COLLECTOR_APPLICATION_ID").api # Only company_id is required. -# Campaign object is optional, but useful if you want to track ROI of acquisition channels -# See https://www.moesif.com/docs/api#update-a-company for campaign schema # metadata can be any custom object companies = [{ 'company_id': '67890', 'company_domain': 'acmeinc.com', # If domain is set, Moesif will enrich your profiles with publicly available info - 'campaign': { - 'utm_source': 'google', - 'utm_medium': 'cpc', - 'utm_campaign': 'adwords', - 'utm_term': 'api+tooling', - 'utm_content': 'landing' - }, 'metadata': { 'org_name': 'Acme, Inc', 'plan_name': 'Free', @@ -564,11 +451,6 @@ companies = [{ { 'company_id': '09876', 'company_domain': 'contoso.com', # If domain is set, Moesif will enrich your profiles with publicly available info - 'campaign': { - 'utm_source': 'facebook', - 'utm_medium': 'cpc', - 'utm_campaign': 'retargeting' - }, 'metadata': { 'org_name': 'Contoso, Inc', 'plan_name': 'Paid', @@ -600,21 +482,11 @@ metadata => { } } -# Campaign object is optional, but useful if you want to track ROI of acquisition channels -# See https://www.moesif.com/docs/api#update-a-company for campaign schema -campaign = CampaignModel.new() -campaign.utm_source = "google" -campaign.utm_medium = "cpc" -campaign.utm_campaign = "adwords" -campaign.utm_term = "api+tooling" -campaign.utm_content = "landing" - # Only company_id is required. # metadata can be any custom object company = CompanyModel.new() company.company_id = "67890" company.company_domain = "acmeinc.com" # If domain is set, Moesif will enrich your profiles with publicly available info -company.campaign = campaign company.metadata = metadata companies << company @@ -632,20 +504,9 @@ require_once "vendor/autoload.php"; use MoesifApi\MoesifApiClient; $apiClient = new MoesifApiClient("YOUR_COLLECTOR_APPLICATION_ID")->getApi(); -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema -$campaignA = new Models\CampaignModel(); -$campaignA->utmSource = "google"; -$campaignA->utmCampaign = "cpc"; -$campaignA->utmMedium = "adwords"; -$campaignA->utmContent = "api+tooling"; -$campaignA->utmTerm = "landing"; - - $companyA = new Models\CompanyModel(); $companyA->companyId = "67890"; $companyA->companyDomain = "acmeinc.com"; -$companyA->campaign = $campaign; // metadata can be any custom object $companyB->metadata = array( @@ -662,7 +523,6 @@ $companyB->metadata = array( $companyB = new Models\CompanyModel(); $companyB->companyId = "67890"; $companyB->companyDomain = "acmeinc.com"; -$companyB->campaign = $campaign; // metadata can be any custom object $companyB->metadata = array( @@ -688,16 +548,6 @@ apiClient := moesifapi.NewAPI("YOUR_COLLECTOR_APPLICATION_ID") // List of Companies var companies []*models.CompanyModel - -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema -campaign := models.CampaignModel { - UtmSource: "google", - UtmMedium: "cpc", - UtmCampaign: "adwords", - UtmTerm: "api+tooling", - UtmContent: "landing", -} // metadata can be any custom dictionary metadata := map[string]interface{}{ @@ -715,7 +565,6 @@ metadata := map[string]interface{}{ companyA := models.CompanyModel{ CompanyId: "67890", // The only required field is your company id CompanyDomain: "acmeinc.com", // If domain is set, Moesif will enrich your profiles with publicly available info - Campaign: &campaign, Metadata: &metadata, } @@ -733,17 +582,6 @@ var apiClient = new MoesifApiClient("YOUR_COLLECTOR_APPLICATION_ID").Api;; var companies = new List(); -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#companies for campaign schema -var campaignA = new CampaignModel() -{ - UtmSource = "google", - UtmMedium = "cpc" - UtmCampaign = "adwords" - UtmTerm = "api+tooling" - UtmContent = "landing" -}; - // metadata can be any custom dictionary var metadataA = new Dictionary { @@ -762,7 +600,6 @@ var companyA = new CompanyModel() { CompanyId = "67890", CompanyDomain = "acmeinc.com", // If domain is set, Moesif will enrich your profiles with publicly available info - Campaign = campaign, Metadata = metadata }; @@ -784,7 +621,6 @@ var companyB = new CompanyModel() { CompanyId = "09876", CompanyDomain = "contoso.com", // If domain is set, Moesif will enrich your profiles with publicly available info - Campaign = campaign, Metadata = metadata }; @@ -802,22 +638,11 @@ apiClient.UpdateCompaniesBatch(companies); ```java MoesifAPIClient apiClient = new MoesifAPIClient("YOUR_COLLECTOR_APPLICATION_ID").Api; -// Campaign object is optional, but useful if you want to track ROI of acquisition channels -// See https://www.moesif.com/docs/api#update-a-company for campaign schema -CampaignModel campaign = new CampaignBuilder() - .utmSource("google") - .utmCampaign("cpc") - .utmMedium("adwords") - .utmTerm("api+tooling") - .utmContent("landing") - .build(); - // Only companyId is required // metadata can be any custom object CompanyModel company = new CompanyBuilder() .companyId("67890") .companyDomain("acmeinc.com") // If set, Moesif will enrich your profiles with publicly available info - .campaign(campaign) .metadata(APIHelper.deserialize("{" + "\"org_name\": \"Acme, Inc\"," + "\"plan_name\": \"Free\"," + diff --git a/source/includes/collector-api/_events-api.md b/source/includes/collector-api/_events-api.md index 47bdc43..fb454f7 100644 --- a/source/includes/collector-api/_events-api.md +++ b/source/includes/collector-api/_events-api.md @@ -4,8 +4,8 @@ **`POST https://api.moesif.net/v1/events`** -Log a single API call to Moesif. -The request payload is a single API event model containing the API request, the API response, and any custom event metadata. +Log a single API call to Moesif as an event. +The request payload is a single API event containing the API request, the API response, and any custom event metadata.