Exporting Companies from ConnectWise REST Interface
This task will export companies from the Companies -> Companies area of ConnectWise in an XML format. The results can be filtered using the Conditions if required. See below for a sample output file.
Settings
ConnectWise REST Interface Connection
Required
The ConnectWise REST Interface connection to use. See the Connecting to ConnectWise REST Interface article if you require more information on how to create/manage connections.
Child Conditions
Optional
Use this setting to specify where clauses to filter the records returned. This setting is used to specify conditions applying to standard fields which are part of a collection.
Child Condition > Comparison
Required
The following types of filter are available:
- Equals - Returns records where the field matches the specified value.
- Contains - Returns records where the field contains the specified value. This filter type is only valid for String fields on ConnectWise.
- GreaterThan - Returns records where the field is greater than the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- GreaterThanOrEqual - Returns records where the field is greater than or equal to the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- In - Returns records where the field matches one of the specified values. Must be enclosed in parenthesis, with multiple values separated by a comma. e.g. ("John", "Ben")for string values,(1, 3)for numeric values. See the Condition > Value section below for more information on how different value types should be entered.
- Like - Returns records where the field matches the specified value. The asterisk (*) character can be used as a wild card. This filter type is only valid for String fields on ConnectWise.
- LessThan - Returns records where the field is less than the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- LessThanOrEqual - Returns records where the field is less than or equal to the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- NotContains - Returns records where the field does not contain the specified value. This filter type is only valid for String fields on ConnectWise.
- NotEqual - Returns records where the field does not match the specified value.
- NotIn - Returns records where the field does not match one of the specified values.  Must be enclosed in parenthesis, with multiple values separated by a comma. e.g. ("John", "Ben")for string values,(1, 3)for numeric values etc. See the Condition > Value section below for more information on how different value types should be entered.
- NotLike - Returns records where the field does not match the specified value. The asterisk (*) character can be used as a wild card. This filter type is only valid for String fields on ConnectWise.
Child Condition > Field
Required
The name of the field the condition applies to. The name should match the API field name, as seen in the output file. If using a reference field, include the name of the reference field followed by a slash, then the field to filter on. 
The supported fields are listed below: -
- types/id (Integer)
- types/name (String)
- types/defaultFlag (Boolean) nullable
- types/vendorFlag (Boolean) nullable
- types/serviceAlertFlag (Boolean) nullable
- types/serviceAlertMessage (String)
Child Condition > Logic Operator
Optional
The logic operator to use for the condition being added when building the where clause. Choose from:
- And - Will return records which meet both of the conditions specified.
- Or - Will return records which meet at least of the conditions specified.
Child Condition > Value
Optional
The value to use in the filter.
- String values should be surrounded by quotes. e.g. "John"
- Boolean values should be specified as either TrueorFalse, with no quotes.
- Datetime values should be specified in ISO8601 format, surrounded by square brackets. e.g. [2000-01-31T14:51:00Z]
- Null is specified as null.
- When using the In or NotIn comparison, values must be separated by a comma and be surrounded by rounded brackets. e.g. ("John", "Ben"). See how different values types should be specified above.
Conditions
Optional
Use this setting to specify where clauses to filter the records returned. This setting is used to specify conditions applying to standard fields.
Condition > Comparison
Required
The following types of filter are available:
- Equals - Returns records where the field matches the specified value.
- Contains - Returns records where the field contains the specified value. This filter type is only valid for String fields on ConnectWise.
- GreaterThan - Returns records where the field is greater than the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- GreaterThanOrEqual - Returns records where the field is greater than or equal to the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- In - Returns records where the field matches one of the specified values. Must be enclosed in parenthesis, with multiple values separated by a comma. e.g. ("John", "Ben")for string values,(1, 3)for numeric values. See the Condition > Value section below for more information on how different value types should be entered.
- Like - Returns records where the field matches the specified value. The asterisk (*) character can be used as a wild card. This filter type is only valid for String fields on ConnectWise.
- LessThan - Returns records where the field is less than the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- LessThanOrEqual - Returns records where the field is less than or equal to the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- NotContains - Returns records where the field does not contain the specified value. This filter type is only valid for String fields on ConnectWise.
- NotEqual - Returns records where the field does not match the specified value.
- NotIn - Returns records where the field does not match one of the specified values.  Must be enclosed in parenthesis, with multiple values separated by a comma. e.g. ("John", "Ben")for string values,(1, 3)for numeric values etc. See the Condition > Value section below for more information on how different value types should be entered.
- NotLike - Returns records where the field does not match the specified value. The asterisk (*) character can be used as a wild card. This filter type is only valid for String fields on ConnectWise.
Condition > Field
Required
The name of the field the condition applies to. The name should match the API field name, as seen in the output file. If using a reference field, include the name of the reference field followed by a slash, then the field to filter on. 
The supported fields are listed below: -
- id (Integer)
- identifier (String)
- name (String)
- addressLine1 (String)
- addressLine2 (String)
- city (String)
- state (String)
- zip (String)
- phoneNumber (String)
- faxNumber (String)
- website (String)
- accountNumber (String)
- dateAcquired (String)
- annualRevenue (Decimal) nullable
- numberOfEmployees (Integer) nullable
- yearEstablished (Integer) nullable
- leadSource (String)
- leadFlag (Boolean) nullable
- unsubscribeFlag (Boolean) nullable
- userDefinedField1 (String)
- userDefinedField2 (String)
- userDefinedField3 (String)
- userDefinedField4 (String)
- userDefinedField5 (String)
- userDefinedField6 (String)
- userDefinedField7 (String)
- userDefinedField8 (String)
- userDefinedField9 (String)
- userDefinedField10 (String)
- vendorIdentifier (String)
- taxIdentifier (String)
- invoiceToEmailAddress (String)
- invoiceCCEmailAddress (String)
- deletedFlag (Boolean) nullable
- dateDeleted (String)
- deletedBy (String)
- mobileGuid (String) nullable
- facebookUrl (String)
- twitterUrl (String)
- linkedInUrl (String)
Condition > Logic Operator
Optional
The logic operator to use for the condition being added when building the where clause. Choose from:
- And - Will return records which meet both of the conditions specified.
- Or - Will return records which meet at least of the conditions specified.
Condition > Value
Optional
The value to use in the filter.
- String values should be surrounded by quotes. e.g. "John"
- Boolean values should be specified as either TrueorFalse, with no quotes.
- Datetime values should be specified in ISO8601 format, surrounded by square brackets. e.g. [2000-01-31T14:51:00Z]
- Null is specified as null.
- When using the In or NotIn comparison, values must be separated by a comma and be surrounded by rounded brackets. e.g. ("John", "Ben"). See how different values types should be specified above.
Custom Field Conditions
Optional
Use this setting to specify where clauses to filter the records returned. This setting is used to specify conditions applying to custom fields.
Custom Field Condition > Comparison
Required
The following types of filter are available:
- Equals - Returns records where the field matches the specified value.
- Contains - Returns records where the field contains the specified value. This filter type is only valid for String fields on ConnectWise.
- GreaterThan - Returns records where the field is greater than the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- GreaterThanOrEqual - Returns records where the field is greater than or equal to the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- In - Returns records where the field matches one of the specified values. Must be enclosed in parenthesis, with multiple values separated by a comma. e.g. ("John", "Ben")for string values,(1, 3)for numeric values. See the Condition > Value section below for more information on how different value types should be entered.
- Like - Returns records where the field matches the specified value. The asterisk (*) character can be used as a wild card. This filter type is only valid for String fields on ConnectWise.
- LessThan - Returns records where the field is less than the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- LessThanOrEqual - Returns records where the field is less than or equal to the specified value. This filter type is only valid for Numeric and DateTime fields on ConnectWise.
- NotContains - Returns records where the field does not contain the specified value. This filter type is only valid for String fields on ConnectWise.
- NotEqual - Returns records where the field does not match the specified value.
- NotIn - Returns records where the field does not match one of the specified values.  Must be enclosed in parenthesis, with multiple values separated by a comma. e.g. ("John", "Ben")for string values,(1, 3)for numeric values etc. See the Condition > Value section below for more information on how different value types should be entered.
- NotLike - Returns records where the field does not match the specified value. The asterisk (*) character can be used as a wild card. This filter type is only valid for String fields on ConnectWise.
Custom Field Condition > Field
Required
The caption of the custom field that the condition applies to. You can find the caption by looking at how the custom field appears in ConnectWise or by finding the custom field in an export file via Zynk.
Custom Field Condition > Logic Operator
Optional
The logic operator to use for the condition being added when building the where clause. Choose from:
- And - Will return records which meet both of the conditions specified.
- Or - Will return records which meet at least of the conditions specified.
Custom Field Condition > Value
Optional
The value to use in the filter.
- String values should be surrounded by quotes. e.g. "John"
- Boolean values should be specified as either TrueorFalse, with no quotes.
- Datetime values should be specified in ISO8601 format, surrounded by square brackets. e.g. [2000-01-31T14:51:00Z]
- Null is specified as null.
- When using the In or NotIn comparison, values must be separated by a comma and be surrounded by rounded brackets. e.g. ("John", "Ben"). See how different values types should be specified above.
Export Settings > Date Created
Required
When the 'Export Modified, New or All Records' setting is set to 'New', only batches created after this date will be exported. This date will update automatically each time the task runs, to ensure only new batches are exported each time.
Defaults to the current date and time.
Export Settings > Date Modified
Required
When the 'Export Modified, New or All Records' setting is set to 'Modified', only batches updated after this date will be downloaded. This date will update automatically each time the task runs, to ensure only modified batches are exported each time.
Defaults to the current date and time.
Export Settings > Export Modified, New or All Records
Required
Choose which records should be downloaded. The available options are:
- Modified - Only records updated after the date shown in the 'Date Modified' setting will be downloaded.
- New - Only records created after the date shown in the 'Date Created' setting will be downloaded.
- All - All records will be downloaded, regardless of when they were created or updated.
Defaults to Modified.
Export Settings > Page Size
Required
The number of records to include in each page of results. Increasing this value will reduce the number of requests made to the API but will increase the amount of memory needed while making each request. 
Defaults to 100.
The maximum value is 1000.
Output File
Required
The name of the file to save the exported records to.
Defaults to connectwise_export_companies.xml
References To Fetch
Optional
The exported data may include fields which reference other record types in ConnectWise. If you specify the reference field names in this setting the task will fetch the related records and include them in the exported data. 
The supported record types are listed below: -
- territory
- status
- type
- defaultContact
- parentCompany
- ownershipType
- timeZone
- taxCode
- billingTerms
- invoiceTemplate
- companyEntityType
- billToCompany
- billingSite
- billingContact
- invoiceDeliveryMethod
- currency
- territoryManager
References To Fetch Page Size
Required
The number of referenced records to fetch per page. Increasing this value will reduce the number of requests made to the API but will increase the amount of memory needed while making each request.
Defaults to 100.
The maximum value is 1000.
Timeout
Optional
The maximum length of time to wait (in seconds) for API requests to be processed. Specifying this value will override the timeout set at the connection level. Leave blank to use the value specified in the connection.
Zynk Settings
Examples
A sample output file is shown below.
<?xml version="1.0" encoding="utf-8"?>
<Companies xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
  <Company>
    <id>2</id>
    <externalId>MYCOM</externalId>
    <_info>
      <dateEntered>2002-08-20T18:04:26Z</dateEntered>
      <enteredBy>CONVERSION</enteredBy>
      <lastUpdated>2018-05-01T14:33:38Z</lastUpdated>
      <updatedBy>Admin1</updatedBy>
    </_info>
    <identifier>YourCompany</identifier>
    <name>Your Company</name>
    <status>
      <id>1</id>
      <name>Active</name>
    </status>
    <type>
      <id>5</id>
      <name>Partner</name>
    </type>
    <addressLine1>test</addressLine1>
    <addressLine2>test</addressLine2>
    <city>test</city>
    <state>MS</state>
    <zip />
    <country>
      <id>1</id>
      <name>United States</name>
    </country>
    <phoneNumber />
    <faxNumber />
    <website>http://www.example.com</website>
    <territoryId>38</territoryId>
    <marketId>23</marketId>
    <accountNumber>MYCOM</accountNumber>
    <defaultContact>
      <id>77</id>
      <name>Arnie Bellini</name>
    </defaultContact>
    <dateAcquired>2002-08-20T18:04:26Z</dateAcquired>
    <annualRevenue>0</annualRevenue>
    <numberOfEmployees xsi:nil="true" />
    <timeZone>
      <id>1</id>
      <name>US Eastern</name>
    </timeZone>
    <leadFlag>false</leadFlag>
    <unsubscribeFlag>false</unsubscribeFlag>
    <calendarId xsi:nil="true" />
    <vendorIdentifier />
    <taxIdentifier />
    <taxCode>
      <id>11</id>
      <name>Standard VAT</name>
    </taxCode>
    <billingTerms>
      <id>2</id>
      <name>Net 10</name>
    </billingTerms>
    <billToCompany>
      <id>2</id>
      <name>Your Company</name>
      <identifier>YourCompany</identifier>
    </billToCompany>
    <invoiceDeliveryMethod>
      <id>1</id>
      <name>Mail</name>
    </invoiceDeliveryMethod>
    <deletedFlag>false</deletedFlag>
    <dateDeleted xsi:nil="true" />
    <mobileGuid>f3bd951a-f535-446d-ba4e-fccb1f7ac954</mobileGuid>
    <customFields>
      <customField>
        <id>3</id>
        <caption>Sage Ref</caption>
        <type>Text</type>
        <entryMethod>EntryField</entryMethod>
        <numberOfDecimals>0</numberOfDecimals>
        <value>MYC001</value>
      </customField>
      <customField>
        <id>6</id>
        <caption>CustomNumber</caption>
        <type>Number</type>
        <entryMethod>EntryField</entryMethod>
        <numberOfDecimals>2</numberOfDecimals>
        <value>3.5</value>
      </customField>
    </customFields>
  </Company>
</Companies>