Hubspot Connector - Source Code
<?xml version="1.0" encoding="utf-8"?>
<ApiConfig Name="Hubspot"
Slug="hubspot-connector"
Id="125a72f8-ba3c-430a-96a6-41b6507dfc43"
EngineVersion="12"
Version="5"
Desc="Hubspot Connector can be used to integrate Hubspot and your data source, e.g. Microsoft SQL Server, Oracle, Excel, Power BI, etc. Get, write, delete Hubspot data in a few clicks!"
Logo=""
>
<VersionHistory>
<Change Ver="5" Date="2024-12-10">Added images to authentication instructions</Change>
<Change Date="2023-07-07">Added upload_file endpoint</Change>
<Change Date="2022-12-08">Added error retry on status code 429</Change>
<Change Date="2022-12-08">Added new endpoints for Quotes</Change>
<Change Date="2022-12-08">Added search endpoints for companies, contacts, deals, tickets, products and lineitems. You can search by filter expressions</Change>
<Change Date="2022-10-04">Added support for private app authentication (Using static AccessToken)</Change>
<Change Date="2021-10-19">Added "Get Owners" endpoint.</Change>
<Change Date="2021-09-30">Initial version</Change>
</VersionHistory>
<ServiceUrls>
<ServiceUrl Name="Hubspot API" Url="https://api.hubapi.com" />
</ServiceUrls>
<Auths>
<Auth Type="HTTP" Name="PrivateApp" Label="Private app (Static Access Token)"
Desc="Private apps allow you to use HubSpot's APIs to access specific data from your HubSpot account.
You can authorize what each private app can request or change in your account, which will generate an access token that's unique to your app."
TODO_Desc="Authenticate using static AccessToken (Private app) to access specific account. Follow 3 simple steps. 1) Create an App, 2) select permissions and 3) get Token and use on this UI. For more information on how to obtain AccessToken visit https://developers.hubspot.com/docs/api/private-apps"
HelpLink="https://developers.hubspot.com/docs/api/private-apps"
TestEndPoint="get_contact_properties" ConnStr="CredentialType=Token;">
<Notes>
<![CDATA[
<p>
Follow these instructions to create a Private app in HubSpot and configure HubSpot authentication in SSIS package or ODBC data source:
<p/>
<ol>
<li>
First of all, go to <a target="_blank" href="https://app.hubspot.com">HubSpot portal</a>.
</li>
<li>
Then click <strong>Data Management</strong> option on the left
and then hit <strong>Integrations</strong> menu item:
<img src="https://cdn.zappysys.com/api/images/authentication/hubspot/Private-App/go-to-integrations-in-hubspot.png"
loading="lazy"
decoding="async"
class="img-thumbnail block"
alt="Go to integrations in HubSpot"
title="Going to integrations in HubSpot"
width="1000"
height="790" />
</li>
<li>
Move on by clicking <strong>Private Apps</strong> menu item
and then click <strong>Create a private app</strong> button to create one:
<img src="https://cdn.zappysys.com/api/images/authentication/hubspot/Private-App/create-private-app-to-get-hubspot-data-via-rest-api.png"
loading="lazy"
decoding="async"
class="img-thumbnail block"
alt="Create private app to get HubSpot data via REST API"
title="Creating private app to get HubSpot data via REST API"
width="1000"
height="700" />
</li>
<li>
Then continue by following the instructions on <a target="_blank" href="https://developers.hubspot.com/beta-docs/guides/apps/private-apps/overview#create-a-private-app">HubSpot Docs</a>.
</li>
<li>
Once you create an app, go to SSIS package or ODBC data source and in <strong>Private App</strong> authentication set these parameters:
<ul>
<li>For <strong>AccessToken</strong> field use <strong>Access token</strong> value from the Private app configuration in HubSpot.</li>
</ul>
</li>
<li>
Done! Now you are ready to use HubSpot Connector!
</li>
</ol>
]]>
</Notes>
<Params>
<Param Name="Password" Label="AccessToken" Type="Property" Secret="True" Required="True" />
<Param Name="RetryMode" Value="RetryWhenStatusCodeMatch" Options="None;RetryAny;RetryWhenStatusCodeMatch;" Hidden="True" />
<Param Name="RetryStatusCodeList" Value="429" Hidden="True" />
<Param Name="RetryCountMax" Value="5" Hidden="True" />
<Param Name="RetryMultiplyWaitTime" Value="True" Hidden="True" />
</Params>
</Auth>
<Auth Type="OAuth" Name="UserCreds" Label="Public app"
Desc="In HubSpot, a public app is a type of integration that can be installed on customer accounts or listed on the App Marketplace.
It requires authentication via OAuth. Once a user installs your app on their HubSpot account, you’ll be able to make API calls to that account using an OAuth access token."
HelpLink="https://developers.hubspot.com/docs/api/creating-an-app"
ConnStr="Provider=HubSpot;OAuthVersion=OAuth2;ScopeSeparator={space};GrantType=Default;Scope=[$Scope$];ScopeSeparator={space};ContentType=application/x-www-form-urlencoded;ClientId=[$ClientId$];ClientSecret=[$ClientSecret$];"
TestEndpoint="get_contact_properties">
<Notes>
<![CDATA[
<p>
Follow these instructions to create a Public app in HubSpot and configure HubSpot authentication in SSIS package or ODBC data source:
<p/>
<ol>
<li>
First of all, if you don't have HubSpot Developer's account, <a href="https://app.hubspot.com/signup/developers">register one</a>.
</li>
<li>
Go to <a href="https://app.hubspot.com">HubSpot</a> and select your Developer account.
</li>
<li>
Click <strong>Apps</strong> on the left hand side and then click <strong>Create app</strong> button to create a Public app:
<img src="https://cdn.zappysys.com/api/images/authentication/hubspot/OAuth/create-public-app-to-get-hubspot-data-via-rest-api.png"
loading="lazy"
decoding="async"
class="img-thumbnail block"
alt="Create public app to get HubSpot data via REST API"
title="Creating public app to get HubSpot data via REST API"
width="1000"
height="350" />
</li>
<li>
Then continue by following the instructions in <a target="_blank" href="https://developers.hubspot.com/beta-docs/guides/apps/public-apps/overview#create-a-public-app">HubSpot Docs</a>.
<div class="alert alert-info">
<strong>NOTE:</strong>
If you don't have a working Redirect URL, you can use <code>https://zappysys.com/oauth</code> (it's safe).
</p>
</li>
<li>
Once you create an app, go to SSIS package or ODBC data source
and in <strong>Public app</strong> authentication set these parameters
(use values from your Public app configuration in HubSpot):
<ul>
<li>For <strong>ClientId</strong> field use <strong>Client ID</strong> value.</li>
<li>For <strong>ClientSecret</strong> field use <strong>Client secret</strong> value.</li>
<li>
For <strong>Scope</strong> field use <strong>Scopes</strong> values, e.g.:
<pre>accounting
tickets
files
crm.lists.read
crm.lists.write
crm.objects.contacts.read
crm.objects.contacts.write
crm.schemas.contacts.read
crm.objects.custom.read
crm.objects.custom.write
crm.schemas.custom.read
crm.objects.companies.read
crm.objects.companies.write
crm.schemas.companies.read
crm.objects.deals.read
crm.objects.deals.write
crm.schemas.deals.read
crm.objects.quotes.read
crm.objects.quotes.write
crm.schemas.quotes.read
crm.objects.line_items.read
crm.objects.line_items.write
crm.schemas.line_items.read
</pre>
<div class="alert alert-info">
<strong>NOTE:</strong>
You can use other scopes too, but they <strong>must</strong> match the scopes defined in your Public app.
</p>
</li>
<li>For <strong>ReturnUrl</strong> field use one of <strong>Redirect URLs</strong>.</li>
</ul>
</li>
<li>
When you are done with that, click <strong>Generate Token</strong> button to generate Access and Refresh Tokens.
</li>
<li>
Done! Now you are ready to use HubSpot Connector!
</li>
</ol>
]]>
</Notes>
<Params>
<Param Name="UseCustomApp" Value="True" Required="True" Hidden="False" Desc="Use your own app credentials or inbuilt app provided by ZappySys for ease of use. If you choose UseCustomApp=true then make sure to obtain your own ClientId and Secret using steps provided (Click [Steps to Configure] link found next to Authentication Type dropdown)" />
<Param Name="ClientId" Label="Client ID" VisibleIf="UseCustomApp" RequiredIf="UseCustomApp==true"/>
<Param Name="ClientSecret" Label="Client Secret" VisibleIf="UseCustomApp" RequiredIf="UseCustomApp==true" Secret="True"/>
<Param Name="Scope"
Label="Scope (Must Match with App Scopes)"
Required="True"
Options="account-info.security.read;accounting;actions;automation;business-intelligence;cms.domains.read;cms.domains.write;communication_preferences.read;communication_preferences.read_write;communication_preferences.write;content;conversations.read;conversations.write;crm.export;crm.import;crm.lists.read;crm.lists.write;crm.objects.companies.read;crm.objects.companies.write;crm.objects.contacts.read;crm.objects.contacts.write;crm.objects.custom.read;crm.objects.custom.write;crm.objects.deals.read;crm.objects.deals.write;crm.objects.line_items.read;crm.objects.line_items.write;crm.objects.marketing_events.read;crm.objects.marketing_events.write;crm.objects.owners.read;crm.objects.quotes.read;crm.objects.quotes.write;crm.schemas.companies.read;crm.schemas.contacts.read;crm.schemas.contacts.write;crm.schemas.custom.read;crm.schemas.custom.write;crm.schemas.deals.read;crm.schemas.deals.write;crm.schemas.line_items.read;crm.schemas.quotes.read;e-commerce;files;files.ui_hidden.read;forms;forms-uploaded-files;integration-sync;media_bridge.read;media_bridge.write;oauth;sales-email-read;settings.users.read;settings.users.teams.read;settings.users.teams.write;settings.users.write;tickets;timeline;"
MultiSelectSeparator=" "
MultiSelect="True"
Value="accounting~files~crm.lists.read~crm.lists.write~crm.objects.companies.read~crm.objects.companies.write~crm.objects.contacts.read~crm.objects.contacts.write~crm.objects.custom.read~crm.objects.custom.write~crm.objects.deals.read~crm.objects.deals.write~crm.objects.line_items.read~crm.objects.line_items.write~crm.objects.quotes.read~crm.objects.quotes.write~crm.schemas.companies.read~crm.schemas.contacts.read~crm.schemas.custom.read~crm.schemas.deals.read~crm.schemas.line_items.read~crm.schemas.quotes.read~tickets"
Desc="Permissions you want to use."
Example="contacts~tickets"
HelpLink=""/>
<Param Name="ReturnUrl" Options="https://zappysys.com/oauth"/>
<Param Name="RetryMode" Value="RetryWhenStatusCodeMatch" Options="None;RetryAny;RetryWhenStatusCodeMatch;" Hidden="True" />
<Param Name="RetryStatusCodeList" Value="429" Hidden="True" />
<Param Name="RetryCountMax" Value="5" Hidden="True" />
<Param Name="RetryMultiplyWaitTime" Value="True" Hidden="True" />
</Params>
</Auth>
<Auth Type="HTTP" Name="Token" Label="Developer API key (Deprecated)"
Desc="Deprecated authentication method. Use [Private app] instead."
HelpLink="https://developers.hubspot.com/beta-docs/guides/apps/authentication/intro-to-auth"
TestEndPoint="get_contact_properties" ConnStr="">
<Notes>
<![CDATA[
<p>
Using HubSpot API key is <strong>deprecated</strong> method for authentication. Use <strong>Private app</strong> authentication instead. If you still need one, then follow these instructions to get HubSpot API key:
<p/>
<ul>
<li>
First of all, if you don't have HubSpot Developer's account, <a href="https://app.hubspot.com/signup/developers">register one</a>.
</li>
<li>
Go to <a href="https://app.hubspot.com">HubSpot</a> and select your Developer account.
</li>
<li>
Click <strong>Apps</strong> on the left hand side and then click <strong>Get HubSpot API key</strong> button to get one:
<img src="https://cdn.zappysys.com/api/images/authentication/hubspot/API-Key/get-hubspot-api-key.png"
loading="lazy"
decoding="async"
class="img-thumbnail block"
alt="Get HubSpot API key"
title="Getting HubSpot API key"
width="1000"
height="350" />
</li>
<li>
When a popup appears, click <strong>Show Key</strong> button and then hit <strong>Copy</strong> button to copy API key:
<img src="https://cdn.zappysys.com/api/images/authentication/hubspot/API-Key/use-api-key-to-read-hubspot-data-via-rest-api.png"
loading="lazy"
decoding="async"
class="img-thumbnail block"
alt="Use API key to read HubSpot data via REST API"
title="Using API key to read HubSpot data via REST API"
width="1000"
height="770" />
</li>
<li>
Once copy the API key, go to SSIS package or ODBC data source and use it in <strong>API Key</strong> authentication configuration:
<ul>
<li>Paste it in <strong>ApiKey</strong> parameter field.</li>
</ul>
</li>
<li>
Done! Now you are ready to use HubSpot Connector!
</li>
</ul>
]]>
</Notes>
<Params>
<Param Name="hapikey" Label="ApiKey" Type="Query" Secret="True" Required="True" />
<Param Name="RetryMode" Value="RetryWhenStatusCodeMatch" Options="None;RetryAny;RetryWhenStatusCodeMatch;" Hidden="True" />
<Param Name="RetryStatusCodeList" Value="429" Hidden="True" />
<Param Name="RetryCountMax" Value="5" Hidden="True" />
<Param Name="RetryMultiplyWaitTime" Value="True" Hidden="True" />
</Params>
</Auth>
</Auths>
<Template>
<EndPoint Name="Pagination">
<Params>
<Param Name="NextUrlAttributeOrExpr"
Value="$.paging.next.link"
Type="Property"
/>
</Params>
</EndPoint>
<EndPoint Name="PaginationAndSeveralColumns" Template="Pagination">
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_WSTR" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
</OutputColumns>
</EndPoint>
<EndPoint Name="SingleRow" Method="GET">
<Params>
<Param Name="Id"
Required="True"
IsKey="True"
/>
</Params>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_WSTR" Key="True" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
</OutputColumns>
</EndPoint>
<EndPoint Name="ArchiveItems" Method="POST" DotAsPath="True" BatchSize="100" ContentType="application/json">
<Params>
<Param Name="RawOutputDataRowTemplate" Type="Property" Value="{Status:'Archived'}" />
<Param Name="EnableRawOutputModeSingleRow" Type="Property" Value="True" />
</Params>
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" Desc="Id of a company"
DataType="DT_WSTR"
Length="100"
/>
</InputColumns>
<OutputColumns>
<Column Name="Status" DataType="DT_WSTR" Length="50" />
</OutputColumns>
</EndPoint>
<EndPoint Name="PaginationForSearch"
Method="POST" Filter="$.results[*]" ContentType="application/json" MaxRows="10000"
HelpLink="https://developers.hubspot.com/docs/api/crm/search">
<Body><![CDATA[{ "limit": 100, "after": "{$after$}", "filters": [$SearchFilters$], "properties" : [ [$Properties$] ] }]]>
</Body>
<Params>
<Param Name="SearchFilters"
Editor="MultiLine"
Value="[ {"propertyName": "createdate", "operator": "GT", "value": "<<today-10year||unix_timestamp_ms,FUN_TO_DATE>>" } ]" />
<Param Name="PagingMode" Value="ByPostData" Hidden="True" Type="Property"/>
<Param Name="PagingByUrlCurrentPage" Value="0" Hidden="True" Type="Property"/>
<Param Name="PagingByUrlAttributeName" Value="{$after$}" Hidden="True" Type="Property"/>
<Param Name="PagingIncrementBy" Value="100" Hidden="True" Type="Property"/>
</Params>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_WSTR" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
</OutputColumns>
</EndPoint>
</Template>
<EndPoints>
<!-- ==================
Search Contacts, Company, Deal, Ticket, Product, LineItem, Quote
================== -->
<EndPoint Name="search_companies" Label="Search Companies" Desc="Search companies using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/companies/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_company_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_company_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<EndPoint Name="search_contacts" Label="Search Contacts" Desc="Search contacts using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/contacts/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_contact_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<EndPoint Name="search_tickets" Label="Search Tickets" Desc="Search tickets using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/tickets/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_ticket_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<EndPoint Name="search_deals" Label="Search Deals" Desc="Search deals using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/deals/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_deal_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<EndPoint Name="search_products" Label="Search Products" Desc="Search products using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/products/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_product_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<EndPoint Name="search_lineitems" Label="Search LineItems" Desc="Search LineItems using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/line_items/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_lineitem_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<EndPoint Name="search_quotes" Label="Search Quotes" Desc="Search Quotes using one or more filter conditions. Choose properties to include in the output." Template="PaginationForSearch"
Url="/crm/v3/objects/quotes/search" >
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_quote_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate=""{@value}""
MultiSelectSeparator=","
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ==================
CONTACTS
================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_contacts" Label="Get Contacts" Url="/crm/v3/objects/contacts?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_contact_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
CONTACT BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_contact" Label="Get Contact By ID" Url="/crm/v3/objects/contacts/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_contact_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
CONTACT PROPERTIES
===================== -->
<EndPoint Template="Pagination" Name="get_contact_properties" Label="Get Contact Properties" CachedTtl="120" Url="/crm/v3/properties/contacts" Method="GET" Filter="$.results[*]">
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ====================
CREATE CONTACTS
===================== -->
<EndPoint Name="create_contacts" Label="Create Contacts" Url="/crm/v3/objects/contacts/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime,date;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
UPDATE CONTACTS
===================== -->
<EndPoint Name="update_contacts" Label="Update Contacts" Url="/crm/v3/objects/contacts/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_contact_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE CONTACTS
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_contacts" Label="Archive Contacts" Url="/crm/v3/objects/contacts/batch/archive" >
</EndPoint>
<!-- ==================
DEALS
=================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_deals" Label="Get Deals" Url="/crm/v3/objects/deals?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_deal_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_R8=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
DEAL PROPERTIES
===================== -->
<EndPoint Template="Pagination" Name="get_deal_properties" Label="Get Deal Properties" CachedTtl="120" Url="/crm/v3/properties/deals" Method="GET" Filter="$.results[*]">
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ====================
DEAL BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_deal" Label="Get Deal By ID" Url="/crm/v3/objects/deals/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_deal_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ===================
CREATE DEALS
==================== -->
<EndPoint Name="create_deals" Label="Create Deals" Url="/crm/v3/objects/deals/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" BatchSize="100" ContentType="application/json">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_WSTR" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE DEALS
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_deals" Label="Archive Deals" Url="/crm/v3/objects/deals/batch/archive">
</EndPoint>
<!-- ====================
UPDATE DEALS
===================== -->
<EndPoint Name="update_deals" Label="Update Deals" Url="/crm/v3/objects/deals/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_deal_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
PRODUCTS
===================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_products" Label="Get Products" Url="/crm/v3/objects/products?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_product_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
PRODUCT BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_product" Label="Get Product By ID" Url="/crm/v3/objects/products/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_product_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
PRODUCT PROPERTIES
===================== -->
<EndPoint Template="Pagination" Name="get_product_properties" Label="Get Product Properties" CachedTtl="120" Url="/crm/v3/properties/products" Method="GET" Filter="$.results[*]">
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ===================
CREATE PRODUCTS
==================== -->
<EndPoint Name="create_products" Label="Create Products" Url="/crm/v3/objects/products/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" BatchSize="100" ContentType="application/json">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE PRODUCTS
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_products" Label="Archive Products" Url="/crm/v3/objects/products/batch/archive">
</EndPoint>
<!-- ====================
UPDATE PRODUCTS
===================== -->
<EndPoint Name="update_products" Label="Update Products" Url="/crm/v3/objects/products/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
COMPANIES
===================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_companies" Label="Get Companies" Url="/crm/v3/objects/companies?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_company_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_company_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
COMPANY BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_company" Label="Get Company By ID" Url="/crm/v3/objects/companies/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_company_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_company_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
COMPANY PROPERTIES
===================== -->
<EndPoint Template="Pagination" Name="get_company_properties" Label="Get Company Properties" CachedTtl="120" Url="/crm/v3/properties/companies" Method="GET" Filter="$.results[*]">
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ===================
CREATE COMPANIES
==================== -->
<EndPoint Name="create_companies" Label="Create Companies" Url="/crm/v3/objects/companies/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" BatchSize="100" ContentType="application/json">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_company_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_WSTR" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_product_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_WSTR=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE COMPANIES
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_companies" Label="Archive Companies" Url="/crm/v3/objects/companies/batch/archive">
</EndPoint>
<!-- ====================
UPDATE COMPANIES
==================== -->
<EndPoint Name="update_companies" Label="Update Companies" Url="/crm/v3/objects/companies/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_company_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_company_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
LINE ITEMS
===================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_lineitems" Label="Get Line Items" Url="/crm/v3/objects/line_items?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_lineitem_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
LINE ITEMS BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_lineitem" Label="Get Line Item By ID" Url="/crm/v3/objects/line_items/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_lineitem_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
LINE ITEM PROPERTIES
======================= -->
<EndPoint Name="get_lineitem_properties" Label="Get Line Item Properties" CachedTtl="120" Url="/crm/v3/properties/line_items" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="NextUrlAttributeOrExpr"
Value="$.paging.next.link"
Type="Property"
/>
</Params>
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ======================
CREATE LINE ITEMS
======================= -->
<EndPoint Name="create_lineitems" Label="Create Line Items" Url="/crm/v3/objects/line_items/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100" >
<Params>
<Param Name="NextUrlAttributeOrExpr"
Value="$.paging.next.link"
Type="Property"
/>
</Params>
<InputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- Dynamic -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE LINE ITEMS
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_lineitems" Label="Archive Line Items" Url="/crm/v3/objects/line_items/batch/archive">
</EndPoint>
<!-- ====================
UPDATE LINE ITEMS
==================== -->
<EndPoint Name="update_lineitems" Label="Update Line items" Url="/crm/v3/objects/line_items/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_lineitem_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
TICKETS
===================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_tickets" Label="Get Tickets" Url="/crm/v3/objects/tickets?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_ticket_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
TICKET BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_ticket" Label="Get Ticket By ID" Url="/crm/v3/objects/tickets/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_ticket_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
TICKET PROPERTIES
===================== -->
<EndPoint Name="get_ticket_properties" Label="Get Tickets Properties" CachedTtl="120" Url="/crm/v3/properties/tickets" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="NextUrlAttributeOrExpr"
Value="$.paging.next.link"
Type="Property"
/>
</Params>
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ===================
CREATE TICKETS
==================== -->
<EndPoint Name="create_tickets" Label="Create Tickets" Url="/crm/v3/objects/tickets/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" BatchSize="100" ContentType="application/json">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE TICKETS
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_tickets" Label="Archive Tickets" Url="/crm/v3/objects/tickets/batch/archive">
</EndPoint>
<!-- ====================
UPDATE TICKETS
==================== -->
<EndPoint Name="update_tickets" Label="Update Tickets" Url="/crm/v3/objects/tickets/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_ticket_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
QUOTES
===================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_quotes" Label="Get Quotes" Url="/crm/v3/objects/quotes?limit=100&[$Properties$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_quote_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
QUOTE BY ID
===================== -->
<EndPoint Template="SingleRow" Name="get_quote" Label="Get Quote By ID" Url="/crm/v3/objects/quotes/[$Id$]?[$Properties$]"
>
<Params>
<Param Name="Properties"
Type="Placeholder"
OptionsEndPoint="get_quote_properties"
OptionsEndPointValueColumn="name"
MultiSelect="True"
MultiSelectAllOnBlank="True"
MultiSelectLimit="5000"
MultiSelectTemplate="properties={@value}"
MultiSelectSeparator="&"
Hidden="True"
/>
</Params>
<OutputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
QUOTE PROPERTIES
===================== -->
<EndPoint Name="get_quote_properties" Label="Get Quotes Properties" CachedTtl="120" Url="/crm/v3/properties/quotes" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="NextUrlAttributeOrExpr"
Value="$.paging.next.link"
Type="Property"
/>
</Params>
<OutputColumns>
<Column Name="name" Label="Name" DataType="DT_WSTR" Length="300" />
<Column Name="label" Label="Label" DataType="DT_WSTR" Length="300" />
<Column Name="type" Label="Type" DataType="DT_WSTR" Length="150" />
<Column Name="hidden" Label="IsHidden" DataType="DT_BOOL" />
<Column Name="fieldType" Label="FieldType" DataType="DT_WSTR" Length="150" />
<Column Name="description" Label="Description" DataType="DT_WSTR" Length="1500" />
</OutputColumns>
</EndPoint>
<!-- ===================
CREATE QUOTES
==================== -->
<EndPoint Name="create_quotes" Label="Create Quotes" Url="/crm/v3/objects/quotes/batch/create" Method="POST" Filter="$.results[*]" DotAsPath="True" BatchSize="100" ContentType="application/json">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ======================
ARCHIVE QUOTES
=========================== -->
<EndPoint Template="ArchiveItems" Name="archive_quotes" Label="Archive Quotes" Url="/crm/v3/objects/quotes/batch/archive">
</EndPoint>
<!-- ====================
UPDATE QUOTES
==================== -->
<EndPoint Name="update_quotes" Label="Update Quotes" Url="/crm/v3/objects/quotes/batch/update" Method="POST" Filter="$.results[*]" DotAsPath="True" ContentType="application/json" BatchSize="100">
<Body>
<![CDATA[ { "inputs": {$rows$}
}
]]>
</Body>
<InputColumns>
<Column Name="id" Key="True" ReadAs="Id" Label="Id" DataType="DT_I8" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
KeyIf="id" ReadAs="Id"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</InputColumns>
<OutputColumns>
<Column Name="id" Label="Id" DataType="DT_I8" />
<Column Name="createdAt" Label="CreatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="updatedAt" Label="UpdatedAt" DataType="DT_DBTIMESTAMP" />
<Column Name="archived" Label="IsArchived" DataType="DT_BOOL" />
<!-- DYNAMIC CUSTOM FIELDS -->
<Column Name="properties.[$parent.name$]" Label="[$parent.name$]" Desc="[$parent.label$]"
DataType="DT_WSTR"
Length="2000"
Expand="True"
DataEndPoint="get_quote_properties"
ColumnInfoMap="Name=name;DataType=type"
DataTypeMap="DT_NUMERIC=number;DT_WSTR=string;DT_DBTIMESTAMP=datetime;DT_BOOL=bool"
/>
</OutputColumns>
</EndPoint>
<!-- ====================
OWNERS
===================== -->
<EndPoint Template="PaginationAndSeveralColumns" Name="get_owners" Label="Get Owners" Url="/crm/v3/owners/[$OwnerId$]" Method="GET" Filter="$.results[*]">
<Params>
<Param Name="OwnerId" />
<Param Name="ContineOnErrorForStatusCode" Type="Property" Value="True"/>
</Params>
<OutputColumns>
<Column Name="email" Label="Email" DataType="DT_WSTR" />
<Column Name="firstName" Label="FirstName" DataType="DT_WSTR" />
<Column Name="lastName" Label="LastName" DataType="DT_WSTR" />
<Column Name="userId" Label="UserId" DataType="DT_I8" />
</OutputColumns>
</EndPoint>
<!-- ====================
Upload File
===================== -->
<EndPoint Name="upload_file"
Method="POST"
Filter="$.objects[*]"
Label="Upload File from Local Disk"
Desc="Uploads local file to Hubspot CRM. This API requires files permission for the App (see scopes)"
HelpLink="https://legacydocs.hubspot.com/docs/methods/files/v3/upload_new_file"
Url="/filemanager/api/v3/files/upload"
IsMultiPart="True"
>
<Body>
<![CDATA[file=@[$SourceFilePath$]
folderPath=[$TargetFolder$]
fileName=[$TargetFileName$]
options={"access": "[$AccessType$]", "overwrite": [$Overwrite$], "duplicateValidationStrategy": "[$DuplicateValidationStrategy$]" , "duplicateValidationScope": "[$DuplicateValidationScope$]" }]]>
</Body>
<Params>
<Param Name="SourceFilePath"
Label="Source File Path"
Required="True"
Desc="Specify a disk file path"
Example="C:\MyParentFolder\Subfolder\file.txt"
Value=""
Editor="FileOpen"
/>
<Param Name="TargetFolder"
Label="Target Folder Path"
Required="True"
Desc="Specify Target folder path. Partially optional field. One of folderPath or folderId must be specified. Path of the folder the file should be uploaded into. Uploading files into the root path “/” is highly discouraged."
Example="/SalesDocs"
Value="/"
/>
<Param Name="TargetFileName"
Label="Target File Name (e.g. MyFile.xlsx)"
Desc="Specify file name you like to give"
/>
<Param Name="AccessType"
Required="True"
Desc="Specify file access type"
Value="PRIVATE" Options="PRIVATE;PUBLIC_NOT_INDEXABLE;PUBLIC_INDEXABLE"
/>
<Param Name="Overwrite"
Required="True"
Desc="Specify wheather you like to overwrite target file if exists. If true this file with replace any existing files with the name, folder, and type. Note: If this is set to false, and the uploaded file matches the filename of an existing file in the same folder, the file will be uploaded with a number incremented filename (e.g. example_file.txt will become example_file-1.txt)"
Value="true" Options="false;true"
/>
<Param Name="DuplicateValidationStrategy"
Required="True"
Desc="Specify how to handle duplicate target file."
Value="NONE" Options="NONE;REJECT;RETURN_EXISTING"
/>
<Param Name="DuplicateValidationScope"
Required="True"
Desc="Specify scope of duplicate validation."
Value="EXACT_FOLDER" Options="EXACT_FOLDER;ENTIRE_PORTAL"
/>
</Params>
<OutputColumns>
<Column Name="id" DataType="DT_I8" Label="Id" />
<Column Name="portal_id" DataType="DT_I8" Label="PortalId" />
<Column Name="name" DataType="DT_WSTR" Label="Name" Length="50" />
<Column Name="size" DataType="DT_I8" Label="Size" />
<Column Name="height" DataType="DT_I4" Label="Height" />
<Column Name="width" DataType="DT_I4" Label="Width" />
<Column Name="encoding" DataType="DT_WSTR" Label="Encoding" Length="1020" />
<Column Name="type" DataType="DT_WSTR" Label="Type" Length="50" />
<Column Name="extension" DataType="DT_WSTR" Label="Extension" Length="50" />
<Column Name="cloud_key" DataType="DT_WSTR" Label="CloudKey" Length="500" />
<Column Name="s3_url" DataType="DT_WSTR" Label="S3Url" Length="500" />
<Column Name="friendly_url" DataType="DT_WSTR" Label="FriendlyUrl" Length="500" />
<Column Name="alt_key" DataType="DT_WSTR" Label="AltKey" Length="500" />
<Column Name="alt_key_hash" DataType="DT_WSTR" Label="AltKeyHash" Length="500" />
<Column Name="title" DataType="DT_WSTR" Label="Title" Length="50" />
<Column Name="meta.url_scheme" DataType="DT_WSTR" Label="MetaUrlScheme" Length="50" />
<Column Name="meta.allows_anonymous_access" DataType="DT_BOOL" Label="MetaAllowsAnonymousAccess" />
<Column Name="meta.indexable" DataType="DT_BOOL" Label="MetaIndexable" />
<Column Name="created" DataType="DT_DBTIMESTAMP" Label="Created" Functions="unix_timestamp_ms_to_date" />
<Column Name="updated" DataType="DT_DBTIMESTAMP" Label="Updated" Functions="unix_timestamp_ms_to_date" />
<Column Name="deleted_at" DataType="DT_DBTIMESTAMP" Label="DeletedAt" Functions="unix_timestamp_ms_to_date" />
<Column Name="folder_id" DataType="DT_I8" Label="FolderId" />
<Column Name="hidden" DataType="DT_BOOL" Label="Hidden" />
<Column Name="cloud_key_hash" DataType="DT_WSTR" Label="CloudKeyHash" Length="500" />
<Column Name="archived" DataType="DT_BOOL" Label="Archived" />
<Column Name="created_by" DataType="DT_WSTR" Label="CreatedBy" Length="1020" />
<Column Name="deleted_by" DataType="DT_WSTR" Label="DeletedBy" Length="1020" />
<Column Name="replaceable" DataType="DT_BOOL" Label="Replaceable" />
<Column Name="url" DataType="DT_WSTR" Label="Url" Length="500" />
<Column Name="alt_url" DataType="DT_WSTR" Label="AltUrl" Length="500" />
<Column Name="cdn_purge_embargo_time" DataType="DT_WSTR" Label="CdnPurgeEmbargoTime" Length="1020" />
<Column Name="file_hash" DataType="DT_WSTR" Label="FileHash" Length="1020" />
</OutputColumns>
</EndPoint>
</EndPoints>
<Tables>
<Table Name="Contacts"
SelectEndPoint="get_contacts"
LookupEndPoint="get_contact"
InsertEndPoint="create_contacts"
UpdateEndPoint="update_contacts"
DeleteEndPoint="archive_contacts"
/>
<Table Name="Companies"
SelectEndPoint="get_companies"
LookupEndPoint="get_company"
InsertEndPoint="create_companies"
UpdateEndPoint="update_companies"
DeleteEndPoint="archive_companies"
/>
<Table Name="Deals"
SelectEndPoint="get_deals"
LookupEndPoint="get_deal"
InsertEndPoint="create_deals"
UpdateEndPoint="update_deals"
DeleteEndPoint="archive_deals"
/>
<Table Name="Products"
SelectEndPoint="get_products"
LookupEndPoint="get_product"
InsertEndPoint="create_products"
UpdateEndPoint="update_products"
DeleteEndPoint="archive_products"
/>
<Table Name="Tickets"
SelectEndPoint="get_tickets"
LookupEndPoint="get_ticket"
InsertEndPoint="create_tickets"
UpdateEndPoint="update_tickets"
DeleteEndPoint="archive_tickets"
/>
<Table Name="LineItems"
SelectEndPoint="get_lineitems"
LookupEndPoint="get_lineitem"
InsertEndPoint="create_lineitems"
UpdateEndPoint="update_lineitems"
DeleteEndPoint="archive_lineitems"
/>
<Table Name="Owners"
SelectEndPoint="get_owners"
/>
<Table Name="Quotes"
SelectEndPoint="get_quotes"
LookupEndPoint="get_quote"
InsertEndPoint="create_quotes"
UpdateEndPoint="update_quotes"
DeleteEndPoint="archive_quotes"
/>
</Tables>
<Examples>
<Example Group="ODBC" Label="Get companies" Desc="Gets companies">
<Code>
<![CDATA[SELECT * FROM Companies --Where Id=123]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get contacts" Desc="Gets contacts">
<Code>
<![CDATA[SELECT * FROM Contacts --Where Id=123]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get contact by Id" Desc="Gets contact by Id">
<Code>
<![CDATA[SELECT * FROM Contacts Where Id=51]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get contact by email (search)" Desc="Gets contacts">
<Code>
<![CDATA[SELECT Id
, IsArchived
, CreatedAt
, UpdatedAt
, email
, firstname
, lastname
, company_size
--, custom_checkbox
--, custom_multi_select
--, custom_number
--, custom_pickuser
--, custom_richtext
--, custom_string
--, custom_string_multi
FROM search_contacts
With(SearchFilters='[ {"propertyName": "email", "operator": "EQ", "value": "bh@hubspot.com" } ]')]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get deals" Desc="Gets deals">
<Code>
<![CDATA[SELECT * FROM Deals --Where Id=123]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get line items" Desc="Gets line items">
<Code>
<![CDATA[SELECT * FROM LineItems --Where Id=123]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get owners" Desc="Gets owners">
<Code>
<![CDATA[SELECT * FROM Owners]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get products" Desc="Gets products">
<Code>
<![CDATA[SELECT * FROM Products --Where Id=123]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get tickets" Desc="Gets tickets">
<Code>
<![CDATA[SELECT * FROM Tickets]]>
</Code>
</Example>
<Example Group="ODBC" Label="Get quotes" Desc="Gets quotes">
<Code>
<![CDATA[SELECT * FROM Quotes]]>
</Code>
</Example>
<Example Group="ODBC" Label="Generic Request (Company Search API Example)" Desc="This example shows how to invoke generic request when connector file doesnt have specific EndPoint / Table you like to query. This example invokes search endpoint but you can call any valid API endpoint GET/POST etc with this method">
<Code>
<![CDATA[SELECT *
FROM generic_request
WITH(
Url='crm/v3/objects/companies/search'
,Filter='$.results[*]'
,RequestContentTypeCode='ApplicationJson'
,RequestMethod='POST'
,RequestData='{
"filters": [ {"propertyName": "hs_lastmodifieddate", "operator": "GT", "value": "<<yearstart-1y||unix_timestamp_ms,FUN_TO_DATE>>" } ],
"properties": ["address","city","state"]
}'
)]]>
</Code>
</Example>
<Example Group="ODBC" Label="Upload File (Generic Request Example)" Desc="This example shows how to upload a file using generic request. You might have to add file-manager-permission to your OAuth App else you might get message=This oauth-token (CJT87I6) does not have proper permissions! (requires any of [file-manager-access]). For more information please refer to this link https://developers.hubspot.com/docs/api/files/files">
<Code>
<![CDATA[SELECT *
FROM generic_request
WITH(
Url='filemanager/api/v3/files/upload'
, RequestMethod='POST'
, Filter ='$.objects[*]'
, Body='file=@c:\temp\dump.png
folderPath=/
fileName=my_dump.png
options={"access": "PRIVATE", "overwrite": true}'
, IsMultiPart='True'
, Meta='id:long; name:string; title:string; url: string; type:string; size:long; friendly_url:string; meta.allows_anonymous_access:string; meta.indexable:bool'
)]]>
</Code>
</Example>
<Example Group="ODBC" Label="Insert into Contacts" Desc="Inserts contacts" >
<Code><![CDATA[INSERT INTO Contacts(email, firstname, lastname,custom_checkbox, custom_date, custom_number)
VALUES ('john.doe@abc.com', 'John', 'Doe','true','2023-01-01', 100.55)]]>
</Code>
</Example>
<Example Group="ODBC" Label="Update Contacts" Desc="Updates contacts in your account" >
<Code>
<![CDATA[UPDATE Contacts
SET firstname = 'Brian'
,lastname = 'Halligan (Sample Contact)'
--,custom_number=12.12
--,custom_date='2023-01-01'
--,custom_string='My Test<<FUN_NOW>>'
--,custom_richtext='<p><span style="color: #b5b5b5;">##-Please reply-##</span></p>'
--,custom_multi_select='Blue;Yellow;Black'
--,custom_pickuser=45581955
--,custom_dropdown='BB'
--,custom_checkbox='true'
WHERE Id = 51]]>
</Code>
</Example>
<Example Group="ODBC" Label="Delete a contact" Desc="Deletes a contact">
<Code>
<![CDATA[DELETE FROM Contacts Where Id=1234]]>
</Code>
</Example>
<Example Group="ODBC" Label="Create multiple records - (BULK read / write from external source)" Desc="This examples shows how to perform bulk update using SOURCE clause. It reads data from external system (in this example MS SQL Server) and sends data to Hubspot using Bulk API">
<Code>
<![CDATA[INSERT INTO Contacts
SOURCE(
'MSSQL' --ODBC or OLEDB
,'Data Source=localhost;Initial Catalog=Test;Integrated Security=true'
,'
''bob'' as firstname, ''rock'' as firstname, ''new-email1@abc.com'' as email
UNION
''sam'' as firstname, ''smith'' as firstname, ''new-email2@abc.com'' as email
)]]>
</Code>
</Example>
<Example Group="ODBC" Label="Delete multiple records - (BULK read / write from external source)" Desc="This examples shows how to perform bulk delete using SOURCE clause. It reads data from external system (in this example MS SQL Server) and sends data to Hubspot using Bulk API">
<Code>
<![CDATA[DELETE FROM Contacts
SOURCE(
'MSSQL' --ODBC or OLEDB
,'Data Source=localhost;Initial Catalog=Test;Integrated Security=true'
,'select 104897 as Id
UNION
select 104898 as Id'
)
]]>
</Code>
</Example>
<Example Group="ODBC" Label="Update multiple records - (BULK read / write from external source)" Desc="This examples shows how to perform bulk update using SOURCE clause. It reads data from external system (in this example MS SQL Server) and sends data to Hubspot using Bulk API">
<Code>
<![CDATA[UPDATE Contacts
SOURCE(
'MSSQL' --ODBC or OLEDB
,'Data Source=localhost;Initial Catalog=Test;Integrated Security=true'
,'select 104811 as Id, ''new-email1@abc.com'' as email
UNION
select 104812 as Id, ''new-email2@abc.com'' as email
)]]>
</Code>
</Example>
</Examples>
</ApiConfig>