ServiceNow Connector
Documentation
Version: 1
Documentation

ServiceNow Connector - Source Code


<?xml version="1.0" encoding="utf-8"?>
<ApiConfig Name="ServiceNow"
           Desc="Allows the reading and writing of incidents, attachments, and more in ServiceNow without coding! The ZappySys ServiceNow API Connector provides easy-to-use, high-performance API access."
           Slug="servicenow-connector"
           Id="17205e73-c22f-4d57-a9d4-db295d46bdb3"
           Logo=""
           Version="1"
           EngineVersion="12"
		   >
  <VersionHistory>
	<Change Date="2023-09-01" Type="Fix">Test connection always works</Change>
    <Change Date="2023-03-15" Type="New">Initial version</Change>
  </VersionHistory>

  <ServiceUrls>
    <ServiceUrl Name="ServiceNow API" Url="https://[$InstanceName$].service-now.com/api/now" />
  </ServiceUrls>
  
  <Auths>
        <Auth Type="HTTP" Name="BasicAuth" Label="Basic Auth" Desc="Authenticate using ServiceNow instance username and password"
              ConnStr="CredentialType=Basic;UserName=[$UserName$];Password=[$Password$];RetryMode=[$RetryMode$];RetryCountMax=[$RetryCountMax$];RetryMultiplyWaitTime=[$RetryMultiplyWaitTime$];RetryStatusCodeList=[$RetryStatusCodeList$];"
              TestEndPoint="get_table_columns"              
              TestParameters="TableName=incident"
              >
          <Params>
            <Param Name="InstanceName" Required="True" />
            <Param Name="UserName" Label="User name" Required="True" Desc="You can create new user account and set password here https://{your-instance-id}.service-now.com/now/nav/ui/classic/params/target/sys_user.do or visit All \ Organization \ Users in the portal" />
            <Param Name="Password" Required="True" Secret="True" Desc="You can create new user account and set password here https://{your-instance-id}.service-now.com/now/nav/ui/classic/params/target/sys_user.do or visit All \ Organization \ Users in the portal"/>
            <Param Name="ApiVersion" Required="True" Value="v2" Options="Default=;v2=v2;v1=v1" ValueTemplate="{$value$}/"/>
			
            <!--below not exposed as root level property in HTTP Connection so use as placeholder-->
            <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>
          <Notes>
<![CDATA[
<html>
  </body>
    <p>To get your Instance name, Username and Password:</p>
    <ol>
      <li>Log in into your ServiceNow and go to <a href="https://developer.servicenow.com/dev.do" target="_blank">https://developer.servicenow.com/dev.do</a>.</li>
      <li>Click on your profile icon.</li>
      <li>Select your instance.</li>
      <li>Click on "Manage instance password" or similar link.</li>
      <li>In the opened page you should see Instance name, Username and Password.</li>
    </ol>
  </body>
</html>
]]>
          </Notes>
        </Auth>    
        <Auth Name="OAuth" Type="OAuth" Desc="Authenticate using ServiceNow instance username, password and clientid, clientsecret" 
              HelpLink="https://support.servicenow.com/kb?id=kb_article_view&amp;sysparm_article=KB0778194"
              ConnStr="Provider=Custom;OAuthVersion=OAuth2;GrantType=Password;TokenUrl=https://[$InstanceName$].service-now.com/oauth_token.do;Username=[$UserName$];Password=[$Password$]"
              TestEndPoint="get_table_columns"
			  TestParameters="TableName=incident"
			  >
          <Notes>
<![CDATA[ 
<html>
  </body>
    <p>To get your OAuth client ID / ClientSecret perform the below steps:</p>
    <ol>
      <li>Login to your instance https://{your-instance-id}.service-now.com/.</li>
	  <li>Click on All > System OAuth > Application Registry (or just search for "Application Registry" under All menu)</li>
      <li>You can also Navigate to "Application Registry" using this link (Replace your instance-id in link) https://{your-instance-id}.service-now.com/now/nav/ui/classic/params/target/oauth_entity_list.do.</li>
      <li>Click on "New" button (see top-right corner for most user) and select "Create an OAuth API endpoint for external clients".</li>
      <li>Fill out the form according to your requirement and click "Submit". If you are unsure then populating the "Name" field will suffice.
Please note down the "Client ID" and "Client Secret" as they will be used later.</li>
      <li>Go back to Connection UI and enter your UserName, Password and ClientID, Secret.</li>
	  <li>To create new User you can go to All > Organization > Users </li>
	  <li>Click Test Connection.</li>
    </ol>
  </body>
</html>
]]>
          </Notes>
          <Params>
            <Param Name="InstanceName" Required="True" />
            <Param Name="UserName" Label="User name" Required="True" Desc="You can create new user account and set password here https://{your-instance-id}.service-now.com/now/nav/ui/classic/params/target/sys_user.do or visit All \ Organization \ Users in the portal" />
            <Param Name="Password" Required="True" Secret="True" Desc="You can create new user account and set password here https://{your-instance-id}.service-now.com/now/nav/ui/classic/params/target/sys_user.do or visit All \ Organization \ Users in the portal"/>
            <Param Name="ClientId" Label="Client ID" Required="True" />
            <Param Name="ClientSecret" Label="Client Secret" Required="True" Secret="True"/>
            <Param Name="ApiVersion" Required="True" Value="v2" Options="Default=;v2=v2;v1=v1" ValueTemplate="{$value$}/"/>

            <!--below not exposed as root level property in HTTP Connection so use as placeholder-->
            <Param Name="RetryMode" Value="RetryWhenStatusCodeMatch" Options="None;RetryAny;RetryWhenStatusCodeMatch;" Hidden="True" />
            <Param Name="RetryStatusCodeList" Value="429|503" Hidden="True" />
            <Param Name="RetryCountMax" Value="5" Hidden="True" />
            <Param Name="RetryMultiplyWaitTime" Value="True" Hidden="True" />
          </Params>
        </Auth>
  </Auths>


  <Template>
      <EndPoint Name="TmpPagination">  
          <Params>
			  <Param Name="PagingRowCount" Type="Query" Key="sysparm_limit" Hidden="True" Required="True" Value="10000" />
              <Param Name="PagingMode" Type="Property" Value="ByResponseHeaderRfc5988" />
          </Params>        
      </EndPoint>
 
      <EndPoint Name="TmpPaginationOffset">  
          <Params>
			  <Param Name="PagingRowCount" Type="Query" Key="sysparm_limit" Hidden="True" Required="True" Value="10000" />
			  <Param Name="PagingOffset" Type="Query" Key="sysparm_offset" Hidden="True" Required="True" Value="0" />
              <Param Name="PagingMode" Type="Property" Value="ByUrlParameter" />
              <Param Name="PagingByUrlAttributeName" Type="Property" Value="sysparm_offset" />
			  <Param Name="PagingIncrementBy" Type="Property" Value="10000" Desc="This must match with PagingRowCount Value" />
              <Param Name="PagingByUrlEndStrategy" Type="Property" Required="True" Value="DetectBasedOnResponseSize" />              
			  <Param Name="PagingByUrlCheckResponseMaxBytes" Type="Property" Required="True" Value="20" Desc="If Last response is less than 20 bytes stop. Last response is {result:[]}"/>              
			  <Param Name="PagingByUrlCurrentPage" Type="Property" Value="0" />
          </Params>        
      </EndPoint>	  

      <EndPoint Name="TmpTableOutputColumns">
          <OutputColumns>
            <Column Name="sys_id" DataType="DT_WSTR" Length="500" />
            <Column Name="name" DataType="DT_WSTR" Length="500" />
            <Column Name="label" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_name" DataType="DT_WSTR" Length="500" />
            <Column Name="create_access" DataType="DT_WSTR" Length="50" />
            <Column Name="alter_access" DataType="DT_WSTR" Length="50" />
            <Column Name="access" DataType="DT_WSTR" Length="500" />
            <Column Name="live_feed_enabled" DataType="DT_WSTR" Length="50" />
            <Column Name="sys_updated_on" DataType="DT_DBTIMESTAMP" />
            <Column Name="sys_class_name" DataType="DT_WSTR" Length="500" />
            <Column Name="is_extendable" DataType="DT_WSTR" Length="50" />        
            <Column Name="user_role" DataType="DT_WSTR" Length="500" />
            <Column Name="create_access_controls" DataType="DT_WSTR" Length="50" />
            <Column Name="delete_access" DataType="DT_WSTR" Length="50" />
            <Column Name="sys_updated_by" DataType="DT_WSTR" Length="100" />
            <Column Name="sys_class_path" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_created_on" DataType="DT_DBTIMESTAMP" />
            <Column Name="caller_access" DataType="DT_WSTR" Length="500" />
            <Column Name="client_scripts_access" DataType="DT_WSTR" Length="50" />
            <Column Name="extension_model" DataType="DT_WSTR" Length="500" />
            <Column Name="actions_access" DataType="DT_WSTR" Length="50" />        
            <Column Name="sys_scope.link" Label="sys_scope_link" DataType="DT_WSTR" Length="1000" />
            <Column Name="sys_scope.value" Label="sys_scope_value" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_created_by" DataType="DT_WSTR" Length="100" />
            <Column Name="sys_class_code" DataType="DT_WSTR" Length="500" />
            <Column Name="read_access" DataType="DT_WSTR" Length="50" />
            <Column Name="super_class" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_mod_count" DataType="DT_WSTR" Length="50" />
            <Column Name="ws_access" DataType="DT_WSTR" Length="50" />        
            <Column Name="update_access" DataType="DT_WSTR" Length="50" />
            <Column Name="sys_package.link" Label="sys_package_link"  DataType="DT_WSTR" Length="1000" />
            <Column Name="sys_package.value" Label="sys_package_value" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_update_name" DataType="DT_WSTR" Length="500" />
            <Column Name="scriptable_table" DataType="DT_WSTR" Length="50" />
            <Column Name="configuration_access" DataType="DT_WSTR" Length="50" />        
            <Column Name="number_ref" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_policy" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_scope" DataType="DT_WSTR" Length="500" />
            <Column Name="sys_package" DataType="DT_WSTR" Length="500" />
            <Column Name="super_class.link" Label="super_class_link" DataType="DT_WSTR" Length="1000" />
            <Column Name="super_class.value" Label="super_class_value" DataType="DT_WSTR" Length="500" />
            <Column Name="number_ref.link" Label="number_ref_link" DataType="DT_WSTR" Length="1000" />
            <Column Name="number_ref.value" Label="number_ref_value" DataType="DT_WSTR" Length="500" />
            <Column Name="user_role.link" Label="user_role_link" DataType="DT_WSTR" Length="1000" />
            <Column Name="user_role.value" Label="user_role_value" DataType="DT_WSTR" Length="500" />
          </OutputColumns>  
      </EndPoint>

	  <EndPoint Name="TmpDynamicTableInputColumns">
		  <InputColumns>
			  <Column Name="[$parent.Pivot_Name$]" 
					  DataType="DT_WSTR" 
					  Length="2000"
					  Expand="True"
					  DataEndPoint="get_table_columns"
					  DataEndPointParameters="TableName=[$TableName$];"
					  ColumnInfoMap="DataType=Pivot_Value_internal_type"                  
					  DataTypeMap="DT_BOOL=boolean;
                                     DT_NUMERIC=currency,price,float,decimal,percent_complete;
                                     DT_STR=currency2,domain_id,document_id,reference,audio,video,user_image,phone_number_e164,file_attachment,GUID;
                                     DT_DBTIMESTAMP=glide_date_time,calendar_date_time,due_date,glide_duration,insert_timestamp,glide_utc_time,glide_time;
                                     DT_DBDATE=glide_date;
                                     DT_I4=integer;
                                     DT_I8=longint"
					  KeyIf="sys_id"
			  />                  
		  </InputColumns>	  
	  </EndPoint>
	  
      <EndPoint Name="TmpDynamicTableOutputColumns">
          <OutputColumns>
		    <Column Name="sys_id" DataType="DT_WSTR" Length="64" />
            <Column 
					  Name="&lt;&lt;[$parent.Pivot_Value_internal_type$]|~|domain_id|document_id|reference|currency2|~|[$parent.Pivot_Name$].value|~|[$parent.Pivot_Name$],FUN_IF_REGEX_MATCH&gt;&gt;"	
					  Label="[$parent.Pivot_Name$]" 
                      DataType="DT_WSTR" 
                      Length="2000"
                      Expand="True"
                      DataEndPoint="get_table_columns"
                      DataEndPointParameters="TableName=[$TableName$];"
                      ColumnInfoMap="DataType=Pivot_Value_internal_type"                  
                      DataTypeMap="DT_BOOL=boolean;
                                   DT_NUMERIC=currency,price,float,decimal,percent_complete;
                                   DT_STR=currency2,domain_id,document_id,reference,audio,video,user_image,phone_number_e164,file_attachment,GUID;
                                   DT_DBTIMESTAMP=glide_date_time,calendar_date_time,due_date,glide_duration,insert_timestamp,glide_utc_time,glide_time;
                                   DT_DBDATE=glide_date;
                                   DT_I4=integer;
                                   DT_I8=longint" 
                      KeyIf="sys_id"
              />                
          </OutputColumns>
      </EndPoint>
  </Template>

  <EndPoints>
  


    <!-- GET TABLES **********************************************************-->
    <EndPoint Name="get_tables_admin"
              Template="TmpTableOutputColumns, TmpPagination"
              Label="Get List of Tables - Admin (Use sys_db_object)"
              Url="[$ApiVersion$]table/sys_db_object"
              Method="GET"
              Filter="$.result"
              Desc="Get a list of tables by quering sys_db_object. To read data from this object make sure user has read permission to this table."
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html"
              CachedTtl="120"
              >    
      <Params>
          <Param Name="SysId" ReadAs="sys_id" Key="sys_id" IsKey="True" Type="Query" />
          <Param Name="Query" Key="sysparm_query" Type="Query" Value="ORDERBYname" />
          <Param Name="Fields" Key="sysparm_fields" Type="Query" />
      </Params>
    </EndPoint> 

	

    <!-- GET USER TABLES  **********************************************************-->
    <EndPoint Name="get_user_tables_admin"
              Template="TmpTableOutputColumns, TmpPagination"
              Label="Get List of User Tables - Admin (Use sys_db_object)"
              Url="[$ApiVersion$]table/sys_db_object?sysparm_query=sys_created_by!=system"
              Method="GET"
              Filter="$.result"
			        Desc="Get a list of tables not created by 'system' user"
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html"
              CachedTtl="120"
              >          
      <Params>
          <Param Name="SysId" ReadAs="sys_id" Key="sys_id" IsKey="True" Type="Query" />
      </Params>              
    </EndPoint>

    <!-- GET SYSTEM TABLES  **********************************************************-->
    <EndPoint Name="get_system_tables_admin"
              Template="TmpTableOutputColumns, TmpPagination"
              Label="Get List of System Tables - Admin (Use sys_db_object)"
              Url="[$ApiVersion$]table/sys_db_object?sysparm_query=sys_created_by=system"
              Method="GET"
              Filter="$.result"
			  Desc="Get a list of tables created by 'system' user"
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html"
              CachedTtl="120"
              >          
      <Params>
          <Param Name="SysId" ReadAs="sys_id" Key="sys_id" IsKey="True" Type="Query" />
      </Params>              
    </EndPoint>    

    <!-- GET METADATA  **********************************************************-->
    <EndPoint Name="get_table_columns_admin"
              Template="TmpPaginationOffset"
              Label="Get Table Columns - Admin (Use sys_dictionary)"              
              Url="[$ApiVersion$]table/sys_dictionary"
              Method="GET"
			        Desc="Get a list of columns by quering sys_dictionary. To read data from this table make sure user has read permission to sys_dictionary table."
              HelpLink="https://docs.servicenow.com/bundle/utah-application-development/page/administer/data-dictionary-tables/concept/c_SystemDictionary.html"
              DotAsPath="True"
              UseRawCache="True"
              CachedTtl="120"              
              >          
      <Params>
          <Param Name="TableName" Key="name" ReadAs="name"  Required="True" IsKey="True" Type="Query" />
          <Param Name="Filter" Required="True" Type="Property" Value="$.result" />
      </Params>              
      <OutputColumns>
		<Column Name="sys_id" DataType="DT_WSTR" Length="500" />
        <Column Name="name" DataType="DT_WSTR" Length="50" />
        <Column Name="element" DataType="DT_WSTR" Length="100" />
        <Column Name="internal_type.value" Label="internal_type"  DataType="DT_WSTR" Length="100" />
        <Column Name="max_length" DataType="DT_WSTR" Length="50" />
        <Column Name="column_label" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_name" DataType="DT_WSTR" Length="100" />
        <Column Name="comments" DataType="DT_WSTR" Length="100" />        
        <Column Name="calculation" DataType="DT_WSTR" Length="500" />
        <Column Name="dynamic_ref_qual" DataType="DT_WSTR" Length="100" />
        <Column Name="choice_field" DataType="DT_WSTR" Length="100" />
        <Column Name="function_field" DataType="DT_WSTR" Length="50" />
        <Column Name="sys_updated_on" DataType="DT_WSTR" Length="100" />
        <Column Name="spell_check" DataType="DT_WSTR" Length="50" />
        <Column Name="reference_cascade_rule" DataType="DT_WSTR" Length="100" />
        <Column Name="reference" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_updated_by" DataType="DT_WSTR" Length="50" />
        <Column Name="read_only" DataType="DT_WSTR" Length="50" />
        <Column Name="sys_created_on" DataType="DT_WSTR" Length="100" />
        <Column Name="array_denormalized" DataType="DT_WSTR" Length="50" />
        <Column Name="element_reference" DataType="DT_WSTR" Length="50" />
        <Column Name="reference_key" DataType="DT_WSTR" Length="100" />
        <Column Name="reference_qual_condition" DataType="DT_WSTR" Length="100" />
        <Column Name="xml_view" DataType="DT_WSTR" Length="50" />
        <Column Name="dependent" DataType="DT_WSTR" Length="100" />
        <Column Name="internal_type_link" DataType="DT_WSTR" Length="500" />        
        <Column Name="sys_created_by" DataType="DT_WSTR" Length="50" />        
        <Column Name="use_dependent_field" DataType="DT_WSTR" Length="50" />
        <Column Name="delete_roles" DataType="DT_WSTR" Length="100" />
        <Column Name="virtual_type" DataType="DT_WSTR" Length="100" />
        <Column Name="active" DataType="DT_WSTR" Length="50" />
        <Column Name="choice_table" DataType="DT_WSTR" Length="100" />
        <Column Name="foreign_database" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_update_name" DataType="DT_WSTR" Length="500" />
        <Column Name="unique" DataType="DT_WSTR" Length="50" />        
        <Column Name="dependent_on_field" DataType="DT_WSTR" Length="100" />
        <Column Name="dynamic_creation" DataType="DT_WSTR" Length="50" />
        <Column Name="primary" DataType="DT_WSTR" Length="50" />
        <Column Name="sys_policy" DataType="DT_WSTR" Length="100" />
        <Column Name="next_element" DataType="DT_WSTR" Length="100" />
        <Column Name="virtual" DataType="DT_WSTR" Length="50" />
        <Column Name="widget" DataType="DT_WSTR" Length="100" />
        <Column Name="use_dynamic_default" DataType="DT_WSTR" Length="50" />
        <Column Name="sizeclass" DataType="DT_WSTR" Length="100" />
        <Column Name="mandatory" DataType="DT_WSTR" Length="50" />
        <Column Name="sys_class_name" DataType="DT_WSTR" Length="100" />
        <Column Name="dynamic_default_value" DataType="DT_WSTR" Length="100" />
        
        <Column Name="write_roles" DataType="DT_WSTR" Length="100" />
        <Column Name="array" DataType="DT_WSTR" Length="50" />
        <Column Name="audit" DataType="DT_WSTR" Length="50" />
        <Column Name="read_roles" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_scope_link" DataType="DT_WSTR" Length="500" />
        <Column Name="sys_scope_value" DataType="DT_WSTR" Length="50" />
        <Column Name="create_roles" DataType="DT_WSTR" Length="100" />
        <Column Name="dynamic_creation_script" DataType="DT_WSTR" Length="100" />
        <Column Name="defaultsort" DataType="DT_WSTR" Length="100" />
        <Column Name="use_reference_qualifier" DataType="DT_WSTR" Length="50" />
        <Column Name="display" DataType="DT_WSTR" Length="50" />
        <Column Name="reference_floats" DataType="DT_WSTR" Length="50" />
        <Column Name="sys_mod_count" DataType="DT_WSTR" Length="50" />
        <Column Name="default_value" DataType="DT_WSTR" Length="100" />
        <Column Name="staged" DataType="DT_WSTR" Length="50" />
        <Column Name="reference_type" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_package_link" DataType="DT_WSTR" Length="500" />
        <Column Name="sys_package_value" DataType="DT_WSTR" Length="50" />
        <Column Name="formula" DataType="DT_WSTR" Length="100" />
        <Column Name="attributes" DataType="DT_WSTR" Length="100" />
        <Column Name="choice" DataType="DT_WSTR" Length="100" />
        <Column Name="reference_qual" DataType="DT_WSTR" Length="100" />
        <Column Name="table_reference" DataType="DT_WSTR" Length="50" />
        <Column Name="text_index" DataType="DT_WSTR" Length="50" />
        <Column Name="function_definition" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_scope" DataType="DT_WSTR" Length="100" />
        <Column Name="sys_package" DataType="DT_WSTR" Length="100" />
      </OutputColumns>      
    </EndPoint>

    <!-- GET TABLES **********************************************************-->
    <EndPoint Name="get_tables"
              Label="Get List of Tables"
              Url="/doc/table/schema"
              Method="GET"
              Filter="$.result"
			        Desc="Get a list of tables."
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html"
              CachedTtl="120"
              >    
	  <OutputColumns>
		<Column Name="value" Label="name" DataType="DT_WSTR" Length="500" />
		<Column Name="label" DataType="DT_WSTR" Length="500" />
	  </OutputColumns>
    </EndPoint> 
	
<!-- GET METADATA  **********************************************************-->
    <EndPoint Name="get_table_columns"
              Label="Get Table Columns"              
              Url="/ui/meta/[$TableName$]"
              Method="GET"
			        Desc="Get a list of columns of a table"
              HelpLink="https://docs.servicenow.com/bundle/utah-application-development/page/administer/data-dictionary-tables/concept/c_SystemDictionary.html"
              CachedTtl="120"              
              >          
      <Params>
        <Param Name="TableName" Required="True" Desc="Table name" OptionsEndPoint="get_tables" OptionsEndPointValueColumn="name" />
        <Param Name="Filter" Required="True" Type="Property" Value="$.result.columns" />
        <Param Name="EnablePivot" Type="Property" Value="True" Hidden="True"/>
        <Param Name="ElementScopeSeparator" Type="Property" Value="_" Hidden="True"/>
      </Params>       

      <OutputColumns>
	    <Column Name="Pivot_Value_name" Label="name" DataType="DT_WSTR" Length="128" />
        <Column Name="Pivot_Name" Label="element" DataType="DT_WSTR" Length="128" />
        <Column Name="Pivot_Value_label" Label="label" DataType="DT_WSTR" Length="96" />
        <Column Name="Pivot_Value_internal_type" Label="internal_type" DataType="DT_WSTR" Length="128" />
        <Column Name="Pivot_Value_max_length" Label="max_length" DataType="DT_I8" />
        <Column Name="Pivot_Value_column_type" Label="column_type" DataType="DT_WSTR" Length="128" />        
        <Column Name="Pivot_Value_type" Label="type" DataType="DT_WSTR" Length="60" />		
        <Column Name="Pivot_Value_filterable" Label="filterable" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_reference_display_field" Label="reference_display_field" DataType="DT_WSTR" Length="60" />
        <Column Name="Pivot_Value_reference_attributes_display_field" Label="reference_attributes_display_field" DataType="DT_WSTR" Length="60" />
        <Column Name="Pivot_Value_reference_attributes_ref_ac_columns" Label="reference_attributes_ref_ac_columns" DataType="DT_WSTR" Length="108" />
        <Column Name="Pivot_Value_reference_attributes_ref_ac_columns_search" Label="reference_attributes_ref_ac_columns_search" DataType="DT_WSTR" Length="80" />
        <Column Name="Pivot_Value_reference_attributes_ref_ac_display_value" Label="reference_attributes_ref_ac_display_value" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_reference_attributes_ref_auto_completer" Label="reference_attributes_ref_auto_completer" DataType="DT_WSTR" Length="80" />
        <Column Name="Pivot_Value_canmatch" Label="canmatch" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_cangroup" Label="cangroup" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_max_unit" Label="max_unit" DataType="DT_WSTR" Length="80" />
        <Column Name="Pivot_Value_mandatory" Label="mandatory" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_reference" Label="reference" DataType="DT_WSTR" Length="100" />
        <Column Name="Pivot_Value_default" Label="default" DataType="DT_WSTR" Length="255" />
        <Column Name="Pivot_Value_base_type" Label="base_type" DataType="DT_WSTR" Length="32" />
        <Column Name="Pivot_Value_read_only" Label="read_only" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_hint" Label="hint" DataType="DT_WSTR" Length="388" />
        <Column Name="Pivot_Value_attributes" Label="attributes" DataType="DT_WSTR" Length="4000" />
        <Column Name="Pivot_Value_cansort" Label="cansort" DataType="DT_BOOL" />        
        <Column Name="Pivot_Value_multitext" Label="multitext" DataType="DT_BOOL" />
        <Column Name="Pivot_Value_choice_type" Label="choice_type" DataType="DT_I8" />
        <Column Name="Pivot_Value_choices" Label="choices" DataType="DT_NTEXT" /> 
      </OutputColumns>
	  
    </EndPoint>

    <!-- GET TABLE DATA  **********************************************************-->
    <EndPoint Name="get_table_rows"
              Template="TmpDynamicTableOutputColumns, TmpPagination"
              Label="Get Table Rows"
              Url="[$ApiVersion$]table/[$TableName$][$SysId$]"
              Method="GET"
              Filter="$.result"
			        Desc="Get table rows"              
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html">          
      <Params>
		  <Param Name="TableName" Required="True" Desc="Table name" OptionsEndPoint="get_tables" OptionsEndPointValueColumn="name" />
          <Param Name="SysId" ReadAs="sys_id" IsKey="True" ValueTemplate="/{$value$}" Desc="Row 'sys_id'"  />
          <Param Name="Fields" Type="Query" Key="sysparm_fields" MultiSelect="True"  OptionsEndPoint="get_table_columns" OptionsEndPointValueColumn="name" OptionsEndPointParameters="TableName=[$TableName$]" Desc="Comma-separated field names you want to return in the response. E.g. sys_id,name,label,sys_name,sys_updated_on. Using this setting reduces the response size and speed up the processing." />         
          <Param Name="DateFormatString" Type="Property" Value="yyyy-MM-dd HH:mm:ss" />
          <Param Name="ContineOn404Error" Hidden="True" Type="Property" Value="True" />
          <Param Name="Query" Type="Query" Key="sysparm_query" Options="Equal Example=numberISINC0000060;AND Example=category=software^category=hardware;OR Example=category=software^ORcategory=hardware;IN Example=categoryINsoftware,hardware;STARTSWITH Example=categorySTARTSWITHsoftware;NOT EQUAL Example=category!=software;" Desc="Server side search condition" HelpLink="https://docs.servicenow.com/bundle/utah-platform-user-interface/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.html"/>         
      </Params>
      <OutputColumns>
          <Column Name="sys_id" DataType="DT_STR" Length="64" />
      </OutputColumns>
    </EndPoint>

    <!-- INSERT TABLE ROW  **********************************************************-->
    <EndPoint Name="insert_table_row"
              Template="TmpDynamicTableOutputColumns,TmpDynamicTableInputColumns"
              Label="Delete a Table Row"
              Url="[$ApiVersion$]table/[$TableName$]"
              Method="POST"
              ContentType="application/json" 
              JsonRowFormat="Multicontent"
              Filter="$.result"
			  Desc="Insert a row into the table."
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html"
              DotAsPath="True">
      <Params>
          <Param Name="TableName" Required="True" Desc="Table name" OptionsEndPoint="get_tables" OptionsEndPointValueColumn="name" />
      </Params>
      <Body>
          <![CDATA[{$rows$}]]>
      </Body>          
    </EndPoint>    

    <!-- UPDATE TABLE ROW  **********************************************************-->
    <EndPoint Name="update_table_row"
              Template="TmpDynamicTableOutputColumns,TmpDynamicTableInputColumns"
              Label="Update a Table Row"
              Url="[$ApiVersion$]table/[$TableName$]/[$SysId$]"
              Method="PUT"
              ContentType="application/json" 
              JsonRowFormat="Multicontent"
              Filter="$.result"
			        Desc="Insert a row into the table."
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html"
              DotAsPath="True">
      <Params>
          <Param Name="TableName" Required="True" Desc="Table name" OptionsEndPoint="get_tables" OptionsEndPointValueColumn="name" />
          <Param Name="SysId" ReadAs="sys_id" IsKey="True" Required="True" Desc="Row 'sys_id'" />
          <Param Name="ContineOn404Error" Hidden="True" Type="Property" Value="True" />
      </Params>
      <InputColumns>
        <Column Name="SysId" Label="sys_id" ReadAs="sys_id" DataType="DT_WSTR" Length="500" MapToParam="True" Key="True" ExcludeFromRowMap="True" />      
      </InputColumns>
      <Body>
          <![CDATA[{$rows$}]]>
      </Body>          
    </EndPoint>        

    <!-- DELETE TABLE ROW  **********************************************************-->
    <EndPoint Name="delete_table_row"
              Label="Delete table row"
              Url="[$ApiVersion$]table/[$TableName$]/[$SysId$]"
              Method="DELETE"
              OutputHeaders="StatusCode"
              Desc="Delete the specified row in the table by row 'sys_id'."
              HelpLink="https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html">          
      <Params>
          <Param Name="TableName" Required="True" Desc="Table name" OptionsEndPoint="get_tables" OptionsEndPointValueColumn="name" />
          <Param Name="SysId" ReadAs="sys_id" Required="True" IsKey="True" Desc="Row 'sys_id'" />
          <Param Name="RawOutputDataRowTemplate" Type="Property" Value="{}" ValueTemplate="{status:'Deleted', sys_id:'[$SysId$]'}" />
          <Param Name="EnableRawOutputModeSingleRow" Type="Property" Value="True" />
          <Param Name="ContineOn404Error" Hidden="True" Type="Property" Value="True" />
      </Params>                  
      <InputColumns>
        <Column Name="SysId" Label="sys_id" ReadAs="sys_id" DataType="DT_WSTR" Length="500" MapToParam="True" Key="True" />      
      </InputColumns>
      <OutputColumns>
        <Column Name="status" DataType="DT_WSTR" Length="64" />
        <Column Name="sys_id" DataType="DT_WSTR" Length="64" />
        <Column Name="ResponseHeaders_StatusCode" Label="http_status" DataType="DT_I4" />
      </OutputColumns>         
    </EndPoint>

  </EndPoints>
  <Tables>
    <Table Name="Tables"
           SelectEndPoint="get_tables"
           LookupEndPoint="get_tables"
    />  
     
    <Table Name="[$parent.value$]"
           Expand="True"
		   Order="-1"
           SelectEndPoint="get_table_rows"
           LookupEndPoint="get_table_rows"
           InsertEndPoint="insert_table_row"
           UpdateEndPoint="update_table_row"
           DeleteEndPoint="delete_table_row"
           DataEndPoint="get_tables"
           DataEndPointParameters="Fields=name">
        <Params>
            <Param Name="TableName" Value="[$parent.value$]" Hidden="True"/>
        </Params>
    </Table>    
  </Tables>


  <Examples>
        <Example Group="ODBC" Label="Get a list of incidents" Default="True">
            <Code>
                <![CDATA[SELECT * FROM incident 

--Using Primary Key				
--SELECT * FROM any_table_here WHERE sys_id='109562a3c611227500a7b7ff98cc0dc7' --Primary Key in WHERE clause

--Using Filter Expression
--SELECT * FROM incident WITH(Query='number=INC0000001') --Equal condition
--SELECT * FROM incident WITH(Query='number!=INC0000001') --Not equal condition
--SELECT * FROM incident WITH(Query='numberININC0000001,INC0000002,INC0000003') --IN condition
--SELECT * FROM incident WITH(Query='number=INC0000001^state=7') --AND condition
--SELECT * FROM incident WITH(Query='number=INC0000001^ORnumber=INC0000002') --OR condition
--SELECT * FROM incident WITH(Query='numberLIKE0001') --LIKE condition
--SELECT * FROM incident WITH(Query='numberSTARTSWITHINC00') --StartWith condition
--SELECT * FROM incident WITH(Query='numberENDSWITH0001') --StartWith condition
--SELECT * FROM incident WITH(Query='number=INC0000001^state=7^NQORnumber=INC0000002') --AND / OR MIXED using NQ (NewQuery Operator)  -- (number=INC0000001 and state=7) OR (number=INC0000002)

--more information about filter here https://docs.servicenow.com/bundle/utah-platform-user-interface/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.html


-- To read all available tables execute this query:
-- SELECT * FROM Tables

-- Other common tables:
-----------------------
-- SELECT * FROM sys_db_object
-- SELECT * FROM sys_dictionary
-- SELECT * FROM sys_user
-- SELECT * FROM sys_user_has_role
-- SELECT * FROM sys_user_grmember
-- SELECT * FROM task
-- SELECT * FROM task_sla
-- SELECT * FROM incident
-- SELECT * FROM incident_sla
-- SELECT * FROM change_request
-- SELECT * FROM cmdb_ci_computer
-- SELECT * FROM cmdb_ci_outage
-- SELECT * FROM cmdb_ci
-- SELECT * FROM sn_customerservice_case
-- SELECT * FROM kb_knowledge
-- SELECT * FROM kb_use
-- SELECT * FROM sc_req_item
-- SELECT * FROM sc_request
-- SELECT * FROM sc_task

]]>
            </Code>
        </Example>  
        <Example Group="ODBC" Label="Get an incident by sys_id">
            <Code>
                <![CDATA[SELECT * FROM incident
WHERE sys_id = 'SYS_ID_GOES_HERE']]>
            </Code>
        </Example>
    <Example Group="ODBC" Label="Get only selected columns and speed up the query" Desc="By default all column values are returned in the result set. However, you can instruct the ServiceNow API to send only specific columns you care about by setting 'Fields' parameter in the WITH clause. This will speed up the response significantly.">
      <Code>
        <![CDATA[SELECT number,name FROM incident WITH (Fields='number,name') --Setting Fields parameter will speed up the query]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="Get the display value of a reference field" Desc="This example shows how to get related record(s) from the reference field. Basically, you need to know referenced table name for that referenced field. Then you can query by sys_id (Primary Key)">
      <Code>
       <![CDATA[--STEP#1 returns incident number and related company (sys_id)
SELECT number,company FROM incident

--STEP#2 find related table for company field
select name,reference from get_table_columns order by 1 WITH(TableName='incident')

--STEP#3 query related table with sys_id returned in step#1
select sys_id, name  from core_company where sys_id='31bea3d53790200044e0bfc8bcbe5dec'        
        
        ]]>
      </Code>
    </Example>
    <Example Group="ODBC" Label="Query table using serverside filter expression" Desc="This example shows how to filter data from a table using server side filter expression. Its always faster to do this way rather than using in WHERE clause (Client Side Filter)">
      <Code>
        <![CDATA[SELECT * FROM incident WITH(Query='number=INC0000001') --Equal condition

--syntax (single condition)
--sysparm_query=<col_name><operator><value>

--syntax (multiple conditions)
--sysparm_query=<col_name><operator><value>[<operator><col_name><operator><value>]

--more info check below links
--  https://docs.servicenow.com/bundle/rome-application-development/page/integrate/inbound-rest/concept/c_TableAPI.html#title_table-GET
--  https://docs.servicenow.com/bundle/utah-platform-user-interface/page/use/common-ui-elements/reference/r_OpAvailableFiltersQueries.html
  
--More examples				
--SELECT * FROM any_table_here WHERE sys_id='109562a3c611227500a7b7ff98cc0dc7' --Primary Key in WHERE clause
--SELECT * FROM incident WITH(Query='number=INC0000001') --Equal condition
--SELECT * FROM incident WITH(Query='number!=INC0000001') --Not equal condition
--SELECT * FROM incident WITH(Query='numberININC0000001,INC0000002,INC0000003') --IN condition
--SELECT * FROM incident WITH(Query='number=INC0000001^state=7') --AND condition
--SELECT * FROM incident WITH(Query='number=INC0000001^ORnumber=INC0000002') --OR condition
--SELECT * FROM incident WITH(Query='numberLIKE0001') --LIKE condition
--SELECT * FROM incident WITH(Query='numberSTARTSWITHINC00') --StartWith condition
--SELECT * FROM incident WITH(Query='numberENDSWITH0001') --StartWith condition
--SELECT * FROM incident WITH(Query='number=INC0000001^state=7^NQORnumber=INC0000002') --AND / OR MIXED using NQ (NewQuery Operator)  -- (number=INC0000001 and state=7) OR (number=INC0000002)

        ]]>
      </Code>
    </Example>
    
    <Example Group="ODBC" Label="Create an incident">
            <Code>
                <![CDATA[INSERT INTO incident(incident_state, severity, category, cause)
VALUES (3, 1, 'software', 'Missing a software feature.')]]>
            </Code>
        </Example>          
        <Example Group="ODBC" Label="Update an incident">
            <Code>
                <![CDATA[UPDATE incident
SET cause = 'A bug in the software'
   ,severity = 3
   ,incident_state = 2
WHERE sys_id = 'SYS_ID_GOES_HERE']]>
            </Code>
        </Example>             
        <Example Group="ODBC" Label="Delete an incident">
            <Code>
                <![CDATA[DELETE incident
WHERE sys_id = 'SYS_ID_GOES_HERE']]>
            </Code>
        </Example>             

        <Example Group="ODBC" Label="Get a list of tables">
            <Code>
                <![CDATA[SELECT * FROM Tables]]>
            </Code>
        </Example>
        <Example Group="ODBC" Label="Get a list of system tables">
            <Code>
                <![CDATA[SELECT * FROM SystemTables]]>
            </Code>
        </Example>
        <Example Group="ODBC" Label="Get a list of user tables">
            <Code>
                <![CDATA[SELECT * FROM UserTables]]>
            </Code>
        </Example>
        <Example Group="ODBC" Label="Get columns of a specific table">
            <Code>
                <![CDATA[SELECT * FROM get_table_columns
where name = 'TableNameGoesHere']]>
            </Code>            
        </Example> 
        <Example Group="ODBC" Label="Get all columns of all tables (can be slow)">
            <Code>
                <![CDATA[SELECT * FROM get_table_columns_admin --requires readonly permissions on sys_dictionary and sys_db_object tables]]>
            </Code>            
        </Example>
        <Example Group="ODBC" Label="Use 'generic_request' endpoint to get Accounts" 
Desc="Use 'generic_request' endpoint to get Accounts (or access another ServiceNow API). Use ServiceNow API Reference and Query Builder to build custom requests.">
            <Code><![CDATA[SELECT *
FROM generic_request
WITH(
	Url='/v2/table/incident?sysparm_limit=10000&sysparm_query=numberLIKE0001^ORDERBYsys_created_on',
	Filter='$.result',
	Meta='sys_id:string;number:string;business_stc:int', --//comment this to see all columns (SLOW)
	PagingMode='ByResponseHeaderRfc5988',
  --Method='GET',
  --Body='{your POST body}'  
)

-- Request URL should be partial like this one:
-- /v2/some_table?some-parameter=somevalue1&some-parameter=somevalue2
]]>
            </Code>
        </Example>
  </Examples>  
</ApiConfig>